:root{
  --font-body: 'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --font-display: 'Raleway', 'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;

  --font-sans: 'Space Grotesk', 'Inter', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;

  --bg:#06070b;
  --panel: rgba(255,255,255,.06);
  --panel2: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.12);
  --border2: rgba(255,255,255,.18);
  --text:#e9ecf1;
  --muted: rgba(233,236,241,.72);
  --muted2: rgba(233,236,241,.55);
  --accent:#7cf7c7;
  --accent2:#7aa7ff;
  --danger:#ff6b6b;
  --warn:#ffd166;
  --ok:#2ee59d;
  --shadow: 0 18px 55px rgba(0,0,0,.55);
  --shadow2: 0 10px 32px rgba(0,0,0,.42);
  --radius: 18px;
  --radius2: 22px;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial;
}

*{box-sizing:border-box}
html,body{
  margin:0;
  color: var(--text);
  background:
    radial-gradient(900px 500px at 18% 18%, rgba(0,180,255,.10), transparent 55%),
    radial-gradient(900px 500px at 80% 22%, rgba(124,247,199,.08), transparent 58%),
    radial-gradient(900px 600px at 60% 80%, rgba(82,126,255,.08), transparent 60%),
    linear-gradient(180deg, #070A10 0%, #05070C 55%, #04060A 100%);
}
body{
  margin:0;
  font-family: var(--sans);
  color:var(--text);
  background:
    radial-gradient(1100px 500px at 20% 10%, rgba(124,247,199,.18), transparent 60%),
    radial-gradient(900px 550px at 85% 0%, rgba(122,167,255,.18), transparent 55%),
    radial-gradient(800px 600px at 60% 90%, rgba(255,209,102,.10), transparent 55%),
    var(--bg);
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
a.underline{ text-decoration: underline; text-decoration-color: rgba(233,236,241,.28); text-underline-offset: 3px; }
a.underline:hover{ text-decoration-color: rgba(124,247,199,.55); }

.container{max-width:1120px;margin:0 auto;padding:0 18px}
.grid-bg{
  position:fixed; inset:0; pointer-events:none; opacity:.14;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 42px 42px;
  background-position: var(--bx, 50%) var(--by, 50%), var(--bx, 50%) var(--by, 50%);
  mask-image:linear-gradient(to bottom, rgba(0,0,0,1), rgba(0,0,0,0.6) 35%, transparent 65%);
}

.skip{
  position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{
  left:18px; top:18px; width:auto; height:auto; z-index:100;
  padding:10px 12px; border-radius:12px;
  background: rgba(255,255,255,.08);
  border:1px solid var(--border2);
}

.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: rgba(6,7,11,.62);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.nav.scrolled{
  background: rgba(6,7,11,.78);
  border-bottom-color: rgba(255,255,255,.10);
  box-shadow: 0 14px 40px rgba(0,0,0,.28);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:14px}
.brand{display:flex;align-items:center;gap:10px;font-weight:850;letter-spacing:.2px}
.logo{
  width:34px;height:34px;border-radius:12px;
  background: linear-gradient(135deg, rgba(124,247,199,.95), rgba(122,167,255,.95));
  box-shadow: 0 10px 30px rgba(124,247,199,.18);
  position:relative;
}
.logo::after{
  content:"";
  position:absolute; inset:2px;
  border-radius:10px;
  background: radial-gradient(circle at 30% 30%, rgba(0,0,0,.25), transparent 55%);
}
.brand small{display:block;color:var(--muted);font-weight:650;font-family:var(--mono);letter-spacing:.2px}

.nav-links{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.pill{
  font-family:var(--mono);
  font-size:13px;
  padding:8px 10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  background: rgba(255,255,255,.04);
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.pill:hover{transform: translateY(-1px); border-color: rgba(124,247,199,.35); background: rgba(124,247,199,.06)}
.pill.active{border-color: rgba(122,167,255,.55); background: rgba(122,167,255,.08)}

.nav-right{display:flex;align-items:center;gap:10px}
.btn{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color:var(--text);
  border-radius: 14px;
  padding:10px 12px;
  font-family: var(--mono);
  font-size: 13px;
  cursor:pointer;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}

.btn .btn-icon{display:inline-flex;align-items:center;justify-content:center;margin-right:8px;}
.btn:hover{transform: translateY(-1px); border-color: rgba(255,255,255,.28); background: rgba(255,255,255,.07)}
.btn.primary{
  border-color: rgba(124,247,199,.55);
  background: rgba(124,247,199,.12);
}
.btn.primary:hover{border-color: rgba(124,247,199,.85)}
.btn.ghost{ background: transparent; }
.btn.full{ width:100%; }

.select{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color:var(--text);
  border-radius: 14px;
  padding:10px 10px;
  font-family: var(--mono);
  font-size: 13px;
}

.hamburger{display:none}
@media (max-width: 940px){
  .nav-links{display:none}
  .hamburger{display:inline-flex}
}

.hero{padding:58px 0 10px}
.kicker{font-family:var(--mono); color:var(--muted); letter-spacing:.25px}
.h1{font-size: clamp(34px, 4.6vw, 58px); line-height:1.03; margin:14px 0 14px; font-weight:920; letter-spacing:-.9px}
.sub{max-width: 74ch; color:var(--muted); font-size: 16px; line-height:1.65}
.badge{
  display:inline-flex; align-items:center; gap:8px;
  border-radius:999px;
  padding:7px 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  font-family: var(--mono);
  font-size: 12px;
  color: rgba(233,236,241,.84);
}
.badge .dot{ width:8px; height:8px; }
.hero-row{display:grid; grid-template-columns: 1.15fr .85fr; gap:18px; align-items:stretch; margin-top:20px}
@media (max-width: 940px){ .hero-row{grid-template-columns:1fr} }

.card{
  position: relative;
  overflow: hidden;
  background: var(--panel);
  border:1px solid var(--border);
  border-radius: var(--radius2);
  box-shadow: var(--shadow);
}
.card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(520px 240px at var(--mx, 20%) var(--my, 15%), rgba(124,247,199,.14), transparent 60%),
              radial-gradient(520px 240px at 80% 0%, rgba(0,180,255,.10), transparent 55%);
  opacity:0;
  transition: opacity .25s var(--ease);
  pointer-events:none;
  filter: blur(18px);
}
.card:hover::before{ opacity:.95; }
.card.pad{padding:18px}
.card.flat{box-shadow:none}
.card.hover{
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.card.hover:hover{
  transform: translateY(-2px);
  border-color: rgba(124,247,199,.22);
  background: rgba(255,255,255,.07);
  box-shadow: var(--shadow2);
}
.card h3{margin:0 0 8px; font-size: 16px}
.card p{margin:0; color:var(--muted); line-height:1.6}
.card .meta{margin-top:10px; display:flex; flex-wrap:wrap; gap:8px}

.tag{
  font-family:var(--mono);
  font-size:12px;
  padding:6px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(233,236,241,.84);
}
.tag.ok{border-color: rgba(46,229,157,.35); background: rgba(46,229,157,.08)}
.tag.warn{border-color: rgba(255,209,102,.35); background: rgba(255,209,102,.08)}
.tag.danger{border-color: rgba(255,107,107,.35); background: rgba(255,107,107,.08)}

.grid2{display:grid; grid-template-columns: repeat(2, 1fr); gap:14px}
.grid3{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
@media (max-width: 940px){ .grid3,.grid2{grid-template-columns:1fr} }

.section{padding: 36px 0}
.section h2{margin:0 0 8px; font-size: 22px; letter-spacing:-.3px}
.section .lead{margin:0 0 16px; color:var(--muted); max-width: 90ch; line-height:1.7}

.divider{
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
  margin: 10px 0 0;
}

.pricing{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px}
@media (max-width: 940px){ .pricing{grid-template-columns:1fr} }
.price{padding:18px}
.price .tier{font-family:var(--mono); color:rgba(233,236,241,.84)}
.price .cost{font-size:34px; font-weight:920; margin:8px 0}
.price ul{margin:0; padding-left:18px; color:var(--muted); line-height:1.65}
.price .cta{margin-top:14px; width:100%}

.footer{padding:26px 0 42px; color:rgba(233,236,241,.62); font-family:var(--mono); font-size:12px}
.footer a{color:rgba(233,236,241,.75)}
.footer .row{
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.08);padding-top:14px
}

/* console */
.console{padding:18px}
.console .top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.dot{width:10px;height:10px;border-radius:999px;display:inline-block;background: rgba(255,255,255,.25);}
.dot.ok{background: var(--ok); box-shadow: 0 0 18px rgba(46,229,157,.35)}
.dot.warn{background: var(--warn); box-shadow: 0 0 18px rgba(255,209,102,.25)}
.dot.danger{background: var(--danger); box-shadow: 0 0 18px rgba(255,107,107,.25)}
.pulse{animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.25);opacity:1}}
.kv{display:grid; grid-template-columns: 1fr auto; gap:10px; padding:10px 0; border-top:1px solid rgba(255,255,255,.08)}
.kv:first-of-type{border-top:0}
.kv span{color:var(--muted); font-family:var(--mono); font-size:12px}
.kv strong{font-family:var(--mono); font-size:12px; letter-spacing:.2px}

/* feed */
.feed{font-family:var(--mono); font-size:12px; color:rgba(233,236,241,.78); line-height:1.65}
.feed .line{padding:9px 0; border-top:1px solid rgba(255,255,255,.08)}
.feed .line:first-child{border-top:0}
.feed .ts{color:rgba(233,236,241,.55)}

/* forms */
.field{display:flex;flex-direction:column;gap:6px;margin:10px 0}
label{font-family:var(--mono);font-size:12px;color:rgba(233,236,241,.80)}
input, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color:var(--text);
  outline:none;
}
select{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: var(--text);
  outline:none;
}
select:focus{border-color: rgba(124,247,199,.55); box-shadow: 0 0 0 4px rgba(124,247,199,.08)}

.sr-only{
  position:absolute !important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

.hide{display:none !important}

/* app/admin UI */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 12px}
.tab{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  border-radius: 999px;
  padding:10px 12px;
  font-family: var(--mono);
  font-size: 12px;
  cursor:pointer;
  transition: transform .2s var(--ease), border-color .2s var(--ease), background .2s var(--ease);
}
.tab:hover{transform: translateY(-1px); border-color: rgba(124,247,199,.35)}
.tab.active{background: rgba(124,247,199,.12); border-color: rgba(124,247,199,.45)}

.table-wrap{overflow:auto;border:1px solid rgba(255,255,255,.12);border-radius:16px}
table{width:100%;border-collapse:collapse}
th, td{padding:12px 12px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left}
th{font-family:var(--mono);font-size:12px;color:rgba(233,236,241,.85);background: rgba(255,255,255,.03);position:sticky;top:0}
tr:hover td{background: rgba(255,255,255,.02)}

.status-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.14);background: rgba(255,255,255,.04);font-family:var(--mono);font-size:12px}
.status-pill.ok{border-color: rgba(124,247,199,.35);background: rgba(124,247,199,.10)}
.status-pill.warn{border-color: rgba(255,210,107,.35);background: rgba(255,210,107,.10)}
.status-pill.bad{border-color: rgba(255,107,141,.35);background: rgba(255,107,141,.10)}

