/* ============================================================
   SUCUNDURI — Amazon Fishing Lodge
   Design system: cinematic expedition / premium
   (adapted from the approved "expedição premium" design)
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,500;1,600&family=Archivo:wght@300;400;500;600;700&display=swap');

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Archivo', system-ui, sans-serif;

  /* palette: Rio Negro */
  --ink:        #0b1311;
  --ink-2:      #101b17;
  --ink-3:      #16241f;
  --paper:      #f3ecdd;
  --paper-2:    #e8dec9;
  --gold:       #c89446;
  --gold-bright:#e2b766;
  --river:      #2f5e54;
  --river-deep: #1a3a34;
  --moss:       #6f8a5e;

  --t-on-dark:  #ece6d7;
  --m-on-dark:  rgba(236,230,215,.62);
  --t-on-light: #1a221e;
  --m-on-light: #585f55;
  --line-dark:  rgba(236,230,215,.14);
  --line-light: rgba(26,34,30,.13);

  --accent:      var(--gold);
  --accent-bright: var(--gold-bright);

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 72px);
  --r-sm: 4px;
  --r-md: 10px;
  --r-lg: 18px;
  --shadow: 0 30px 80px -30px rgba(0,0,0,.55);
  --eyebrow-tr: .32em;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; touch-action:manipulation; }
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--t-on-dark);
  font-size:17px; line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4{ margin:0; font-weight:400; line-height:1.04; font-family:var(--font-display); letter-spacing:-.01em; }
p{ margin:0; }
::selection{ background:var(--accent); color:var(--ink); }

/* skip link (a11y) */
.skip-link{ position:absolute; left:-9999px; top:0; z-index:300; background:var(--accent); color:var(--ink);
  padding:.7em 1.2em; border-radius:0 0 var(--r-sm) 0; font-weight:700; font-size:.85rem; }
.skip-link:focus{ left:0; }
:focus-visible{ outline:2px solid var(--accent-bright); outline-offset:3px; }

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.wrap-wide{ max-width:1560px; margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:clamp(72px,9vw,150px); position:relative; }
.section--tight{ padding-block:clamp(54px,6vw,90px); }

.bg-ink{ background:var(--ink); color:var(--t-on-dark); }
.bg-ink2{ background:var(--ink-2); color:var(--t-on-dark); }
.bg-river{ background:var(--river-deep); color:var(--t-on-dark); }
.bg-paper{ background:var(--paper); color:var(--t-on-light); }

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.eyebrow{
  font-family:var(--font-body);
  font-size:.74rem; font-weight:600;
  letter-spacing:var(--eyebrow-tr); text-transform:uppercase;
  color:var(--accent-bright);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow.on-light{ color:var(--gold); }
.eyebrow::before{ content:""; width:26px; height:1px; background:currentColor; opacity:.7; }
.eyebrow.no-rule::before{ display:none; }

.display-xl{ font-size:clamp(2.8rem,7.4vw,6.4rem); line-height:.98; }
.display-lg{ font-size:clamp(2.3rem,5vw,4.4rem); }
.display-md{ font-size:clamp(1.9rem,3.4vw,3rem); }
.display-sm{ font-size:clamp(1.5rem,2.4vw,2.1rem); }
em.italic{ font-style:italic; }
.text-accent{ color:var(--accent-bright); }
.lead{ font-size:clamp(1.05rem,1.5vw,1.32rem); line-height:1.6; color:var(--m-on-dark); font-weight:400; }
.bg-paper .lead{ color:var(--m-on-light); }
.muted{ color:var(--m-on-dark); }
.bg-paper .muted{ color:var(--m-on-light); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-body); font-weight:600; font-size:.82rem;
  letter-spacing:.14em; text-transform:uppercase;
  padding:1.05em 1.9em; border:1px solid transparent;
  border-radius:var(--r-sm); transition:.35s cubic-bezier(.2,.7,.2,1);
  white-space:nowrap;
}
.btn svg{ width:1.05em; height:1.05em; transition:transform .35s; }
.btn--gold{ background:var(--accent); color:var(--ink); }
.btn--gold:hover{ background:var(--accent-bright); transform:translateY(-2px); box-shadow:0 14px 30px -12px rgba(0,0,0,.6); }
.btn--gold:hover svg{ transform:translateX(4px); }
.btn--ghost{ background:transparent; color:var(--t-on-dark); border-color:var(--line-dark); }
.btn--ghost:hover{ border-color:var(--accent-bright); color:var(--accent-bright); }
.bg-paper .btn--ghost{ color:var(--t-on-light); border-color:var(--line-light); }
.bg-paper .btn--ghost:hover{ border-color:var(--gold); color:var(--gold); }
.btn--wa{ background:#1f7a4d; color:#fff; }
.btn--wa:hover{ background:#23905a; transform:translateY(-2px); }
.btn--sm{ padding:.78em 1.3em; font-size:.72rem; }

.link-arrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-family:var(--font-body); font-weight:600; font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--accent-bright);
}
.link-arrow svg{ width:1em; height:1em; transition:transform .3s; }
.link-arrow:hover svg{ transform:translateX(5px); }
.bg-paper .link-arrow{ color:var(--gold); }

