:root{
  --ink:#141109;--ink-2:#1F1A11;--paper:#FBF8F2;--paper-2:#F2ECE0;
  --amber:#C8860A;--amber-2:#E6A129;--amber-deep:#9C6708;--amber-soft:#F6EBD6;
  --mid:#4A4338;--grey:#8C8273;--line:#E4DBCB;--line-d:#2D2718;--wa:#25D366;--wa-d:#1da851;--white:#fff;
  --shadow:0 26px 64px -26px rgba(20,16,9,.4);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Archivo',sans-serif;color:var(--ink);background:var(--paper);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}a{color:inherit;text-decoration:none}
::selection{background:var(--amber);color:#fff}
.grain{position:absolute;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.bp{position:absolute;inset:0;pointer-events:none;opacity:.05;background-image:linear-gradient(rgba(232,161,41,.6) 1px,transparent 1px),linear-gradient(90deg,rgba(232,161,41,.6) 1px,transparent 1px);background-size:44px 44px}

/* utility + header */
.util{background:var(--ink);color:#cbbfa8;font-size:12.5px;letter-spacing:.03em;padding:9px 0}
.util .w{max-width:1280px;margin:0 auto;padding:0 32px;display:flex;justify-content:center;gap:9px;align-items:center;flex-wrap:wrap;text-align:center}
.util a{color:var(--amber-2);font-weight:700}.util .s{color:#5a513f}
header{position:sticky;top:0;z-index:200;background:rgba(251,248,242,.9);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line);transition:.3s}
header.shrink{box-shadow:0 6px 22px -12px rgba(20,16,9,.25);background:rgba(251,248,242,.98)}
.hd{max-width:1280px;margin:0 auto;padding:0 32px;height:86px;display:flex;align-items:center;justify-content:space-between;transition:height .3s}
header.shrink .hd{height:68px}
.logo{display:flex;align-items:baseline;gap:2px}
.logo .b{font-family:'Archivo';font-weight:900;font-size:25px}.logo .by{font-family:'Fraunces';font-style:italic;font-size:15px;color:var(--amber);margin:0 4px}.logo .t{font-family:'Archivo';font-weight:900;font-size:25px;color:var(--amber)}
.logo.dark .b{color:#fff}
nav ul{display:flex;gap:2px;list-style:none}
nav a{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);padding:10px 13px;position:relative}
nav a::after{content:'';position:absolute;left:13px;right:13px;bottom:3px;height:2px;background:var(--amber);transform:scaleX(0);transform-origin:left;transition:transform .25s}
nav a:hover{color:var(--ink)}nav a:hover::after{transform:scaleX(1)}
.hd-cta{display:flex;align-items:center;gap:16px}
.hd-ph{font-family:'Oswald';font-weight:700;font-size:25px;color:var(--amber-deep);white-space:nowrap;display:flex;align-items:center;gap:8px;line-height:1}
.hd-ph .lbl{font-family:'Archivo';font-size:9px;font-weight:800;letter-spacing:.16em;color:var(--grey);display:block;margin-bottom:1px}
.hd-ph svg{color:var(--amber)}
.hd-ph:hover{color:var(--amber)}
/* big phone in hero cta */
.bigphone{margin-top:26px;display:flex;flex-direction:column;align-items:center;gap:2px;position:relative}
.bigphone .s{font-size:12px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--amber-2)}
.bigphone a{font-family:'Oswald';font-weight:700;font-size:clamp(40px,7vw,72px);line-height:1;color:#fff;letter-spacing:.01em;display:inline-flex;align-items:center;gap:14px;transition:.2s}
.bigphone a svg{color:var(--amber-2);flex-shrink:0}
.bigphone a:hover{color:var(--amber-2)}
/* recurring full-width phone strip */
.phonestrip{background:var(--amber);color:#fff;position:relative;overflow:hidden}
.phonestrip .bp{opacity:.12}
.phonestrip .w{display:flex;align-items:center;justify-content:space-between;gap:26px;flex-wrap:wrap;padding:30px 32px;position:relative}
.phonestrip .ps-l{display:flex;flex-direction:column;gap:2px}
.phonestrip .lbl{font-size:13px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.9)}
.phonestrip .num{font-family:'Oswald';font-weight:700;font-size:clamp(42px,7vw,70px);line-height:1;color:#fff;display:inline-flex;align-items:center;gap:14px;letter-spacing:.01em;transition:transform .2s}
.phonestrip .num svg{flex-shrink:0;animation:ring 1.6s ease-in-out infinite}
.phonestrip .num:hover{transform:scale(1.02)}
@keyframes ring{0%,70%,100%{transform:rotate(0)}10%,30%{transform:rotate(-14deg)}20%,40%{transform:rotate(14deg)}}
.phonestrip .ps-btns{display:flex;gap:12px;flex-wrap:wrap}
.ps-wa{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--ink);padding:15px 26px;border-radius:3px;font-size:15px;font-weight:800;transition:.2s}
.ps-wa:hover{background:var(--ink);color:#fff;transform:translateY(-2px)}
.ps-wa svg{color:var(--wa)}.ps-wa:hover svg{color:#fff}
/* dual floating buttons */
.fab{position:fixed;right:24px;bottom:24px;z-index:300;display:flex;flex-direction:column;gap:12px}
.fab a{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px -6px rgba(0,0,0,.4);transition:transform .2s}
.fab a:hover{transform:scale(1.08)}
.fab .wa{background:var(--wa);animation:pulse 2.6s infinite}
.fab .call{background:var(--amber);animation:pulse-a 2.6s infinite}
@keyframes pulse{0%,100%{box-shadow:0 10px 28px -6px rgba(37,211,102,.5)}50%{box-shadow:0 10px 28px -6px rgba(37,211,102,.7),0 0 0 12px rgba(37,211,102,.08)}}
@keyframes pulse-a{0%,100%{box-shadow:0 10px 28px -6px rgba(200,134,10,.5)}50%{box-shadow:0 10px 28px -6px rgba(200,134,10,.7),0 0 0 12px rgba(200,134,10,.1)}}
/* mobile sticky call bar */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:310;display:none;grid-template-columns:1fr 1fr;box-shadow:0 -6px 20px rgba(0,0,0,.25)}
.callbar a{display:flex;align-items:center;justify-content:center;gap:9px;padding:15px 10px;font-size:16px;font-weight:800;letter-spacing:.02em;color:#fff}
.callbar .call{background:var(--amber)}.callbar .wa{background:var(--wa)}
.btn-amber{display:inline-flex;align-items:center;gap:8px;background:var(--amber);color:#fff;padding:11px 20px;border-radius:3px;font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;transition:.2s;white-space:nowrap}
.btn-amber:hover{background:var(--ink);transform:translateY(-2px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--ink)}

/* hero */
.logo-img{height:52px;width:auto;display:block;transition:height .3s}
header.shrink .logo-img{height:42px}
.hero-banner{position:relative;background:var(--ink);line-height:0}
.hero-banner img{width:100%;height:auto;display:block}
.hero-cta{background:var(--ink);color:#fff;text-align:center;padding:54px 0 60px;position:relative;overflow:hidden;border-top:3px solid var(--amber)}
.hero-cta h1{font-family:'Fraunces';font-weight:500;font-size:clamp(34px,5vw,58px);line-height:1.04;color:#fff;margin-bottom:14px;position:relative}
.hero-cta h1 em{font-style:italic;color:var(--amber-2)}
.hero-cta p{color:#bdb29c;font-size:17px;max-width:60ch;margin:0 auto 30px;position:relative}
.hero-cta .hero-btns{justify-content:center;position:relative}
@media(max-width:600px){
  .hero-banner{min-height:360px;display:flex;align-items:center}
  .hero-banner img{height:360px;object-fit:cover;object-position:center}
}
.hero{position:relative;height:max(640px,90vh);overflow:hidden;background:var(--ink)}
.hslide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.07);transition:opacity 1.2s ease,transform 8s ease}
.hslide.on{opacity:1;transform:scale(1)}
.hero-veil{position:absolute;inset:0;background:linear-gradient(100deg,rgba(15,11,6,.92),rgba(15,11,6,.6) 44%,rgba(15,11,6,.12) 74%,rgba(15,11,6,.5))}
.hero-w{position:relative;z-index:3;max-width:1280px;margin:0 auto;padding:0 32px;height:100%;display:flex;flex-direction:column;justify-content:center}
.h-eye{display:inline-flex;align-items:center;gap:12px;font-size:12px;font-weight:800;letter-spacing:.28em;text-transform:uppercase;color:var(--amber-2);margin-bottom:22px}
.h-eye::before{content:'';width:38px;height:2px;background:var(--amber)}
.hero h1{font-family:'Fraunces';font-weight:400;font-size:clamp(48px,8vw,108px);line-height:.95;color:#fff;letter-spacing:-.015em;margin-bottom:24px}
.hero h1 .am{font-style:italic;color:var(--amber-2)}
.hero h1 span{display:block;overflow:hidden}
.hero h1 span i{display:block;font-style:inherit;transform:translateY(110%);animation:rise .9s cubic-bezier(.16,1,.3,1) forwards}
.hero h1 span:nth-child(2) i{animation-delay:.1s}.hero h1 span:nth-child(3) i{animation-delay:.2s}
@keyframes rise{to{transform:translateY(0)}}
.hero-sub{font-size:18.5px;color:rgba(255,255,255,.88);max-width:54ch;line-height:1.7;margin-bottom:38px;opacity:0;animation:fadeUp .7s ease .5s forwards}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fadeUp .7s ease .65s forwards}
.btn-wa{display:inline-flex;align-items:center;gap:11px;background:var(--wa);color:#fff;padding:17px 32px;font-size:15px;font-weight:800;border-radius:3px;box-shadow:0 14px 32px -10px rgba(37,211,102,.7);transition:.2s}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 20px 40px -10px rgba(37,211,102,.85)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;color:#fff;padding:17px 30px;font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border:1.5px solid rgba(255,255,255,.45);border-radius:3px;transition:.2s}
.btn-ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero-dots{position:absolute;left:32px;bottom:28px;z-index:4;display:flex;gap:9px}
.hdot{width:32px;height:4px;background:rgba(255,255,255,.3);border:0;cursor:pointer;border-radius:2px;transition:.3s}.hdot.on{background:var(--amber-2);width:46px}
.hero-tag{position:absolute;right:0;bottom:0;z-index:4;background:rgba(200,134,10,.95);color:#fff;padding:16px 26px;font-size:13px;font-weight:700;letter-spacing:.04em;max-width:300px;line-height:1.4}

/* sections */
section{padding:104px 0;position:relative}
.w{max-width:1280px;margin:0 auto;padding:0 32px}
.alt{background:var(--paper-2)}
.eye{display:flex;align-items:center;gap:12px;font-size:12px;font-weight:800;letter-spacing:.24em;text-transform:uppercase;color:var(--amber-deep);margin-bottom:16px}
.eye::before{content:'';width:30px;height:2px;background:var(--amber)}
.eye.c{justify-content:center}
h2.t{font-family:'Fraunces';font-weight:500;font-size:clamp(31px,4.4vw,50px);line-height:1.06;letter-spacing:-.01em;margin-bottom:18px}
h2.t em{font-style:italic;color:var(--amber)}
.lead{font-size:17px;color:var(--mid);max-width:64ch;line-height:1.8}
.center{text-align:center}.center .eye{justify-content:center}.center .lead{margin:0 auto}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}

/* intro split */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:72px;align-items:center}
.media{position:relative}
.media img{width:100%;height:560px;object-fit:cover;border-radius:4px}
.media .fr{position:absolute;inset:18px -18px -18px 18px;border:1.5px solid var(--amber);z-index:-1;border-radius:4px}
.intro p{font-size:16px;color:var(--mid);line-height:1.85;margin-bottom:18px}
.intro p strong{color:var(--ink)}
.sign{margin-top:24px;font-family:'Fraunces';font-style:italic;font-size:26px;color:var(--amber-deep)}
.sign small{display:block;font-family:'Archivo';font-style:normal;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);margin-top:4px}

/* full service band */
.band{background:var(--ink);color:#fff;text-align:center;position:relative}
.band h2{color:#fff}.band .lead{color:#b8ad98;margin:0 auto 8px}
.trades{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:34px}
.trade{border:1px solid var(--line-d);border-radius:30px;padding:9px 20px;font-size:14px;font-weight:600;color:#e7dcc6;display:flex;align-items:center;gap:9px}
.trade svg{color:var(--amber-2)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:54px;border-top:1px solid var(--line-d)}
.stat{padding:30px 16px;border-right:1px solid var(--line-d)}.stat:last-child{border-right:0}
.stat .n{font-family:'Oswald';font-weight:600;font-size:42px;color:var(--amber-2);line-height:1}
.stat .l{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#a99e89;margin-top:8px}

/* service rows */
.srow{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;margin-bottom:30px;background:var(--white);border:1px solid var(--line);border-radius:6px;overflow:hidden;box-shadow:0 12px 40px -28px rgba(20,16,9,.4)}
.srow .im{position:relative;overflow:hidden;min-height:380px}
.srow .im img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}
.srow:hover .im img{transform:scale(1.05)}
.srow .im .nm{position:absolute;top:18px;left:18px;font-family:'Oswald';font-weight:600;font-size:14px;letter-spacing:.1em;color:#fff;background:rgba(20,16,9,.65);padding:5px 12px;border-radius:2px;backdrop-filter:blur(4px)}
.srow .tx{padding:46px 48px;display:flex;flex-direction:column;justify-content:center}
.srow:nth-child(even) .im{order:2}
.srow .tx .eye{margin-bottom:13px}
.srow h3{font-family:'Fraunces';font-weight:600;font-size:30px;line-height:1.12;margin-bottom:14px}
.srow p{font-size:14.5px;color:var(--mid);line-height:1.75;margin-bottom:18px}
.srow ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:26px}
.srow li{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;font-weight:500}
.srow li::before{content:'';width:18px;height:18px;border-radius:50%;background:var(--amber-soft);border:1.5px solid var(--amber);flex-shrink:0;margin-top:1px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23C8860A' stroke-width='4'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.slink{align-self:flex-start;display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:#fff;padding:13px 24px;border-radius:3px;font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;transition:.2s}
.slink:hover{background:var(--amber);gap:14px}

/* before/after */
.ba{background:var(--ink);color:#fff;overflow:hidden}
.ba .center{margin-bottom:44px}.ba h2{color:#fff}.ba .lead{color:#b8ad98;margin:0 auto}
.ba-s{position:relative;max-width:1000px;margin:0 auto;aspect-ratio:16/10;border-radius:6px;overflow:hidden;box-shadow:0 40px 80px -30px rgba(0,0,0,.7);cursor:ew-resize;user-select:none;touch-action:none}
.ba-s img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba-aft{clip-path:inset(0 0 0 50%)}
.ba-tag{position:absolute;top:18px;font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;padding:7px 15px;border-radius:2px;z-index:4}
.ba-tag.b{left:18px;background:rgba(20,16,9,.8);color:#fff;backdrop-filter:blur(4px)}.ba-tag.a{right:18px;background:var(--amber);color:#fff}
.ba-h{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;z-index:5;transform:translateX(-50%);box-shadow:0 0 18px rgba(0,0,0,.5)}
.ba-k{position:absolute;top:50%;left:50%;width:52px;height:52px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.4);color:var(--ink);font-weight:900;letter-spacing:-2px}
.ba-cap{text-align:center;color:#b8ad98;font-size:15px;margin-top:26px;max-width:60ch;margin-left:auto;margin-right:auto}.ba-cap b{color:var(--amber-2)}
/* progression scrubber */
.prog{background:var(--ink);color:#fff;overflow:hidden}
.prog .center{margin-bottom:42px}.prog h2{color:#fff}.prog .lead{color:#b8ad98;margin:0 auto}
.prog-wrap{max-width:560px;margin:0 auto}
.prog-stage{position:relative;aspect-ratio:4/5;border-radius:6px;overflow:hidden;box-shadow:0 40px 80px -30px rgba(0,0,0,.7)}
.prog-stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .35s ease}
.prog-badge{position:absolute;top:16px;left:16px;z-index:5;font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;padding:8px 16px;border-radius:2px;background:var(--amber);color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.3)}
.prog-pct{position:absolute;top:16px;right:16px;z-index:5;font-family:'Oswald';font-weight:600;font-size:15px;color:#fff;background:rgba(20,16,9,.6);backdrop-filter:blur(4px);padding:6px 12px;border-radius:2px}
/* track */
.prog-track{position:relative;margin:30px auto 0;height:54px;max-width:560px;display:flex;align-items:center}
.prog-line{position:absolute;left:8px;right:8px;height:6px;background:rgba(255,255,255,.16);border-radius:4px;top:50%;transform:translateY(-50%)}
.prog-fill{position:absolute;left:8px;height:6px;background:linear-gradient(90deg,var(--amber),var(--amber-2));border-radius:4px;top:50%;transform:translateY(-50%);width:0;pointer-events:none}
.prog-stop{position:absolute;top:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:var(--ink);border:3px solid rgba(255,255,255,.4);z-index:2;transition:.25s;cursor:pointer}
.prog-stop.done{border-color:var(--amber-2);background:var(--amber)}
.prog-knob{position:absolute;top:50%;left:0;transform:translate(-50%,-50%);width:34px;height:34px;border-radius:50%;background:#fff;z-index:4;box-shadow:0 6px 18px rgba(0,0,0,.45);cursor:grab;display:flex;align-items:center;justify-content:center;color:var(--ink);font-weight:900;font-size:14px;letter-spacing:-2px}
.prog-knob:active{cursor:grabbing}
.prog-steps{display:flex;justify-content:space-between;max-width:560px;margin:14px auto 0}
.prog-step{flex:1;text-align:center;position:relative}
.prog-step .ic{width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 8px;color:#7d7361;transition:.25s}
.prog-step.on .ic{border-color:var(--amber);color:var(--amber-2);background:rgba(200,134,10,.12)}
.prog-step .nm{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#7d7361;transition:.25s}
.prog-step.on .nm{color:#fff}
.prog-cap{text-align:center;color:#b8ad98;font-size:15.5px;line-height:1.6;margin:26px auto 0;max-width:54ch;min-height:48px}
.prog-cap b{color:var(--amber-2)}

/* why */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-top:54px}
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-top:54px}
.wcell{background:var(--white);padding:34px 30px}
.wcell .ic{width:50px;height:50px;border-radius:50%;background:var(--amber-soft);border:1.5px solid var(--amber);display:flex;align-items:center;justify-content:center;color:var(--amber-deep);margin-bottom:18px}
.wcell h4{font-size:17px;font-weight:800;margin-bottom:8px}
.wcell p{font-size:13.5px;color:var(--grey);line-height:1.7}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:8px;margin-top:52px}
.gtile{position:relative;overflow:hidden;border-radius:3px;cursor:pointer;background:var(--ink)}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.gtile:hover img{transform:scale(1.08)}
.gtile::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(15,11,6,.7));opacity:0;transition:.35s}.gtile:hover::after{opacity:1}
.gtile .z{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--ink);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.7);transition:.3s;z-index:2}.gtile:hover .z{opacity:1;transform:scale(1)}
.tall{grid-row:span 2}.wide{grid-column:span 2}
.lb{position:fixed;inset:0;z-index:1000;background:rgba(12,9,4,.95);display:none;align-items:center;justify-content:center;padding:40px;backdrop-filter:blur(6px)}
.lb.open{display:flex}.lb img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:4px}
.lb-x{position:absolute;top:22px;right:30px;background:none;border:0;color:#fff;font-size:38px;cursor:pointer}
.lb-n{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;width:52px;height:52px;border-radius:50%;font-size:24px;cursor:pointer}.lb-n:hover{background:var(--amber);border-color:var(--amber)}.lp{left:26px}.ln{right:26px}

/* reviews */
.rev{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.rcard{background:var(--white);border:1px solid var(--line);border-radius:5px;padding:32px 28px;position:relative;transition:.3s}
.rcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.rcard .q{font-family:'Fraunces';font-size:74px;color:var(--amber);opacity:.16;position:absolute;top:6px;right:20px;line-height:1}
.rcard .st{color:var(--amber-2);font-size:16px;letter-spacing:2px;margin-bottom:14px}
.rcard p{font-size:14.5px;color:var(--mid);line-height:1.8;font-style:italic;margin-bottom:18px}
.rcard .wh{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.rcard .lo{font-size:12.5px;color:var(--grey)}
.rbadges{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:40px}
.rb{background:var(--white);border:1px solid var(--line);border-radius:4px;padding:11px 22px;display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:700}.rb .s{color:var(--amber-2)}

/* cta band */
.cta{background:var(--ink);color:#fff;text-align:center;overflow:hidden}
.cta h2{font-family:'Fraunces';font-weight:500;font-size:clamp(33px,4.8vw,56px);color:#fff;margin-bottom:12px}.cta h2 em{font-style:italic;color:var(--amber-2)}
.cta p{color:#b8ad98;font-size:17px;margin-bottom:34px}
.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* contact */
.cg{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:46px}
.ci p{font-size:15.5px;color:var(--mid);line-height:1.8;margin-bottom:28px}
.ci-it{display:flex;gap:15px;align-items:flex-start;margin-bottom:20px}
.ci-it .ic{width:46px;height:46px;border-radius:50%;background:var(--amber-soft);border:1.5px solid var(--amber);display:flex;align-items:center;justify-content:center;color:var(--amber-deep);flex-shrink:0}
.ci-it .l{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--grey);margin-bottom:3px}.ci-it .v{font-size:16px;font-weight:800}
.cmap{margin-top:8px;border-radius:6px;overflow:hidden;border:1px solid var(--line);height:220px;background:var(--paper-2)}
.cmap iframe{width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}
.form{background:var(--white);border:1px solid var(--line);border-radius:6px;padding:38px;box-shadow:var(--shadow)}
.form h3{font-family:'Fraunces';font-weight:600;font-size:23px;margin-bottom:6px}.form .fs{font-size:13.5px;color:var(--grey);margin-bottom:24px}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.fg{margin-bottom:17px}
label{display:block;font-size:11.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:7px}
input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:4px;font-family:'Archivo';font-size:15px;color:var(--ink);background:var(--paper);outline:none;transition:.2s}
input:focus,select:focus,textarea:focus{border-color:var(--amber);background:#fff;box-shadow:0 0 0 3px var(--amber-soft)}
textarea{min-height:92px;resize:vertical}
.fsub{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--wa);color:#fff;padding:16px;font-family:'Archivo';font-size:15px;font-weight:800;border:0;border-radius:4px;cursor:pointer;transition:.2s}.fsub:hover{background:var(--wa-d);transform:translateY(-2px)}
.fnote{font-size:12px;color:var(--grey);text-align:center;margin-top:12px}

footer{background:#0D0A05;color:#9a9078;padding:70px 0 0}
.fg4{max-width:1280px;margin:0 auto;padding:0 32px 50px;display:grid;grid-template-columns:2.2fr 1fr 1fr 1.2fr;gap:44px}
.fb p{font-size:13.5px;line-height:1.85;margin-top:16px;max-width:34ch}
.fcol h4{font-size:12px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-2);margin-bottom:17px}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:10px}.fcol a,.fcol li{font-size:13.5px;color:#9a9078}.fcol a:hover{color:var(--amber-2)}
.fbot{border-top:1px solid #221c12;padding:22px 32px;max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center}
.fbot p{font-size:12.5px;color:#5f5743}
.soc{display:flex;gap:10px}.soc a{width:38px;height:38px;border:1px solid #2c2416;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#9a9078;font-size:13px;font-weight:800;transition:.2s}.soc a:hover{background:var(--amber);border-color:var(--amber);color:#fff}

.fab{position:fixed;right:24px;bottom:24px;z-index:300}
.fab a{width:62px;height:62px;border-radius:50%;background:var(--wa);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px -6px rgba(37,211,102,.6);animation:pulse 2.6s infinite}
.fab a:hover{transform:scale(1.08)}
@keyframes pulse{0%,100%{box-shadow:0 10px 28px -6px rgba(37,211,102,.5)}50%{box-shadow:0 10px 28px -6px rgba(37,211,102,.7),0 0 0 12px rgba(37,211,102,.08)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.mobnav{position:fixed;inset:0;z-index:250;background:var(--ink);display:none;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.mobnav.open{display:flex}.mobnav a{color:#fff;font-family:'Fraunces';font-size:27px;padding:9px}.mobnav .x{position:absolute;top:24px;right:26px;font-size:36px;color:#fff;background:none;border:0}

@media(max-width:1000px){
  nav,.hd-ph{display:none}.burger{display:flex}
  .callbar{display:grid}.fab{bottom:84px}
  .split,.cg{grid-template-columns:1fr;gap:46px}
  .srow{grid-template-columns:1fr}.srow .im{min-height:280px}.srow:nth-child(even) .im{order:0}
  .why{grid-template-columns:1fr 1fr}.rev{grid-template-columns:1fr}
  .gal{grid-template-columns:repeat(2,1fr)}.stats{grid-template-columns:1fr 1fr}
  .fg4{grid-template-columns:1fr 1fr}.media img{height:440px}
}
@media(max-width:600px){
  section{padding:70px 0}.w,.hd,.util .w{padding-left:20px;padding-right:20px}
  .why{grid-template-columns:1fr}.srow ul{grid-template-columns:1fr}.srow .tx{padding:32px 28px}
  .gal{grid-template-columns:1fr 1fr;grid-auto-rows:150px}.fr{display:none}
  .hero h1{font-size:clamp(42px,12vw,68px)}.fg4{grid-template-columns:1fr}.hero-tag{display:none}
}

/* === final pass refinements === */
.prog{padding-top:64px}
.hero-cta{padding-bottom:44px}
.prog-stage::after{content:'';position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 90px rgba(0,0,0,.4);border-radius:6px;z-index:4}
.prog-badge{display:inline-flex;align-items:center;gap:8px}
.prog-badge i{width:8px;height:8px;border-radius:50%;background:#fff;animation:bdot 1.8s infinite}
@keyframes bdot{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.prog-knob{width:42px;height:42px;color:var(--amber-deep);box-shadow:0 6px 22px rgba(0,0,0,.5),0 0 0 6px rgba(255,255,255,.12)}
.prog-fill{box-shadow:0 0 14px rgba(232,161,41,.5)}
.prog-hint{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);z-index:6;background:rgba(20,16,9,.8);backdrop-filter:blur(4px);color:#fff;font-size:11.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:8px 16px;border-radius:30px;pointer-events:none;animation:hintb 1.8s ease-in-out infinite;transition:opacity .35s,visibility .35s}
@keyframes hintb{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-5px)}}
.prog-wrap.touched .prog-hint{opacity:0;visibility:hidden}
.prog-stop{cursor:pointer}.prog-stop:hover{transform:translate(-50%,-50%) scale(1.25)}
/* scroll progress bar */
.scrollprog{position:fixed;top:0;left:0;height:3px;width:0;z-index:400;background:linear-gradient(90deg,var(--amber),var(--amber-2));box-shadow:0 0 10px rgba(232,161,41,.6);transition:width .08s linear}
/* ===== SEO + FAQ sections ===== */
.seo{padding:104px 0}
.seo-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:46px}
.seo-col p{font-size:15.5px;color:var(--mid);line-height:1.85;margin-bottom:16px}
.seo-col h3{font-family:'Fraunces';font-weight:600;font-size:22px;margin:26px 0 10px;color:var(--ink)}
.seo-col strong{color:var(--ink)}
.faq-list{max-width:820px;margin:42px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-q{background:var(--white);border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:.25s}
.faq-q[open]{box-shadow:var(--shadow);border-color:var(--amber)}
.faq-q summary{cursor:pointer;list-style:none;padding:22px 26px;font-size:17px;font-weight:700;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-q summary::-webkit-details-marker{display:none}
.faq-q summary::after{content:'+';font-family:'Oswald';font-size:26px;font-weight:400;color:var(--amber);transition:transform .25s;line-height:1}
.faq-q[open] summary::after{transform:rotate(45deg)}
.faq-a{padding:0 26px 24px}
.faq-a p{font-size:15px;color:var(--mid);line-height:1.8}
.footer .legal,.fb .legal{font-size:12.5px;color:#6f664f;margin-top:14px;line-height:1.6}
.fb .legal strong{color:var(--amber-2)}
@media(max-width:1000px){.seo-grid{grid-template-columns:1fr;gap:32px}}
@media(max-width:600px){.seo{padding:70px 0}}

/* ===== company visibility ===== */
.logo.lk{display:flex;flex-direction:column;align-items:flex-start;gap:3px;line-height:1}
.logo-co{font-size:9.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-deep)}
header.shrink .logo-co{font-size:9px}
.hero-co{margin-top:16px;font-size:13.5px;letter-spacing:.04em;color:#bdb29c}
.hero-co span{color:#fff;font-weight:800}
.hero-co strong{color:var(--amber-2);font-weight:800}
.band-co{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#a99e89;margin:-4px auto 0}
.band-co strong{color:var(--amber-2)}
/* ===== construction image strip ===== */
.con-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:40px 0 6px}
.ci{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 18px 44px -28px rgba(20,16,9,.5)}
.ci img{width:100%;height:280px;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.ci:hover img{transform:scale(1.07)}
.ci figcaption{position:absolute;left:12px;bottom:12px;background:rgba(20,16,9,.62);backdrop-filter:blur(4px);color:#fff;font-size:12px;font-weight:600;letter-spacing:.02em;padding:7px 13px;border-radius:3px}
.ci figcaption b{color:var(--amber-2);font-weight:800}
@media(max-width:760px){.con-imgs{grid-template-columns:1fr 1fr}.ci img{height:180px}}
@media(max-width:460px){.con-imgs{grid-template-columns:1fr}.ci img{height:230px}}
/* richer reveal */
.reveal{will-change:opacity,transform}
.eye::before{transition:width .6s cubic-bezier(.16,1,.3,1)}
.reveal:not(.in) .eye::before{width:0}
/* performance: defer offscreen heavy sections */
#recenzii,.faq{content-visibility:auto;contain-intrinsic-size:1px 700px}
