:root{
  --bg:#070b14;
  --text:#eef2ff;
  --muted:#aab4cf;
  --line:rgba(255,255,255,.10);
  --line2:rgba(255,255,255,.08);
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius: 18px;
  --radius2: 22px;
  --accentA: rgba(110,231,255,.28);
  --accentB: rgba(167,139,250,.26);
  --ok: rgba(34,197,94,.95);
}

*{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;
  color:var(--text);
  background:
    radial-gradient(1200px 900px at 12% 0%, rgba(110,231,255,.14), transparent 60%),
    radial-gradient(900px 700px at 85% 12%, rgba(167,139,250,.18), transparent 58%),
    radial-gradient(800px 650px at 50% 100%, rgba(34,197,94,.08), transparent 55%),
    var(--bg);
}

a{color:inherit;text-decoration:none}
code{background:rgba(255,255,255,.07); padding:.12rem .35rem; border-radius:8px}
.container{width:min(1120px, 92%); margin:0 auto}

.m0{margin:0}
.mt8{margin-top:8px}
.small{font-size:.9rem}
.muted{color:var(--muted)}
.req{color: rgba(110,231,255,.95)}
.hidden{display:none !important}
.divider{height:1px; background: var(--line); margin:14px 0}

.header{
  position:sticky; top:0; z-index:80;
  backdrop-filter: blur(12px);
  background: rgba(7,11,20,.62);
  border-bottom:1px solid var(--line);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:14px; padding:12px 0;
}
.brand{display:flex; align-items:center; gap:10px}
.brand__mark{
  width:42px; height:42px; border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, var(--accentA), var(--accentB));
  border:1px solid var(--line);
  box-shadow: var(--shadow);
  font-weight:900;
}
.brand__name{font-weight:900}
.brand__tag{font-size:.82rem; color:var(--muted)}

.nav{display:flex; gap:16px; align-items:center}
.nav a{color:var(--muted); font-size:.95rem; padding:8px 10px; border-radius:12px}
.nav a:hover{color:var(--text); background: rgba(255,255,255,.04)}
.nav__pill{border:1px solid var(--line); background: rgba(255,255,255,.03)}
.header__actions{display:flex; gap:10px; align-items:center}

.nav__toggle{
  display:none;
  border:1px solid var(--line);
  background: rgba(255,255,255,.05);
  color:var(--text);
  border-radius:12px;
  padding:8px 10px;
}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:8px; padding:10px 14px;
  border-radius: 14px;
  border:1px solid var(--line);
  font-weight:750;
  cursor:pointer;
  user-select:none;
  background: rgba(255,255,255,.04);
}
.btn--primary{
  background: linear-gradient(135deg, var(--accentA), var(--accentB));
  box-shadow: var(--shadow);
}
.btn--ghost{background: rgba(255,255,255,.04)}
.btn:active{transform: translateY(1px)}

.hero{padding:58px 0 22px}
.hero__grid{
  display:grid; gap:22px;
  grid-template-columns: 1.05fr .95fr;
  align-items:stretch;
}
.pill{
  display:inline-flex; gap:10px; align-items:center;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  padding:8px 12px;
  color:var(--muted);
  width:fit-content;
}
.dot{
  width:9px; height:9px; border-radius:99px;
  background: rgba(34,197,94,.9);
  box-shadow: 0 0 0 6px rgba(34,197,94,.12);
}
.hero h1{font-size: clamp(2.0rem, 3.1vw, 3.05rem); margin:14px 0 10px; line-height:1.10}
.hero p{color:var(--muted); margin:0 0 18px; max-width:62ch}
.hero__cta{display:flex; gap:10px; flex-wrap:wrap}
.hero__stats{
  display:grid; gap:12px;
  grid-template-columns: repeat(3, 1fr);
  margin-top:18px;
}
.stat{
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding:12px 14px;
}
.stat__k{color:var(--muted); font-size:.85rem}
.stat__v{font-weight:900; margin-top:5px}

.hero__visual{display:flex; align-items:stretch}
.glassCard{
  width:100%;
  border:1px solid var(--line);
  border-radius: var(--radius2);
  padding:16px;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: var(--shadow);
}
.glassCard__head{display:flex; align-items:center; justify-content:space-between; gap:10px}
.glassCard__title{font-weight:900}
.badge{
  font-size:.78rem;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  padding:6px 10px;
  border-radius: 999px;
}

