*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#08080d;
  --bg2:#0f0f18;
  --bg3:#17171f;
  --bg4:#1e1e28;
  --border:rgba(255,255,255,0.07);
  --border2:rgba(255,255,255,0.13);
  --text:#f0f0f5;
  --text2:#8b8b9e;
  --text3:#55556a;
  --accent:#7c3aed;
  --accent2:#6d28d9;
  --blue:#2563eb;
  --teal:#0d9488;
  --red:#dc2626;
  --green:#059669;
  --amber:#d97706;
  --r:12px;
  --r-lg:18px;
  --r-sm:8px;
}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,'Inter','Segoe UI',sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:inherit}

/* ── TOPBAR ── */
.topbar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  height:38px;display:flex;align-items:center;justify-content:flex-end;
  padding:0 28px;gap:16px;font-size:12.5px;color:var(--text2);
}
.topbar a{color:var(--text2);transition:color .15s}
.topbar a:hover{color:var(--text)}
.topbar-sep{opacity:.3}
.lang-switch{display:flex;gap:2px;align-items:center}
.lang-btn{
  display:flex;align-items:center;gap:5px;
  padding:4px 9px;border-radius:6px;font-size:12px;font-weight:500;
  background:transparent;border:1px solid transparent;color:var(--text3);
  transition:all .15s;
}
.lang-btn:hover{color:var(--text2);background:rgba(255,255,255,0.04)}
.lang-btn.active{color:var(--text);background:rgba(255,255,255,0.07);border-color:var(--border2)}
.flag{font-size:14px}

/* ── NAVBAR ── */
.nav{
  position:sticky;top:0;z-index:100;
  height:62px;display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;
  background:rgba(8,8,13,0.88);
  backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  border-bottom:1px solid var(--border);
}
.logo{display:flex;align-items:center;gap:10px}
.logo-mark{
  width:32px;height:32px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,#7c3aed,#2563eb);
  display:flex;align-items:center;justify-content:center;
}
.logo-mark svg{width:17px;height:17px;fill:#fff}
.logo-name{font-size:16px;font-weight:700;letter-spacing:-.4px}
.logo-name em{font-style:normal;color:var(--text2);font-weight:400;font-size:14px}
.nav-links{display:flex;gap:2px}
.nav-links a{
  font-size:13.5px;color:var(--text2);padding:6px 13px;border-radius:7px;
  transition:color .15s,background .15s;font-weight:450;
}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,0.05)}
.nav-links a.active{color:var(--text)}
.nav-right{display:flex;align-items:center;gap:10px}
.btn-store{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--accent);color:#fff;padding:8px 16px;border-radius:var(--r-sm);
  font-size:13px;font-weight:600;border:none;
  transition:background .15s,transform .1s;
  box-shadow:0 0 18px rgba(124,58,237,.3);
}
.btn-store:hover{background:var(--accent2);transform:translateY(-1px)}
.nav-hamburger{display:none;background:none;border:none;color:var(--text2);padding:6px}
.nav-hamburger svg{width:22px;height:22px}