.toast{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);
  z-index:70;min-width:min(460px, calc(100vw - 36px));
  display:none;padding:12px 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(12,13,18,.78);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  border-radius:16px;
}
.toast.open{display:block}
input:focus, textarea:focus{border-color: rgba(124,247,199,.55); box-shadow: 0 0 0 4px rgba(124,247,199,.08)}
.help{font-size:12px;color:var(--muted2);line-height:1.5}

/* FAQ */
details{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  border-radius: 16px;
  padding: 12px 12px;
}
details + details{ margin-top:10px; }
summary{
  cursor:pointer;
  list-style:none;
  font-family: var(--mono);
  font-size: 13px;
}
summary::-webkit-details-marker{ display:none; }
details p{ margin:10px 0 0; color: var(--muted); }

/* chat */
.chat-fab{
  position:fixed; right:18px; bottom:18px; z-index:60;
  width:54px;height:54px;border-radius:16px;
  border:1px solid rgba(124,247,199,.45);
  background: rgba(124,247,199,.12);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
}
.chat-panel{
  position:fixed; right:18px; bottom:84px; z-index:60;
  width:min(420px, calc(100vw - 36px));
  max-height: 70vh;
  display:none;
}
.chat-panel.open{display:block}
.chat-header{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.10)
}

/* --- App (portal/admin) components --- */
.tabs{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0 0 12px}
.tab{
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: var(--text);
  padding:10px 12px;
  border-radius: 14px;
  cursor:pointer;
  transition: transform .18s var(--ease), border-color .18s var(--ease), background .18s var(--ease);
}
.tab:hover{ transform: translateY(-1px); border-color: rgba(124,247,199,.35); }
.tab.active{ border-color: rgba(124,247,199,.45); background: rgba(124,247,199,.10); }

