:root{
  --bg:#07070a;
  --bg2:#0c0c10;
  --card:rgba(255,255,255,.06);
  --stroke:rgba(255,255,255,.10);
  --text:#f5f6fb;
  --muted:rgba(245,246,251,.72);
  --red:#ff1b2d;
  --red2:#b30012;
  --shadow: 0 26px 90px rgba(0,0,0,.70);
  --r1:16px;
  --r2:24px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background: radial-gradient(900px 520px at 70% 10%, rgba(255,27,45,.18), transparent 60%),
              radial-gradient(900px 520px at 20% 80%, rgba(255,27,45,.10), transparent 60%),
              linear-gradient(180deg,var(--bg),var(--bg2));
  color:var(--text);
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
.container{max-width:1120px;margin:0 auto;padding:0 18px}

/* Noise overlay */
.bg-noise{
  position:fixed;inset:0;pointer-events:none;z-index:-3;opacity:.08;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.22'/%3E%3C/svg%3E");
}
.bg-glow{
  position:fixed;inset:-240px;pointer-events:none;z-index:-4;opacity:.9;
  background:
    radial-gradient(520px 520px at 20% 20%, rgba(255,27,45,.18), transparent 62%),
    radial-gradient(740px 740px at 80% 10%, rgba(255,27,45,.22), transparent 62%),
    radial-gradient(900px 900px at 50% 82%, rgba(255,27,45,.12), transparent 62%);
  filter: blur(18px);
}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px;
  transition: background .25s ease, border-color .25s ease, box-shadow .25s ease;
  border-bottom:1px solid rgba(255,255,255,.06);
  background: rgba(7,7,10,.20);
  backdrop-filter: blur(12px);
}
.nav.scrolled{
  background: rgba(0,0,0,.72);
  border-color: rgba(255,255,255,.10);
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
}
.brand{display:flex;align-items:center;gap:12px}
.logo{height:42px;width:auto;display:block;filter: drop-shadow(0 14px 24px rgba(0,0,0,.55))}
.logo.small{height:34px}

.nav-links{
  display:flex;gap:16px;
  font-weight:800;
  color: rgba(245,246,251,.82);
}
.nav-links a{padding:10px 10px;border-radius:12px}
.nav-links a:hover{background:rgba(255,255,255,.06);color:var(--text)}

.nav-actions{display:flex;align-items:center;gap:10px}
.pill{
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  font-weight:900;font-size:13px;
}

.btn{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:12px 14px;border-radius:14px;
  font-weight:900;
  display:inline-flex;align-items:center;justify-content:center;
  gap:10px;cursor:pointer;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, filter .15s ease, box-shadow .2s ease;
}
.btn:hover{transform: translateY(-1px); background:rgba(255,255,255,.07); box-shadow: var(--shadow); border-color: rgba(255,255,255,.22)}
.btn:active{transform: translateY(0)}
.btn-red{
  border-color: rgba(255,27,45,.55);
  background: linear-gradient(135deg, rgba(255,27,45,1), rgba(179,0,18,.90));
}
.btn-ghost{background:rgba(255,255,255,.02)}
.w100{width:100%}

/* Burger */
.burger{display:none;width:44px;height:44px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);cursor:pointer}
.burger span{display:block;width:18px;height:2px;background:rgba(255,255,255,.9);margin:5px auto;border-radius:10px}

/* Drawer */
.drawer{position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.65);backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .2s ease}
.drawer.open{opacity:1;pointer-events:auto}
.drawer-card{
  position:absolute;right:14px;top:14px;width:min(92vw,360px);
  border-radius:22px;background:rgba(10,10,14,.92);
  border:1px solid rgba(255,255,255,.14);box-shadow:var(--shadow);padding:14px;
}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:8px 8px 12px}
.drawer-title{font-weight:900}
.drawer-close{width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04);color:var(--text);cursor:pointer}
.drawer-link{
  display:block;padding:12px;border-radius:14px;margin:6px 0;
  border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);
  font-weight:900;color:rgba(245,246,251,.92);
}
.drawer-link:hover{background:rgba(255,255,255,.06)}
.drawer-cta{margin-top:10px;display:grid;gap:10px}

