*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0e0a1c;--bg2:#171129;--ink:#f5f2fa;--mut:#a79fc0;--vio:#8b5cf6;--mag:#ec4899;--grad:linear-gradient(100deg,#8b5cf6,#ec4899);--line:#2c2344;--glass:rgba(255,255,255,.05)}
html{scroll-behavior:smooth}
body{font-family:'Schibsted Grotesk',sans-serif;background:var(--bg);color:var(--ink);line-height:1.7;font-size:16.5px;overflow-x:hidden}
h1,h2,h3{font-family:'Bodoni Moda',serif;font-weight:600;line-height:1.12}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 24px}
.grad-t{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.ribbon{background:#080614;color:#a79fc0;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:60}
.ribbon b{color:#f5f2fa}
.ribbon a{display:inline-block;margin-left:12px;background:var(--grad);color:#fff;font-weight:700;padding:3px 14px;border-radius:99px;font-size:13px}
.ribbon a:hover{filter:brightness(1.15)}

header{position:sticky;top:0;z-index:50;background:rgba(14,10,28,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:70px;max-width:1160px;margin:0 auto;padding:0 24px}
.logo{font-family:'Bodoni Moda',serif;font-weight:700;font-size:27px;letter-spacing:.06em}
.logo b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;font-style:italic}
nav.menu{display:flex;gap:28px;align-items:center}
nav.menu a{font-size:14.5px;font-weight:600;color:var(--mut);transition:.15s}
nav.menu a:hover,nav.menu a.on{color:#fff}
.cta-btn{background:var(--grad);color:#fff!important;padding:11px 24px;border-radius:99px;font-weight:700!important;box-shadow:0 6px 24px rgba(180,80,220,.35)}
.cta-btn:hover{filter:brightness(1.12)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2px;background:#fff;margin:6px 0}

/* hero */
.hero{position:relative;overflow:hidden;text-align:center}
.hero .bgimg{position:absolute;inset:0;background:url(../img/hero.jpg) center/cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,10,28,.38) 0%,rgba(14,10,28,.55) 55%,rgba(14,10,28,.97) 100%)}
.hero .in{position:relative;z-index:2;padding:110px 24px 130px;max-width:900px;margin:0 auto}
.hero .kicker{display:inline-flex;align-items:center;gap:10px;border:1px solid rgba(255,255,255,.28);background:rgba(14,10,28,.45);backdrop-filter:blur(6px);color:#fff;font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-size:12px;padding:9px 20px;border-radius:99px;margin-bottom:26px}
.hero h1{font-size:clamp(44px,7.2vw,92px);font-weight:700}
.hero h1 em{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:#d8d2e8;font-size:19px;max-width:620px;margin:22px auto 34px}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-block;background:var(--grad);color:#fff;padding:16px 34px;border-radius:99px;font-weight:700;font-size:16px;transition:.15s;border:0;cursor:pointer;font-family:'Schibsted Grotesk',sans-serif;box-shadow:0 10px 34px rgba(180,80,220,.4)}
.btn:hover{filter:brightness(1.12);transform:translateY(-2px)}
.btn.ghost{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.35);box-shadow:none}
.btn.ghost:hover{background:rgba(255,255,255,.14)}

/* stats */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg2)}
.stats .in{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1160px;margin:0 auto;padding:36px 24px;text-align:center}
.stats .v{font-family:'Bodoni Moda',serif;font-weight:700;font-size:44px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stats p{color:var(--mut);font-size:13.5px;text-transform:uppercase;letter-spacing:.1em}

section{padding:96px 0}
.shead{text-align:center;max-width:680px;margin:0 auto 54px}
.shead .eyebrow{display:inline-block;color:var(--mag);font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:12.5px;margin-bottom:14px}
.shead h2{font-size:clamp(32px,4.6vw,54px)}
.shead h2 em{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.shead p{color:var(--mut);margin-top:14px}

/* glass service cards */
.svc-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{background:var(--glass);border:1px solid var(--line);border-radius:20px;padding:34px 30px;backdrop-filter:blur(8px);transition:.18s;position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:30px;right:30px;height:2px;background:var(--grad);opacity:0;transition:.18s}
.svc:hover{transform:translateY(-5px);border-color:#4b3a78}
.svc:hover::before{opacity:1}
.svc .n{font-family:'Bodoni Moda',serif;font-style:italic;font-size:20px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:12px}
.svc h3{font-size:22px;margin-bottom:10px}
.svc p{color:var(--mut);font-size:14.5px}

/* case photo cards */
.case{position:relative;border-radius:24px;overflow:hidden;margin-bottom:28px;border:1px solid var(--line)}
.case img{width:100%;height:480px;object-fit:cover;transition:.4s}
.case:hover img{transform:scale(1.03)}
.case .ov{position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(10,7,20,.92) 82%);display:flex;flex-direction:column;justify-content:flex-end;padding:40px 44px}
.case .tag{align-self:flex-start;background:var(--grad);color:#fff;font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 16px;border-radius:99px;margin-bottom:14px}
.case h3{font-size:clamp(24px,3vw,36px)}
.case p{color:#d8d2e8;font-size:15.5px;max-width:640px;margin-top:8px}
.case .meta{display:flex;gap:30px;margin-top:18px;flex-wrap:wrap}
.case .meta div b{font-family:'Bodoni Moda',serif;font-size:26px;display:block;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.case .meta div span{color:var(--mut);font-size:12.5px;text-transform:uppercase;letter-spacing:.08em}
.case-g2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.case-g2 .case img{height:380px}
.case-g2 .case .ov{padding:30px 32px}

/* process */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;position:relative}
.proc::before{content:"";position:absolute;top:26px;left:6%;right:6%;height:2px;background:var(--grad);opacity:.45}
.proc .p{text-align:center;position:relative}
.proc .n{width:52px;height:52px;margin:0 auto 18px;border-radius:50%;background:var(--bg);border:2px solid transparent;background:linear-gradient(var(--bg2),var(--bg2)) padding-box,var(--grad) border-box;display:flex;align-items:center;justify-content:center;font-family:'Bodoni Moda',serif;font-style:italic;font-size:20px;position:relative;z-index:1}
.proc h3{font-size:19px;margin-bottom:8px}
.proc p{color:var(--mut);font-size:14px}

/* tags */
.tags{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.tags span{border:1px solid var(--line);background:var(--glass);border-radius:99px;padding:9px 20px;font-size:14.5px;color:#d8d2e8}

/* calc */
.calc{background:var(--bg2);border:1px solid var(--line);border-radius:24px;padding:44px}
.calc-g{display:grid;grid-template-columns:1.2fr .8fr;gap:46px}
.cfg label{display:block;font-weight:700;font-size:14.5px;margin:22px 0 9px}
.cfg input[type=range]{width:100%;accent-color:var(--mag)}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{border:1px solid var(--line);background:var(--glass);color:var(--ink);padding:10px 18px;border-radius:99px;cursor:pointer;font-family:inherit;font-size:14.5px;transition:.12s}
.seg button.on{background:var(--grad);border-color:transparent;font-weight:700}
.calc-out{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;padding:34px;text-align:center;align-self:start}
.calc-out .sum{font-family:'Bodoni Moda',serif;font-weight:700;font-size:46px;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.calc-out p{color:var(--mut);font-size:13.5px;margin-top:10px}

/* form */
.form-g{display:grid;grid-template-columns:1fr 1fr;gap:54px}
.fg{margin-bottom:16px}
.fg label{display:block;margin-bottom:7px;font-weight:700;font-size:14px}
input,select,textarea{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--ink);padding:13px 16px;font-family:inherit;font-size:15px;border-radius:12px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--vio)}
.fnote{font-size:13px;color:var(--mut);margin-top:10px}
.ok-msg{display:none;background:#122a1c;border:1px solid #2e7d4f;color:#a5d6b7;padding:16px;border-radius:12px;margin-top:14px}
.k-card{background:var(--glass);border:1px solid var(--line);border-radius:18px;padding:28px;margin-bottom:18px}
.k-card h3{font-size:21px;margin-bottom:8px}
.k-card p,.k-card a{color:var(--mut);font-size:15px}

.band{position:relative;overflow:hidden;background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:84px 0;text-align:center}
.band::before{content:"";position:absolute;top:-120px;left:50%;transform:translateX(-50%);width:700px;height:280px;background:radial-gradient(ellipse,rgba(139,92,246,.35),transparent 70%)}
.band .in{position:relative}
.band h2{font-size:clamp(32px,4.8vw,56px)}
.band h2 em{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.band p{color:var(--mut);margin:12px 0 28px}

footer{background:#080614;padding:58px 0 40px;border-top:1px solid var(--line)}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:1160px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Bodoni Moda',serif;font-size:21px;margin-bottom:12px}
footer a,footer p{color:var(--mut);font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.f-bot{max-width:1160px;margin:36px auto 0;padding:20px 24px 0;border-top:1px solid var(--line);color:var(--mut);font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{position:relative;overflow:hidden;text-align:center;border-bottom:1px solid var(--line);background:radial-gradient(ellipse at 50% -40%,rgba(139,92,246,.28),transparent 60%)}
.phero .in{padding:76px 24px 64px;max-width:820px;margin:0 auto}
.phero .eyebrow{display:inline-block;color:var(--mag);font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:12.5px;margin-bottom:14px}
.phero h1{font-size:clamp(38px,6vw,72px)}
.phero h1 em{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.phero p{color:var(--mut);margin-top:16px;font-size:17.5px}

section.hero,section.phero{padding:0}

@media(max-width:960px){
 .svc-g{grid-template-columns:1fr 1fr}
 .case-g2,.form-g,.calc-g{grid-template-columns:1fr}
 .proc{grid-template-columns:1fr 1fr;row-gap:40px}
 .proc::before{display:none}
 .stats .in{grid-template-columns:1fr 1fr;gap:28px}
 .case img{height:380px}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 nav.menu{position:absolute;top:100%;left:0;right:0;background:var(--bg);flex-direction:column;gap:0;padding:10px 0 20px;border-bottom:1px solid var(--line);display:none}
 nav.menu.open{display:flex}
 nav.menu a{padding:14px 24px;width:100%;font-size:16px}
 .cta-btn{margin:12px 24px 0;width:calc(100% - 48px);text-align:center}
 .burger{display:block}
 .svc-g,.proc,.f-g,.stats .in{grid-template-columns:1fr}
 section{padding:64px 0}
 .hero .in{padding:70px 20px 84px}
 .case img{height:300px}
 .case .ov{padding:22px 22px}
 .case .meta{gap:18px}
 .calc{padding:26px 20px}
 .phero .in{padding:52px 20px 46px}
}