/* ============================================================
   IMAGE / VIDEO PLACEHOLDERS + REAL MEDIA
   ============================================================ */
.ph{
  position:relative; overflow:hidden; background:var(--river-deep);
  display:flex; align-items:center; justify-content:center;
  color:var(--m-on-dark);
}
.ph::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 30% 10%, rgba(226,183,102,.10), transparent 55%),
    linear-gradient(160deg, var(--river) 0%, var(--river-deep) 55%, var(--ink) 100%);
}
.ph::after{
  content:""; position:absolute; inset:0; opacity:.06; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.ph__inner{
  position:relative; z-index:2; display:flex; flex-direction:column;
  align-items:center; gap:.7em; opacity:.85;
}
.ph__inner svg{ width:34px; height:34px; stroke:currentColor; opacity:.7; }
.ph__label{
  font-family:var(--font-body); font-size:.66rem; font-weight:600;
  letter-spacing:.34em; text-transform:uppercase;
}
.ph--rounded{ border-radius:var(--r-lg); }
.ph--media{ box-shadow:var(--shadow); }

/* real image filling a .ph / media box */
.ph-fill{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; }
.media{ position:relative; overflow:hidden; }
.media .ph-fill{ z-index:0; }
img.ph-fill{ background:var(--river-deep); }
/* gentle load-in */
.ph-fill{ opacity:0; transition:opacity .6s ease; }
.ph-fill.loaded, .no-js .ph-fill{ opacity:1; }

/* ============================================================
   CARDS / FEATURES
   ============================================================ */
.grid{ display:grid; gap:clamp(20px,2.4vw,36px); }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }

.feature{ display:flex; flex-direction:column; gap:.7rem; }
.feature__ico{
  width:46px; height:46px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line-dark); border-radius:50%; color:var(--accent-bright);
  margin-bottom:.4rem;
}
.bg-paper .feature__ico{ border-color:var(--line-light); color:var(--gold); }
.feature__ico svg{ width:22px; height:22px; }
.feature h3{ font-size:1.22rem; }
.feature p{ font-size:.96rem; color:var(--m-on-dark); }
.bg-paper .feature p{ color:var(--m-on-light); }

.rule{ height:1px; background:var(--line-dark); border:0; }
.bg-paper .rule{ background:var(--line-light); }

