/* ── RESET ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img,svg{max-width:100%;display:block}
ul{list-style:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}

/* ── TOKENS ─────────────────────────────────────────────────────── */
:root{
  --bg:#07070f;--bg2:#0d0d1c;--bg3:#13132a;
  --border:rgba(66,70,212,.14);--border2:rgba(66,70,212,.28);
  --text:#e4e4f2;--muted:#6a6a8e;
  --accent:#4246d4;--accent2:#6468f8;--accent3:rgba(66,70,212,.12);
  --nav-h:80px;
  --ff-h:'Syne',sans-serif;--ff-b:'DM Sans',sans-serif;
  --shadow:0 24px 64px rgba(0,0,10,.55);
  --r:14px;--r2:20px;--r3:24px;
  --container:1240px;--gap:clamp(16px,3vw,28px);
}
[data-theme="light"]{
  --bg:#f0f0f8;--bg2:#fff;--bg3:#eaeaf4;
  --border:rgba(66,70,212,.11);--border2:rgba(66,70,212,.22);
  --text:#0f0f1e;--muted:#7070a0;--accent3:rgba(66,70,212,.08);
  --shadow:0 24px 64px rgba(66,70,212,.1);
}

/* ── BASE ────────────────────────────────────────────────────────── */
/* cursor:none is applied via JS only once the custom cursor is mounted */
body{background:var(--bg);color:var(--text);font-family:var(--ff-b);line-height:1.65;overflow-x:hidden;transition:background .3s,color .3s}
body.loaded #preloader{opacity:0;pointer-events:none;transition:opacity .4s}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}

