/* ============================================================
   ROD’S CUSTOM PAINTING — "The Studio Coat" design system
   Editorial paint-atelier: warm paper, ink, one LIVING accent.
   The accent is the visitor's chosen paint color (fan deck) —
   picking a swatch repaints the whole site. Fonts: Instrument
   Serif (display) · Archivo (grotesque) · Space Mono (spec).
   ============================================================ */
:root{
  /* living paint color (JS swaps these from the fan deck) */
  --paint:#31513f;            /* No.02 Cascade Pine (default) */
  --paint-deep:#243d2f;
  --paint-soft:#e3e9e2;       /* pale tint of paint for washes */
  --on-paint:#f6f3ec;         /* text on paint */
  /* fixed system */
  --paper:#f5f1e8;            /* warm gallery paper */
  --paper-2:#ede8db;          /* deeper paper */
  --card:#fbf9f3;
  --ink:#191512;              /* warm near-black */
  --ink-2:#4c453c;            /* muted body */
  --ink-3:#7c7466;            /* captions */
  --line:#dcd5c6;
  --line-2:#c9c1af;
  --gold:#b98a2f;             /* review stars only */
  --ff-d:"Instrument Serif",Georgia,serif;
  --ff-g:"Archivo",system-ui,sans-serif;
  --ff-m:"Space Mono",monospace;
  --sh-1:0 1px 2px rgba(25,21,18,.06),0 6px 24px -12px rgba(25,21,18,.22);
  --sh-2:0 2px 6px rgba(25,21,18,.08),0 24px 48px -20px rgba(25,21,18,.3);
  --r:14px;
  --ease:cubic-bezier(.19,1,.22,1);
  --wrap:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth;scroll-padding-top:96px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
::selection{background:var(--paint);color:var(--on-paint)}
body{font-family:var(--ff-g);color:var(--ink);background:var(--paper);line-height:1.6;font-size:16.5px;-webkit-font-smoothing:antialiased;overflow-x:clip}
/* paper grain over everything, very quiet */
body::before{content:"";position:fixed;inset:0;z-index:2000;pointer-events:none;opacity:.05;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
h1,h2,h3,.dsp{font-family:var(--ff-d);font-weight:400;line-height:1.04;letter-spacing:-.01em}
h1 em,h2 em,h3 em{font-style:italic;color:var(--paint)}
h4{font-family:var(--ff-g);font-weight:700;letter-spacing:-.01em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,4vw,48px)}
section{padding:clamp(64px,9vw,120px) 0;position:relative}

/* ---- spec chips (masking-tape mono labels) ---- */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--ff-m);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-2);background:var(--paper-2);border:1px solid var(--line);padding:7px 14px 6px;border-radius:3px;position:relative;transform:rotate(-.6deg)}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--paint);flex:none}
.eyebrow.c-center{transform:rotate(.4deg)}
.sec-head{max-width:820px;margin-bottom:clamp(34px,5vw,56px)}
.sec-head h2{font-size:clamp(2.4rem,5.4vw,4.2rem);margin:18px 0 14px}
.sec-head p{color:var(--ink-2);font-size:1.1rem;max-width:58ch}
.sec-head.c-center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.c-center p{margin-left:auto;margin-right:auto}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:11px;background:var(--ink);color:var(--paper);font-weight:600;font-size:1rem;letter-spacing:.01em;padding:15px 26px;border-radius:9px;border:1.5px solid var(--ink);transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease)}
.btn::before{content:"";width:13px;height:13px;border-radius:3px 3px 3px 8px;background:var(--paint);flex:none;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25);transition:transform .35s var(--ease),background .5s}
.btn:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.btn:hover::before{transform:rotate(90deg)}
.btn-cool,.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn-cool:hover,.btn-ghost:hover{border-color:var(--ink);background:var(--card)}
.btn-dark{background:var(--paint);border-color:var(--paint);color:var(--on-paint)}
.btn-dark::before{background:var(--paper)}
.btn-dark:hover{background:var(--paint-deep)}
.btn-lg{padding:18px 32px;font-size:1.06rem}
.btn.full{width:100%;justify-content:center}