.timeline{margin-top:14px; display:grid; gap:12px}
.tl{display:flex; gap:12px; align-items:flex-start}
.tl__dot{
  width:12px; height:12px; border-radius:999px;
  margin-top:6px;
  background: rgba(255,255,255,.25);
  box-shadow: 0 0 0 6px rgba(255,255,255,.06);
}
.tl__dot.ok{background: var(--ok); box-shadow: 0 0 0 6px rgba(34,197,94,.13)}
.tl__content{flex:1}
.tl__top{display:flex; justify-content:space-between; gap:10px}
.tl__title{font-weight:850}
.tl__time{color:var(--muted); font-size:.85rem}
.tl__sub{color:var(--muted); font-size:.92rem; margin-top:4px}

.glassCard__foot{
  margin-top:14px;
  display:grid; gap:10px;
  grid-template-columns: repeat(2, 1fr);
}
.mini{
  border:1px solid var(--line2);
  background: rgba(0,0,0,.12);
  border-radius: 16px;
  padding:10px 12px;
}
.mini__k{color:var(--muted); font-size:.82rem}
.mini__v{font-weight:850; margin-top:3px}

.hero__strip{margin-top:18px}
.strip{
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: 999px;
  padding:10px 14px;
  display:flex; flex-wrap:wrap; align-items:center; gap:12px;
  justify-content:center;
}
.strip__item{color:var(--muted); font-weight:650; font-size:.92rem}
.strip__sep{width:6px; height:6px; border-radius:99px; background: rgba(255,255,255,.18)}

.section{padding:60px 0}
.section--alt{
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.section__head h2{margin:0 0 8px; font-size: clamp(1.55rem, 2.2vw, 2.2rem)}
.section__head p{margin:0; color:var(--muted); max-width:72ch}

.cards{margin-top:18px; display:grid; gap:14px; grid-template-columns: repeat(4, 1fr)}
.cards--3{grid-template-columns: repeat(3, 1fr)}
.card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius2);
  padding:16px;
}
.card--pad{padding:18px}
.feature .icon{font-size:1.3rem; margin-bottom:10px}
.card h3{margin:0 0 8px}
.card p{margin:0; color:var(--muted); line-height:1.45}

.steps{margin-top:18px; display:grid; gap:12px; grid-template-columns: repeat(3, 1fr)}
.step{
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius2);
  padding:16px;
  display:flex; gap:12px;
}
.step__num{
  width:36px; height:36px; border-radius:14px;
  display:grid; place-items:center;
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  font-weight:900;
}

.tableWrap{
  margin-top:18px;
  border:1px solid var(--line);
  border-radius: var(--radius2);
  overflow:hidden;
  background: rgba(255,255,255,.02);
}
.tableWrap--soft{margin-top:10px; background: rgba(0,0,0,.10)}
.table{width:100%; border-collapse:collapse}
.table th, .table td{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  text-align:left;
}
.table th{background: rgba(255,255,255,.04)}
.table tr:last-child td{border-bottom:none}
.table--mini th, .table--mini td{padding:10px 12px; font-size:.95rem}
.table tbody tr:hover{background: rgba(255,255,255,.03); cursor:pointer}

.fineprint{margin-top:12px; color:var(--muted); font-size:.92rem}

.grid2{margin-top:18px; display:grid; gap:14px; grid-template-columns: 1fr 1fr}
.form{display:grid; gap:12px}
label{display:grid; gap:6px; color:var(--muted); font-size:.95rem}
input, textarea, select{
  width:100%;
  padding:12px 12px;
  border-radius: 14px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.16);
  color:var(--text);
  outline:none;
}
input:focus, textarea:focus, select:focus{border-color: rgba(110,231,255,.55)}

.result__big{font-size:2.1rem; font-weight:950}
.result__sub{color:var(--muted); margin-top:4px}

.portal{margin-top:18px}
.dashHead{display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px}
.dashHead__actions{display:flex; gap:10px; flex-wrap:wrap}
.dashGrid{display:grid; gap:14px; grid-template-columns: 1.3fr .7fr}
.panel{
  border:1px solid var(--line);
  background: rgba(0,0,0,.10);
  border-radius: var(--radius2);
  padding:14px;
}
.panel__title{font-weight:950}
.panel__sub{margin-top:4px}

.searchRow{display:flex; gap:10px; align-items:center; margin-bottom:10px}
.searchRow input{flex:1}
.alert{min-height:18px}