.stat__num{ font-family:var(--font-display); font-size:clamp(2.4rem,4vw,3.4rem); line-height:1; color:var(--accent-bright); }
.bg-paper .stat__num{ color:var(--gold); }
.stat__lbl{ font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--m-on-dark); margin-top:.6rem; display:block; }
.bg-paper .stat__lbl{ color:var(--m-on-light); }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }
[data-reveal-delay="1"]{ transition-delay:.08s; }
[data-reveal-delay="2"]{ transition-delay:.16s; }
[data-reveal-delay="3"]{ transition-delay:.24s; }
[data-reveal-delay="4"]{ transition-delay:.32s; }
.no-js [data-reveal]{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ [data-reveal]{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:200;
  transition:background .45s, border-color .45s, backdrop-filter .45s;
  border-bottom:1px solid transparent;
}
.nav__in{ display:flex; align-items:center; gap:2rem; height:78px; }
.nav.scrolled{ background:color-mix(in oklab, var(--ink) 86%, transparent); backdrop-filter:blur(14px) saturate(1.2); border-bottom-color:var(--line-dark); }
/* dark gradient behind the bar over bright heroes (fades out once scrolled) */
.nav::after{ content:""; position:absolute; left:0; right:0; top:0; height:132px; z-index:-1; pointer-events:none; background:linear-gradient(180deg, rgba(7,12,11,.6), rgba(7,12,11,0)); transition:opacity .4s; }
.nav.scrolled::after{ opacity:0; }
.nav__logo{ display:flex; align-items:center; gap:.7rem; margin-right:auto; }
.nav__logo-img{ height:34px; width:auto; filter:drop-shadow(0 1px 4px rgba(0,0,0,.5)); }
.footer .nav__logo-img{ height:38px; }
.nav__links{ display:flex; align-items:center; gap:clamp(1.05rem,1.5vw,1.7rem); }
.nav__links a{
  font-size:.8rem; font-weight:500; letter-spacing:.06em; text-transform:uppercase;
  color:var(--t-on-dark); opacity:.82; position:relative; padding-block:.4rem; transition:.25s;
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--accent-bright); transition:width .3s; }
.nav__links a:hover{ opacity:1; }
.nav__links a:hover::after, .nav__links a.active::after{ width:100%; }
.nav__links a.active{ opacity:1; color:var(--accent-bright); }
.nav__right{ display:flex; align-items:center; gap:1rem; }

/* language switcher */
.lang{ position:relative; }
.lang__btn{
  display:flex; align-items:center; gap:.45rem; background:transparent; border:1px solid var(--line-dark);
  color:var(--t-on-dark); padding:.5rem .8rem; border-radius:var(--r-sm); font-size:.76rem;
  font-weight:600; letter-spacing:.08em; text-transform:uppercase; transition:.25s;
}
.lang__btn:hover{ border-color:var(--accent-bright); }
.lang__btn .chev{ width:.85em; height:.85em; transition:transform .25s; }
.lang__btn .flag{ font-size:1rem; line-height:1; }
.lang__btn svg:first-child{ width:1em; height:1em; opacity:.85; }
.lang.open .lang__btn .chev{ transform:rotate(180deg); }
.lang__menu{
  position:absolute; top:calc(100% + 8px); right:0; min-width:170px;
  background:var(--ink-2); border:1px solid var(--line-dark); border-radius:var(--r-md);
  padding:.4rem; opacity:0; visibility:hidden; transform:translateY(-6px); transition:.25s; box-shadow:var(--shadow);
}
.lang.open .lang__menu{ opacity:1; visibility:visible; transform:none; }
.lang__opt{
  display:flex; align-items:center; gap:.7rem; width:100%; text-align:left; background:transparent; border:0;
  color:var(--t-on-dark); padding:.6rem .7rem; border-radius:var(--r-sm); font-size:.82rem; font-weight:500; transition:.18s;
}
.lang__opt:hover{ background:var(--ink-3); }
.lang__opt.active{ color:var(--accent-bright); }
.lang__opt .flag{ font-size:1.05rem; }

/* hamburger */
.burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:6px; }
.burger span{ width:24px; height:2px; background:var(--t-on-dark); transition:.3s; }
.nav.menu-open .burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.menu-open .burger span:nth-child(2){ opacity:0; }
.nav.menu-open .burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:190; background:var(--ink);
  display:flex; flex-direction:column; justify-content:center; gap:.4rem; padding:var(--gutter);
  transform:translateX(100%); transition:transform .5s cubic-bezier(.7,0,.2,1); visibility:hidden;
}
.drawer.open{ transform:none; visibility:visible; }
.drawer a{ font-family:var(--font-display); font-size:2rem; padding-block:.35rem; color:var(--t-on-dark); }
.drawer a:hover{ color:var(--accent-bright); }
.drawer a.active{ color:var(--accent-bright); }

