:root{
  --bg:#060A12;
  --bg2:#0B1220;
  --txt:#EAF0FF;
  --muted:#AAB4D6;
  --line:rgba(255,255,255,.10);
  --glass:rgba(255,255,255,.06);
  --glass2:rgba(255,255,255,.10);
  --shadow: 0 30px 80px rgba(0,0,0,.45);
  --r:22px;
  --r2:28px;
  --primary:#ffffff;
  --accent1:#5B7CFF;
  --accent2:#22D3EE;
  --accent3:#D946EF;
  --ok:#34D399;
  --danger:#FB7185;
  --max:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: linear-gradient(180deg, var(--bg) 0%, #050814 100%);
  color:var(--txt);
  overflow-x:hidden;
}
a{color:inherit; text-decoration:none}
.container{max-width:var(--max); margin:0 auto; padding:0 18px}

.bg{position:fixed; inset:0; z-index:-1; pointer-events:none}
.blob{
  position:absolute; width:620px; height:620px; border-radius:999px;
  filter:blur(120px); opacity:.22;
}
.blob--1{top:-240px; left:50%; transform:translateX(-50%); background:var(--accent1)}
.blob--2{bottom:-260px; left:-220px; background:var(--accent2)}
.blob--3{bottom:-240px; right:-220px; background:var(--accent3)}
.grain{
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  opacity:.06;
  mix-blend-mode:overlay;
}

.topbar{
  position:sticky; top:0; z-index:30;
  background:rgba(6,10,18,.65);
  backdrop-filter: blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar__inner{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:12px 0;
}
.brand{display:flex; align-items:center; gap:10px}
.brand__logo{width:38px; height:38px; border-radius:14px; object-fit:contain; background:rgba(255,255,255,.05); border:1px solid var(--line)}
.brand__name{font-weight:700; letter-spacing:-.02em}
.brand__tag{font-size:12px; color:var(--muted)}

.nav{display:flex; gap:18px; font-size:14px; color:rgba(234,240,255,.86)}
.nav a{padding:8px 10px; border-radius:12px}
.nav a:hover{background:rgba(255,255,255,.06)}

.topbar__actions{display:flex; align-items:center; gap:10px}
.lang{
  display:flex; align-items:center; gap:8px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  border-radius:999px;
  padding:6px 10px;
}
.lang__label{font-size:12px; color:var(--muted)}
.lang__btn{
  border:0; cursor:pointer;
  background:transparent; color:rgba(234,240,255,.9);
  font-weight:700; font-size:12px;
  padding:5px 10px; border-radius:999px;
}
.lang__btn.active{background:#fff; color:#0b1020}

.burger{
  display:none; width:44px; height:44px;
  border:1px solid var(--line); background:rgba(255,255,255,.05);
  border-radius:14px; cursor:pointer;
}
.burger span{display:block; height:2px; background:rgba(255,255,255,.9); margin:7px 10px; border-radius:2px}

.mobileNav{
  display:none;
  border-top:1px solid var(--line);
  padding:12px 18px 16px;
}
.mobileNav a{
  display:block;
  padding:12px 10px;
  border-radius:14px;
  border:1px solid transparent;
  color:rgba(234,240,255,.90);
}
.mobileNav a:hover{border-color:var(--line); background:rgba(255,255,255,.05)}
.mobileLang{display:flex; gap:8px; padding-top:10px}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:16px;
  padding:11px 16px;
  font-size:14px;
  font-weight:800;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .08s ease, opacity .15s ease, background .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn--primary{
  background:var(--primary); color:#0A0F1E;
  box-shadow: 0 18px 50px rgba(255,255,255,.10);
}
.btn--primary:hover{opacity:.92}
.btn--ghost{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12);
  color:rgba(255,255,255,.95);
}
.btn--ghost:hover{background:rgba(255,255,255,.10)}
.btn--soft{
  background:transparent;
  border-color:rgba(255,255,255,.14);
  color:rgba(234,240,255,.86);
}
.btn--soft:hover{background:rgba(255,255,255,.05)}
.btn--full{width:100%}

.hero{padding:64px 0 40px}
.hero__grid{display:grid; gap:26px; grid-template-columns: 1.1fr .9fr; align-items:center}
.pill{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  border-radius:999px; padding:8px 12px;
  font-size:12px; color:rgba(234,240,255,.90);
}
.dot{width:8px; height:8px; border-radius:999px; background:var(--ok); box-shadow:0 0 0 6px rgba(52,211,153,.12)}
.hero__title{margin:14px 0 0; font-size:48px; letter-spacing:-.03em; line-height:1.05}
.hero__subtitle{margin:12px 0 0; font-size:22px; color:rgba(234,240,255,.92); letter-spacing:-.01em}
.hero__desc{margin:12px 0 0; color:var(--muted); line-height:1.7; max-width:54ch}
.hero__cta{margin-top:18px; display:flex; gap:10px; flex-wrap:wrap}

.hero__stats{margin-top:18px; display:grid; grid-template-columns:repeat(3,1fr); gap:10px}
.stat{
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  border-radius:18px; padding:12px;
}
.stat__k{font-size:12px; color:var(--muted)}
.stat__v{margin-top:4px; font-weight:800; font-size:13px; color:rgba(255,255,255,.95)}

.glass{
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  border-radius:var(--r2);
  box-shadow: var(--shadow);
}
.card{padding:18px}
.card__head{display:flex; align-items:center; justify-content:space-between}
.card__title{font-weight:900}
.badge{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  border-radius:999px;
  padding:6px 10px;
  font-size:12px;
  color:rgba(255,255,255,.88);
}

.metrics{margin-top:14px; display:grid; grid-template-columns:repeat(3,1fr); gap:10px}
.metric{
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  border-radius:18px;
  padding:12px;
}
.metric__k{font-size:12px; color:var(--muted)}
.metric__v{margin-top:4px; font-size:20px; font-weight:950; letter-spacing:-.02em}
.metric__d{margin-top:4px; font-size:12px; color:rgba(255,255,255,.80)}
.metric__d--neg{color:rgba(251,113,133,.95)}

.chart{margin-top:14px; border:1px solid var(--line); background:rgba(5,8,20,.50); border-radius:20px; padding:14px}
.chart__head{display:flex; justify-content:space-between; gap:12px}
.chart__title{font-weight:900}
.chart__meta{font-size:12px; color:var(--muted)}
.chart__bar{
  margin-top:12px; height:118px; border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(90deg, rgba(91,124,255,.22), rgba(34,211,238,.10), rgba(217,70,239,.10));
}
.chart__note{margin-top:10px; font-size:12px; color:var(--muted); line-height:1.5}

.hero__right{position:relative}
.mini{
  position:absolute; left:-16px; bottom:-16px;
  padding:14px 16px;
  width:180px;
}
.mini__k{font-size:12px; color:var(--muted)}
.mini__v{margin-top:6px; font-size:20px; font-weight:950}

.section{padding:56px 0}
.section--dark{
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px; font-weight:900; letter-spacing:.12em;
  color:rgba(234,240,255,.88);
}
.eyebrow span:first-child{width:10px; height:10px; border-radius:999px; background:rgba(91,124,255,.9); box-shadow:0 0 0 6px rgba(91,124,255,.18)}
.h2{margin:14px 0 0; font-size:34px; letter-spacing:-.03em}
.lead{margin:10px 0 0; color:var(--muted); line-height:1.7; max-width:72ch}

.grid3{margin-top:18px; display:grid; gap:14px; grid-template-columns:repeat(3,1fr)}
.box{padding:18px}
.box h3{margin:0; font-size:18px; letter-spacing:-.01em}
.box p{margin:10px 0 0; color:var(--muted); line-height:1.7}
.list{margin:12px 0 0; padding:0; list-style:none}
.list li{display:flex; gap:10px; margin:10px 0; color:rgba(234,240,255,.86); line-height:1.6}
.list li::before{
  content:"";
  width:8px; height:8px; border-radius:999px;
  background:rgba(34,211,238,.85);
  margin-top:8px;
  flex:0 0 auto;
}

.panel{
  border:1px solid rgba(255,255,255,.10);
  background:rgba(5,8,20,.55);
  border-radius:var(--r2);
  padding:18px;
}
.panel__n{
  width:44px; height:44px; border-radius:16px;
  background:#fff; color:#0A0F1E;
  display:grid; place-items:center;
  font-weight:950;
}
.panel h3{margin:12px 0 0}

.pricing{margin-top:20px; display:grid; gap:14px; grid-template-columns:repeat(3,1fr)}
.priceCard{padding:18px}
.priceCard__top h3{margin:0}
.price{margin-top:10px; display:flex; align-items:baseline; gap:8px}
.price__value{font-size:30px; font-weight:950; letter-spacing:-.02em}
.price__per{font-size:13px; color:var(--muted)}
.priceCard__top p{margin:10px 0 0; color:var(--muted); line-height:1.7}
.priceCard--featured{
  background:#fff; color:#0A0F1E;
  border-radius:var(--r2);
  padding:18px;
  box-shadow:0 30px 90px rgba(255,255,255,.10);
  position:relative;
}
.priceCard--featured .list li{color:rgba(10,15,30,.85)}
.priceCard--featured .price__per, .priceCard--featured p{color:rgba(10,15,30,.65)}
.priceCard--featured .btn--primary{background:#0A0F1E; color:#fff}
.priceCard--featured .btn--ghost{background:rgba(10,15,30,.06); border-color:rgba(10,15,30,.14); color:#0A0F1E}
.ribbon{
  position:absolute; top:14px; right:14px;
  background:#0A0F1E; color:#fff;
  padding:6px 10px; border-radius:999px;
  font-size:12px; font-weight:900;
}

.booking{margin-top:18px; padding:18px}
.booking__row{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}
.input{
  width:100%;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(5,8,20,.55);
  color:rgba(234,240,255,.92);
  padding:12px 14px;
  border-radius:16px;
  outline:none;
}
.input:focus{border-color:rgba(255,255,255,.26)}
.booking__row .input{max-width:420px}
.muted{color:var(--muted); font-size:13px}
.faq{margin-top:18px; display:grid; gap:10px}
details{padding:16px 18px; border-radius:var(--r2); border:1px solid rgba(255,255,255,.10); background:rgba(255,255,255,.05)}
summary{cursor:pointer; list-style:none; font-weight:950; font-size:16px}
details p{margin:10px 0 0; color:var(--muted); line-height:1.7}

.contact{margin-top:18px; display:grid; gap:14px; grid-template-columns:1.2fr .8fr}
.form{padding:18px}
.form__grid{display:grid; gap:12px; grid-template-columns:repeat(2,1fr)}
label{font-size:13px; font-weight:900; color:rgba(234,240,255,.90)}
textarea.input{resize:vertical}
.check{display:flex; gap:10px; align-items:flex-start; margin:10px 0 0; color:var(--muted); font-size:13px}
.check input{margin-top:4px}

.aside{padding:18px}
.aside h3{margin:0}
.infoRow{
  margin-top:10px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.05);
  border-radius:16px;
  padding:12px 14px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
}
.aside__cta{display:flex; gap:10px; margin-top:14px; flex-wrap:wrap}

.footer{
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(6,10,18,.7);
}
.footer__inner{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:18px 0}
.footer__brand{display:flex; align-items:center; gap:10px}
.footer__brand img{width:38px; height:38px; border-radius:14px; border:1px solid var(--line); background:rgba(255,255,255,.05); object-fit:contain}
.footer__name{font-weight:950}
.footer__tag{font-size:13px; color:var(--muted)}
.footer__actions{display:flex; gap:10px; flex-wrap:wrap}
.footer__bottom{padding:0 0 18px; font-size:12px; color:var(--muted)}

.hp{position:absolute; left:-9999px; top:-9999px; opacity:0; height:0; width:0}

@media (max-width: 980px){
  .hero__grid{grid-template-columns:1fr}
  .hero__stats{grid-template-columns:1fr}
  .metrics{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr}
  .pricing{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .form__grid{grid-template-columns:1fr}
  .nav{display:none}
  .burger{display:block}
  .topbar__actions{display:none}
  .mobileNav.open{display:block}
  .mini{display:none}
}
