/* ═══════════════════════════════════════════════════
   WANDER — SHARED CASE STUDY STYLESHEET
   Used by: bonvoy.html, canada-goose.html, project.html
   ═══════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{-webkit-tap-highlight-color:transparent;outline:none}
button{-webkit-tap-highlight-color:transparent;outline:none}
:root{
  --forest:#0E1A13;--moss:#162118;--grove:#1E2E22;
  --terr:#C4614A;--terrb:#D4745D;
  --sage:#7A9B7E;--fern:#4A6E4C;--parch:#E8E2D6;--cream:#F2EDD8;
  --ease:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
a,button{cursor:none}
body{font-family:'Inter',sans-serif;background:var(--forest);color:var(--parch);overflow-x:hidden;-webkit-font-smoothing:antialiased;cursor:none}

/* ── CURSOR ── */
.cur{position:fixed;z-index:9999;pointer-events:none}
.cur-dot{width:10px;height:10px;background:#fff;border-radius:50%;transform:translate(-50%,-50%)}
.cur-ring{position:fixed;width:40px;height:40px;border:1px solid rgba(232,226,214,.5);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;z-index:9998;transition:width .3s,height .3s,border-color .3s}
body:has(a:hover) .cur-ring,body:has(button:hover) .cur-ring{width:56px;height:56px;border-color:var(--terrb)}
@media(max-width:768px){.cur,.cur-ring{display:none}body{cursor:auto}}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:100px;display:flex;align-items:center;justify-content:space-between;padding:0 36px;background:linear-gradient(to bottom,rgba(8,15,10,.7) 0%,transparent 100%);transition:background .4s}
nav.scrolled{background:rgba(14,26,19,.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(44,62,45,.5)}
.nlogo{text-decoration:none;flex-shrink:0;display:block;position:relative;z-index:2;border-radius:50%;overflow:hidden;-webkit-tap-highlight-color:transparent;width:76px;height:76px}
.nlogo img{width:76px;height:76px;object-fit:cover;border-radius:50%;display:block;position:relative;z-index:2;background:rgba(14,26,19,.98)}
.nr{display:flex;align-items:center;gap:28px;flex-shrink:0}
.nl{font-size:10px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);text-decoration:none;transition:color .25s;cursor:none}
.nl:hover{color:var(--parch)}
.ns{font-size:10px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--parch);text-decoration:none;border:1px solid rgba(122,155,126,.3);padding:8px 18px;transition:all .25s;cursor:none}
.ns:hover{background:var(--terr);border-color:var(--terr);color:#fff}
.nl-back{font-size:10px;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(122,155,126,.6);text-decoration:none;transition:color .25s;cursor:none;display:flex;align-items:center;gap:6px}
.nl-back:hover{color:var(--parch)}
@media(max-width:640px){.nr .nl:not(.nl-back){display:none}}

/* ── HERO VIDEO ── */
.hero-video,.project-hero{padding-top:100px;background:var(--forest)}
@media(max-width:768px){.hero-video,.project-hero{padding-top:80px}}
.video-wrap-hero,.video-wrap{position:relative;width:100%;padding-bottom:56.25%;background:var(--forest);overflow:hidden}
.video-wrap-hero iframe,.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:none}
.video-placeholder{position:absolute;inset:0;background:var(--moss);display:flex;align-items:center;justify-content:center}
.placeholder-text{font-family:'Unbounded',sans-serif;font-size:10px;font-weight:300;letter-spacing:.2em;text-transform:uppercase;color:var(--fern)}

