:root{
 --cyan:#00C6FF; --blue:#0055CC; --navy:#06286B; --ink:#0B1B33;
 --bg:#EEF5FF; --paper:#FFFFFF; --muted:#56688A; --line:#D9E5F7;
 --grad:linear-gradient(135deg,#00C6FF 0%,#0055CC 100%);
 --grad-deep:linear-gradient(135deg,#0089E0 0%,#06286B 100%);
 --shadow:0 18px 50px rgba(6,40,107,.16);
 --r:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Manrope,system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:Archivo,sans-serif;line-height:1.04;letter-spacing:-.02em}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.eyebrow{font-family:Archivo;font-weight:800;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
 background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.6rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:Archivo;font-weight:800;font-size:1rem;
 padding:.92rem 1.5rem;border-radius:999px;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s}
.btn:hover{transform:translateY(-2px)}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 10px 26px rgba(0,90,204,.4)}
.btn-wa{background:#1FB955;color:#fff;box-shadow:0 10px 26px rgba(31,185,85,.34)}
.btn-ghost{background:#fff;color:var(--navy);border:2px solid var(--line)}
svg.ic{width:1.15em;height:1.15em;fill:currentColor}

/* header */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);
 border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem}
.brand img{height:52px;width:auto}
.brand b{font-family:Archivo;font-weight:900;font-size:1.05rem;color:var(--navy);letter-spacing:-.01em;display:none}
.hnav{display:flex;align-items:center;gap:1.4rem}
.hnav .lk{font-weight:600;color:var(--navy);font-size:.95rem}
.hnav .lk:hover{color:var(--blue)}
.hcall{display:flex;align-items:center;gap:.55rem}
.hcall .num{font-family:Archivo;font-weight:900;color:var(--navy);font-size:1.05rem}
@media(max-width:860px){.hnav .lk{display:none}.hcall .num{display:none}}

/* hero */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
 radial-gradient(120% 80% at 100% 0%,rgba(0,198,255,.16),transparent 60%),
 radial-gradient(90% 70% at 0% 100%,rgba(0,85,204,.10),transparent 60%);pointer-events:none}
.hero-in{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;padding:64px 0 72px;position:relative}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:900;color:var(--ink)}
.hero h1 .hl{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.18rem;color:var(--muted);margin:1.1rem 0 1.6rem;max-width:33ch}
.hero .cta{display:flex;gap:.75rem;flex-wrap:wrap}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.chip{display:inline-flex;align-items:center;gap:.4rem;background:#fff;border:1px solid var(--line);
 border-radius:999px;padding:.42rem .8rem;font-size:.82rem;font-weight:600;color:var(--navy)}
.chip svg{width:1rem;height:1rem;fill:none;stroke:url(#cg);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}

/* before-after slider (the signature) */
.ba{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);
 aspect-ratio:4/5;user-select:none;touch-action:none;background:#0b1b33}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba .after{clip-path:inset(0 0 0 50%)}
.ba .lbl{position:absolute;top:14px;font-family:Archivo;font-weight:800;font-size:.72rem;letter-spacing:.12em;
 text-transform:uppercase;color:#fff;background:rgba(11,27,51,.62);padding:.34rem .7rem;border-radius:999px;backdrop-filter:blur(4px)}
.ba .lbl.b{left:14px} .ba .lbl.a{right:14px}
.ba .handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);box-shadow:0 0 0 1px rgba(0,90,204,.3)}
.ba .grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;
 background:var(--grad);display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,90,204,.5);color:#fff;font-weight:900}
.ba .grip svg{width:22px;height:22px;fill:#fff}

/* generic section */
section{padding:74px 0}
.sec-head{max-width:640px;margin-bottom:40px}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:900;color:var(--ink)}
.sec-head p{color:var(--muted);margin-top:.6rem;font-size:1.06rem}

