:root{
  --primary:#5c3a2e;--secondary:#a89589;--accent:#d4a574;
  --bg:#faf6f1;--surface:#f0e8dd;--text:#2d1b1b;
  --text-muted:#2d1b1b99;--border:#2d1b1b15;--border-strong:#2d1b1b28;
  --radius:6px;--radius-lg:18px;--radius-xl:28px;
  --spring:cubic-bezier(0.16, 1, 0.3, 1);
  --shadow-diffuse:0 20px 40px -15px #2d1b1b14, 0 4px 12px -4px #2d1b1b0a;
  --shadow-spotlight:0 0 0 1px #d4a57433, 0 8px 30px -8px #d4a57455;
  --pointer-x:50%;--pointer-y:50%;--scroll-progress:0;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden;text-rendering:optimizeLegibility}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.05;letter-spacing:-0.02em}
h1{font-size:clamp(40px,7vw,84px)}
h2{font-size:clamp(32px,5vw,56px)}
h3{font-size:clamp(22px,3vw,32px)}
a{color:inherit;text-decoration:none;transition:opacity 0.25s var(--spring)}
a:hover{opacity:0.72}
.container{max-width:1280px;margin:0 auto;padding:0 32px}

/* Grain overlay (fixed — never on scrolling containers) */
body::before{content:'';position:fixed;inset:0;pointer-events:none;opacity:0.04;z-index:1000;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* Scroll progress bar (top of viewport) */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:101;background:transparent;pointer-events:none}
.scroll-progress::after{content:'';display:block;height:100%;width:calc(var(--scroll-progress,0) * 100%);background:linear-gradient(90deg,var(--accent),#5c3a2e);transform-origin:left;transition:width 0.05s linear;will-change:width}

/* ============ NAV ============ */
/* Old fixed-bar nav rules removed — all pages now use .glass-nav (with .on-light on inner pages). */

/* ============ HERO ============ */
.hero{min-height:100dvh;position:relative;display:flex;align-items:flex-end;padding:120px 32px 80px;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:-1;will-change:transform}
.hero-media img,.hero-media video{width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 8s linear}
.hero:hover .hero-media img,.hero:hover .hero-media video{transform:scale(1.0)}
.hero-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,#faf6f1f0 100%)}
.hero-content{max-width:1100px;margin:0 auto;width:100%;position:relative;z-index:1}
.hero-eyebrow{font-size:13px;letter-spacing:0.2em;text-transform:uppercase;margin-bottom:24px;font-weight:500;display:inline-flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:currentColor;display:inline-block}
.hero h1{margin-bottom:32px;max-width:900px}
.hero h1 em{color:var(--accent);font-style:italic}
.hero-sub{font-size:18px;max-width:540px;margin-bottom:40px;color:var(--text-muted)}
.hero-cta-row{display:flex;gap:16px;flex-wrap:wrap}

/* Mesh-gradient backdrop (motionsites-style) — applied via .has-mesh */
.has-mesh{position:relative;isolation:isolate}
.has-mesh::before{content:'';position:absolute;inset:-15%;z-index:-1;pointer-events:none;background:
  radial-gradient(60% 50% at 20% 30%, #d4a57438, transparent 70%),
  radial-gradient(50% 40% at 80% 20%, #5c3a2e30, transparent 70%),
  radial-gradient(70% 50% at 60% 90%, #a8958928, transparent 70%);
  filter:blur(40px);opacity:0.9;animation:meshDrift 22s ease-in-out infinite}
@keyframes meshDrift{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(2%,-2%,0) rotate(8deg)}}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;font-size:13px;letter-spacing:0.15em;text-transform:uppercase;font-weight:500;border-radius:100px;cursor:pointer;border:none;font-family:inherit;will-change:transform;transition:transform 0.35s var(--spring),background 0.25s var(--spring),color 0.25s var(--spring),box-shadow 0.35s var(--spring)}
.btn-primary{background:var(--text);color:var(--bg);box-shadow:0 1px 0 #2d1b1b10 inset, 0 8px 22px -10px #2d1b1b55}
.btn-primary:hover{transform:translateY(-2px);opacity:1;box-shadow:0 1px 0 #2d1b1b10 inset, 0 14px 32px -10px #2d1b1b66}
.btn-primary:active{transform:translateY(1px) scale(0.985)}
.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--text)}
.btn-secondary:hover{background:var(--text);color:var(--bg);opacity:1;transform:translateY(-2px)}
.btn-secondary:active{transform:translateY(1px) scale(0.985)}

/* Magnetic button — physical pull toward cursor (handled in JS) */
.magnetic{will-change:transform;transition:transform 0.4s var(--spring)}

/* ============ SECTIONS ============ */
section{padding:120px 32px;position:relative}
.section-eyebrow{font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;font-weight:500;display:inline-flex;align-items:center;gap:10px}
.section-eyebrow::before{content:'';width:24px;height:1px;background:currentColor;display:inline-block}
.section-title{margin-bottom:32px;max-width:800px}
.section-title em{color:var(--accent);font-style:italic}

/* ============ ABOUT PREVIEW (asymmetric) ============ */
.about-preview{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center;max-width:1280px;margin:0 auto}
.about-preview img{width:100%;border-radius:var(--radius-lg);aspect-ratio:4/5;object-fit:cover;box-shadow:var(--shadow-diffuse)}
.about-preview p{font-size:18px;margin-bottom:24px;color:var(--text-muted)}
@media(max-width:800px){.about-preview{grid-template-columns:1fr;gap:40px}}

/* ============ SERVICES — spotlight + tilt cards ============ */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1280px;margin:0 auto}
.service-card{position:relative;background:var(--surface);padding:40px 32px;border-radius:var(--radius-lg);border:1px solid var(--border);transition:transform 0.5s var(--spring),border-color 0.4s var(--spring),box-shadow 0.5s var(--spring);transform-style:preserve-3d;will-change:transform;overflow:hidden;isolation:isolate}
.service-card::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;background:radial-gradient(220px circle at var(--pointer-x) var(--pointer-y), #d4a57488, transparent 70%);-webkit-mask:linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity 0.4s var(--spring);z-index:1}
.service-card:hover{transform:translateY(-4px);border-color:var(--border-strong);box-shadow:var(--shadow-diffuse)}
.service-card:hover::before{opacity:1}
.service-card .num{font-family:'Cormorant Garamond',serif;font-size:48px;font-style:italic;color:var(--accent);margin-bottom:16px;display:block}
.service-card h3{margin-bottom:12px;position:relative;z-index:2}
.service-card p{color:var(--text-muted);position:relative;z-index:2}

/* ============ GALLERY ============ */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;max-width:1280px;margin:0 auto}
.gallery-item{aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius-lg);position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--spring);will-change:transform}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,#faf6f1aa 100%);opacity:0;transition:opacity 0.4s var(--spring)}
.gallery-item:hover::after{opacity:1}