.list{margin:10px 0 0; padding:0; list-style:none; display:grid; gap:8px}
.list li{
  border:1px solid var(--line2);
  background: rgba(255,255,255,.03);
  padding:10px 12px;
  border-radius: 14px;
}

.tag{
  display:inline-flex;
  padding:4px 8px;
  border-radius: 999px;
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  font-size:.78rem;
  color:var(--muted);
}

.modal{position:fixed; inset:0; z-index:100; display:grid; place-items:center}
.modal__backdrop{position:absolute; inset:0; background: rgba(0,0,0,.6)}
.modal__card{
  position:relative;
  width:min(640px, 92%);
  border:1px solid var(--line);
  background: rgba(10,14,26,.92);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
  padding:14px;
}
.modal__head{
  display:flex; justify-content:space-between; gap:12px; align-items:flex-start;
  border-bottom:1px solid var(--line);
  padding-bottom:10px;
}
.modal__title{font-weight:950}
.modal__body{padding-top:12px; color:var(--muted); line-height:1.55}

.footer{
  border-top:1px solid var(--line);
  padding:24px 0;
  background: rgba(0,0,0,.18);
}
.footer__grid{
  display:grid; gap:14px;
  grid-template-columns: 1.4fr 1fr 1fr;
  align-items:start;
}
.footer__brand{font-weight:950}
.footer__head{font-weight:850; margin-bottom:8px}
.footer__links{display:grid; gap:8px; color:var(--muted)}
.footer__links a:hover{color:var(--text)}
.footer__bottom{margin-top:12px}

.tabs{display:flex; gap:10px; margin-bottom:10px}
.tab{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  font-weight:800;
}
.tab.active{background: linear-gradient(135deg, var(--accentA), var(--accentB));}

.chatFab{
  position:fixed; right:18px; bottom:18px; z-index:120;
  border:1px solid var(--line);
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accentA), var(--accentB));
  box-shadow: var(--shadow);
  width:54px; height:54px;
  display:grid; place-items:center;
  cursor:pointer;
  font-size:1.2rem;
}
.chat{
  position:fixed; right:18px; bottom:86px; z-index:130;
  width:min(380px, calc(100vw - 36px));
  border:1px solid var(--line);
  border-radius: var(--radius2);
  background: rgba(10,14,26,.95);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.chat__head{
  padding:12px 12px;
  display:flex; justify-content:space-between; gap:10px; align-items:flex-start;
  border-bottom:1px solid var(--line);
}
.chat__title{font-weight:950}
.chat__sub{color:var(--muted); font-size:.82rem; margin-top:2px}
.chat__close{
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  color:var(--text);
  border-radius: 12px;
  padding:8px 10px;
  cursor:pointer;
}
.chat__body{
  height: 300px;
  padding:12px;
  overflow:auto;
  display:grid;
  gap:10px;
}
.bubble{
  max-width: 85%;
  padding:10px 12px;
  border:1px solid var(--line2);
  border-radius: 16px;
  background: rgba(255,255,255,.03);
}
.bubble.me{
  margin-left:auto;
  background: linear-gradient(135deg, rgba(110,231,255,.14), rgba(167,139,250,.12));
}
.bubble .meta{
  display:flex; justify-content:space-between; gap:10px;
  color:var(--muted); font-size:.78rem; margin-top:6px
}
.chat__form{
  border-top:1px solid var(--line);
  padding:10px;
  display:flex; gap:10px;
}
.chat__form input{flex:1}

@media (max-width: 1040px){
  .cards{grid-template-columns: repeat(2, 1fr)}
  .cards--3{grid-template-columns: repeat(2, 1fr)}
}
@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr}
  .steps{grid-template-columns: 1fr}
  .hero__stats{grid-template-columns: 1fr}
  .dashGrid{grid-template-columns: 1fr}
}
@media (max-width: 720px){
  .nav{display:none; position:absolute; top:64px; right:4%; left:4%;
    background: rgba(7,11,20,.95); border:1px solid var(--line);
    border-radius: 16px; padding:12px; flex-direction:column; align-items:stretch;
  }
  .nav a{padding:10px 12px; border-radius: 12px}
  .nav a:hover{background: rgba(255,255,255,.05)}
  .nav__toggle{display:inline-flex}
  .header__actions{display:none}
  .grid2{grid-template-columns: 1fr}
  .footer__grid{grid-template-columns: 1fr}
}