/* ── HERO ── */
.hero{
  min-height:92vh;display:flex;align-items:center;
  padding:80px 28px 60px;position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);
  background-size:52px 52px;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 30%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,black 30%,transparent 100%);
}
.orb{position:absolute;border-radius:50%;filter:blur(72px);pointer-events:none}
.orb-1{width:480px;height:480px;top:-100px;left:-80px;background:radial-gradient(circle,rgba(124,58,237,.18) 0%,transparent 70%)}
.orb-2{width:360px;height:360px;top:25%;right:-60px;background:radial-gradient(circle,rgba(37,99,235,.14) 0%,transparent 70%)}
.orb-3{width:280px;height:280px;bottom:-40px;left:38%;background:radial-gradient(circle,rgba(13,148,136,.10) 0%,transparent 70%)}
.hero-inner{
  max-width:1160px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;gap:40px;
  align-items:center;
  position:relative;z-index:2;
}
.hero-shapes-zone{
  /* right column — transparent so 3D shapes show through */
  min-height:400px;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.25);
  border-radius:99px;padding:5px 14px 5px 8px;
  font-size:12px;color:#a78bfa;font-weight:500;margin-bottom:22px;
}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:#a78bfa;animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.hero h1{
  font-size:clamp(34px,4.5vw,58px);font-weight:750;
  line-height:1.08;letter-spacing:-2px;margin-bottom:18px;
}
.hero h1 span{
  background:linear-gradient(135deg,#a78bfa 0%,#60a5fa 55%,#34d399 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero p{font-size:16.5px;color:var(--text2);line-height:1.7;max-width:420px;margin-bottom:30px}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--accent);color:#fff;padding:12px 22px;border-radius:var(--r-sm);
  font-size:14px;font-weight:650;border:none;
  transition:background .15s,transform .1s,box-shadow .15s;
  box-shadow:0 0 22px rgba(124,58,237,.35);
}
.btn-primary:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 28px rgba(124,58,237,.45)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:7px;
  background:transparent;color:var(--text2);padding:12px 22px;border-radius:var(--r-sm);
  font-size:14px;font-weight:500;border:1px solid var(--border2);
  transition:color .15s,border-color .15s,background .15s;
}
.btn-ghost:hover{color:var(--text);border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.04)}
.hero-stats{
  display:flex;gap:28px;margin-top:36px;
  padding-top:28px;border-top:1px solid var(--border);
}
.stat-num{font-size:22px;font-weight:750;letter-spacing:-.5px}
.stat-lbl{font-size:11.5px;color:var(--text3);margin-top:2px}