.table{ width:100%; border-collapse: separate; border-spacing:0; overflow:hidden; border-radius: 16px; border:1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); }
.table th, .table td{ padding:12px 12px; border-bottom:1px solid rgba(255,255,255,.08); text-align:left; vertical-align:top; }
.table th{ font-family: var(--mono); font-size:12px; color: rgba(233,236,241,.75); }
.table tr:last-child td{ border-bottom:0; }
.table td .small{ margin:0; }

.status{
  display:inline-flex;
  gap:8px;
  align-items:center;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  padding:6px 10px;
  border-radius: 999px;
  font-family: var(--mono);
  font-size:11px;
  letter-spacing:.15px;
}
.status .dot{ width:8px; height:8px; border-radius:99px; display:inline-block; }
.status.open .dot{ background: rgba(255,210,107,.9); box-shadow: 0 0 0 4px rgba(255,210,107,.10); }
.status.in_progress .dot{ background: rgba(0,180,255,.9); box-shadow: 0 0 0 4px rgba(0,180,255,.10); }
.status.done .dot{ background: rgba(124,247,199,.95); box-shadow: 0 0 0 4px rgba(124,247,199,.10); }

.toast{
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%);
  z-index: 80;
  width: min(520px, calc(100vw - 24px));
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(6,7,11,.85);
  backdrop-filter: blur(10px);
  color: var(--text);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
  display:none;
}
.toast.show{display:block}

