:root{
  /* Spring-tinted base: deep forest with warmth, not flat black */
  --bg:#08100a;
  --bg2:#0f1a12;
  --spring-sun:rgba(255, 244, 210, 0.14);
  --spring-sky:rgba(130, 200, 215, 0.09);
  --spring-mint:rgba(120, 210, 150, 0.12);
  --spring-bloom:rgba(255, 190, 205, 0.05);
  --surface:rgba(255,255,255,.06);
  --surface2:rgba(255,255,255,.1);
  --surface3:#131913;
  --text:#f6faf4;
  --muted:#c4d4c8;
  --line:rgba(255,255,255,.14);
  --brand:#6bc24a;
  --brand2:#4a9e38;
  --brandGlow:rgba(120, 200, 90, 0.4);
  --shadow:0 20px 60px rgba(0,0,0,.5);
  --radius:16px;
  --radius2:24px;
  --radius3:30px;
  --container:1180px;
  --font:"Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    /* Soft morning sun (top) */
    radial-gradient(1200px 520px at 50% -8%, var(--spring-sun), transparent 55%),
    /* Fresh sky (upper right) */
    radial-gradient(700px 400px at 95% 8%, var(--spring-sky), transparent 65%),
    /* New growth (left) */
    radial-gradient(900px 560px at 8% 25%, var(--spring-mint), transparent 62%),
    /* Subtle blossom warmth (lower) */
    radial-gradient(600px 380px at 75% 85%, var(--spring-bloom), transparent 70%),
    radial-gradient(800px 500px at 70% 70%, rgba(255,255,255,.05), transparent 70%),
    linear-gradient(185deg, #122018 0%, var(--bg2) 38%, var(--bg) 100%),
    var(--bg);
  color:var(--text);
  font-family:var(--font);
  line-height:1.5;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:.1;
  background-image:
    radial-gradient(rgba(255,255,255,.2) 0.4px, transparent 0.5px),
    radial-gradient(rgba(120,200,140,.08) 0.35px, transparent 0.45px);
  background-size: 3px 3px, 5px 5px;
  background-position: 0 0, 2px 2px;
}

a{color:inherit}
.container{max-width:var(--container); margin:0 auto; padding:0 20px}

.skipLink{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skipLink:focus{
  left:16px; top:16px; width:auto; height:auto;
  padding:10px 12px; background:#111; border:1px solid var(--line);
  border-radius:12px; z-index:9999;
}

.siteHeader{
  position:sticky; top:0; z-index:50;
  border-bottom:1px solid rgba(120,185,130,.18);
  backdrop-filter: blur(12px);
  background: rgba(10,18,12,.82);
}
.siteHeader.isElevated{box-shadow:0 8px 30px rgba(0,0,0,.45)}
.headerInner{
  display:flex; align-items:center; justify-content:space-between;
  padding:17px 0;
}
.brand{display:flex; align-items:center; gap:12px}
.brandMark{
  width:44px; height:44px; border-radius:999px;
  display:grid; place-items:center;
  background: linear-gradient(145deg, rgba(92,176,64,.2), rgba(92,176,64,.03));
  border:1px solid rgba(92,176,64,.40);
  font-weight:800; letter-spacing:.04em;
  overflow:hidden;
}
.brandMark img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.brandName{font-weight:800}
.brandTag{font-size:12px; color:var(--muted)}

.headerNav{display:flex; align-items:center; gap:12px}
.navLink{
  text-decoration:none;
  color:var(--muted);
  padding:10px 10px;
  border-radius:12px;
}
.navLink:hover{background:rgba(255,255,255,.06); color:var(--text)}

.button{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:13px 16px;
  border-radius:14px;
  border:1px solid transparent;
  text-decoration:none;
  font-weight:800;
  line-height:1;
  white-space:nowrap;
  transition: transform .08s ease, background .18s ease, border-color .18s ease;
}
.button:active{transform: translateY(1px)}
.buttonFull{width:100%}

.buttonPrimary{
  background: linear-gradient(180deg, var(--brand), var(--brand2));
  color:#061006;
  border-color: rgba(255,255,255,.14);
  box-shadow: 0 14px 28px rgba(92,176,64,.26);
}
.buttonPrimary:hover{filter:brightness(1.02)}

.buttonGhost{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.14);
}
.buttonGhost:hover{background: rgba(255,255,255,.09)}

.buttonSubtle{
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.10);
  color: var(--muted);
}
.buttonSubtle:hover{background: rgba(255,255,255,.06); color:var(--text)}