/* ── SKIP LINK ────────────────────────────────────────────────────── */
.skip-link{position:absolute;top:-100%;left:0;padding:12px 20px;background:var(--accent);color:#fff;font-weight:700;font-size:.9rem;z-index:99999;border-radius:0 0 8px 0;transition:top .2s;text-decoration:none}
.skip-link:focus{top:0}

/* ── SCROLL PROGRESS ─────────────────────────────────────────────── */
#prog-bar{position:fixed;top:0;left:0;height:3px;background:var(--accent);z-index:9999;width:0%;pointer-events:none;transition:width .1s linear}

/* ── CUSTOM CURSOR ───────────────────────────────────────────────── */
#cdot{position:fixed;border-radius:50%;pointer-events:none;z-index:99999;width:8px;height:8px;background:var(--accent);transform:translate(-50%,-50%);transition:width .15s,height .15s,background .15s}
#cring{display:none}
body.ch #cdot{width:12px;height:12px;background:var(--accent2)}
@media(hover:none){#cdot{display:none}}

/* ── PRELOADER ───────────────────────────────────────────────────── */
#preloader{position:fixed;inset:0;z-index:9998;background:var(--bg);display:flex;align-items:center;justify-content:center;opacity:1}
#preloader svg{opacity:.55}

/* ── INTRO (first-visit curtain) ─────────────────────────────────── */
#intro{position:fixed;inset:0;z-index:9997;pointer-events:none;overflow:hidden}
.intro-panel{position:absolute;left:0;right:0;background:#07070f;pointer-events:none}
#intro.done{display:none}
.intro-bar{position:absolute;right:0;top:0;bottom:0;pointer-events:none;width:clamp(4px,1vw,7px);background:var(--accent);transform-origin:bottom;z-index:2}
.intro-name-wrap{position:absolute;top:50%;left:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:3;display:flex;align-items:center;white-space:nowrap}
.intro-name{font-family:'Syne',sans-serif;font-size:clamp(4rem,14vw,10rem);font-weight:800;color:#d8d8e8;letter-spacing:-.02em;line-height:1;opacity:0}
.intro-cursor{display:inline-block;width:clamp(3px,0.5vw,5px);height:.82em;background:var(--accent);margin-left:.12em;border-radius:2px;vertical-align:middle;animation:iblink .65s step-end infinite}
@keyframes iblink{0%,100%{opacity:1}50%{opacity:0}}

/* ── LAYOUT ──────────────────────────────────────────────────────── */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gap)}
.section{padding:clamp(64px,10vw,110px) 0}
.section.bg2{background:var(--bg2)}

/* ── SECTION LABELS ──────────────────────────────────────────────── */
.sec-lbl{display:inline-flex;align-items:center;gap:10px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin-bottom:14px}
.sec-lbl::before{content:"";width:26px;height:2px;background:var(--accent);flex-shrink:0}
.sec-title{font-family:var(--ff-h);font-size:clamp(1.75rem,3.2vw,2.8rem);font-weight:800;line-height:1.12;color:var(--text)}
.sec-title span{color:var(--accent)}
.sec-center{text-align:center;max-width:560px;margin-left:auto;margin-right:auto}

/* ── BUTTONS ──────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-weight:600;font-size:.88rem;cursor:pointer;border:none;transition:all .25s;white-space:nowrap;font-family:var(--ff-b);line-height:1}
.btn-p{background:var(--accent);color:#fff}
.btn-p:hover{background:var(--accent2);transform:translateY(-3px);box-shadow:0 12px 32px rgba(66,70,212,.4)}
.btn-o{background:transparent;color:var(--text);border:1.5px solid var(--border2)}
.btn-o:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--accent)}
.btn-white:hover{background:rgba(255,255,255,.9);transform:translateY(-2px)}
.arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(5px)}

/* ── HEADER ──────────────────────────────────────────────────────── */
#hdr{position:fixed;top:0;left:0;width:100%;z-index:900;height:var(--nav-h);display:flex;align-items:center;transition:all .3s}
#hdr.scrolled{height:66px;background:rgba(7,7,15,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border)}
[data-theme="light"] #hdr.scrolled{background:rgba(255,255,255,.94)}
.hni{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{display:flex;align-items:center;flex-shrink:0;color:var(--text);transition:opacity .2s}
.logo:hover{opacity:.8}
.mnav{display:flex;align-items:center;gap:2px}
.nitem{position:relative}
.nlnk{display:flex;align-items:center;gap:5px;padding:7px 12px;border-radius:7px;font-size:.87rem;font-weight:500;color:var(--muted);transition:color .2s,background .2s;white-space:nowrap}
.nlnk:hover,.nlnk.active{color:var(--text);background:var(--bg3)}
.hna{display:flex;align-items:center;gap:10px}
.lang-btn{padding:6px 12px;border-radius:6px;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:.78rem;font-weight:700;font-family:var(--ff-h);transition:all .2s;letter-spacing:.06em}
.lang-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.ibtn{width:38px;height:38px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text);font-size:.9rem;transition:all .2s}
.ibtn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.hbg{display:none;width:38px;height:38px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hbg span{display:block;width:19px;height:2px;background:var(--text);transition:all .3s;transform-origin:center}
.hbg.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hbg.open span:nth-child(2){opacity:0}
.hbg.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── MOBILE NAV ───────────────────────────────────────────────────── */
#mnv{position:fixed;inset:0;z-index:899;background:var(--bg2);transform:translateX(100%);transition:transform .36s cubic-bezier(.4,0,.2,1);padding:calc(var(--nav-h) + 28px) var(--gap) 40px;overflow-y:auto}
#mnv.open{transform:translateX(0)}
#mnv a{display:block;padding:16px 0;font-family:var(--ff-h);font-size:1.15rem;font-weight:700;color:var(--text);border-bottom:1px solid var(--border);transition:color .2s,padding-left .2s}
#mnv a:hover{color:var(--accent);padding-left:10px}

/* ── PAGE HERO ────────────────────────────────────────────────────── */
.page-hero{padding:calc(var(--nav-h) + 60px) 0 60px;background:var(--bg2);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.ph-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.45}
.ph-glow{position:absolute;top:-30%;left:25%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(66,70,212,.15) 0%,transparent 70%);pointer-events:none}
.ph-content{position:relative;z-index:1}
.ph-title{font-family:var(--ff-h);font-size:clamp(2.2rem,6vw,4rem);font-weight:800;margin-bottom:14px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--muted);flex-wrap:wrap}
.breadcrumb a{color:var(--text);transition:color .2s}.breadcrumb a:hover{color:var(--accent)}
.breadcrumb-sep{color:var(--accent);font-size:.6rem}

/* ── MARQUEE ──────────────────────────────────────────────────────── */
.mwrap{padding:16px 0;overflow:hidden}
.mwrap.accent{background:var(--accent)}
.mwrap.dark{background:transparent;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.mwrap.rev .mtrack{animation-direction:reverse}
.mtrack{display:flex;width:max-content;animation:mq 30s linear infinite}
.mi{display:flex;align-items:center;gap:20px;padding:0 20px;font-family:var(--ff-h);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
.mwrap.accent .mi{color:#fff}
.mwrap.dark .mi{color:var(--muted)}.mwrap.dark .mi:nth-child(odd){color:var(--accent)}
.mi::after{content:"✦";font-size:.5rem;opacity:.55}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SERVICE CARDS ────────────────────────────────────────────────── */
.sgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(14px,2vw,22px)}
.scard{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column}
.scard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--border2)}
.scard-img{width:100%;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative;overflow:hidden;flex-shrink:0;transition:transform .5s}
.scard:hover .scard-img{transform:scale(1.06)}
.scard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,15,.6),transparent 50%)}
.scard-body{padding:clamp(16px,3vw,26px);display:flex;flex-direction:column;flex:1}
.scard-tag{font-size:.68rem;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:7px;display:block}
.scard-title{font-family:var(--ff-h);font-size:1.1rem;font-weight:700;margin-bottom:9px;line-height:1.25}
.scard-desc{font-size:.85rem;color:var(--muted);line-height:1.65;margin-bottom:18px;flex:1}
.scard-lnk{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;color:var(--accent);transition:gap .2s;margin-top:auto}
.scard-lnk:hover{gap:10px}