/* ── SHARE BAR ── */
.share-bar{display:flex;justify-content:flex-end;align-items:center;padding:14px 36px;border-bottom:1px solid rgba(44,62,45,.3);background:var(--forest);position:relative}
.share-trigger{display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif;font-size:10px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);background:transparent;border:none;cursor:none;padding:0;transition:color 180ms var(--ease)}
.share-trigger:hover{color:var(--parch)}
.share-trigger svg{width:13px;height:13px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2}
.share-popover{position:absolute;top:calc(100% + 8px);right:36px;background:var(--moss);border:1px solid rgba(44,62,45,.7);min-width:220px;z-index:100;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity 180ms var(--ease),transform 180ms var(--ease)}
.share-popover.open{opacity:1;transform:translateY(0);pointer-events:all}
.share-option{display:flex;align-items:center;gap:12px;width:100%;padding:14px 20px;background:none;border:none;font-family:'Inter',sans-serif;font-size:12px;font-weight:300;letter-spacing:.04em;color:rgba(232,226,214,.72);text-decoration:none;cursor:none;transition:background 150ms ease,color 150ms ease;text-align:left}
.share-option:not(:last-child){border-bottom:1px solid rgba(44,62,45,.5)}
.share-option:hover{background:rgba(44,62,45,.6);color:var(--cream)}
.share-option svg{width:14px;height:14px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.5;opacity:.6}
.share-toast{position:fixed;bottom:32px;left:50%;transform:translateX(-50%) translateY(10px);background:var(--parch);color:var(--forest);font-family:'Unbounded',sans-serif;font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:12px 24px;opacity:0;transition:opacity 250ms var(--ease),transform 250ms var(--ease);pointer-events:none;z-index:400}
.share-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── PROJECT INTRO ── */
.project-intro{padding:36px 36px 44px;display:block;border-bottom:1px solid rgba(44,62,45,.4)}
.intro-label{font-size:10px;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--terr);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.intro-label::before{content:'';display:block;width:16px;height:1px;background:var(--terr)}
.intro-subhed{font-family:'Unbounded',sans-serif;font-size:clamp(26px,4vw,58px);font-weight:900;line-height:1.0;letter-spacing:-.03em;text-transform:uppercase;color:var(--cream);margin-top:10px;margin-bottom:0;max-width:none}
.intro-client{font-family:'Inter',sans-serif;font-size:clamp(11px,1vw,13px);font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:rgba(232,226,214,.52);margin-bottom:0;margin-top:20px;line-height:1.8}
.intro-campaign{font-size:clamp(12px,1.1vw,14px);font-weight:300;color:rgba(232,226,214,.38);letter-spacing:.04em;margin-top:2px;margin-bottom:0}
.intro-services{font-size:10px;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:rgba(232,226,214,.52);margin-top:16px;margin-bottom:4px;line-height:1.8}
.intro-role{font-size:11px;font-weight:300;letter-spacing:.16em;text-transform:uppercase;color:rgba(122,155,126,.85);margin-top:12px}
.intro-award{display:inline-block;font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;background:var(--terr);color:#fff;padding:4px 12px;margin-bottom:20px}
.intro-deck{font-size:18px;font-weight:300;line-height:1.6;color:rgba(232,226,214,.78);max-width:480px;margin-bottom:24px}
.intro-tags{display:flex;gap:8px;flex-wrap:wrap}
.intro-tag{font-size:9px;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--sage);border:1px solid rgba(74,110,76,.3);padding:5px 12px}
.intro-right{padding-top:8px}

/* ── PROJECT HOOK ── */
.project-hook{padding:24px 36px 20px;max-width:none}
.project-hook p{font-family:'Inter',sans-serif;font-size:clamp(14px,1.5vw,20px);font-weight:300;line-height:1.6;letter-spacing:-.005em;color:rgba(232,226,214,.75);font-style:italic}

/* ── PROJECT SNAPSHOT ── */
.project-snapshot{padding:0 36px 28px;border-bottom:1px solid rgba(44,62,45,.3);background:var(--moss);margin-bottom:60px}
.snapshot-label{font-family:'Unbounded',sans-serif;font-size:10px;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);margin-bottom:20px;padding-top:28px;display:flex;align-items:center;gap:14px;border-bottom:1px solid rgba(44,62,45,.3);padding-bottom:12px}
.snapshot-label::before{content:'';display:block;width:20px;height:1px;background:var(--terr)}
.snapshot-grid{display:flex;flex-wrap:wrap;gap:0;align-items:baseline}
.snapshot-item{flex:1;min-width:0;padding-right:36px;border-right:1px solid rgba(44,62,45,.2);margin-right:36px}
.snapshot-item:last-child{border-right:none;margin-right:0;padding-right:0}
.snapshot-num{font-family:'Unbounded',sans-serif;font-size:clamp(28px,3.2vw,52px);font-weight:700;color:rgba(232,226,214,.97);letter-spacing:-.03em;line-height:1}
.snapshot-key{font-size:11px;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:rgba(122,155,126,.94);margin-top:12px}
.snapshot-val{font-size:13px;font-weight:300;color:rgba(232,226,214,.85);line-height:1.4}

