/* website.css — Monolith Coatings homepage prototype. Dark, premium, brass accent. */
:root{
  --charcoal:#1C1F22; --graphite:#0E0F11; --panel:#24282C; --panel2:#16191c;
  --concrete:#6E7378; --brass:#C49A4A; --brass-dim:#9c7a32; --bone:#EDEAE3;
  --line:rgba(255,255,255,.09); --maxw:1180px;
}
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ background:var(--graphite); color:var(--bone); font-family:'Inter',sans-serif; line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 32px; }
.nm{ font-family:'Bebas Neue','Oswald',sans-serif; line-height:.78; color:var(--bone); }
.nm small{ display:block; font-family:'Inter'; font-weight:600; color:var(--brass); }

/* ---- shared bits ---- */
.eyebrow{ font-family:'Oswald'; font-weight:600; text-transform:uppercase; letter-spacing:.28em; font-size:.74rem; color:var(--brass); }
.h-sec{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:clamp(2.6rem,5vw,4.4rem); letter-spacing:.02em; line-height:.95; }
.h-sec .brass{ color:var(--brass); }
.lead{ color:var(--concrete); font-size:1.05rem; max-width:60ch; }
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:'Oswald'; font-weight:600; text-transform:uppercase; letter-spacing:.08em; font-size:.86rem; padding:15px 26px; border-radius:8px; border:1px solid transparent; cursor:pointer; transition:transform .15s, background .15s, color .15s, border-color .15s; }
.btn-brass{ background:var(--brass); color:var(--graphite); }
.btn-brass:hover{ transform:translateY(-2px); background:#d6ad5e; }
.btn-ghost{ background:transparent; color:var(--bone); border-color:rgba(237,234,227,.28); }
.btn-ghost:hover{ border-color:var(--brass); color:var(--brass); }
.btn-dark{ background:var(--charcoal); color:var(--bone); }
.btn-dark:hover{ transform:translateY(-2px); }

/* flake floor texture */
.floor{ position:relative; background-color:#14171a; background-image:
    radial-gradient(circle, rgba(196,154,74,.55) 0.9px, transparent 1.4px),
    radial-gradient(circle, rgba(237,234,227,.5) 0.9px, transparent 1.4px),
    radial-gradient(circle, rgba(110,115,120,.6) 1.1px, transparent 1.6px),
    radial-gradient(circle, rgba(196,154,74,.3) 0.7px, transparent 1.2px);
  background-size:15px 15px, 23px 23px, 31px 31px, 19px 19px;
  background-position:0 0, 8px 12px, 17px 5px, 3px 9px; }
.floor-gloss::before{ content:""; position:absolute; inset:0; background:linear-gradient(125deg, rgba(255,255,255,.10) 0%, transparent 26%, transparent 70%, rgba(255,255,255,.05) 100%); pointer-events:none; }
.floor-vignette::after{ content:""; position:absolute; inset:0; background:radial-gradient(120% 80% at 50% -10%, rgba(40,46,52,.55), rgba(8,9,11,.86) 78%); pointer-events:none; }
.floor > *{ position:relative; z-index:1; }

/* image placeholder */
.ph{ position:relative; overflow:hidden; background-image:repeating-linear-gradient(135deg,#1d2024 0 12px,#16191c 12px 24px); border:1px solid var(--line); display:flex; align-items:flex-end; }
.ph .tagm{ font-family:'JetBrains Mono',ui-monospace,monospace; font-size:.66rem; color:#8d9197; background:rgba(8,9,11,.66); padding:5px 9px; border-radius:5px; margin:12px; }

/* reveal — content is VISIBLE by default; .anim plays a one-shot fade-up when
   the observer fires. If JS/IO never runs, content simply shows (never stuck hidden). */
.reveal.anim{ animation:riseIn .75s cubic-bezier(.2,.7,.2,1) both; }
@keyframes riseIn{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
@media(prefers-reduced-motion:reduce){ .reveal.anim{ animation:none; } }

/* ---- NAV ---- */
.nav{ position:fixed; top:0; left:0; right:0; z-index:60; transition:background .3s, border-color .3s, padding .3s; border-bottom:1px solid transparent; }
.nav.scrolled{ background:rgba(14,15,17,.86); backdrop-filter:blur(12px); border-bottom-color:var(--line); }
.nav .bar{ max-width:var(--maxw); margin:0 auto; padding:18px 32px; display:flex; align-items:center; gap:30px; transition:padding .3s; }
.nav.scrolled .bar{ padding:12px 32px; }
.nav .brand{ display:flex; align-items:center; gap:13px; }
.nav .brand .nm{ font-size:1.6rem; letter-spacing:.05em; }
.nav .brand .nm small{ font-size:.36rem; letter-spacing:.4em; margin-top:.35em; }
.nav .links{ display:flex; align-items:center; gap:26px; margin-left:auto; }
.nav .links a{ font-family:'Oswald'; font-weight:500; text-transform:uppercase; letter-spacing:.1em; font-size:.76rem; color:var(--bone); opacity:.82; transition:opacity .15s,color .15s; white-space:nowrap; }
.nav .links a:hover{ opacity:1; color:var(--brass); }
.nav .phone{ font-family:'Oswald'; font-weight:600; font-size:.82rem; color:var(--brass); letter-spacing:.03em; }
.nav .navcta{ padding:11px 18px; font-size:.78rem; }
.nav .burger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:6px; margin-left:auto; }
.nav .burger span{ width:24px; height:2px; background:var(--bone); transition:.25s; }
.nav.open .burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.open .burger span:nth-child(2){ opacity:0; }
.nav.open .burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.mobile-menu{ position:fixed; inset:0 0 0 auto; width:min(82vw,360px); background:var(--charcoal); z-index:55; transform:translateX(100%); transition:transform .32s cubic-bezier(.2,.7,.2,1); padding:96px 30px 30px; display:flex; flex-direction:column; gap:6px; border-left:1px solid var(--line); }
.mobile-menu.open{ transform:none; }
.mobile-menu a{ font-family:'Oswald'; font-weight:600; text-transform:uppercase; letter-spacing:.1em; font-size:1.1rem; color:var(--bone); padding:14px 0; border-bottom:1px solid var(--line); }
.mobile-menu a:hover{ color:var(--brass); }
.mobile-menu .mcta{ margin-top:20px; justify-content:center; }
.scrim{ position:fixed; inset:0; background:rgba(8,9,11,.6); z-index:54; opacity:0; pointer-events:none; transition:opacity .3s; }
.scrim.open{ opacity:1; pointer-events:auto; }

/* ---- HERO ---- */
.hero{ min-height:88vh; display:flex; flex-direction:column; justify-content:center; padding:112px 0 60px; }
.hero .grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:54px; align-items:center; }
.hero .ey{ margin-bottom:18px; }
.hero h1{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:clamp(3.4rem,7vw,6rem); line-height:.9; letter-spacing:.02em; }
.hero h1 .brass{ color:var(--brass); }
.hero .sub{ font-family:'Oswald'; font-weight:300; font-size:1.3rem; color:var(--concrete); margin-top:22px; }
.hero .sub b{ color:var(--bone); font-weight:500; }
.hero .actions{ display:flex; gap:14px; margin-top:34px; flex-wrap:wrap; }
.hero .trust{ display:flex; gap:26px; margin-top:40px; flex-wrap:wrap; }
.hero .trust .t{ }
.hero .trust .t .n{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:2.2rem; color:var(--bone); line-height:1; }
.hero .trust .t .n .brass{ color:var(--brass); }
.hero .trust .t .l{ font-size:.78rem; color:var(--concrete); text-transform:uppercase; letter-spacing:.08em; margin-top:3px; }
.hero .visual{ position:relative; aspect-ratio:3/4; border-radius:16px; overflow:hidden; box-shadow:0 30px 60px rgba(0,0,0,.5); border:1px solid var(--line); }
.hero .visual img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.hero .visual .badge{ position:absolute; top:18px; left:18px; z-index:2; background:rgba(14,15,17,.7); border:1px solid var(--line); border-radius:10px; padding:10px 14px; backdrop-filter:blur(6px); }
.hero .visual .badge .p{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:1.8rem; color:var(--bone); line-height:1; }
.hero .visual .badge .p .brass{ color:var(--brass); }
.hero .visual .badge .s{ font-family:'Oswald'; font-weight:500; font-size:.62rem; text-transform:uppercase; letter-spacing:.1em; color:var(--concrete); }

/* ---- SECTION SCAFFOLD ---- */
.section{ padding:88px 0; border-top:1px solid var(--line); position:relative; }
.sec-head{ max-width:var(--maxw); margin:0 auto 44px; padding:0 32px; }
.sec-head .ey{ margin-bottom:14px; }
.sec-head p{ margin-top:16px; }

/* process */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; list-style:none; }
.step{ background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:28px 24px; transition:transform .2s, border-color .2s, opacity .35s, box-shadow .35s; }
.step:hover{ transform:translateY(-4px); border-color:rgba(196,154,74,.4); }
.step .n{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:1.5rem; color:var(--brass); }
.step .ic{ height:2px; width:34px; background:var(--brass); margin:14px 0 18px; transition:width .35s; }
.step h3{ font-family:'Oswald'; font-weight:600; font-size:1.15rem; }
.step p{ font-size:.9rem; color:var(--concrete); margin-top:8px; }

/* process build-up: static fallback by default (no JS / reduced motion) */
.process-stage{ position:relative; border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--panel2); margin-bottom:30px; }
.process-stage img, .process-stage video{ display:block; width:100%; height:100%; object-fit:contain; background:var(--panel2); }
.process-video{ display:none; }            /* no JS: never show a non-scrubbing video */
.process-stage figcaption{ position:absolute; left:0; right:0; bottom:0; padding:16px 18px; font-family:'Oswald'; font-weight:500; font-size:.84rem; color:#cfccc4; background:linear-gradient(transparent, rgba(8,9,11,.92)); }

/* enhanced: JS present and motion allowed -> pin + scrub */
html.js .process-scroll{ height:300vh; position:relative; }
html.js .process-pin{ position:sticky; top:0; min-height:100vh; display:grid; grid-template-columns:minmax(0,1.15fr) minmax(260px,.85fr); gap:42px; align-items:center; }
html.js .process-stage{ margin:0; aspect-ratio:1/1; max-height:82vh; width:100%; }
html.js .process-video{ display:block; }
html.js .process-fallback{ display:none; }
html.js .process-pin .steps{ display:flex; flex-direction:column; gap:14px; }
html.js .process-pin .step{ opacity:.4; }
html.js .process-pin .step.lit{ opacity:1; }
html.js .process-pin .step.active{ opacity:1; border-color:rgba(196,154,74,.55); transform:translateX(5px); box-shadow:0 12px 32px rgba(0,0,0,.32); }
html.js .process-pin .step.active .ic{ width:52px; }

@media(max-width:880px){
  html.js .process-pin{ grid-template-columns:1fr; gap:22px; align-content:center; }
  html.js .process-stage{ max-height:56vh; }
  html.js .process-pin .steps{ flex-direction:row; flex-wrap:wrap; }
  html.js .process-pin .step{ flex:1 1 44%; padding:16px 16px; }
}

/* reduced motion (even with JS): force the static diagram + step grid */
@media(prefers-reduced-motion:reduce){
  html.js .process-scroll{ height:auto; }
  html.js .process-pin{ position:static; min-height:0; display:block; }
  html.js .process-video{ display:none; }
  html.js .process-fallback{ display:block; }
  html.js .process-stage{ aspect-ratio:auto; max-height:none; margin-bottom:30px; }
  html.js .process-pin .steps{ display:grid; grid-template-columns:repeat(4,1fr); }
  html.js .process-pin .step{ opacity:1; }
}
@media(prefers-reduced-motion:reduce) and (max-width:760px){
  html.js .process-pin .steps{ grid-template-columns:1fr 1fr; }
}

/* pricing */
.price-wrap{ display:grid; grid-template-columns:.9fr 1.1fr; gap:46px; align-items:center; }
.price-card{ background:linear-gradient(180deg,var(--panel),#1a1d20); border:1px solid rgba(196,154,74,.3); border-radius:18px; padding:42px; text-align:center; box-shadow:0 24px 50px rgba(0,0,0,.35); }
.price-card .big{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:6rem; line-height:.82; color:var(--bone); }
.price-card .big .u{ font-size:1.6rem; color:var(--brass); letter-spacing:.04em; }
.price-card .per{ font-family:'Oswald'; font-weight:500; text-transform:uppercase; letter-spacing:.16em; font-size:.78rem; color:var(--concrete); margin-top:8px; }
.price-card .tag2{ margin-top:20px; font-family:'Oswald'; font-weight:600; color:var(--brass); letter-spacing:.04em; }
.incl{ list-style:none; }
.incl li{ display:flex; align-items:flex-start; gap:13px; padding:13px 0; border-bottom:1px solid var(--line); font-size:.98rem; color:#cfccc4; }
.incl li .ck{ flex:0 0 auto; width:20px; height:20px; border-radius:50%; background:rgba(196,154,74,.16); color:var(--brass); display:flex; align-items:center; justify-content:center; font-size:.7rem; font-weight:700; margin-top:2px; }
.incl li b{ color:var(--bone); font-weight:600; }

/* what we coat */
.coat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.coat{ border-radius:14px; overflow:hidden; position:relative; aspect-ratio:3/4; border:1px solid var(--line); }
.coat .ph{ position:absolute; inset:0; }
.coat .cap{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:18px 20px 20px; background:linear-gradient(transparent, rgba(8,9,11,.55) 38%, rgba(8,9,11,.92)); }
.coat .cap h3{ font-family:'Oswald'; font-weight:600; font-size:1.1rem; line-height:1.2; }
.coat .cap span{ display:block; margin-top:5px; font-size:.8rem; line-height:1.4; color:var(--concrete); }
.coat{ transition:border-color .3s, transform .3s, box-shadow .3s; }
.coat:hover{ border-color:rgba(196,154,74,.4); box-shadow:0 18px 40px rgba(0,0,0,.45); }
.coat img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.coat:hover img{ transform:scale(1.05); }

/* gallery */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.gallery .g{ position:relative; overflow:hidden; border-radius:12px; aspect-ratio:4/3; border:1px solid var(--line); }
.gallery .g img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.gallery .g:hover img{ transform:scale(1.06); }

/* flake colors */
.flake-banner{ position:relative; border-radius:16px; overflow:hidden; border:1px solid var(--line); margin-bottom:30px; aspect-ratio:24/7; box-shadow:0 20px 44px rgba(0,0,0,.4); }
.flake-banner img{ width:100%; height:100%; object-fit:cover; display:block; }
.flake-banner::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(8,9,11,.18), transparent 40%, rgba(8,9,11,.34)); pointer-events:none; }
.flakes{ display:grid; grid-template-columns:repeat(6,1fr); gap:16px; }
.flake{ text-align:center; cursor:pointer; }
.flake .sw{ aspect-ratio:1; border-radius:50%; border:2px solid var(--line); transition:transform .2s, border-color .2s; }
.flake:hover .sw{ transform:scale(1.06); border-color:var(--brass); }
.flake .nm2{ font-family:'Oswald'; font-weight:500; font-size:.78rem; margin-top:11px; color:#cfccc4; }

/* reviews */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.review{ background:var(--panel); border:1px solid var(--line); border-radius:14px; padding:28px; }
.review .stars{ color:var(--brass); letter-spacing:.18em; font-size:.9rem; }
.review p{ margin:14px 0 18px; color:#d6d3cb; font-size:1rem; }
.review .who{ font-family:'Oswald'; font-weight:600; font-size:.86rem; }
.review .who span{ display:block; color:var(--concrete); font-weight:400; font-size:.76rem; text-transform:uppercase; letter-spacing:.08em; }

/* meet the team */
.team-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.member{ display:grid; grid-template-columns:auto 1fr; gap:22px; align-items:center; background:var(--panel); border:1px solid var(--line); border-radius:16px; padding:22px; transition:border-color .3s, transform .3s, box-shadow .3s; }
.member:hover{ border-color:rgba(196,154,74,.35); transform:translateY(-3px); box-shadow:0 18px 40px rgba(0,0,0,.4); }
.team-photo{ position:relative; width:128px; aspect-ratio:4/5; border-radius:12px; overflow:hidden; border:1px solid var(--line);
  background:linear-gradient(160deg,#23282e,#0e0f11);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; }
.team-photo img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.team-photo .tp-soon{ font-family:'JetBrains Mono',ui-monospace,monospace; font-size:.6rem; letter-spacing:.04em; color:#8d9197; }
.member .m-body h3{ font-family:'Oswald'; font-weight:600; font-size:1.3rem; }
.member .role{ font-family:'Oswald'; font-weight:500; font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--brass); margin:4px 0 12px; }
.member .m-body p{ font-size:.92rem; color:var(--concrete); line-height:1.6; }

/* service area */
.area{ display:grid; grid-template-columns:1fr 1fr; gap:46px; align-items:center; }
.area .towns{ display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.area .town{ font-family:'Oswald'; font-weight:500; font-size:.84rem; color:#cfccc4; padding:8px 15px; border:1px solid var(--line); border-radius:30px; }
.area-map{ aspect-ratio:4/3; border-radius:16px; overflow:hidden; border:1px solid var(--line); background:#0d0e10; box-shadow:0 20px 44px rgba(0,0,0,.4); }
.area-map svg{ width:100%; height:100%; display:block; }
.area .towns .town{ transition:color .2s, border-color .2s; }
.area .towns .town:hover{ color:var(--brass); border-color:rgba(196,154,74,.45); }

/* CTA band */
.cta-band{ text-align:center; padding:96px 0; position:relative; }
.cta-band h2{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:clamp(2.8rem,6vw,5rem); line-height:.92; letter-spacing:.02em; }
.cta-band h2 .brass{ color:var(--brass); }
.cta-band p{ color:var(--concrete); margin:18px auto 32px; font-size:1.1rem; max-width:46ch; }

/* ---- QUOTE MODAL ---- */
.quote-overlay{ position:fixed; inset:0; z-index:80; display:none; align-items:center; justify-content:center; padding:24px; background:rgba(8,9,11,.72); backdrop-filter:blur(6px); }
.quote-overlay.open{ display:flex; }
.quote{ width:min(560px,100%); background:var(--charcoal); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 40px 80px rgba(0,0,0,.6); }
.quote .qhead{ display:flex; align-items:center; justify-content:space-between; padding:20px 26px; border-bottom:1px solid var(--line); }
.quote .qhead .nm{ font-size:1.4rem; letter-spacing:.05em; }
.quote .qhead .x{ background:none; border:none; color:var(--concrete); font-size:1.5rem; cursor:pointer; line-height:1; }
.quote .qhead .x:hover{ color:var(--bone); }
.qprog{ height:3px; background:var(--panel); }
.qprog .fill{ height:100%; background:var(--brass); width:25%; transition:width .3s; }
.qbody{ padding:34px 32px 32px; }
.qstep{ display:none; } .qstep.active{ display:block; animation:qin .35s ease; }
@keyframes qin{ from{ opacity:0; transform:translateX(14px); } to{ opacity:1; transform:none; } }
.qstep .qey{ font-family:'Oswald'; font-weight:600; text-transform:uppercase; letter-spacing:.16em; font-size:.66rem; color:var(--brass); }
.qstep h3{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:2rem; letter-spacing:.02em; margin:6px 0 22px; }
.opts{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.opt{ background:var(--panel); border:1px solid var(--line); border-radius:11px; padding:18px; cursor:pointer; transition:border-color .15s, background .15s; font-family:'Oswald'; font-weight:500; }
.opt:hover{ border-color:rgba(196,154,74,.5); }
.opt.sel{ border-color:var(--brass); background:rgba(196,154,74,.1); }
.opt .os{ display:block; font-family:'Inter'; font-weight:400; font-size:.78rem; color:var(--concrete); margin-top:4px; }
.field{ margin-bottom:16px; }
.field label{ font-family:'Oswald'; font-weight:500; text-transform:uppercase; letter-spacing:.1em; font-size:.68rem; color:var(--concrete); display:block; margin-bottom:7px; }
.field input, .field select{ width:100%; background:var(--panel2); border:1px solid var(--line); border-radius:9px; padding:14px 15px; color:var(--bone); font-family:'Inter'; font-size:.95rem; }
.field select{ -webkit-appearance:none; appearance:none; cursor:pointer; padding-right:38px; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C49A4A' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; }
.field select option{ background:var(--charcoal); color:var(--bone); }
.field input:focus, .field select:focus{ outline:none; border-color:var(--brass); }
.sizerow{ display:flex; align-items:center; gap:16px; }
.sizerow input[type=range]{ flex:1; accent-color:var(--brass); }
.estimate{ text-align:center; padding:8px 0 4px; }
.estimate .lab{ font-family:'Oswald'; text-transform:uppercase; letter-spacing:.14em; font-size:.7rem; color:var(--concrete); }
.estimate .val{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:4.2rem; color:var(--brass); line-height:1; margin:6px 0; }
.estimate .note{ font-size:.82rem; color:var(--concrete); }
.qnav{ display:flex; justify-content:space-between; gap:12px; margin-top:26px; }
.qnav .btn{ flex:1; justify-content:center; }
.qdone{ text-align:center; }
.qdone .big{ font-family:'Bebas Neue','Oswald',sans-serif; font-size:2.4rem; }
.qdone .chk{ width:64px; height:64px; border-radius:50%; background:rgba(196,154,74,.16); color:var(--brass); display:flex; align-items:center; justify-content:center; font-size:1.8rem; margin:0 auto 18px; }

/* ---- FOOTER ---- */
.footer{ border-top:1px solid var(--line); padding:70px 0 30px; background:var(--panel2); }
.footer .top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:34px; }
.footer .brand{ display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.footer .brand .nm{ font-size:1.8rem; letter-spacing:.05em; }
.footer .brand .nm small{ font-size:.4rem; letter-spacing:.4em; margin-top:.4em; }
.footer .col h4{ font-family:'Oswald'; text-transform:uppercase; letter-spacing:.12em; font-size:.72rem; color:var(--brass); margin-bottom:16px; }
.footer .col a, .footer .col p{ display:block; color:var(--concrete); font-size:.9rem; padding:5px 0; }
.footer .col a:hover{ color:var(--bone); }
.footer .desc{ color:var(--concrete); font-size:.9rem; max-width:34ch; }
.phone-soon{ color:var(--concrete); font-style:italic; }
.nav .phone.phone-soon{ font-style:normal; opacity:.7; cursor:default; }
.social{ display:flex; gap:12px; margin-top:18px; }
.social a{ display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:9px; border:1px solid var(--line); color:var(--concrete); transition:color .2s, border-color .2s, transform .2s; }
.social a:hover{ color:var(--brass); border-color:rgba(196,154,74,.5); transform:translateY(-2px); }
.footer .bottom{ display:flex; justify-content:space-between; align-items:center; margin-top:50px; padding-top:24px; border-top:1px solid var(--line); color:#55514b; font-size:.8rem; flex-wrap:wrap; gap:12px; }

/* ---- RESPONSIVE ---- */
@media(max-width:980px){
  .hero .grid{ grid-template-columns:1fr; gap:38px; } .hero .visual{ aspect-ratio:16/10; }
  .price-wrap,.area{ grid-template-columns:1fr; gap:30px; }
  .steps,.coat-grid{ grid-template-columns:1fr 1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .reviews{ grid-template-columns:1fr; }
  .team-grid{ grid-template-columns:1fr; }
  .flakes{ grid-template-columns:repeat(3,1fr); }
  .footer .top{ grid-template-columns:1fr 1fr; }
}
@media(max-width:480px){
  .member{ grid-template-columns:1fr; justify-items:start; }
}
@media(max-width:680px){
  .nav .links, .nav .phone, .nav .navcta{ display:none; }
  .nav .burger{ display:flex; }
  .wrap,.nav .bar,.sec-head{ padding-left:22px; padding-right:22px; }
  .gallery{ grid-template-columns:1fr; }
  .coat-grid{ grid-template-columns:1fr 1fr; }
  .flakes{ grid-template-columns:repeat(2,1fr); }
  .footer .top{ grid-template-columns:1fr; }
  .opts{ grid-template-columns:1fr; }
  .section{ padding:74px 0; }
}