@media (prefers-reduced-motion: reduce){
  .tab{ transition:none !important; }
}
.chat-header .title{font-family:var(--mono);font-size:13px}
.chat-body{padding:12px 14px; overflow:auto; max-height: 46vh}
.bubble{
  padding:10px 12px; border-radius:16px; border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  margin: 10px 0;
  font-size: 14px; line-height: 1.5;
}
.bubble.me{border-color: rgba(122,167,255,.35); background: rgba(122,167,255,.08)}
.bubble.ai{border-color: rgba(124,247,199,.35); background: rgba(124,247,199,.08)}
.chat-input{display:flex;gap:10px; padding:12px 14px; border-top:1px solid rgba(255,255,255,.10)}
.chat-input button{white-space:nowrap}
.small{font-size:12px;color:rgba(233,236,241,.62);line-height:1.5}

/* mobile menu */
.drawer{
  position:fixed; inset:0; z-index:80; display:none;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}
.drawer.open{display:block}
.drawer-panel{
  position:absolute; right:0; top:0; height:100%; width:min(360px, 92vw);
  background: rgba(10,12,18,.90);
  border-left:1px solid rgba(255,255,255,.10);
  padding:14px;
}
.drawer .title{font-family:var(--mono); font-weight:800; margin:6px 0 10px}
.drawer a{display:block;margin:8px 0}

/* Brand */
.brand-mark{
  width:34px;
  height:34px;
  border-radius:12px;
  object-fit:contain;
  box-shadow: 0 10px 30px rgba(124,247,199,.18);
}
@media (max-width: 940px){
  .brand-mark{ width:32px; height:32px; border-radius:11px; }
}

