
:root{
  --navy:#0a1420; --bg-d:#0b1724; --panel-d:#101f30;
  --ink:#0d2235; --ink-2:#46627a; --ink-3:#6c869b;
  --paper:#ffffff; --frost:#eef5fa; --frost-2:#e4eef6;
  --line:#dae7f0; --line-2:#c8dae8; --line-d:rgba(226,242,251,.12);
  --sky:#0ea5e9; --cyan:#22d3ee; --sky-deep:#0369a1; --sky-soft:#7dd3fc;
  --cream:#eaf4fb; --cream-2:#aac6dc;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,.disp{font-family:'Space Grotesk',sans-serif;letter-spacing:-.01em;margin:0}
.mono{font-family:'JetBrains Mono',monospace}
a{color:inherit}
img{display:block;max-width:100%}
::selection{background:var(--sky);color:#fff}
.wrap{max-width:1240px;margin:0 auto;padding:0 26px}
.sec{padding:clamp(4rem,7.5vw,6.8rem) 0}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--sky-deep);display:inline-flex;align-items:center;gap:.7rem}
.eyebrow::before{content:"";width:28px;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--sky),var(--cyan))}
.eyebrow.center{justify-content:center}.eyebrow.light{color:var(--sky-soft)}.eyebrow.light::before{background:var(--sky-soft)}
.h-sec{font-size:clamp(2rem,4.6vw,3.2rem);font-weight:700;line-height:1.04;letter-spacing:-.02em}
.lead{color:var(--ink-2);font-size:1.06rem;line-height:1.7}
.sky{color:var(--sky)}
.grad{background:linear-gradient(120deg,var(--sky),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.9rem 1.55rem;border-radius:10px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14.5px;cursor:pointer;border:1px solid transparent;transition:.3s cubic-bezier(.2,.7,.3,1);white-space:nowrap;text-decoration:none}
.btn svg{width:17px;height:17px}
.btn-sky{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#04202e;box-shadow:0 12px 30px -10px rgba(14,165,233,.6);position:relative;overflow:hidden}
.btn-sky:hover{transform:translateY(-2px);box-shadow:0 18px 40px -12px rgba(14,165,233,.75)}
.btn-sky::after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-18deg);animation:shineb 4.6s infinite;pointer-events:none}
@keyframes shineb{0%,66%{left:-130%}82%{left:150%}100%{left:150%}}
.btn-dark{background:var(--ink);color:#fff}.btn-dark:hover{background:#0a1a29;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}.btn-ghost:hover{border-color:var(--sky);color:var(--sky-deep)}
.btn-glass{background:rgba(234,244,251,.1);color:#fff;border-color:rgba(234,244,251,.25);backdrop-filter:blur(8px)}.btn-glass:hover{background:rgba(234,244,251,.2)}

/* reveal */
[data-rev]{opacity:0;transform:translateY(26px);transition:opacity .85s cubic-bezier(.2,.7,.3,1),transform .85s cubic-bezier(.2,.7,.3,1)}
[data-rev].in{opacity:1;transform:none}
[data-d="1"]{transition-delay:.07s}[data-d="2"]{transition-delay:.14s}[data-d="3"]{transition-delay:.21s}[data-d="4"]{transition-delay:.28s}[data-d="5"]{transition-delay:.35s}

/* progress */
.prog{position:fixed;top:0;left:0;height:3px;width:0;z-index:99;background:linear-gradient(90deg,var(--sky),var(--cyan));box-shadow:0 0 12px rgba(34,211,238,.6);transition:width .1s ease-out}

/* topbar */
.topbar{background:var(--navy);color:var(--cream-2);font-size:12.5px;border-bottom:1px solid var(--line-d)}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:1rem}
.topbar a{color:var(--cream-2);text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:.25s}
.topbar a:hover{color:var(--sky-soft)}.topbar svg{width:14px;height:14px;color:var(--sky)}
.tb-l{display:flex;gap:1.4rem;align-items:center}.tb-r{display:flex;gap:1.3rem;align-items:center}
.tb-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(14,165,233,.16);border:1px solid rgba(34,211,238,.3);color:var(--sky-soft);padding:.2rem .6rem;border-radius:100px;font-weight:600}