/* Featured card */
.feat-card{
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r-lg);padding:28px;position:relative;overflow:hidden;
}
.feat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(124,58,237,.5),rgba(37,99,235,.5),transparent);
}
.feat-glow{
  position:absolute;top:-50px;right:-50px;width:180px;height:180px;
  background:radial-gradient(circle,rgba(124,58,237,.2) 0%,transparent 70%);
  filter:blur(28px);pointer-events:none;border-radius:50%;
}
.feat-label{
  display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:#a78bfa;background:rgba(124,58,237,.12);
  border:1px solid rgba(124,58,237,.2);padding:3px 10px;border-radius:99px;margin-bottom:18px;
}
.feat-product{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.feat-icon{
  width:54px;height:54px;border-radius:13px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:26px;
}
.feat-name{font-size:18px;font-weight:700;letter-spacing:-.3px}
.feat-cat{font-size:12px;color:var(--text2);margin-top:2px}
.feat-desc{font-size:13.5px;color:var(--text2);line-height:1.6;margin-bottom:18px}
.feat-checks{display:flex;flex-direction:column;gap:7px;margin-bottom:22px}
.feat-check{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text2)}
.feat-check .ck{
  width:17px;height:17px;border-radius:50%;flex-shrink:0;
  background:rgba(124,58,237,.15);display:flex;align-items:center;justify-content:center;
}
.feat-check .ck svg{width:9px;height:9px;stroke:#a78bfa;fill:none;stroke-width:2.5}
.feat-footer{display:flex;align-items:center;justify-content:space-between}
.feat-price .old{font-size:12px;color:var(--text3);text-decoration:line-through;display:block}
.feat-price .now{font-size:26px;font-weight:750;letter-spacing:-.5px}
.feat-price .per{font-size:13px;color:var(--text2);font-weight:400}
.feat-btn{
  background:linear-gradient(135deg,var(--accent),var(--blue));color:#fff;
  padding:10px 20px;border-radius:var(--r-sm);font-size:13.5px;font-weight:650;
  border:none;box-shadow:0 2px 14px rgba(124,58,237,.3);
  transition:opacity .15s,transform .1s;
}
.feat-btn:hover{opacity:.88;transform:translateY(-1px)}

/* ── FIND PRODUCT CTA ── */
.find-bar{
  background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:28px;
}
.find-inner{
  max-width:1160px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.find-text h3{font-size:19px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}
.find-text p{font-size:13.5px;color:var(--text2)}
.find-search{
  display:flex;gap:8px;flex:1;max-width:440px;
}
.find-search input{
  flex:1;background:var(--bg3);border:1px solid var(--border2);
  border-radius:var(--r-sm);padding:10px 14px;font-size:13.5px;
  color:var(--text);outline:none;transition:border-color .2s;font-family:inherit;
}
.find-search input::placeholder{color:var(--text3)}
.find-search input:focus{border-color:var(--accent)}
.find-search button{
  background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);
  padding:10px 18px;font-size:13.5px;font-weight:600;
  transition:background .15s;white-space:nowrap;
}
.find-search button:hover{background:var(--accent2)}

/* ── SECTION COMMONS ── */
.section{padding:70px 28px}
.section-inner{max-width:1160px;margin:0 auto}
.sec-header{text-align:center;margin-bottom:48px}
.sec-eyebrow{
  display:inline-block;font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:#a78bfa;background:rgba(124,58,237,.1);
  border:1px solid rgba(124,58,237,.2);padding:4px 14px;border-radius:99px;margin-bottom:14px;
}
.sec-title{font-size:clamp(26px,3.5vw,36px);font-weight:750;letter-spacing:-.8px;margin-bottom:10px}
.sec-sub{font-size:15px;color:var(--text2);max-width:520px;margin:0 auto;line-height:1.65}
.divider{width:60px;height:2px;background:linear-gradient(90deg,var(--accent),var(--blue));border-radius:2px;margin:18px auto 0}

/* ── PRODUCTS GRID ── */
.products-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
}
.prod-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:24px 20px 20px;
  display:flex;flex-direction:column;align-items:center;text-align:center;
  transition:border-color .2s,transform .2s;
  position:relative;overflow:hidden;
}
.prod-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.prod-card::after{
  content:'';position:absolute;inset:0;border-radius:var(--r);
  background:linear-gradient(135deg,rgba(124,58,237,.04),rgba(37,99,235,.03));
  opacity:0;transition:opacity .25s;pointer-events:none;
}
.prod-card:hover::after{opacity:1}
.prod-icon{
  width:64px;height:64px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;font-size:28px;
  margin-bottom:14px;flex-shrink:0;
}
.prod-name{font-size:16px;font-weight:700;margin-bottom:6px;letter-spacing:-.2px}
.prod-desc{font-size:13px;color:var(--text2);line-height:1.55;margin-bottom:16px;flex:1}
.prod-link{
  font-size:12.5px;color:#a78bfa;font-weight:600;
  display:inline-flex;align-items:center;gap:5px;
  transition:gap .15s;
}
.prod-link:hover{gap:8px}
.prod-link svg{width:12px;height:12px}