/* --- Brand (responsive, optimized) --- */
.brand{ min-width:0; }
.brand-text{ display:flex; flex-direction:column; min-width:0; }
.brand-name{
  font-weight: 900;
  letter-spacing: .2px;
  line-height: 1.05;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.brand-tagline{
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.brand-mark{
  width: 38px;
  height: 38px;
  border-radius: 14px;
  object-fit: contain;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 10px 30px rgba(124,247,199,.18);
}
@media (max-width: 940px){
  .brand-mark{ width:34px; height:34px; border-radius: 12px; }
}
/* Tablet: hide tagline, keep name */
@media (max-width: 820px){
  .brand-tagline{ display:none; }
}
/* Mobile: icon only */
@media (max-width: 520px){
  .brand-text{ display:none; }
  .brand{ gap:0; }
}
/* Better tap targets on mobile */
@media (max-width: 520px){
  .pill{ padding: 10px 12px; }
  .nav-inner{ padding: 10px 0; }
}

/* --- Typography refresh --- */
html, body{
  font-family: var(--font-body);
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
h1,h2,h3{ letter-spacing: -0.02em; }
.kicker{ letter-spacing: .18em; font-weight: 700; }

/* --- Interaction polish --- */
a, button{ -webkit-tap-highlight-color: transparent; }

.btn, .pill, .card, .mini, .pricing, .kbd{
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background-color .18s ease, color .18s ease, opacity .18s ease;
}

.btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}
.btn:active{ transform: translateY(0px) scale(.99); }

.pill:hover{
  transform: translateY(-1px);
  border-color: rgba(124,247,199,.45);
  box-shadow: 0 12px 30px rgba(124,247,199,.12);
}
.pill:active{ transform: translateY(0px) scale(.99); }

/* Cards */
.card:hover, .mini:hover, .pricing:hover{
  transform: translateY(-2px);
  border-color: rgba(0,180,255,.30);
  box-shadow: 0 22px 60px rgba(0,0,0,.45), 0 0 0 1px rgba(124,247,199,.10) inset;
}
.card:active, .mini:active, .pricing:active{
  transform: translateY(-1px) scale(.995);
}

/* Visible keyboard focus */
:focus-visible{
  outline: 2px solid rgba(124,247,199,.75);
  outline-offset: 3px;
  border-radius: 12px;
}
/* --- Plans polish --- */
:root{ --ease: cubic-bezier(.2,.8,.2,1); }

/* Scroll reveal (respects reduced motion) */
[data-animate]{
  opacity: 0;
  transform: translateY(10px) scale(.99);
  filter: blur(4px);
  transition: opacity .55s var(--ease), transform .55s var(--ease), filter .55s var(--ease);
  transition-delay: var(--d, 0ms);
  will-change: opacity, transform, filter;
}
[data-animate].in{
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}
@media (prefers-reduced-motion: reduce){
  [data-animate]{ opacity:1 !important; transform:none !important; transition:none !important; }
}

/* Plan cards with tier glows */
.pricing{ position:relative; overflow:hidden; }
.pricing::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(600px 240px at var(--mx, 30%) var(--my, 10%), rgba(124,247,199,.18), transparent 55%),
              radial-gradient(600px 240px at 70% 10%, rgba(0,180,255,.18), transparent 55%);
  opacity:.55; filter: blur(18px);
  pointer-events:none;
}
.pricing::after{
  content:""; position:absolute; inset:0;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,.10);
  pointer-events:none;
}
.plan-launch::before{
  background: radial-gradient(620px 260px at var(--mx, 20%) var(--my, 10%), rgba(0,180,255,.22), transparent 55%),
              radial-gradient(520px 240px at 70% 0%, rgba(82,126,255,.18), transparent 55%);
}
.plan-growth::before{
  background: radial-gradient(620px 260px at var(--mx, 20%) var(--my, 10%), rgba(124,247,199,.26), transparent 58%),
              radial-gradient(520px 240px at 78% 0%, rgba(0,180,255,.18), transparent 55%);
}
.plan-pro::before{
  background: radial-gradient(720px 300px at var(--mx, 30%) var(--my, 10%), rgba(255,210,107,.18), transparent 60%),
              radial-gradient(520px 240px at 78% 0%, rgba(124,247,199,.16), transparent 55%);
}

/* Card spotlight (subtle, mouse-only; JS sets --mx/--my) */
.card{ position: relative; overflow: hidden; }
.card::before{
  content:"";
  position:absolute; inset:-1px;
  background: radial-gradient(520px 260px at var(--mx, 25%) var(--my, 20%), rgba(124,247,199,.10), transparent 60%);
  opacity: 0;
  transition: opacity .25s var(--ease);
  pointer-events:none;
}
.card:hover::before{ opacity: .95; }

/* Slightly stronger glass when scrolling */
.nav.scrolled{
  background: rgba(6,7,11,.78);
  border-bottom-color: rgba(255,255,255,.11);
}

/* Price row */
.price-row{ display:flex; gap:10px; align-items:baseline; flex-wrap:wrap; margin:10px 0 14px; }
.price-row .price{ font-size:34px; font-weight:900; letter-spacing:-0.02em; line-height:1; }
.price-row .sub{ font-size:13px; font-weight:700; opacity:.78; }

.badge{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:800;
  padding:6px 10px; border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}
