:root{
      --black:#090909;
      --black-2:#11110f;
      --paper:#fbfaf6;
      --paper-2:#f1efe8;
      --gold:#c79b4b;
      --gold-soft:#e6c989;
      --muted:#6e6b64;
      --line-dark:rgba(9,9,9,.14);
      --line-light:rgba(251,250,246,.18);
      --serif:"DM Serif Display", "Iowan Old Style", "Baskerville", Georgia, serif;
      --sans:Manrope,Arial,sans-serif;
      --max:1420px;
      --ease:cubic-bezier(.22,.78,.18,1);
    }
    *{box-sizing:border-box}
    html{background:var(--black);scroll-behavior:smooth}
    body{margin:0;background:var(--black);color:var(--paper);font-family:var(--sans);overflow-x:hidden}
    html.is-scroll-locked,body.is-scroll-locked{overflow:hidden;overscroll-behavior:none}
    a{color:inherit;text-decoration:none}
    button,input,select,textarea{font:inherit}
    button{cursor:pointer}
    .shell{width:min(var(--max),calc(100% - 96px));margin-inline:auto}
    .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}
    ::selection{background:var(--gold);color:var(--black)}
    .eyebrow{display:inline-flex;align-items:center;gap:10px;margin:0;color:var(--gold);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}
    .eyebrow:before{content:"";width:30px;height:1px;background:currentColor}
    .eyebrow.dark{color:#916e32}
    .btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:50px;padding:0 19px;border:1px solid transparent;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;transition:transform .25s var(--ease),background .25s ease,color .25s ease,border .25s ease}
    .btn:hover{transform:translateY(-2px)}
    .btn-white{background:var(--paper);color:var(--black);border-color:var(--paper)}
    .btn-white:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
    .btn-gold{background:var(--gold);color:var(--black);border-color:var(--gold)}
    .btn-gold:hover{background:var(--gold-soft);border-color:var(--gold-soft)}
    .btn-dark{background:var(--black);color:var(--paper);border-color:var(--black)}
    .btn-dark:hover{background:var(--gold);border-color:var(--gold);color:var(--black)}
    .arrow{font-size:18px;line-height:1;font-weight:400}
    .section-title{margin:0;font:400 clamp(48px,6.4vw,96px)/.92 var(--serif);letter-spacing:-.055em;font-optical-sizing:auto}
    .section-copy{margin:0;max-width:410px;color:#68645c;font-size:13px;line-height:1.7}

    /* Header */
    .site-header{position:fixed;z-index:100;inset:0 0 auto;height:95px;border-bottom:1px solid rgba(251,250,246,.18);background:linear-gradient(180deg,rgba(9,9,9,.52),rgba(9,9,9,.05));transition:background .28s ease,backdrop-filter .28s ease}
    .site-header.scrolled{background:rgba(9,9,9,.87);backdrop-filter:blur(15px)}
    .nav{position:relative;height:95px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
    .nav > .brand{grid-column:1}
    .brand{display:inline-flex;align-items:center;justify-self:start;color:inherit}
    .brand-logo{display:block;width:clamp(128px,11vw,172px);height:44px;object-fit:contain;object-position:left center}
    .menu-trigger{position:absolute;left:50%;top:50%;justify-self:center;width:42px;height:42px;border:1px solid rgba(251,250,246,.84);border-radius:50%;background:transparent;color:var(--paper);display:grid;place-items:center;transform:translate(-50%,-50%);transition:transform .28s var(--ease),background .28s ease,color .28s ease}
    .menu-trigger:hover{transform:translate(-50%,-50%) scale(1.08);background:var(--paper);color:var(--black)}
    .hamburger{display:grid;gap:5px;width:18px}.hamburger span{display:block;width:18px;height:2px;border-radius:999px;background:currentColor}
    .nav-cta{grid-column:3;justify-self:end;min-height:47px;padding-inline:19px;border-radius:4px}

    /* Full-screen menu */
    .menu-overlay{position:fixed;z-index:140;inset:0;overflow:hidden;background:var(--paper);color:var(--black);opacity:0;visibility:hidden;pointer-events:none;clip-path:inset(0 0 100% 0);transform:translateY(-10px) scale(.985);transform-origin:top center;transition:clip-path .78s var(--ease),opacity .28s ease,transform .78s var(--ease),visibility 0s linear .8s}
    .menu-overlay:before{content:"";position:absolute;z-index:0;inset:0;background:linear-gradient(115deg,rgba(201,165,76,.1),transparent 35%,rgba(8,8,8,.035) 72%);transform:translateY(-100%);transition:transform .92s .08s var(--ease)}
    .menu-overlay.open{opacity:1;visibility:visible;pointer-events:auto;clip-path:inset(0 0 0 0);transform:none;transition:clip-path .78s var(--ease),opacity .28s ease,transform .78s var(--ease),visibility 0s linear 0s}
    .menu-overlay.open:before{transform:translateY(0)}
    .menu-head{position:relative;z-index:1;height:98px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;border-bottom:1px solid var(--line-dark);opacity:0;transform:translateY(-18px);transition:opacity .42s .15s ease,transform .55s .15s var(--ease)}
    .menu-overlay.open .menu-head{opacity:1;transform:none}
    .menu-head .brand-logo{filter:brightness(0)}
    .menu-close{justify-self:center;width:42px;height:42px;border:1px solid #b45038;border-radius:50%;background:transparent;color:#b45038;font-size:29px;font-weight:300;display:grid;place-items:center;transition:background .25s ease,color .25s ease,transform .28s var(--ease)}
    .menu-close:hover{background:#b45038;color:#fff;transform:rotate(90deg)}
    .menu-head .btn{justify-self:end;min-height:46px;border-radius:4px}
    .menu-body{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1.02fr;min-height:calc(100svh - 98px)}
    .menu-primary{display:flex;flex-direction:column;padding:62px clamp(44px,6.2vw,98px) 50px;border-right:1px solid var(--line-dark)}
    .menu-primary a{display:inline-flex;align-items:center;gap:16px;width:max-content;margin:14px 0;font-size:clamp(37px,4.2vw,64px);font-weight:500;line-height:1.05;letter-spacing:-.08em;opacity:0;transform:translateY(28px);transition:color .25s ease,transform .25s var(--ease),opacity .48s ease} 
    .menu-overlay.open .menu-primary a{opacity:1;transform:none}
    .menu-overlay.open .menu-primary a:nth-child(1){transition-delay:.20s}.menu-overlay.open .menu-primary a:nth-child(2){transition-delay:.29s}.menu-overlay.open .menu-primary a:nth-child(3){transition-delay:.38s}.menu-overlay.open .menu-primary a:nth-child(4){transition-delay:.47s}.menu-overlay.open .menu-primary a:nth-child(5){transition-delay:.56s}
    .menu-primary a:after{content:"↗";opacity:0;font:400 25px/1 var(--serif);transform:translate(-10px,4px);transition:opacity .25s ease,transform .25s var(--ease)}
    .menu-primary a:hover{color:var(--gold)}
    .menu-primary a:hover:after{opacity:1;transform:translate(0,4px)}
    .menu-primary small{display:block;margin-top:auto;padding-top:32px;color:#706a60;font:400 clamp(20px,1.8vw,27px)/1.12 var(--serif);letter-spacing:-.035em;max-width:300px}.menu-mobile-note{display:none!important}.menu-mobile-socials{display:none}
    .menu-featured{padding:88px clamp(44px,6.2vw,98px) 52px;display:flex;flex-direction:column;opacity:0;transform:translateX(34px);transition:opacity .55s .28s ease,transform .68s .28s var(--ease)}
    .menu-overlay.open .menu-featured{opacity:1;transform:none}
    .menu-featured > p{margin:0 0 23px;color:#7b766e;font-size:10px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}
    .feature-link{display:grid;grid-template-columns:112px 1fr auto;align-items:center;gap:28px;padding:31px 0;border-top:1px solid var(--line-dark);transition:transform .25s var(--ease)}
    .feature-link:last-of-type{border-bottom:1px solid var(--line-dark)}
    .feature-link:hover{transform:translateX(7px)}
    .feature-link img{width:112px;height:76px;object-fit:cover;background:#151411}
    .feature-link small{display:block;color:#77736b;font-size:10px;line-height:1.45}.feature-link h3{margin:7px 0 0;font-size:clamp(16px,1.5vw,22px);font-weight:500;line-height:1.02;letter-spacing:-.06em}.feature-link em{color:#7f7a71;font-size:10px;font-style:normal;white-space:nowrap}
    .menu-contact{display:flex;justify-content:space-between;gap:18px;margin-top:auto;padding-top:28px;color:#7a766e;font-size:12px;line-height:1.5}

    /* Full-bleed hero film — temporary clips can be replaced with licensed Pexels / Keris footage */
    .hero{position:relative;min-height:640px;height:100svh;height:100dvh;overflow:hidden;background:#080808;isolation:isolate}
    .hero-bg{display:none}
    .hero-backdrop{position:absolute;z-index:1;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(6,6,6,.82) 0%,rgba(6,6,6,.36) 47%,rgba(6,6,6,.6) 100%),linear-gradient(0deg,rgba(5,5,5,.86) 0%,rgba(5,5,5,.12) 54%,rgba(5,5,5,.4) 100%)}
    .hero-grain{position:absolute;z-index:2;inset:0;opacity:.16;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:5px 5px;mix-blend-mode:soft-light}
    .hero-stage{position:absolute;z-index:0;inset:0;width:100%;height:100%;min-height:100%;overflow:hidden;background:#151310;box-shadow:none}
    .stage-film{position:absolute;inset:0;opacity:0;transition:opacity 1.08s ease}.stage-film.active{opacity:1}.stage-film video{width:100%;height:100%;object-fit:cover;filter:brightness(.72) contrast(1.1) saturate(.7) sepia(.08);transform:scale(1.03)}
    .stage-film:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,6,6,.5),transparent 62%,rgba(6,6,6,.26))}
    .hero-shell{position:relative;z-index:3;height:100%;padding-top:95px}
    .hero-title{position:absolute;left:0;bottom:clamp(82px,12vh,112px);max-width:1060px;margin:0;color:var(--paper);font-size:clamp(68px,9.2vw,138px);font-weight:400;line-height:.86;letter-spacing:-.07em;font-optical-sizing:auto}
    .hero-title span{display:block;overflow:hidden}.hero-title strong{display:block;transform:translateY(105%);animation:titleRise 1s var(--ease) forwards}.hero-title span:nth-child(2) strong{animation-delay:.12s}.hero-title em{font-family:var(--serif);font-weight:400;letter-spacing:-.06em;font-optical-sizing:auto}
    @keyframes titleRise{to{transform:translateY(0)}}
    .hero-note{position:absolute;right:0;bottom:116px;width:min(265px,23vw);margin:0;color:rgba(251,250,246,.89);font-size:14px;font-weight:600;line-height:1.35;letter-spacing:-.04em;transform:translateY(12px);opacity:0;animation:fadeUp .7s .48s var(--ease) forwards}
    .hero-note b{display:block;margin-bottom:13px;color:var(--gold-soft);font-size:10px;letter-spacing:.13em;text-transform:uppercase}
    .hero-scroll{position:absolute;left:0;bottom:39px;display:flex;align-items:center;gap:11px;color:rgba(251,250,246,.76);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;transform:translateY(12px);opacity:0;animation:fadeUp .7s .56s var(--ease) forwards}
    .hero-scroll .down{font-size:17px;font-weight:400}.film-count{position:absolute;z-index:4;right:max(23px,4vw);bottom:30px;display:flex;align-items:center;gap:8px;color:#f4ead2;font-size:9px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.film-count i{display:block;width:37px;height:1px;background:rgba(251,250,246,.52);position:relative;overflow:hidden}.film-count i:after{content:"";position:absolute;inset:0 auto 0 0;width:35%;background:var(--gold-soft);transition:transform .8s var(--ease)}.film-count i.one:after{transform:translateX(0)}.film-count i.two:after{transform:translateX(100%)}.film-count i.three:after{transform:translateX(200%)}
    @keyframes fadeUp{to{transform:none;opacity:1}}

    /* Service-only moving banner */
    .service-marquee{overflow:hidden;background:var(--paper);color:var(--black);border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);white-space:nowrap}
    .marquee-track{display:flex;width:max-content;animation:marquee 30s linear infinite}
    .marquee-track span{display:flex;align-items:center;height:92px;padding:0 39px;font:400 clamp(29px,3vw,46px)/1 var(--serif);letter-spacing:-.055em}
    .marquee-track span:after{content:"";display:block;width:7px;height:7px;margin-left:78px;background:var(--gold);border-radius:50%}
    @keyframes marquee{to{transform:translateX(-50%)}}

    /* Who we are — editorial statement */

    /* Shared section header — used for Who We Are, Keris Gallery and Get In Touch */
    .section-header{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(260px,.75fr);gap:58px;align-items:end;margin-bottom:48px}
    .section-header .section-title{margin-top:18px}
    .section-header .section-copy{max-width:390px;margin:0 0 4px;justify-self:end}
    .section-header.light .eyebrow{color:var(--gold-soft)}
    .section-header.light .section-title{color:var(--paper)}
    .section-header.light .section-copy{color:rgba(251,250,246,.72)}
    .who-we-are{position:relative;overflow:hidden;padding:clamp(112px,13vw,176px) 0 clamp(120px,15vw,218px);background:#000;color:var(--paper);border-bottom:1px solid rgba(251,250,246,.12)}
    .who-we-are:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 11% 15%,rgba(199,155,75,.09),transparent 25%),linear-gradient(112deg,transparent 40%,rgba(255,255,255,.025),transparent 73%)}
    .who-label{position:relative;margin:0 0 32px;color:var(--gold-soft)}
    .who-statement{position:relative;max-width:1240px;margin:0;font:400 clamp(49px,6.22vw,97px)/.99 var(--serif);letter-spacing:-.05em;font-optical-sizing:auto}
    .who-statement .line{display:block;overflow:hidden}
    .who-statement .line > span{display:block;transform:translateY(105%);opacity:0;transition:transform 1.05s var(--ease),opacity 1.05s ease}
    .who-statement .line:nth-child(2) > span{transition-delay:.1s}.who-statement .line:nth-child(3) > span{transition-delay:.2s}.who-statement .line:nth-child(4) > span{transition-delay:.3s}
    .who-statement.in .line > span{transform:none;opacity:1}
    .who-statement em{font-style:italic;font-weight:400;color:var(--gold-soft)}
    .who-note{position:relative;display:flex;align-items:center;justify-content:space-between;gap:22px;margin:38px 0 0;padding-top:18px;border-top:1px solid var(--line-light);color:rgba(251,250,246,.58);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
    .who-note span{display:inline-flex;align-items:center;gap:10px}.who-note span:first-child:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold)}


    /* Our Engagement — partner logo carousel + testimonials */
    .engagement{position:relative;padding:118px 0 0;background:#f7f1ec;color:var(--black);overflow:hidden}
    .engagement:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 86% 10%,rgba(201,165,76,.11),transparent 24%),linear-gradient(180deg,rgba(255,255,255,.62),transparent 36%)}
    .engagement-head{position:relative;z-index:1;margin-bottom:52px}
    .engagement-head .section-title{color:var(--black)}
    .engagement-head .section-copy{color:#5d6673}
    .engagement-marquee{position:relative;z-index:1;padding:0 0 80px;overflow:hidden}
    .engagement-marquee:before,.engagement-marquee:after{content:"";position:absolute;z-index:3;top:0;bottom:80px;width:clamp(54px,10vw,150px);pointer-events:none}
    .engagement-marquee:before{left:0;background:linear-gradient(90deg,#f7f1ec,rgba(247,241,236,0))}
    .engagement-marquee:after{right:0;background:linear-gradient(270deg,#f7f1ec,rgba(247,241,236,0))}
    .engagement-marquee .partner-track{display:flex;align-items:center;width:max-content;will-change:transform;animation:partnerMarquee 34s linear infinite}
    .engagement-marquee .partner-group{display:flex;align-items:center;gap:20px;padding-right:20px;flex:none}
    .partner-card{display:flex;position:relative;align-items:center;justify-content:center;width:224px;height:96px;margin:0;padding:20px 28px;border:1px solid rgba(122,73,45,.13);border-radius:14px;background:rgba(255,255,255,.92);box-shadow:0 10px 26px rgba(72,45,31,.08);overflow:hidden;flex:none}
    .partner-card img{display:block;max-width:100%;max-height:54px;width:auto;height:auto;object-fit:contain;filter:grayscale(1) opacity(.72);transition:filter .28s ease,transform .28s var(--ease)}
    .partner-card:hover img{filter:none;transform:scale(1.04)}
    .partner-card figcaption{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
    .partner-card-plaza img{max-height:68px}
    .partner-card-popgo img{max-height:46px;filter:none;opacity:.82}
    .engagement-testimonials{position:relative;z-index:1;margin-top:0;padding:124px 0 136px;background:#090909;color:var(--paper)}
    .testimonials-head{display:grid;grid-template-columns:1fr minmax(260px,370px);gap:34px;align-items:end;margin-bottom:46px}
    .testimonials-head .eyebrow{color:var(--gold-soft)}
    .testimonials-head h2{max-width:700px;margin:19px 0 0;font:400 clamp(54px,6vw,92px)/.91 var(--serif);letter-spacing:-.06em}
    .testimonials-head p:last-child{margin:0;color:rgba(251,250,246,.68);font-size:13px;line-height:1.68}
    .testimonial-grid{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(251,250,246,.22);border-bottom:1px solid rgba(251,250,246,.22)}
    .testimonial{position:relative;display:flex;min-height:330px;flex-direction:column;padding:34px 36px 30px}
    .testimonial + .testimonial{border-left:1px solid rgba(251,250,246,.22)}
    .testimonial-mark{color:var(--gold-soft);font:400 80px/.65 var(--serif)}
.testimonial blockquote{max-width:560px;margin:34px 0 0;font:700 clamp(28px,2.7vw,43px)/1.08 var(--sans);letter-spacing:-.05em}
    .testimonial footer{margin-top:auto;padding:30px 0 0;border:0;background:transparent;color:rgba(251,250,246,.62);font-size:10px;font-style:normal;font-weight:800;letter-spacing:.13em;text-transform:uppercase}
    .testimonial footer span{display:block;margin-top:7px;color:rgba(251,250,246,.42);font-size:9px;font-weight:500;letter-spacing:.1em}
    .testimonial-note{margin-top:18px;color:rgba(251,250,246,.45);font-size:10px;line-height:1.55}
    @keyframes partnerMarquee{to{transform:translateX(-50%)}}

    /* Services */
    .services{padding:138px 0 145px;background:var(--paper);color:var(--black)}
    .service-intro{display:grid;grid-template-columns:1.05fr .95fr;align-items:end;gap:60px;margin-bottom:52px}
    .service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
    .service-card{display:flex;min-height:690px;flex-direction:column;padding:0;border:1px solid var(--line-dark);background:#fff;color:var(--black);overflow:hidden;text-align:left;transition:transform .35s var(--ease),box-shadow .35s ease}
    .service-card:hover{transform:translateY(-6px);box-shadow:0 24px 52px rgba(0,0,0,.12)}
    .service-card:focus-visible{outline:3px solid var(--gold);outline-offset:4px}
    .service-image{height:350px;overflow:hidden;position:relative;background:#161512}.service-image:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.22),transparent 58%)}.service-image img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.service-card:hover .service-image img{transform:scale(1.065)}
    .service-body{display:flex;flex:1;flex-direction:column;padding:23px 25px 25px}.service-top{display:flex;align-items:center;justify-content:space-between}.service-number{color:#8c692f;font-size:9px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.service-icon{display:grid;place-items:center;width:46px;height:46px;border:1px solid rgba(199,155,75,.82);color:#8c692f}.service-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.45}
    .service-card h3{max-width:330px;margin:44px 0 0;font:400 clamp(47px,4vw,65px)/.86 var(--serif);letter-spacing:-.055em;font-optical-sizing:auto}.service-card h3.wide{font-size:clamp(40px,3.6vw,58px)}
    .service-card p{margin:18px 0 0;color:#605c54;font-size:12px;line-height:1.68}.service-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:23px}.service-tags span{padding:6px 8px;border:1px solid var(--line-dark);color:#5e5a52;font-size:9px;letter-spacing:.035em}.service-link{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:23px;border-top:1px solid var(--line-dark);color:#7c5d28;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.service-link b{font:400 25px/1 var(--serif)}

    /* Booking */

    .gallery-section{position:relative;padding:142px 0 152px;background:#090909;color:var(--paper);overflow:hidden}
    .gallery-section:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 24%,rgba(201,165,76,.08),transparent 24%),radial-gradient(circle at 82% 78%,rgba(201,165,76,.05),transparent 28%),linear-gradient(180deg,rgba(255,255,255,.02),transparent 18%,transparent 84%,rgba(255,255,255,.02));opacity:.85}
    .gallery-section:after{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(180deg,rgba(255,255,255,.018) 0,rgba(255,255,255,.018) 1px,transparent 1px,transparent 7px);mix-blend-mode:soft-light;opacity:.16}
    /* Keep the Keris Gallery heading in the same editorial system as What We Do. */
    .gallery-head{position:relative;z-index:2;margin-bottom:52px}
    .gallery-head .section-title{margin-top:19px;color:var(--paper)}
    .gallery-head .section-copy{max-width:410px;color:rgba(251,250,246,.74)}
    .gallery-stage{position:relative;z-index:2;width:min(1500px,calc(100vw - 56px));height:clamp(760px,72vw,1030px);margin:0 auto}
    .gallery-scene{position:relative;width:100%;height:100%}
    .gallery-scene:hover .gallery-card{opacity:.7}.gallery-scene:hover .gallery-card:hover{opacity:1}
    .gallery-card{position:absolute;top:var(--t);left:var(--l);width:var(--w);height:var(--h);opacity:0;transform:translate3d(var(--px,0px),calc(var(--py,0px) + 34px),0);transition:opacity .9s ease,transform .9s var(--ease),filter .45s ease,box-shadow .45s ease;transition-delay:var(--delay,0s);will-change:transform,opacity;z-index:var(--z,1)}
    .gallery-section.in .gallery-card{opacity:1;transform:translate3d(var(--px,0px),var(--py,0px),0)}
    .gallery-card-float{position:relative;width:100%;height:100%;overflow:hidden;border-radius:6px;background:#161616;box-shadow:0 24px 64px rgba(0,0,0,.34);animation:galleryDriftA var(--dur,18s) cubic-bezier(.44,0,.27,1) infinite;animation-delay:calc(var(--delay,0s) * -2);will-change:transform}
    .gallery-card.feature .gallery-card-float,.gallery-card.hero .gallery-card-float{box-shadow:0 30px 82px rgba(0,0,0,.44),0 0 28px rgba(201,165,76,.09)}
    .gallery-card:nth-child(2) .gallery-card-float{animation-name:galleryDriftB}.gallery-card:nth-child(3) .gallery-card-float{animation-name:galleryDriftC}.gallery-card:nth-child(4) .gallery-card-float{animation-name:galleryDriftD}.gallery-card:nth-child(5) .gallery-card-float{animation-name:galleryDriftE}.gallery-card:nth-child(6) .gallery-card-float{animation-name:galleryDriftB}.gallery-card:nth-child(7) .gallery-card-float{animation-name:galleryDriftD}.gallery-card:nth-child(8) .gallery-card-float{animation-name:galleryDriftC}.gallery-card:nth-child(9) .gallery-card-float{animation-name:galleryDriftE}
    .gallery-card img{display:block;width:100%;height:100%;object-fit:cover;filter:saturate(.92) contrast(1.04) brightness(.92);transition:transform .8s var(--ease),filter .45s ease}
    .gallery-card figcaption{position:absolute;left:14px;right:14px;bottom:14px;z-index:2;padding-top:34px;color:var(--paper);pointer-events:none;background:linear-gradient(180deg,transparent,rgba(0,0,0,.7));text-shadow:0 12px 28px rgba(0,0,0,.55)}
    .gallery-card figcaption small{display:block;color:var(--gold-soft);font-size:8px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}
    .gallery-card figcaption span{display:block;margin-top:5px;font-size:13px;font-weight:800;letter-spacing:-.035em}
    .gallery-card.is-logo img{object-fit:contain;padding:clamp(22px,3vw,48px);background:#111;filter:grayscale(1) brightness(.95) contrast(.96)}
    .gallery-card.is-popgo .gallery-card-float{background:#f4f1e8}
    .gallery-card.is-popgo img{background:#f4f1e8;filter:none;object-fit:contain}
    .gallery-card:hover{z-index:20}.gallery-card:hover .gallery-card-float{box-shadow:0 34px 96px rgba(0,0,0,.52),0 0 34px rgba(201,165,76,.14)}
    .gallery-card[role="button"]{cursor:pointer}
    .gallery-card[role="button"]:focus-visible{outline:2px solid var(--gold-soft);outline-offset:6px}
    .gallery-card:hover img{transform:scale(1.04);filter:saturate(1.02) contrast(1.06) brightness(.99)}
    .gallery-scene:hover .gallery-card:not(:hover) img{filter:saturate(.74) contrast(.98) brightness(.74)}
    /* Continuous closed-loop drift: cards never settle, but the movement stays slow and restrained. */
    @keyframes galleryDriftA{0%{transform:translate3d(0,0,0) rotate(0deg)}26%{transform:translate3d(7px,-10px,0) rotate(.12deg)}55%{transform:translate3d(-4px,-15px,0) rotate(-.1deg)}78%{transform:translate3d(-8px,4px,0) rotate(-.05deg)}100%{transform:translate3d(0,0,0) rotate(0deg)}}
    @keyframes galleryDriftB{0%{transform:translate3d(0,0,0) rotate(0deg)}28%{transform:translate3d(-9px,7px,0) rotate(-.13deg)}58%{transform:translate3d(5px,13px,0) rotate(.09deg)}82%{transform:translate3d(8px,-5px,0) rotate(.05deg)}100%{transform:translate3d(0,0,0) rotate(0deg)}}
    @keyframes galleryDriftC{0%{transform:translate3d(0,0,0)}24%{transform:translate3d(5px,8px,0)}52%{transform:translate3d(-8px,-9px,0)}76%{transform:translate3d(4px,-13px,0)}100%{transform:translate3d(0,0,0)}}
    @keyframes galleryDriftD{0%{transform:translate3d(0,0,0) rotate(0deg)}30%{transform:translate3d(-7px,-9px,0) rotate(.1deg)}57%{transform:translate3d(9px,-4px,0) rotate(-.11deg)}81%{transform:translate3d(4px,9px,0) rotate(.06deg)}100%{transform:translate3d(0,0,0) rotate(0deg)}}
    @keyframes galleryDriftE{0%{transform:translate3d(0,0,0)}27%{transform:translate3d(10px,-6px,0)}56%{transform:translate3d(-5px,10px,0)}79%{transform:translate3d(-8px,-7px,0)}100%{transform:translate3d(0,0,0)}}


    .gallery-more{display:none}
    @media (prefers-reduced-motion: reduce){.gallery-card-float{animation:none!important}.gallery-card{transition:none}.gallery-card img{transition:none}}
    .booking-section-header{position:relative;margin-bottom:48px}
    .booking-section-header .section-copy{color:rgba(251,250,246,.72)}
    .booking{position:relative;padding:125px 0 108px;background:var(--black);overflow:hidden}.booking:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 8% 16%,rgba(199,155,75,.16),transparent 31%),radial-gradient(circle at 88% 90%,rgba(199,155,75,.09),transparent 28%)}
    .booking-wrap{position:relative}.booking-layout{display:grid;grid-template-columns:.86fr 1.14fr;border:1px solid var(--line-light)}
    .booking-visual{position:relative;min-height:615px;overflow:hidden;border-right:1px solid var(--line-light)}.booking-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.92}.booking-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(9,9,9,.96),rgba(9,9,9,.03) 67%)}
    .booking-copy{position:absolute;z-index:2;left:34px;right:34px;bottom:34px}.booking-copy h2{margin:18px 0 0;font:400 clamp(44px,4.4vw,70px)/.9 var(--serif);letter-spacing:-.055em;font-optical-sizing:auto}.booking-copy p:last-child{max-width:330px;margin:17px 0 0;color:rgba(251,250,246,.7);font-size:12px;line-height:1.67}
    .booking-icons{display:flex;gap:9px;margin-top:23px}.booking-icons span{display:grid;place-items:center;width:40px;height:40px;border:1px solid rgba(230,201,137,.62);color:var(--gold-soft)}.booking-icons svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.5}
    .form-panel{padding:40px 38px;background:var(--paper);color:var(--black)}.form-heading{display:flex;align-items:end;justify-content:space-between;gap:26px;padding-bottom:24px;border-bottom:1px solid var(--line-dark)}.form-heading h3{margin:17px 0 0;font:400 43px/.94 var(--serif);letter-spacing:-.05em;font-optical-sizing:auto}.form-heading > p{max-width:220px;margin:0;color:#68635b;text-align:right;font-size:11px;line-height:1.62}
    .form{margin-top:27px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:17px}.field{display:flex;flex-direction:column;gap:8px}.field label{color:#80632d;font-size:9px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.field input,.field select{height:49px;padding:0 13px;border:1px solid rgba(9,9,9,.22);background:white;color:var(--black);outline:none;font-size:12px;transition:border .2s ease,box-shadow .2s ease}.field input:focus,.field select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(199,155,75,.13)}
    .form-submit{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:26px}.form-submit small{max-width:225px;color:#716c64;font-size:10px;line-height:1.56}.form-note{display:none;margin-top:15px;padding:12px 13px;background:#edf4e9;border:1px solid #b7d0ae;color:#254c31;font-size:11px;line-height:1.5}.form-note.show{display:block}
    /* The process — intentionally separate from the booking form */
    .process-section{padding:122px 0 126px;background:#f4f5ef;color:var(--black)}
    .process-heading{display:block;margin-bottom:42px;text-align:center}.process-kicker{display:block;color:#35592b;font-size:12px;font-weight:800;letter-spacing:.28em;text-transform:uppercase}.process-heading h2{margin:14px auto 0;max-width:920px;font:400 clamp(52px,5.7vw,78px)/.95 var(--sans);letter-spacing:-.06em;font-weight:800}.process-heading h2 em{font-style:normal;color:#4d8b39}.process-heading p{max-width:560px;margin:16px auto 0;color:#6a6d60;font-size:14px;line-height:1.65}
    .process{padding:0;background:transparent;color:var(--black);border:0}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.process-step{min-height:388px;padding:24px;border:1px solid #d8ddd0;border-radius:28px;background:#fbfcf8;box-shadow:0 8px 22px rgba(44,54,29,.04)}.process-visual{display:grid;place-items:center;height:128px;margin-bottom:20px;border-radius:24px;background:#ebefe6}.process-icon{display:grid;place-items:center;width:72px;height:72px;color:#315126}.process-icon svg{width:54px;height:54px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}.process-step span{display:block;color:#1b4d1f;font-size:18px;font-weight:800;letter-spacing:-.04em;text-transform:none}.process-step h4{margin:8px 0 0;font:800 24px/1.1 var(--sans);letter-spacing:-.04em}.process-step p{margin:12px 0 0;color:#586055;font-size:14px;line-height:1.68}
    .process-visual{background:linear-gradient(135deg,#eef3e9,#dfe8d7)}
    .process-icon{width:78px;height:78px;border:1px solid rgba(49,81,38,.16);border-radius:22px;background:rgba(255,255,255,.82);box-shadow:0 14px 30px rgba(49,81,38,.12),inset 0 1px 0 rgba(255,255,255,.86)}
    .process-icon img{display:block;width:48px;height:48px;object-fit:contain}
    .process-icon svg{width:46px;height:46px;stroke:#294b22;stroke-width:1.75}
    @media(max-width:720px){.brand-logo{width:132px;height:38px}.process-icon img{width:38px;height:38px}}

    /* Footer */
    footer{padding:60px 0 32px;border-top:1px solid var(--line-light);background:#080808}.footer-top{display:grid;grid-template-columns:1.1fr .9fr .8fr;gap:38px;padding-bottom:49px}.footer-lead{max-width:280px;margin:20px 0 0;color:rgba(251,250,246,.7);font:400 25px/1.08 var(--serif);letter-spacing:-.03em;font-optical-sizing:auto}.footer-title{margin:0 0 15px;color:var(--gold-soft);font-size:9px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.footer-nav,.socials{display:grid;gap:10px}.footer-nav a,.socials a{width:max-content;color:rgba(251,250,246,.84);font-size:12px;transition:color .2s ease}.footer-nav a:hover,.socials a:hover{color:var(--gold-soft)}.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-top:20px;border-top:1px solid var(--line-light);color:rgba(251,250,246,.48);font-size:10px}.address{line-height:1.55;text-align:right}

    /* Service dialog */
    .modal{position:fixed;z-index:160;inset:0;display:grid;place-items:center;padding:20px;background:rgba(0,0,0,.7);opacity:0;pointer-events:none;transition:opacity .3s ease}.modal.open{opacity:1;pointer-events:auto}.modal-window{width:min(1120px,100%);max-height:calc(100svh - 40px);overflow:auto;background:var(--paper);color:var(--black);transform:translateY(18px);transition:transform .35s var(--ease)}.modal.open .modal-window{transform:none}.modal-top{display:flex;align-items:center;justify-content:space-between;height:66px;padding:0 25px;border-bottom:1px solid var(--line-dark)}.modal-top span{color:#80612d;font-size:9px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.modal-close{border:0;background:transparent;color:var(--black);font-size:33px;font-weight:300;line-height:1}.modal-content{padding:42px}.modal-lead{display:grid;grid-template-columns:1fr .85fr;align-items:end;gap:56px}.modal-lead h2{margin:19px 0 0;font:400 clamp(44px,5.1vw,72px)/.91 var(--serif);letter-spacing:-.055em;font-optical-sizing:auto}.modal-lead > p{margin:0;color:#635f57;font-size:13px;line-height:1.72}.modal-image{height:330px;margin-top:42px;background:#151411;overflow:hidden}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-meta{display:grid;grid-template-columns:repeat(3,1fr);margin-top:16px;border:1px solid var(--line-dark)}.modal-meta article{padding:20px;border-right:1px solid var(--line-dark)}.modal-meta article:last-child{border-right:0}.modal-meta svg{width:22px;height:22px;stroke:#8c672d;fill:none;stroke-width:1.45}.modal-meta h4{margin:20px 0 0;font:400 24px/.96 var(--serif);letter-spacing:-.04em}.modal-meta p{margin:9px 0 0;color:#656158;font-size:11px;line-height:1.58}.modal-work{margin-top:48px}.modal-work-heading{display:flex;align-items:end;justify-content:space-between;gap:25px}.modal-work-heading h3{margin:0;font:400 38px/.95 var(--serif);letter-spacing:-.045em;font-optical-sizing:auto}.modal-work-heading p{max-width:325px;margin:0;color:#666158;text-align:right;font-size:11px;line-height:1.6}.project-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:22px}.project-card{border:1px solid var(--line-dark);background:#fff}.project-card img{display:block;width:100%;height:210px;object-fit:cover}.project-card div{padding:17px}.project-card small{color:#8c672b;font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.project-card h4{margin:13px 0 0;font:400 27px/1 var(--serif);letter-spacing:-.04em;font-optical-sizing:auto}.project-card p{margin:8px 0 0;color:#68645c;font-size:11px;line-height:1.56}.modal-action{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:22px;padding-top:22px;border-top:1px solid var(--line-dark)}.modal-action p{max-width:520px;margin:0;color:#646058;font-size:12px;line-height:1.6}
    .portfolio-window{width:min(1180px,100%)}
    .portfolio-media-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:34px}
    .portfolio-media-card{min-height:310px;overflow:hidden;border:1px solid var(--line-dark);background:#111}
    .portfolio-media-card img,.portfolio-media-card video{display:block;width:100%;height:100%;min-height:310px;object-fit:cover}
    .portfolio-media-card.is-logo{display:grid;place-items:center;background:#111}
    .portfolio-media-card.is-logo img{width:min(64%,360px);height:auto;max-height:220px;min-height:0;object-fit:contain;filter:grayscale(1) brightness(.95)}
    .portfolio-media-card.is-popgo{background:#f4f1e8}
    .portfolio-media-card.is-popgo img{width:min(70%,420px);max-height:190px;filter:none}
    .project-card[role="button"]{cursor:pointer;transition:transform .25s var(--ease),box-shadow .25s ease}
    .project-card[role="button"]:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(0,0,0,.12)}
    .project-card[role="button"]:focus-visible{outline:2px solid var(--gold);outline-offset:4px}
    .project-card.is-logo-card img{object-fit:contain;padding:32px;background:#111;filter:grayscale(1) brightness(.96)}
    .project-card.is-logo-card.is-popgo img{background:#f4f1e8;filter:none;padding:36px}



    /* Premium corporate media, refined service compositions, and expanded project form */
    .reel-stamp{position:absolute;z-index:2;left:max(18px,4vw);top:calc(95px + 33px);padding:8px 11px;border:1px solid rgba(251,250,246,.52);background:rgba(9,9,9,.3);backdrop-filter:blur(8px);color:rgba(251,250,246,.92);font-size:9px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
    .service-image{background:#12110f}.service-image img{object-position:center}
    .field-full{grid-column:1 / -1}
    .field textarea{display:block;width:100%;min-height:130px;resize:vertical;padding:14px 0 12px;border:0;border-bottom:1px solid rgba(9,9,9,.3);outline:0;background:transparent;color:#151411;font-size:13px;line-height:1.55}
    .field textarea:focus{border-bottom-color:#956e2f}.field textarea::placeholder{color:#89847a}
    .booking-photo{position:relative;display:block;min-height:620px;overflow:hidden;background:#16130f}
    .booking-photo img{display:block;width:100%;height:100%;object-fit:cover;filter:saturate(.68) contrast(1.03) brightness(.72);transition:transform 1.15s var(--ease),filter .55s ease}
    .booking-photo:hover img{transform:scale(1.05);filter:saturate(.8) contrast(1.04) brightness(.78)}
    .booking-photo:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(9,9,9,.84) 0%,rgba(9,9,9,.48) 44%,rgba(9,9,9,.16) 76%),linear-gradient(0deg,rgba(9,9,9,.58),transparent 54%);pointer-events:none}
    .booking-overlay{position:absolute;z-index:1;left:clamp(28px,4vw,58px);right:18%;bottom:clamp(32px,5vw,59px);max-width:430px}.booking-overlay h2{margin:18px 0 15px;font:400 clamp(43px,4.4vw,67px)/.91 var(--serif);letter-spacing:-.05em}.booking-overlay > p:last-of-type{margin:0;color:rgba(251,250,246,.76);font-size:12px;line-height:1.68}.booking-overlay .eyebrow{color:var(--gold-soft)}

    .reveal{opacity:0;transform:translateY(28px);transition:opacity .72s ease,transform .72s var(--ease)}.reveal.in{opacity:1;transform:none}


    /* Desktop menu fit: preserve breathing room at 100% zoom while still fitting shorter laptop screens. */
    @media (min-width:721px){
      .menu-overlay{overflow-y:auto;overflow-x:hidden}
      .menu-primary{gap:clamp(12px,2vh,24px)}
      .menu-primary a{margin:0}
      .menu-desktop-note{
        margin-top:auto;
        padding-top:clamp(26px,4vh,48px);
        color:#706a60;
        font-family:var(--sans);
        font-size:clamp(16px,1.35vw,20px);
        font-weight:500;
        line-height:1.18;
        letter-spacing:-.055em;
        max-width:320px;
      }
    }
    @media (min-width:721px) and (max-height:760px){
      .menu-head{height:84px}
      .menu-body{min-height:calc(100svh - 84px)}
      .menu-primary{padding:28px clamp(34px,5vw,72px) 22px;gap:clamp(8px,1.25vh,13px)}
      .menu-primary a{margin:0;font-size:clamp(34px,3.75vw,54px);line-height:1.02}
      .menu-primary .menu-desktop-note{margin-top:auto;padding-top:18px;font-size:15px;line-height:1.25;max-width:270px}
      .menu-featured{padding:34px clamp(34px,5vw,72px) 24px}
      .menu-featured > p{margin-bottom:13px}
      .feature-link{grid-template-columns:88px minmax(0,1fr) auto;gap:18px;padding:14px 0}
      .feature-link img{width:88px;height:60px}
      .feature-link h3{margin-top:5px;font-size:clamp(15px,1.45vw,19px)}
      .feature-link small,.feature-link em{font-size:9px}
      .menu-contact{padding-top:15px;font-size:10px}
    }

    @media(max-width:1040px){
      .shell{width:calc(100% - 56px)}.hero{height:100svh;height:100dvh;min-height:680px}.hero-stage{inset:0;width:100%;height:100%;min-height:100%}.hero-title{max-width:760px}.hero-note{width:230px}.menu-body{grid-template-columns:1fr}.menu-primary{border-right:0;border-bottom:1px solid var(--line-dark);min-height:49svh}.menu-featured{padding-top:34px}.service-intro,.booking-layout,.modal-lead,.who-grid{grid-template-columns:1fr}.who-media{min-height:430px}.who-copy{max-width:720px}.booking-visual{min-height:420px;border-right:0;border-bottom:1px solid var(--line-light)}.service-card{min-height:635px}.form-panel{padding:35px 29px}
    }
    @media(max-width:720px){
      .shell{width:calc(100% - 32px)}.site-header,.nav{height:78px}.brand span:last-child{display:none}.nav-cta{min-height:42px;padding-inline:12px;font-size:8px}.menu-overlay{opacity:1;visibility:hidden;clip-path:inset(0 0 100% 0);transform:translateY(-18px);transform-origin:top center;transition:clip-path .68s var(--ease),transform .68s var(--ease),visibility 0s linear .7s}.menu-overlay:before{background:linear-gradient(145deg,rgba(201,165,76,.12),transparent 42%);transform:translateY(-100%);transition:transform .8s .06s var(--ease)}.menu-overlay.open{visibility:visible;clip-path:inset(0 0 0 0);transform:none;transition:clip-path .68s var(--ease),transform .68s var(--ease),visibility 0s linear 0s}.menu-overlay.open:before{transform:none}.menu-head{height:78px;display:flex;justify-content:space-between;gap:14px;transform:translateY(-13px);transition:opacity .3s .14s ease,transform .44s .14s var(--ease)}.menu-body{transform:translateY(-8px);opacity:0;transition:transform .48s .14s var(--ease),opacity .3s .14s ease}.menu-overlay.open .menu-body{transform:none;opacity:1}.menu-head .brand{justify-self:start}.menu-head .brand span:last-child{display:inline}.menu-head .btn{display:none}.menu-close{justify-self:end;width:36px;height:36px;font-size:24px}.menu-body{display:block;min-height:calc(100svh - 78px)}.menu-primary{min-height:calc(100svh - 78px);padding:30px 12px 28px;border:0}.menu-primary a{display:flex;width:100%;min-height:66px;align-items:center;margin:0;padding:14px 2px;border:0;font-size:29px;line-height:1.02;letter-spacing:-.065em;transform:translateY(-14px);transition:color .22s ease,transform .38s var(--ease),opacity .46s ease}.menu-overlay.open .menu-primary a:nth-child(1){transition-delay:.18s}.menu-overlay.open .menu-primary a:nth-child(2){transition-delay:.25s}.menu-overlay.open .menu-primary a:nth-child(3){transition-delay:.32s}.menu-overlay.open .menu-primary a:nth-child(4){transition-delay:.39s}.menu-overlay.open .menu-primary a:nth-child(5){transition-delay:.46s}.menu-primary a:after{display:none}.menu-primary a:hover{color:var(--black);transform:translateY(-2px)}.menu-desktop-note{display:none!important}.menu-mobile-socials{display:grid!important;grid-template-columns:1fr;gap:9px;width:100%;margin-top:auto;padding-top:32px}.menu-mobile-socials a{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:48px;margin:0;padding:13px 14px;border:1px solid rgba(9,9,9,.18);border-left:3px solid var(--gold);border-radius:0;color:#24211c;font-size:12px;font-weight:800;letter-spacing:.08em;line-height:1;text-transform:uppercase;opacity:0;transform:translateY(18px);transition:background .25s ease,color .25s ease,border-color .25s ease,opacity .42s ease,transform .48s var(--ease)}.menu-mobile-socials a:after{content:"↗";font:400 20px/1 var(--serif);letter-spacing:0}.menu-overlay.open .menu-mobile-socials a{opacity:1;transform:none}.menu-overlay.open .menu-mobile-socials a:nth-child(1){transition-delay:.58s}.menu-overlay.open .menu-mobile-socials a:nth-child(2){transition-delay:.64s}.menu-overlay.open .menu-mobile-socials a:nth-child(3){transition-delay:.70s}.menu-mobile-socials a:hover{background:var(--black);border-color:var(--black);border-left-color:var(--gold);color:var(--paper)}.menu-mobile-note{display:block!important;margin-top:18px!important;padding-top:0!important;font-size:11px!important;line-height:1.45!important;color:#777169!important;opacity:0;transform:translateY(12px);transition:opacity .45s .76s ease,transform .5s .76s var(--ease)}.menu-overlay.open .menu-mobile-note{opacity:1;transform:none}.menu-featured{display:none}

      .booking-photo{min-height:530px}.booking-overlay{left:24px;right:20px;bottom:28px}.booking-overlay h2{font-size:52px}.field-full{grid-column:auto}
      .section-header{grid-template-columns:1fr;gap:14px;margin-bottom:32px}.section-header .section-title{font-size:64px}.section-header .section-copy{justify-self:start;max-width:520px}.who-we-are{padding:100px 0 98px}.who-statement{font-size:clamp(47px,12vw,72px);line-height:.98;letter-spacing:-.07em}.who-note{margin-top:28px;align-items:flex-start;flex-direction:column;gap:10px;font-size:9px;line-height:1.35}.engagement{padding-top:58px}.engagement-head{margin-bottom:34px}.engagement-head .section-title{font-size:64px}.engagement-marquee .partner-group{gap:20px;padding-right:20px}.partner-card{width:204px;height:90px}.engagement-testimonials{padding:84px 0}.testimonials-head{grid-template-columns:1fr;gap:14px;margin-bottom:30px}.testimonial-grid{grid-template-columns:1fr}.testimonial{min-height:285px;padding:28px 20px}.testimonial + .testimonial{border-left:0;border-top:1px solid rgba(251,250,246,.22)}.testimonial blockquote{font-size:34px}
      .hero{height:100svh;height:100dvh;min-height:680px}.hero-stage{inset:0;width:100%;height:100%;min-height:100%}.hero-title{left:0;right:0;bottom:96px;font-size:clamp(56px,15.3vw,86px);line-height:.84}.hero-note{display:none}.hero-scroll{bottom:34px}.film-count{right:16px;bottom:22px}.reel-stamp{left:16px;top:100px}.service-marquee .marquee-track span{height:65px;padding:0 20px;font-size:28px}.marquee-track span:after{width:5px;height:5px;margin-left:40px}.services,.booking,.gallery-section{padding:84px 0}.who-we-are,.process-section{padding:84px 0}.service-intro{gap:23px;margin-bottom:31px}.who-media{min-height:365px}.who-copy .section-title{font-size:64px}.who-points{grid-template-columns:1fr}.who-point + .who-point{padding-left:0;border-left:0;border-top:1px solid var(--line-light)}.gallery-head{grid-template-columns:1fr;gap:23px;margin-bottom:31px}.gallery-head .section-title{font-size:64px}.gallery-stage{width:calc(100% - 40px);height:auto}.gallery-scene{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.gallery-card,.gallery-card.feature,.gallery-card.hero,.gallery-card.wide,.gallery-card.tall{position:relative;top:auto;left:auto;width:auto;height:auto;grid-column:auto!important;grid-row:auto!important;aspect-ratio:1/1!important;transform:none!important;opacity:1!important;transition:opacity .35s ease}.gallery-card-float{height:100%;animation:none!important;transform:none!important}.gallery-card img{transition:opacity .25s ease;transform:none!important}.gallery-card:hover img{transform:none!important}.gallery-scene:hover .gallery-card:not(:hover) img{filter:saturate(.92) contrast(1.04) brightness(.92)}
      /* Mobile gallery: normal in-page grid, equal square cards, no desktop floating/parallax motion. */
      .gallery-stage{height:auto!important}.gallery-scene{height:auto!important}.gallery-card,.gallery-card.feature,.gallery-card.hero,.gallery-card.wide,.gallery-card.tall{animation:none!important}.gallery-more{display:inline-flex}
.gallery-scene:not(.expanded) .gallery-card:nth-child(n+5){display:none}.gallery-more{display:inline-flex;align-items:center;justify-content:center;gap:9px;margin:28px auto 0;padding:13px 18px;border:1px solid rgba(201,165,76,.54);background:transparent;color:var(--paper);font-size:10px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;transition:background .25s ease,color .25s ease}.gallery-more:hover{background:var(--gold);color:#111}.gallery-more span{font-size:18px;line-height:0;font-weight:400}.gallery-card:nth-child(1) .gallery-card-float{animation-duration:13s}.gallery-card:nth-child(2) .gallery-card-float{animation-duration:16s}.gallery-card:nth-child(3) .gallery-card-float{animation-duration:12s}.gallery-card:nth-child(4) .gallery-card-float{animation-duration:15s}.gallery-card:nth-child(5) .gallery-card-float{animation-duration:14s}.gallery-card:nth-child(6) .gallery-card-float{animation-duration:11s}.gallery-card:nth-child(7) .gallery-card-float{animation-duration:16s}.gallery-card:nth-child(8) .gallery-card-float{animation-duration:12s}.gallery-card:nth-child(9) .gallery-card-float{animation-duration:15s}.process-heading{display:block;margin-bottom:28px}.process-heading h2{font-size:50px}.process-heading p{margin-top:15px}.service-grid{grid-template-columns:1fr}.service-card{min-height:0}.service-image{height:295px}.service-body{min-height:340px}.service-card h3{font-size:54px}.service-card h3.wide{font-size:48px}.form-heading{display:block}.form-heading > p{text-align:left;margin-top:14px}.field-grid{grid-template-columns:1fr}.form-submit{flex-direction:column;align-items:stretch}.form-submit .btn{width:100%}.process-grid{grid-template-columns:1fr 1fr}.process-step{min-height:0;padding:16px!important;border-radius:22px}.process-visual{height:104px;margin-bottom:16px;border-radius:18px}.process-icon{width:58px;height:58px}.process-icon svg{width:42px;height:42px}.footer-top{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;align-items:flex-start}.address{text-align:left}.modal{padding:10px}.modal-window{max-height:calc(100svh - 20px)}.modal-content{padding:29px 18px}.modal-top{padding:0 18px}.modal-image{height:210px;margin-top:30px}.modal-meta,.project-grid,.portfolio-media-grid{grid-template-columns:1fr}.modal-meta article{border-right:0;border-bottom:1px solid var(--line-dark)}.modal-meta article:last-child{border-bottom:0}.modal-work-heading,.modal-action{align-items:flex-start;flex-direction:column}.modal-work-heading p{text-align:left}.project-card img{height:175px}.portfolio-media-card,.portfolio-media-card img,.portfolio-media-card video{min-height:220px}.modal-action .btn{width:100%}
    }
    @media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.stage-film,.hero-bg .bg-film{display:none}.stage-film:first-child,.hero-bg .bg-film:first-child{display:block;opacity:1}.marquee-track,.partner-track{animation:none}}
      @media (max-width: 767px){.menu-primary a{border-bottom:0!important}}
    @media (max-width: 560px){.nav-cta{display:none}.section-header .section-title{font-size:52px}.gallery-head .section-title{font-size:52px}.gallery-stage{width:calc(100% - 28px)}.gallery-scene{gap:10px}.gallery-more{width:100%}.engagement-intro p:last-child{max-width:300px}.engagement-item{grid-template-columns:34px 76px minmax(0,1fr);gap:11px}.engagement-thumb{height:70px}.engagement-copy h3{font-size:22px}.testimonial blockquote{font-size:30px}.hero-title em{display:block}}

    /* Final menu refinement: desktop gets more breathing room; mobile social links and tagline stay comfortably in view. */
    @media (min-width:721px){
      .menu-primary{gap:clamp(20px,3.1vh,38px)}
      .menu-primary .menu-desktop-note{
        margin-top:auto;
        padding-top:clamp(34px,5vh,60px);
        font-family:var(--sans)!important;
        font-size:clamp(15px,1.25vw,19px)!important;
        font-weight:500!important;
        line-height:1.18!important;
        letter-spacing:-.055em!important;
        text-transform:none!important;
      }
    }
    @media (min-width:721px) and (max-height:760px){
      .menu-primary{gap:clamp(10px,1.7vh,18px)}
      .menu-primary .menu-desktop-note{padding-top:22px;font-size:15px!important}
    }
    @media (max-width:720px){
      .menu-primary{
        min-height:calc(100svh - 78px);
        padding:22px 12px 22px;
        justify-content:flex-start;
        overflow-y:auto;
        overscroll-behavior:contain;
      }
      .menu-primary a{
        min-height:55px;
        padding:8px 2px;
        font-size:28px;
      }
      .menu-mobile-socials{
        margin-top:20px!important;
        padding-top:0!important;
        gap:8px!important;
      }
      .menu-mobile-socials a{
        min-height:43px!important;
        padding:11px 13px!important;
        font-size:11px!important;
      }
      .menu-mobile-note{
        margin-top:14px!important;
        font-size:11px!important;
        line-height:1.42!important;
      }
    }

    /* Final menu layout: more desktop rhythm; mobile tagline stays anchored beneath social links. */
    @media (min-width:721px){
      .menu-primary{gap:clamp(28px,4vh,48px)}
      .menu-primary a{margin:0}
      .menu-primary .menu-desktop-note{
        margin-top:auto;
        padding-top:clamp(36px,5vh,66px);
        font-family:var(--sans)!important;
        font-size:clamp(15px,1.25vw,19px)!important;
        font-weight:800!important;
        line-height:1.2!important;
        letter-spacing:.08em!important;
        text-transform:uppercase!important;
      }
    }
    @media (min-width:721px) and (max-height:760px){
      .menu-primary{padding:24px clamp(34px,5vw,72px) 20px;gap:22px}
      .menu-primary a{font-size:clamp(34px,3.75vw,54px)}
      .menu-primary .menu-desktop-note{padding-top:22px;font-size:14px!important}
    }
    @media (max-width:720px){
      .menu-primary{
        min-height:calc(100svh - 78px);
        padding:22px 12px 20px;
        display:flex;
        flex-direction:column;
        overflow-y:auto;
        overscroll-behavior:contain;
      }
      .menu-primary a{min-height:55px;padding:8px 2px}
      .menu-mobile-socials{
        margin-top:auto!important;
        padding-top:24px!important;
        gap:8px!important;
      }
      .menu-mobile-note{
        display:block!important;
        margin-top:16px!important;
        padding-top:0!important;
        color:#24211c!important;
        font-family:var(--sans)!important;
        font-size:10px!important;
        font-weight:800!important;
        line-height:1.35!important;
        letter-spacing:.1em!important;
        text-transform:uppercase!important;
        max-width:280px;
      }
    }


    /* Mobile menu adjustment: lift social links while keeping the tagline anchored at the bottom. */
    @media (max-width:720px){
      .menu-overlay{
        height:100dvh;
        max-height:100dvh;
        overflow:hidden!important;
        overscroll-behavior:contain;
      }
      .menu-head{
        display:grid!important;
        grid-template-columns:1fr auto 1fr!important;
        align-items:center;
      }
      .menu-head .brand{
        grid-column:1;
        min-width:0;
      }
      .menu-close{
        grid-column:2;
        justify-self:center;
      }
      .menu-body{
        height:calc(100dvh - 78px);
        min-height:0!important;
        overflow:hidden;
      }
      .menu-primary{
        height:100%;
        min-height:0!important;
        overflow-y:auto;
        -webkit-overflow-scrolling:touch;
        overscroll-behavior:contain;
      }
      .menu-mobile-socials{
        margin-top:18px!important;
        padding-top:8px!important;
      }
      .menu-mobile-note{
        margin-top:auto!important;
        padding-top:18px!important;
      }
    }

    /* Mobile portfolio gallery: rebuilt as a centered one-column feed. */
    @media (max-width:720px){
      .gallery-section{
        overflow:hidden;
      }
      .gallery-stage{
        width:min(calc(100vw - 32px),430px)!important;
        max-width:430px!important;
        height:auto!important;
        margin:0 auto;
      }
      .gallery-scene{
        display:flex!important;
        flex-direction:column!important;
        align-items:center!important;
        gap:16px!important;
        width:100%!important;
        height:auto!important;
      }
      .gallery-card,
      .gallery-card.feature,
      .gallery-card.hero,
      .gallery-card.wide,
      .gallery-card.tall{
        position:relative!important;
        top:auto!important;
        left:auto!important;
        width:100%!important;
        max-width:100%!important;
        height:auto!important;
        margin:0 auto!important;
        aspect-ratio:1 / 1!important;
        transform:none!important;
        opacity:1!important;
        transition:opacity .35s ease,box-shadow .35s ease!important;
        z-index:1!important;
      }
      .gallery-card-float{
        width:100%!important;
        height:100%!important;
        animation:none!important;
        transform:none!important;
        border-radius:10px;
        box-shadow:0 18px 46px rgba(0,0,0,.28);
      }
      .gallery-card img{
        width:100%!important;
        height:100%!important;
        object-fit:cover;
        transform:none!important;
      }
      .gallery-card.is-logo img{
        object-fit:contain!important;
        padding:28px!important;
      }
      .gallery-card:hover img,
      .gallery-scene:hover .gallery-card:not(:hover) img{
        transform:none!important;
        filter:saturate(.92) contrast(1.04) brightness(.92);
      }
      .gallery-card.is-popgo:hover img,
      .gallery-scene:hover .gallery-card.is-popgo:not(:hover) img{
        filter:none;
      }
      .gallery-scene:not(.expanded) .gallery-card:nth-child(n+5){
        display:block!important;
      }
      .gallery-more{
        display:none!important;
      }
    }
    @media (max-width:560px){
      .gallery-stage{width:min(calc(100vw - 28px),390px)!important}
      .gallery-card,
      .gallery-card.feature,
      .gallery-card.hero,
      .gallery-card.wide,
      .gallery-card.tall{
        aspect-ratio:1 / 1!important;
      }
    }

    @media (max-width:720px){
      .engagement{padding-top:58px}
      .engagement-head{margin-bottom:34px}
      .engagement-head .section-title{font-size:52px}
      .engagement-head .section-copy{font-size:14px}
      .engagement-marquee{padding-bottom:58px}
      .engagement-marquee:before,.engagement-marquee:after{bottom:58px;width:52px}
      .engagement-marquee .partner-track{animation-duration:26s}
      .engagement-marquee .partner-group{gap:14px;padding-right:14px}
      .partner-card{width:184px;height:82px;padding:17px 23px;border-radius:12px}
      .partner-card img{max-height:44px}
      .partner-card-plaza img{max-height:58px}
      .partner-card-popgo img{max-height:36px}
    }