/* ── LINES ── */
.lines-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.line-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);overflow:hidden;
  transition:border-color .2s,transform .2s;
}
.line-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.line-card.featured{border-color:rgba(124,58,237,.35);position:relative}
.line-card.featured::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--blue));
}
.line-top{padding:24px 24px 20px}
.line-badge{
  display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;padding:3px 9px;border-radius:99px;margin-bottom:14px;
}
.badge-std{background:rgba(255,255,255,.07);color:var(--text2)}
.badge-pro{background:rgba(124,58,237,.15);color:#a78bfa;border:1px solid rgba(124,58,237,.2)}
.badge-ent{background:rgba(37,99,235,.12);color:#60a5fa;border:1px solid rgba(37,99,235,.2)}
.line-name{font-size:20px;font-weight:750;margin-bottom:4px;letter-spacing:-.4px}
.line-tagline{font-size:12.5px;color:var(--text2)}
.line-price{font-size:30px;font-weight:750;letter-spacing:-.8px;margin:16px 0 4px}
.line-price span{font-size:14px;font-weight:400;color:var(--text2)}
.line-sep{height:1px;background:var(--border);margin:0 24px 20px}
.line-features{padding:0 24px 24px;display:flex;flex-direction:column;gap:9px}
.line-feat{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text2)}
.line-feat .icon{
  width:18px;height:18px;border-radius:5px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.icon-check{background:rgba(5,150,105,.12)}
.icon-check svg{width:10px;height:10px;stroke:#34d399;fill:none;stroke-width:2.5}
.line-cta{
  display:block;margin:0 24px 24px;padding:11px;border-radius:var(--r-sm);
  text-align:center;font-size:13.5px;font-weight:650;
  transition:all .15s;border:1px solid var(--border2);color:var(--text2);background:transparent;
}
.line-cta:hover{background:rgba(255,255,255,.05);color:var(--text)}
.line-card.featured .line-cta{
  background:linear-gradient(135deg,var(--accent),var(--blue));color:#fff;
  border-color:transparent;box-shadow:0 2px 14px rgba(124,58,237,.3);
}
.line-card.featured .line-cta:hover{opacity:.88}

/* ── CATALOG ── */
.catalog-section{
  background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:60px 28px;
}
.catalog-inner{
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;
}
.cat-eyebrow{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#a78bfa;margin-bottom:10px}
.cat-title{font-size:30px;font-weight:750;letter-spacing:-.6px;margin-bottom:10px}
.cat-desc{font-size:14.5px;color:var(--text2);line-height:1.65;max-width:500px;margin-bottom:22px}
.cat-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn-download{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff;padding:11px 20px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:650;border:none;
  transition:background .15s,transform .1s;box-shadow:0 0 16px rgba(124,58,237,.3);
}
.btn-download:hover{background:var(--accent2);transform:translateY(-1px)}
.btn-download svg{width:15px;height:15px}
.catalog-visual{
  width:180px;height:220px;border-radius:var(--r);
  background:var(--bg3);border:1px solid var(--border2);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:var(--text3);font-size:13px;position:relative;overflow:hidden;
  flex-shrink:0;
}
.catalog-visual::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(124,58,237,.08),rgba(37,99,235,.05));
}
.catalog-visual svg{width:48px;height:48px;stroke:var(--text3);fill:none;stroke-width:1;position:relative}

/* ── QUICK LINKS ── */
.quick-links{padding:50px 28px}
.ql-inner{max-width:1160px;margin:0 auto}
.ql-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ql-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
  padding:28px 22px;display:flex;align-items:center;gap:18px;
  transition:border-color .2s,transform .15s;
}
.ql-card:hover{border-color:var(--border2);transform:translateY(-2px)}
.ql-icon{
  width:48px;height:48px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:22px;
}
.ql-info h4{font-size:14.5px;font-weight:700;margin-bottom:4px}
.ql-info p{font-size:12.5px;color:var(--text2)}
.ql-arrow{margin-left:auto;color:var(--text3);flex-shrink:0}
.ql-arrow svg{width:16px;height:16px}

/* ── CERTIFICATION ── */
.cert-section{padding:70px 28px;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cert-inner{
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.cert-badge-wrap{display:flex;justify-content:center}
.cert-badge{
  width:180px;height:180px;border-radius:50%;
  background:var(--bg3);border:2px solid rgba(124,58,237,.3);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  box-shadow:0 0 40px rgba(124,58,237,.15);
}
.cert-badge .cert-icon{font-size:40px}
.cert-badge .cert-txt{font-size:11px;font-weight:700;color:#a78bfa;letter-spacing:.08em;text-align:center;text-transform:uppercase;line-height:1.4}
.cert-content h2{font-size:26px;font-weight:750;letter-spacing:-.5px;margin-bottom:12px}
.cert-content p{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:20px}
.cert-points{display:flex;flex-direction:column;gap:9px}
.cert-point{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--text2)}
.cert-point span{
  width:20px;height:20px;border-radius:6px;flex-shrink:0;
  background:rgba(5,150,105,.1);display:flex;align-items:center;justify-content:center;
  font-size:11px;
}

/* ── NEWS ── */
.news-section{padding:70px 28px}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:0}
.news-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);
  overflow:hidden;transition:border-color .2s,transform .2s;
}
.news-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.news-img{
  height:160px;display:flex;align-items:center;justify-content:center;
  font-size:42px;position:relative;overflow:hidden;
}
.news-body{padding:18px 18px 20px}
.news-date{font-size:11px;color:var(--text3);margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em}
.news-title{font-size:14.5px;font-weight:700;margin-bottom:8px;line-height:1.4;letter-spacing:-.2px}
.news-excerpt{font-size:12.5px;color:var(--text2);line-height:1.55;margin-bottom:14px}
.news-read{font-size:12px;color:#a78bfa;font-weight:600;display:inline-flex;align-items:center;gap:5px;transition:gap .15s}
.news-read:hover{gap:8px}
.news-read svg{width:11px;height:11px}

/* ── SOCIAL ── */
.social-section{
  padding:60px 28px;
  background:linear-gradient(135deg,rgba(124,58,237,.08),rgba(37,99,235,.05));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.social-inner{max-width:1160px;margin:0 auto;text-align:center}
.social-inner h2{font-size:clamp(24px,3vw,34px);font-weight:750;letter-spacing:-.6px;margin-bottom:8px}
.social-inner p{font-size:14.5px;color:var(--text2);margin-bottom:28px}
.social-links{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.social-btn{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--bg3);border:1px solid var(--border2);
  border-radius:var(--r-sm);padding:11px 20px;font-size:13.5px;font-weight:600;
  color:var(--text2);transition:all .15s;
}
.social-btn:hover{color:var(--text);border-color:rgba(255,255,255,.2);background:var(--bg4)}
.social-btn svg{width:18px;height:18px}

/* ── NEWSLETTER ── */
.nl-section{padding:60px 28px;border-top:1px solid var(--border)}
.nl-inner{max-width:560px;margin:0 auto;text-align:center}
.nl-inner h2{font-size:26px;font-weight:750;letter-spacing:-.5px;margin-bottom:8px}
.nl-inner p{font-size:14px;color:var(--text2);margin-bottom:24px;line-height:1.6}
.nl-form{display:flex;gap:8px}
.nl-form input{
  flex:1;background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--r-sm);padding:11px 14px;font-size:13.5px;
  color:var(--text);outline:none;transition:border-color .2s;font-family:inherit;
}
.nl-form input::placeholder{color:var(--text3)}
.nl-form input:focus{border-color:var(--accent)}
.nl-form button{
  background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);
  padding:11px 20px;font-size:13.5px;font-weight:650;white-space:nowrap;
  transition:background .15s;
}
.nl-form button:hover{background:var(--accent2)}
.nl-note{font-size:11.5px;color:var(--text3);margin-top:12px}