.badge.pop{ border-color: rgba(124,247,199,.28); background: rgba(124,247,199,.10); }

.pricing:hover{
  transform: translateY(-3px);
  box-shadow: 0 26px 70px rgba(0,0,0,.48), 0 0 0 1px rgba(124,247,199,.10) inset;
}

.plan-list{ padding-left:18px; margin:0 0 16px; line-height:1.85; }
/* --- Plan layout system --- */
.plans-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}
@media (max-width: 960px){
  .plans-grid{ grid-template-columns: 1fr; }
}

.plan-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap: 14px;
  min-height: 420px;
}
.plan-head{
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.plan-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.plan-title{ font-size: 18px; font-weight: 800; letter-spacing: -0.03em; margin: 0; }
.plan-sub{
  margin: 0;
  opacity: .8;
}
.plan-pricing{
  display:grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding-top: 2px;
}
.price-line{
  display:flex;
  align-items:baseline;
  gap: 8px;
  flex-wrap:wrap;
}
.price-big{
  font-size: 30px;
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1;
}
.price-label{
  font-size: 12px;
  font-weight: 800;
  opacity: .78;
}
.plan-features{
  padding-left: 18px;
  margin: 0;
  line-height: 1.85;
}
.plan-features li{ margin: 0; }
.plan-cta{
  display:flex;
  gap: 10px;
  align-items:center;
}
.plan-cta .btn{ width:100%; }
.plan-note{
  font-size: 12px;
  opacity:.7;
  margin: 0;
}

/* Make pricing cards feel structured */
.pricing.plan-card{ padding: 18px; }
.pricing .badge{ flex: 0 0 auto; }
/* --- Typography: Raleway + Inter --- */
html, body{
  font-family: var(--font-body);
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, .plan-title, .brand-name{
  font-family: var(--font-display);
  letter-spacing: -0.03em;
}

h1{ font-weight: 900; }
h2{ font-weight: 800; }
h3{ font-weight: 700; }

/* Make small text feel cleaner */
.small{
  letter-spacing: -0.005em;
}

/* Buttons: slightly bolder for a premium feel */
.btn{
  font-family: var(--font-body);
  font-weight: 700;
}

/* Kicker more elegant */
.kicker{
  font-family: var(--font-display);
  letter-spacing: .22em;
  font-weight: 800;
}
/* --- Navbar polish v7 --- */
.nav{
  position: sticky;
  top: 0;
  z-index: 50;
}
.nav-inner{
  gap: 10px;
}
.nav{
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
/* Make menu pills more elegant */
.pill{
  border-radius: 999px;
  padding: 9px 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.pill:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(124,247,199,.28);
}
.pill.active, .pill[aria-current="page"]{
  background: rgba(124,247,199,.10);
  border-color: rgba(124,247,199,.32);
  box-shadow: 0 14px 36px rgba(124,247,199,.10), 0 10px 30px rgba(0,0,0,.25);
}

/* Language selector clarity */
.lang, .lang select{
  font-weight: 800;
}
select#lang{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 9px 38px 9px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: inherit;
  cursor: pointer;
}
.lang{
  position: relative;
}
.lang::after{
  content:"▾";
  position:absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  opacity: .75;
  pointer-events:none;
  font-size: 12px;
  font-weight: 900;
}

/* Remove any tiny brand line if present */
.brand-tagline{ display:none !important; }

/* Better spacing for bottom info blocks (Add-ons / AI credits / Library) */
.grid-3{
  gap: 18px;
}
@media (max-width: 960px){
  .grid-3{
    gap: 14px;
  }
  .mini.card{
    padding: 14px;
  }
}
/* Footer spacing */
.footer-links-spaced a{
  margin-left: 14px;
}
@media (max-width: 520px){
  .footer-links-spaced a{ margin-left: 0; margin-right: 14px; }
}
/* Brand row lock */
.brand{ align-items:center; }
.brand-text{ line-height: 1.1; }
.brand-name{ font-size: 15px; }
/* Layout fill */
html, body{ height: 100%; }
body{
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
main{ flex: 1 0 auto; }
footer{ flex: 0 0 auto; }
/* Custom language menu */
.langMenu{ position: relative; }
.langBtn{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  min-width: 170px;
}
.langChev{ opacity:.75; font-weight:900; }
.langDropdown{
  position:absolute;
  right:0;
  top: calc(100% + 8px);
  min-width: 210px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(18,18,22,.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
  padding: 8px;
  display:none;
  z-index: 50;
}
.langDropdown.open{ display:block; }
.langDropdown button{
  width:100%;
  text-align:left;
  padding: 10px 12px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid transparent;
  color: inherit;
  cursor:pointer;
  font-family: var(--font-body);
  font-weight: 700;
}
.langDropdown button:hover{
  background: rgba(124,247,199,.10);
  border-color: rgba(124,247,199,.22);
}
/* Nav typography refinement */
.nav a, .pill, .langBtn{
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.nav a.pill{ font-size: 13px; }


/* ========= CDMG v12 Website Polish ========= */

/* Layout fill (avoid "half page") */
html, body { height: 100%; }
body { min-height: 100vh; display: flex; flex-direction: column; }
main { flex: 1 0 auto; }
footer { flex: 0 0 auto; }

/* Premium nav (less "cheap") */
.nav .pill {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.01em;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: none;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.nav .pill:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(124,247,199,.22);
  transform: translateY(-1px);
}
.nav .pill:active{ transform: translateY(0); }

/* Softer reveal animations */
[data-animate]{
  opacity: 0;
  transform: translateY(12px);
  transition: opacity .55s ease, transform .55s ease;
  will-change: opacity, transform;
}
[data-animate].in{
  opacity: 1;
  transform: translateY(0);
}

/* Language menu (SVG flags) */
.langMenu { position: relative; }
.langBtn{
  display:flex; align-items:center; justify-content:space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: inherit;
  cursor:pointer;
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}
.langBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(124,247,199,.22);
  background: rgba(255,255,255,.06);
}
.langBtnInner{ display:flex; align-items:center; gap:10px; }
.flag{
  width:18px; height:12px;
  border-radius:3px;
  border:1px solid rgba(255,255,255,.18);
  display:block;
}
.langChev{ opacity:.75; font-weight:900; }

.langDropdown{
  position:absolute;
  right:0; top: calc(100% + 8px);
  min-width: 220px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(18,18,22,.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 24px 70px rgba(0,0,0,.55);
  padding: 8px;
  display:none;
  z-index: 80;
}
.langDropdown.open{ display:block; }
.langDropdown button{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  text-align:left;
  padding: 10px 12px;
  border-radius: 10px;
  background: transparent;
  border: 1px solid transparent;
  color: inherit;
  cursor:pointer;
  font-family: var(--font-body);
  font-weight: 700;
}
.langDropdown button:hover{
  background: rgba(124,247,199,.10);
  border-color: rgba(124,247,199,.22);
}

/* Footer spacing */
footer .grid, footer .grid-3 { gap: 14px !important; }
footer .small { line-height: 1.5; }

/* ==========================
   CDMG Premium Polish (v13)
   Fixes: grid-3, mini cards, spacing, cart UI, chat bubbles
   ========================== */

:root{
  --space-1: 6px;
  --space-2: 10px;
  --space-3: 14px;
  --space-4: 18px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 64px;
  --radius-lg: 18px;
}

/* Global rhythm */
.section{ padding: var(--space-7) 0; }
/* Ensure anchored sections aren’t hidden behind sticky nav */
[id]{ scroll-margin-top: 96px; }

/* Better responsive grids (avoid overly wide single-column cards on laptops) */
.grid3{ display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
@media (max-width: 1040px){
  .grid3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px){
  .grid3{ grid-template-columns: 1fr; }
}

/* Nav utilities */
.nav-right{ gap: 10px; }
.nav-portal{ display:inline-flex; }
@media (max-width: 760px){
  .nav-portal{ display:none; }
}

.hero{padding:90px 0 32px;}
.h1{ max-width: 22ch; }
.sub, .lead{ max-width: 72ch; }

p{ line-height: 1.68; }
.small{ line-height: 1.55; }

/* Avoid card/content overflow in grids */
.grid3 > *, .grid2 > *, .grid-2 > *, .grid-3 > *{ min-width: 0; }
.card, .pill, .tag, .badge{ overflow-wrap: anywhere; }

/* FIX: .grid-3 was missing display rules on some pages */
.grid-3{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}
@media (max-width: 980px){
  .grid-3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px){
  .grid-3{ grid-template-columns: 1fr; }
}

/* Give unpadded cards inside grid-3 proper spacing */
.grid-3 > .card{
  padding: 16px;
  border-radius: var(--radius-lg);
}

/* Mini cards: used in Premium sections */
.card.mini, .mini.card{
  padding: 16px;
  border-radius: var(--radius-lg);
}

/* Better headings */
h2, h3{ line-height: 1.18; }

/* Chat bubbles */
.chat-body{ display:flex; flex-direction:column; gap: 10px; }
.bubble{ max-width: 88%; padding: 10px 12px; border-radius: 14px; border: 1px solid rgba(255,255,255,.10); }
.bubble.me{ align-self: flex-end; }
.bubble.ai{ align-self: flex-start; }
.bubble .meta{ opacity: .75; font-size: 12px; margin-bottom: 6px; }

/* Cart icon in navbar */
.cart-pill{
  display:flex;
  align-items:center;
  gap: 8px;
  position: relative;
}
.cart-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(124,247,199,.10);
}

/* Cart page layout */
.cart-layout{
  display:grid;
  grid-template-columns: 1.35fr .95fr;
  gap: 18px;
  align-items: start;
}
@media (max-width: 980px){
  .cart-layout{ grid-template-columns: 1fr; }
}

.cart-item{
  display:flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-top: 1px solid rgba(255,255,255,.10);
}
.cart-item:first-child{ border-top: 0; padding-top: 0; }
.cart-item .title{ font-weight: 900; }
.cart-item .sub{ margin: 6px 0 0; max-width: 60ch; }
.cart-item .actions{ display:flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }

.qty{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 6px 8px;
  background: rgba(255,255,255,.03);
}
.qty button{
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: inherit;
  cursor:pointer;
}
.qty button:hover{ background: rgba(255,255,255,.07); }

.notice{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,204,102,.08);
  border-radius: var(--radius-lg);
  padding: 12px;
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; }
  [data-animate]{ transition: none !important; transform: none !important; opacity: 1 !important; }
  .orb{ animation: none !important; }
}

/* ===============================
   CDMG Enterprise UI Polish (v14)
   =============================== */

:root{
  --container: 1180px;
  --section-y: clamp(72px, 7vw, 120px);
  --section-y-lg: clamp(90px, 8vw, 140px);
}

body{
  font-size: 17px;
  line-height: 1.6;
}

.container{
  max-width: var(--container);
}

.section{
  padding: var(--section-y) 0;
}

.hero{
  padding: var(--section-y-lg) 0 var(--section-y);
}

.h1{ letter-spacing: -0.02em; }
.sub{ font-size: 18px; line-height: 1.65; }

@media (max-width: 640px){
  body{ font-size: 16px; }
  .sub{ font-size: 16px; }
}

/* Nav: clearer IA + stronger CTA */
.nav-links{ gap: 10px; }
.nav-cta{
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(124,247,199,.18), rgba(84,189,255,.14));
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
.nav-cta:hover{ transform: translateY(-1px); }

/* Footer */
.footer .row{ align-items: flex-start; gap: 16px; }
.footer-meta{ margin-top: 8px; display:flex; gap: 10px; flex-wrap: wrap; font-size: 13px; opacity: .85; }
.footer-links{ display:flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.footer-links a{ opacity: .9; }
.footer-links a:hover{ opacity: 1; }

@media (max-width: 780px){
  .footer-links{ justify-content: flex-start; }
}

/* Integration/logo strip */
.logo-strip{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.logo-chip{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  border-radius: 999px;
  font-weight: 800;
  font-size: 13px;
}
.logo-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.28);
  box-shadow: 0 0 0 4px rgba(255,255,255,.06);
}

/* Tables (plan comparison, terms) */
.table{
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,.12);
}
.table th, .table td{
  padding: 12px 14px;
  border-top: 1px solid rgba(255,255,255,.10);
  vertical-align: top;
}
.table th{
  text-align: left;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .75;
  background: rgba(255,255,255,.03);
}

/* Form polish */
input, textarea, select{
  font-size: 16px;
}

/* Stronger focus visibility */
:focus-visible{
  outline: 3px solid rgba(84,189,255,.6);
  outline-offset: 2px;
}

@media(min-width:900px){.section{padding:104px 0}}

[id]{scroll-margin-top:96px}

.nav-portal{display:inline-flex}
@media(max-width:760px){.nav-portal{display:none}}