/* ── PRICING ──────────────────────────────────────────────────────── */
.prc-toggle{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:44px;flex-wrap:wrap}
/* Pricing switch now uses role=switch button — cursor set by JS */
.prc-track{width:48px;height:26px;background:var(--accent);border-radius:13px;position:relative;transition:background .2s;flex-shrink:0;border:none;padding:0}
.prc-thumb{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .25s;pointer-events:none}
.prc-track[aria-checked="true"] .prc-thumb{transform:translateX(22px)}
.prc-lbl{font-family:var(--ff-h);font-size:.88rem;font-weight:600;color:var(--muted);transition:color .2s}
.prc-lbl.on{color:var(--text)}
.prc-badge{font-size:.68rem;background:var(--accent3);color:var(--accent);padding:2px 8px;border-radius:50px;font-weight:700}
.prc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:clamp(14px,2vw,22px);align-items:start}
.prccard{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r2);padding:clamp(24px,4vw,36px) clamp(20px,3vw,30px);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;display:flex;flex-direction:column}
.prccard:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--border2)}
.prccard.featured{background:var(--accent);border-color:transparent}
.prc-plan{font-family:var(--ff-h);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--accent);margin-bottom:5px}
.prccard.featured .prc-plan{color:rgba(255,255,255,.75)}
.prc-price-row{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}
.prc-price{font-family:var(--ff-h);font-size:clamp(2.4rem,5vw,3.2rem);font-weight:800;color:var(--text);line-height:1}
.prccard.featured .prc-price{color:#fff}
.prc-price sup{font-size:1.1rem;font-weight:700;vertical-align:super}
.prc-price sub{font-size:.9rem;font-weight:400;color:var(--muted)}
.prccard.featured .prc-price sub{color:rgba(255,255,255,.65)}
.prc-tag{font-size:.82rem;color:var(--muted);margin-bottom:26px;line-height:1.4}
.prccard.featured .prc-tag{color:rgba(255,255,255,.7)}
.prc-div{height:1px;background:var(--border);margin-bottom:22px}
.prccard.featured .prc-div{background:rgba(255,255,255,.2)}
.prc-feats{display:flex;flex-direction:column;gap:9px;margin-bottom:28px;flex:1}
.prc-feat{display:flex;align-items:flex-start;gap:10px;font-size:.85rem;color:var(--text);line-height:1.45}
.prccard.featured .prc-feat{color:rgba(255,255,255,.92)}
.prc-chk{width:20px;height:20px;border-radius:50%;background:var(--accent3);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:.58rem;flex-shrink:0;margin-top:1px}
.prccard.featured .prc-chk{background:rgba(255,255,255,.2);color:#fff}
.prc-popular{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.22);color:#fff;font-size:.65rem;padding:3px 10px;border-radius:50px;font-weight:700;font-family:var(--ff-h);letter-spacing:.06em}

/* ── FAQ ──────────────────────────────────────────────────────────── */
.flist{display:flex;flex-direction:column;gap:10px}
.fitem{border:1px solid var(--border);border-radius:var(--r);background:var(--bg2);overflow:hidden;transition:border-color .25s}
.fitem.open{border-color:var(--border2)}
.fq{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;gap:14px;font-family:var(--ff-h);font-size:.95rem;font-weight:600;user-select:none;transition:color .2s;width:100%;background:none;border:none;color:var(--text);text-align:left}
.fitem.open .fq{color:var(--accent)}
.fico{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.1rem;font-weight:300;transition:transform .32s,background .22s,border-color .22s}
.fitem.open .fico{transform:rotate(45deg);background:var(--accent);color:#fff;border-color:var(--accent)}
.fa{max-height:0;overflow:hidden;font-size:.87rem;color:var(--muted);line-height:1.72;transition:max-height .38s cubic-bezier(.4,0,.2,1),padding .38s;padding:0 22px}
.fitem.open .fa{max-height:300px;padding:0 22px 20px}

/* ── FOOTER ───────────────────────────────────────────────────────── */
footer{background:var(--bg2);border-top:1px solid var(--border);padding-top:70px}
.fgrid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.4fr;gap:clamp(24px,4vw,50px)}
.flogo{margin-bottom:0}
.fdesc{font-size:.86rem;color:var(--muted);line-height:1.72;max-width:280px;margin:14px 0 20px}
.srow{display:flex;gap:8px;flex-wrap:wrap}
.sbtn{width:34px;height:34px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--muted);transition:all .2s;flex-shrink:0}
.sbtn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.fh{font-family:var(--ff-h);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.13em;color:var(--text);margin-bottom:16px}
.flnks{display:flex;flex-direction:column;gap:8px}
.flnks a{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:6px;transition:color .2s,gap .2s}
.flnks a::before{content:"→";font-size:.7rem;color:var(--border);transition:color .2s}
.flnks a:hover{color:var(--accent);gap:10px}.flnks a:hover::before{color:var(--accent)}
.cti{display:flex;gap:10px;align-items:flex-start;margin-bottom:10px;font-size:.85rem;color:var(--muted);line-height:1.5}
.ctio{color:var(--accent);flex-shrink:0;margin-top:1px;font-size:.9rem}
.ft-hours{font-size:.77rem;color:var(--muted);margin-bottom:18px;padding:9px 12px;background:var(--bg3);border-radius:9px;border:1px solid var(--border);line-height:1.6}
.ft-hours strong{color:var(--text);display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}
.nlform{display:flex;gap:7px;margin-top:12px}
.nlinp{flex:1;min-width:0;background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:10px 13px;font-size:.85rem;color:var(--text);outline:none;transition:border-color .2s;font-family:var(--ff-b)}
.nlinp:focus{border-color:var(--accent)}
.nlinp::placeholder{color:var(--muted)}
.nlbtn{background:var(--accent);border:none;color:#fff;border-radius:9px;padding:10px 16px;font-size:.82rem;font-weight:600;transition:background .2s}
.nlbtn:hover{background:var(--accent2)}
.nl-consent{display:flex;align-items:flex-start;gap:7px;margin-top:9px;font-size:.76rem;color:var(--muted);line-height:1.5}
.nl-consent input[type=checkbox]{width:13px;height:13px;accent-color:var(--accent);flex-shrink:0;margin-top:2px}
.fbot-wrap{border-top:1px solid var(--border);margin-top:48px}
.fbot{padding:18px 0;display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--muted);flex-wrap:wrap;gap:10px}
.fbls{display:flex;gap:18px;flex-wrap:wrap}.fbls a:hover{color:var(--accent)}

/* ── BTT ──────────────────────────────────────────────────────────── */
#btt{position:fixed;bottom:24px;right:24px;z-index:800;width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;font-size:.95rem;box-shadow:0 8px 24px rgba(66,70,212,.4);opacity:0;pointer-events:none;transform:translateY(12px);transition:all .3s}
#btt.vis{opacity:1;pointer-events:all;transform:translateY(0)}
#btt:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(66,70,212,.5)}

/* ── VIDEO MODAL ──────────────────────────────────────────────────── */
#vid-modal{position:fixed;inset:0;z-index:9990;background:rgba(0,0,10,.92);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(8px);padding:var(--gap)}
#vid-modal.open{opacity:1;pointer-events:all}
.vid-inner{position:relative;width:100%;max-width:860px;aspect-ratio:16/9;border-radius:16px;overflow:hidden;background:#000}
.vid-inner iframe{width:100%;height:100%;border:none}
.vid-close{position:absolute;top:-46px;right:0;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .2s}
.vid-close:hover{background:var(--accent)}

/* ── FORM SHARED ─────────────────────────────────────────────────── */
.field-error{font-size:.76rem;color:#E24B4A;margin-top:4px;display:block}
input[aria-invalid="true"],
textarea[aria-invalid="true"],
select[aria-invalid="true"]{border-color:#E24B4A !important}


/* ── CONTACT ICONS ────────────────────────────────────────────────── */
.ctico{color:var(--accent);flex-shrink:0;margin-top:1px;width:16px;height:16px}
.ctio{display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* ── RESPONSIVE ───────────────────────────────────────────────────── */
@media(max-width:1200px){
  .fgrid{grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,36px)}
  .fcol-brand{grid-column:1 / -1}
  .fdesc{max-width:100%}
}
@media(max-width:1024px){
  :root{--nav-h:72px}
  .mnav{display:none}
  .hbg{display:flex}
}
@media(max-width:768px){
  :root{--nav-h:64px}
  .hna .btn-p{display:none}
  .fgrid{grid-template-columns:1fr}
  .fbot{flex-direction:column;text-align:center;align-items:center}
  .prc-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .lang-btn{font-size:.7rem;padding:5px 9px}
  .ibtn{width:34px;height:34px}
}

/* ── REDUCED MOTION ──────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  .mtrack{animation-play-state:paused}
  .scard,.prccard,.fitem,.step-card,.cinfo-card{transition:none}
  .scard:hover,.prccard:hover{transform:none}
  #intro{display:none}
}