/* ── FOOTER ── */
footer{border-top:1px solid var(--border);background:var(--bg2);padding:48px 28px 28px}
.footer-inner{max-width:1160px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:40px}
.footer-brand .logo{margin-bottom:14px;display:inline-flex}
.footer-brand p{font-size:13px;color:var(--text3);line-height:1.65;max-width:240px;margin-bottom:18px}
.footer-social{display:flex;gap:8px}
.footer-social a{
  width:32px;height:32px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;color:var(--text2);
  transition:color .15s,background .15s;
}
.footer-social a:hover{color:var(--text);background:var(--bg4)}
.footer-social svg{width:15px;height:15px}
.footer-col h5{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:13.5px;color:var(--text2);transition:color .15s}
.footer-col ul li a:hover{color:var(--text)}
.footer-contact p{font-size:13px;color:var(--text2);line-height:1.7}
.footer-contact a{color:var(--text2);transition:color .15s}
.footer-contact a:hover{color:var(--text)}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding-top:24px;border-top:1px solid var(--border);
  font-size:12.5px;color:var(--text3);
}
.footer-bottom a{color:var(--text3);transition:color .15s}
.footer-bottom a:hover{color:var(--text2)}

/* ── MOBILE NAV MENU ── */
.mobile-nav{
  display:none;flex-direction:column;
  background:var(--bg2);border-bottom:1px solid var(--border);padding:16px 22px;gap:2px;
}
.mobile-nav a{font-size:14px;color:var(--text2);padding:9px 10px;border-radius:8px;display:block;transition:all .15s}
.mobile-nav a:hover{color:var(--text);background:rgba(255,255,255,.04)}
.mobile-nav.open{display:flex}