/* trust strip */
.trust{background:var(--navy);color:#fff;padding:20px 0}
.trust .row{display:flex;flex-wrap:wrap;gap:10px 30px;justify-content:center;align-items:center}
.trust .t{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem}
.trust .t svg{width:1.2rem;height:1.2rem;stroke:var(--cyan);fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}

/* services */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .ico{width:52px;height:52px;border-radius:14px;background:var(--grad);display:grid;place-items:center;margin-bottom:16px}
.card .ico svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.card h3{font-size:1.22rem;font-weight:800;color:var(--navy)}
.card p{color:var(--muted);font-size:.96rem;margin:.5rem 0 .9rem}
.card .from{font-family:Archivo;font-weight:800;color:var(--blue);font-size:.92rem}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gitem{position:relative;border:none;padding:0;cursor:pointer;border-radius:var(--r);overflow:hidden;
 box-shadow:var(--shadow);background:#0b1b33;aspect-ratio:4/3}
.gitem img{width:100%;height:100%;object-fit:cover;transition:transform .4s;display:block}
.gitem:hover img{transform:scale(1.06)}
.gitem:focus-visible{outline:3px solid var(--cyan);outline-offset:2px}
.gbadge{position:absolute;top:10px;left:10px;font-family:Archivo;font-weight:800;font-size:.66rem;
 letter-spacing:.1em;text-transform:uppercase;color:#fff;padding:.28rem .6rem;border-radius:999px}
.gbadge.b{background:rgba(11,27,51,.78)} .gbadge.a{background:var(--grad)}
/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(6,16,32,.94);display:none;
 align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:80vh;border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.lb-cap{position:absolute;bottom:22px;left:0;right:0;text-align:center;color:#fff;font-weight:600;font-size:.98rem}
.lb-x{position:absolute;top:16px;right:20px;background:none;border:none;color:#fff;font-size:2.6rem;line-height:1;cursor:pointer}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);border:none;color:#fff;
 width:54px;height:54px;border-radius:50%;font-size:2rem;cursor:pointer;display:grid;place-items:center}
.lb-nav:hover{background:var(--grad)}
.lb-prev{left:18px} .lb-next{right:18px}
@media(max-width:560px){.lb-nav{width:44px;height:44px}.lb-prev{left:8px}.lb-next{right:8px}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{position:relative;padding-top:8px}
.step .n{font-family:Archivo;font-weight:900;font-size:2.4rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.step h3{font-size:1.18rem;font-weight:800;color:var(--navy);margin:.4rem 0}
.step p{color:var(--muted);font-size:.98rem}

/* areas */
.areas{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:36px;text-align:center}
.areas .tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:18px}
.areas .tag{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:.5rem 1rem;font-weight:700;color:var(--navy);font-size:.92rem}

/* faq */
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:14px;margin-bottom:12px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:18px 22px;font-family:Archivo;font-weight:700;color:var(--navy);
 font-size:1.06rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--blue);transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq p{padding:0 22px 20px;color:var(--muted)}

/* cta band */
.band{background:var(--grad-deep);border-radius:28px;padding:54px 40px;text-align:center;color:#fff;position:relative;overflow:hidden}
.band h2{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:900}
.band p{opacity:.92;margin:.7rem auto 1.6rem;max-width:46ch;font-size:1.1rem}
.band .cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.band .btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.4)}

/* footer */
footer{background:var(--ink);color:#aebfd8;padding:54px 0 30px;margin-top:10px}
footer .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
footer h4{font-family:Archivo;color:#fff;font-size:.92rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
footer a{color:#aebfd8}footer a:hover{color:var(--cyan)}
footer .li{display:block;margin-bottom:9px;font-size:.95rem}
footer .logo{height:54px;margin-bottom:14px;background:#fff;border-radius:10px;padding:6px 10px;width:max-content}
.copy{border-top:1px solid rgba(255,255,255,.1);margin-top:34px;padding-top:20px;font-size:.84rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* floating call */
.fab{position:fixed;right:18px;bottom:18px;z-index:60;display:none;gap:10px}
.fab a{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.fab .c{background:var(--grad)} .fab .w{background:#1FB955}
.fab svg{width:26px;height:26px;fill:#fff}

@media(max-width:860px){
 .hero-in{grid-template-columns:1fr;gap:34px;padding:40px 0 50px}
 .cards,.gal,.steps{grid-template-columns:1fr}
 footer .grid{grid-template-columns:1fr}
 .fab{display:flex}
 .ba{aspect-ratio:4/5;max-width:440px;margin:0 auto}
}
@media(min-width:560px) and (max-width:860px){.cards,.gal{grid-template-columns:repeat(2,1fr)}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
/* shared additions */
.card{display:block;color:inherit}
.card-link{display:inline-block;margin-top:.7rem;font-family:Archivo;font-weight:800;font-size:.85rem;color:var(--blue)}
.card-link:hover{text-decoration:underline}
.bc{font-size:.85rem;color:var(--muted);padding:14px 0}
.bc a{color:var(--blue)}
.prose{max-width:760px}.prose p{margin-bottom:1rem;color:#27364d}.prose h2{margin:1.6rem 0 .6rem}
.pricetable{width:100%;border-collapse:collapse;margin:8px 0 4px}
.pricetable td{padding:11px 14px;border-bottom:1px solid var(--line)}
.pricetable td:last-child{text-align:right;font-family:Archivo;font-weight:800;color:var(--blue);white-space:nowrap}
.tick{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.6rem;color:#27364d}
.tick svg{flex:none;width:1.2rem;height:1.2rem;stroke:url(#cg);fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;margin-top:.2rem}