/* ============ CTA SECTION ============ */
.cta-section{background:var(--text);color:var(--bg);text-align:center;padding:120px 32px;position:relative;overflow:hidden}
.cta-section h2 em{color:var(--accent);font-style:italic}
.cta-section p{font-size:18px;max-width:540px;margin:24px auto 40px;opacity:0.8}
.cta-section .btn-primary{background:var(--bg);color:var(--text)}

/* Kinetic marquee — endless text band */
.marquee{display:flex;overflow:hidden;gap:40px;padding:24px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:'Cormorant Garamond',serif;font-size:clamp(28px,4vw,52px);font-style:italic;white-space:nowrap;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:40px;animation:marquee 32s linear infinite;will-change:transform;flex-shrink:0}
.marquee-track > *{flex-shrink:0;display:inline-flex;align-items:center;gap:40px}
.marquee-track > * > span:nth-child(even){color:var(--accent)}
@keyframes marquee{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:1280px;margin:0 auto}
.contact-info p{margin-bottom:16px;font-size:18px}
.contact-info strong{display:block;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);margin-bottom:4px;font-weight:500}
.contact-form{display:flex;flex-direction:column;gap:20px}
.contact-form input,.contact-form textarea{padding:16px 20px;background:transparent;border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:16px;color:var(--text);outline:none;transition:border-color 0.3s var(--spring),box-shadow 0.3s var(--spring)}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px #d4a5741c}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form button{align-self:flex-start;margin-top:8px}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr;gap:40px}}

/* ============ FOOTER ============ */
footer{padding:60px 32px 32px;border-top:1px solid var(--border);text-align:center;font-size:13px;color:var(--text-muted)}
footer .footer-brand{font-family:'Cormorant Garamond',serif;font-size:24px;font-style:italic;color:var(--text);margin-bottom:16px}
footer .footer-links{display:flex;justify-content:center;gap:32px;margin-bottom:24px;flex-wrap:wrap}

/* ============ SCROLL REVEAL ============ */
.fade-up{opacity:0;transform:translate3d(0,40px,0);transition:opacity 0.9s var(--spring),transform 0.9s var(--spring);will-change:transform,opacity}
.fade-up.visible{opacity:1;transform:translate3d(0,0,0)}
.stagger > *{opacity:0;transform:translate3d(0,30px,0);transition:opacity 0.7s var(--spring),transform 0.7s var(--spring)}
.stagger.visible > *{opacity:1;transform:translate3d(0,0,0);transition-delay:calc(var(--i,0) * 80ms)}