/* logo wordmark text (footer fallback) */
.logo-txt{ display:flex; flex-direction:column; line-height:1; }
.logo-txt b{ font-family:var(--font-display); font-size:1.18rem; font-weight:600; letter-spacing:.02em; }
.logo-txt small{ font-size:.56rem; letter-spacing:.36em; text-transform:uppercase; color:var(--accent-bright); margin-top:.28em; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--ink-2); border-top:1px solid var(--line-dark); padding-block:clamp(56px,7vw,96px) 2rem; }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.3fr; gap:clamp(28px,4vw,56px); }
.footer h4{ font-family:var(--font-body); font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:var(--accent-bright); margin-bottom:1.2rem; }
.footer__col a, .footer__col p{ display:block; font-size:.92rem; color:var(--m-on-dark); margin-bottom:.7rem; transition:.2s; }
.footer__col a:hover{ color:var(--t-on-dark); }
.footer__bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; margin-top:clamp(40px,5vw,72px); padding-top:1.8rem; border-top:1px solid var(--line-dark); font-size:.78rem; color:var(--m-on-dark); }

/* ============================================================
   FORMS
   ============================================================ */
.field{ display:flex; flex-direction:column; gap:.5rem; }
.field label{ font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--m-on-dark); font-weight:600; }
.field input, .field select, .field textarea{
  background:rgba(255,255,255,.03); border:1px solid var(--line-dark); border-radius:var(--r-sm);
  color:var(--t-on-dark); padding:.95em 1.05em; font-family:var(--font-body); font-size:.98rem; transition:.25s; width:100%;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--accent-bright); background:rgba(255,255,255,.05); }
.field textarea{ resize:vertical; min-height:120px; }
.field select{ appearance:none; }
.form-status{ font-size:.9rem; margin-top:.3rem; }
.form-status.ok{ color:var(--moss); }
.form-status.err{ color:#e0915a; }

/* ============================================================
   FLOATING WHATSAPP
   ============================================================ */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:150;
  width:58px; height:58px; border-radius:50%; background:#1f9d57; color:#fff;
  display:flex; align-items:center; justify-content:center; box-shadow:0 12px 30px -8px rgba(0,0,0,.5);
  transition:.3s; border:0;
}
.wa-float:hover{ transform:scale(1.08); background:#23b063; }
.wa-float svg{ width:30px; height:30px; }

/* ============================================================
   MISC
   ============================================================ */
.kicker-num{ font-family:var(--font-display); font-size:.95rem; color:var(--accent-bright); letter-spacing:.1em; }
.pill{ display:inline-flex; align-items:center; gap:.5em; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; font-weight:600;
  border:1px solid var(--line-dark); border-radius:100px; padding:.5em 1em; color:var(--m-on-dark); }
.bg-paper .pill{ border-color:var(--line-light); color:var(--m-on-light); }
.pill--gold{ background:var(--accent); color:var(--ink); border-color:transparent; }
.rating-badge{ display:inline-flex; align-items:center; gap:.6rem; font-size:.95rem; color:var(--m-on-light); }
.rating-badge b{ font-family:var(--font-display); font-size:1.5rem; color:var(--gold); }
.rating-badge .stars{ color:var(--gold); letter-spacing:.12em; }

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.sec-head{ max-width:60ch; margin-bottom:.5rem; display:flex; flex-direction:column; gap:1.1rem; }
.sec-head h2{ margin-top:.2rem; }
.sec-head--center{ margin-inline:auto; text-align:center; align-items:center; }
.sec-head--row{ flex-direction:row; justify-content:space-between; align-items:flex-end; max-width:none; gap:2rem; flex-wrap:wrap; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:flex-end; padding-bottom:clamp(28px,5vh,64px); overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
/* hero background slideshow (crossfade loop) */
.hero__slide{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 1.4s ease; }
.hero__slide.is-active{ opacity:1; }
@media (prefers-reduced-motion:reduce){ .hero__slide{ transition:none; } }
.hero__scrim{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(7,12,11,.6) 0%, rgba(7,12,11,.22) 26%, rgba(7,12,11,.55) 58%, rgba(7,12,11,.9) 82%, var(--ink) 100%); }
.hero__in{ position:relative; z-index:2; width:100%; padding-top:120px; }
.hero__title{ margin-block:1rem 1.4rem; max-width:18ch; }
.hero__lead{ max-width:54ch; color:var(--t-on-dark); opacity:.92; }
/* legibility of hero/page-hero text over bright photos */
.hero .eyebrow, .hero__title, .hero__lead,
.page-hero .breadcrumb, .page-hero h1, .page-hero .lead{
  text-shadow:0 2px 16px rgba(7,12,11,.5), 0 1px 4px rgba(7,12,11,.6);
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2rem; }
.hero__strip{ position:relative; z-index:2; display:grid; grid-template-columns:repeat(4,auto); justify-content:start; gap:clamp(28px,5vw,80px);
  margin-top:clamp(40px,6vh,76px); padding-top:clamp(24px,3vw,36px); border-top:1px solid var(--line-dark); }
.hero__stat{ display:flex; flex-direction:column; gap:.3rem; }
.hero__stat .stat__num{ font-size:clamp(1.9rem,3vw,2.7rem); }
.hero__stat .stat__lbl{ margin-top:.2rem; }
.hero__down{ position:absolute; left:50%; bottom:18px; transform:translateX(-50%); z-index:3; width:40px; height:40px;
  display:flex; align-items:center; justify-content:center; color:var(--t-on-dark); opacity:.6; animation:bob 2.2s ease-in-out infinite; }
.hero__down svg{ width:24px; height:24px; }
@keyframes bob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,7px); } }