.hero{padding:46px 0 28px}
.heroGrid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:24px;
  align-items:stretch;
}
/* Spring Break only: DOM = eyebrow → media → main. Desktop: eyebrow+main left, image right. Mobile: stacked eyebrow → image → headline. */
.heroGrid--split{
  grid-template-rows:auto 1fr;
  align-items:start;
}
.heroGrid--split .heroEyebrow{
  grid-column:1;
  grid-row:1;
  margin:0;
}
.heroGrid--split .heroMain{
  grid-column:1;
  grid-row:2;
  min-width:0;
}
.heroGrid--split > .heroMedia{
  grid-column:2;
  grid-row:1 / -1;
  align-self:stretch;
  min-height:min(520px, 70vh);
}
.eyebrow{
  margin:0 0 10px;
  color:#d8eadc;
  font-weight:700;
  letter-spacing:.01em;
  text-transform:uppercase;
  font-size:12px;
}
.h1{
  margin:0 0 12px;
  font-size:clamp(40px, 6vw, 64px);
  line-height:1.02;
  letter-spacing:-.03em;
  max-width:12ch;
}
.h1Serif{
  font-family:var(--serif);
  font-weight:700;
  font-style:italic;
  font-size:clamp(46px, 6.9vw, 74px);
  line-height:.95;
  letter-spacing:-.01em;
}
.h1Serif .whiteLine{display:block; color:#ffffff}
.h1Serif .greenLine{display:block; color:#7fd85a}
.h2{margin:0; font-size:clamp(24px, 4vw, 36px); letter-spacing:-.02em; line-height:1.1}
.lede{margin:0 0 18px; max-width:58ch; color:var(--muted); font-size:18px}

.ctaRow{display:flex; gap:12px; flex-wrap:wrap}

.trustRow{
  list-style:none; padding:0; margin:16px 0 0;
  display:flex; gap:12px; flex-wrap:wrap;
  color:#dce8df;
}
.trustRow li{
  padding:8px 12px;
  border:1px solid rgba(130,200,150,.22);
  background: rgba(100,180,120,.08);
  border-radius:999px;
  font-size:12px;
  font-weight:700;
}

.heroCard{
  border-radius: var(--radius3);
  padding:22px;
  border:1px solid rgba(130,200,150,.2);
  background:
    radial-gradient(760px 320px at 20% 0%, rgba(120,210,140,.2), transparent 58%),
    radial-gradient(400px 200px at 100% 100%, rgba(255,235,200,.06), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025));
  box-shadow: var(--shadow);
  display:flex; flex-direction:column; gap:12px;
}
.cardBadge{
  align-self:flex-start;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(130,210,150,.45);
  background: rgba(100,180,120,.16);
  color: rgba(248,255,245,.95);
  font-weight:750;
  font-size:12px;
}
.muted{color:var(--muted)}
.cardActions{display:flex; flex-direction:column; gap:10px; margin-top:auto}

.section{padding:52px 0}
.sectionHeader{margin-bottom:18px}
.sectionBandA{
  background:
    radial-gradient(1000px 420px at 12% 8%, rgba(120,210,140,.16), transparent 68%),
    radial-gradient(680px 260px at 88% 14%, rgba(255,235,200,.06), transparent 70%),
    linear-gradient(180deg, rgba(18,32,22,.88), rgba(12,22,16,.78));
  border-top:1px solid rgba(130,200,150,.28);
  border-bottom:1px solid rgba(130,200,150,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), inset 0 -1px 0 rgba(100,160,120,.06);
}
.sectionBandB{
  background:
    radial-gradient(900px 360px at 84% 18%, rgba(130,200,215,.08), transparent 74%),
    radial-gradient(700px 260px at 16% 82%, rgba(100,180,120,.1), transparent 72%),
    linear-gradient(180deg, rgba(12,18,14,.94), rgba(8,14,10,.9));
  border-top:1px solid rgba(120,175,190,.12);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), inset 0 -1px 0 rgba(255,255,255,.02);
}
.sectionBandC{
  background:
    radial-gradient(860px 340px at 52% 0%, rgba(255,248,220,.07), transparent 68%),
    radial-gradient(760px 320px at 12% 95%, rgba(110,195,130,.12), transparent 72%),
    linear-gradient(180deg, rgba(20,28,22,.82), rgba(14,20,16,.76));
  border-top:1px solid rgba(140,200,155,.15);
  border-bottom:1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), inset 0 -1px 0 rgba(255,255,255,.03);
}

.grid3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
}
.infoCard{
  display:block;
  padding:18px;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.11);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  text-decoration:none;
  transition: transform .12s ease, background .18s ease, border-color .18s ease;
}
.infoCard:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
}
.infoCardTitle{font-weight:800; margin-bottom:6px; font-size:20px; line-height:1.25; letter-spacing:-.01em}

.heroMedia{
  position:relative;
  border-radius: var(--radius3);
  overflow:hidden;
  border:1px solid rgba(130,200,150,.25);
  box-shadow: var(--shadow), 0 0 80px rgba(100,180,120,.12);
  min-height:460px;
}
.heroMedia img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.heroMedia::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 38%, rgba(12,28,16,.55) 72%, rgba(8,18,10,.82) 100%);
}
.mediaBadge{
  position:absolute;
  left:16px;
  top:16px;
  z-index:2;
  padding:10px 12px;
  border-radius:999px;
  background:rgba(14,32,18,.78);
  border:1px solid rgba(140,210,150,.35);
  font-size:12px;
  font-weight:700;
  color:#e8f5e8;
}