/* ── PRE-NOTES CTA ── */
.pre-notes-cta{padding:24px 36px;display:flex;align-items:center;gap:20px;border-top:1px solid rgba(44,62,45,.2)}
.pre-notes-cta-label{font-size:12px;font-weight:300;color:rgba(232,226,214,.4);letter-spacing:.04em}

/* ── PRODUCTION NOTES TOGGLE ── */
.notes-toggle-trigger{width:100%;display:flex;align-items:center;justify-content:flex-start;gap:16px;padding:28px 36px;background:var(--grove);border:none;border-bottom:1px solid rgba(44,62,45,.5);cursor:none;text-align:left;border-top:2px solid rgba(44,62,45,.5);transition:background .2s}
.notes-toggle-label{font-family:'Unbounded',sans-serif;font-size:10px;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--parch);display:flex;align-items:center;gap:12px}
.notes-toggle-label::before{content:'';display:block;width:20px;height:1px;background:var(--terr)}
.notes-toggle-arr{font-size:11px;letter-spacing:.1em;color:rgba(232,226,214,.45);display:inline-block}
.notes-toggle-trigger:hover{background:rgba(44,62,45,.6)}
.notes-toggle-trigger:hover .notes-toggle-label{color:var(--parch)}
.notes-toggle-trigger:hover .notes-toggle-arr{color:var(--sage)}
.notes-toggle-panel{max-height:0;overflow:hidden;transition:max-height 900ms var(--ease)}
.notes-toggle-panel.open{max-height:6000px}

/* ── CASE STUDY TYPOGRAPHY HIERARCHY ── */
.case-sections-wrap{border-top:1px solid rgba(44,62,45,.3)}
.case-section{padding:48px 36px;border-bottom:1px solid rgba(44,62,45,.18)}
.case-section:last-of-type{border-bottom:none}
.case-section-label{font-family:'Unbounded',sans-serif;font-size:8px;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:rgba(196,97,74,.9);margin-bottom:18px;display:flex;align-items:center;gap:10px}
.case-section-label::before{content:'';display:block;width:16px;height:1px;background:rgba(196,97,74,.9)}
.case-section-hed{font-family:'Inter',sans-serif;font-size:clamp(20px,2.4vw,34px);font-weight:700;line-height:1.15;letter-spacing:-.03em;color:rgba(232,226,214,.97);margin-bottom:20px;max-width:800px}
.case-body{font-size:17px;font-weight:300;line-height:1.85;color:rgba(232,226,214,.75);max-width:800px}
.case-body p+p{margin-top:16px}
.case-bullets{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:14px;max-width:800px}
.case-bullets li{font-size:16px;font-weight:400;line-height:1.55;color:rgba(232,226,214,.82);padding-left:22px;position:relative}
.case-bullets li::before{content:'—';position:absolute;left:0;color:rgba(196,97,74,.85);font-weight:600}
.case-bullets--outcome li{font-size:18px;font-weight:500;color:rgba(232,226,214,.96);letter-spacing:-.01em;line-height:1.35}
.case-bullets--outcome li::before{color:var(--terr);font-weight:700}
.case-producers-note{font-size:19px;font-weight:300;font-style:italic;line-height:1.75;color:rgba(232,226,214,.65);max-width:680px}

/* ── EXECUTIVE PRODUCTION CREDIT ── */
.case-section--credit{border-top:1px solid rgba(44,62,45,.3)!important}
.case-credit-name{font-family:'Unbounded',sans-serif;font-size:16px;font-weight:700;color:var(--cream);letter-spacing:-.01em;margin-bottom:6px;margin-top:4px}
.case-credit-role{font-size:14px;font-weight:300;color:rgba(232,226,214,.55);line-height:1.6;max-width:440px}