/* ============================================================
   WELCOME
   ============================================================ */
.welcome{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,5vw,80px); align-items:start; }
.welcome__body{ display:flex; flex-direction:column; gap:1.2rem; padding-top:.5rem; }
.welcome__body p{ font-size:1.05rem; color:var(--m-on-light); }
.welcome__body .link-arrow{ margin-top:.6rem; }
.welcome__stats{ text-align:left; }

/* ============================================================
   LODGE
   ============================================================ */
.lodge__hero{ width:100%; }

/* ============================================================
   FISHING / SPECIES
   ============================================================ */
.fishing__top{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,4vw,64px); align-items:end; }
.fishing__top .lead{ color:var(--t-on-dark); opacity:.86; }
.species{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,32px); }
.species__card{ display:flex; flex-direction:column; }
.species__img{ aspect-ratio:4/3; border-radius:var(--r-lg) var(--r-lg) 0 0; }
.species__body{ background:color-mix(in oklab, var(--ink) 55%, transparent); border:1px solid var(--line-dark); border-top:0;
  border-radius:0 0 var(--r-lg) var(--r-lg); padding:1.6rem 1.5rem 1.8rem; display:flex; flex-direction:column; gap:.55rem; flex:1; }
.species__body h3{ margin-top:.1rem; }
.species__body p{ color:var(--m-on-dark); font-size:.96rem; }
.fishing__cta{ margin-top:clamp(32px,4vw,52px); }

/* ============================================================
   SEASON
   ============================================================ */
.season__bar{ display:grid; grid-template-columns:1fr 1.4fr .8fr .6fr; gap:10px; margin-top:clamp(36px,4vw,56px); }
.season__month{ border-radius:var(--r-md); padding:1.5rem 1.3rem; display:flex; flex-direction:column; gap:.35rem; border:1px solid var(--line-light); }
.season__month b{ font-family:var(--font-body); font-weight:700; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; }
.season__month span{ font-size:.92rem; color:var(--m-on-light); }
.season__month.off{ background:transparent; opacity:.6; }
.season__month.good{ background:color-mix(in oklab, var(--moss) 22%, var(--paper)); border-color:transparent; }
.season__month.peak{ background:var(--accent); border-color:transparent; }
.season__month.peak b, .season__month.peak span{ color:var(--ink); }
.season__month.peak span{ opacity:.8; }

/* ============================================================
   PACKAGES
   ============================================================ */
.pk__card{ background:var(--ink-2); border:1px solid var(--line-dark); border-radius:var(--r-lg); padding:2rem 1.9rem 2.1rem;
  display:flex; flex-direction:column; gap:1.1rem; transition:.4s cubic-bezier(.2,.7,.2,1); }