/* ---- preview + top bars ---- */
.preview-bar{background:var(--ink);color:#cfc8bb;text-align:center;font-size:.83rem;padding:9px 14px;position:relative;z-index:60}
.preview-bar b{color:var(--paper)}
.preview-bar a{color:var(--paper);text-decoration:underline;text-underline-offset:3px;font-weight:600}
.topbar{background:var(--paint);color:var(--on-paint);text-align:center;font-size:.82rem;letter-spacing:.02em;padding:7px 14px;transition:background .5s}
.topbar b{font-weight:700}
.topbar .dot{opacity:.55;margin:0 9px}

/* ---- header ---- */
header{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 88%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;height:76px}
.logo{display:flex;align-items:center;gap:12px;font-family:var(--ff-g);font-weight:800;font-size:1.22rem;letter-spacing:-.02em}
.logo .mark{width:38px;height:38px;border-radius:8px 8px 8px 16px;background:var(--paint);display:grid;place-items:center;box-shadow:inset 0 -10px 0 rgba(0,0,0,.14);transition:background .5s;flex:none}
.logo .mark svg{width:20px;height:20px;fill:none;stroke:var(--on-paint);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.logo small{display:block;font-family:var(--ff-m);font-weight:400;font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-3);margin-top:1px}
.mnav{display:flex;align-items:center;gap:4px}
.mnav>a,.drop>span{display:inline-block;padding:10px 14px;font-weight:500;font-size:.98rem;color:var(--ink-2);border-radius:8px;cursor:pointer;transition:color .2s,background .2s}
.mnav>a:hover,.drop:hover>span,.mnav>a.on,.drop>span.on{color:var(--ink);background:var(--paper-2)}
.drop{position:relative}
.drop>span::after{content:"";display:inline-block;width:7px;height:7px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;transform:rotate(45deg) translateY(-2px);margin-left:8px;transition:transform .25s}
.drop:hover>span::after{transform:rotate(225deg) translateY(-1px)}
.drop-menu{position:absolute;top:calc(100% + 10px);left:-12px;background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-2);padding:10px;display:grid;grid-template-columns:repeat(2,270px);gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:all .3s var(--ease)}
.drop:hover .drop-menu{opacity:1;visibility:visible;transform:none}
.drop-menu a{display:flex;gap:12px;align-items:flex-start;padding:11px 12px;border-radius:10px;transition:background .2s}
.drop-menu a:hover{background:var(--paper-2)}
.drop-menu .di{width:34px;height:34px;flex:none;border-radius:8px 8px 8px 14px;background:var(--paint-soft);display:grid;place-items:center;transition:background .5s}
.drop-menu .di svg{width:18px;height:18px;fill:none;stroke:var(--paint);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.drop-menu a.warm .di{background:var(--paper-2)}
.drop-menu .dt{display:block;font-weight:600;font-size:.95rem}
.drop-menu .dd{display:block;font-size:.8rem;color:var(--ink-3)}
.drop-menu .dm-all{grid-column:1/-1;justify-content:center;font-family:var(--ff-m);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paint);border-top:1px dashed var(--line);border-radius:0;margin-top:6px;padding-top:14px}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:700;font-size:.98rem;letter-spacing:.01em}
.nav-phone svg{width:17px;height:17px;fill:none;stroke:var(--paint);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ============ HERO — editorial split + Color Studio ============ */
.hero{padding:clamp(48px,6vw,84px) 0 0;overflow:clip}
.hero .wrap{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,.98fr);gap:clamp(28px,4vw,64px);align-items:center;position:relative}
.hero-copy{padding-bottom:clamp(40px,6vw,80px)}
.hero .badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--ff-m);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-2);background:var(--paper-2);border:1px solid var(--line);padding:8px 14px;border-radius:3px;transform:rotate(-.8deg)}
.hero .badge i{width:8px;height:8px;border-radius:50%;background:var(--paint);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 color-mix(in srgb,var(--paint) 45%,transparent)}55%{box-shadow:0 0 0 8px transparent}}
.hero h1{font-size:clamp(3.1rem,7vw,5.9rem);margin:22px 0 20px;max-width:12ch}
.hero h1 .swash{position:relative;white-space:nowrap}
.hero h1 .swash svg{position:absolute;left:-2%;bottom:-.14em;width:104%;height:.34em;overflow:visible}
.hero h1 .swash svg path{fill:none;stroke:var(--paint);stroke-width:10;stroke-linecap:round;opacity:.9;stroke-dasharray:620;stroke-dashoffset:620;animation:swash 1.1s .5s var(--ease) forwards;transition:stroke .5s}
@keyframes swash{to{stroke-dashoffset:0}}
.hero .sub{font-size:1.16rem;color:var(--ink-2);max-width:52ch;line-height:1.66}
.hero .acts{display:flex;align-items:center;gap:20px;margin-top:30px;flex-wrap:wrap}
.hero .or{font-size:.98rem;color:var(--ink-3)}
.hero .or b{color:var(--ink);font-weight:700}
.hero .trust{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero .trust .ti{position:relative;padding-left:16px}
.hero .trust .ti::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:3px;border-radius:2px;background:var(--paint);opacity:.85;transition:background .5s}
.hero .trust .tn{display:block;font-weight:800;font-size:1.02rem;letter-spacing:-.01em}
.hero .trust .tn .stars{color:var(--gold);letter-spacing:.05em}
.hero .trust .tl{display:block;font-size:.8rem;color:var(--ink-3);margin-top:2px}
.hero{overflow:hidden}
.hero::after{content:"ROD’S";position:absolute;z-index:-1;right:-2vw;top:-1vw;max-width:100%;font-family:var(--ff-g);font-weight:900;font-size:clamp(7rem,17vw,15rem);letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1.5px var(--line-2);opacity:.5;pointer-events:none;user-select:none}