/* ── CASE STUDY GALLERIES ── */
.cs-gallery-label{font-family:'Unbounded',sans-serif;font-size:9px;font-weight:300;letter-spacing:.26em;text-transform:uppercase;color:var(--terr);padding:48px 36px 20px;display:flex;align-items:center;gap:10px;border-top:1px solid rgba(44,62,45,.3)}
.cs-gallery-label::before{content:'';display:block;width:16px;height:1px;background:var(--terr)}
.cs-stills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;max-width:1200px;margin:0 auto}
.cs-still-item img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;filter:brightness(.88);transition:filter .3s}
.cs-still-item img:hover{filter:brightness(1)}
.cs-bts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;max-width:1200px;margin:0 auto}
.cs-bts-item img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block;filter:brightness(.82) saturate(.85);transition:filter .3s}
.cs-bts-item img:hover{filter:brightness(1) saturate(1)}
#cs-storyboard{padding:0;background:rgba(14,26,19,.6);max-width:1200px;margin:0 auto}
#cs-press{padding:48px 36px;border-top:1px solid rgba(44,62,45,.3)}
.cs-press-quote{display:none}
.cs-press-quote--secondary{display:none}
.cs-press-source{display:none}
.cs-press-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:0;max-width:1200px}
.cs-press-img img{width:100%;display:block;border:1px solid rgba(44,62,45,.4);opacity:.72;transition:opacity .2s}
.cs-press-img img:hover{opacity:1}
@media(max-width:768px){
  .cs-stills-grid{grid-template-columns:1fr}
  .cs-bts-grid{grid-template-columns:1fr}
  .cs-gallery-label{padding-left:20px;padding-right:20px}
  #cs-press{padding:36px 20px}
  .cs-press-grid{grid-template-columns:repeat(2,1fr)}
}
.snapshot-award-badge{display:inline-flex;align-items:center;gap:10px;margin-top:20px;padding:10px 20px;border:1px solid rgba(196,97,74,.4);border-radius:2px;background:rgba(196,97,74,.08)}
.award-icon{color:var(--terr);font-size:14px}
.award-text{font-family:'Unbounded',sans-serif;font-size:10px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:rgba(232,226,214,.75)}
.production-context{padding:72px 36px;border-top:1px solid rgba(44,62,45,.4);border-bottom:1px solid rgba(44,62,45,.4);background:var(--moss)}
.production-context-inner{max-width:760px}
.production-context-label{font-family:'Unbounded',sans-serif;font-size:9px;font-weight:300;letter-spacing:.26em;text-transform:uppercase;color:var(--terr);margin-bottom:28px;display:flex;align-items:center;gap:10px}
.production-context-label::before{content:'';display:block;width:16px;height:1px;background:var(--terr)}
.production-context-body{font-size:clamp(17px,1.6vw,22px);font-weight:300;line-height:1.75;color:rgba(232,226,214,.85)}
.production-context-body+.production-context-body{margin-top:24px;color:rgba(232,226,214,.65);font-size:clamp(15px,1.4vw,19px)}
@media(max-width:768px){
  .production-context{padding:48px 20px}
  .production-context-inner{max-width:100%}
  .production-context-body{font-size:16px}
  .production-context-body+.production-context-body{font-size:15px}
}
.project-cta{background:var(--moss);padding:64px 36px;display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;border-top:1px solid rgba(44,62,45,.5)}
.cta-hed{font-family:'Unbounded',sans-serif;font-size:clamp(26px,3.5vw,52px);font-weight:700;color:var(--cream);text-transform:uppercase;letter-spacing:-.025em;line-height:1.0}
.cta-sub-copy{font-size:14px;font-weight:300;color:rgba(232,226,214,.6);line-height:1.7;margin-top:12px;max-width:380px}
.cta-btns{display:flex;flex-direction:column;align-items:flex-start;gap:12px}
.btn-primary{font-family:'Unbounded',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--forest);background:var(--parch);padding:16px 32px;text-decoration:none;cursor:none;transition:background 180ms var(--ease),color 180ms var(--ease),transform 180ms var(--ease)}
.btn-primary:hover{background:var(--grove);color:var(--parch);transform:scale(1.015)}
.btn-primary:active{transform:scale(.99)}
.btn-ghost{font-size:10px;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--sage);border:1px solid rgba(122,155,126,.3);padding:16px 32px;text-decoration:none;cursor:none;transition:all 180ms var(--ease)}
.btn-ghost:hover{border-color:var(--parch);color:var(--parch)}

