/* ========================================
   ALL IMPORTS MUST COME FIRST
======================================== */

@import "./design-tokens.css";

/* Atoms */
@import "./components/atoms/button.css";
@import "./components/atoms/tag.css";
@import "./components/atoms/input.css";
@import "./components/atoms/dropdown.css";
@import "./components/atoms/multi-select.css";
@import "./components/atoms/toast.css";

/* Molecules */
@import "./components/molecules/form-success.css";
@import "./components/molecules/horizontal-card.css";
@import "./components/molecules/horizontal-statistics.css";
@import "./components/molecules/hero-carousel.css";
@import "./components/molecules/itinerary.css";
@import "./components/molecules/image-card.css";
@import "./components/molecules/vertical-card.css";
@import "./components/molecules/section-card.css";

/* Organisms */
@import "./components/organisms/cta-section.css";
@import "./components/organisms/customize-modal.css";
@import "./components/organisms/book-modal.css";
@import "./components/organisms/header.css";
@import "./components/organisms/footer.css";

/* Pages */
@import "./pages/index.css";
@import "./pages/our-tours.css";
@import "./pages/our-tours-detail.css";
@import "./pages/our-story.css";
@import "./pages/contact-us.css";
@import "./pages/before-you-travel.css";


/* ========================================
   BASE STYLES
======================================== */

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: var(--font-primary);
  background-color: var(--color-surface);
  color: var(--color-text);
  margin: 0;
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
}

.text-highlight {
  color: var(--color-text-dark-green);
  font-weight: var(--font-semibold);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.page-wrapper {
  width: 100%;
  height: fit-content;
  padding: 0;
  gap: var(--space-section-pad);   /* 40px between sections */
  display: flex;
  flex-direction: column;
}
.container {
  width: 100%;
  height: fit-content;
  gap: var(--space-section-y);
  display: flex;
  flex-direction: column;
  /* No horizontal padding — each section controls its own side padding.
     Full-bleed sections (hero, CTA) are naturally edge-to-edge. */
}