/* Floating bar */
.floatbar{
  position:fixed;right:16px;bottom:16px;z-index:60;
  display:flex;flex-direction:column;gap:10px;
}
.floatbtn{
  width:52px;height:52px;border-radius:18px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.45);
  display:grid;place-items:center;
  font-weight:900;cursor:pointer;color:var(--text);
  backdrop-filter: blur(10px);
}
.floatbtn.red{
  border-color: rgba(255,27,45,.50);
  background: linear-gradient(135deg, rgba(255,27,45,1), rgba(179,0,18,.90));
}

/* HERO */
.hero{min-height:100vh;display:grid;place-items:center;padding:92px 0 36px;position:relative}
.hero-media{
  position:absolute;inset:0;
  background-image:
    radial-gradient(1000px 520px at 70% 20%, rgba(255,27,45,.22), transparent 60%),
    url("https://images.unsplash.com/photo-1542362567-b07e54358753?q=80&w=2000&auto=format&fit=crop");
  background-size: cover;
  background-position:center;
  filter: saturate(1.05) contrast(1.05);
}
.hero-overlay{
  position:absolute;inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.55), rgba(0,0,0,.85));
}
.hero-grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:18px;
  align-items:start;
}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.28);
  color: rgba(245,246,251,.80);
  font-weight:900;
}
.kdot{width:10px;height:10px;border-radius:999px;background:var(--red);box-shadow:0 0 0 7px rgba(255,27,45,.12)}

h1{
  margin:16px 0 10px;
  font-size: clamp(34px, 4.2vw, 58px);
  line-height: 1.02;
  letter-spacing:-1.2px;
}
.accent{
  background: linear-gradient(135deg, rgba(255,27,45,1), rgba(179,0,18,1));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.lead{
  color: rgba(245,246,251,.72);
  font-size: 16px;
  line-height: 1.6;
  max-width: 62ch;
}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}

.trust{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
  margin-top:18px;
}
.trust-item{
  display:flex;gap:10px;align-items:center;
  padding:14px;border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.28);
}
.trust-ic{
  width:40px;height:40px;border-radius:16px;
  display:grid;place-items:center;
  background: rgba(255,27,45,.12);
  border:1px solid rgba(255,27,45,.22);
}
.trust-title{font-weight:900}
.trust-sub{color:rgba(245,246,251,.62);font-weight:800;font-size:12px;margin-top:2px}
.note{margin-top:14px;color:rgba(245,246,251,.52);font-size:12px;font-weight:700}