/* ---- Color Studio card (signature tool) ---- */
.studio{background:var(--card);border:1px solid var(--line);border-radius:22px;box-shadow:var(--sh-2);overflow:hidden;position:relative}
.studio .room{position:relative;aspect-ratio:16/10.6;overflow:hidden;background:var(--paper-2)}
.studio .room img{width:100%;height:100%;object-fit:cover}
.studio .wallpaint{position:absolute;inset:0;background:var(--wall,#31513f);mix-blend-mode:color;transition:background .45s var(--ease)}
.studio .walldepth{position:absolute;inset:0;background:var(--wall,#31513f);mix-blend-mode:multiply;opacity:.18;transition:background .45s var(--ease)}
.studio .wallpaint,.studio .walldepth{-webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 40%,transparent 55%);mask-image:linear-gradient(to bottom,#000 0%,#000 40%,transparent 55%);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%;pointer-events:none}
.studio .room .tag-live{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;gap:8px;background:color-mix(in srgb,var(--ink) 82%,transparent);color:var(--paper);backdrop-filter:blur(6px);font-family:var(--ff-m);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;padding:7px 12px;border-radius:4px}
.studio .room .tag-live i{width:7px;height:7px;border-radius:50%;background:#7fd77f;animation:pulse 2s infinite}
.studio .room .readout{position:absolute;left:14px;bottom:14px;right:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;background:color-mix(in srgb,var(--card) 92%,transparent);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:12px;padding:12px 16px;box-shadow:var(--sh-1)}
.studio .readout .swn{font-family:var(--ff-d);font-size:1.3rem;line-height:1.1}
.studio .readout .swno{display:block;font-family:var(--ff-m);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-top:3px}
.studio .readout .hex{font-family:var(--ff-m);font-size:.72rem;color:var(--ink-3);letter-spacing:.08em}
.studio .deckbar{padding:18px 20px 20px}
.studio .deckbar .lbl{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--ff-m);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px}
.studio .deckbar .lbl a{color:var(--paint);text-decoration:underline;text-underline-offset:3px;text-transform:none;letter-spacing:.04em}
.deck{display:grid;grid-template-columns:repeat(10,1fr);gap:8px}
.deck button{aspect-ratio:1/1.28;border-radius:6px 6px 6px 12px;background:var(--c);position:relative;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1),inset 0 -8px 14px -8px rgba(0,0,0,.28);transition:transform .3s var(--ease),box-shadow .3s var(--ease);outline-offset:3px}
.deck button::after{content:"";position:absolute;top:5px;left:50%;transform:translateX(-50%);width:5px;height:5px;border-radius:50%;background:var(--paper);box-shadow:inset 0 1px 2px rgba(0,0,0,.35)}
.deck button:hover{transform:translateY(-4px)}
.deck button[aria-pressed="true"]{transform:translateY(-4px);box-shadow:0 0 0 2px var(--paper),0 0 0 3.5px var(--ink),inset 0 -8px 14px -8px rgba(0,0,0,.28)}
.studio .studio-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;border-top:1px dashed var(--line);padding:14px 20px;flex-wrap:wrap}
.studio .studio-foot .note{font-size:.8rem;color:var(--ink-3);max-width:30ch}
.studio .studio-foot .btn{padding:12px 20px;font-size:.92rem}
.hero-edge{height:clamp(34px,5vw,64px);background:var(--paint);transition:background .5s;-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 64' preserveAspectRatio='none'%3E%3Cpath d='M0 40 C60 20 140 58 240 44 C340 30 420 12 540 26 C660 40 740 60 860 48 C980 36 1060 10 1180 22 C1300 34 1380 52 1440 38 L1440 64 L0 64 Z'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 64' preserveAspectRatio='none'%3E%3Cpath d='M0 40 C60 20 140 58 240 44 C340 30 420 12 540 26 C660 40 740 60 860 48 C980 36 1060 10 1180 22 C1300 34 1380 52 1440 38 L1440 64 L0 64 Z'/%3E%3C/svg%3E");-webkit-mask-size:100% 100%;mask-size:100% 100%}

/* ============ GIANT TYPE MARQUEE ============ */
.bigband{background:var(--paint);color:var(--on-paint);padding:clamp(20px,3vw,34px) 0;overflow:clip;transition:background .5s}
.bigband .track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:slide 34s linear infinite}
.bigband:hover .track{animation-play-state:paused}
@keyframes slide{to{transform:translateX(-50%)}}
.bigband .cell{font-family:var(--ff-g);font-weight:900;font-size:clamp(2.6rem,6vw,5rem);letter-spacing:-.02em;text-transform:uppercase;padding:0 .45em;display:inline-flex;align-items:center;gap:.5em}
.bigband .cell.ghost{color:transparent;-webkit-text-stroke:1.5px color-mix(in srgb,var(--on-paint) 65%,transparent)}
.bigband .cell::after{content:"";width:.55em;height:.55em;border-radius:35% 35% 35% 60%;background:var(--on-paint);opacity:.35;margin-left:.45em}
@media(prefers-reduced-motion:reduce){.bigband .track{animation:none}}

/* ============ STATS AS FAN-DECK CHIPS ============ */
.stats{padding:clamp(56px,8vw,96px) 0 0}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,26px)}
.stat{background:var(--card);border:1px solid var(--line);border-radius:10px 10px 10px 22px;box-shadow:var(--sh-1);padding:26px 24px 22px;position:relative;transition:transform .4s var(--ease)}
.stat::before{content:"";position:absolute;top:12px;right:14px;width:10px;height:10px;border-radius:50%;background:var(--paper);box-shadow:inset 0 1px 3px rgba(0,0,0,.3),0 0 0 3px var(--paper-2)}
.stat::after{content:"";position:absolute;left:0;right:0;bottom:0;height:9px;border-radius:0 0 9px 21px;background:var(--paint);opacity:.9;transition:background .5s}
.stat:nth-child(1){transform:rotate(-1.1deg)}
.stat:nth-child(2){transform:rotate(.7deg) translateY(8px)}
.stat:nth-child(3){transform:rotate(-.5deg)}
.stat:nth-child(4){transform:rotate(1deg) translateY(6px)}
.stat:hover{transform:rotate(0) translateY(-4px)}
.stat .n{font-family:var(--ff-d);font-size:clamp(2.4rem,3.6vw,3.3rem);line-height:1;display:flex;align-items:baseline;gap:2px}
.stat .n em{font-style:italic;color:var(--paint);font-size:.62em;transition:color .5s}
.stat .l{font-family:var(--ff-m);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}

/* ============ SERVICES — drawdown cards ============ */
.svc-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.8vw,22px)}
.svc-c{grid-column:span 4;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;position:relative;display:flex;flex-direction:column;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.svc-c:hover{transform:translateY(-6px);box-shadow:var(--sh-2)}
.svc-c.photo .ph{aspect-ratio:16/9.4;overflow:hidden;position:relative}
.svc-c.photo .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);filter:saturate(.94)}
.svc-c.photo:hover .ph img{transform:scale(1.05)}
.svc-c.photo .ph::after{content:"";position:absolute;inset:auto 0 0 0;height:44%;background:linear-gradient(to top,rgba(25,21,18,.34),transparent)}
.svc-c .num{position:absolute;top:12px;left:14px;z-index:2;font-family:var(--ff-m);font-size:.64rem;letter-spacing:.22em;color:#fff;background:color-mix(in srgb,var(--ink) 72%,transparent);backdrop-filter:blur(4px);padding:6px 10px;border-radius:3px}
.svc-c .bd{padding:22px 24px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.svc-c h3{font-size:1.65rem}
.svc-c p{color:var(--ink-2);font-size:.95rem;line-height:1.6;flex:1}
.svc-c .more{font-weight:700;font-size:.9rem;color:var(--ink);display:inline-flex;align-items:center;gap:8px;margin-top:8px}
.svc-c .more::before{content:"";width:22px;height:2px;background:var(--paint);transition:width .35s var(--ease),background .5s}
.svc-c:hover .more::before{width:34px}
.svc-c:nth-child(1),.svc-c:nth-child(2){grid-column:span 6}
.svc-c:nth-child(1) .ph,.svc-c:nth-child(2) .ph{aspect-ratio:16/8.2}
.svc-c.svc-all{grid-column:span 12;background:var(--ink);color:var(--paper);flex-direction:row;align-items:center;justify-content:space-between;gap:26px;padding:34px 38px;min-height:0;border-color:var(--ink);flex-wrap:wrap}
.svc-c.svc-all::before{content:"";flex:none;order:2;width:min(300px,34vw);height:74px;border-radius:8px 8px 8px 18px;background:linear-gradient(115deg,#31513f 0 20%,#8a9b83 0 40%,#c2734a 0 60%,#8d9aa6 0 80%,#c8a24a 0 100%);box-shadow:inset 0 0 0 1px rgba(255,255,255,.14)}
.svc-c.svc-all .sa-k{font-family:var(--ff-m);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:#b3aa99;margin-bottom:8px}.svc-c.svc-all .grp-txt{flex:1 1 320px}.svc-c.svc-all .more{order:3}
.svc-c.svc-all h3{color:var(--paper);font-size:1.8rem}
.svc-c.svc-all p{color:#b3aa99}
.svc-c.svc-all .more{color:var(--paper)}

/* ============ CRAFT — "why coats fail" editorial ============ */
.craft{background:var(--ink);color:var(--paper)}
.craft .eyebrow{background:#241f1a;border-color:#3a332b;color:#b3aa99}
.craft h2{color:var(--paper)}
.craft .sec-head p{color:#b3aa99}
.craft-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:start}
.craft-steps{counter-reset:cs;display:flex;flex-direction:column}
.craft-step{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:26px 0;border-top:1px solid #2e2822;position:relative;transition:background .3s}
.craft-step:last-child{border-bottom:1px solid #2e2822}
.craft-step .cn{font-family:var(--ff-d);font-style:italic;font-size:2.2rem;color:var(--paint-soft);opacity:.55;min-width:64px;transition:color .5s}
.craft-step:hover .cn{opacity:1;color:var(--paint-soft)}
.craft-step h4{color:var(--paper);font-size:1.18rem;margin-bottom:6px}
.craft-step h4 .tape{display:inline-block;font-family:var(--ff-m);font-weight:400;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);background:var(--paint-soft);padding:4px 9px 3px;border-radius:2px;margin-left:10px;transform:rotate(-2deg) translateY(-3px);transition:background .5s}
.craft-step p{color:#b3aa99;font-size:.97rem;line-height:1.64;max-width:52ch}
.craft-fig{position:sticky;top:110px;border-radius:18px;overflow:hidden;box-shadow:var(--sh-2)}
.craft-fig img{width:100%;aspect-ratio:4/4.6;object-fit:cover}
.craft-fig .fig-cap{position:absolute;left:16px;bottom:16px;background:color-mix(in srgb,var(--ink) 78%,transparent);backdrop-filter:blur(6px);color:var(--paper);font-family:var(--ff-m);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;padding:8px 12px;border-radius:4px}

/* ============ ESTIMATOR — spec-sheet calculator ============ */
.est{background:var(--paper-2)}
.est-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,4vw,64px);align-items:start}
.est-card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh-2);overflow:hidden}
.est-card .ehead{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px dashed var(--line);font-family:var(--ff-m);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.est-card .ehead b{color:var(--ink)}
.est-body{padding:24px}
.est-row{margin-bottom:22px}
.est-row>.elbl{display:flex;justify-content:space-between;font-weight:700;font-size:.95rem;margin-bottom:10px}
.est-row>.elbl small{font-weight:400;color:var(--ink-3)}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opts button{border:1.5px solid var(--line-2);background:var(--paper);padding:10px 16px;border-radius:8px;font-weight:600;font-size:.92rem;transition:all .25s var(--ease)}
.opts button:hover{border-color:var(--ink)}
.opts button[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.opts.multi button[aria-pressed="true"]{background:var(--paint);border-color:var(--paint);color:var(--on-paint)}
.est-out{border-top:2px solid var(--ink);margin-top:6px;padding:20px 24px 24px;background:var(--paper)}
.est-out .eo-lbl{font-family:var(--ff-m);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.est-out .eo-val{font-family:var(--ff-d);font-size:clamp(2.2rem,3.4vw,3rem);line-height:1.1;margin:6px 0 4px}
.est-out .eo-val em{font-style:italic;color:var(--paint)}
.est-out .eo-note{font-size:.8rem;color:var(--ink-3);max-width:46ch}
.est-out .btn{margin-top:16px}
.est-copy .bullets{display:flex;flex-direction:column;gap:0;margin-top:28px}
.est-copy .bullets .bl{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:18px 0;border-top:1px solid var(--line)}
.est-copy .bullets .bl:last-child{border-bottom:1px solid var(--line)}
.est-copy .bl .ic{width:38px;height:38px;border-radius:9px 9px 9px 16px;background:var(--card);border:1px solid var(--line);display:grid;place-items:center}
.est-copy .bl .ic svg{width:19px;height:19px;fill:none;stroke:var(--paint);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .5s}
.est-copy .bl b{display:block;font-size:1rem;margin-bottom:2px}
.est-copy .bl p{color:var(--ink-2);font-size:.92rem;line-height:1.6}

/* ============ GALLERY — editorial masonry ============ */
.gal{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.6vw,20px)}
.gcell{position:relative;border-radius:var(--r);overflow:hidden;grid-column:span 4;aspect-ratio:4/3.1;box-shadow:var(--sh-1)}
.gcell img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);filter:saturate(.95)}
.gcell:hover img{transform:scale(1.06)}
.gcell::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(25,21,18,.55) 0%,transparent 42%)}
.gcell .cap{position:absolute;left:18px;bottom:16px;right:18px;color:#fff;z-index:2}
.gcell .cap .t{font-family:var(--ff-d);font-size:1.35rem;line-height:1.15}
.gcell .cap .s{font-family:var(--ff-m);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;opacity:.75;margin-top:4px}
.gcell.big{grid-column:span 8;grid-row:span 2;aspect-ratio:auto}
.gcell.wide{grid-column:span 8;aspect-ratio:16/6.4}

/* ============ WHY — ledger list ============ */
.why .wgrid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(30px,5vw,80px);align-items:start}
.why .sec-head{position:sticky;top:110px;margin-bottom:0}
.why-list{display:flex;flex-direction:column}
.why-i{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:24px 0;border-top:1px solid var(--line);transition:padding .3s var(--ease)}
.why-i:last-child{border-bottom:1px solid var(--line)}
.why-i .wn{font-family:var(--ff-m);font-size:.78rem;letter-spacing:.1em;color:var(--ink-3);background:var(--paper-2);border:1px solid var(--line);border-radius:4px;width:44px;height:44px;display:grid;place-items:center;transform:rotate(-2deg)}
.why-i:hover .wn{background:var(--paint);color:var(--on-paint);border-color:var(--paint)}
.why-i h4{font-size:1.16rem;margin-bottom:5px}
.why-i p{color:var(--ink-2);font-size:.96rem;line-height:1.62;max-width:54ch}

/* ============ CARE PLAN band ============ */
.plan-hi{background:var(--paint);color:var(--on-paint);border-radius:24px;padding:clamp(30px,4.5vw,60px);display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,60px);align-items:center;position:relative;overflow:hidden;transition:background .5s}
.plan-hi::after{content:"CARE";position:absolute;right:-.1em;bottom:-.32em;font-family:var(--ff-g);font-weight:900;font-size:clamp(6rem,13vw,11rem);letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1.2px color-mix(in srgb,var(--on-paint) 30%,transparent);pointer-events:none}
.plan-hi .eyebrow{background:color-mix(in srgb,var(--paint-deep) 70%,transparent);border-color:color-mix(in srgb,var(--on-paint) 25%,transparent);color:var(--on-paint)}
.plan-hi .eyebrow::before{background:var(--on-paint)}
.plan-hi h2{color:var(--on-paint);font-size:clamp(2.2rem,4.4vw,3.6rem);margin:16px 0 12px}
.plan-hi h2 em{color:var(--on-paint);opacity:.85}
.plan-hi p{color:color-mix(in srgb,var(--on-paint) 82%,transparent);max-width:52ch}
.plan-hi .btn{background:var(--on-paint);border-color:var(--on-paint);color:var(--ink);margin-top:22px}
.plan-hi .pfeat{list-style:none;display:flex;flex-direction:column;gap:0;position:relative;z-index:2}
.plan-hi .pfeat li{display:flex;gap:14px;align-items:center;padding:15px 0;border-top:1px solid color-mix(in srgb,var(--on-paint) 22%,transparent);font-weight:600}
.plan-hi .pfeat li:last-child{border-bottom:1px solid color-mix(in srgb,var(--on-paint) 22%,transparent)}
.plan-hi .pfeat li svg{width:20px;height:20px;flex:none;fill:none;stroke:var(--on-paint);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ============ REVIEWS — spotlight + strip ============ */
.rev-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:clamp(28px,4vw,44px)}
.rev-spot{border-left:4px solid var(--paint);padding:6px 0 6px clamp(20px,3vw,36px);margin-bottom:clamp(30px,4vw,48px);transition:border-color .5s;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:26px;align-items:center}
.rev-spot .q,.rev-spot .who{grid-column:1}
.rev-src{grid-column:2;grid-row:1/span 2;display:flex;flex-direction:column;gap:12px}
.rev-src .rs{background:var(--card);border:1px solid var(--line);border-radius:10px 10px 10px 18px;box-shadow:var(--sh-1);padding:12px 16px;min-width:0;flex:1 1 150px;max-width:240px}
.rev-src .rs b{font-size:1.25rem;display:flex;align-items:baseline;gap:8px}
.rev-src .rs b .stars{color:var(--gold);font-size:.85rem;letter-spacing:.1em}
.rev-src .rs span{display:block;font-family:var(--ff-m);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-top:3px}
@media(max-width:900px){.rev-spot{grid-template-columns:1fr}.rev-src{flex-direction:row;flex-wrap:wrap}}
.rev-spot .q{font-family:var(--ff-d);font-size:clamp(1.6rem,3.4vw,2.7rem);line-height:1.22;max-width:26ch}
.rev-spot .q em{font-style:italic;color:var(--paint)}
.rev-spot .who{margin-top:16px;font-family:var(--ff-m);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.rev-wrap{overflow:hidden;position:relative;margin:0 calc(-1*clamp(20px,4vw,48px));padding:0 clamp(20px,4vw,48px)}
.rev-wrap::before,.rev-wrap::after{content:"";position:absolute;top:0;bottom:0;width:clamp(20px,4vw,48px);z-index:3;pointer-events:none}
.rev-wrap::before{left:0;background:linear-gradient(to right,var(--paper),transparent)}
.rev-wrap::after{right:0;background:linear-gradient(to left,var(--paper),transparent)}
.revs{display:flex;gap:18px;width:max-content;animation:slide 60s linear infinite}
.rev-wrap:hover .revs{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){.revs{animation:none;width:auto;overflow-x:auto}}
.rev{width:360px;flex:none;background:var(--card);border:1px solid var(--line);border-radius:14px 14px 14px 26px;padding:24px 24px 20px;box-shadow:var(--sh-1);display:flex;flex-direction:column}
.rev .stars{color:var(--gold);letter-spacing:.12em;font-size:.92rem}
.rev p{margin:12px 0 16px;color:var(--ink-2);font-size:.95rem;line-height:1.62;flex:1}
.rev .by{font-weight:800;font-size:.94rem}
.rev .by span{display:block;font-family:var(--ff-m);font-weight:400;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-top:3px}

/* ============ AREA + MAP ============ */
.area{background:var(--paper-2)}
.area-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(28px,4vw,64px);align-items:center}
.area h2{font-size:clamp(2.2rem,4.6vw,3.6rem);margin:16px 0 12px}
.area h2 em{color:var(--paint)}
.area p{color:var(--ink-2);font-size:1.06rem;max-width:52ch}
.area .cities{display:flex;flex-wrap:wrap;gap:9px;margin-top:22px}
.area .cities a{border:1.5px solid var(--line-2);background:var(--card);border-radius:7px 7px 7px 13px;padding:9px 15px;font-weight:600;font-size:.9rem;transition:all .25s var(--ease)}
.area .cities a:hover{border-color:var(--paint);color:var(--paint);transform:translateY(-2px)}
.area-map{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-2);position:relative}
.area-map iframe{display:block;width:100%;height:420px;border:0;filter:grayscale(1) sepia(.18) contrast(1.02)}
.area-map::after{content:"";position:absolute;inset:0;pointer-events:none;background:color-mix(in srgb,var(--paint) 10%,transparent);mix-blend-mode:multiply;transition:background .5s}

/* ============ FAQ ============ */
.faq{max-width:820px;margin:0 auto}
.faq details{border-top:1px solid var(--line);transition:background .3s}
.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:22px 4px;font-weight:700;font-size:1.08rem;letter-spacing:-.01em}
.faq summary::-webkit-details-marker{display:none}
.faq summary .qi{width:34px;height:34px;flex:none;border:1.5px solid var(--line-2);border-radius:8px 8px 8px 14px;display:grid;place-items:center;font-weight:400;font-size:1.2rem;color:var(--ink-2);transition:all .3s var(--ease)}
.faq details[open] summary .qi{background:var(--paint);border-color:var(--paint);color:var(--on-paint);transform:rotate(45deg)}
.faq .fa{padding:0 4px 24px;color:var(--ink-2);line-height:1.66;max-width:64ch}