.pk__card:hover{ transform:translateY(-5px); border-color:color-mix(in oklab, var(--accent-bright) 45%, transparent); }
.pk__card--feat{ background:linear-gradient(165deg, color-mix(in oklab, var(--accent) 16%, var(--ink-2)), var(--ink-2)); border-color:color-mix(in oklab, var(--accent-bright) 35%, transparent); }
.pk__head{ display:flex; flex-direction:column; gap:.9rem; }
.pk__list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.7rem; flex:1; }
.pk__list li{ position:relative; padding-left:1.5rem; font-size:.94rem; color:var(--m-on-dark); }
.pk__list li::before{ content:""; position:absolute; left:0; top:.5em; width:8px; height:8px; border-radius:50%; background:var(--accent-bright); }
.pk__card .link-arrow{ margin-top:auto; }

/* ============================================================
   GALLERY GRID (home preview)
   ============================================================ */
.gal-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:clamp(10px,1.2vw,16px); }
.gal-grid .ph{ width:100%; height:100%; }
.gal-a{ grid-column:span 2; grid-row:span 2; }
.gal-b{ grid-column:span 2; }

/* ============================================================
   REVIEWS
   ============================================================ */
.review{ background:var(--paper-2); border-radius:var(--r-lg); padding:2rem 1.9rem; margin:0; display:flex; flex-direction:column; gap:1.1rem; }
.review__stars{ color:var(--gold); letter-spacing:.18em; font-size:.95rem; }
.review blockquote{ margin:0; font-family:var(--font-display); font-size:1.28rem; line-height:1.4; color:var(--t-on-light); }
.review figcaption{ display:flex; flex-direction:column; gap:.2rem; margin-top:auto; }
.review figcaption b{ font-weight:600; }
.review figcaption span{ font-size:.82rem; letter-spacing:.06em; color:var(--m-on-light); }

/* ============================================================
   SUSTAINABILITY
   ============================================================ */
.susta{ max-width:64ch; display:flex; flex-direction:column; gap:1.3rem; }
.susta .lead{ color:var(--t-on-dark); opacity:.9; }

/* ============================================================
   CTA
   ============================================================ */
.cta{ position:relative; padding-block:clamp(90px,13vw,180px); overflow:hidden; }
.cta__media{ position:absolute; inset:0; z-index:0; }
.cta__scrim{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(7,12,11,.5), rgba(7,12,11,.78)); }
.cta__in{ position:relative; z-index:2; text-align:center; display:flex; flex-direction:column; align-items:center; gap:1.3rem; }
.cta__in .hero__cta{ justify-content:center; }
.cta__in .lead{ color:var(--t-on-dark); opacity:.9; max-width:46ch; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .welcome, .fishing__top{ grid-template-columns:1fr; gap:1.6rem; }
  .species{ grid-template-columns:1fr 1fr; }
  .season__bar{ grid-template-columns:1fr 1fr; }
  .gal-grid{ grid-template-columns:repeat(2,1fr); }
  .gal-a, .gal-b{ grid-column:span 2; grid-row:auto; }
}
@media (max-width:860px){
  body{ font-size:16px; }
  .nav__links{ display:none; }
  .nav__cta{ display:none; }
  .burger{ display:flex; }
  .g-3,.g-4{ grid-template-columns:repeat(2,1fr); }
  .lang__btn svg:first-child{ display:none; } /* hide globe on mobile, keep flag + code */
  .hero__strip{ grid-template-columns:repeat(2,1fr); gap:1.6rem 2rem; }
  .sec-head--row{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:600px){
  .g-2,.g-3,.g-4{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; }
  .species{ grid-template-columns:1fr; }
  .season__bar{ grid-template-columns:1fr; }
  .gal-grid{ grid-template-columns:1fr; grid-auto-rows:220px; }
  .gal-a, .gal-b{ grid-column:auto; }
  .reviews{ grid-template-columns:1fr; }
}

/* ============================================================
   SUB-PAGE: PAGE HERO
   ============================================================ */
.page-hero{ position:relative; min-height:62vh; display:flex; align-items:flex-end; overflow:hidden; padding-bottom:clamp(40px,6vw,72px); }
.page-hero__media{ position:absolute; inset:0; z-index:0; }
.page-hero__scrim{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(7,12,11,.5) 0%, rgba(7,12,11,.25) 40%, var(--ink) 100%); }
.page-hero__in{ position:relative; z-index:2; width:100%; padding-top:130px; }
.page-hero h1{ margin-block:1rem .9rem; max-width:16ch; }
.page-hero .lead{ max-width:54ch; color:var(--t-on-dark); opacity:.9; }
.breadcrumb{ display:flex; gap:.6rem; align-items:center; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--m-on-dark); }
.breadcrumb a:hover{ color:var(--accent-bright); }
.breadcrumb span{ opacity:.5; }