.statsStrip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:18px;
}
.statCard{
  background:linear-gradient(165deg, rgba(110,200,130,.22), rgba(80,150,95,.08));
  border:1px solid rgba(130,210,150,.4);
  border-radius:16px;
  padding:16px 14px;
}
.statValue{
  display:block;
  font-weight:900;
  font-size:26px;
  line-height:1;
  color:#f8fff4;
}
.statLabel{
  margin-top:6px;
  display:block;
  color:#d8eee0;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:700;
}

.noticeBar{
  margin-top:18px;
  border:1px solid rgba(130,200,150,.45);
  background:linear-gradient(95deg, rgba(110,195,130,.32), rgba(255,240,210,.08), rgba(100,170,120,.12));
  border-radius:14px;
  padding:11px 14px;
  font-weight:700;
  color:#eef8ef;
}

.mediaCard{
  overflow:hidden;
}
.mediaCard img{
  width:100%;
  height:240px;
  object-fit:cover;
  border-radius:12px;
  margin-bottom:12px;
  border:1px solid rgba(255,255,255,.13);
}

.packagesGrid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(3,1fr);
}
.packageCard{
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  overflow:hidden;
}
.packageCard img{
  width:100%;
  height:380px;
  object-fit:cover;
  display:block;
}
.packageBody{padding:16px}
.packageTag{
  display:inline-flex;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  color:#dce3db;
  padding:6px 10px;
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.packagePopular{
  border-color: rgba(130,210,150,.55);
  box-shadow:0 0 0 2px rgba(120,200,140,.22), 0 16px 44px rgba(40,80,50,.25);
}
.packagePopular .packageTag{
  border-color: rgba(140,220,160,.75);
  background:rgba(100,185,120,.24);
  color:#f4fff0;
}

.list{
  margin:10px 0 0;
  padding-left:18px;
  color:#c9d1c8;
}
.list li{margin:5px 0}

.tourThumb{
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.14);
}
.tourThumb img{
  width:100%;
  display:block;
  height:360px;
  object-fit:cover;
}
.twoCol{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}

.testimonialCard{
  position:relative;
  padding-top:28px;
}
.testimonialCard::before{
  content:"\201C";
  position:absolute;
  top:4px;
  left:14px;
  color:var(--brandGlow);
  font-size:42px;
  line-height:1;
  font-family:var(--serif);
}
.testimonialRole{
  margin-top:4px;
  color:#d5dfd1;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
}

.siteFooter{
  border-top:1px solid rgba(120,180,140,.18);
  background: linear-gradient(180deg, rgba(10,22,14,.92), rgba(6,12,8,.88));
  padding:26px 0;
}
.footerInner{display:flex; align-items:flex-start; justify-content:space-between; gap:18px; flex-wrap:wrap}
.footerBrand{display:flex; gap:12px; align-items:center}
.footerLinks{display:flex; flex-wrap:wrap; gap:14px; color:var(--muted)}
.footerLinks a{color:var(--muted); text-decoration:none}
.footerLinks a:hover{color:var(--text); text-decoration:underline}

@media (max-width: 920px){
  .heroGrid{grid-template-columns: 1fr}
  .heroGrid--split{
    grid-template-rows:auto auto auto;
  }
  .heroGrid--split .heroEyebrow{
    grid-column:1;
    grid-row:1;
  }
  .heroGrid--split > .heroMedia{
    grid-column:1;
    grid-row:2;
    min-height:0;
    max-height:min(52vh, 440px);
    aspect-ratio:16 / 10;
    width:100%;
  }
  .heroGrid--split .heroMain{
    grid-column:1;
    grid-row:3;
  }
  /* Pill badge: sit on lower part of dog photo (desktop stays top-left) */
  .heroGrid--split .mediaBadge{
    top:auto;
    bottom:14px;
    left:14px;
  }
  .grid3{grid-template-columns: 1fr}
  .packagesGrid{grid-template-columns:1fr}
  .statsStrip{grid-template-columns:1fr 1fr}
  .twoCol{grid-template-columns:1fr}
  .headerNav .navLink{display:none}

  /* Extra horizontal inset so logo and CTAs don’t hug screen edges */
  .siteHeader .container{
    padding-left: max(24px, env(safe-area-inset-left, 0px));
    padding-right: max(24px, env(safe-area-inset-right, 0px));
  }

  /* Mobile header: brand on row 1, CTAs full-width row 2 */
  .headerInner{
    flex-wrap:wrap;
    align-items:center;
    row-gap:10px;
    column-gap:12px;
    padding:12px 0;
  }
  .brand{
    flex:1 1 auto;
    min-width:0;
    max-width:100%;
  }
  .brandText{min-width:0}
  .brandName{
    font-size:15px;
    line-height:1.2;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .brandTag{font-size:11px}
  .headerNav{
    flex:1 1 100%;
    flex-wrap:nowrap;
    justify-content:stretch;
    gap:8px;
    min-width:0;
  }
  .headerNav .button{
    flex:1 1 0;
    min-width:0;
    padding:11px 10px;
    font-size:13px;
    line-height:1.25;
    white-space:normal;
    text-align:center;
  }
}

@media (max-width: 400px){
  .brandMark{width:38px;height:38px}
  .brandName{font-size:14px}
  .headerNav .button{
    padding:10px 8px;
    font-size:12px;
  }
}