/* ============ FINAL CTA — painted panel ============ */
.cta{padding:0 0 clamp(64px,9vw,120px)}
.cta .wrap>div,.cta .inner{position:relative}
.cta-panel{background:var(--paint);color:var(--on-paint);border-radius:26px;padding:clamp(44px,7vw,90px) clamp(24px,5vw,80px);text-align:center;position:relative;overflow:hidden;transition:background .5s}
.cta-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 320px at 85% -10%,color-mix(in srgb,var(--on-paint) 14%,transparent),transparent 70%)}
.cta h2{color:var(--on-paint);font-size:clamp(2.6rem,6vw,4.8rem);max-width:18ch;margin:0 auto 16px;position:relative}
.cta h2 em{color:var(--on-paint);opacity:.85}
.cta p{color:color-mix(in srgb,var(--on-paint) 84%,transparent);max-width:54ch;margin:0 auto;position:relative}
.cta .acts{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:30px;flex-wrap:wrap;position:relative}
.cta .btn{background:var(--on-paint);border-color:var(--on-paint);color:var(--ink)}
.cta .call{color:var(--on-paint);font-weight:700;text-decoration:underline;text-underline-offset:4px}

/* ============ FOOTER ============ */
.mfoot{background:var(--ink);color:#b3aa99;padding:clamp(56px,7vw,90px) 0 0;overflow:clip}
.mfoot .fcols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:clamp(24px,4vw,56px)}
.mfoot h4{color:var(--paper);font-family:var(--ff-m);font-weight:400;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;margin-bottom:16px}
.mfoot a{display:block;padding:5px 0;font-size:.96rem;transition:color .2s}
.mfoot a:hover{color:var(--paper)}
.mfoot .flogo{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.mfoot .flogo .mark{width:38px;height:38px;border-radius:8px 8px 8px 16px;background:var(--paint);display:grid;place-items:center;transition:background .5s}
.mfoot .flogo .mark svg{width:20px;height:20px;fill:none;stroke:var(--on-paint);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.mfoot .flogo b{color:var(--paper);font-size:1.15rem;font-weight:800}
.mfoot .fp{font-size:.93rem;line-height:1.6;max-width:34ch}
.mfoot .fbadges{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.mfoot .fbadges span{font-family:var(--ff-m);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid #37312a;border-radius:4px;padding:6px 10px;color:#8f8677}
.mfoot .fbot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;border-top:1px solid #2b2620;margin-top:clamp(36px,5vw,56px);padding:22px 0 26px;font-size:.8rem;color:#8f8677}
.mfoot .fbot a{display:inline}
.mfoot .fword{font-family:var(--ff-g);font-weight:900;font-size:clamp(4rem,14vw,12.5rem);letter-spacing:-.03em;text-transform:uppercase;line-height:.86;text-align:center;color:transparent;-webkit-text-stroke:1.2px #37312a;user-select:none;pointer-events:none;margin-top:clamp(20px,3vw,40px)}
.mfoot .fword em{font-family:var(--ff-d);font-style:italic;text-transform:none;color:var(--paint);-webkit-text-stroke:0;transition:color .5s}

/* ============ SUBPAGES — hero / prose / aside ============ */
.phero{background-color:var(--ink);background-size:cover;background-position:center;color:var(--paper);padding:clamp(72px,9vw,130px) 0;position:relative}
.phero::before{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(20,16,12,.55),rgba(20,16,12,.15))}
.phero .wrap{position:relative;z-index:2}
.crumb{font-family:var(--ff-m);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:#cfc8bb;margin-bottom:18px}
.crumb a:hover{color:#fff;text-decoration:underline}
.crumb span{color:#fff}
.phero h1{font-size:clamp(2.6rem,5.6vw,4.6rem);max-width:20ch;color:#fff}
.phero h1 .cool,.phero h1 .warm{font-style:italic;color:var(--paint-soft)}
.phero .lead{margin-top:16px;font-size:1.13rem;color:#e9e4d8;max-width:62ch;line-height:1.66}
.phero .acts{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.phero .call,.cta .call{font-weight:700}
.phero .call{color:#fff;text-decoration:underline;text-underline-offset:4px}
.sphero{padding:clamp(60px,7vw,100px) 0}
.pbody{padding:clamp(48px,6vw,84px) 0}
.pgrid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:clamp(30px,4vw,64px);align-items:start}
.prose{font-size:1.02rem;color:var(--ink-2)}
.prose h2{font-size:clamp(1.9rem,3.6vw,2.7rem);color:var(--ink);margin:44px 0 14px}
.prose h2:first-child{margin-top:0}
.prose p{margin:0 0 16px;line-height:1.7}
.prose .lead-p{font-family:var(--ff-d);font-size:1.45rem;line-height:1.42;color:var(--ink);margin-bottom:24px}
.prose ul{list-style:none;margin:0 0 20px}
.prose ul li{position:relative;padding:10px 0 10px 34px;border-bottom:1px dashed var(--line)}
.prose ul li::before{content:"";position:absolute;left:2px;top:16px;width:14px;height:14px;border-radius:4px 4px 4px 8px;background:var(--paint);opacity:.9;transition:background .5s}
.prose ul li::after{content:"";position:absolute;left:6px;top:20px;width:6px;height:3px;border-left:1.6px solid var(--on-paint);border-bottom:1.6px solid var(--on-paint);transform:rotate(-45deg)}
.prose ul li b{color:var(--ink)}
.psteps{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:22px 0 8px}
.pstep{background:var(--card);border:1px solid var(--line);border-radius:12px 12px 12px 22px;padding:20px;display:flex;gap:16px;align-items:flex-start}
.pstep .pn{font-family:var(--ff-m);font-size:.8rem;width:40px;height:40px;flex:none;display:grid;place-items:center;background:var(--paint);color:var(--on-paint);border-radius:8px 8px 8px 14px;transform:rotate(-2deg);transition:background .5s}
.pstep h4{font-size:1.05rem;margin-bottom:4px;color:var(--ink)}
.pstep p{font-size:.9rem;margin:0;line-height:1.6}
.brands{display:flex;flex-wrap:wrap;gap:9px;margin:10px 0 8px}
.brands span{font-family:var(--ff-m);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line-2);background:var(--card);border-radius:5px;padding:8px 13px;color:var(--ink-2)}
.paside{position:sticky;top:110px;display:flex;flex-direction:column;gap:18px}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-1);padding:24px}
.pcard h3{font-size:1.5rem;margin-bottom:8px}
.pcard p{color:var(--ink-2);font-size:.93rem;line-height:1.6}
.pcard .res{display:flex;gap:18px;margin:14px 0}
.pcard .res .n{font-family:var(--ff-d);font-size:1.7rem}
.pcard .res .l{font-family:var(--ff-m);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-top:2px}
.pcard .btn{width:100%;justify-content:center;margin-top:10px}
.pcard .call{display:block;text-align:center;margin-top:12px;font-size:.92rem;color:var(--ink-2)}
.pcard .call b{color:var(--ink)}
.aside-emg{background:var(--paint-soft);border:1px solid var(--line);border-radius:16px;padding:20px;transition:background .5s}
.aside-emg .t{font-weight:800;margin-bottom:4px}
.aside-emg p{font-size:.9rem;color:var(--ink-2);line-height:1.55}
.aside-emg a{font-weight:700;color:var(--paint);text-decoration:underline;text-underline-offset:3px}
.rel-svc{border-top:1px solid var(--line);margin-top:34px;padding-top:20px}
.rel-svc h4{font-family:var(--ff-m);font-weight:400;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px}
.rel-svc a{display:inline-block;border:1.5px solid var(--line-2);border-radius:7px;padding:8px 14px;margin:0 8px 8px 0;font-weight:600;font-size:.88rem;transition:all .2s}
.rel-svc a:hover{border-color:var(--paint);color:var(--paint)}

/* ============ PLANS (maintenance) ============ */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,26px);align-items:stretch}
.plan{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:28px;display:flex;flex-direction:column;position:relative;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.plan:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.plan.feat{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.plan.feat h3,.plan.feat .price{color:var(--paper)}
.plan .tag{position:absolute;top:-13px;left:24px;background:var(--paint);color:var(--on-paint);font-family:var(--ff-m);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px;border-radius:4px;transform:rotate(-1.5deg);transition:background .5s}
.plan .pn{font-family:var(--ff-m);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.plan.feat .pn{color:#b3aa99}
.plan .pd{font-size:.92rem;color:var(--ink-2);margin:6px 0 14px}
.plan.feat .pd{color:#b3aa99}
.plan .price{font-family:var(--ff-d);font-size:2.6rem;line-height:1}
.plan .price span{font-family:var(--ff-g);font-size:1rem;color:var(--ink-3)}
.plan .pbill{font-size:.78rem;color:var(--ink-3);margin-top:4px}
.plan ul{list-style:none;margin:18px 0 22px;flex:1}
.plan li{display:flex;gap:11px;align-items:flex-start;padding:8px 0;font-size:.93rem}
.plan li svg{width:17px;height:17px;flex:none;margin-top:3px;fill:none;stroke:var(--paint);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.plan.feat li svg{stroke:var(--paint-soft)}
.plan .btn{justify-content:center}
.plan.feat .btn{background:var(--paper);border-color:var(--paper);color:var(--ink)}
.plan-note{font-size:.85rem;color:var(--ink-3);text-align:center;margin-top:22px}

/* ============ BOOKING / CONTACT ============ */
.bk-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,60px);align-items:start}
.emg-card{display:flex;gap:16px;background:var(--paint-soft);border:1px solid var(--line);border-radius:16px;padding:20px;transition:background .5s}
.emg-card .eic{width:42px;height:42px;flex:none;border-radius:10px 10px 10px 18px;background:var(--paint);display:grid;place-items:center;transition:background .5s}
.emg-card .eic svg{width:20px;height:20px;fill:none;stroke:var(--on-paint);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.emg-card .t{font-weight:800}
.emg-card .d{font-size:.92rem;color:var(--ink-2);line-height:1.55}
.emg-card a{font-weight:700;color:var(--paint);text-decoration:underline;text-underline-offset:3px}
.bk-pts{list-style:none;margin:22px 0}
.bk-pts li{display:flex;gap:13px;padding:12px 0;border-bottom:1px dashed var(--line);font-size:.97rem;color:var(--ink-2)}
.bk-pts .ck{width:24px;height:24px;flex:none;border-radius:6px 6px 6px 11px;background:var(--paint);display:grid;place-items:center;margin-top:1px;transition:background .5s}
.bk-pts .ck svg{width:13px;height:13px;fill:none;stroke:var(--on-paint);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.bk-pts b{color:var(--ink)}
.bk-hours{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 22px}
.bk-hours h4{font-family:var(--ff-m);font-weight:400;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:10px}
.bk-hours .row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed var(--line);font-size:.92rem}
.bk-hours .row:last-child{border:0}
.bk-hours .row b{font-weight:700}
.bk-card{background:var(--card);border:1px solid var(--line);border-radius:20px;box-shadow:var(--sh-2);padding:clamp(22px,3vw,34px);position:relative}
.bk-card::before{content:"EST-04";position:absolute;top:18px;right:22px;font-family:var(--ff-m);font-size:.62rem;letter-spacing:.22em;color:var(--ink-3)}
.bk-card .bh{font-family:var(--ff-d);font-size:2rem;line-height:1.1}
.bk-card .bs{color:var(--ink-2);font-size:.95rem;margin:8px 0 20px}
.bk-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bk-f{margin-bottom:14px}
.bk-f label{display:block;font-family:var(--ff-m);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);margin-bottom:7px}
.bk-f label .req{color:#a4442c}
.bk-f input,.bk-f select,.bk-f textarea{width:100%;font:inherit;font-size:.98rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--line-2);border-radius:9px;padding:13px 14px;transition:border .2s,box-shadow .2s}
.bk-f input:focus,.bk-f select:focus,.bk-f textarea:focus{outline:none;border-color:var(--paint);box-shadow:0 0 0 3px color-mix(in srgb,var(--paint) 18%,transparent)}
.bk-f input.bad,.bk-f select.bad{border-color:#a4442c;box-shadow:0 0 0 3px rgba(164,68,44,.14)}
.urg{display:flex;gap:10px;flex-wrap:wrap}
.urg .uo{position:relative}
.urg input{position:absolute;opacity:0;inset:0;cursor:pointer}
.urg label{display:inline-block;border:1.5px solid var(--line-2);border-radius:8px;padding:10px 16px;font-weight:600;font-size:.9rem;transition:all .2s;cursor:pointer}
.urg input:checked+label{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.urg .em input:checked+label{background:var(--paint);border-color:var(--paint);color:var(--on-paint)}
.bk-card .btn{margin-top:8px}
.bk-fine{font-size:.8rem;color:var(--ink-3);margin-top:14px}
.bk-fine b{color:var(--ink-2)}
.bk-done{display:none;text-align:center;padding:40px 10px}
.bk-done.on{display:block}
.bk-done .ic{width:64px;height:64px;margin:0 auto 18px;border-radius:16px 16px 16px 28px;background:var(--paint);display:grid;place-items:center;transition:background .5s}
.bk-done .ic svg{width:30px;height:30px;fill:none;stroke:var(--on-paint);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.bk-done h3{font-size:1.9rem;margin-bottom:8px}
.bk-done p{color:var(--ink-2);max-width:44ch;margin:0 auto}
.warm-card{background:var(--paint-soft)}

/* ============ EMERGENCY / DEADLINE BAND ============ */
.emg .wrap{background:var(--ink);color:var(--paper);border-radius:20px;padding:clamp(24px,3.4vw,40px) clamp(24px,3.4vw,44px);display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.emg .el{display:flex;align-items:center;gap:18px;flex:1 1 420px}
.emg .eic{width:52px;height:52px;flex:none;border-radius:12px 12px 12px 22px;background:var(--paint);display:grid;place-items:center;transition:background .5s}
.emg .eic svg{width:24px;height:24px;fill:none;stroke:var(--on-paint);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.emg h3{color:var(--paper);font-size:1.6rem;margin-bottom:4px}
.emg p{color:#b3aa99;font-size:.95rem;max-width:56ch}
.emg .btn{background:var(--paper);border-color:var(--paper);color:var(--ink);flex:none}

/* ============ MOBILE MENU / BURGER / FAB ============ */
.burger{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;gap:5px;padding:10px;border-radius:9px;border:1px solid var(--line)}
.burger span{display:block;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
body.menu-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.m-menu{position:fixed;inset:0;z-index:90;pointer-events:none;overflow:hidden}
.m-menu .ov{position:absolute;inset:0;background:rgba(25,21,18,.5);opacity:0;transition:opacity .3s}
.m-menu .panel{position:absolute;top:0;right:0;bottom:0;width:min(88vw,380px);background:var(--paper);box-shadow:var(--sh-2);transform:translateX(102%);transition:transform .45s var(--ease);display:flex;flex-direction:column;overflow-y:auto;padding:18px 22px 28px}
body.menu-open .m-menu{pointer-events:auto}
body.menu-open .m-menu .ov{opacity:1}
body.menu-open .m-menu .panel{transform:none}
.m-menu .mm-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:10px}
.m-menu .mm-head b{font-family:var(--ff-m);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-3)}
.m-menu .mm-close{font-size:1.6rem;width:40px;height:40px;border:1px solid var(--line);border-radius:9px}
.m-menu .ml{display:block;padding:13px 6px;font-weight:600;font-size:1.05rem;border-bottom:1px dashed var(--line)}
.m-menu .ml.sub{padding-left:22px;font-weight:500;font-size:.98rem;color:var(--ink-2)}
.m-menu .ml.grp{font-family:var(--ff-m);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);border:0;padding-top:18px}
.m-menu .mm-cta{margin-top:auto;padding-top:22px;display:flex;flex-direction:column;gap:12px}
.m-menu .mm-cta .btn{justify-content:center}
.m-menu .mm-phone{text-align:center;font-weight:800;font-size:1.06rem}
.fab-call{display:none;position:fixed;left:14px;right:14px;bottom:14px;z-index:70;background:var(--ink);color:var(--paper);border-radius:13px;padding:15px 20px;align-items:center;justify-content:center;gap:10px;font-weight:700;box-shadow:var(--sh-2)}
.fab-call svg{width:18px;height:18px;fill:none;stroke:var(--paint-soft);stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}

/* ============ MOTION / FOCUS ============ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.no-js .reveal{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.deck button,.stat,.btn{transition:none}}
:focus-visible{outline:2.5px solid var(--paint);outline-offset:3px;border-radius:4px}

/* ============ RESPONSIVE ============ */
@media(max-width:1120px){
  .mnav{display:none}
  .burger{display:flex}
  .nav-phone{display:none}
  .hero .wrap{grid-template-columns:1fr;gap:34px}
  .hero-copy{padding-bottom:0}
  .hero::after{font-size:22vw;right:-4vw;top:-4vw}
  .craft-grid{grid-template-columns:1fr}
  .craft-fig{position:static;max-width:640px}
  .est-grid{grid-template-columns:1fr}
  .why .wgrid{grid-template-columns:1fr}
  .why .sec-head{position:static}
  .area-grid{grid-template-columns:1fr}
  .pgrid{grid-template-columns:1fr}
  .paside{position:static}
  .bk-grid{grid-template-columns:1fr}
  .plan-hi{grid-template-columns:1fr}
  .mfoot .fcols{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  body{font-size:15.5px}
  .nav{height:64px;gap:10px}
  .nav-right{gap:8px}
  .nav-right .btn{padding:10px 13px;font-size:.84rem;white-space:nowrap}
  .logo{font-size:1.05rem;gap:9px}
  .logo .mark{width:32px;height:32px}
  .logo small{letter-spacing:.18em;white-space:nowrap}
  .stats .wrap{grid-template-columns:1fr 1fr;gap:14px}
  .stat:nth-child(n){transform:none}
  .svc-grid{grid-template-columns:1fr}
  .svc-c,.svc-c:nth-child(1),.svc-c:nth-child(2),.svc-c.svc-all{grid-column:span 12}
  .gal{grid-template-columns:1fr}
  .gcell,.gcell.big,.gcell.wide{grid-column:span 1;aspect-ratio:4/2.9}
  .deck{grid-template-columns:repeat(5,1fr)}
  .deck button{aspect-ratio:1/1.1}
  .psteps{grid-template-columns:1fr}
  .plans{grid-template-columns:1fr}
  .bk-row{grid-template-columns:1fr}
  .rev{width:300px}
  .fab-call{display:flex}
  body{padding-bottom:70px}
  .mfoot .fcols{grid-template-columns:1fr}
  .area-map iframe{height:320px}
  .cta .acts{flex-direction:column}
  .studio .room{aspect-ratio:16/11}
  .studio .studio-foot{flex-direction:column;align-items:stretch;text-align:center}
  .studio .studio-foot .btn{justify-content:center}
  .hero h1{font-size:clamp(2.7rem,12vw,3.6rem)}
  .rev-spot .q{font-size:1.5rem}
}