@media(prefers-reduced-motion:reduce){
  .fade-up,.stagger > *{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  .has-mesh::before{animation:none}
  .hero-media img,.hero-media video{transform:none;transition:none}
  .service-card,.tilt{transform:none !important}
}

/* ============ TILT CARD (parallax 3D) ============ */
.tilt{transform-style:preserve-3d;will-change:transform;transition:transform 0.45s var(--spring)}
.tilt-inner{transform:translateZ(20px)}

/* ============ LIQUID GLASS SYSTEM (motionsites.ai-inspired) ============ */
.lg,.lg-strong{position:relative;background:rgba(255,255,255,0.01);background-blend-mode:luminosity;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:none;box-shadow:inset 0 1px 1px rgba(255,255,255,0.1);overflow:hidden;isolation:isolate}
.lg-strong{backdrop-filter:blur(50px);-webkit-backdrop-filter:blur(50px);box-shadow:4px 4px 4px rgba(0,0,0,0.05),inset 0 1px 1px rgba(255,255,255,0.15)}
.lg::before,.lg-strong::before{content:'';position:absolute;inset:0;border-radius:inherit;padding:1.4px;background:linear-gradient(180deg,rgba(255,255,255,0.45) 0%,rgba(255,255,255,0.15) 20%,rgba(255,255,255,0) 40%,rgba(255,255,255,0) 60%,rgba(255,255,255,0.15) 80%,rgba(255,255,255,0.45) 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.lg-strong::before{background:linear-gradient(180deg,rgba(255,255,255,0.5) 0%,rgba(255,255,255,0.2) 20%,rgba(255,255,255,0) 40%,rgba(255,255,255,0) 60%,rgba(255,255,255,0.2) 80%,rgba(255,255,255,0.5) 100%)}
.lg-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:9999px;font-size:12px;color:rgba(255,255,255,0.92);font-weight:500;letter-spacing:0.01em;line-height:1.3;white-space:nowrap}
.lg-pill .pill-chip{display:inline-flex;align-items:center;background:#fff;color:#000;padding:3px 10px;border-radius:9999px;font-size:10.5px;font-weight:600;letter-spacing:0.02em;text-transform:uppercase}
.lg-card{padding:20px;border-radius:20px;color:#fff}
.lg-stat{padding:18px 20px;border-radius:20px;color:#fff;display:flex;flex-direction:column;gap:14px;min-width:200px}
.lg-stat .lg-stat-icon{width:28px;height:28px;color:#fff;opacity:0.9}
.lg-stat .lg-stat-value{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,3vw,40px);line-height:0.9;letter-spacing:-0.02em;font-style:italic;color:#fff}
.lg-stat .lg-stat-label{font-size:11px;color:rgba(255,255,255,0.78);font-weight:300;letter-spacing:0.02em;line-height:1.35}

/* ============ MOTION HERO (full-bleed video) ============ */
.motion-hero{position:relative;height:100dvh;min-height:640px;display:flex;flex-direction:column;justify-content:center;padding:96px 24px 56px;overflow:hidden;background:#000;color:#fff;isolation:isolate}
.motion-hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.motion-hero-media video,.motion-hero-media img{position:absolute;left:50%;top:0;transform:translateX(-50%) scale(1.0);width:120%;height:120%;object-fit:cover;object-position:top center;opacity:0;transition:opacity 0.6s ease}
.motion-hero-media.ready video,.motion-hero-media.ready img{opacity:1}
/* Radial vignette behind centered content — boosts headline contrast against a noisy video
   without flattening the edges (preserving the cinematic feel motionsites.ai goes for). */
.motion-hero::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(ellipse at center, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.32) 38%, rgba(0,0,0,0.05) 75%, transparent 100%)}
.motion-hero-content{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding-top:80px;max-width:1100px;margin:0 auto;width:100%}
.motion-hero-badge{margin-bottom:28px}
.motion-hero h1{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;color:#fff;font-size:clamp(40px,6.4vw,76px);line-height:0.92;letter-spacing:-0.03em;max-width:820px;margin:0 0 18px;display:flex;flex-wrap:wrap;justify-content:center;row-gap:0.05em;text-shadow:0 2px 30px rgba(0,0,0,0.55), 0 1px 3px rgba(0,0,0,0.35)}
.motion-hero-sub,.motion-hero-badge{text-shadow:0 1px 12px rgba(0,0,0,0.45)}
.motion-hero h1 .blur-word{display:inline-block;margin-right:0.28em;will-change:transform,filter,opacity;filter:blur(10px);opacity:0;transform:translate3d(0,20px,0);transition:filter 0.7s var(--spring),opacity 0.7s var(--spring),transform 0.7s var(--spring);transition-delay:calc(var(--i,0) * 100ms + 200ms)}
.motion-hero.in h1 .blur-word{filter:blur(0);opacity:1;transform:none}
.motion-hero h1 em{color:#fff;font-style:italic}
.motion-hero-sub{font-size:clamp(14px,1.4vw,16px);color:rgba(255,255,255,0.92);font-weight:300;line-height:1.45;max-width:580px;margin-bottom:28px;opacity:0;transform:translate3d(0,20px,0);transition:opacity 0.7s var(--spring),transform 0.7s var(--spring);transition-delay:0.8s;filter:blur(10px)}
.motion-hero.in .motion-hero-sub{opacity:1;transform:none;filter:blur(0)}
.motion-hero-cta-row{display:flex;align-items:center;gap:24px;margin-bottom:36px;opacity:0;transform:translate3d(0,20px,0);transition:opacity 0.7s var(--spring),transform 0.7s var(--spring);transition-delay:1.1s;filter:blur(10px)}
.motion-hero.in .motion-hero-cta-row{opacity:1;transform:none;filter:blur(0)}
.btn-glass{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;border-radius:9999px;font-size:13px;font-weight:500;color:#fff;letter-spacing:0.01em;text-transform:none;text-decoration:none;transition:transform 0.35s var(--spring)}
.btn-glass:hover{transform:translateY(-1px);opacity:1}
.btn-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#fff;letter-spacing:0.01em;text-decoration:none;transition:opacity 0.25s var(--spring)}
.btn-link:hover{opacity:0.78}
.motion-hero-stats{display:flex;align-items:stretch;gap:14px;flex-wrap:wrap;justify-content:center;opacity:0;transform:translate3d(0,20px,0);transition:opacity 0.7s var(--spring),transform 0.7s var(--spring);transition-delay:1.3s;filter:blur(10px)}
.motion-hero.in .motion-hero-stats{opacity:1;transform:none;filter:blur(0)}

/* Capability strip — sits BELOW the hero in normal page flow, light theme */
.caps-strip{padding:56px 24px 24px;background:var(--bg)}
.caps-strip-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:1280px;margin:0 auto}
.cap-card{padding:22px;border-radius:18px;display:flex;flex-direction:column;min-height:180px}
.cap-card-light{background:var(--surface);border:1px solid var(--border);color:var(--text);transition:transform 0.4s var(--spring),border-color 0.3s var(--spring),box-shadow 0.4s var(--spring)}
.cap-card-light:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow-diffuse)}
.cap-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:auto}
.cap-icon-light{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:11px;flex-shrink:0;color:var(--accent);background:#d4a57414;border:1px solid #d4a57428}
.cap-tags{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:5px;max-width:70%}
.cap-tag-light{padding:3px 9px;border-radius:9999px;font-size:10.5px;color:var(--text-muted);font-weight:500;line-height:1.35;white-space:nowrap;background:var(--surface2,#f0e8ddcc);border:1px solid var(--border)}
.cap-card h3{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(20px,2.2vw,26px);letter-spacing:-0.02em;line-height:1.05;margin:20px 0 0}
.cap-card-light h3{color:var(--text)}
.cap-card p{font-size:13px;font-weight:400;line-height:1.45;margin-top:8px;max-width:34ch}
.cap-card-light p{color:var(--text-muted)}
@media(max-width:900px){
  .caps-strip-inner{grid-template-columns:1fr}
  .motion-hero{padding:88px 16px 40px}
}

/* Nav variant for motion hero — light, delicate, theme-aware */
.glass-nav{position:fixed;top:18px;left:0;right:0;z-index:100;padding:0 24px;display:flex;justify-content:space-between;align-items:center;background:transparent;border-bottom:none;backdrop-filter:none;-webkit-backdrop-filter:none}
.glass-nav .glass-brand{width:46px;height:46px;border-radius:9999px;display:inline-flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:21px;color:#fff;text-decoration:none;flex-shrink:0;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);box-shadow:none}
.glass-nav .glass-brand.lg::before{display:none}
.glass-nav .glass-brand:hover{background:rgba(255,255,255,0.10)}
.glass-nav .glass-links{display:flex;align-items:center;gap:2px;padding:6px;border-radius:9999px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:none}
.glass-nav .glass-links.lg::before{display:none}
.glass-nav .glass-links a{padding:10px 18px;font-size:14.5px;font-weight:500;color:rgba(255,255,255,0.82);text-decoration:none;border-radius:9999px;transition:color 0.25s var(--spring),background 0.25s var(--spring)}
.glass-nav .glass-links a:hover{color:#fff;background:rgba(255,255,255,0.08);opacity:1}
.glass-nav .glass-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--accent);color:var(--bg);border-radius:9999px;font-size:14px;font-weight:600;text-decoration:none;white-space:nowrap;margin-left:4px;transition:transform 0.3s var(--spring),box-shadow 0.3s var(--spring);box-shadow:0 2px 12px -4px #d4a57466}
.glass-nav .glass-cta:hover{transform:translateY(-1px) scale(1.02);box-shadow:0 6px 20px -4px #d4a57488;opacity:1}
.glass-nav .glass-cta svg{width:16px;height:16px}
.glass-nav .glass-spacer{width:46px;height:46px;flex-shrink:0;visibility:hidden}
.glass-nav .menu-toggle{display:none;width:46px;height:46px;border-radius:9999px;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:20px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);box-shadow:none}
.glass-nav .menu-toggle.lg::before{display:none}
@media(max-width:900px){
  .glass-nav .glass-links,.glass-nav .glass-cta{display:none}
  .glass-nav .menu-toggle{display:inline-flex}
  .glass-nav .glass-spacer{display:none}
}

/* Light variant — used on inner pages where nav sits over the light page bg */
.glass-nav.on-light .glass-brand{color:var(--text);background:#faf6f1;border-color:#2d1b1b1f;box-shadow:0 4px 20px -8px #2d1b1b1c}
.glass-nav.on-light .glass-brand:hover{background:#faf6f1;border-color:#2d1b1b33}
.glass-nav.on-light .glass-links{background:#faf6f1f5;border-color:#2d1b1b14;box-shadow:0 4px 20px -8px #2d1b1b1c}
.glass-nav.on-light .glass-links a{color:#2d1b1bb3}
.glass-nav.on-light .glass-links a:hover{color:var(--text);background:#2d1b1b0c}
.glass-nav.on-light .menu-toggle{color:var(--text);background:#faf6f1;border-color:#2d1b1b1f;box-shadow:0 4px 20px -8px #2d1b1b1c}
/* CTA stays accent — same on both variants */

/* Mobile menu drawer — themed glass instead of plain dark slab.
   Default = on-dark (used by motion-hero on home). .on-light = inner pages. */
.mobile-menu{display:none;position:fixed;top:64px;left:16px;right:16px;backdrop-filter:blur(40px) saturate(160%);-webkit-backdrop-filter:blur(40px) saturate(160%);border-radius:20px;padding:14px;z-index:99}
.mobile-menu{background:rgba(10,10,12,0.85);border:1px solid rgba(255,255,255,0.08);box-shadow:0 20px 60px -10px rgba(0,0,0,0.55),inset 0 1px 0 rgba(255,255,255,0.08)}
.mobile-menu.on-light{background:#faf6f1f0;border:1px solid #2d1b1b14;box-shadow:0 20px 60px -10px #2d1b1b28,inset 0 1px 0 #2d1b1b06}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none;display:flex;flex-direction:column;gap:2px}
.mobile-menu ul li a{display:block;padding:14px 18px;border-radius:12px;font-size:15px;font-weight:500;color:rgba(255,255,255,0.92);text-decoration:none;transition:background 0.25s var(--spring)}
.mobile-menu.on-light ul li a{color:var(--text)}
.mobile-menu ul li a:hover{background:rgba(255,255,255,0.06);color:#fff;opacity:1}
.mobile-menu.on-light ul li a:hover{background:#2d1b1b0c;color:var(--text)}
.mobile-menu ul li:last-child a{margin-top:6px;background:var(--accent);color:var(--bg);text-align:center;font-weight:600}
.mobile-menu ul li:last-child a:hover{background:var(--accent);opacity:0.9}

/* ============ AGENCY MODE ============ */
/* Editorial hero — uploaded video/image as a backdrop, giant typography on top */
.agency-hero{min-height:100dvh;padding:140px 32px 80px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;isolation:isolate}
.agency-hero::before{content:'';position:absolute;inset:-10%;z-index:0;background:
  radial-gradient(50% 40% at 15% 20%, #d4a57428, transparent 70%),
  radial-gradient(40% 30% at 85% 80%, #5c3a2e1f, transparent 70%);
  filter:blur(60px);animation:meshDrift 26s ease-in-out infinite;pointer-events:none}
.agency-hero-media{position:absolute;inset:0;z-index:0;overflow:hidden}
.agency-hero-media img,.agency-hero-media video{width:100%;height:100%;object-fit:cover;opacity:0.55;transform:scale(1.04);transition:transform 8s linear, opacity 0.6s var(--spring)}
.agency-hero:hover .agency-hero-media img,.agency-hero:hover .agency-hero-media video{transform:scale(1.0);opacity:0.7}
.agency-hero-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#faf6f180 0%,#faf6f155 40%,#faf6f1f5 100%),linear-gradient(90deg,#faf6f1aa 0%,transparent 50%)}
.agency-hero .container{max-width:1400px;margin:0 auto;width:100%}
.giant-type{font-family:'Cormorant Garamond',sans-serif;font-size:clamp(56px,12vw,180px);line-height:0.92;letter-spacing:-0.04em;font-weight:500;margin-bottom:48px;max-width:1300px}
.giant-type em{color:var(--accent);font-style:normal;display:inline-block}
.rotating-word{display:inline-block;color:var(--accent);font-style:italic;min-width:6ch;position:relative;height:1em;vertical-align:baseline;overflow:hidden}
.rotating-word > span{display:block;animation:wordCycle 12s steps(1) infinite;will-change:transform}
@keyframes wordCycle{
  0%,20%{transform:translate3d(0,0%,0)}
  25%,45%{transform:translate3d(0,-100%,0)}
  50%,70%{transform:translate3d(0,-200%,0)}
  75%,95%{transform:translate3d(0,-300%,0)}
  100%{transform:translate3d(0,0%,0)}
}
.agency-meta{display:flex;flex-wrap:wrap;gap:32px;margin-top:40px;padding-top:32px;border-top:1px solid var(--border);font-family:'Outfit',monospace;font-size:13px;letter-spacing:0.02em;color:var(--text-muted);text-transform:uppercase}
.agency-meta strong{color:var(--text);font-weight:500;display:block;font-size:11px;letter-spacing:0.15em;margin-bottom:6px;opacity:0.6}

/* Bento grid — asymmetric tile layout (Taste skill Section 9) */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;max-width:1400px;margin:0 auto}
.bento-tile{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px;overflow:hidden;transition:transform 0.5s var(--spring),border-color 0.4s var(--spring),box-shadow 0.5s var(--spring);will-change:transform}
.bento-tile:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:var(--shadow-diffuse)}
.bento-tile h3{font-size:22px;line-height:1.15;margin-bottom:12px}
.bento-tile p{color:var(--text-muted);font-size:15px;line-height:1.55}
.bento-tile .tile-eyebrow{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:block;opacity:0.85}
.bento-tile.span-3{grid-column:span 3}
.bento-tile.span-4{grid-column:span 4}
.bento-tile.span-2{grid-column:span 2}
.bento-tile.span-6{grid-column:span 6}
.bento-tile.row-2{grid-row:span 2;display:flex;flex-direction:column;justify-content:space-between;min-height:340px}
/* Always-dark tile — fixed deep slate so it reads as a contrast surface regardless of whether
   the surrounding palette is light-mode or dark-mode. Using var(--text) here flipped to white
   on dark themes, which made the "Get in touch" tile blast-bright. */
.bento-tile.dark{background:#0d0e12;color:#fff;border-color:transparent}
.bento-tile.dark p{color:rgba(255,255,255,0.72)}
.bento-tile.dark .tile-eyebrow{color:var(--accent)}
.bento-tile.accent{background:var(--accent);color:var(--bg);border-color:transparent}
.bento-tile.accent p,.bento-tile.accent .tile-eyebrow{color:var(--bg)}
.bento-tile.next-tile{display:flex;flex-direction:column;justify-content:flex-start;min-height:200px;color:var(--text);position:relative}
.bento-tile.next-tile p{flex:1}
.bento-tile.next-tile .next-tile-arrow{position:absolute;right:28px;bottom:24px;font-size:28px;color:var(--accent);transition:transform 0.4s var(--spring);will-change:transform}
.bento-tile.next-tile:hover .next-tile-arrow{transform:translate3d(6px,-6px,0)}
.bento-tile.next-tile.dark{background:#0d0e12;color:#fff;border-color:transparent}
.bento-tile.next-tile.dark:hover{background:#11121a;border-color:rgba(255,255,255,0.08)}
.bento-tile.next-tile.dark .next-tile-arrow{color:var(--accent)}
.bento-tile.next-tile.dark p{color:rgba(255,255,255,0.72)}
.bento-tile.has-image{color:var(--bg);border-color:transparent;isolation:isolate}
.bento-tile.has-image .tile-eyebrow{color:var(--accent)}
.bento-tile-media{position:absolute;inset:0;z-index:0;overflow:hidden;border-radius:inherit}
.bento-tile-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);transition:transform 1.2s var(--spring)}
.bento-tile.has-image:hover .bento-tile-media img{transform:scale(1.12)}
.bento-tile-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#faf6f155 0%,#faf6f1cc 100%)}
.bento-tile .big-num{font-family:'Cormorant Garamond',sans-serif;font-size:clamp(56px,8vw,120px);line-height:0.85;letter-spacing:-0.03em;font-weight:500;display:block;margin-bottom:8px}
@media(max-width:1000px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento-tile.span-3,.bento-tile.span-4,.bento-tile.span-2,.bento-tile.span-6{grid-column:span 2}
  .bento-tile.row-2{grid-row:auto;min-height:auto}
}
@media(max-width:600px){
  .bento{grid-template-columns:1fr}
  .bento-tile.span-3,.bento-tile.span-4,.bento-tile.span-2,.bento-tile.span-6{grid-column:span 1}
}

/* Live status indicator (breathing pulse) for agency hero meta */
.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#d4a574;margin-right:8px;vertical-align:middle;animation:livePulse 2.4s ease-in-out infinite;box-shadow:0 0 0 0 #d4a57466}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 #d4a57455}50%{box-shadow:0 0 0 8px #d4a57400}}

/* Sticky case-study stack — cards stick and stack on scroll */
.case-stack{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
.case-stack[style*="--case-stack-static"]{gap:24px}
.case-stack[style*="--case-stack-static"] .case-card{position:relative;top:auto;margin-bottom:0}
.case-card{position:sticky;top:80px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px;display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:center;margin-bottom:24px;transition:transform 0.6s var(--spring);will-change:transform}
.case-card:nth-child(odd){background:var(--text);color:var(--bg);border-color:transparent}
.case-card:nth-child(odd) .case-eyebrow{color:var(--accent)}
.case-card:nth-child(odd) .case-meta{color:#fffaa}
.case-card .case-info h3{font-size:clamp(28px,3.5vw,44px);line-height:1.05;margin-bottom:16px;letter-spacing:-0.02em}
.case-card .case-eyebrow{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;margin-bottom:14px;font-weight:500;color:var(--accent)}
.case-card .case-meta{font-size:13px;color:var(--text-muted);margin-top:18px;display:flex;gap:24px;flex-wrap:wrap;font-family:'Outfit',monospace;text-transform:uppercase;letter-spacing:0.05em}
.case-card .case-visual{aspect-ratio:4/3;border-radius:var(--radius-lg);background:linear-gradient(135deg,#5c3a2e33,#d4a57433,#a8958933);display:flex;align-items:center;justify-content:center;color:var(--text);position:relative;overflow:hidden;isolation:isolate}
.case-card .case-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 1s var(--spring);z-index:0}
.case-card:hover .case-visual img{transform:scale(1.12)}
.case-card .case-visual::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#5c3a2e55 0%,#d4a57433 100%);mix-blend-mode:multiply;z-index:1}
.case-card .case-visual-mono{position:relative;z-index:2;font-family:'Cormorant Garamond',sans-serif;font-size:clamp(40px,5vw,72px);font-weight:500;letter-spacing:-0.03em;color:#fff;mix-blend-mode:difference;text-shadow:0 1px 0 rgba(0,0,0,0.2)}
.case-card .case-visual::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--pointer-x,50%) var(--pointer-y,50%), #d4a57433, transparent 60%);pointer-events:none;z-index:3}
@media(max-width:900px){
  .case-card{grid-template-columns:1fr;gap:24px;padding:32px;position:relative;top:auto}
}

/* Client / capability marquee for agencies */
.client-marquee{padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.client-marquee-track{display:flex;gap:64px;animation:marquee 40s linear infinite;white-space:nowrap;will-change:transform}
.client-marquee-track > div{display:inline-flex;align-items:center;gap:64px;flex-shrink:0;font-family:'Cormorant Garamond',sans-serif;font-size:clamp(20px,2.5vw,32px);font-weight:500;letter-spacing:-0.02em;color:var(--text-muted)}
.client-marquee-track > div > span{flex-shrink:0}

/* Agency footer hero CTA — typographic, full-width */
.agency-cta{padding:160px 32px;text-align:left;position:relative;overflow:hidden}
.agency-cta .container{max-width:1400px;margin:0 auto}
.agency-cta h2{font-size:clamp(48px,9vw,140px);line-height:0.95;letter-spacing:-0.04em;margin-bottom:40px;font-weight:500}
.agency-cta h2 em{color:var(--accent);font-style:italic}

/* ============ SERVICE ARCHETYPE (Plumbing / Consulting style) ============ */
/* Hero — saturated brand color full-bleed, headline left + cutout person right with blob backdrop */
.svc-hero{position:relative;background:var(--primary);color:#fff;overflow:hidden;padding:120px 32px 80px;min-height:90dvh;display:flex;align-items:center;isolation:isolate}
.svc-hero::before{content:'';position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);background-size:50px 50px;opacity:0.5;pointer-events:none}
.svc-hero::after{content:'';position:absolute;top:-40%;right:-15%;width:80%;height:160%;border-radius:50%;background:radial-gradient(circle, #2d1b1b1f, transparent 70%);z-index:0;pointer-events:none}
.svc-hero-grid{position:relative;z-index:2;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;width:100%}
.svc-hero-text{max-width:640px}
.svc-hero h1{font-family:'Outfit',sans-serif;font-weight:700;font-size:clamp(40px,5.6vw,68px);line-height:1.05;letter-spacing:-0.02em;color:#fff;margin-bottom:24px}
.svc-hero p.svc-sub{font-size:clamp(15px,1.4vw,17px);color:rgba(255,255,255,0.85);max-width:520px;line-height:1.6;margin-bottom:36px}
.svc-hero .svc-cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.btn-svc-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;background:var(--accent);color:var(--bg);border-radius:9999px;font-size:14px;font-weight:600;text-decoration:none;transition:transform 0.3s var(--spring),box-shadow 0.3s var(--spring);box-shadow:0 6px 20px -6px #d4a57488}
.btn-svc-primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px -6px #d4a574aa;opacity:1}
.btn-svc-outline{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,0.5);border-radius:9999px;font-size:14px;font-weight:500;text-decoration:none;transition:background 0.3s var(--spring)}
.btn-svc-outline:hover{background:rgba(255,255,255,0.1);opacity:1}
.svc-hero-rating{display:flex;align-items:center;gap:14px;margin-top:18px;font-size:13px;color:rgba(255,255,255,0.85)}
.svc-hero-rating-stars{color:#facc15;letter-spacing:2px}
.svc-hero-media{position:relative;height:520px;display:flex;align-items:center;justify-content:center}
.svc-hero-media::before{content:'';position:absolute;width:65%;aspect-ratio:1;border-radius:50%;background:var(--accent);right:5%;top:50%;transform:translateY(-50%);opacity:0.92;z-index:0}
.svc-hero-media img{position:relative;z-index:1;max-height:100%;max-width:100%;object-fit:cover;object-position:center;filter:drop-shadow(0 30px 40px rgba(0,0,0,0.35))}
@media(max-width:900px){
  .svc-hero{padding:100px 20px 40px;min-height:auto}
  .svc-hero-grid{grid-template-columns:1fr;gap:30px}
  .svc-hero-media{height:340px}
}

/* Trust strip — 3 quick promises with dashed connectors (Plumbing's killer pattern) */
.trust-strip{background:#f0e8dd;padding:64px 32px;color:var(--text)}
.trust-strip-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:32px;align-items:center;position:relative}
.trust-block{text-align:center;padding:0 24px;position:relative;z-index:1}
.trust-icon{width:72px;height:72px;border-radius:50%;background:#d4a57422;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px;position:relative}
.trust-icon::before{content:'';position:absolute;width:120%;height:120%;background:var(--accent);opacity:0.18;border-radius:48% 52% 60% 40%;animation:trustBlob 12s ease-in-out infinite;z-index:-1}
@keyframes trustBlob{0%,100%{border-radius:48% 52% 60% 40%;transform:rotate(0deg)}50%{border-radius:60% 40% 48% 52%;transform:rotate(8deg)}}
.trust-block h4{font-size:18px;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:-0.01em}
.trust-block p{font-size:14px;color:var(--text-muted);line-height:1.5}
.trust-connector{position:absolute;top:36px;height:60px;color:var(--text-muted);opacity:0.45;pointer-events:none;z-index:0}
.trust-connector svg{width:100%;height:100%}
@media(max-width:900px){
  .trust-strip-inner{grid-template-columns:1fr;gap:36px}
  .trust-connector{display:none}
}

/* Eyebrow signpost — horizontal dash + accent label (used throughout) */
.svc-eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:13px;font-weight:600;letter-spacing:0.02em;color:var(--accent);margin-bottom:18px;text-transform:none}
.svc-eyebrow::before{content:'';width:36px;height:2px;background:var(--accent);display:inline-block}

/* About preview with floating widget card overlap */
.svc-about{padding:96px 32px;background:var(--bg)}
.svc-about-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.svc-about-media{position:relative;aspect-ratio:4/5;border-radius:18px;overflow:hidden;background:#f0e8dd}
.svc-about-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--spring)}
.svc-about-media:hover img{transform:scale(1.04)}
.svc-about-widget{position:absolute;right:-24px;bottom:-24px;background:#fff;color:#0a0a0a;padding:18px 22px;border-radius:14px;box-shadow:0 24px 50px -10px rgba(0,0,0,0.25);min-width:240px;z-index:2}
.svc-about-widget-title{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;margin-bottom:10px;color:#0a0a0a}
.svc-about-widget-title .svc-widget-trend{color:var(--accent);font-weight:700}
.svc-about-widget-bars{display:flex;align-items:flex-end;gap:6px;height:60px}
.svc-about-widget-bars span{flex:1;background:var(--primary);border-radius:3px;opacity:0.78;transition:opacity 0.3s var(--spring)}
.svc-about-widget-bars span:hover{opacity:1}
.svc-about h2{font-size:clamp(28px,4vw,46px);line-height:1.1;letter-spacing:-0.02em;color:var(--text);margin-bottom:18px;max-width:520px}
.svc-about p{font-size:15px;color:var(--text-muted);line-height:1.6;margin-bottom:24px;max-width:520px}
.svc-checklist{list-style:none;padding:0;margin:24px 0 0}
.svc-checklist li{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);font-size:15px;color:var(--text)}
.svc-checklist li:last-child{border-bottom:none}
.svc-check-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
@media(max-width:900px){
  .svc-about-grid{grid-template-columns:1fr;gap:48px}
  .svc-about-media{aspect-ratio:4/3}
  .svc-about-widget{right:12px;bottom:12px;min-width:200px;padding:14px 16px}
}

/* Services — saturated brand-color bg with 6-up icon grid */
.svc-services{padding:96px 32px;background:var(--primary);color:#fff;position:relative;overflow:hidden}
.svc-services::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);background-size:50px 50px;opacity:0.4;pointer-events:none}
.svc-services-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.svc-services-head{text-align:center;margin-bottom:56px}
.svc-services-head h2{font-size:clamp(32px,5vw,52px);line-height:1.05;letter-spacing:-0.02em;color:#fff;margin-bottom:14px}
.svc-services-head p{font-size:16px;color:rgba(255,255,255,0.78);max-width:560px;margin:0 auto;line-height:1.5}
.svc-services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-service-tile{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:18px;padding:32px 28px;transition:transform 0.4s var(--spring),background 0.3s var(--spring),border-color 0.3s var(--spring);will-change:transform}
.svc-service-tile:hover{transform:translateY(-3px);background:rgba(255,255,255,0.10);border-color:rgba(255,255,255,0.22)}
.svc-service-tile-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;color:#fff;margin-bottom:18px}
.svc-service-tile h3{font-size:19px;font-weight:600;color:#fff;margin-bottom:10px;letter-spacing:-0.01em}
.svc-service-tile p{font-size:14px;color:rgba(255,255,255,0.78);line-height:1.55;margin:0}
@media(max-width:900px){.svc-services-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.svc-services-grid{grid-template-columns:1fr}}

/* Mid-page CTA strip — full-bleed brand color */
.svc-cta-strip{background:var(--primary);color:#fff;padding:48px 32px;border-top:1px solid rgba(255,255,255,0.08)}
.svc-cta-strip-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.svc-cta-strip h2{font-size:clamp(24px,3vw,36px);font-weight:600;color:#fff;margin:0;letter-spacing:-0.01em;flex:1}
.svc-cta-strip .btn-svc-outline{padding:14px 28px;border-color:rgba(255,255,255,0.55);font-weight:500}

/* Testimonials — light bg, 4 cards with star + quote + person + meta */
.svc-testimonials{padding:96px 32px;background:#f0e8dd}
.svc-testimonials-inner{max-width:1280px;margin:0 auto}
.svc-testimonials-head{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-bottom:48px;align-items:end}
.svc-testimonials-head h2{font-size:clamp(32px,5vw,52px);line-height:1.05;letter-spacing:-0.02em;color:var(--text);margin:0;max-width:540px}
.svc-testimonials-head p{font-size:15px;color:var(--text-muted);line-height:1.6;max-width:480px;margin:0}
.svc-testimonials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.svc-testimonial-card{background:var(--bg);border-radius:14px;padding:24px;display:flex;flex-direction:column;box-shadow:0 4px 20px -8px #2d1b1b1c;transition:transform 0.4s var(--spring),box-shadow 0.3s var(--spring)}
.svc-testimonial-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px -10px #2d1b1b28}
.svc-testimonial-stars{color:#facc15;letter-spacing:2px;font-size:14px;margin-bottom:14px}
.svc-testimonial-quote{font-size:14.5px;color:var(--text);line-height:1.55;margin-bottom:20px;flex:1}
.svc-testimonial-person{display:flex;align-items:center;gap:10px;margin-top:auto}
.svc-testimonial-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#5c3a2eaa,#d4a57488);flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px}
.svc-testimonial-meta{line-height:1.3}
.svc-testimonial-name{font-size:13.5px;font-weight:600;color:var(--text)}
.svc-testimonial-sub{font-size:11.5px;color:var(--text-muted)}
@media(max-width:1100px){.svc-testimonials-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.svc-testimonials-grid{grid-template-columns:1fr}.svc-testimonials-head{grid-template-columns:1fr}}

/* ============ CINEMATIC SERVICES — asymmetric bento ============ */
.svc-bento-tile{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:240px;padding:32px;color:var(--text);overflow:hidden}
.svc-bento-tile.svc-bento-feature{min-height:340px;padding:40px}
.svc-bento-tile .svc-bento-num{position:absolute;top:18px;right:24px;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(60px,8vw,120px);line-height:0.85;color:var(--accent);opacity:0.18;pointer-events:none;transition:opacity 0.5s var(--spring),transform 0.5s var(--spring);will-change:transform}
.svc-bento-tile:hover .svc-bento-num{opacity:0.45;transform:translate3d(-6px,-4px,0)}
.svc-bento-tile.svc-bento-feature .svc-bento-num{font-size:clamp(80px,12vw,180px)}
.svc-bento-body{position:relative;z-index:2;display:flex;flex-direction:column;gap:8px}
.svc-bento-tile h3{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:400;font-size:clamp(22px,2.6vw,32px);line-height:1.05;letter-spacing:-0.02em;margin:0;color:var(--text)}
.svc-bento-tile.svc-bento-feature h3{font-size:clamp(30px,4vw,48px)}
.svc-bento-tile p{font-size:14.5px;color:var(--text-muted);line-height:1.55;margin:6px 0 14px;max-width:36ch}
.svc-bento-tile.svc-bento-feature p{font-size:16px;max-width:48ch}
.svc-bento-cta{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent);transition:gap 0.3s var(--spring)}
.svc-bento-cta span{transition:transform 0.3s var(--spring)}
.svc-bento-tile:hover .svc-bento-cta span{transform:translate3d(4px,0,0)}
@media(max-width:900px){
  .svc-page-head{grid-template-columns:1fr !important}
}

/* ============ RESTAURANT MENU ============ */
.menu-page{padding:120px 24px 100px;background:var(--bg)}
.menu-page-inner{max-width:880px;margin:0 auto}
.menu-intro{text-align:center;margin-bottom:80px}
.menu-intro .section-eyebrow{justify-content:center}
.menu-intro h1{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(40px,7vw,82px);line-height:1.0;letter-spacing:-0.02em;margin-bottom:24px;color:var(--text)}
.menu-intro p{color:var(--text-muted);font-size:16px;line-height:1.6;max-width:560px;margin:0 auto}
.menu-section{margin-bottom:64px}
.menu-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);padding-bottom:18px;margin-bottom:28px}
.menu-section-title{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(28px,4.2vw,44px);line-height:1.05;letter-spacing:-0.02em;color:var(--text);margin:0}
.menu-section-note{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:0.18em;color:var(--text-muted);text-transform:uppercase;white-space:nowrap}
.menu-items{display:flex;flex-direction:column;gap:0}
.menu-item{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start;padding:18px 0;border-bottom:1px dotted #2d1b1b28}
.menu-item:last-child{border-bottom:none}
.menu-item-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(20px,2.2vw,24px);line-height:1.15;letter-spacing:-0.01em;color:var(--text);margin:0 0 6px}
.menu-item-desc{color:var(--text-muted);font-size:14.5px;line-height:1.55;margin:0;max-width:580px}
.menu-item-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.menu-item-tag{padding:2px 8px;border-radius:4px;font-size:10.5px;color:var(--text-muted);background:#f0e8dd;letter-spacing:0.04em;text-transform:uppercase;font-weight:500}
.menu-item-price{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,2vw,22px);font-weight:500;color:var(--accent);white-space:nowrap;align-self:start;padding-top:4px}
.menu-cta{text-align:center;padding:32px;margin-top:32px;background:#f0e8dd;border-radius:14px}
.menu-cta h3{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(22px,3vw,30px);margin-bottom:10px}
.menu-cta p{color:var(--text-muted);font-size:14px;margin-bottom:18px}
@media(max-width:600px){
  .menu-section-head{flex-direction:column;align-items:flex-start;gap:6px}
  .menu-item{grid-template-columns:1fr;gap:6px}
  .menu-item-price{padding-top:0}
}

/* Service inner page header — full-bleed photo with centered white title */
.svc-inner-header{position:relative;height:48vh;min-height:340px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;color:#fff;isolation:isolate}
.svc-inner-header img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transform:scale(1.04);transition:transform 1.4s var(--spring)}
.svc-inner-header.in img{transform:scale(1)}
.svc-inner-header::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#2d1b1b33 0%,#2d1b1b88 100%);z-index:1}
.svc-inner-header > *{position:relative;z-index:2}
.svc-inner-header h1{font-family:'Cormorant Garamond',sans-serif;font-weight:600;font-size:clamp(40px,6vw,72px);color:#fff;letter-spacing:-0.02em;margin:0}

/* ============ MOBILE POLISH ============ */
@media(max-width:700px){
  .glass-nav{padding:0 16px;top:14px}
  .glass-nav .glass-brand{width:42px;height:42px;font-size:19px}
  .glass-nav .menu-toggle{width:42px;height:42px;font-size:18px}
  .glass-nav .glass-spacer{width:42px;height:42px}
  .motion-hero{padding:84px 18px 40px;min-height:580px;height:auto}
  .motion-hero-content{padding-top:48px}
  .motion-hero h1{font-size:clamp(34px,9vw,52px) !important;letter-spacing:-0.02em !important;line-height:1.0 !important;margin-bottom:14px;text-shadow:0 1px 18px rgba(0,0,0,0.6),0 1px 3px rgba(0,0,0,0.4)}
  .motion-hero-sub{font-size:14px;margin-bottom:22px}
  .motion-hero-badge{font-size:11.5px;padding:5px 12px 5px 6px;max-width:100%;flex-wrap:wrap;justify-content:center;text-align:center;line-height:1.4}
  .motion-hero-badge span:not(.pill-chip){white-space:normal}
  .motion-hero-cta-row{flex-direction:column;gap:12px;width:100%;align-items:stretch;margin-bottom:28px}
  .motion-hero-cta-row .btn-glass,.motion-hero-cta-row .btn-link{width:100%;justify-content:center;padding:14px 20px}
  .motion-hero-stats{flex-direction:column;gap:10px;width:100%;align-items:stretch}
  .lg-stat{min-width:0;width:100%;padding:14px 18px;flex-direction:row;align-items:center;gap:14px}
  .lg-stat-icon{flex-shrink:0}
  .lg-stat-value{font-size:22px !important}
  .lg-stat-label{font-size:11.5px}
  .caps-strip{padding:40px 16px 24px}
  .caps-strip-inner{gap:12px}
  .cap-card{min-height:auto;padding:20px}
  .bento{grid-template-columns:1fr !important;gap:12px}
  .bento-tile,.bento-tile.span-2,.bento-tile.span-3,.bento-tile.span-4,.bento-tile.span-6{grid-column:span 1 !important}
  .bento-tile.row-2{grid-row:auto;min-height:auto}
  .bento-tile{padding:24px}
  .bento-tile h3{font-size:20px}
  .bento-tile .big-num{font-size:64px}
  section{padding:64px 18px}
  .about-preview{grid-template-columns:1fr !important;gap:32px !important}
  .svc-about-grid{grid-template-columns:1fr !important;gap:32px !important}
  .svc-about-media{aspect-ratio:4/3}
  .svc-about-widget{right:12px;bottom:12px;min-width:180px;padding:12px 14px}
  .svc-hero{padding:96px 18px 40px;min-height:auto}
  .svc-hero-grid{grid-template-columns:1fr !important;gap:24px}
  .svc-hero-media{height:280px}
  .svc-hero h1{font-size:clamp(32px,8vw,48px) !important}
  .svc-hero p.svc-sub{font-size:14.5px;margin-bottom:24px}
  .svc-cta-row{flex-direction:column;gap:10px;align-items:stretch}
  .svc-cta-row .btn-svc-primary,.svc-cta-row .btn-svc-outline{justify-content:center}
  .trust-strip{padding:40px 18px}
  .trust-block{padding:0 8px}
  .svc-services-grid{grid-template-columns:1fr !important}
  .svc-cta-strip-inner{flex-direction:column;align-items:flex-start;gap:16px}
  .svc-cta-strip h2{font-size:24px}
  .svc-testimonials-grid{grid-template-columns:1fr !important}
  .svc-testimonials-head{grid-template-columns:1fr !important;gap:14px}
  .home-demos-section{padding:48px 18px 72px}
  .home-demos-head{margin-bottom:24px}
  .home-demos-head h2{font-size:26px}
  .pricing-grid{grid-template-columns:1fr !important;gap:14px}
  .pricing-section{padding:32px 18px 64px}
  .map-iframe{height:200px !important}
  .contact-form input,.contact-form textarea,.contact-form select{padding:14px 16px !important;font-size:16px !important;border-radius:12px}
}
@media(max-width:420px){
  .glass-nav{padding:0 12px;top:10px}
  .glass-nav .glass-brand{width:40px;height:40px;font-size:18px}
  .glass-nav .menu-toggle{width:40px;height:40px}
  .motion-hero{padding:80px 14px 36px}
  section{padding:56px 14px}
  .bento-tile{padding:20px}
  .home-demos-section{padding:40px 14px 60px}
}