/* VISANA website UI kit — layout & component styles (tokens.css holds vars) */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper)}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}

.wrap{max-width:1160px;margin:0 auto;padding:0 28px}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--blue-900);color:rgba(255,255,255,.9);font-size:12.5px}
.topbar .wrap{display:flex;align-items:center;gap:20px;height:38px}
.topbar .promo{flex:1;display:flex;align-items:center;gap:7px;color:#bfe9ff}
.topbar .promo b{color:var(--aqua);font-family:var(--font-head);font-weight:700}
.topbar a{color:rgba(255,255,255,.9);display:inline-flex;align-items:center;gap:6px;font-weight:500}
.topbar a:hover{color:var(--aqua)}
.topbar .sep{opacity:.3}

/* ---------- HEADER ---------- */
.hdr{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hdr .wrap{display:flex;align-items:center;gap:28px;height:74px}
.hdr .logo{height:34px}
.nav{display:flex;align-items:center;gap:4px;margin-left:8px}
.nav > .item{position:relative}
.nav > .item > a{display:inline-flex;align-items:center;gap:5px;padding:10px 13px;border-radius:9px;font-family:var(--font-head);font-weight:600;font-size:14.5px;color:var(--ink);white-space:nowrap}
.nav > .item:hover > a{background:var(--blue-50);color:var(--deep-blue)}
.nav .chev{transition:transform .15s}
.nav > .item:hover .chev{transform:rotate(180deg)}
.mega{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-3);padding:18px;width:520px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.16s ease}
.nav > .item:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}
.mega h6{font-family:var(--font-head);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin:6px 0 8px}
.mega .cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px 14px}
.mega a{font-size:13px;color:#374063;padding:5px 7px;border-radius:7px}
.mega a:hover{background:var(--blue-50);color:var(--deep-blue)}
.hdr .spacer{flex:1}

/* ---------- BUTTONS ---------- */
.btn{font-family:var(--font-head);font-weight:700;border:0;border-radius:var(--r-pill);display:inline-flex;align-items:center;gap:8px;transition:.16s ease;white-space:nowrap}
.btn:active{transform:scale(.98)}
.btn-md{padding:12px 22px;font-size:14px}
.btn-sm{padding:9px 16px;font-size:13px}
.btn-lg{padding:15px 30px;font-size:15.5px}
.btn-primary{background:var(--deep-blue);color:#fff;box-shadow:var(--sh-blue)}
.btn-primary:hover{background:var(--blue-800)}
.btn-accent{background:var(--aqua);color:var(--accent-ink)}
.btn-accent:hover{background:#13e7af}
.btn-secondary{background:#fff;color:var(--deep-blue);border:1.5px solid var(--deep-blue)}
.btn-secondary:hover{background:var(--blue-50)}
.btn-ghost{background:transparent;color:var(--deep-blue);padding-left:6px;padding-right:6px}
.btn-ghost:hover{color:var(--blue-800)}
.btn-white{background:#fff;color:var(--deep-blue)}
.btn-white:hover{background:var(--mint)}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;background:var(--grad-hero);color:#fff}
.hero .glow{position:absolute;inset:0;background:var(--glow-aqua)}
.hero .blob{position:absolute;right:4%;bottom:-22%;width:300px;height:560px;background:linear-gradient(180deg,#16b89a,#1A43AD);border-radius:160px 160px 0 0;transform:rotate(-12deg);opacity:.45;filter:blur(1px)}
.hero .wrap{position:relative;z-index:2;padding:84px 28px 96px;max-width:1160px}
.hero .kicker{font-family:var(--font-head);font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--aqua);font-size:13px;margin-bottom:18px}
.hero h1{font-family:var(--font-head);font-weight:900;font-size:clamp(40px,6.4vw,78px);line-height:.96;letter-spacing:-.02em;max-width:14ch}
.hero h1 .em{color:var(--aqua)}
.hero .sub{margin-top:22px;font-size:18px;font-weight:300;color:rgba(255,255,255,.86);max-width:520px;line-height:1.55}
.hero .chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;font-family:var(--font-head);font-weight:600;font-size:13.5px;padding:9px 16px;border-radius:var(--r-pill);transition:.16s}
.chip:hover{background:var(--aqua);color:var(--accent-ink);border-color:var(--aqua)}
.hero .actions{display:flex;gap:12px;margin-top:34px;flex-wrap:wrap}

/* ---------- STAT BAR ---------- */
.stats{background:var(--blue-900);color:#fff}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:34px 28px}
.stat{text-align:center}
.stat .n{font-family:var(--font-head);font-weight:900;font-size:clamp(30px,4vw,46px);line-height:1;letter-spacing:-.02em}
.stat .n .pop{color:var(--aqua)}
.stat .l{font-size:13px;color:rgba(255,255,255,.72);margin-top:7px}

/* ---------- SECTION ---------- */
section.block{padding:80px 0}
section.alt{background:linear-gradient(180deg,#fff,#F3F6FC)}
.sec-head{text-align:center;margin-bottom:42px}
.sec-head .kick{font-family:var(--font-head);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal)}
.sec-head h2{font-family:var(--font-head);font-weight:900;font-size:clamp(30px,4.6vw,50px);color:var(--deep-blue);letter-spacing:-.02em;margin-top:10px;line-height:1.05}
.sec-head p{color:var(--slate);font-size:16px;max-width:600px;margin:14px auto 0}
.sec-rule{width:64px;height:4px;border-radius:4px;background:var(--grad-rule);margin:16px auto 0}

/* ---------- SERVICE CARDS ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-2);transition:.18s ease}
.svc:hover{transform:translateY(-4px);box-shadow:var(--sh-3)}
.svc .ph{height:158px;background:var(--grad-hero);position:relative;overflow:hidden}
.svc .ph .g{position:absolute;inset:0;background:radial-gradient(220px 150px at 82% 8%,rgba(0,255,188,.32),transparent 60%)}
.svc .ph .ic{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.9)}
.svc .ph .tag{position:absolute;left:16px;bottom:14px;background:var(--aqua);color:var(--accent-ink);font-family:var(--font-head);font-weight:700;font-size:12px;padding:6px 13px;border-radius:var(--r-pill)}
.svc .body{padding:22px}
.svc .body h3{font-family:var(--font-head);font-weight:800;font-size:21px;color:var(--deep-blue);text-transform:none;margin-bottom:8px}
.svc .body p{font-size:14px;color:var(--slate);margin-bottom:14px}
.svc .body ul{list-style:none}
.svc .body li{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;color:#374063;padding:5px 0}
.svc .body li svg{color:var(--teal);flex:0 0 auto;margin-top:2px}

/* ---------- OTHER SERVICES (chips grid) ---------- */
.other-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.other{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px;transition:.16s;color:var(--ink)}
.other:hover{border-color:var(--deep-blue);box-shadow:var(--sh-2)}
.other .ic{width:40px;height:40px;border-radius:10px;background:var(--blue-50);color:var(--deep-blue);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.other .t{font-family:var(--font-head);font-weight:600;font-size:13.5px;line-height:1.25}

/* ---------- PROCESS ---------- */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.step{text-align:center;padding:0 18px;position:relative}
.step .dot{width:64px;height:64px;border-radius:50%;background:#fff;border:2px solid var(--blue-100);color:var(--deep-blue);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;position:relative;z-index:2}
.step.on .dot{background:var(--deep-blue);border-color:var(--deep-blue);color:#fff;box-shadow:var(--sh-blue)}
.step .n{position:absolute;top:-6px;right:calc(50% - 42px);width:24px;height:24px;border-radius:50%;background:var(--aqua);color:var(--accent-ink);font-family:var(--font-head);font-weight:800;font-size:12px;display:flex;align-items:center;justify-content:center;z-index:3}
.step h4{font-family:var(--font-head);font-weight:700;font-size:16px;color:var(--deep-blue);margin-bottom:6px}
.step p{font-size:13px;color:var(--slate)}
.proc .conn{position:absolute;top:32px;left:12.5%;right:12.5%;height:2px;background:repeating-linear-gradient(90deg,var(--blue-100) 0 8px,transparent 8px 16px);z-index:1}

/* ---------- WHY GRID ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.why{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:.16s}
.why:hover{box-shadow:var(--sh-2)}
.why .ic{width:52px;height:52px;border-radius:14px;background:var(--mint);color:var(--teal);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.why h4{font-family:var(--font-head);font-weight:800;font-size:18px;color:var(--deep-blue);margin-bottom:8px}
.why p{font-size:14px;color:var(--slate);line-height:1.55}

/* ---------- CTA BAND ---------- */
.cta-band{position:relative;overflow:hidden;border-radius:24px;background:var(--grad-hero);color:#fff;padding:50px;text-align:center}
.cta-band .glow{position:absolute;inset:0;background:radial-gradient(500px 280px at 82% 0,rgba(0,255,188,.26),transparent 60%)}
.cta-band .mk{position:absolute;right:-30px;bottom:-40px;width:200px;opacity:.12}
.cta-band h2{position:relative;color:#fff;font-family:var(--font-head);font-weight:900;font-size:clamp(26px,3.4vw,40px);line-height:1.08;letter-spacing:-.01em}
.cta-band p{position:relative;color:rgba(255,255,255,.8);margin:12px 0 24px;font-size:16px}
.cta-band .actions{position:relative;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- FOOTER ---------- */
.ftr{background:var(--blue-900);color:rgba(255,255,255,.78);padding:64px 0 30px}
.ftr .top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:36px}
.ftr .logo{height:34px;margin-bottom:18px}
.ftr p{font-size:13.5px;line-height:1.6;color:rgba(255,255,255,.7);max-width:340px}
.ftr h6{font-family:var(--font-head);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--aqua);margin-bottom:14px}
.ftr a{color:rgba(255,255,255,.78);font-size:13.5px;display:block;padding:4px 0}
.ftr a:hover{color:var(--aqua)}
.ftr .socials{display:flex;gap:10px;margin-top:16px}
.ftr .socials a{width:36px;height:36px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}
.ftr .socials a:hover{background:var(--aqua);color:var(--accent-ink)}
.ftr .rule{height:1px;background:rgba(255,255,255,.14);margin:34px 0 18px}
.ftr .fine{font-size:12px;color:rgba(255,255,255,.45)}

/* ---------- MODAL ---------- */
.overlay{position:fixed;inset:0;background:rgba(14,35,92,.55);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:90;padding:20px;animation:fade .2s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border-radius:22px;box-shadow:var(--sh-3);width:100%;max-width:440px;overflow:hidden;animation:rise .22s ease}
@keyframes rise{from{transform:translateY(14px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal .head{background:var(--grad-hero);color:#fff;padding:24px;position:relative;overflow:hidden}
.modal .head .glow{position:absolute;inset:0;background:radial-gradient(280px 160px at 88% 0,rgba(0,255,188,.28),transparent 60%)}
.modal .head .k{position:relative;font-family:var(--font-head);font-weight:600;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--aqua)}
.modal .head h3{position:relative;font-family:var(--font-head);font-weight:800;font-size:23px;margin-top:6px;color:#fff;text-transform:none}
.modal .head .x{position:absolute;top:18px;right:18px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;border:0;display:flex;align-items:center;justify-content:center}
.modal .head .x:hover{background:rgba(255,255,255,.3)}
.modal form{padding:24px}
.field-row{margin-bottom:14px}
.field-row label{display:block;font-size:12.5px;font-weight:600;color:var(--slate);margin-bottom:6px}
.field{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font-family:var(--font-body);font-size:14px;color:var(--ink);background:var(--paper);transition:.14s}
.field:focus{outline:0;border-color:var(--deep-blue);background:#fff;box-shadow:0 0 0 3px rgba(26,67,173,.1)}
.success{padding:42px 28px;text-align:center}
.success .ok{width:72px;height:72px;border-radius:50%;background:var(--mint);color:var(--teal);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.success h3{font-family:var(--font-head);font-weight:800;font-size:22px;color:var(--deep-blue);margin-bottom:8px;text-transform:none}
.success p{font-size:14px;color:var(--slate);line-height:1.55}

@media(max-width:920px){
  .svc-grid,.why-grid,.ftr .top{grid-template-columns:1fr 1fr}
  .other-grid{grid-template-columns:1fr 1fr}
  .proc{grid-template-columns:1fr 1fr;gap:30px 0}
  .proc .conn{display:none}
  .nav,.topbar .promo{display:none}
}
