/* ============================================================
   TREND CONTRACT FURNISHINGS — Brand prototype
   Palette: deep burgundy + metallic gold (from logo)
   Type:    Fraunces (editorial serif) + Jost (geometric sans)
   ============================================================ */
:root{
  --burgundy-900:#27060a;
  --burgundy-800:#360a0f;
  --burgundy-700:#46101a;
  --burgundy-600:#5c1721;
  --burgundy-500:#73202c;
  --gold-200:#f1dba2;
  --gold-300:#e6c878;
  --gold-400:#cda657;
  --gold-500:#bd9038;
  --gold-600:#9a722a;
  --gold-700:#7d5d22;
  --cream:#f6f1e7;
  --cream-2:#efe7d8;
  --paper:#fbf8f2;
  --ink:#211a16;
  --ink-soft:#5a4f47;
  --line:rgba(189,144,56,.28);
  --gold-grad:linear-gradient(104deg,#a8813a 0%,#f3dea1 38%,#c9a24b 64%,#e9d08a 100%);
  --shadow-lg:0 30px 60px -20px rgba(39,6,10,.55);
  --shadow-sm:0 12px 30px -14px rgba(39,6,10,.4);
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',sans-serif;
  --page-bg:var(--paper);
  --page-ink:var(--ink);
  background:var(--page-bg);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background-color 1.1s var(--ease);
}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:400;line-height:1.04;letter-spacing:-.01em}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;font-weight:500;color:var(--gold-600)}
.gold-text{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.amp{font-family:'Fraunces',serif;font-style:italic;font-weight:500;padding:0 .02em;letter-spacing:0}
.contact-page .form-section{padding-top:150px}
/* ---- Interactive Contact hero ---- */
.contact-hero{position:relative;overflow:hidden;background:radial-gradient(120% 90% at 80% 0%,#6e1b2a,var(--burgundy-800) 45%,var(--burgundy-900));color:var(--gold-200);padding:150px 0 90px}
.contact-hero-form{padding:118px 0 70px}
.contact-hero-form .ch-grid{align-items:start}
.contact-hero-form .form-card{margin-top:6px}
.ci-row.light{color:rgba(241,219,162,.85)}
.ci-row.light a{color:var(--gold-300)}
.ch-orbs{position:absolute;inset:0;z-index:0;pointer-events:none}
.ch-orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;mix-blend-mode:screen;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.ch-orb.o1{width:40%;height:70%;left:-6%;top:-12%;background:radial-gradient(circle,#bd9038,transparent 70%)}
.ch-orb.o2{width:46%;height:80%;right:-10%;bottom:-20%;background:radial-gradient(circle,#73202c,transparent 70%)}
.ch-orb.o3{width:30%;height:50%;right:28%;top:10%;background:radial-gradient(circle,#e6c878,transparent 70%);opacity:.35}
.ch-inner{position:relative;z-index:2;max-width:880px}
.ch-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.ch-grid .ch-inner{max-width:none}
.ch-stage{position:relative;min-height:440px;height:100%;cursor:grab;border-radius:18px}
.ch-stage.dragging{cursor:grabbing}
#ch3dCanvas{width:100%;height:100%;display:block}
.ch3d-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--gold-300);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase}
.ch3d-hint{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);color:rgba(241,219,162,.55);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;pointer-events:none}
.ch3d-swatches{position:absolute;top:14px;right:14px;display:flex;gap:9px;z-index:3}
.ch3d-sw{width:26px;height:26px;border-radius:50%;border:2px solid rgba(255,255,255,.35);cursor:pointer;transition:.25s;box-shadow:0 4px 10px rgba(0,0,0,.3)}
.ch3d-sw:hover{transform:scale(1.12)}
.ch3d-sw.active{border-color:#fff;box-shadow:0 0 0 3px rgba(241,219,162,.4)}
@media(max-width:860px){.ch-grid{grid-template-columns:1fr}.ch-stage{min-height:360px;order:-1}}
/* technique cards (meaningful, not bland) */
.tech-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.tech-card{background:var(--paper);padding:30px 26px;transition:.4s var(--ease)}
.tech-card:hover{background:#fff}
.tech-card h3{font-family:'Fraunces',serif;font-weight:500;font-size:1.18rem;color:var(--burgundy-700);margin-bottom:8px;line-height:1.15}
.tech-card p{font-size:.9rem;color:var(--ink-soft);font-weight:300;line-height:1.6}
@media(max-width:820px){.tech-cards{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.tech-cards{grid-template-columns:1fr}}
/* barstool 3D showpiece (About) */
.bar-showpiece{background:radial-gradient(120% 100% at 50% 0%,#5c1721,var(--burgundy-800) 55%,var(--burgundy-900));padding:0;overflow:hidden}
.bar-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:24px}
.bar-text{padding:7% 2% 7% 0}
.bar-text h2{color:#fff;font-size:clamp(1.9rem,3.6vw,2.9rem);margin:14px 0 16px;line-height:1.05}
.bar-text p{color:rgba(241,219,162,.82);font-weight:300;line-height:1.7;max-width:30rem}
@media(max-width:860px){.bar-grid{grid-template-columns:1fr}.bar-text{padding:44px 0 0}.bar-showpiece .ch-stage{height:380px;min-height:0;margin-bottom:20px}}
.ch-inner h1{font-size:clamp(2.4rem,6vw,4.6rem);color:#fff;line-height:1.06;margin:16px 0 18px;font-weight:400;min-height:1.1em}
.type-cursor{display:inline-block;width:3px;height:1.05em;background:var(--gold-300);margin-left:4px;vertical-align:middle;animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.ch-sub{color:rgba(241,219,162,.82);font-weight:300;font-size:clamp(1rem,1.5vw,1.2rem);max-width:38rem;line-height:1.6}
.pills-block{margin-top:42px}
.pills-q{font-family:'Fraunces',serif;font-size:1.5rem;color:#fff}
.pills-sub{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-400);margin:6px 0 20px}
.pills{display:flex;flex-wrap:wrap;gap:12px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:40px;background:rgba(255,255,255,.08);border:1px solid rgba(241,219,162,.28);color:var(--gold-200);font-size:.9rem;font-family:'Jost',sans-serif;transition:.3s var(--ease)}
.pill:hover{background:rgba(241,219,162,.14);border-color:var(--gold-400)}
.pill.active{background:var(--gold-grad);color:var(--burgundy-900);border-color:transparent;font-weight:500;box-shadow:0 8px 20px -10px rgba(189,144,56,.7)}
.pill.active::before{content:"✓";font-weight:700}
.pills-banner{margin-top:22px;font-size:.85rem;color:rgba(241,219,162,.55);font-style:italic;transition:.4s var(--ease)}
.pills-banner.active{font-style:normal;background:rgba(241,219,162,.07);border:1px solid rgba(241,219,162,.2);border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:var(--gold-200)}
.pills-banner.active b{color:#fff;font-weight:500}
.pill-go{margin-left:auto;background:none;border:none;color:var(--gold-300);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:.3s}
.pill-go:hover{color:#fff}
/* Installs page */
.installs-hero{padding:190px 0 70px;text-align:center;background:radial-gradient(120% 90% at 80% 0%,#6e1b2a,var(--burgundy-800) 50%,var(--burgundy-900));color:#fff}
.installs-hero h1{font-size:clamp(2.8rem,6vw,4.8rem);margin:16px 0 0}
.installs-hero p{color:rgba(241,219,162,.82);font-weight:300;max-width:600px;margin:18px auto 0;font-size:1.08rem}
.install-full{display:grid;grid-template-columns:1.25fr 1fr;min-height:72vh;cursor:pointer;background:var(--burgundy-900)}
.install-full.flip{grid-template-columns:1fr 1.25fr}
.install-full.flip .if-img{order:2}
.install-full .if-img{overflow:hidden}
.install-full .if-img img{width:100%;height:100%;object-fit:cover;transition:1.4s var(--ease)}
.install-full:hover .if-img img{transform:scale(1.05)}
.install-full .if-text{display:flex;flex-direction:column;justify-content:center;padding:6vw;background:var(--burgundy-800);color:var(--gold-200)}
.install-full .if-loc{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-400)}
.install-full .if-text h2{font-size:clamp(2rem,4vw,3.2rem);color:#fff;margin:12px 0 18px}
.install-full .if-text p{font-weight:300;color:rgba(241,219,162,.85);font-size:1.05rem;line-height:1.7}
.install-full .if-cta{margin-top:24px;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-300)}
@media(max-width:860px){
  .install-full,.install-full.flip{grid-template-columns:1fr;min-height:0}
  .install-full.flip .if-img{order:0}
  .install-full .if-img{aspect-ratio:16/10}
  .install-full .if-text{padding:44px 24px}
}
/* portfolio install feature */
.install-feature{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.install-card{position:relative;overflow:hidden;border-radius:5px;cursor:pointer;box-shadow:var(--shadow-lg);margin:0;aspect-ratio:16/10}
.install-card img{width:100%;height:100%;object-fit:cover;transition:1.3s var(--ease)}
.install-card:hover img{transform:scale(1.06)}
.install-card figcaption{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:30px;background:linear-gradient(0deg,rgba(39,6,10,.92) 0%,rgba(39,6,10,.25) 55%,transparent);color:#fff}
.install-card .i-cat{color:var(--gold-300);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;margin-bottom:8px}
.install-card .i-title{font-family:'Fraunces',serif;font-size:1.9rem;line-height:1}
.install-card .i-loc{color:var(--gold-200);font-size:.85rem;letter-spacing:.16em;text-transform:uppercase;margin-top:6px}
.install-card .i-note{color:rgba(255,255,255,.82);font-weight:300;font-size:.9rem;margin-top:12px;max-width:90%;opacity:0;max-height:0;transition:.5s var(--ease)}
.install-card:hover .i-note{opacity:1;max-height:80px}
.install-card .i-count{position:absolute;top:14px;right:14px;z-index:2;background:rgba(20,4,7,.62);color:var(--gold-200);border:1px solid rgba(217,180,106,.45);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:40px;backdrop-filter:blur(3px)}
@media(max-width:680px){.install-feature{grid-template-columns:1fr}.install-card .i-note{opacity:1;max-height:80px}}
/* lightbox */
.lightbox{position:fixed;inset:0;z-index:220;background:rgba(20,4,7,.94);display:flex;align-items:center;justify-content:center;flex-direction:column;opacity:0;pointer-events:none;transition:.4s var(--ease);padding:30px}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:92vw;max-height:82vh;border-radius:4px;box-shadow:var(--shadow-lg)}
.lightbox .lb-cap{color:var(--gold-200);margin-top:18px;letter-spacing:.18em;text-transform:uppercase;font-size:.8rem}
.lightbox .lb-close{position:absolute;top:24px;right:30px;color:var(--gold-200);font-size:2.4rem;line-height:1;cursor:pointer}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.35);border:1px solid rgba(217,180,106,.5);color:var(--gold-200);font-size:2rem;line-height:0;cursor:pointer;transition:.25s var(--ease)}
.lightbox .lb-nav:hover{background:rgba(0,0,0,.7);transform:translateY(-50%) scale(1.06)}
.lightbox .lb-prev{left:26px}.lightbox .lb-next{right:26px}
.lightbox .lb-dots{display:flex;gap:9px;margin-top:14px}
.lightbox .lb-dots span{width:8px;height:8px;border-radius:50%;background:rgba(217,180,106,.4);cursor:pointer;transition:.25s var(--ease)}
.lightbox .lb-dots span.on{background:var(--gold-200);transform:scale(1.35)}
@media(max-width:680px){.lightbox .lb-nav{width:44px;height:44px;font-size:1.6rem}.lightbox .lb-prev{left:10px}.lightbox .lb-next{right:10px}}
/* finishes pop-out modal */
.fin-panel{position:fixed;inset:0;z-index:210;background:rgba(39,6,10,.6);backdrop-filter:blur(6px);display:flex;align-items:flex-start;justify-content:center;padding:5vh 20px;opacity:0;pointer-events:none;transition:.4s var(--ease);overflow-y:auto}
.fin-panel.open{opacity:1;pointer-events:auto}
.fin-modal{background:var(--paper);border-radius:8px;max-width:1000px;width:100%;padding:48px;box-shadow:var(--shadow-lg);position:relative;transform:translateY(24px);transition:.45s var(--ease);margin:auto}
.fin-panel.open .fin-modal{transform:none}
.fin-close{position:absolute;top:18px;right:22px;font-size:2rem;line-height:1;color:var(--gold-700);width:40px;height:40px;border-radius:50%;transition:.3s}
.fin-close:hover{background:var(--cream-2)}
.fin-head{margin-bottom:30px}
.fin-head h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:10px 0 8px}
.fin-head p{color:var(--ink-soft);font-weight:300;max-width:560px}
.fin-sec{margin-bottom:34px}
.fin-sec h3{font-size:1.3rem;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--line);color:var(--burgundy-700)}
.fin-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;border-top:1px solid var(--line);padding-top:24px}
@media(max-width:680px){.fin-modal{padding:30px 20px}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .85s var(--ease),transform .85s var(--ease);will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
/* thin gold hairline divider */
.hairline{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--gold-400) 18%,var(--gold-300) 50%,var(--gold-400) 82%,transparent);opacity:.6;max-width:1280px;margin:0 auto}
/* oversized serif pull-quote */
.pullquote{text-align:center;padding:44px 24px 36px}
.pullquote blockquote{font-family:'Fraunces',serif;font-weight:300;font-style:italic;font-size:clamp(1.8rem,4.4vw,3.4rem);line-height:1.18;color:var(--burgundy-700);max-width:1000px;margin:0 auto;letter-spacing:-.01em}
.pullquote .pq-mark{display:block;font-size:2.4rem;color:var(--gold-400);line-height:.5;margin-bottom:14px;font-family:'Fraunces',serif}
.pullquote cite{display:block;margin-top:20px;font-family:'Jost',sans-serif;font-style:normal;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-600)}
.pullquote.dark{background:var(--burgundy-800)}
.pullquote.dark blockquote{color:#fff}
.pullquote.dark cite{color:var(--gold-400)}
/* press / credibility strip */
.press{padding:8px 0 56px;text-align:center}
.press .press-label{font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-600);margin-bottom:26px}
.press-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0}
.press-item{display:flex;flex-direction:column;align-items:center;gap:5px;color:var(--ink-soft);padding:6px 38px;position:relative}
.press-item:not(:last-child)::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:42px;width:1px;background:var(--line)}
.press-item b{font-family:'Fraunces',serif;font-size:1.7rem;color:var(--burgundy-700);font-weight:500;line-height:1}
.press-item span{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase}
.press-newh{padding:6px 44px 6px 0;position:relative}
.press-newh::after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);height:54px;width:1px;background:var(--line)}
.press-newh img{height:58px;width:auto;object-fit:contain;mix-blend-mode:multiply;filter:saturate(.2) contrast(1.05)}
.foot-newh{display:inline-flex;align-items:center;gap:10px}
.foot-newh img{height:30px;width:auto;object-fit:contain;background:#f6f1e7;border-radius:3px;padding:3px 5px;opacity:.92}
@media(max-width:680px){
  .press-row{gap:18px 0}
  .press-item{padding:10px 22px}
  .press-item:not(:last-child)::after,.press-newh::after{display:none}
}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.6em;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;padding:15px 30px;border-radius:2px;transition:.4s var(--ease);position:relative}
.btn-gold{background:var(--gold-grad);color:var(--burgundy-900);box-shadow:0 10px 24px -12px rgba(189,144,56,.7)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(189,144,56,.8)}
.btn:active{transform:translateY(0) scale(.97)}
.pill:active,.prod-card:active{transform:scale(.98)}
@media(min-width:681px){
  header .logo{animation:fadeDown .7s var(--ease) both;animation-delay:.05s}
  nav.links{animation:fadeDown .7s var(--ease) both;animation-delay:.16s}
  .header-tools{animation:fadeDown .7s var(--ease) both;animation-delay:.27s}
}
@keyframes fadeDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
.btn-ghost{border:1px solid var(--line);color:var(--ink)}
.btn-ghost:hover{background:var(--burgundy-700);color:var(--gold-200);border-color:var(--burgundy-700)}
.btn-ghost-light{border:1px solid rgba(241,219,162,.4);color:var(--gold-200)}
.btn-ghost-light:hover{background:var(--gold-grad);color:var(--burgundy-900);border-color:transparent}
.btn-burgundy{background:var(--burgundy-800);color:var(--gold-200);border:1px solid var(--burgundy-800);box-shadow:0 10px 24px -14px rgba(39,6,10,.7)}
.btn-burgundy:hover{background:var(--burgundy-900);border-color:var(--gold-500);color:#fff}

/* ============================================================
   HEADER
   ============================================================ */
header{position:fixed;top:0;left:0;right:0;z-index:120;background:rgba(39,6,10,.0);transition:.45s var(--ease)}
header.solid{background:rgba(39,6,10,.97);box-shadow:0 8px 30px -16px rgba(0,0,0,.7)}
.nav{display:flex;align-items:center;justify-content:space-between;height:86px;gap:24px}
/* CSS recreation of the logo wordmark (swap for PNG anytime) */
.logo{display:flex;flex-direction:column;align-items:center;line-height:1;cursor:pointer;user-select:none}
.logo .word{font-family:'Jost',sans-serif;font-weight:600;font-size:1.9rem;letter-spacing:.14em;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.logo .sub{font-family:'Jost',sans-serif;font-weight:300;font-size:.46rem;letter-spacing:.46em;color:var(--gold-300);margin-top:4px}
nav.links{display:flex;gap:26px;align-items:center}
nav.links a{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-200);font-weight:400;position:relative;padding:6px 0;transition:.3s;white-space:nowrap}
nav.links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold-grad);transition:.35s var(--ease)}
nav.links a:hover::after,nav.links a.active::after{width:100%}
nav.links a:hover{color:#fff}
.header-tools{display:flex;align-items:center;gap:14px}
/* visible search pill (desktop) */
.search-pill{display:flex;align-items:center;gap:10px;color:var(--gold-200);background:rgba(241,219,162,.08);border:1px solid rgba(241,219,162,.32);border-radius:40px;padding:11px 20px 11px 16px;transition:.3s;min-width:210px}
.search-pill span{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(241,219,162,.7)}
.search-pill:hover{background:rgba(241,219,162,.16);border-color:var(--gold-400)}
.search-pill:hover span{color:#fff}
.search-toggle,.menu-toggle{color:var(--gold-200);width:42px;height:42px;display:none;align-items:center;justify-content:center;border-radius:50%;transition:.3s;border:1px solid rgba(241,219,162,.32)}
.search-toggle:hover{background:rgba(241,219,162,.14)}
.menu-toggle{display:none;border:none;position:relative;z-index:130}
.menu-toggle .ic-close{display:none}
body.nav-open{position:fixed;left:0;right:0;width:100%;overflow:hidden}
body.nav-open .menu-toggle .ic-menu{display:none}
body.nav-open .menu-toggle .ic-close{display:block}
header .btn{padding:12px 22px}

/* search overlay */
.search-panel{position:fixed;inset:0;z-index:200;background:rgba(39,6,10,.97);backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;padding-top:13vh;opacity:0;pointer-events:none;transition:.4s var(--ease)}
.search-panel.open{opacity:1;pointer-events:auto}
.search-panel .close{position:absolute;top:28px;right:32px;color:var(--gold-200);font-size:2.4rem;line-height:1}
.search-box{width:min(760px,92vw)}
.search-box .field{display:flex;align-items:center;gap:16px;border:2px solid var(--gold-500);border-radius:6px;padding:18px 22px;background:rgba(241,219,162,.05)}
.search-box input{flex:1;background:none;border:none;outline:none;color:#fff;font-size:1.7rem;font-family:'Fraunces',serif}
.search-box input::placeholder{color:rgba(241,219,162,.4)}
.search-box svg{color:var(--gold-300)}
.search-hint{color:rgba(241,219,162,.5);font-size:.82rem;letter-spacing:.08em;margin-top:18px}
.search-results{width:min(760px,92vw);margin-top:18px;max-height:54vh;overflow:auto}
.sr-item{display:flex;gap:14px;align-items:center;padding:14px 8px;border-bottom:1px solid rgba(241,219,162,.14);cursor:pointer;transition:.25s}
.sr-item:hover{background:rgba(241,219,162,.07);padding-left:16px}
.sr-item img{width:64px;height:48px;object-fit:cover;border-radius:2px}
.sr-item .sr-ico{width:64px;height:48px;border-radius:2px;background:var(--burgundy-700);display:flex;align-items:center;justify-content:center;color:var(--gold-300);flex-shrink:0}
.sr-item .sr-ico svg{width:24px;height:24px}
.sr-item .t{color:#fff;font-size:1rem}
.sr-item .c{color:var(--gold-400);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}

/* ============================================================
   GENERIC PAGE SECTIONS
   ============================================================ */
.page{min-height:60vh;animation:fade .6s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
section{position:relative}
.pad{padding:84px 0}
.pad-sm{padding:56px 0}
.center{text-align:center}
.section-head{max-width:760px;margin:0 auto 42px}
.section-head.left{margin-left:0;text-align:left}
.section-head h1,.section-head h2{font-size:clamp(2.1rem,4.4vw,3.4rem);margin:18px 0 0}
.section-head p{color:var(--ink-soft);margin-top:18px;font-weight:300;font-size:1.05rem}

/* ============================================================
   HERO CAROUSEL
   ============================================================ */
.hero{height:100vh;min-height:640px;position:relative;overflow:hidden;background:var(--burgundy-900)}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s var(--ease);}
.slide.active{opacity:1}
.slide .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);transition:transform 7s linear}
.slide.active .bg{transform:scale(1)}
.slide::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(39,6,10,.82) 0%,rgba(39,6,10,.45) 45%,rgba(39,6,10,.2) 100%),linear-gradient(0deg,rgba(39,6,10,.85),transparent 55%)}
.slide-content{position:absolute;z-index:3;left:0;right:0;bottom:13vh;}
.slide-content .wrap{max-width:1280px}
.slide .kick{display:inline-flex;align-items:center;gap:8px;color:var(--burgundy-900);background:var(--gold-grad);padding:7px 16px;border-radius:40px;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin-bottom:18px;opacity:0;transform:translateY(20px);transition:.6s .1s var(--ease)}
.slide .loc{display:block;color:#fff;font-family:'Fraunces',serif;font-weight:500;font-size:clamp(2.2rem,5vw,4rem);line-height:1.02;letter-spacing:-.01em;opacity:0;transform:translateY(20px);transition:.7s .25s var(--ease)}
.slide .loc .place{display:block;color:var(--gold-300);font-size:clamp(.8rem,1.4vw,1.05rem);font-family:'Jost',sans-serif;font-weight:400;letter-spacing:.32em;text-transform:uppercase;margin-top:14px}
.slide .headline{color:rgba(255,255,255,.92);font-size:clamp(1.05rem,1.7vw,1.4rem);max-width:680px;margin-top:20px;font-weight:300;font-family:'Jost',sans-serif;line-height:1.5;opacity:0;transform:translateY(24px);transition:.8s .4s var(--ease)}
.slide.active .kick,.slide.active .loc,.slide.active .headline{opacity:1;transform:none}
.hero-nav{position:absolute;z-index:5;bottom:6vh;right:40px;display:flex;gap:12px}
.hero-arrow{width:64px;height:64px;border:1px solid rgba(241,219,162,.4);color:var(--gold-200);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s;backdrop-filter:blur(4px);font-size:1.5rem;line-height:1}
.hero-arrow:hover{background:var(--gold-grad);color:var(--burgundy-900);border-color:transparent}
.hero-dots{position:absolute;z-index:5;bottom:6vh;left:40px;display:flex;gap:10px;align-items:center}
.hero-dots button{width:34px;height:3px;background:rgba(241,219,162,.3);border-radius:2px;transition:.4s}
.hero-dots button.active{background:var(--gold-grad);width:54px}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:5;color:rgba(241,219,162,.6);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;writing-mode:vertical-rl;animation:bob 2.4s infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ============================================================
   MARQUEE / TRUST
   ============================================================ */
.marquee{background:var(--burgundy-800);overflow:hidden;border-top:1px solid var(--burgundy-600);border-bottom:1px solid var(--burgundy-600)}
.marquee .track{display:flex;gap:64px;padding:22px 0;white-space:nowrap;animation:scroll 30s linear infinite;width:max-content}
.marquee span{color:var(--gold-300);font-family:'Fraunces',serif;font-style:italic;font-size:1.15rem;opacity:.85}
.marquee span::before{content:"◆";color:var(--gold-600);margin-right:64px;font-size:.7rem;vertical-align:middle}
@keyframes scroll{to{transform:translateX(-50%)}}

/* Made in USA band */
.usa-band{background:var(--burgundy-700);color:var(--gold-200);border-top:1px solid var(--burgundy-500);border-bottom:1px solid var(--burgundy-500)}
.usa-inner{display:flex;align-items:center;gap:24px;justify-content:center;padding:34px 0;text-align:left}
.usa-flag{font-size:2.6rem;background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent;flex-shrink:0}
.usa-inner h3{color:#fff;font-size:1.6rem}
.usa-inner p{color:rgba(241,219,162,.75);font-weight:300;font-size:.95rem;margin-top:4px;max-width:560px}

/* ============================================================
   INTRO / SPLIT
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:70px;align-items:center}
.split.rev{grid-template-columns:1fr 1.05fr}
.split-img{position:relative}
.split-img img{width:100%;height:560px;object-fit:cover;border-radius:3px;box-shadow:var(--shadow-lg)}
.split-img .badge{position:absolute;bottom:-26px;left:-26px;background:var(--burgundy-700);color:var(--gold-200);padding:24px 30px;border-radius:3px;box-shadow:var(--shadow-lg);border:1px solid var(--burgundy-500)}
.split-img .badge b{font-family:'Fraunces',serif;font-size:2.4rem;display:block;line-height:1}
.split-img .badge small{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;opacity:.8}
.split-body h2{font-size:clamp(2rem,3.8vw,3rem);margin:18px 0 22px}
.split-body p{color:var(--ink-soft);margin-bottom:18px;font-weight:300}

/* ============================================================
   SEGMENTS (who we serve)
   ============================================================ */
.seg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.seg{background:var(--paper);padding:42px 34px;transition:.4s var(--ease);position:relative}
.seg:hover{background:var(--burgundy-700);color:var(--gold-200)}
.seg .num{font-family:'Fraunces',serif;font-size:.9rem;color:var(--gold-500);margin-bottom:20px}
.seg h3{font-size:1.45rem;margin-bottom:10px}
.seg:hover h3{color:#fff}
.seg p{font-size:.92rem;color:var(--ink-soft);font-weight:300}
.seg:hover p{color:rgba(241,219,162,.8)}
.seg .ico{width:34px;height:34px;margin-bottom:18px;color:var(--gold-500)}
.seg:hover .ico{color:var(--gold-300)}

/* ============================================================
   PORTFOLIO GRID
   ============================================================ */
.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:44px}
.filters button{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;padding:10px 20px;border:1px solid var(--line);border-radius:40px;color:var(--ink-soft);transition:.3s}
.filters button.active,.filters button:hover{background:var(--burgundy-700);color:var(--gold-200);border-color:var(--burgundy-700)}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.port-card{position:relative;overflow:hidden;border-radius:3px;cursor:pointer;aspect-ratio:4/3;box-shadow:var(--shadow-sm)}
.port-card.tall{aspect-ratio:4/5}
/* Finishes page */
.fin-block{margin-top:40px}
.fin-cat{font-family:'Fraunces',serif;font-weight:500;font-size:1.5rem;color:var(--burgundy-700);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px}
.fin-cat::before{content:"";width:28px;height:2px;background:var(--gold-grad)}
.fin-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
.fin-card{text-align:center}
.fin-card .fin-img{aspect-ratio:1;border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);transition:.4s var(--ease)}
.fin-card .fin-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.fin-card:hover .fin-img{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.fin-card:hover .fin-img img{transform:scale(1.07)}
.fin-card figcaption{margin-top:10px;font-size:.82rem;letter-spacing:.04em;color:var(--ink-soft);font-weight:400}
@media(max-width:900px){.fin-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.fin-grid{grid-template-columns:repeat(2,1fr)}}
.port-card img{width:100%;height:100%;object-fit:cover;transition:1.2s var(--ease)}
.port-card:hover img{transform:scale(1.07)}
.port-card .ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(39,6,10,.9) 0%,rgba(39,6,10,.15) 55%,transparent);display:flex;flex-direction:column;justify-content:flex-end;padding:26px;opacity:.92;transition:.4s}
.port-card .ov .cat{color:var(--gold-300);font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;transform:translateY(8px);opacity:0;transition:.4s}
.port-card:hover .ov .cat{transform:none;opacity:1}
.port-card .ov h3{color:#fff;font-size:1.5rem;font-weight:400}
.port-card .ov .plus{position:absolute;top:22px;right:22px;width:38px;height:38px;border:1px solid rgba(241,219,162,.5);border-radius:50%;color:var(--gold-200);display:flex;align-items:center;justify-content:center;font-size:1.2rem;opacity:0;transform:scale(.8);transition:.4s}
.port-card:hover .ov .plus{opacity:1;transform:none}

/* ============================================================
   PRODUCTS
   ============================================================ */
.prod-toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:36px;flex-wrap:wrap}
.prod-search{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:40px;padding:10px 18px;flex:1;max-width:360px}
.prod-search input{border:none;outline:none;background:none;font-family:inherit;font-size:.9rem;flex:1;color:var(--ink)}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prod-card{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:#fff;transition:.4s var(--ease);cursor:pointer}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--gold-400)}
.prod-card .ph{aspect-ratio:1;overflow:hidden;background:var(--cream-2)}
.prod-card .ph img{width:100%;height:100%;object-fit:cover;transition:1s var(--ease)}
.prod-card:hover .ph img{transform:scale(1.06)}
.prod-card .info{padding:16px 16px 18px}
.prod-card .cat{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-600)}
.prod-card h3{font-size:1.25rem;margin:6px 0 4px}
.prod-card .desc{font-size:.86rem;color:var(--ink-soft);font-weight:300;min-height:42px}
.prod-card .row{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.prod-card .tear{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-600);display:flex;align-items:center;gap:6px}

/* product detail */
.pd{display:grid;grid-template-columns:1.1fr 1fr;gap:60px}
.pd-gallery .main{aspect-ratio:1;border-radius:4px;overflow:hidden;background:var(--cream-2);box-shadow:var(--shadow-sm)}
.pd-gallery .main img{width:100%;height:100%;object-fit:cover}
.pd-gallery .thumbs{display:flex;gap:12px;margin-top:14px}
.pd-gallery .thumbs img{width:84px;height:84px;object-fit:cover;border-radius:3px;cursor:pointer;border:2px solid transparent;transition:.3s}
.pd-gallery .thumbs img.active,.pd-gallery .thumbs img:hover{border-color:var(--gold-400)}
.pd-info .cat{color:var(--gold-600);letter-spacing:.26em;text-transform:uppercase;font-size:.72rem}
.pd-info h1{font-size:clamp(2.2rem,4vw,3.1rem);margin:14px 0 18px}
.pd-info p{color:var(--ink-soft);font-weight:300;margin-bottom:24px}
.spec{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden;margin-bottom:26px}
.spec div{background:var(--paper);padding:16px 18px}
.spec .k{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-600)}
.spec .v{font-size:.95rem;margin-top:4px}
.pd-actions{display:flex;flex-direction:column;gap:12px;max-width:360px}
.pd-actions .btn{width:100%;justify-content:center}

/* ============================================================
   WHERE WE WORK  (studioother-inspired)
   ============================================================ */
.www{background:radial-gradient(120% 90% at 80% 0%,#6e1b2a 0%,var(--burgundy-800) 45%,var(--burgundy-900) 100%);color:var(--gold-200);position:relative;overflow:hidden}
.www::before{content:"";position:absolute;top:-10%;left:-10%;width:50%;height:60%;background:radial-gradient(circle,rgba(189,144,56,.18),transparent 70%);pointer-events:none}
.www .section-head h2{color:#fff}
.www .section-head p{color:rgba(241,219,162,.7)}
.www-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--burgundy-500)}
.www-row{display:flex;align-items:center;justify-content:space-between;padding:26px 8px;border-bottom:1px solid var(--burgundy-500);cursor:default;transition:.4s var(--ease);position:relative}
.www-row:hover{padding-left:24px;background:rgba(241,219,162,.06)}
.www-row .city{font-family:'Fraunces',serif;font-size:1.7rem;color:#fff;transition:.4s}
.www-row:hover .city{color:var(--gold-300)}
.www-row .region{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-400)}
.www-note{text-align:center;margin-top:40px;color:rgba(241,219,162,.6);font-style:italic;font-family:'Fraunces',serif}
/* client / trusted-by strip */
.clients{margin-top:40px;padding-top:30px;border-top:1px solid var(--burgundy-500);text-align:center}
.clients-label{display:block;font-size:.95rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-300);margin-bottom:24px;font-weight:500}
.client-row{display:flex;flex-wrap:wrap;justify-content:center;gap:18px 40px;align-items:center}
.quote-terms{margin-top:30px;background:linear-gradient(135deg,rgba(189,144,56,.16),rgba(241,219,162,.08));border:1px solid var(--gold-500);border-radius:14px;padding:34px 36px;box-shadow:0 16px 40px -20px rgba(0,0,0,.5)}
/* parallax portrait: image drifts gently against the cursor */
.parallax-portrait{overflow:hidden}
.parallax-portrait img{transition:transform .25s cubic-bezier(.22,1,.36,1);will-change:transform;transform:scale(1.12)}
@media(prefers-reduced-motion:reduce){.parallax-portrait img{transform:none}}
.quote-terms h3{font-family:'Fraunces',serif;font-weight:500;color:var(--gold-200);font-size:1.5rem;margin-bottom:22px;display:flex;align-items:center;gap:10px}
.quote-terms h3::before{content:"";width:26px;height:2px;background:var(--gold-grad)}
.qt-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 40px}
.qt-item{display:flex;flex-direction:column;gap:4px;padding-bottom:14px;border-bottom:1px solid rgba(241,219,162,.22)}
.qt-k{font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-400);font-weight:600}
.qt-v{color:#fff;font-weight:300;font-size:.96rem}
@media(max-width:680px){.qt-grid{grid-template-columns:1fr}}
.client-marquee{position:relative;overflow:hidden;margin-top:6px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.client-marquee{overflow:hidden;max-width:100%}
.client-track{display:flex;align-items:center;gap:40px;width:max-content;animation:clientslide 34s linear infinite}
/* fixed-width slots keep the track width stable regardless of logo load/aspect → smooth seamless loop */
.client-track>.client-logo{flex:0 0 auto;width:160px;justify-content:center}
.client-marquee:hover .client-track{animation-play-state:paused}
@keyframes clientslide{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.client-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}}
.client-logo{font-family:'Fraunces',serif;font-size:1.4rem;letter-spacing:.02em;color:rgba(241,219,162,.55);transition:.4s var(--ease);cursor:default;position:relative;padding-bottom:4px}
.client-logo:hover{color:#fff}
.client-logo:hover::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--gold-grad)}

/* ============================================================
   CONTACT + QUOTE FORMS
   ============================================================ */
.form-section{background:var(--burgundy-700);color:var(--gold-200)}
.form-card{background:var(--paper);color:var(--ink);border-radius:5px;padding:48px;box-shadow:var(--shadow-lg)}
.contact-split{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.contact-info h2{color:#fff;font-size:clamp(2rem,4vw,3rem);margin:18px 0 22px}
.contact-info p{color:rgba(241,219,162,.78);font-weight:300;margin-bottom:28px}
.ci-row{display:flex;align-items:center;gap:14px;padding:16px 0;border-top:1px solid var(--burgundy-500)}
.ci-row svg{color:var(--gold-300);flex-shrink:0}
.ci-row a,.ci-row span{color:var(--gold-200);font-size:.95rem}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:18px}
.field.full{grid-column:1/-1}
label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-600);font-weight:500}
input,select,textarea{font-family:inherit;font-size:.95rem;padding:13px 15px;border:1px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);outline:none;transition:.3s}
input:focus,select:focus,textarea:focus{border-color:var(--gold-400);box-shadow:0 0 0 3px rgba(205,166,87,.15)}
textarea{resize:vertical;min-height:120px}
.form-card h3{font-size:1.9rem;margin-bottom:6px}
.form-card .lede{color:var(--ink-soft);font-size:.92rem;margin-bottom:28px;font-weight:300}
.dropzone{border:1.5px dashed var(--gold-400);border-radius:4px;padding:30px;text-align:center;color:var(--ink-soft);cursor:pointer;transition:.3s;background:var(--cream)}
.dropzone:hover{background:var(--cream-2);border-color:var(--gold-500)}
.dropzone svg{color:var(--gold-500);margin:0 auto 10px}
.dropzone b{color:var(--gold-600)}
.file-list{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}
.file-chip{background:var(--cream-2);border:1px solid var(--line);border-radius:30px;padding:6px 14px;font-size:.78rem;display:flex;align-items:center;gap:8px}
.file-chip button{color:var(--gold-700);font-size:1rem;line-height:1}
.qty-row{display:flex;align-items:center;gap:0;border:1px solid var(--line);border-radius:3px;width:fit-content;overflow:hidden}
.qty-row button{width:46px;height:46px;background:var(--cream-2);font-size:1.2rem;color:var(--gold-700)}
.qty-row input{border:none;width:70px;text-align:center;border-radius:0;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.form-success{text-align:center;padding:30px 0}
.form-success .ck{width:72px;height:72px;border-radius:50%;background:var(--gold-grad);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--burgundy-900)}
.note{font-size:.78rem;color:var(--ink-soft);background:rgba(205,166,87,.1);border-left:3px solid var(--gold-400);padding:12px 16px;border-radius:3px;margin-top:18px}