/* ============================================================
   INCLUSIONS
   ============================================================ */
.incl{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.1rem 3rem; }
.incl__item{ display:flex; gap:1rem; padding-block:.4rem; align-items:flex-start; }
.incl__check{ flex:none; width:26px; height:26px; border-radius:50%; background:color-mix(in oklab, var(--accent) 18%, transparent);
  display:flex; align-items:center; justify-content:center; color:var(--accent-bright); margin-top:.1rem; }
.incl__check svg{ width:14px; height:14px; }
.incl__item p{ font-size:1rem; color:var(--t-on-dark); opacity:.9; }
.incl__item b{ font-weight:600; opacity:1; }

.info-col h3{ font-size:1.25rem; margin-bottom:1.1rem; display:flex; align-items:center; gap:.7rem; }
.info-col h3 .feature__ico{ width:40px; height:40px; margin:0; }
.info-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.info-col li{ position:relative; padding-left:1.4rem; font-size:.96rem; color:var(--m-on-dark); }
.info-col li::before{ content:""; position:absolute; left:0; top:.55em; width:7px; height:7px; border-radius:50%; background:var(--accent-bright); }
/* fix: info-col on the light (paper) section must use dark text */
.bg-paper .info-col li{ color:var(--m-on-light); }
.bg-paper .info-col h3{ color:var(--t-on-light); }

.pkg-detail{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,28px); }

/* ============================================================
   SPECIES DETAIL ROWS
   ============================================================ */
.fish-row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,64px); align-items:center; }
.fish-row:nth-child(even) .fish-row__media{ order:2; }
.fish-row__media{ aspect-ratio:4/3; }
.fish-row__body{ display:flex; flex-direction:column; gap:1rem; }
.fish-row__meta{ display:flex; gap:1.8rem; margin-top:.4rem; flex-wrap:wrap; }
.fish-row__meta div{ display:flex; flex-direction:column; gap:.2rem; }
.fish-row__meta dt{ font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--m-on-dark); }
.fish-row__meta dd{ margin:0; font-family:var(--font-display); font-size:1.25rem; color:var(--accent-bright); }
.fish-stack{ display:flex; flex-direction:column; gap:clamp(48px,7vw,104px); }

/* ============================================================
   GALLERY (full)
   ============================================================ */
.gal-filter{ display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:clamp(28px,3vw,44px); }
.gal-filter button{ background:transparent; border:1px solid var(--line-dark); color:var(--m-on-dark); padding:.6em 1.3em;
  border-radius:100px; font-family:var(--font-body); font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; transition:.25s; }
.gal-filter button:hover{ border-color:var(--accent-bright); color:var(--t-on-dark); }
.gal-filter button.active{ background:var(--accent); border-color:transparent; color:var(--ink); }
.gal-full{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:240px; gap:clamp(10px,1.2vw,16px); }
.gal-full .ph{ width:100%; height:100%; }
.gal-full .tall{ grid-row:span 2; }
.gal-full .wide{ grid-column:span 2; }

/* ============================================================
   BOOKING
   ============================================================ */
