/* ============================================================
   Alpha Prime Garage — shared stylesheet (DARK)
   Pages: index.html · services.html · tips.html · about.html
   ============================================================ */
:root{
  --bg:#121316; --bg-2:#16181C; --surface:#1B1E23; --surface-2:#23262C;
  --text:#ECE7DD; --muted:#9A958B; --muted-2:#6E6A62;
  --red:#E11E2A; --red-bright:#FF3A45; --red-glow:rgba(225,30,42,.4);
  --gold:#E6A700;
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.17);
  --maxw:1180px; --ease:cubic-bezier(.16,.84,.44,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;-webkit-font-smoothing:antialiased}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,28px)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:-.015em;color:#fff}
.red{color:var(--red-bright)}
.eyebrow{font-size:.76rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--red-bright);display:inline-block}
.section{padding:clamp(70px,8.5vw,112px) 0}
.lede{color:var(--muted);font-size:1.12rem;max-width:560px}
.center{text-align:center}
.sec-title{font-size:clamp(2rem,4.4vw,3.2rem);margin:14px 0 0}
.sec-intro{max-width:620px;margin-top:16px;color:var(--muted);font-size:1.06rem}
.alt{background:var(--bg-2)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6rem;font-family:'Hanken Grotesk';font-weight:600;font-size:1rem;padding:14px 26px;border-radius:8px;border:1.5px solid transparent;cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s;white-space:nowrap}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-bright);transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--text);border-color:var(--line-2)}
.btn-line:hover{border-color:#fff;transform:translateY(-2px)}
.btn-wa{background:#1FAE54;color:#fff}
.btn-wa:hover{background:#23c25e;transform:translateY(-2px)}
.link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;color:var(--red-bright);border-bottom:1.5px solid transparent;padding-bottom:2px;transition:border-color .2s,gap .2s}
.link-arrow:hover{border-color:var(--red-bright);gap:.75rem}

/* topbar */
.topbar{background:#0C0D0F;color:#B7B2A8;font-size:.82rem;border-bottom:1px solid var(--line)}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:40px;gap:18px}
.topbar a:hover{color:#fff}.topbar i{color:var(--red-bright);margin-right:6px}
.topbar .tr{display:flex;gap:18px;align-items:center}.topbar .soc{display:flex;gap:14px}
@media(max-width:720px){.topbar .tl{display:none}.topbar .container{justify-content:center}}

/* header */
header{position:sticky;top:0;z-index:90;background:rgba(18,19,22,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
header.scrolled{border-color:var(--line);background:rgba(18,19,22,.96)}
header .container{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:40px;width:auto}
.brand .wm{font-family:'Fraunces',serif;font-weight:600;font-size:1.26rem;line-height:1;color:#fff}
.brand .wm small{display:block;font-family:'Hanken Grotesk';font-size:.58rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:3px}
nav ul{display:flex;align-items:center;gap:30px;list-style:none}
nav a:not(.btn){font-weight:600;font-size:.98rem;color:var(--muted);transition:color .2s}
nav a:not(.btn):hover,nav a.active{color:#fff}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-cta .phone{font-weight:600;color:#fff}.nav-cta .phone:hover{color:var(--red-bright)}
.nav-cta .btn{padding:10px 20px}
.menu-btn{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer}
.nav-backdrop{position:fixed;inset:0;background:rgba(8,8,9,.55);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .35s;z-index:110}
.nav-backdrop.on{opacity:1;visibility:visible}
@media(max-width:980px){
  nav ul{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);flex-direction:column;justify-content:center;gap:26px;background:#0E0F12;border-left:1px solid var(--line);box-shadow:-24px 0 60px rgba(0,0,0,.55);transform:translateX(100%);transition:transform .4s var(--ease);z-index:120}
  nav ul.open{transform:translateX(0)}nav a:not(.btn){font-size:1.35rem}
  .menu-btn{display:block;position:relative;z-index:130}.nav-cta .phone,.nav-cta .btn{display:none}
  header{backdrop-filter:none;-webkit-backdrop-filter:none;background:#121316}
}

/* hero (one per page) */
.hero{padding:clamp(40px,6vw,70px) 0 clamp(50px,7vw,86px)}
.hero-grid{display:flex;flex-wrap:wrap;gap:clamp(34px,5vw,54px);align-items:center}
.hero-grid>div{flex:1 1 340px}
.hero h1{font-size:clamp(2.6rem,5.4vw,4.4rem);font-weight:500;margin:18px 0 20px;color:#fff}
.hero h1 em{font-style:normal;color:var(--red-bright)}
.hero .btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.hero-trust{display:flex;gap:22px;flex-wrap:wrap;margin-top:28px;color:var(--muted);font-size:.92rem}
.hero-trust span{display:inline-flex;align-items:center;gap:8px}.hero-trust i{color:var(--red-bright)}
.hero-photo{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/4.3;background:var(--surface);box-shadow:0 36px 70px -30px #000}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo .stamp{position:absolute;left:18px;bottom:18px;background:rgba(18,19,22,.9);border:1px solid var(--line-2);border-radius:10px;padding:11px 16px;display:flex;align-items:center;gap:11px;backdrop-filter:blur(6px)}
.hero-photo .stamp b{font-family:'Fraunces';font-size:1.4rem;line-height:1;color:#fff}
.hero-photo .stamp .stars{color:var(--gold);font-size:.82rem;letter-spacing:1px}
.hero-photo .stamp small{color:var(--muted);font-size:.74rem}
/* page hero (interior pages, no photo) */
.page-hero{padding:54px 0 10px}
.page-hero .crumb{font-size:.85rem;color:var(--muted-2);margin-bottom:18px}
.page-hero .crumb a:hover{color:var(--red-bright)}
.page-hero h1{font-size:clamp(2.3rem,5vw,3.8rem);font-weight:500;margin:14px 0 18px;color:#fff}

/* brands */
.brands{padding:42px 0;border-top:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);background:linear-gradient(135deg,#5E101A,#3A0A10);overflow:hidden}
.brands .lbl{text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,236,236,.72);margin-bottom:26px}
.brand-marquee{display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.brand-track{display:flex;align-items:center;gap:48px;padding-right:48px;flex-shrink:0;animation:brand-scroll 40s linear infinite}
.brands:hover .brand-track{animation-play-state:paused}
.brand-track img{height:36px;width:auto;max-width:112px;object-fit:contain;filter:grayscale(1) brightness(2.4);opacity:.8;transition:filter .35s,opacity .35s,transform .35s}
.brand-track img:hover{filter:none;opacity:1;transform:scale(1.12)}
@keyframes brand-scroll{to{transform:translateX(-50%)}}

/* services teaser (home) + list (services page) */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,420px),1fr));gap:clamp(34px,4vw,42px) 60px;margin-top:50px}
.svc-cat>h3{font-family:'Hanken Grotesk';font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red-bright);padding-bottom:14px;border-bottom:1px solid var(--line-2);margin-bottom:4px}
.svc{display:block;padding:18px 0;border-bottom:1px solid var(--line)}
.svc:last-child{border-bottom:none}
.svc .n{font-family:'Fraunces';font-size:1.3rem;font-weight:600;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:color .2s}
.svc .d{color:var(--muted);font-size:.97rem;margin-top:5px;max-width:48ch}
.svc:hover .n{color:var(--red-bright)}

/* owner */
.owner-grid{display:flex;flex-wrap:wrap;gap:clamp(28px,4vw,52px);align-items:center}
.owner-photo{flex:0 0 clamp(220px,30vw,300px)}
.owner-copy{flex:1 1 340px}
.owner-photo{border-radius:14px;overflow:hidden;aspect-ratio:1;background:var(--surface);border:1px solid var(--line-2)}
.owner-photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.owner-copy h2{font-size:clamp(1.9rem,3.8vw,2.7rem);margin:14px 0 16px;color:#fff}
.owner-copy p{color:var(--muted);font-size:1.06rem;margin-bottom:14px;max-width:60ch}
.owner-copy .sig{margin-top:18px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.owner-name{font-family:'Fraunces';font-style:italic;font-size:1.25rem;color:var(--text)}

/* ===== uniform gallery (equal squares) ===== */
.gal-filters{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px}
.gal-chip{font-weight:600;font-size:.9rem;padding:8px 17px;border-radius:50px;border:1.5px solid var(--line-2);background:transparent;color:var(--muted);cursor:pointer;transition:all .2s}
.gal-chip:hover{border-color:#fff;color:#fff}
.gal-chip.on{background:var(--red);border-color:var(--red);color:#fff}
.gal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,160px),1fr));gap:14px;margin-top:30px}
.gal-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;background:var(--surface)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gal-item .cap{position:absolute;left:0;right:0;bottom:0;padding:30px 14px 13px;background:linear-gradient(transparent,rgba(0,0,0,.8));color:#fff;font-family:'Fraunces';font-weight:600;font-size:1rem;opacity:0;transform:translateY(8px);transition:opacity .35s,transform .35s}
.gal-item .zoom{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(18,19,22,.85);border:1px solid var(--line-2);color:#fff;display:grid;place-items:center;opacity:0;transform:scale(.7);transition:.3s}
.gal-item:hover img{transform:scale(1.07)}
.gal-item:hover .cap,.gal-item:hover .zoom{opacity:1;transform:none}
.gal-item.hide{display:none}
/* lightbox */
#lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,8,9,.95);display:none;align-items:center;justify-content:center;padding:30px}
#lightbox.on{display:flex}
#lightbox figure{display:flex;flex-direction:column;align-items:center;gap:12px}
#lightbox img{max-width:92vw;max-height:80vh;border-radius:8px;box-shadow:0 30px 80px #000}
#lightbox figcaption{color:#ECE7DD;font-family:'Fraunces';font-size:1.15rem}
#lightbox .lb-count{color:#7d786f;font-size:.85rem}
#lightbox .x{position:absolute;top:22px;right:28px;color:#fff;font-size:2rem;cursor:pointer;opacity:.85}
#lightbox .nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:1.2rem;cursor:pointer;display:grid;place-items:center;transition:.2s}
#lightbox .nav:hover{background:var(--red);border-color:var(--red)}
#lightbox .prev{left:24px}#lightbox .next{right:24px}
@media(max-width:640px){#lightbox .nav{width:44px;height:44px}#lightbox .prev{left:8px}#lightbox .next{right:8px}}

/* instagram multi-reel carousel */
.ig-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.ig-nav{display:flex;gap:10px}
.ig-nav button{width:46px;height:46px;border-radius:50%;border:1.5px solid var(--line-2);background:transparent;color:#fff;cursor:pointer;transition:all .2s}
.ig-nav button:hover{background:var(--red);border-color:var(--red)}
.ig-track{display:flex;align-items:stretch;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;margin-top:38px;padding-bottom:10px;scrollbar-width:none}
.ig-track::-webkit-scrollbar{display:none}
/* crop reel embeds to the VIDEO only — clip IG's header/caption/action bar */
.ig-slide{position:relative;flex:0 0 auto;width:330px;height:586px;scroll-snap-align:start;border-radius:16px;overflow:hidden;background:#000;border:1px solid var(--line-2);box-shadow:0 18px 40px -22px #000}
.ig-slide iframe{position:absolute;top:-54px;left:0;width:100%;height:750px;border:0;display:block}
.ig-cta{flex:0 0 auto;width:280px;scroll-snap-align:start;border-radius:16px;background:var(--surface);border:1px solid var(--line-2);color:var(--text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:36px}
.ig-cta i{font-size:2.4rem;color:#fff}.ig-cta h4{font-family:'Fraunces';color:#fff;font-size:1.4rem}
@media(max-width:560px){.ig-slide{width:320px;height:569px}.ig-slide iframe{top:-54px;height:733px}}

/* reviews */
.reviews .rv-stage{max-width:840px;margin:34px auto 0;text-align:center;min-height:220px}
.rv-q{font-family:'Fraunces';font-weight:500;font-size:clamp(1.45rem,2.9vw,2.1rem);line-height:1.4;color:#fff}
.rv{display:none}.rv.on{display:block;animation:fade .5s ease}
.rv .who{margin-top:22px;color:var(--muted);font-size:1rem}.rv .who b{color:#fff;font-weight:600}
.rv-stars{color:var(--gold);letter-spacing:2px;margin-bottom:16px}
.rv-dots{display:flex;gap:9px;justify-content:center;margin-top:30px}
.rv-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.22);cursor:pointer;transition:.25s}
.rv-dots span.on{background:var(--red);width:26px;border-radius:5px}
.rv-foot{text-align:center;margin-top:30px}
.rv-foot a{color:#fff;border-bottom:1.5px solid var(--red);padding-bottom:2px;font-weight:600}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ===== service page bits ===== */
.prose{max-width:760px}
.prose p{color:var(--muted);font-size:1.08rem;margin-bottom:16px}
.svc-list{margin-top:46px}
.svc-row{display:flex;flex-wrap:wrap;gap:6px 30px;padding:26px 0;border-bottom:1px solid var(--line)}
.svc-row h3{flex:0 0 210px;font-family:'Fraunces';font-size:1.45rem;font-weight:600;color:#fff}
.svc-row p{flex:1 1 320px;color:var(--muted);font-size:1.02rem}
/* process steps */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:30px 18px;margin-top:48px;counter-reset:s}
.step{position:relative;padding-top:46px}
.step::before{counter-increment:s;content:"0" counter(s);position:absolute;top:0;left:0;font-family:'Fraunces';font-style:italic;font-size:1.5rem;color:var(--red-bright)}
.step::after{display:none}
.step h4{font-family:'Fraunces';font-size:1.18rem;font-weight:600;color:#fff;margin-bottom:6px}
.step p{color:var(--muted);font-size:.92rem}
/* spare parts split */
.parts{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:20px;margin-top:44px}
.part{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:30px 28px}
.part i{font-size:1.5rem;color:var(--red-bright);margin-bottom:14px}
.part h4{font-family:'Fraunces';font-size:1.4rem;font-weight:600;color:#fff;margin-bottom:8px}
.part p{color:var(--muted);font-size:1rem}

/* ===== tips: card skeleton ===== */
.tip-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:18px;margin-top:48px}
.tcard{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:30px 26px;transition:transform .3s var(--ease),border-color .3s}
.tcard:hover{transform:translateY(-5px);border-color:var(--line-2)}
.tcard .ic{width:50px;height:50px;border-radius:12px;display:grid;place-items:center;background:rgba(225,30,42,.12);border:1px solid rgba(225,30,42,.3);color:var(--red-bright);font-size:1.3rem;margin-bottom:18px}
.tcard h4{font-family:'Fraunces';font-size:1.32rem;font-weight:600;color:#fff;margin-bottom:8px}
.tcard p{color:var(--muted);font-size:.97rem}

/* ===== car map (interactive) ===== */
.carmap{display:flex;flex-wrap:wrap;gap:clamp(24px,3vw,40px);align-items:center;margin-top:46px;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:clamp(22px,3vw,36px)}
.carmap>div:first-child{flex:2 1 360px}
.car-panel{flex:1 1 240px}
.carmap-legend{display:flex;gap:18px;margin-bottom:18px;font-size:.82rem;color:var(--muted)}
.carmap-legend b{display:inline-flex;align-items:center;gap:7px}
.carmap-legend .dot{width:11px;height:11px;border-radius:50%}
.dot-ess{background:var(--red)}.dot-home{background:var(--gold)}
.car-stage{position:relative;width:100%}
.car-stage svg{width:100%;height:auto;display:block}
.hot{position:absolute;width:30px;height:30px;border-radius:50%;border:2px solid #fff;cursor:pointer;transform:translate(-50%,-50%);display:grid;place-items:center;font-size:.72rem;font-weight:700;color:#fff;transition:transform .2s,box-shadow .2s;animation:hotpulse 2.4s infinite}
.hot.ess{background:var(--red)}.hot.home{background:var(--gold);color:#1a1a1a}
.hot:hover,.hot.on{transform:translate(-50%,-50%) scale(1.25);box-shadow:0 0 0 6px rgba(255,255,255,.12)}
@keyframes hotpulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.25)}70%{box-shadow:0 0 0 10px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.car-panel{min-height:200px}
.car-panel .tag{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:8px}
.car-panel .tag.ess{color:var(--red-bright)}.car-panel .tag.home{color:var(--gold)}
.car-panel h4{font-family:'Fraunces';font-size:1.7rem;font-weight:600;color:#fff;margin-bottom:10px}
.car-panel p{color:var(--muted);font-size:1.02rem}
.car-hint{color:var(--muted-2);font-size:.9rem;margin-top:14px}

/* about */
.about-block{display:flex;flex-wrap:wrap;gap:8px 36px;padding:34px 0;border-bottom:1px solid var(--line)}
.about-block h3{flex:0 0 200px;font-family:'Fraunces';font-size:1.6rem;font-weight:600;color:#fff}
.about-block p{flex:1 1 320px;color:var(--muted);font-size:1.06rem}
/* heartfelt owner note */
.ownernote{max-width:760px;margin:0 auto;text-align:center}
.ownernote .qm{font-family:'Fraunces';font-size:4.2rem;line-height:.5;color:var(--red);opacity:.55}
.ownernote .av{width:64px;height:64px;border-radius:50%;overflow:hidden;margin:0 auto 12px;border:1px solid var(--line-2)}
.ownernote .av img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.ownernote .eyebrow{margin:6px 0 16px}
.ownernote .msg{font-family:'Fraunces';font-weight:400;font-size:clamp(1.02rem,1.7vw,1.3rem);line-height:1.6;color:#fff}
.ownernote .msg p{margin-bottom:16px}
.ownernote .sign{font-family:'Fraunces';font-style:italic;font-size:1.3rem;color:var(--red-bright);margin-top:24px}

/* faq */
.faq{max-width:820px;margin-top:16px}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{width:100%;text-align:left;background:none;border:none;color:#fff;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;font-family:'Fraunces';font-weight:600;font-size:1.28rem}
.faq-q i{color:var(--red-bright);transition:transform .3s;font-size:1rem}
.faq-q.open i{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{color:var(--muted);font-size:1.04rem;padding:0 0 24px;max-width:70ch}

/* cta band */
.cta{text-align:center;background:radial-gradient(700px 360px at 50% 25%,rgba(225,30,42,.16),transparent 65%)}
.cta h2{font-size:clamp(2rem,4.4vw,3.1rem);max-width:680px;margin:14px auto 24px;color:#fff}
.cta .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* contact */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr));gap:clamp(32px,4vw,50px);margin-top:44px}
.ci{display:flex;gap:16px;padding:20px 0;border-bottom:1px solid var(--line)}
.ci:first-child{padding-top:0}
.ci i{flex-shrink:0;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line-2);color:var(--red-bright);font-size:1.05rem}
.ci .k{font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.ci .v,.ci .v a{font-family:'Fraunces';font-size:1.28rem;font-weight:600;color:#fff}
.ci .v a:hover{color:var(--red-bright)}
.map{border-radius:14px;overflow:hidden;border:1px solid var(--line-2);min-height:420px}
.map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.4) invert(.92) contrast(.92) hue-rotate(180deg)}

/* footer */
footer{background:linear-gradient(180deg,#0E0F12,#0A0B0D);color:#9A958B;padding:clamp(52px,6vw,76px) 0 30px;border-top:3px solid var(--red)}
.foot-grid{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,70px);margin-bottom:48px}
.foot-brand{flex:1.7 1 300px}
.foot-col{flex:1 1 160px}
.foot-brand .wm{font-family:'Fraunces';font-weight:600;font-size:clamp(1.7rem,3vw,2.3rem);color:#fff;line-height:1;letter-spacing:-.01em}
.foot-brand p{margin:18px 0 22px;max-width:350px;font-size:.96rem;line-height:1.75}
.foot-soc{display:flex;gap:12px}
.foot-soc a{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.04);border:1px solid var(--line);color:#9A958B;font-size:1.05rem;transition:.25s}
.foot-soc a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-3px)}
.foot-col h5{color:#fff;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:20px;padding-bottom:12px;position:relative}
.foot-col h5::after{content:"";position:absolute;left:0;bottom:0;width:26px;height:2px;background:var(--red)}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.foot-col a,.foot-col li{color:#9A958B;font-size:.96rem;transition:color .2s,padding-left .2s}
.foot-col a:hover{color:#fff;padding-left:5px}
.foot-bottom{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.83rem;color:var(--muted-2);letter-spacing:.02em}

/* fab + reveal */
.fab{position:fixed;right:22px;bottom:22px;z-index:80;width:58px;height:58px;border-radius:50%;background:#1FAE54;color:#fff;display:grid;place-items:center;font-size:1.65rem;box-shadow:0 12px 30px -6px rgba(31,174,84,.55);animation:pulse 2.6s infinite}
.fab:hover{transform:scale(1.08)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,174,84,.5)}70%{box-shadow:0 0 0 15px rgba(31,174,84,0)}100%{box-shadow:0 0 0 0 rgba(31,174,84,0)}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