.panel{
  border-radius:24px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.34);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.panel-head{
  display:flex;align-items:center;gap:10px;
  padding:16px;border-bottom:1px solid rgba(255,255,255,.10);
  background: radial-gradient(780px 260px at 20% 10%, rgba(255,27,45,.22), transparent 60%), rgba(255,255,255,.02);
}
.panel-title{font-weight:900}
.panel-chip{
  margin-left:auto;
  padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,27,45,.35);
  background: rgba(255,27,45,.14);
  font-weight:900;font-size:12px;
}
.panel-body{padding:16px;display:grid;gap:10px}
.mini-prices{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.mini-price{
  padding:12px;border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.mp-name{font-weight:900;color:rgba(245,246,251,.86)}
.mp-val{margin-top:6px;font-weight:900;color:var(--red)}
.panel-foot{margin-top:6px;color:rgba(245,246,251,.62);font-weight:800;font-size:12px}

/* Sections */
.section{padding:72px 0}
.section-dark{
  background: rgba(0,0,0,.26);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.section-head h2{margin:0;font-size: clamp(26px, 3vw, 40px);letter-spacing:-.8px}
.section-head p{margin:10px 0 0;color:rgba(245,246,251,.70);line-height:1.6;max-width:80ch}

.grid4{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
}
.card{
  padding:18px;border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  transition: transform .2s ease, border-color .2s ease, background .2s ease;
}
.card:hover{transform: translateY(-4px);border-color: rgba(255,27,45,.35);background: rgba(255,255,255,.05)}
.ic{
  width:44px;height:44px;border-radius:18px;
  display:grid;place-items:center;
  background: rgba(255,27,45,.10);
  border:1px solid rgba(255,27,45,.22);
  font-size:20px;
}
.card h3{margin:12px 0 8px;font-size:16px}
.card p{margin:0;color:rgba(245,246,251,.70);line-height:1.55}
.card strong{color:var(--text)}

.pricing-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.pricecard{
  padding:18px;border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  display:grid;gap:10px;
}
.pc-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.pc-name{font-weight:900}
.pc-price{font-weight:900;color:var(--red);font-size:22px}
.pc-sub{color:rgba(245,246,251,.66);font-weight:700;font-size:13px}
.legal{margin-top:14px;color:rgba(245,246,251,.56);font-size:12px;font-weight:800}
.legal.tiny{margin-top:10px}

.steps{margin-top:18px;display:grid;gap:10px}
.step{
  display:flex;gap:14px;align-items:flex-start;
  padding:16px;border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.step-n{
  width:46px;height:46px;border-radius:18px;
  display:grid;place-items:center;font-weight:900;
  border:1px solid rgba(255,27,45,.22);
  background: rgba(255,27,45,.08);
}
.step-t{font-weight:900}
.step-p{margin-top:6px;color:rgba(245,246,251,.68);font-weight:700;line-height:1.55}

.quotes{margin-top:18px;display:grid;grid-template-columns: repeat(3, 1fr);gap:14px}
.quote{
  margin:0;padding:18px;border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
blockquote{margin:0;color:rgba(245,246,251,.86);font-weight:800;line-height:1.6}
figcaption{margin-top:12px;color:rgba(245,246,251,.58);font-weight:800}

.contact-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
.contact-card{
  padding:18px;border-radius:24px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.contact-row{display:flex;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);font-weight:800;color:rgba(245,246,251,.86)}
.contact-row:last-child{border-bottom:none}
.contact-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.contact-note{margin-top:10px;color:rgba(245,246,251,.56);font-size:12px;font-weight:800}

.form-title{margin:0 0 12px;font-size:16px}
.form label{display:block;margin-bottom:10px}
.form span{display:block;margin-bottom:6px;color:rgba(245,246,251,.70);font-weight:900;font-size:13px}
input,select,textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.26);
  color: var(--text);
  outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color: rgba(255,27,45,.55);
  box-shadow: 0 0 0 6px rgba(255,27,45,.10);
}
.form-help{margin-top:10px;color:rgba(245,246,251,.56);font-size:12px;font-weight:800}
.grid2{display:grid;grid-template-columns: 1fr 1fr;gap:12px}

/* Footer */
.footer{
  padding:26px 0 40px;
  border-top:1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.22);
}
.footer-inner{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.footer-meta{margin-top:10px;color:rgba(245,246,251,.62);font-weight:800}
.footer-right a{font-weight:900;color:rgba(245,246,251,.84)}
.sep{opacity:.45;padding:0 10px}
.footer-bottom{margin-top:16px;color:rgba(245,246,251,.48);font-size:12px;font-weight:800}

/* Modal */
.modal{
  position:fixed;inset:0;z-index:80;
  display:none;align-items:center;justify-content:center;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(12px);
  padding:18px;
}
.modal.open{display:flex}
.modal-card{
  width:min(92vw,760px);
  border-radius:26px;
  background: rgba(10,10,14,.94);
  border:1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modal-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
  padding:16px;
  border-bottom:1px solid rgba(255,255,255,.10);
  background: radial-gradient(780px 260px at 20% 10%, rgba(255,27,45,.22), transparent 60%), rgba(255,255,255,.02);
}
.modal-title{font-weight:900;font-size:18px}
.modal-sub{margin-top:4px;color:rgba(245,246,251,.68);font-weight:800;font-size:13px}
.modal-close{
  width:44px;height:44px;border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color:var(--text);cursor:pointer;
}
.modal-body{padding:16px}

/* Reveal animation */
.reveal{opacity:0;transform: translateY(10px);transition: opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform: translateY(0)}

/* Responsive */
@media (max-width: 980px){
  .nav-links{display:none}
  .burger{display:inline-block}
  .hero-grid{grid-template-columns: 1fr; gap:14px}
  .trust{grid-template-columns: 1fr}
  .grid4{grid-template-columns: repeat(2,1fr)}
  .pricing-grid{grid-template-columns: 1fr}
  .quotes{grid-template-columns: 1fr}
  .contact-grid{grid-template-columns: 1fr}
  .grid2{grid-template-columns: 1fr}
}
@media (max-width: 520px){
  .pill{display:none}
}

send-choice{
  margin-top: 10px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  display: grid;
  gap: 10px;
}
.send-title{
  font-weight: 900;
  color: rgba(245,246,251,.82);
  font-size: 13px;
}
.send-opt{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
  cursor:pointer;
  font-weight: 900;
  color: rgba(245,246,251,.86);
}
.send-opt:hover{
  border-color: rgba(255,27,45,.35);
}
.send-opt input{
  accent-color: var(--red);
}
