:root{
    --bone:#f4f1ea;          /* cream / bone page bg */
    --bone-2:#ece8de;        /* slightly deeper cream */
    --ink:#141414;           /* near-black ink */
    --navy:#14213d;          /* brand navy */
    --navy-2:#1c2c4f;
    --azure:#1f63d6;         /* modernized azure accent */
    --azure-d:#1850b3;
    --muted:#5b5f66;         /* secondary on light */
    --muted-2:#8a8d93;
    --line:#d8d3c6;          /* hairline on cream */
    --line-d:#2a2d36;        /* hairline on dark */
    --paper:#efece3;         /* light text on dark */
    --muted-dk:#a4a7b2;      /* secondary on dark */
  }
  *{margin:0;padding:0;box-sizing:border-box;border-radius:0 !important}
  html{scroll-behavior:smooth}
  body{
    background:var(--bone);color:var(--ink);
    font-family:"Schibsted Grotesk",Helvetica,Arial,sans-serif;
    font-size:18px;line-height:1.6;font-weight:400;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  img{display:block;max-width:100%;height:auto}
  a{color:inherit;text-decoration:none}
  .wrap{max-width:1320px;margin:0 auto;padding:0 44px}
  .disp{font-family:"Bricolage Grotesque",Helvetica,Arial,sans-serif;font-weight:800;line-height:.98;letter-spacing:-0.02em}
  .disp-700{font-family:"Bricolage Grotesque",Helvetica,Arial,sans-serif;font-weight:700;line-height:1.02;letter-spacing:-0.018em}
  .eyebrow{font-family:"Schibsted Grotesk";font-size:12.5px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--azure);display:inline-block}
  .eyebrow.on-dark{color:#7aa6f0}

  /* ---------- scroll-reveal baseline (only after JS adds .is-ready) ---------- */
  .is-ready .reveal{opacity:0;transform:translateY(26px)}
  .is-ready .reveal.in{opacity:1;transform:none;transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
  @media (prefers-reduced-motion: reduce){
    .is-ready .reveal{opacity:1 !important;transform:none !important;transition:none !important}
    html{scroll-behavior:auto}
  }

  /* ---------- header ---------- */
  header{position:sticky;top:0;z-index:60;background:rgba(244,241,234,.86);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
  .bar{display:flex;align-items:center;justify-content:space-between;height:82px}
  .logo-plate{display:inline-flex;align-items:center}
  .logo-plate img{height:42px;width:auto}
  nav.main{display:flex;align-items:center;gap:32px}
  nav.main a.nl{font-size:14.5px;font-weight:600;letter-spacing:.01em;color:var(--ink)}
  nav.main a.nl:hover{color:var(--azure)}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:"Schibsted Grotesk";font-weight:700;font-size:13.5px;letter-spacing:.07em;text-transform:uppercase;padding:15px 26px;border:1.5px solid transparent;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
  .btn-primary{background:var(--azure);color:#fff}
  .btn-primary:hover{background:var(--azure-d)}
  .btn-ink{background:var(--ink);color:var(--bone)}
  .btn-ink:hover{background:#000}
  .btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
  .btn-ghost:hover{background:var(--ink);color:var(--bone)}
  .btn-ghost-d{background:transparent;color:var(--paper);border-color:rgba(239,236,227,.5)}
  .btn-ghost-d:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
  .menu-toggle{display:none;background:none;border:0;color:var(--ink);font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer}

  /* ---------- hero ---------- */
  .hero{position:relative;min-height:calc(96vh - 82px);display:flex;align-items:flex-end;overflow:hidden;background:var(--ink)}
  .hero .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 34%}
  .hero .scrim{position:absolute;inset:0;background:
     linear-gradient(180deg,rgba(20,33,61,.30) 0%,rgba(20,20,20,.05) 30%,rgba(20,20,20,.48) 68%,rgba(20,20,20,.93) 100%),
     linear-gradient(90deg,rgba(20,20,20,.6) 0%,rgba(20,20,20,0) 62%)}
  .hero .hero-inner{position:relative;z-index:2;width:100%;padding:46px 0 7vh}
  .hero .eyebrow{color:#9ec0fb;margin-bottom:20px}
  .hero .hero-title{font-family:"Fraunces",Georgia,serif;font-weight:500;font-size:clamp(46px,7.1vw,108px);line-height:1.0;letter-spacing:-.02em;color:#fff;max-width:15ch}
  .hero .hero-title em{font-style:italic;font-weight:400;color:#cfe0ff}
  .hero .hero-sub{font-family:"Schibsted Grotesk";font-size:clamp(17px,1.5vw,21px);line-height:1.5;max-width:54ch;color:rgba(255,255,255,.9);margin-top:24px}
  .hero .cta-row{display:flex;align-items:center;gap:18px;margin-top:36px;flex-wrap:wrap}
  .hero .meta{display:flex;align-items:center;gap:9px;font-size:14px;color:rgba(255,255,255,.85);letter-spacing:.01em}
  .stars{color:#d99a17;letter-spacing:2px;font-size:15px}
  .hero .stars{color:#f5c451}
  .hero .btn-ghost{color:#fff;border-color:rgba(255,255,255,.6)}
  .hero .btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}

  /* ---------- marquee ---------- */
  .marquee-band{background:var(--ink);color:var(--bone);padding:30px 0;overflow:hidden;position:relative}
  .marquee-label{font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted-dk);padding:0 44px 14px;max-width:1320px;margin:0 auto}
  .marquee{position:relative;display:flex;width:100%;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
  .marquee-track{display:flex;flex:0 0 auto;align-items:center;will-change:transform}
  .marquee-track .m-item{display:flex;align-items:center;white-space:nowrap;padding:0 2.2rem}
  .marquee-track .m-item img{height:40px;width:auto;display:block;filter:brightness(0) invert(1);opacity:.82}
  .marquee-track .dot{color:var(--azure);font-weight:700;padding:0 .15em}
  /* animate only when motion allowed */
  @media (prefers-reduced-motion: no-preference){
    .marquee-track{animation:marq 38s linear infinite}
    .marquee:hover .marquee-track{animation-play-state:paused}
  }
  @keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

  /* ---------- section scaffolding ---------- */
  section{padding:96px 0}
  .sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:54px;flex-wrap:wrap}
  .sec-head h2{font-size:clamp(38px,5.2vw,76px);max-width:16ch}
  .muted{color:var(--muted)}
  .link-arrow{font-weight:700;font-size:14px;letter-spacing:.04em;text-transform:uppercase;color:var(--azure);white-space:nowrap}
  .link-arrow:hover{opacity:.7}
  .band-navy{background:var(--navy);color:var(--paper)}
  .band-navy h2,.band-navy h3{color:#fff}
  .band-navy .muted{color:var(--muted-dk)}
  .band-navy .eyebrow{color:#7aa6f0}

  /* ---------- horizontal selected work strip ---------- */
  #work{padding-bottom:118px}
  .strip-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:40px}
  .strip-head .hint{font-size:13px;letter-spacing:.04em;color:var(--muted);display:flex;align-items:center;gap:10px}
  .strip-head .hint svg{width:34px;height:10px}
  .hstrip{
    display:flex;gap:22px;overflow-x:auto;overflow-y:hidden;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    padding:4px 44px 26px;margin:0 -44px;
    scrollbar-width:none;cursor:grab;
  }
  .hstrip::-webkit-scrollbar{display:none}
  .hstrip.dragging{cursor:grabbing;scroll-snap-type:none}
  .hslide{flex:0 0 auto;width:min(72vw,640px);scroll-snap-align:center;position:relative}
  .hslide:first-child{scroll-snap-align:start}
  .hslide .ph{position:relative;overflow:hidden;background:var(--bone-2)}
  .hslide img{width:100%;aspect-ratio:16/10;object-fit:cover;pointer-events:none}
  .hslide .num{position:absolute;top:0;left:0;background:var(--ink);color:var(--bone);font-family:"Bricolage Grotesque";font-weight:700;font-size:14px;letter-spacing:.04em;padding:8px 13px}
  .hslide .cap{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-top:14px}
  .hslide .cap b{font-family:"Bricolage Grotesque";font-weight:700;font-size:19px;letter-spacing:-.01em;color:var(--ink)}
  .hslide .cap span{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
  .progress{height:3px;background:var(--line);position:relative;margin-top:24px;max-width:340px}
  .progress .bar{position:absolute;left:0;top:0;bottom:0;width:90px;background:var(--azure);min-width:44px}

  /* ---------- narrative ---------- */
  .narrative{display:grid;grid-template-columns:1.05fr 1fr;gap:78px;align-items:center}
  .narrative .body h2{font-size:clamp(32px,3.6vw,52px);margin:16px 0 28px;max-width:16ch}
  .narrative .body p{font-size:19px;line-height:1.62;color:var(--ink);margin-bottom:20px}
  .band-navy .narrative .body p{color:var(--paper)}
  .narrative .body p .lead-in{font-family:"Bricolage Grotesque";font-weight:700}
  .narrative .figure{position:relative}
  .narrative .figure img{width:100%;aspect-ratio:4/5;object-fit:cover}
  .narrative .figure .tag{position:absolute;bottom:0;left:0;background:var(--azure);color:#fff;font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:12px 18px;font-weight:600}

  /* ---------- hover-reveal events ---------- */
  .events-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
  .events-list{border-top:1px solid var(--line)}
  .event-row{display:grid;grid-template-columns:58px 1fr;gap:24px;align-items:start;padding:30px 8px;border-bottom:1px solid var(--line);cursor:default;transition:padding-left .3s,background .3s}
  .event-row .num{font-family:"Bricolage Grotesque";font-weight:700;font-size:18px;color:var(--azure)}
  .event-row h3{font-family:"Bricolage Grotesque";font-weight:700;font-size:clamp(24px,2.5vw,34px);color:var(--ink);line-height:1.02;letter-spacing:-.015em;transition:color .25s}
  .event-row p{font-size:15.5px;line-height:1.55;color:var(--muted);margin-top:8px}
  .event-row .rowimg{display:none}
  .event-row.active{padding-left:18px;background:var(--bone-2)}
  .event-row.active h3{color:var(--azure)}
  /* desktop fixed preview panel */
  .events-preview{position:sticky;top:108px;align-self:start}
  .events-preview .frame{position:relative;overflow:hidden;background:var(--bone-2);aspect-ratio:4/5}
  .events-preview .frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0}
  .events-preview .frame img.show{opacity:1}
  @media (prefers-reduced-motion: no-preference){
    .events-preview .frame img{transition:opacity .5s ease}
  }
  .events-preview .pcap{margin-top:14px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

  /* ---------- videography split ---------- */
  .video-split{display:grid;grid-template-columns:1fr 1fr;min-height:580px}
  .video-split .media{position:relative;overflow:hidden}
  .video-split .media img{width:100%;height:100%;object-fit:cover;min-height:440px}
  .video-split .copy{background:var(--navy);color:var(--paper);padding:88px 72px;display:flex;flex-direction:column;justify-content:center}
  .video-split .copy h2{color:#fff;font-size:clamp(30px,3.4vw,48px);margin:14px 0 22px;max-width:15ch}
  .video-split .copy p.muted{color:var(--muted-dk)}
  .video-split ul{list-style:none;margin:26px 0 36px}
  .video-split li{padding:16px 0;border-top:1px solid rgba(239,236,227,.18);font-size:16px;display:flex;gap:14px;color:var(--paper)}
  .video-split li b{font-weight:700}
  .video-split li::before{content:"";flex:0 0 26px;height:2px;background:var(--azure);margin-top:12px}

  /* ---------- pricing ---------- */
  .pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line)}
  .price-card{padding:50px 42px;border-right:1px solid var(--line);background:var(--bone)}
  .price-card:last-child{border-right:0}
  .price-card .kind{font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:24px;font-weight:600}
  .price-card .amt{font-family:"Bricolage Grotesque";font-weight:800;font-size:58px;color:var(--ink);line-height:1;letter-spacing:-.02em}
  .price-card .amt span{font-size:18px;color:var(--muted);font-weight:600}
  .price-card .note{margin-top:14px;font-size:15px;color:var(--muted)}
  .price-foot{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:32px;flex-wrap:wrap}
  .price-foot p{font-size:15px;color:var(--muted);max-width:62ch}

  /* ---------- why choose ---------- */
  .why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line-d)}
  .why-cell{padding:46px 44px 46px 0;border-bottom:1px solid var(--line-d)}
  .why-cell:nth-child(even){padding-left:44px;border-left:1px solid var(--line-d)}
  .why-cell .wn{font-family:"Bricolage Grotesque";font-weight:700;font-size:20px;color:#7aa6f0;margin-bottom:14px}
  .why-cell h3{font-family:"Bricolage Grotesque";font-weight:700;font-size:26px;color:#fff;margin-bottom:12px;letter-spacing:-.01em}
  .why-cell p{color:var(--muted-dk);font-size:16px;line-height:1.55}

  /* ---------- reviews ---------- */
  .reviews-head{display:flex;align-items:center;gap:18px;margin-bottom:50px;flex-wrap:wrap}
  .reviews-head .score{font-family:"Bricolage Grotesque";font-weight:800;font-size:64px;color:var(--ink);line-height:1;letter-spacing:-.03em}
  .reviews-head .gmeta{font-size:14px;color:var(--muted);letter-spacing:.02em}
  .reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
  .review{border:1px solid var(--line);padding:36px 32px;background:var(--bone)}
  .review .stars{margin-bottom:18px;display:block}
  .review p{font-size:16.5px;line-height:1.55;color:var(--ink)}
  .review .who{margin-top:22px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}

  /* ---------- faq ---------- */
  .faq-item{border-top:1px solid var(--line);padding:32px 0;display:grid;grid-template-columns:1fr 1.4fr;gap:50px}
  .faq-item:last-child{border-bottom:1px solid var(--line)}
  .faq-item h3{font-family:"Bricolage Grotesque";font-weight:700;font-size:23px;color:var(--ink);line-height:1.12;letter-spacing:-.01em}
  .faq-item p{font-size:16px;color:var(--muted);line-height:1.6}

  /* ---------- final cta ---------- */
  .final{position:relative;overflow:hidden;background:var(--ink)}
  .final img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.34}
  .final .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,20,20,.55),rgba(20,20,20,.9))}
  .final .inner{position:relative;text-align:center;padding:140px 0}
  .final h2{font-size:clamp(42px,6vw,92px);color:#fff;max-width:18ch;margin:0 auto 26px}
  .final p{font-size:19px;color:var(--paper);max-width:54ch;margin:0 auto 40px}
  .final .phone{display:inline-block;font-family:"Bricolage Grotesque";font-weight:700;font-size:32px;color:#fff;letter-spacing:-.01em}
  .final .final-cta{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap;margin-top:38px}

  /* ---------- areas ---------- */
  .areas .wrap{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;background:var(--line-d)}
  .area{background:var(--ink);padding:34px 30px}
  .area b{font-family:"Bricolage Grotesque";font-weight:700;font-size:21px;color:#fff;display:block;margin-bottom:6px;letter-spacing:-.01em}
  .area span{font-size:14px;color:var(--muted-dk)}

  /* ---------- footer ---------- */
  footer{background:var(--ink);border-top:1px solid var(--line-d);padding:72px 0 40px;color:var(--paper)}
  .foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid var(--line-d)}
  .foot-top h4{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-dk);margin-bottom:18px;font-weight:600}
  .foot-top a,.foot-top p{display:block;font-size:15px;color:var(--paper);margin-bottom:10px;opacity:.85}
  .foot-top a:hover{color:#7aa6f0;opacity:1}
  .foot-logo img{height:42px;width:auto;filter:grayscale(1) brightness(0) invert(1)}
  .foot-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:26px;font-size:13px;color:var(--muted-dk);flex-wrap:wrap;gap:14px}

  /* ---------- mobile sticky ---------- */
  .sticky-mobile{display:none}

  /* ---------- responsive ---------- */
  @media(max-width:980px){
    .wrap{padding:0 22px}
    .marquee-label{padding-left:22px;padding-right:22px}
    nav.main{display:none}
    nav.main.open{display:flex;position:absolute;top:82px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--bone);border-bottom:1px solid var(--line);padding:8px 22px 20px}
    nav.main.open a.nl{padding:15px 0;width:100%;border-bottom:1px solid var(--line)}
    nav.main.open .btn{margin-top:14px}
    .menu-toggle{display:block}
    .hero .grid{grid-template-columns:1fr;gap:38px}
    .hero .shot img{aspect-ratio:16/11}
    .narrative,.video-split,.why-grid,.events-wrap{grid-template-columns:1fr}
    .narrative{gap:42px}
    .events-wrap{gap:0}
    .pricing-grid,.reviews-grid{grid-template-columns:1fr}
    .price-card{border-right:0;border-bottom:1px solid var(--line)}
    .why-cell:nth-child(even){padding-left:0;border-left:0}
    .why-cell{padding-right:0}
    .faq-item{grid-template-columns:1fr;gap:12px}
    .video-split .copy{padding:58px 26px}
    .areas .wrap{grid-template-columns:repeat(2,minmax(0,1fr))}
    .foot-top{grid-template-columns:1fr 1fr}
    section{padding:78px 0}
    #work{padding-bottom:78px}
    .hstrip{padding-left:22px;padding-right:22px;margin:0 -22px}
    .hslide{width:84vw}
    /* events mobile = image per row, no sticky panel */
    .events-preview{display:none}
    .event-row{grid-template-columns:1fr;gap:14px;cursor:default}
    .event-row.active{padding-left:8px;background:transparent}
    .event-row.active h3{color:var(--ink)}
    .event-row .nh{display:flex;align-items:baseline;gap:16px}
    .event-row .rowimg{display:block;width:100%;aspect-ratio:16/10;object-fit:cover;margin-top:6px;background:var(--bone-2)}
    .sticky-mobile{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:70}
    .sticky-mobile a{flex:1;text-align:center}
    body{padding-bottom:60px}
  }
  @media(max-width:560px){
    .areas .wrap,.foot-top{grid-template-columns:1fr}
    .reviews-head .score{font-size:50px}
    .hslide{width:88vw}
  }
.page-hero .inner,.final .inner,.ty .inner,.nextproj .inner,.hero .hero-inner{padding-left:44px!important;padding-right:44px!important}@media(max-width:980px){.page-hero .inner,.final .inner,.ty .inner,.nextproj .inner,.hero .hero-inner{padding-left:22px!important;padding-right:22px!important}}