/* ── 3D HERO CANVAS — FULL BLEED ── */
.hero-3d-wrap{
  position:absolute;inset:0;z-index:0;overflow:hidden;
}
#hero3d{
  display:block;width:100%!important;height:100%!important;
}
/* subtle vignette so text stays readable */
.hero-3d-wrap::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 110% 90% at 50% 50%,transparent 30%,rgba(8,8,13,.65) 100%);
}
/* solid dark panel — no backdrop-filter so 3D scene isn't distorted */
.hero-text-panel{
  background:rgba(8,8,13,.82);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
  padding:44px 48px;
}
/* badge at bottom-center of full hero */
.hero-3d-badge{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:3;
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(15,15,24,.85);border:1px solid var(--border2);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-radius:99px;padding:6px 14px;font-size:11.5px;color:var(--text2);
  white-space:nowrap;pointer-events:none;
}
.hero-3d-badge .dot{width:6px;height:6px;border-radius:50%;background:#a78bfa;animation:blink 2s ease-in-out infinite}

/* ── MOBILE HERO (CSS 2D rain) ── */
.hero-mobile-bg{
  display:none;
  position:absolute;inset:0;z-index:0;overflow:hidden;
  background:var(--bg);
}
.hero-mobile-bg::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 100% 80% at 50% 40%,rgba(124,58,237,.08) 0%,transparent 70%);
}
.mbit{
  position:absolute;top:-40px;
  font-family:"Courier New",monospace;font-weight:700;
  color:#7c3aed;user-select:none;pointer-events:none;
  animation:mbitfall linear infinite;
  text-shadow:0 0 8px rgba(124,58,237,.6);
}
@keyframes mbitfall{
  0%  {transform:translateY(0);   opacity:0}
  5%  {opacity:.9}
  80% {opacity:.5}
  100%{transform:translateY(110vh);opacity:0}
}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-3d-wrap{display:none!important}
  .hero-mobile-bg{display:block!important}
  .hero-inner{grid-template-columns:1fr}
  .hero-shapes-zone{display:none}
  .hero-text-panel{padding:28px 24px}
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .lines-grid{grid-template-columns:1fr}
  .catalog-inner{grid-template-columns:1fr}
  .catalog-visual{display:none}
  .cert-inner{grid-template-columns:1fr}
  .cert-badge-wrap{order:-1}
  .footer-top{grid-template-columns:1fr 1fr}
  .news-grid{grid-template-columns:1fr}
  .ql-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-hamburger{display:block}
}
@media(max-width:580px){
  .topbar{padding:0 14px;font-size:11.5px;gap:10px}
  .hero{padding:24px 16px 40px}
  .section{padding:48px 16px}
  .find-bar,.catalog-section,.quick-links,.cert-section,.news-section,.social-section,.nl-section{padding:40px 16px}
  .products-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .nl-form{flex-direction:column}
  .hero h1{letter-spacing:-1px}
}