.booking{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,80px); align-items:start; }
.booking__form{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.booking__form .field--full{ grid-column:1 / -1; }
.booking__aside{ display:flex; flex-direction:column; gap:1.6rem; }
.booking__card{ background:var(--ink-2); border:1px solid var(--line-dark); border-radius:var(--r-lg); padding:1.8rem; }
.booking__card h3{ font-size:1.2rem; margin-bottom:1rem; }
.contact-line{ display:flex; align-items:center; gap:.9rem; margin-bottom:1rem; font-size:.96rem; color:var(--m-on-dark); }
.contact-line svg{ width:20px; height:20px; flex:none; color:var(--accent-bright); }
.contact-line a:hover{ color:var(--t-on-dark); }

.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.5vw,36px); counter-reset:s; }
.step{ display:flex; flex-direction:column; gap:.7rem; }
.step__n{ font-family:var(--font-display); font-size:2.4rem; color:var(--accent-bright); line-height:1; }
.step h3{ font-size:1.15rem; }
.step p{ color:var(--m-on-dark); font-size:.95rem; }

/* ============================================================
   BLOG / JOURNAL
   ============================================================ */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(24px,3vw,40px); }
.blog-card{ display:flex; flex-direction:column; }
.blog-card__img{ aspect-ratio:3/2; border-radius:var(--r-lg); margin-bottom:1.2rem; }
.blog-card__tag{ font-size:.7rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent-bright); font-weight:600; }
.blog-card h3{ font-size:1.4rem; margin-block:.6rem .5rem; line-height:1.15; }
.blog-card p{ color:var(--m-on-dark); font-size:.95rem; margin-bottom:.9rem; }
.blog-card__meta{ font-size:.8rem; color:var(--m-on-dark); margin-top:auto; }
.blog-feat{ display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(28px,4vw,56px); align-items:center; margin-bottom:clamp(40px,5vw,72px); }
.blog-feat__img{ aspect-ratio:16/10; }

@media (max-width:900px){
  .incl{ grid-template-columns:1fr; }
  .pkg-detail{ grid-template-columns:1fr; }
  .fish-row{ grid-template-columns:1fr; gap:1.4rem; }
  .fish-row:nth-child(even) .fish-row__media{ order:0; }
  .booking{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .gal-full{ grid-template-columns:repeat(2,1fr); }
  .gal-full .wide{ grid-column:auto; }
  .blog-grid{ grid-template-columns:1fr 1fr; }
  .blog-feat{ grid-template-columns:1fr; }
}
@media (max-width:600px){
  .booking__form{ grid-template-columns:1fr; }
  .gal-full{ grid-template-columns:1fr; grid-auto-rows:220px; }
  .gal-full .tall{ grid-row:auto; }
  .blog-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   FAQ (accordion, zero-JS via <details>)
   ============================================================ */
.faq{ max-width:820px; margin:clamp(28px,3vw,44px) auto 0; display:flex; flex-direction:column; gap:.6rem; }
.faq__item{ border:1px solid var(--line-dark); border-radius:var(--r-md); padding:1.1rem 1.4rem; background:var(--ink-2); }
.faq__item summary{ cursor:pointer; font-family:var(--font-display); font-size:1.18rem; line-height:1.3; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__item summary::after{ content:"+"; color:var(--accent-bright); font-size:1.5rem; line-height:1; transition:transform .3s; }
.faq__item[open] summary::after{ transform:rotate(45deg); }
.faq__item p{ color:var(--m-on-dark); margin-top:.8rem; font-size:.98rem; }

/* ============================================================
   ARTICLE (journal post)
   ============================================================ */
.article-body{ max-width:740px; }
.article-body > .lead{ margin-bottom:.5rem; }
.article-body h2{ margin-top:2.2rem; margin-bottom:.6rem; }
.article-body p{ color:var(--m-on-dark); margin-bottom:1rem; font-size:1.05rem; }
.article-cta{ display:flex; align-items:center; gap:1rem; flex-wrap:wrap; margin-top:2.6rem; padding-top:1.8rem; border-top:1px solid var(--line-dark); }
.lodge-shot{ margin:0; }
.lodge-shot figcaption{ margin-top:.85rem; font-size:.9rem; letter-spacing:.04em; color:var(--m-on-dark); }
.blog-card a.blog-card__link{ color:inherit; }
.blog-card a.blog-card__link:hover h3{ color:var(--accent-bright); }