/* ============================================================
   CLIENT PORTAL
   ============================================================ */
.portal-hero{background:linear-gradient(135deg,var(--burgundy-800),var(--burgundy-600));min-height:100vh;display:flex;align-items:center;padding-top:86px}
.login-card{background:var(--paper);border-radius:6px;padding:46px;max-width:440px;margin:0 auto;box-shadow:var(--shadow-lg)}
.login-card h2{font-size:2rem;margin-bottom:6px}
.login-card .lede{color:var(--ink-soft);font-size:.9rem;margin-bottom:26px;font-weight:300}
.demo-cred{background:var(--cream-2);border-radius:4px;padding:12px 16px;font-size:.8rem;color:var(--ink-soft);margin-bottom:22px;border:1px dashed var(--gold-400)}
.demo-cred b{color:var(--gold-700)}
/* dashboard */
.dash{padding-top:120px;min-height:100vh;background:var(--cream)}
.dash-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-bottom:36px}
.dash-head h1{font-size:clamp(2rem,4vw,2.8rem)}
.dash-head .meta{color:var(--ink-soft);font-size:.9rem}
.dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:6px;padding:30px;box-shadow:var(--shadow-sm)}
.card h3{font-size:1.3rem;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.progress-wrap{margin:10px 0 6px}
.progress-bar{height:12px;border-radius:20px;background:var(--cream-2);overflow:hidden}
.progress-fill{height:100%;background:var(--gold-grad);border-radius:20px;width:0;transition:width 1.6s var(--ease)}
.progress-label{display:flex;justify-content:space-between;font-size:.78rem;color:var(--ink-soft);margin-top:8px}
.timeline{list-style:none;margin-top:8px}
.timeline li{display:flex;gap:16px;padding-bottom:24px;position:relative}
.timeline li::before{content:"";position:absolute;left:13px;top:28px;bottom:-2px;width:2px;background:var(--line)}
.timeline li:last-child::before{display:none}
.tl-dot{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;border:2px solid var(--line);background:#fff;font-size:.8rem;z-index:1}
.tl-dot.done{background:var(--gold-grad);border-color:transparent;color:var(--burgundy-900)}
.tl-dot.active{border-color:var(--gold-500);box-shadow:0 0 0 4px rgba(205,166,87,.2)}
.tl-body .t{font-weight:500}
.tl-body .d{font-size:.8rem;color:var(--ink-soft)}
.tl-body .date{font-size:.72rem;color:var(--gold-600);letter-spacing:.1em}
.gallery-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.gallery-mini img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;cursor:pointer;transition:.3s}
.gallery-mini img:hover{transform:scale(1.04);box-shadow:var(--shadow-sm)}
.doc-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.doc-row:last-child{border:none}
.doc-row .dl{color:var(--gold-600);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:26px}
.stat{background:#fff;border:1px solid var(--line);border-radius:6px;padding:22px;text-align:center}
.stat b{font-family:'Fraunces',serif;font-size:2rem;display:block;color:var(--burgundy-700)}
.stat small{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--burgundy-900);color:var(--gold-200);padding:80px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:50px;border-bottom:1px solid var(--burgundy-600)}
footer h4{font-family:'Jost',sans-serif;font-weight:500;font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-400);margin-bottom:20px}
footer .flogo .word{font-family:'Jost';font-weight:600;font-size:1.6rem;letter-spacing:.14em}
footer .flogo .sub{font-size:.42rem;letter-spacing:.44em;color:var(--gold-300)}
footer p{color:rgba(241,219,162,.65);font-weight:300;font-size:.9rem;margin-top:16px;max-width:280px}
footer ul{list-style:none}
footer ul li{margin-bottom:12px}
footer ul a{color:rgba(241,219,162,.7);font-size:.9rem;transition:.3s}
footer ul a:hover{color:#fff;padding-left:4px}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:42px;height:42px;border:1px solid var(--burgundy-500);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold-200);transition:.3s}
.socials a:hover{background:var(--gold-grad);color:var(--burgundy-900);border-color:transparent}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:28px;font-size:.78rem;color:rgba(241,219,162,.5)}
.newsletter{display:flex;border:1px solid var(--burgundy-500);border-radius:40px;overflow:hidden;margin-top:6px}
.newsletter input{border:none;background:rgba(241,219,162,.06);color:#fff;border-radius:0;flex:1}
.newsletter button{background:var(--gold-grad);color:var(--burgundy-900);padding:0 20px;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1180px){
  nav.links{gap:18px}
  nav.links a{font-size:.68rem;letter-spacing:.16em}
  .search-pill{display:none}
  .search-toggle{display:flex}
  .prod-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:980px){
  .split,.split.rev,.pd,.contact-split,.dash-grid{grid-template-columns:1fr;gap:40px}
  .seg-grid,.port-grid,.prod-grid,.www-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .split-img img{height:420px}
  .pad{padding:80px 0}
  .map-lbl{font-size:14px}
}
@media(max-width:680px){
  nav.links{position:fixed;inset:0;top:0;background:#270609;flex-direction:column;justify-content:center;gap:22px;transform:translateX(100%);transition:.4s var(--ease);z-index:115}
  nav.links.open{transform:none}
  nav.links a{font-size:1.15rem;letter-spacing:.2em}
  nav.links a::after{display:none}
  .nav-quote{display:inline-flex;background:var(--gold-grad);color:var(--burgundy-900)!important;padding:14px 30px;border-radius:2px;letter-spacing:.18em;margin-top:8px}
  .menu-toggle{display:flex}
  .search-toggle{display:flex}
  header .btn.hide-mob{display:none}
  .nav{height:72px}
  .logo .word{font-size:1.6rem}
  .seg-grid,.port-grid,.prod-grid,.www-grid,.field-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .form-card{padding:28px 20px}
  .wrap{padding:0 20px}
  .pad{padding:64px 0}.pad-sm{padding:48px 0}
  .hero{height:88vh;min-height:520px}
  .slide-content{bottom:16vh}
  .slide::after{background:linear-gradient(0deg,rgba(39,6,10,.9) 0%,rgba(39,6,10,.35) 70%),linear-gradient(90deg,rgba(39,6,10,.55),transparent)}
  .hero .headline{font-size:1.5rem}
  .hero-dots{left:20px;bottom:4vh}.hero-nav{right:20px;bottom:4vh}
  .hero-arrow{width:54px;height:54px;font-size:1.3rem}
  .scroll-cue{display:none}
  .section-head h1,.section-head h2,.split-body h2,.contact-info h2{font-size:1.9rem}
  .pd-actions .btn,.pd-actions{width:100%}.pd-actions .btn{justify-content:center}
  .map-wrap{padding:0}.map-lbl{font-size:23px}.map-lbl.hq{font-size:30px}
  .filters{gap:8px}.filters button{padding:9px 15px;font-size:.66rem}
  .dash{padding-top:96px}
  .stat-row{grid-template-columns:1fr 1fr}
  .split-img .badge{left:0;bottom:-18px}
  .btn{padding:14px 24px}
}
@media(max-width:420px){
  .stat-row{grid-template-columns:1fr}
  .gallery-mini{grid-template-columns:repeat(2,1fr)}
}
/* ---- Product tiles (branded placeholder until photos are added) ---- */
.prod-card .ph.tile,.pd-gallery .main.tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:radial-gradient(120% 120% at 30% 20%,var(--burgundy-600),var(--burgundy-800));position:relative;overflow:hidden}
.prod-card .ph.tile::before,.pd-gallery .main.tile::before{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(45deg,rgba(241,219,162,.04) 0 2px,transparent 2px 9px);opacity:.6}
.tile-ico{width:54px;height:54px;color:var(--gold-400);opacity:.9;transition:.5s var(--ease);z-index:1}
.prod-card:hover .tile-ico{transform:translateY(-4px) scale(1.06);color:var(--gold-300)}
.tile-name{font-family:'Fraunces',serif;font-size:1rem;letter-spacing:.04em;color:var(--gold-200);z-index:1;text-align:center;padding:0 16px}
.pd-gallery .main.tile .tile-ico{width:96px;height:96px}
.pd-gallery .main.tile .tile-name{font-size:1.5rem}
.prod-card h3{min-height:auto}
/* real product photos (studio shots on light) */
.prod-card .ph.photo{background:#fff;display:flex;align-items:center;justify-content:center}
.prod-card .ph.photo img{width:100%;height:100%;object-fit:cover;transition:1s var(--ease)}
.prod-card:hover .ph.photo img{transform:scale(1.05)}
.pd-gallery .main.photo{background:#fff;display:flex;align-items:center;justify-content:center}
.pd-gallery .main.photo img{width:100%;height:100%;object-fit:contain;padding:24px}
.sku-mini{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin:6px 0 0;font-family:'Jost',sans-serif}
.sku-badge{display:inline-block;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-700);background:var(--cream-2);border:1px solid var(--line);border-radius:30px;padding:7px 16px;margin-bottom:18px}

/* ---- US map ---- */
.map-wrap{max-width:900px;margin:0 auto 36px;padding:0}
.us-map{width:100%;height:auto;overflow:visible}
.map-land{fill:url(#landGrad);stroke:rgba(241,219,162,.55);stroke-width:1.2;stroke-linejoin:round;filter:drop-shadow(0 8px 26px rgba(0,0,0,.45))}
.map-dot{fill:var(--gold-300);stroke:var(--burgundy-900);stroke-width:1.5;filter:drop-shadow(0 0 5px rgba(241,219,162,.7))}
.map-dot.hq{fill:#fff;stroke:var(--gold-500)}
.map-halo{transform-origin:center;animation:pulse 20s ease-out infinite}
.map-pt{animation:ptin .6s var(--ease) both}
.map-pt:hover .map-lbl{fill:#fff}
@keyframes ptin{from{opacity:0;transform:scale(.4)}to{opacity:1}}
/* one ~2.5s flash, then quiet for the rest of the 20s cycle */
@keyframes pulse{0%{transform:scale(.5);opacity:.9}12%{transform:scale(1.7);opacity:0}100%{transform:scale(1.7);opacity:0}}
.map-lbl{fill:var(--gold-200);font-family:'Jost',sans-serif;font-size:11px;font-weight:400;text-anchor:middle;letter-spacing:.03em;paint-order:stroke;stroke:rgba(39,6,10,.7);stroke-width:3px}
.map-lbl.hq{font-size:14px;font-weight:600;fill:#fff}

/* ---- Nav quote link (mobile menu) ---- */
.nav-quote{display:none}

/* ---- Product toolbar wraps nicely ---- */
.prod-toolbar{margin-bottom:20px}
.filters{margin-bottom:40px}

/* ---- About page ---- */
.about-hero{padding:200px 0 90px;background-size:cover;background-position:center;color:#fff;text-align:center}
/* ---- Glassmorphism hero (About) ---- */
.glass-hero-wrap{padding:104px 14px 20px;background:var(--paper)}
@media(min-width:768px){.glass-hero-wrap{padding:104px 22px 24px}}
.glass-hero{position:relative;width:100%;max-width:1536px;margin:0 auto;height:min(82vh,760px);border-radius:1.5rem;overflow:hidden;display:flex;flex-direction:column;align-items:center;background:#2b070b}
@media(min-width:768px){.glass-hero{border-radius:3rem}}
.gh-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);animation:ghzoom 14s ease-out forwards}
@keyframes ghzoom{to{transform:scale(1)}}
.gh-shade{position:absolute;inset:0;background:linear-gradient(180deg,rgba(39,6,10,.55) 0%,rgba(39,6,10,.15) 30%,rgba(39,6,10,.35) 100%)}
.gh-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;z-index:1;mix-blend-mode:screen;pointer-events:none}
.gh-orb1{width:42%;height:60%;left:-8%;top:-10%;background:radial-gradient(circle,#bd9038,transparent 70%);animation:orbA 16s ease-in-out infinite}
.gh-orb2{width:46%;height:64%;right:-10%;bottom:-14%;background:radial-gradient(circle,#73202c,transparent 70%);animation:orbB 19s ease-in-out infinite}
.gh-orb3{width:34%;height:46%;right:24%;top:8%;background:radial-gradient(circle,#e6c878,transparent 70%);animation:orbA 22s ease-in-out infinite reverse}
@keyframes orbA{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(8%,12%) scale(1.12)}}
@keyframes orbB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-10%,-8%) scale(1.08)}}
@media(prefers-reduced-motion:reduce){.gh-orb{animation:none}}
.gh-content{position:relative;z-index:3;width:100%;max-width:60rem;padding:46px 24px 0;text-align:center;display:flex;flex-direction:column;align-items:center}
.gh-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:40px;background:rgba(255,255,255,.16);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.28);color:#fff;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;margin-bottom:22px}
.glass-hero h1{font-size:clamp(2.6rem,6vw,5rem);color:#fff;line-height:1.02;margin:0 0 16px;font-weight:400}
.glass-hero .gh-content p{color:#fff;font-weight:400;font-size:clamp(1rem,1.5vw,1.2rem);max-width:36rem;line-height:1.6;text-shadow:0 1px 16px rgba(20,4,7,.55),0 1px 3px rgba(20,4,7,.4)}
/* bottom-left glass stat card */
.gh-stat{position:absolute;z-index:4;left:16px;bottom:104px;right:16px;width:fit-content;
  padding:18px 20px;border-radius:1.6rem;background:rgba(255,255,255,.22);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.3);display:flex;flex-direction:column;gap:14px;min-width:180px;box-shadow:var(--shadow-lg)}
@media(min-width:768px){.gh-stat{left:28px;right:auto;bottom:28px}}
@media(min-width:1024px){.gh-stat{left:40px;bottom:40px}}
.gh-stat-top{display:flex;flex-direction:column}
.gh-stat-top b{font-family:'Fraunces',serif;font-size:2.4rem;line-height:1;color:#fff;font-weight:500}
.gh-stat-top span{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.8);margin-top:6px}
.gh-pill{display:inline-flex;align-items:center;gap:10px;align-self:flex-start;background:#fff;color:var(--burgundy-700);border-radius:40px;padding:7px 20px 7px 7px;font-size:.82rem;font-weight:500;transition:.3s;letter-spacing:.02em}
.gh-pill:hover{background:#fff;transform:translateY(-1px)}
.gh-ic{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--gold-grad);color:var(--burgundy-900)}
/* bottom-right faux-cutout card */
.gh-corner{position:absolute;z-index:4;bottom:0;right:0;padding:20px 18px 18px 36px;background:var(--paper);border-top-left-radius:2rem;display:flex;align-items:center;gap:16px;cursor:pointer;transition:background .3s var(--ease)}
.gh-corner:hover{background:#efe7d8}
.gh-corner:hover .gh-corner-circle{background:var(--gold-grad);color:var(--burgundy-900);border-color:transparent}
.gh-corner:hover .gh-corner-link{color:var(--gold-700)}
.gh-corner-circle{transition:.35s var(--ease)}
@media(min-width:768px){.gh-corner{padding:28px 24px 24px 56px;border-top-left-radius:3.5rem}}
.gh-mask{position:absolute;width:2rem;height:2rem;pointer-events:none}
@media(min-width:768px){.gh-mask{width:3.5rem;height:3.5rem}}
.gh-mask-top{top:-2rem;right:0}
.gh-mask-left{bottom:0;left:-2rem}
@media(min-width:768px){.gh-mask-top{top:-3.5rem}.gh-mask-left{left:-3.5rem}}
.gh-corner-circle{width:44px;height:44px;border-radius:50%;background:rgba(115,32,44,.06);border:1px solid rgba(115,32,44,.16);display:flex;align-items:center;justify-content:center;color:var(--burgundy-700);flex-shrink:0}
@media(min-width:768px){.gh-corner-circle{width:56px;height:56px}}
.gh-corner-title{display:block;font-family:'Fraunces',serif;font-size:1.1rem;color:var(--burgundy-700)}
@media(min-width:768px){.gh-corner-title{font-size:1.35rem}}
.gh-corner-link{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;color:var(--ink-soft);cursor:pointer;transition:.3s;margin-top:2px}
.gh-corner-link:hover{color:var(--gold-700)}
@media(max-width:600px){.gh-stat-top b{font-size:2rem}.gh-corner-title{font-size:1rem}.gh-corner-link span{display:none}}
/* Mobile: stack "Start a Project" and "Our Work" as two equal-width, edge-aligned cards */
@media(max-width:767px){
  .gh-stat{left:12px;right:12px;bottom:108px;width:auto;min-width:0;padding:14px 18px;
    flex-direction:row;align-items:center;justify-content:space-between;gap:14px}
  .gh-stat-top b{font-size:1.8rem}
  .gh-pill{flex-shrink:0}
  .gh-corner{left:12px;right:12px;bottom:14px;width:auto;padding:14px 18px;
    border-radius:1.2rem;border-top-left-radius:1.2rem;justify-content:flex-start}
  .gh-mask{display:none}
}
.about-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);margin:18px 0 0}
.about-hero p{color:rgba(241,219,162,.85);font-weight:300;max-width:600px;margin:18px auto 0;font-size:1.1rem}
.seg .num{font-family:'Fraunces',serif;font-size:1.05rem;color:var(--gold-600);margin-bottom:14px;font-style:italic}
.tech-grid{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;max-width:880px;margin:0 auto}
.tech-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:40px;padding:14px 26px;font-size:.95rem;color:var(--ink);background:#fff;transition:.3s}
.tech-chip:hover{background:var(--burgundy-700);color:var(--gold-200);border-color:var(--burgundy-700)}
.tech-chip span{color:var(--gold-500)}
.tech-chip:hover span{color:var(--gold-300)}
/* finishes swatch library */
.swatch-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.swatch{text-align:center}
.swatch .chip{display:block;width:100%;aspect-ratio:1.4;border-radius:6px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08),var(--shadow-sm);transition:.4s var(--ease)}
.swatch:hover .chip{transform:translateY(-4px);box-shadow:inset 0 0 0 1px rgba(0,0,0,.08),var(--shadow-lg)}
.swatch .chip.metal{position:relative;overflow:hidden}
.swatch .chip.metal::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.55) 48%,transparent 62%)}
.swatch .sw-name{display:block;margin-top:12px;font-size:.82rem;letter-spacing:.06em;color:var(--ink)}
.nail-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:24px}
.nail-dot{display:block;width:64px;height:64px;border-radius:50%;margin:0 auto;box-shadow:inset 0 -3px 6px rgba(0,0,0,.35),0 6px 14px -6px rgba(0,0,0,.5)}
@media(max-width:980px){.swatch-grid{grid-template-columns:repeat(3,1fr)}.nail-grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:680px){.swatch-grid{grid-template-columns:repeat(2,1fr)}.nail-grid{grid-template-columns:repeat(3,1fr)}}

.hidden{display:none!important}

/* ============================================================
   ACCESSIBILITY (WCAG 2.2 AA)
   ============================================================ */
#app:focus{outline:none}
/* skip link — hidden until keyboard-focused */
.skip-link{position:absolute;left:-9999px;top:0;z-index:500;background:var(--burgundy-900);color:var(--gold-200);padding:14px 26px;font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;border-radius:0 0 6px 0}
.skip-link:focus{left:0;outline:2px solid var(--gold-300);outline-offset:-2px}
/* visible keyboard focus ring — gold, only for keyboard users (mouse clicks unaffected) */
a:focus-visible,button:focus-visible,[tabindex]:focus-visible,summary:focus-visible,select:focus-visible{outline:2px solid var(--gold-500);outline-offset:2px;border-radius:2px}
.www a:focus-visible,.www button:focus-visible,footer a:focus-visible,header a:focus-visible,header button:focus-visible,.form-section a:focus-visible,.form-section button:focus-visible{outline-color:var(--gold-200)}
/* logo is now a real link — keep its block look */
a.logo{text-decoration:none;color:inherit;display:flex}
/* minimum tap targets (WCAG 2.5.8) */
.hero-dots button{min-width:24px;min-height:24px}
.lb-dots>*{min-width:24px;min-height:24px}
/* motion: stop remaining ambient animation for users who ask for less */
@media(prefers-reduced-motion:reduce){
  .marquee .track,.gh-bg,.map-halo,.scroll-cue{animation:none!important}
  .hero .slide .bg{transition:none!important}
  html{scroll-behavior: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}
/* product cards are real links now (crawlable); keep the card look */
a.prod-card{display:block;color:inherit;text-decoration:none}
/* spam honeypot — hidden from humans, visible to naive bots */
.hp-field{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
/* hero CTAs */
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
/* header phone (desktop) */
.header-phone{display:inline-flex;align-items:center;gap:8px;color:var(--gold-200);font-size:.82rem;letter-spacing:.06em;white-space:nowrap;transition:.3s}
.header-phone:hover{color:#fff}
@media(max-width:1180px){.header-phone{display:none}}
/* sample-request interest chips */
.sample-chips{display:flex;flex-wrap:wrap;gap:10px}
.sample-chip{font-family:'Jost',sans-serif;font-size:.8rem;letter-spacing:.04em;padding:9px 16px;border-radius:40px;border:1px solid rgba(241,219,162,.4);background:transparent;color:var(--gold-200);cursor:pointer;transition:.25s}
.sample-chip:hover{border-color:var(--gold-300)}
.sample-chip.on{background:var(--gold-grad);color:var(--burgundy-900);border-color:transparent;font-weight:600}
/* FAQ accordion (About) */
.faq{max-width:720px;margin:0 auto;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 40px 20px 4px;position:relative;font-family:'Fraunces',serif;font-size:1.12rem;color:var(--burgundy-800);transition:color .25s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--gold-600);transition:transform .3s}
.faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-item summary:hover{color:var(--gold-700)}
.faq-item p{padding:0 40px 22px 4px;color:var(--ink-soft);line-height:1.6;margin:0}

/* ---- Where We Work: flag, clickable map dots, client logos ---- */
.www-flag-img{display:inline-block;height:.78em;width:auto;vertical-align:baseline;margin-right:14px;border-radius:3px;box-shadow:0 2px 10px rgba(0,0,0,.4);transform:translateY(.06em)}
.map-loc{cursor:pointer;outline:none}
.map-loc:hover .map-dot,.map-loc:focus-visible .map-dot{fill:#fff;transform:scale(1.5)}
.map-loc .map-dot{transition:transform .25s var(--ease),fill .25s;transform-origin:center;transform-box:fill-box}
.map-loc:hover .map-lbl{fill:#fff}
.install-card.loc-hit{box-shadow:0 0 0 3px var(--gold-400),0 18px 50px -18px rgba(189,144,56,.55);transition:box-shadow .4s}
.client-logo.has-img{display:inline-flex;align-items:center;padding-bottom:0}
.client-logo.has-img img{height:30px;width:auto;max-width:130px;object-fit:contain;filter:brightness(0) invert(.92) sepia(.18);opacity:.62;transition:opacity .35s var(--ease)}
.client-logo.has-img:hover img{opacity:1}
.client-logo.has-img:hover::after{display:none}
.www-globe-img{display:inline-block;height:.82em;width:.82em;vertical-align:baseline;transform:translateY(.12em);margin-left:8px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.35))}
/* two-line Lavo wordmark lockup for the Trusted-by strip */
.client-logo.lavo{display:inline-flex;flex-direction:column;align-items:center;line-height:1;padding-bottom:0;color:rgba(241,219,162,.62);transition:color .35s var(--ease)}
.client-logo.lavo:hover{color:#fff}
.client-logo.lavo .lv{font-family:'Fraunces',serif;font-weight:400;font-size:1.55rem;letter-spacing:.42em;margin-right:-.42em}
.client-logo.lavo .lv-sub{font-family:'Fraunces',serif;font-size:.46rem;letter-spacing:.34em;margin-top:5px;margin-right:-.34em;text-transform:uppercase}
/* scroll-driven glare: a light band sweeps across flagged buttons as the page scrolls */
.btn-glare{position:relative;overflow:hidden}
.btn-glare::after{content:"";position:absolute;inset:-2px;pointer-events:none;
  background:linear-gradient(115deg,transparent 38%,rgba(255,255,255,.42) 50%,transparent 62%);
  transform:translateX(calc(var(--glare,0)*260% - 130%));}
@media(prefers-reduced-motion:reduce){.btn-glare::after{display:none}}
/* required-field asterisk on the quote form (visual emphasis only — not enforced) */
.field label .req{color:var(--gold-300);font-size:1.5em;font-weight:700;line-height:0;vertical-align:middle;margin-left:2px}