/* header */
.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:.4s}
.hdr.scrolled{background:rgba(255,255,255,.96);border-color:var(--line);box-shadow:0 8px 30px -22px rgba(13,34,53,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;color:var(--ink)}
.brand .logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--sky),var(--cyan));display:grid;place-items:center;color:#fff;box-shadow:0 8px 20px -8px rgba(14,165,233,.7)}
.brand .logo svg{width:23px;height:23px}
.brand b{font-family:'Space Grotesk';font-size:19px;font-weight:700;line-height:1;letter-spacing:-.01em}
.brand span{display:block;font-family:'JetBrains Mono';font-size:9px;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase;margin-top:2px}
.menu{display:flex;gap:1.9rem;align-items:center}
.navlink{position:relative;font-family:'Space Grotesk';font-weight:600;font-size:14.5px;color:var(--ink-2);text-decoration:none;transition:.3s}
.navlink::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--sky),var(--cyan));transition:.35s}
.navlink:hover{color:var(--ink)}.navlink:hover::after{width:100%}
.burger{display:none;background:none;border:1px solid var(--line-2);color:var(--ink);border-radius:8px;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer}
.mob{position:fixed;inset:0;z-index:70;background:rgba(10,20,32,.98);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;opacity:0;visibility:hidden;transition:.35s}
.mob.open{opacity:1;visibility:visible}
.mob a{font-family:'Space Grotesk';font-weight:600;font-size:1.5rem;color:#fff;text-decoration:none}
.mob .x{position:absolute;top:22px;right:22px;background:none;border:none;color:#fff;cursor:pointer}

/* hero */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden;background:var(--bg-d)}
.hero-img{position:absolute;inset:0;background:url(/img/hero.jpg) center/cover;transform:scale(1.07);animation:kb 22s ease-in-out infinite alternate;filter:saturate(1.05)}
@keyframes kb{from{transform:scale(1.07) translate(0,0)}to{transform:scale(1.15) translate(-1.5%,-2%)}}
.hero-veil{position:absolute;inset:0;background:linear-gradient(95deg,rgba(8,16,26,.95) 0%,rgba(8,16,26,.82) 42%,rgba(8,16,26,.42) 100%)}
.hero-glow{position:absolute;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.22),transparent 62%);right:-150px;top:-120px;pointer-events:none}
.hero .wrap{position:relative;z-index:2;width:100%;color:var(--cream)}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:700;line-height:1.02;letter-spacing:-.02em;color:#fff}
.hero h1 em{font-style:normal;background:linear-gradient(120deg,var(--sky-soft),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.chip{display:inline-flex;align-items:center;gap:.5rem;background:rgba(234,244,251,.08);border:1px solid rgba(234,244,251,.18);backdrop-filter:blur(6px);padding:.5rem 1rem;border-radius:100px;font-size:12.5px;color:var(--cream)}
.chip svg{width:15px;height:15px;color:var(--sky-soft)}
.hero-chips{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.8rem}
.hero-stats{display:flex;gap:2.4rem;flex-wrap:wrap;margin-top:2.6rem;padding-top:1.9rem;border-top:1px solid var(--line-d)}
.hero-stats .n{font-family:'Space Grotesk';font-weight:700;font-size:2.5rem;line-height:1;background:linear-gradient(120deg,#fff,var(--sky-soft));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-stats .l{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-2);margin-top:.3rem}

/* marquee */
.strip{background:linear-gradient(90deg,var(--sky),var(--cyan));color:#04202e;overflow:hidden}
.marq{display:flex;gap:3rem;white-space:nowrap;padding:.8rem 0;animation:marq 28s linear infinite;font-family:'Space Grotesk';font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:13.5px}
.marq span{display:inline-flex;align-items:center;gap:1rem}
.marq b{display:inline-flex;align-items:center;gap:1rem}.marq b::before{content:"❄";color:#04202e;opacity:.6}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:-4.5rem;position:relative;z-index:5}
.pill{background:#fff;border:1px solid var(--line);border-radius:16px;padding:1.7rem;box-shadow:0 30px 60px -40px rgba(13,34,53,.4);transition:.4s cubic-bezier(.2,.7,.3,1)}
.pill:hover{transform:translateY(-6px);box-shadow:0 40px 70px -40px rgba(14,165,233,.4);border-color:var(--line-2)}
.pill .ic{width:52px;height:52px;border-radius:13px;background:linear-gradient(135deg,rgba(14,165,233,.12),rgba(34,211,238,.12));border:1px solid var(--line-2);display:grid;place-items:center;color:var(--sky-deep);transition:.35s}
.pill:hover .ic{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#fff;transform:rotate(-6deg)}
.pill .ic svg{width:24px;height:24px}
.pill h3{font-size:1.2rem;font-weight:700;margin:1rem 0 .4rem}
.pill p{color:var(--ink-2);font-size:.94rem;line-height:1.6;margin:0}

/* products */
.grid-p{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.prod{background:#fff;border:1px solid var(--line);border-radius:15px;overflow:hidden;transition:.4s cubic-bezier(.2,.7,.3,1);cursor:pointer}
.prod:hover{transform:translateY(-7px);border-color:var(--sky-soft);box-shadow:0 34px 60px -38px rgba(14,165,233,.45)}
.prod-img{aspect-ratio:5/4;overflow:hidden;position:relative}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:1s cubic-bezier(.2,.7,.3,1)}
.prod:hover .prod-img img{transform:scale(1.09)}
.prod-img::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(8,16,26,.55));opacity:.6}
.prod-tag{position:absolute;left:12px;top:12px;z-index:2;background:rgba(255,255,255,.92);backdrop-filter:blur(4px);color:var(--sky-deep);width:38px;height:38px;border-radius:10px;display:grid;place-items:center}
.prod-tag svg{width:19px;height:19px}
.prod-b{padding:1.1rem 1.2rem 1.3rem}
.prod-b h3{font-size:1.06rem;font-weight:700;margin-bottom:.3rem}
.prod-b p{color:var(--ink-3);font-size:.85rem;line-height:1.55;margin:0}
.prod-ln{margin-top:.9rem;font-family:'Space Grotesk';font-weight:600;font-size:12.5px;color:var(--sky-deep);display:inline-flex;align-items:center;gap:.35rem;transition:.3s}
.prod-ln svg{width:14px;height:14px;transition:.3s}
.prod:hover .prod-ln{gap:.6rem}

/* why */
.why{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.why-img{position:relative}
.why-img img{width:100%;border-radius:18px;object-fit:cover;aspect-ratio:4/5}
.why-card{position:absolute;right:-22px;bottom:30px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.3rem;box-shadow:0 24px 50px -24px rgba(13,34,53,.4);display:flex;gap:.9rem;align-items:center;animation:floaty 6s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.why-card .ic{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--sky),var(--cyan));display:grid;place-items:center;color:#fff;flex:none}
.why-card .ic svg{width:22px;height:22px}
.why-card b{font-family:'Space Grotesk';font-size:1.4rem;display:block;line-height:1}
.why-card span{color:var(--ink-3);font-size:.8rem}
.feat{display:flex;gap:1rem;padding:1.05rem 0;border-bottom:1px solid var(--line);transition:.3s;border-radius:10px}
.feat:hover{background:var(--frost);padding-left:.5rem}
.feat .ic{flex:none;width:46px;height:46px;border-radius:11px;background:linear-gradient(135deg,rgba(14,165,233,.1),rgba(34,211,238,.1));border:1px solid var(--line-2);display:grid;place-items:center;color:var(--sky-deep);transition:.35s}
.feat:hover .ic{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#fff;transform:translateY(-3px)}
.feat .ic svg{width:21px;height:21px}
.feat h4{font-size:1.04rem;font-weight:700;margin-bottom:.2rem}
.feat p{color:var(--ink-2);font-size:.9rem;line-height:1.55;margin:0}

/* services */
.grid-sv{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.svc{background:var(--panel-d);border:1px solid var(--line-d);border-radius:15px;padding:1.6rem;transition:.4s;color:var(--cream)}
.svc:hover{transform:translateY(-6px);border-color:rgba(34,211,238,.4);background:#13263a}
.svc .ic{width:50px;height:50px;border-radius:13px;background:rgba(14,165,233,.14);border:1px solid rgba(34,211,238,.25);display:grid;place-items:center;color:var(--sky-soft);transition:.35s}
.svc:hover .ic{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#04202e}
.svc .ic svg{width:23px;height:23px}
.svc h3{font-size:1.12rem;font-weight:700;margin:1rem 0 .4rem;color:#fff}
.svc p{color:var(--cream-2);font-size:.9rem;line-height:1.6;margin:0}

/* projects */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
.gal a{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--line)}
.gal img{width:100%;height:100%;object-fit:cover;transition:.7s}
.gal a:hover img{transform:scale(1.09)}
.gal a::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(8,16,26,.7))}
.gal .cap{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff}
.gal .cap b{font-family:'Space Grotesk';font-size:1rem;display:block}
.gal .cap span{font-size:.78rem;color:var(--sky-soft);font-family:'JetBrains Mono';letter-spacing:.05em}
.gal .big{grid-column:span 2;grid-row:span 2}

/* financing band */
.fin{position:relative;overflow:hidden;background:var(--bg-d)}
.fin-bg{position:absolute;inset:0;background:url(/img/cta.jpg) center/cover;filter:brightness(.3) saturate(1.1)}
.fin-veil{position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,16,26,.93),rgba(8,16,26,.6))}
.fin .inner{position:relative;z-index:2;color:var(--cream);display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center}
.fin h2{color:#fff}
.fin-badges{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.5rem}
.fin-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(234,244,251,.08);border:1px solid rgba(234,244,251,.18);border-radius:10px;padding:.7rem 1rem;font-size:.88rem}
.fin-badge svg{width:18px;height:18px;color:var(--sky-soft)}

/* testimonials */
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.tcard{background:#fff;border:1px solid var(--line);border-radius:15px;padding:1.6rem;transition:.35s}
.tcard:hover{transform:translateY(-5px);box-shadow:0 30px 55px -38px rgba(14,165,233,.4);border-color:var(--line-2)}
.tcard .stars{color:var(--sky);display:flex;gap:2px;margin-bottom:1rem}.tcard .stars svg{width:16px;height:16px;fill:currentColor}
.tcard .q{color:var(--ink-2);line-height:1.7;font-size:.97rem}
.tu{display:flex;align-items:center;gap:.8rem;margin-top:1.3rem;padding-top:1.1rem;border-top:1px solid var(--line)}
.tu img{width:44px;height:44px;border-radius:50%;object-fit:cover;flex:none}
.tu b{font-family:'Space Grotesk';font-weight:600}.tu span{display:block;color:var(--ink-3);font-size:.8rem}

/* contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:2.4rem;align-items:start}
.form{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.8rem;box-shadow:0 30px 60px -45px rgba(13,34,53,.4)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.field{margin-top:.85rem}
.field label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.35rem;font-family:'Space Grotesk';font-weight:600}
.field input,.field select,.field textarea{width:100%;background:var(--frost);border:1px solid var(--line-2);color:var(--ink);border-radius:9px;padding:.78rem .85rem;font-family:inherit;font-size:.95rem;transition:.25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--sky);background:#fff;box-shadow:0 0 0 3px rgba(14,165,233,.12)}
.field textarea{resize:vertical;min-height:90px}
.note{margin-top:.9rem;font-size:.8rem;color:var(--ink-3);display:flex;gap:.5rem;align-items:flex-start}.note svg{width:15px;height:15px;color:var(--sky);flex:none;margin-top:1px}
.cinfo{display:flex;gap:.9rem;padding:.85rem 0;transition:.3s;border-radius:11px}
.cinfo:hover{background:var(--frost);padding-left:.45rem}
.cinfo .ic{flex:none;width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,rgba(14,165,233,.1),rgba(34,211,238,.1));border:1px solid var(--line-2);display:grid;place-items:center;color:var(--sky-deep);transition:.35s}
.cinfo:hover .ic{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#fff}
.cinfo .ic svg{width:20px;height:20px}
.cinfo b{font-family:'Space Grotesk';font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3)}
.cinfo p{margin:.15rem 0 0;font-size:1.02rem;font-weight:500}
.hours{list-style:none;margin:1.1rem 0 0;padding:0}
.hours li{display:flex;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--line);font-size:.95rem;transition:.25s}
.hours li:hover{padding-left:.4rem;color:var(--sky-deep)}
.hours .t{color:var(--ink-2);font-weight:500}
.map{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line-2);min-height:300px;margin-top:1.4rem}
.map iframe{width:100%;height:100%;min-height:300px;border:0;filter:grayscale(.2) contrast(1.03)}
.map-dir{position:absolute;left:14px;bottom:14px;z-index:2;display:inline-flex;align-items:center;gap:.45rem;background:#fff;color:var(--ink);border:1px solid var(--line-2);padding:.55rem .95rem;border-radius:9px;font-family:'Space Grotesk';font-weight:600;font-size:12.5px;text-decoration:none;box-shadow:0 10px 24px -12px rgba(13,34,53,.4);transition:.3s}
.map-dir svg{width:15px;height:15px;color:var(--sky-deep)}
.map-dir:hover{background:var(--sky);color:#fff}.map-dir:hover svg{color:#fff}

/* footer */
.foot{background:var(--navy);color:var(--cream-2);padding:3.4rem 0 2rem;border-top:1px solid var(--line-d)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:2rem}
.foot .brand b{color:#fff}.foot .brand span{color:var(--cream-2)}
.foot h5{font-family:'Space Grotesk';font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin:0 0 1rem}
.foot a{display:block;color:var(--cream-2);text-decoration:none;padding:.3rem 0;font-size:.92rem;transition:.25s}
.foot a:hover{color:var(--sky-soft)}
.foot-soc{display:flex;gap:.55rem;margin-top:1.1rem;flex-wrap:wrap}
.foot-soc a{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem .9rem;border-radius:100px;background:rgba(234,244,251,.07);border:1px solid var(--line-d);color:var(--cream);font-family:'Space Grotesk';font-weight:600;font-size:12px;transition:.3s}
.foot-soc a svg{width:16px;height:16px;color:var(--sky-soft);transition:.3s}
.foot-soc a:hover{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#04202e;border-color:transparent;transform:translateY(-3px)}
.foot-soc a:hover svg{color:#04202e}
.foot-bot{margin-top:2.6rem;padding-top:1.5rem;border-top:1px solid var(--line-d);display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--cream-2);font-size:.85rem}

/* fab */
.fab{position:fixed;right:20px;bottom:20px;z-index:55;display:flex;flex-direction:column;gap:.7rem}
.fab a{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;box-shadow:0 14px 30px -10px rgba(0,0,0,.4);transition:.3s}
.fab a:hover{transform:translateY(-3px) scale(1.05)}
.fab .ph{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#04202e}
.fab .ml{background:#fff;color:var(--sky-deep);border:1px solid var(--line)}
.fab svg{width:23px;height:23px}

/* ===== premium layer (keeps the light theme) ===== */
#spot{position:fixed;top:0;left:0;width:520px;height:520px;margin:-260px 0 0 -260px;border-radius:50%;pointer-events:none;z-index:3;background:radial-gradient(circle,rgba(14,165,233,.14),rgba(34,211,238,.06) 42%,transparent 64%);opacity:0;transition:opacity .4s;mix-blend-mode:multiply}
.grad{background:linear-gradient(120deg,var(--sky) 0%,var(--cyan) 34%,#67e8f9 50%,var(--cyan) 66%,var(--sky) 100%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 6.5s linear infinite}
@keyframes shimmer{to{background-position:220% center}}
.words span{display:inline-block;opacity:0;transform:translateY(.7em) rotate(3deg);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.words.in span{opacity:1;transform:none}
.tilt{will-change:transform}
.pill::before,.prod::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(34,211,238,.6),rgba(56,189,248,.15) 45%,transparent 72%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.4s;pointer-events:none}
.pill:hover::before,.prod:hover::before{opacity:1}
#frost{position:absolute;inset:0;z-index:1;pointer-events:none}
/* hero slider */
.hero-slides{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.12);transition:opacity 1.3s ease,transform 7s ease;will-change:opacity,transform}
.hero-slide.on{opacity:1;transform:scale(1.04)}
.hero-arrow{position:absolute;top:46%;z-index:4;width:50px;height:50px;border-radius:50%;background:rgba(234,244,251,.1);border:1px solid rgba(234,244,251,.25);backdrop-filter:blur(8px);color:#fff;display:grid;place-items:center;cursor:pointer;transition:.3s}
.hero-arrow:hover{background:rgba(234,244,251,.22);transform:scale(1.07)}
.hero-arrow svg{width:22px;height:22px}
.hero-arrow.prev{left:22px}.hero-arrow.next{right:22px}
.hero-dots{position:absolute;left:0;right:0;bottom:22px;display:flex;gap:.5rem;justify-content:center;z-index:4}
.hero-dot{width:32px;height:4px;border-radius:3px;background:rgba(255,255,255,.32);border:none;cursor:pointer;transition:.35s;padding:0}
.hero-dot.on{background:linear-gradient(90deg,var(--sky),var(--cyan));width:50px}
@media(max-width:720px){.hero-arrow{display:none}}
.gstats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.gstat{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.4rem}
.gauge{width:148px;height:148px;transform:rotate(-90deg)}
.gauge .track{fill:none;stroke:var(--line);stroke-width:9}
.gauge .bar{fill:none;stroke:url(#gg);stroke-width:9;stroke-linecap:round;stroke-dasharray:408.4;stroke-dashoffset:408.4;transition:stroke-dashoffset 1.8s cubic-bezier(.2,.7,.3,1)}
.gauge-c{position:absolute;top:1.4rem;left:0;right:0;height:148px;display:grid;place-items:center}
.gauge-c .n{font-family:'Space Grotesk';font-weight:700;font-size:2rem;line-height:1;color:var(--ink);display:flex;align-items:baseline;gap:1px}
.gstat .l{font-family:'Space Grotesk';font-weight:700;margin-top:1rem;font-size:1.05rem}
.gstat .s{color:var(--ink-3);font-size:.85rem;margin-top:.25rem;max-width:210px}
@media(prefers-reduced-motion:reduce){.grad{animation:none}#frost{display:none}.words span{opacity:1;transform:none}}

@media(max-width:1024px){
  .grid-p{grid-template-columns:repeat(2,1fr)}
  .grid-sv{grid-template-columns:repeat(2,1fr)}
  .pillars{grid-template-columns:1fr;margin-top:-3rem}
  .why{grid-template-columns:1fr}.why-img{order:-1;max-width:520px;margin:0 auto}.why-card{right:10px}
  .fin .inner{grid-template-columns:1fr}
  .tg{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gal{grid-template-columns:repeat(2,1fr)}.gal .big{grid-column:span 2;grid-row:span 1}
}
@media(max-width:720px){
  .menu,.tb-l{display:none}.burger{display:flex}
  .hero h1{font-size:clamp(2.3rem,9vw,3rem)}
  .grid-p{grid-template-columns:1fr 1fr;gap:.8rem}
  .form .row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .gal{grid-template-columns:1fr;grid-auto-rows:200px}.gal .big{grid-column:span 1}
  .gstats{grid-template-columns:1fr;gap:.5rem}
}

/* ---- shared subpage additions ---- */
.navlink.active{color:var(--ink)}.navlink.active::after{width:100%}
a.prod{display:block;text-decoration:none;color:inherit}
.crumb{font-family:'JetBrains Mono';font-size:12px;letter-spacing:.04em;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;color:var(--cream-2)}
.crumb a{color:var(--cream-2);text-decoration:none}.crumb a:hover{color:var(--sky-soft)}.crumb .sep{opacity:.45}
.pagehero{position:relative;overflow:hidden;background:var(--bg-d);color:var(--cream);padding:clamp(3.6rem,7vw,5.6rem) 0 clamp(3rem,5vw,4.4rem)}
.pagehero .pimg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.34;filter:saturate(1.05);transform:scale(1.05);animation:kb 24s ease-in-out infinite alternate}
.pagehero .pveil{position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,16,26,.93),rgba(8,16,26,.55))}
.pagehero .pglow{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,.2),transparent 62%);right:-160px;top:-160px;pointer-events:none}
.pagehero .wrap{position:relative;z-index:2}
.pagehero h1{font-size:clamp(2.1rem,5vw,3.5rem);font-weight:700;color:#fff;margin:.9rem 0 0;letter-spacing:-.02em}
.pagehero p{color:var(--cream-2);max-width:580px;margin:.9rem 0 0;font-size:1.06rem;line-height:1.65}
.pagehero .tag{display:inline-flex;align-items:center;gap:.5rem;background:rgba(234,244,251,.1);border:1px solid rgba(234,244,251,.2);padding:.45rem .9rem;border-radius:100px;font-size:12.5px;color:var(--cream)}
.pagehero .tag svg{width:15px;height:15px;color:var(--sky-soft)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.col-img img{width:100%;border-radius:18px;object-fit:cover;aspect-ratio:4/3;border:1px solid var(--line);box-shadow:0 30px 60px -42px rgba(13,34,53,.5)}
.prose p{color:var(--ink-2);line-height:1.75;font-size:1.04rem;margin:1rem 0 0}
.chiplist{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.3rem}
.chiplist span{display:inline-flex;align-items:center;gap:.4rem;background:var(--frost);border:1px solid var(--line-2);color:var(--ink-2);padding:.5rem .85rem;border-radius:100px;font-size:.85rem;font-weight:500}
.chiplist span svg{width:14px;height:14px;color:var(--sky-deep)}
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.fcard{background:#fff;border:1px solid var(--line);border-radius:15px;padding:1.5rem;position:relative;transition:.4s cubic-bezier(.2,.7,.3,1);will-change:transform}
.fcard:hover{transform:translateY(-6px);box-shadow:0 32px 58px -40px rgba(14,165,233,.45);border-color:var(--line-2)}
.fcard .ic{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,rgba(14,165,233,.1),rgba(34,211,238,.1));border:1px solid var(--line-2);display:grid;place-items:center;color:var(--sky-deep);transition:.35s}
.fcard:hover .ic{background:linear-gradient(135deg,var(--sky),var(--cyan));color:#fff;transform:rotate(-6deg)}
.fcard .ic svg{width:22px;height:22px}
.fcard h3{font-size:1.08rem;font-weight:700;margin:.9rem 0 .35rem}
.fcard p{color:var(--ink-2);font-size:.92rem;line-height:1.6;margin:0}
.spectable{width:100%;border-collapse:collapse}
.spectable td{padding:.85rem 0;border-bottom:1px solid var(--line);font-size:.98rem}
.spectable td:first-child{color:var(--ink-3);font-family:'Space Grotesk';font-weight:600;width:46%}
.spectable td:last-child{font-weight:500}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;counter-reset:s}
.step{position:relative;padding:1.5rem;border:1px solid var(--line);border-radius:15px;background:#fff;transition:.4s}
.step:hover{transform:translateY(-5px);box-shadow:0 30px 55px -40px rgba(14,165,233,.4)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Space Grotesk';font-weight:700;font-size:1.7rem;background:linear-gradient(120deg,var(--sky),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.step h3{font-size:1.05rem;margin:.45rem 0 .3rem}
.step p{color:var(--ink-2);font-size:.9rem;line-height:1.55;margin:0}
.related{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
@media(max-width:1024px){.fgrid{grid-template-columns:repeat(2,1fr)}.steps{grid-template-columns:repeat(2,1fr)}.related{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr}.split .col-img{order:-1;max-width:560px;margin:0 auto}}
@media(max-width:680px){.fgrid,.steps,.related{grid-template-columns:1fr}.spectable td:first-child{width:50%}}
/* projects gallery */
.pstats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:center}
.pstat .n{font-family:'Space Grotesk';font-weight:700;font-size:clamp(1.8rem,3.5vw,2.7rem);line-height:1;background:linear-gradient(120deg,var(--sky),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.pstat .l{color:var(--ink-2);font-size:.9rem;margin-top:.45rem;font-weight:500}
.pgal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:185px;gap:14px}
.pgal a{position:relative;overflow:hidden;border-radius:14px;border:1px solid var(--line);display:block}
.pgal img{width:100%;height:100%;object-fit:cover;transition:.7s}
.pgal a:hover img{transform:scale(1.09)}
.pgal a::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 42%,rgba(8,16,26,.8));opacity:.82;transition:.4s}
.pgal a:hover::after{opacity:1}
.pgal .cap{position:absolute;left:15px;bottom:13px;z-index:2;color:#fff}
.pgal .cap b{font-family:'Space Grotesk';font-size:1rem;display:block}
.pgal .cap span{font-size:.74rem;color:var(--sky-soft);font-family:'JetBrains Mono';letter-spacing:.04em}
.pgal .w2{grid-column:span 2}.pgal .h2{grid-row:span 2}
.ptags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:1.1rem}
.ptags span{background:var(--frost);border:1px solid var(--line-2);color:var(--sky-deep);font-family:'JetBrains Mono';font-size:11px;letter-spacing:.03em;padding:.35rem .7rem;border-radius:100px}
@media(max-width:900px){.pgal{grid-template-columns:repeat(2,1fr)}.pgal .w2{grid-column:span 2}.pgal .h2{grid-row:span 1}.pstats{grid-template-columns:1fr 1fr;gap:1.6rem}}
@media(max-width:560px){.pgal{grid-template-columns:1fr}.pgal .w2{grid-column:span 1}}