/* ── FOOTER ── */
footer{background:#080F0A;padding:28px 36px;display:flex;flex-direction:column;align-items:flex-start;border-top:1px solid rgba(44,62,45,.4)}
.fl{display:block;margin-bottom:12px}
.fl img{width:54px;height:54px;object-fit:cover;border-radius:50%;display:block}
.fright{display:flex;gap:28px;margin-bottom:17px}
.fright a{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:rgba(152,185,156,1);text-decoration:none;transition:color .3s}
.fright a:hover{color:var(--terrb)}
.fc-block{display:flex;flex-direction:column;gap:2px}
.fc--loc{font-size:10px;color:rgba(192,215,185,.65);letter-spacing:.06em}
.fc--copy{font-size:10px;color:rgba(192,215,185,.55);letter-spacing:.08em}

/* ── MOBILE ── */
@media(max-width:768px){
  /* Prevent horizontal scroll on all case study pages */
  html,body{overflow-x:hidden;max-width:100vw}

  /* Nav + shared padding */
  nav{padding:0 16px;height:80px}
  .nlogo{position:absolute!important;left:16px!important;top:50%!important;transform:translateY(-50%)!important;width:54px!important;height:54px!important}
  .nlogo img{width:54px!important;height:54px!important}
  .nr{gap:0}
  .ns{display:none}
  .nl-back{font-size:9px;letter-spacing:.14em;color:rgba(232,226,214,.6)}
  footer{padding:20px 20px 28px;align-items:flex-start}
  .fl{margin-bottom:10px}
  .fl img{width:47px;height:47px}
  .fright{gap:16px;margin-bottom:14px;flex-wrap:wrap}
  .fright a{font-size:9px;letter-spacing:.1em}
  .fc--loc,.fc--copy{font-size:9px}

  /* Share bar */
  .share-bar{padding-left:20px;padding-right:20px}
  .share-popover{right:20px}

  /* Intro */
  .project-intro{padding-left:20px;padding-right:20px;padding-bottom:60px}
  .intro-client{font-size:clamp(10px,2.5vw,13px)}

  /* Hook */
  .project-hook{padding-left:20px;padding-right:20px}

  /* Snapshot — consistent 2×2 grid */
  .project-snapshot{padding-left:20px;padding-right:20px;padding-bottom:36px}
  .snapshot-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
  .snapshot-item{flex:none;padding:20px 16px 20px 0;border-right:none;margin-right:0;border-bottom:1px solid rgba(44,62,45,.2)}
  .snapshot-item:nth-child(odd){padding-right:12px;border-right:1px solid rgba(44,62,45,.2)}
  .snapshot-item:nth-child(even){padding-left:12px;padding-right:0}
  .snapshot-item:nth-last-child(-n+2){border-bottom:none}
  .snapshot-num{font-size:16px !important;padding-top:0 !important;line-height:1.25 !important;letter-spacing:-.01em;word-break:break-word}
  .snapshot-key{font-size:10px;margin-top:8px;color:rgba(122,155,126,.94)}

  /* Pre-notes CTA */
  .pre-notes-cta{padding-left:20px;padding-right:20px;flex-direction:column;align-items:flex-start;gap:14px}
  .pre-notes-cta .btn-primary{width:100%;text-align:center}

  /* Toggle */
  .notes-toggle-trigger{padding-left:20px;padding-right:20px}

  /* Case sections */
  .case-section{padding:48px 20px}
  .case-section-hed{font-size:clamp(20px,5vw,28px)}

  /* Project CTA */
  .project-cta{flex-direction:column;padding:60px 20px}
  .cta-hed{font-size:clamp(22px,6vw,32px)}
  .btn-ghost .btn-arr{display:none}
  .btn-primary .btn-arr{display:none}
  .btn-ghost{width:100%;text-align:center;padding:14px 20px;box-sizing:border-box}
}

@media(max-width:900px) and (orientation:landscape){
  .fl img{width:48px!important;height:48px!important}
  .fright a{font-size:11px!important}
  .fc--loc,.fc--copy{font-size:11px!important}
}
