/* ==========================================================================
   VENUERA - bright modern product theme
   Clean, confident, real-product-led. Built to parry Events Calendar / FooEvents.
   ========================================================================== */

:root{
  --bg:#ffffff;
  --bg-soft:#F6F7FB;        /* light section */
  --bg-tint:#F1EEFE;        /* soft purple tint */
  --ink:#0F1020;           /* darkest */
  --head:#15162B;          /* headings */
  --text:#54586E;          /* body */
  --muted:#8A8EA3;
  --faint:#AEB2C4;
  --line:#ECEDF3;
  --line-2:#E1E3EC;

  --purple:#6C5CE7;
  --purple-d:#5A48DC;
  --purple-dd:#4A37C4;
  --violet:#8B7CF6;
  --indigo:#4F46E5;
  --tint:#EEEBFE;
  --pink:#EC4899;
  --teal:#0EA5A3;
  --amber:#F59E0B;
  --green:#16A34A;

  --grad:linear-gradient(135deg,#7C6CF0 0%,#6C5CE7 50%,#5A48DC 100%);
  --grad-soft:linear-gradient(160deg,#F4F1FE,#EDE9FE);

  --shadow-sm:0 1px 2px rgba(16,16,32,.04),0 2px 6px rgba(16,16,32,.05);
  --shadow:0 4px 12px -2px rgba(16,16,32,.07),0 18px 40px -16px rgba(16,16,32,.14);
  --shadow-lg:0 30px 70px -24px rgba(76,55,196,.30);
  --shadow-window:0 40px 90px -30px rgba(20,16,60,.32),0 6px 18px -8px rgba(20,16,60,.18);

  --r-sm:10px; --r:14px; --r-lg:20px; --r-xl:28px;
  --maxw:1200px;
  --display:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  --body:'Inter',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);color:var(--text);background:var(--bg);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block;height:auto}
a{color:var(--purple);text-decoration:none;transition:color .15s,opacity .15s}
h1,h2,h3,h4{font-family:var(--display);color:var(--head);margin:0 0 .5em;line-height:1.1;letter-spacing:-.025em;font-weight:800}
p{margin:0 0 1em}
ul{margin:0;padding:0;list-style:none}
svg{display:block}
::selection{background:var(--tint)}

/* ---------- Layout ---------- */
.v-container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.v-section{padding:104px 0;position:relative}
.v-section-sm{padding:64px 0;position:relative}
.v-narrow{max-width:760px;margin:0 auto}
.v-center{text-align:center}

/* ---------- Type ---------- */
.v-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:700;
  font-size:13px;letter-spacing:.02em;color:var(--purple);background:var(--bg-tint);
  padding:7px 14px;border-radius:999px;margin-bottom:22px}
.v-eyebrow svg{width:15px;height:15px}
.v-eyebrow.on-dark{color:#D7CFFF;background:rgba(255,255,255,.1)}
.v-h1{font-size:clamp(42px,6vw,72px);font-weight:800;letter-spacing:-.035em;line-height:1.02}
.v-h2{font-size:clamp(30px,4.2vw,50px);font-weight:800;letter-spacing:-.03em}
.v-h3{font-size:21px;font-weight:700;letter-spacing:-.015em}
.v-lead{font-size:clamp(17px,1.6vw,20px);line-height:1.6;color:var(--text)}
.v-gt{color:var(--purple)}
.v-gt-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.v-num{display:inline-block;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--purple);margin-bottom:14px}

/* ---------- Buttons ---------- */
.v-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--display);font-weight:700;font-size:15.5px;line-height:1;padding:15px 26px;
  border-radius:12px;border:1px solid transparent;cursor:pointer;
  transition:transform .16s cubic-bezier(.2,.7,.3,1),box-shadow .16s,background .16s,color .16s,border-color .16s}
.v-btn:active{transform:translateY(1px)}
.v-btn-primary{background:var(--grad);color:#fff;box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 12px 26px -10px rgba(108,92,231,.6)}
.v-btn-primary:hover{color:#fff;transform:translateY(-2px);box-shadow:0 1px 0 rgba(255,255,255,.3) inset,0 18px 40px -12px rgba(108,92,231,.7)}
.v-btn-ghost{background:#fff;color:var(--head);border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.v-btn-ghost:hover{color:var(--head);border-color:var(--violet);transform:translateY(-2px);box-shadow:var(--shadow)}
.v-btn-glass{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.28)}
.v-btn-glass:hover{background:rgba(255,255,255,.2);color:#fff;transform:translateY(-2px)}
.v-btn-lg{padding:17px 32px;font-size:16.5px;border-radius:14px}
.v-btn-sm{padding:11px 18px;font-size:14px;border-radius:10px}
.v-btn .v-arrow{transition:transform .16s}
.v-btn:hover .v-arrow{transform:translateX(3px)}

/* ---------- Header ---------- */
.v-header{position:fixed;top:0;left:0;right:0;z-index:200;transition:background .25s,box-shadow .25s,border-color .25s}
.v-header.at-top{background:transparent;border-bottom:1px solid transparent}
.v-header:not(.at-top){background:rgba(255,255,255,.82);-webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line);box-shadow:0 4px 24px rgba(16,16,32,.05)}
.v-nav{display:flex;align-items:center;gap:30px;height:78px}
.v-brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:22px;letter-spacing:-.02em;color:var(--head)}
.v-nav-menu{display:flex;align-items:center;gap:2px;margin:0 auto}
.v-nav-menu a{display:block;padding:9px 14px;border-radius:9px;color:var(--head);font-weight:600;font-size:15px;opacity:.8}
.v-nav-menu a:hover{opacity:1;background:var(--bg-soft)}
.v-nav-actions{display:flex;align-items:center;gap:12px}
.v-signin{color:var(--head);font-weight:600;font-size:15px;opacity:.8;padding:9px 6px}
.v-signin:hover{opacity:1}
.v-header.at-top.hero-dark .v-brand,.v-header.at-top.hero-dark .v-nav-menu a,.v-header.at-top.hero-dark .v-signin{color:#fff}
.v-header.at-top.hero-dark .v-nav-menu a:hover{background:rgba(255,255,255,.12)}
.v-nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line-2);background:#fff;border-radius:11px;cursor:pointer;align-items:center;justify-content:center;color:var(--head)}
.v-nav-toggle span,.v-nav-toggle span::before,.v-nav-toggle span::after{content:"";display:block;width:18px;height:2px;background:currentColor;border-radius:2px;position:relative;transition:.2s}
.v-header.at-top.hero-dark .v-nav-toggle{color:#fff;border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.08)}
.v-nav-toggle span::before{position:absolute;top:-6px}.v-nav-toggle span::after{position:absolute;top:6px}

/* ---------- HERO (bright) ---------- */
.v-hero{position:relative;overflow:hidden;padding:118px 0 56px;
  background:radial-gradient(1100px 540px at 50% -10%,var(--bg-tint),transparent 62%),var(--bg)}
.v-hero .v-h1{font-size:clamp(36px,4.6vw,56px)}
.v-hero-head{max-width:820px}
.v-hero-rule{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.6;
  -webkit-mask-image:radial-gradient(900px 560px at 50% 6%,#000,transparent 76%);mask-image:radial-gradient(900px 560px at 50% 6%,#000,transparent 76%);
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:58px 58px}
.v-hero .v-container{position:relative;z-index:1}
.v-hero-head{max-width:880px;margin:0 auto;text-align:center}
.v-hero h1{color:var(--head)}
.v-hero-sub{font-size:clamp(17px,1.7vw,20px);color:var(--text);max-width:650px;margin:22px auto 30px}
.v-hero-sub strong{color:var(--head);font-weight:600}
.v-hero-cta{display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.v-hero-note{margin-top:18px;font-size:13.5px;color:var(--muted);display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.v-hero-note span{display:inline-flex;align-items:center;gap:7px}
.v-hero-note svg{width:15px;height:15px;color:var(--green)}

/* ---------- App window (real product frame) ---------- */
.v-window{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-window);overflow:hidden;margin:0 auto;max-width:1040px}
.v-window-bar{display:flex;align-items:center;gap:7px;padding:13px 16px;border-bottom:1px solid var(--line);background:#FBFBFE}
.v-window-bar i{width:11px;height:11px;border-radius:50%;background:#E2E3EE;display:block}
.v-window-bar i:nth-child(1){background:#FF5F57}.v-window-bar i:nth-child(2){background:#FEBC2E}.v-window-bar i:nth-child(3){background:#28C840}
.v-window-bar small{margin-left:10px;color:var(--faint);font-size:12.5px;font-weight:500}
.v-hero-window{margin-top:56px}

/* ---------- Ticket Designer editor mockup ---------- */
.v-ed{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:var(--shadow-window)}
.v-ed-top{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--line)}
.v-ed-back{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);font-weight:600;font-size:11px;color:var(--muted)}
.v-ed-back svg{width:13px;height:13px}
.v-ed-name{font-family:var(--display);font-weight:700;font-size:12px;color:var(--head);border:1px solid var(--line-2);border-radius:7px;padding:5px 14px;background:var(--bg-soft)}
.v-ed-actions{margin-left:auto;display:flex;gap:7px}
.v-ed-btn{font-family:var(--display);font-weight:700;font-size:10.5px;padding:7px 12px;border-radius:8px}
.v-ed-btn.ghost{border:1px solid var(--line-2);color:var(--head)}
.v-ed-btn.primary{background:var(--grad);color:#fff}
.v-ed-body{display:grid;grid-template-columns:48px 1fr 154px;min-height:298px}
.v-ed-rail{background:#15162B;display:flex;flex-direction:column;align-items:center;gap:8px;padding:13px 0}
.v-ed-rail i{width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#9aa0c8}
.v-ed-rail i.on{background:var(--grad);color:#fff}
.v-ed-rail i svg{width:16px;height:16px}
.v-ed-canvas{background:#EBEDF4;background-image:radial-gradient(var(--line-2) 1px,transparent 1px);background-size:16px 16px;display:grid;place-items:center;padding:26px}
.v-ed-sel{position:relative;width:100%;max-width:300px}
.v-ed-sel img{display:block;width:100%;border-radius:6px;box-shadow:0 16px 32px -14px rgba(20,16,60,.5)}
.v-ed-sel::before{content:"";position:absolute;inset:-7px;border:1.6px solid var(--violet);border-radius:4px;pointer-events:none}
.v-ed-h{position:absolute;width:8px;height:8px;background:#fff;border:1.6px solid var(--violet);border-radius:2px}
.v-ed-h.tl{top:-11px;left:-11px}.v-ed-h.tr{top:-11px;right:-11px}.v-ed-h.bl{bottom:-11px;left:-11px}.v-ed-h.br{bottom:-11px;right:-11px}
.v-ed-h.tm{top:-11px;left:50%;transform:translateX(-50%)}.v-ed-h.bm{bottom:-11px;left:50%;transform:translateX(-50%)}
.v-ed-h.lm{left:-11px;top:50%;transform:translateY(-50%)}.v-ed-h.rm{right:-11px;top:50%;transform:translateY(-50%)}
.v-ed-props{border-left:1px solid var(--line);padding:15px 15px}
.v-ed-props .t{font-family:var(--display);font-weight:800;font-size:11.5px;color:var(--head);margin-bottom:13px}
.v-ed-props .s{font-family:var(--display);font-weight:700;font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);margin:0 0 9px}
.v-ed-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:11px}
.v-ed-lab{display:block;font-size:9px;font-weight:600;color:var(--muted);margin-bottom:3px}
.v-ed-f{border:1px solid var(--line-2);border-radius:7px;padding:6px 9px;font-size:11px;font-weight:600;color:var(--head)}
.v-ed-slider{height:4px;border-radius:2px;background:var(--line-2);position:relative;margin:6px 4px 15px 0}
.v-ed-slider span{position:absolute;width:12px;height:12px;border-radius:50%;background:var(--grad);top:50%;transform:translate(-50%,-50%);box-shadow:0 3px 8px -2px rgba(108,92,231,.7)}
@media(max-width:1000px){.v-ed-body{grid-template-columns:44px 1fr}.v-ed-props{display:none}}

/* ---------- Event Page Style preset picker mockup ---------- */
.v-eps-h{font-family:var(--display);font-weight:800;font-size:13px;color:var(--head);margin-bottom:16px}
.v-eps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.v-eps-card{position:relative;background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:11px}
.v-eps-card.on{border-color:var(--violet);box-shadow:0 0 0 3px var(--tint)}
.v-eps-check{position:absolute;top:-9px;right:-9px;width:22px;height:22px;border-radius:50%;background:var(--grad);display:grid;place-items:center;box-shadow:var(--shadow-sm)}
.v-eps-check svg{width:13px;height:13px}
.v-eps-thumb{height:76px;border-radius:9px;border:1px solid var(--line);margin-bottom:11px;display:flex;flex-direction:column;gap:5px;padding:11px;overflow:hidden}
.v-eps-card h4{font-family:var(--display);font-weight:800;font-size:12.5px;color:var(--head);margin:0 0 2px}
.v-eps-card.on h4{color:var(--purple)}
.v-eps-card p{font-family:var(--body);font-weight:600;font-size:11px;color:var(--muted);margin:0}
@media(max-width:600px){.v-eps-grid{grid-template-columns:1fr 1fr}}

/* Ticket Designer app mockup (chrome + real ticket image) */
.v-app{display:grid;grid-template-columns:60px 1fr 232px;min-height:430px;background:#F4F5FA}
.v-app-rail{background:#15162B;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 0}
.v-app-rail .vr{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.07)}
.v-app-rail .vr.on{background:var(--grad)}
.v-app-canvas{display:flex;align-items:center;justify-content:center;padding:30px;
  background-image:radial-gradient(var(--line-2) 1px,transparent 1px);background-size:18px 18px}
.v-app-canvas img{width:100%;max-width:430px;border-radius:10px;box-shadow:0 20px 44px -18px rgba(20,16,60,.4)}
.v-app-panel{background:#fff;border-left:1px solid var(--line);padding:20px 18px}
.v-app-panel .pl{height:9px;border-radius:5px;background:#E7E8F0;margin-bottom:9px;width:60%}
.v-app-panel .pf{height:34px;border-radius:9px;background:#F4F5FA;border:1px solid var(--line);margin-bottom:16px}
.v-app-panel .pbtn{height:38px;border-radius:10px;background:var(--grad);margin-top:8px}

/* ---------- Trust strip (event-kinds marquee) ---------- */
.v-trust{background:#0c0e1c;padding:44px 0 52px;overflow:hidden}
.v-trust p{text-align:center;color:rgba(255,255,255,.5);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:28px}
.v-mq{display:flex;
  -webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.v-mq-row{display:flex;overflow:hidden;width:100%}
.v-mq-track{display:flex;align-items:center;flex:0 0 auto;width:max-content;
  animation:vMqL 150s linear infinite;will-change:transform}
.v-kind{flex:0 0 auto;display:inline-flex;align-items:center;white-space:nowrap;
  font-family:var(--display);font-weight:800;font-size:23px;letter-spacing:-.01em;color:rgba(255,255,255,.9)}
.v-kind::after{content:"\00B7";margin:0 30px;color:#8B7BF7;font-weight:900}
@keyframes vMqL{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.v-mq-track{animation:none}}

/* ---------- Comparison table ---------- */
.v-cmp-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:18px;border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff}
.v-cmp{width:100%;border-collapse:collapse;min-width:820px;font-family:var(--display)}
.v-cmp th,.v-cmp td{padding:15px 18px;text-align:center;border-bottom:1px solid var(--line);vertical-align:middle}
.v-cmp tbody th{text-align:left;font-weight:700;color:var(--head);font-size:15px;width:34%}
.v-cmp tbody th small{display:block;font-weight:600;color:var(--muted);font-size:12.5px;margin-top:3px;line-height:1.4}
.v-cmp thead th{font-size:13px;color:var(--muted);font-weight:700;border-bottom:2px solid var(--line)}
.v-cmp thead .v-cmp-us{color:#fff;background:var(--grad);font-weight:800;border-bottom:none;border-top-left-radius:14px;border-top-right-radius:14px;padding:16px 18px}
.v-cmp thead .v-cmp-us b{font-size:17px}
.v-cmp thead .v-cmp-us small{display:block;font-size:11px;font-weight:700;color:rgba(255,255,255,.85);text-transform:uppercase;letter-spacing:.06em;margin-top:3px}
.v-cmp thead .v-cmp-name{font-size:16px;font-weight:800;color:var(--head)}
.v-cmp .us{background:rgba(108,92,231,.06)}
.v-cmp tbody tr:last-child th,.v-cmp tbody tr:last-child td{border-bottom:none}
.v-mk{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%}
.v-mk.yes{background:rgba(22,199,132,.16);color:#12a566}
.v-mk.yes svg{width:16px;height:16px}
.v-mk.no{color:var(--faint);font-size:18px;font-weight:800}
.v-pill-mini{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.02em;padding:5px 11px;border-radius:999px}
.v-pill-mini.addon{background:rgba(108,92,231,.12);color:#6c5ce7}
.v-pill-mini.partial{background:rgba(245,158,11,.16);color:#b76e00}
.v-cmp tfoot th,.v-cmp tfoot td{font-weight:800;color:var(--head);font-size:13px;border-top:2px solid var(--line);border-bottom:none;line-height:1.5}
.v-cmp tfoot .us{font-size:14px}
.v-cmp-legend{display:flex;gap:22px;flex-wrap:wrap;justify-content:center;margin-top:22px;color:var(--muted);font-size:13px;font-weight:600}
.v-cmp-legend span{display:inline-flex;align-items:center;gap:8px}
.v-cmp-note{text-align:center;color:var(--muted);font-size:12.5px;margin-top:16px;max-width:760px;margin-left:auto;margin-right:auto}

/* ---------- Section heading ---------- */
.v-shead{max-width:720px;margin:0 auto 60px}
.v-shead.v-center{text-align:center}
.v-shead p{font-size:18px;color:var(--text);margin-top:14px;line-height:1.6}
.v-dark .v-shead p{color:rgba(255,255,255,.72)}

/* ---------- Feature grid ---------- */
.v-bento{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.v-bento .v-cell{grid-column:span 2}
.v-bento .v-cell.wide{grid-column:span 3}
.v-cell{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;
  transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,border-color .18s}
.v-cell:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.v-cell-ic{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px;color:#fff;background:var(--grad);box-shadow:0 8px 18px -8px rgba(108,92,231,.7)}
.v-cell-ic svg{width:25px;height:25px}
.v-cell h3{font-size:20px;margin-bottom:7px}
.v-cell p{font-size:15px;margin:0;color:var(--text)}
.v-tag{position:absolute;top:20px;right:20px;font-family:var(--display);font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--purple);background:var(--bg-tint);padding:5px 10px;border-radius:999px}
.v-tag.addon{color:var(--muted);background:var(--bg-soft)}

/* ---------- Split deep-dive ---------- */
.v-split{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.v-split.rev .v-split-media{order:2}
.v-split-body h2{font-size:clamp(28px,3.4vw,42px)}
.v-split-body .v-lead{margin-top:14px}
.v-checks{margin:26px 0 0;display:grid;gap:12px}
.v-checks li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px;color:var(--head);font-weight:500}
.v-ck{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--grad);display:grid;place-items:center;margin-top:1px}
.v-ck svg{width:12px;height:12px}
.v-split-cta{margin-top:28px}
.v-media-wrap{position:relative}
.v-media-glow{display:none}
.v-shot{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff}
.v-shot-pad{padding:24px;background:var(--grad-soft)}
.v-shot-pad img{border-radius:12px;box-shadow:0 18px 40px -18px rgba(20,16,60,.35);width:100%}

/* ---------- Stats ---------- */
.v-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.v-stat b{display:block;font-family:var(--display);font-weight:800;font-size:clamp(32px,4vw,46px);letter-spacing:-.03em;color:var(--head)}
.v-stat span{color:var(--muted);font-size:14px;font-weight:600;margin-top:4px;display:block}

/* ---------- Unlimited: animated infinity + check list ---------- */
.v-unlim2{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center;max-width:980px;margin:0 auto}
.v-unlim-inf{display:flex;justify-content:center;align-items:center}
.v-unlim-inf svg{width:100%;max-width:470px;height:auto;overflow:visible}
.v-unlim-list{display:grid;gap:16px}
.v-unlim-list li{display:flex;align-items:center;gap:13px;font-family:var(--display);font-weight:700;font-size:18px;color:var(--head)}
.v-unlim-list .ck{flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:var(--grad);display:grid;place-items:center;box-shadow:0 6px 14px -6px rgba(108,92,231,.7)}
.v-unlim-list .ck svg{width:16px;height:16px}
@media(max-width:800px){.v-unlim2{grid-template-columns:1fr;gap:32px;max-width:440px}.v-unlim-inf svg{max-width:320px}}

/* ---------- Dark sections ---------- */
.v-dark{background:#14132A;color:rgba(255,255,255,.72);position:relative;overflow:hidden;isolation:isolate}
.v-dark h2,.v-dark h3,.v-dark h4{color:#fff}
.v-dark-bg{position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(680px 360px at 84% -10%,rgba(124,92,255,.32),transparent 62%),radial-gradient(520px 320px at 6% 110%,rgba(14,165,163,.14),transparent 60%)}

/* ---------- Pricing ---------- */
.v-prices{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.v-price{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);padding:32px;display:flex;flex-direction:column;color:rgba(255,255,255,.78);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}
.v-price.feat{background:rgba(124,92,255,.14);box-shadow:0 30px 70px -28px rgba(124,92,255,.6)}
.v-price.feat::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);padding:1.5px;background:var(--grad);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.v-price-badge{align-self:flex-start;font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--grad);padding:5px 12px;border-radius:999px;margin-bottom:14px}
.v-price h3{font-size:21px;margin-bottom:4px;color:#fff}
.v-price-desc{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:18px;min-height:42px}
.v-price-amt{font-family:var(--display);font-weight:800;color:#fff;font-size:42px;line-height:1;letter-spacing:-.03em}
.v-price-amt span{font-size:15px;font-weight:600;color:rgba(255,255,255,.55)}
.v-price ul{margin:20px 0 26px;display:grid;gap:11px}
.v-price li{display:flex;gap:10px;font-size:14.5px;color:rgba(255,255,255,.78)}
.v-price li svg{flex:0 0 auto;width:18px;height:18px;margin-top:3px;color:var(--violet)}
.v-price .v-btn{margin-top:auto;width:100%}

/* ---------- Value ---------- */
.v-quote{max-width:880px;margin:0 auto;text-align:center}
.v-quote blockquote{font-family:var(--display);font-weight:700;font-size:clamp(24px,3.2vw,38px);line-height:1.3;color:var(--head);letter-spacing:-.025em;margin:0}

/* ---------- CTA ---------- */
.v-cta-box{position:relative;overflow:hidden;background:var(--grad);border-radius:var(--r-xl);padding:64px 64px;text-align:center;color:#fff;
  --vn:24px;
  -webkit-mask:radial-gradient(circle at left,transparent var(--vn),#000 calc(var(--vn) + .5px)) left / 50.5% 100% no-repeat,radial-gradient(circle at right,transparent var(--vn),#000 calc(var(--vn) + .5px)) right / 50.5% 100% no-repeat;
          mask:radial-gradient(circle at left,transparent var(--vn),#000 calc(var(--vn) + .5px)) left / 50.5% 100% no-repeat,radial-gradient(circle at right,transparent var(--vn),#000 calc(var(--vn) + .5px)) right / 50.5% 100% no-repeat;
  filter:drop-shadow(0 28px 48px rgba(76,55,196,.32))}
.v-cta-glow{position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(520px 280px at 50% -20%,rgba(255,255,255,.28),transparent 60%)}
.v-cta-box>*{position:relative;z-index:1}
.v-cta-box h2{color:#fff}
.v-cta-box p{color:rgba(255,255,255,.9);font-size:19px;max-width:580px;margin:0 auto 28px}
.v-cta-box .v-btn-foil,.v-cta-box .v-btn-light{background:#fff;color:var(--purple-d);border-color:#fff}
.v-cta-box .v-btn-foil:hover,.v-cta-box .v-btn-light:hover{background:#fff;color:var(--purple-dd);transform:translateY(-2px)}

/* ---------- Footer ---------- */
.v-footer{background:#14132A;color:rgba(255,255,255,.55);padding:78px 0 30px}
.v-footer a{color:rgba(255,255,255,.66)}.v-footer a:hover{color:#fff}
.v-foot-grid{display:grid;grid-template-columns:1.9fr 1fr 1fr;gap:52px;margin-bottom:52px}
.v-foot-brand .v-brand{color:#fff;margin-bottom:16px}
.v-foot-brand p{font-size:14.5px;color:rgba(255,255,255,.5);max-width:320px;line-height:1.6}
.v-foot-col h4{color:#fff;font-size:13px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;font-weight:700}
.v-foot-col ul{display:grid;gap:6px}
.v-foot-col li{line-height:1.2}
.v-foot-col li a{display:inline-block;padding:0}
.v-foot-col a{font-size:14.5px}
.v-foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:13.5px;color:rgba(255,255,255,.5)}
.v-foot-bottom nav{display:flex;gap:20px;flex-wrap:wrap}

/* ---------- Showcase grid (everything, framed) ---------- */
.v-showcase{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.v-sc{grid-column:span 2;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,border-color .18s}
.v-sc.feat{grid-column:span 3}
.v-sc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.v-sc-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.v-sc-bar .nm{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:700;font-size:14.5px;color:var(--head)}
.v-sc-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:#fff;background:var(--grad)}
.v-sc-ic svg{width:16px;height:16px}
.v-sc-chip{font-family:var(--display);font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--bg-soft);padding:4px 9px;border-radius:999px}
.v-sc-chip.free{color:var(--purple);background:var(--bg-tint)}
.v-sc-view{padding:18px;background:linear-gradient(180deg,#FBFBFE,#F4F5FA);min-height:172px;display:flex;align-items:center;justify-content:center}
.v-sc-view img{width:100%;border-radius:9px;box-shadow:0 14px 30px -16px rgba(20,16,60,.4)}
.v-sc-foot{padding:14px 18px 18px;font-size:13.5px;color:var(--text)}

.m-pos{display:grid;grid-template-columns:1fr 86px;gap:10px;width:100%}
.m-pos .grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.m-pos .it{height:40px;border-radius:8px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.m-pos .it:nth-child(1){border-top:3px solid var(--purple)}.m-pos .it:nth-child(2){border-top:3px solid var(--teal)}
.m-pos .it:nth-child(3){border-top:3px solid var(--amber)}.m-pos .it:nth-child(4){border-top:3px solid var(--pink)}
.m-pos .cart{background:#15162B;border-radius:8px;padding:9px;display:flex;flex-direction:column}
.m-pos .cart .ln{height:6px;border-radius:3px;background:rgba(255,255,255,.18);margin-bottom:7px}
.m-pos .cart .pay{height:22px;border-radius:6px;background:var(--grad);margin-top:auto}
.m-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;width:100%}
.m-cal i{aspect-ratio:1;border-radius:6px;background:#fff;border:1px solid var(--line);display:block}
.m-cal i.on{background:var(--grad);border-color:transparent}
.m-cal i.dim{background:#F0F1F6;border-color:transparent}
.m-fields{width:100%;display:grid;gap:11px}
.m-fields .lbl{height:7px;width:42%;border-radius:4px;background:#D9DBE6}
.m-fields .inp{height:30px;border-radius:8px;background:#fff;border:1px solid var(--line)}
.m-fields .rad{display:flex;gap:16px;align-items:center}
.m-fields .rad .r{width:16px;height:16px;border-radius:50%;border:2px solid var(--line-2);position:relative}
.m-fields .rad .r.on{border-color:var(--purple)}
.m-fields .rad .r.on::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--purple)}
.m-fields .rad b{height:7px;width:40px;border-radius:4px;background:#D9DBE6;display:block}
.m-scan{position:relative;width:128px;height:128px;border-radius:14px;background:#15162B;display:grid;place-items:center;overflow:hidden}
.m-scan .qr{width:74px;height:74px;border-radius:8px;
  background-image:repeating-linear-gradient(0deg,#15162B 0 6px,#fff 6px 12px),repeating-linear-gradient(90deg,#15162B 0 6px,#fff 6px 12px);
  background-blend-mode:multiply;background-size:12px 12px;background-color:#fff}
.m-scan .ok{position:absolute;right:14px;bottom:14px;width:34px;height:34px;border-radius:50%;background:var(--green);display:grid;place-items:center;color:#fff;box-shadow:0 6px 16px -4px rgba(22,163,74,.7)}
.m-scan .ok svg{width:18px;height:18px}
.m-scan .beam{position:absolute;left:8%;right:8%;height:2px;background:linear-gradient(90deg,transparent,var(--violet),transparent);top:50%;box-shadow:0 0 12px 2px rgba(139,124,246,.6)}

/* ---------- Hero scene (one composed image: ticket + orbiting product chips) ---------- */
.v-scene{position:relative;max-width:1120px;margin:8px auto 0;height:412px}
.v-scene-glow{position:absolute;left:50%;top:46%;width:860px;height:460px;transform:translate(-50%,-50%);
  background:radial-gradient(closest-side,rgba(124,92,255,.28),rgba(124,92,255,.09) 52%,transparent 72%);
  filter:blur(8px);pointer-events:none}
.v-scene-glow.b{width:520px;height:300px;background:radial-gradient(closest-side,rgba(14,165,163,.16),transparent 70%);left:66%;top:64%}
.v-scene::after{content:"";position:absolute;left:50%;top:calc(50% + 108px);width:560px;height:52px;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(20,16,60,.20),transparent 74%);filter:blur(5px);pointer-events:none;z-index:1}

/* central ticket */
.v-ticket{position:absolute;left:50%;top:50%;width:540px;transform:translate(-50%,-50%) rotate(-3deg);
  filter:drop-shadow(0 40px 70px rgba(20,16,60,.40)) drop-shadow(0 8px 18px rgba(20,16,60,.25));z-index:5;
  animation:floatY 7s ease-in-out infinite}
.v-ticket svg{width:100%;height:auto;display:block;border-radius:18px}
.v-ticket-tag{position:absolute;left:50%;top:calc(50% - 150px);transform:translateX(-50%) rotate(-3deg);z-index:6;
  font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#fff;
  background:var(--grad);padding:6px 13px;border-radius:999px;box-shadow:0 10px 22px -8px rgba(108,92,231,.7);white-space:nowrap}

/* floating product chips */
.v-orb{position:absolute;z-index:4;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border-radius:16px;box-shadow:0 30px 60px -22px rgba(20,16,60,.40),0 6px 16px -8px rgba(20,16,60,.18);
  padding:13px 14px;animation:floatY 8s ease-in-out infinite}
.v-orb .ochip{display:none}
.v-orb .ohd{display:flex;align-items:center;gap:8px;margin-bottom:11px}
.v-orb .oic{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:#fff;background:var(--grad);flex:0 0 auto}
.v-orb .oic svg{width:15px;height:15px}
.v-orb .olb{font-family:var(--display);font-weight:700;font-size:12.5px;color:var(--head);line-height:1.1}
.v-orb .ochip{font-family:var(--display);font-weight:700;font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-left:auto;background:var(--bg-soft);padding:3px 7px;border-radius:999px}
.v-orb .ochip.free{color:var(--purple);background:var(--bg-tint)}
.v-orb .obody{width:150px}

.o-pos  {left:-12px; top:96px;  animation-delay:-1.2s}
.o-cal  {left:88px;  top:-6px;  animation-delay:-3.4s}
.o-scan {right:46px; top:14px;  animation-delay:-2.1s}
.o-seat {right:-22px;top:188px; animation-delay:-4.6s}
.o-field{left:118px; bottom:6px;animation-delay:-0.6s}

@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.v-ticket{animation-name:floatTicket}
@keyframes floatTicket{0%,100%{transform:translate(-50%,-50%) rotate(-3deg)}50%{transform:translate(-50%,calc(-50% - 9px)) rotate(-3deg)}}

@media(max-width:1000px){
  .v-scene{height:480px;transform:scale(.86)}
}
@media(max-width:760px){
  .v-scene{height:330px;transform:scale(.62);margin:-40px auto -30px}
  .o-cal,.o-seat{display:none}
}
@media(prefers-reduced-motion:reduce){.v-ticket,.v-orb{animation:none}}

/* ---------- Premium light split hero (ticket is the hero) ---------- */
.v-hero.v-hero-lux{padding:0;color:var(--ink);
  background:
    radial-gradient(1000px 640px at 50% -14%,#ECE6FF,transparent 60%),
    radial-gradient(720px 540px at 94% 22%,#E3FBF6,transparent 56%),
    radial-gradient(680px 540px at 2% 98%,#F1E9FF,transparent 60%),
    linear-gradient(180deg,#FCFBFF,#F7F5FE)}
.v-hero-aura{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.v-hero-aura::before,.v-hero-aura::after{content:"";position:absolute;border-radius:50%;filter:blur(50px)}
.v-hero-aura::before{width:360px;height:360px;right:12%;top:10%;background:radial-gradient(closest-side,rgba(124,92,255,.20),transparent 70%)}
.v-hero-aura::after{width:300px;height:300px;left:46%;bottom:4%;background:radial-gradient(closest-side,rgba(14,165,163,.16),transparent 70%)}
.v-hero-lux .v-container{position:relative;z-index:1}
.v-hero-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:44px;align-items:center;min-height:90vh;padding:120px 0 84px}
.v-hero-copy{max-width:560px;text-align:left}
.v-hero-copy .v-h1{color:var(--head);font-size:clamp(38px,4.3vw,58px);line-height:1.04;letter-spacing:-.035em}
.v-hero-copy .v-hero-sub{color:var(--text);max-width:none;margin:22px 0 32px;font-size:17px}
.v-hero-copy .v-hero-sub strong{color:var(--head);font-weight:600}
.v-hero-copy .v-hero-cta{justify-content:flex-start;margin:0}
.v-hero-copy .v-hero-note{justify-content:flex-start;color:var(--muted);margin-top:20px}

/* scene tuned for the right column - ticket large and dominant */
.v-hero-stage{position:relative;min-height:520px}
.v-hero-stage .v-scene{height:520px;margin:0;max-width:none}
.v-hero-stage .v-ticket{width:486px;filter:drop-shadow(0 40px 70px rgba(30,20,70,.30)) drop-shadow(0 10px 22px rgba(30,20,70,.16))}
.v-hero-stage .v-ticket-tag{top:calc(50% - 172px)}
.v-hero-stage .v-scene-glow{width:660px;height:500px;background:radial-gradient(closest-side,rgba(124,92,255,.22),transparent 70%)}
.v-hero-stage .v-scene-glow.b{background:radial-gradient(closest-side,rgba(14,165,163,.14),transparent 70%)}

/* small product pills */
.v-pill{position:absolute;z-index:6;display:inline-flex;align-items:center;gap:10px;white-space:nowrap;
  background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  padding:9px 16px 9px 9px;border-radius:999px;font-family:var(--display);font-weight:700;font-size:13.5px;color:var(--head);
  box-shadow:0 18px 38px -16px rgba(30,20,70,.30),0 4px 10px -6px rgba(30,20,70,.16);
  animation:floatY 8s ease-in-out infinite}
.v-pill .pic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;color:#fff;background:var(--grad);flex:0 0 auto;box-shadow:0 6px 14px -6px rgba(108,92,231,.7)}
.v-pill .pic svg{width:17px;height:17px}

.v-hero-stage .o-cal{left:14px;top:44px}
.v-hero-stage .o-scan{right:-6px;top:96px}
.v-hero-stage .o-pos{left:-18px;top:396px}
.v-hero-stage .o-field{left:206px;top:430px;bottom:auto}
.v-hero-stage .o-seat{right:0;top:392px}

@media(max-width:1000px){
  .v-hero-grid{grid-template-columns:1fr;gap:0;min-height:0;padding:118px 0 36px}
  .v-hero-copy{max-width:680px;margin:0 auto;text-align:center}
  .v-hero-copy .v-hero-cta,.v-hero-copy .v-hero-note{justify-content:center}
  .v-hero-stage{margin-top:24px}
}

/* ---------- Reveal ---------- */
.v-reveal{opacity:0;transform:translateY(22px);transition:opacity .6s cubic-bezier(.2,.7,.3,1),transform .6s cubic-bezier(.2,.7,.3,1)}
.v-reveal.in{opacity:1;transform:none}

/* ---------- Add-on pages (reskinned bright) ---------- */
.v-hero.v-ahero{padding:150px 0 90px}
.v-ahero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:60px;align-items:center}
.v-ahero-body{text-align:left}
.v-ahero-media .v-window,.v-ahero-media .v-shot{margin:0}
.v-highlight{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;background:var(--grad-soft);border:1px solid var(--line);border-radius:var(--r-xl);padding:48px 52px}
.v-everything{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px;max-width:920px;margin:0 auto}
.v-everything li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px;color:var(--head);font-weight:500;padding-bottom:14px;border-bottom:1px solid var(--line)}
.v-everything-tick{flex:0 0 auto;width:22px;height:22px;border-radius:6px;display:grid;place-items:center;color:var(--purple);background:var(--bg-tint)}
.v-everything-tick svg{width:13px;height:13px}
.v-addons-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.v-addon-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,border-color .18s}
.v-addon-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--violet)}
.v-addon-card.is-free{border-color:var(--violet)}
.v-addon-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.v-addon-ic{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;color:#fff;background:var(--grad)}
.v-addon-ic svg{width:25px;height:25px}
.v-addon-badge{font-family:var(--display);font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:var(--bg-soft);padding:5px 11px;border-radius:999px}
.v-addon-badge.free{color:var(--purple);background:var(--bg-tint)}
.v-addon-card h3{font-size:21px;margin-bottom:8px;color:var(--head)}
.v-addon-card p{font-size:15px;color:var(--text);margin:0 0 20px;flex:1}
.v-addon-link{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:700;font-size:14.5px;color:var(--purple)}
.v-addon-card:hover .v-addon-link .v-arrow{transform:translateX(3px)}
.v-addon-link .v-arrow{transition:transform .18s}

/* ---------- Prose ---------- */
.v-page{min-height:60vh;padding-top:120px}
.v-prose{font-size:17px;color:var(--text)}
.v-prose h2{font-size:30px;margin:1.4em 0 .5em;color:var(--head)}
.v-prose a{color:var(--purple);text-decoration:underline}
.v-prose ul,.v-prose ol{padding-left:1.2em;margin:0 0 1em;list-style:revert}

/* ---------- Brand mark (identical to POS) ---------- */
.v-mark{--vm:40px;--vm-notch:calc(var(--vm) * 0.152);width:var(--vm);height:var(--vm);flex:0 0 auto;
  display:inline-grid;place-items:center;line-height:1;border-radius:3px;background:var(--purple);
  color:#fff;font-family:'Inter',system-ui,sans-serif;font-weight:800;font-size:calc(var(--vm) * 0.48);
  -webkit-mask:radial-gradient(circle at left,transparent var(--vm-notch),#000 calc(var(--vm-notch) + .5px)) left / 50.5% 100% no-repeat,radial-gradient(circle at right,transparent var(--vm-notch),#000 calc(var(--vm-notch) + .5px)) right / 50.5% 100% no-repeat;
          mask:radial-gradient(circle at left,transparent var(--vm-notch),#000 calc(var(--vm-notch) + .5px)) left / 50.5% 100% no-repeat,radial-gradient(circle at right,transparent var(--vm-notch),#000 calc(var(--vm-notch) + .5px)) right / 50.5% 100% no-repeat;}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .v-bento{grid-template-columns:repeat(2,1fr)}.v-bento .v-cell,.v-bento .v-cell.wide{grid-column:span 1}
  .v-prices{grid-template-columns:1fr;max-width:440px;margin:0 auto}
  .v-split,.v-ahero-grid{grid-template-columns:1fr;gap:44px}.v-split.rev .v-split-media{order:0}
  .v-highlight{grid-template-columns:1fr;gap:28px;padding:36px 28px}
  .v-foot-grid{grid-template-columns:1fr 1fr;gap:34px}.v-stats{grid-template-columns:repeat(2,1fr);gap:32px}
  .v-everything{grid-template-columns:1fr}.v-addons-grid{grid-template-columns:repeat(2,1fr)}
  .v-app{grid-template-columns:48px 1fr}.v-app-panel{display:none}
}
@media(max-width:760px){
  .v-section{padding:68px 0}.v-hero{padding:128px 0 64px}
  .v-nav-menu,.v-signin{display:none}.v-nav-toggle{display:flex}
  .v-nav.open .v-nav-menu{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);padding:14px 24px;gap:4px}
  .v-nav.open .v-nav-menu a{color:var(--head);padding:12px 10px;opacity:1}
  .v-bento,.v-addons-grid{grid-template-columns:1fr}
  .v-hero-cta{flex-direction:column}.v-hero-cta .v-btn{width:100%}
  .v-cta-box{padding:48px 24px}.v-foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){.v-stats{grid-template-columns:1fr 1fr}.v-foot-grid{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.v-reveal{opacity:1;transform:none}}

/* ========================================================================
   PRICING PAGE
   ======================================================================== */
.v-price-hero{padding:140px 0 12px;text-align:center;position:relative;overflow:hidden;
  background:radial-gradient(900px 460px at 50% -16%,var(--bg-tint),transparent 62%),var(--bg)}
.v-price-hero .v-h1{font-size:clamp(36px,4.4vw,56px)}
.v-price-hero .v-lead{max-width:620px;margin:18px auto 0}

/* billing toggle */
.v-toggle{display:inline-flex;align-items:center;gap:4px;background:#fff;border:1px solid var(--line-2);
  border-radius:999px;padding:5px;margin:30px auto 0;box-shadow:var(--shadow-sm)}
.v-toggle button{appearance:none;border:0;background:transparent;cursor:pointer;font-family:var(--display);
  font-weight:700;font-size:14px;color:var(--muted);padding:9px 20px;border-radius:999px;transition:.18s}
.v-toggle button.on{background:var(--grad);color:#fff;box-shadow:0 8px 18px -8px rgba(108,92,231,.6)}
.v-toggle .save{font-family:var(--body);font-weight:600;font-size:11px;color:var(--green);margin-left:2px}
.v-toggles{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.v-toggles .v-toggle{margin:0}
.v-nofee{display:inline-flex;align-items:center;gap:8px;margin:20px auto 0;font-family:var(--display);font-weight:700;
  font-size:14px;color:var(--head);background:#EAF7EF;border:1px solid #CBEBD7;padding:9px 16px;border-radius:999px}
.v-nofee svg{width:17px;height:17px;color:var(--green)}

/* plan cards (light) */
.v-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch;margin-top:48px}
.v-plan{position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow-sm);transition:transform .18s,box-shadow .18s}
.v-plan:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.v-plan.feat{border-color:transparent;box-shadow:var(--shadow-lg)}
.v-plan.feat::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);padding:1.6px;background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.v-plan-badge{align-self:flex-start;font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:#fff;background:var(--grad);padding:5px 12px;border-radius:999px;margin-bottom:14px}
.v-plan h3{font-size:21px;margin-bottom:5px;color:var(--head)}
.v-plan-desc{font-size:14px;color:var(--muted);margin-bottom:18px;min-height:40px}
.v-plan-price{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.v-plan-price b{font-family:var(--display);font-weight:800;font-size:46px;line-height:1;letter-spacing:-.03em;color:var(--head)}
.v-plan-price span{font-size:15px;font-weight:600;color:var(--muted)}
.v-plan-note{font-size:12.5px;color:var(--faint);margin-bottom:22px;min-height:18px}
.v-plan ul{display:grid;gap:11px;margin:4px 0 26px}
.v-plan li{display:flex;gap:10px;font-size:14.5px;color:var(--text)}
.v-plan li svg{flex:0 0 auto;width:18px;height:18px;margin-top:3px;color:var(--purple)}
.v-plan .v-btn{margin-top:auto;width:100%}

/* comparison table */
.v-compare-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;box-shadow:var(--shadow-sm)}
.v-compare{width:100%;border-collapse:collapse;min-width:680px}
.v-compare th,.v-compare td{padding:15px 18px;text-align:left;border-bottom:1px solid var(--line);font-size:14.5px}
.v-compare thead th{font-family:var(--display);font-weight:800;color:var(--head);font-size:14px;background:var(--bg-soft);position:sticky;top:0}
.v-compare thead th:first-child{border-top-left-radius:var(--r-lg)}
.v-compare tbody th{font-weight:600;color:var(--head)}
.v-compare td{text-align:center;color:var(--text)}
.v-compare td:first-child,.v-compare th:first-child{text-align:left}
.v-compare .yes{color:var(--green)}
.v-compare .no{color:var(--faint)}
.v-compare .grp td{background:var(--bg-soft);font-family:var(--display);font-weight:700;color:var(--head);font-size:12.5px;letter-spacing:.04em;text-transform:uppercase}
.v-compare tbody tr:hover td,.v-compare tbody tr:hover th{background:#FBFAFF}
.v-compare svg{width:19px;height:19px;display:inline-block;vertical-align:middle}

/* FAQ */
.v-faq{max-width:820px;margin:0 auto;display:grid;gap:12px}
.v-faq details{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:4px 22px;box-shadow:var(--shadow-sm)}
.v-faq summary{list-style:none;cursor:pointer;font-family:var(--display);font-weight:700;font-size:16.5px;color:var(--head);
  padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:16px}
.v-faq summary::-webkit-details-marker{display:none}
.v-faq summary::after{content:"+";font-size:24px;font-weight:400;color:var(--purple);transition:transform .2s;line-height:1}
.v-faq details[open] summary::after{transform:rotate(45deg)}
.v-faq p{margin:0 0 18px;color:var(--text);font-size:15px;line-height:1.6}

@media(max-width:900px){.v-plans{grid-template-columns:1fr;max-width:440px;margin:48px auto 0}}

/* ---------- Add-ons catalog (archive) ---------- */
.v-ac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.v-ac-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,border-color .18s}
.v-ac-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--violet)}
.v-ac-cover{position:relative;height:130px;display:grid;place-items:center;background:var(--grad-soft);border-bottom:1px solid var(--line)}
.v-ac-card.free .v-ac-cover{background:linear-gradient(160deg,#EDE8FE,#E4DCFD)}
.v-ac-ic{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;color:#fff;background:var(--grad);box-shadow:0 14px 28px -8px rgba(108,92,231,.7)}
.v-ac-ic svg{width:30px;height:30px}
.v-ac-tag{position:absolute;top:13px;right:13px;font-family:var(--display);font-size:10.5px;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;color:var(--muted);background:#fff;padding:5px 11px;border-radius:999px;box-shadow:var(--shadow-sm)}
.v-ac-card.free .v-ac-tag{color:var(--purple)}
.v-ac-body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.v-ac-body h3{font-size:20px;margin-bottom:8px;color:var(--head)}
.v-ac-body p{font-size:14.5px;color:var(--text);margin:0 0 18px;flex:1}
@media(max-width:1000px){.v-ac-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.v-ac-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}}

/* ---------- Add-on buy block ---------- */
#buy{scroll-margin-top:96px}
.v-buy{display:grid;grid-template-columns:1.2fr .8fr;gap:44px;align-items:center;
  background:var(--grad-soft);border:1px solid var(--line);border-radius:var(--r-xl);padding:44px 48px}
.v-buy-info h2{font-size:clamp(26px,3vw,38px)}
.v-buy-info .v-lead{margin:12px 0 22px}
.v-buy-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 26px 22px;box-shadow:var(--shadow)}
.v-buy-row{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line)}
.v-buy-row:first-child{padding-top:0}
.v-buy-row > span{flex:1;color:var(--muted);font-weight:600;font-size:14px}
.v-buy-row b{font-family:var(--display);font-weight:800;font-size:26px;color:var(--head);letter-spacing:-.02em}
.v-buy-row small{font-size:13px;font-weight:600;color:var(--muted);margin-left:2px}
.v-tier{margin-left:auto;margin-right:auto}

/* ========================================================================
   CONTACT PAGE
   ======================================================================== */
.v-contact-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:start}
.v-form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow-sm)}
.v-field{margin-bottom:18px}
.v-field label{display:block;font-family:var(--display);font-weight:700;font-size:13.5px;color:var(--head);margin-bottom:7px}
.v-field input,.v-field select,.v-field textarea{width:100%;font:inherit;font-size:15px;color:var(--head);
  background:var(--bg-soft);border:1px solid var(--line-2);border-radius:11px;padding:13px 15px;transition:border-color .15s,box-shadow .15s}
.v-field input:focus,.v-field select:focus,.v-field textarea:focus{outline:none;border-color:var(--violet);background:#fff;box-shadow:0 0 0 4px var(--tint)}
.v-field textarea{min-height:140px;resize:vertical}
.v-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.v-form .v-btn{width:100%;margin-top:6px}
.v-form-note{font-size:12.5px;color:var(--muted);text-align:center;margin:14px 0 0}
.v-contact-aside{display:grid;gap:16px}
.v-cinfo{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow-sm)}
.v-cinfo .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;color:#fff;background:var(--grad);margin-bottom:13px}
.v-cinfo .ic svg{width:21px;height:21px}
.v-cinfo h3{font-size:16.5px;margin-bottom:4px;color:var(--head)}
.v-cinfo p{font-size:14px;color:var(--text);margin:0 0 8px}
.v-cinfo a{font-family:var(--display);font-weight:700;font-size:14px}

/* ========================================================================
   BLOG
   ======================================================================== */
.v-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.v-post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s cubic-bezier(.2,.7,.3,1),box-shadow .18s,border-color .18s}
.v-post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--line-2)}
.v-post-cover{aspect-ratio:16/10;background:var(--grad-soft);position:relative;overflow:hidden;display:block}
.v-post-cover img{width:100%;height:100%;object-fit:cover}
.v-post-cover .ph{position:absolute;inset:0;display:grid;place-items:center;color:#fff;opacity:.9}
.v-post-cover .ph svg{width:42px;height:42px}
.v-post-body{padding:22px 24px 24px;display:flex;flex-direction:column;flex:1}
.v-post-meta{font-family:var(--display);font-weight:600;font-size:12.5px;color:var(--purple);letter-spacing:.02em;margin-bottom:9px}
.v-post-body h3{font-size:19px;line-height:1.25;margin-bottom:9px}
.v-post-body h3 a{color:var(--head)}
.v-post-body h3 a:hover{color:var(--purple)}
.v-post-body p{font-size:14.5px;color:var(--text);margin:0 0 18px;flex:1}
.v-post-more{font-family:var(--display);font-weight:700;font-size:14px;color:var(--purple);display:inline-flex;align-items:center;gap:7px}
.v-post-card:hover .v-post-more .v-arrow{transform:translateX(3px)}
.v-blog-empty{text-align:center;color:var(--muted);padding:60px 0}

/* single post */
.v-single{max-width:760px;margin:0 auto}
.v-single-cover{border-radius:var(--r-lg);overflow:hidden;margin:0 0 36px;box-shadow:var(--shadow);aspect-ratio:16/8}
.v-single-cover img{width:100%;height:100%;object-fit:cover}
.v-pager{display:flex;justify-content:space-between;gap:16px;margin-top:54px;padding-top:26px;border-top:1px solid var(--line)}
.v-pager a{font-family:var(--display);font-weight:700;font-size:14.5px;color:var(--purple)}

.v-pagination ul{display:inline-flex;gap:8px;list-style:none;padding:0;margin:0;flex-wrap:wrap;justify-content:center}
.v-pagination .page-numbers{display:grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border-radius:11px;
  border:1px solid var(--line-2);background:#fff;font-family:var(--display);font-weight:700;font-size:14.5px;color:var(--head);text-decoration:none}
.v-pagination a.page-numbers:hover{border-color:var(--violet);color:var(--purple)}
.v-pagination .page-numbers.current{background:var(--grad);color:#fff;border-color:transparent}

/* ========================================================================
   DOCS
   ======================================================================== */
.v-docsearch{max-width:520px;margin:26px auto 0;position:relative}
.v-docsearch input{width:100%;font:inherit;font-size:16px;color:var(--head);background:#fff;border:1px solid var(--line-2);
  border-radius:14px;padding:15px 18px 15px 48px;box-shadow:var(--shadow-sm)}
.v-docsearch input:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 4px var(--tint)}
.v-docsearch svg{position:absolute;left:17px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--muted)}
.v-docs-layout{display:grid;grid-template-columns:248px 1fr;gap:52px;align-items:start}
.v-docs-nav{position:sticky;top:100px}
.v-docs-nav h4{font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 12px;padding-left:14px}
.v-docs-nav ul{display:grid;gap:2px;margin-bottom:22px}
.v-docs-nav a{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:10px;font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--text)}
.v-docs-nav a:hover{background:var(--bg-soft);color:var(--head)}
.v-docs-nav a .di{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;color:#fff;background:var(--grad);flex:0 0 auto}
.v-docs-nav a .di svg{width:15px;height:15px}
.v-docs-sec{scroll-margin-top:100px;padding-bottom:40px;margin-bottom:40px;border-bottom:1px solid var(--line)}
.v-docs-sec:last-child{border-bottom:0;margin-bottom:0}
.v-docs-sec-head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.v-docs-sec-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff;background:var(--grad);flex:0 0 auto;box-shadow:0 10px 22px -8px rgba(108,92,231,.6)}
.v-docs-sec-ic svg{width:23px;height:23px}
.v-docs-sec h2{font-size:24px;margin:0}
.v-docs-sec-tag{font-family:var(--display);font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--purple);background:var(--bg-tint);padding:4px 9px;border-radius:999px;margin-left:auto}
.v-docs-sec-tag.addon{color:var(--muted);background:var(--bg-soft)}
.v-docs-sec > p{color:var(--text);margin:0 0 18px;font-size:15px}
.v-docs-topics{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.v-docs-topics a{display:flex;align-items:center;gap:10px;padding:13px 16px;border:1px solid var(--line);border-radius:11px;
  background:#fff;font-size:14.5px;font-weight:500;color:var(--head);transition:border-color .15s,box-shadow .15s,transform .15s}
.v-docs-topics a:hover{border-color:var(--violet);box-shadow:var(--shadow-sm);transform:translateY(-2px)}
.v-docs-topics a svg{width:15px;height:15px;color:var(--purple);flex:0 0 auto}
@media(max-width:900px){.v-docs-layout{grid-template-columns:1fr;gap:30px}.v-docs-nav{position:static;display:none}.v-docs-topics{grid-template-columns:1fr}}

@media(max-width:900px){.v-contact-grid{grid-template-columns:1fr;gap:30px}.v-blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.v-blog-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto}.v-field-row{grid-template-columns:1fr}}
.v-buy-amt{display:flex;align-items:baseline;gap:5px;padding:6px 0 16px}
.v-buy-amt b{font-family:var(--display);font-weight:800;font-size:42px;line-height:1;letter-spacing:-.03em;color:var(--head)}
.v-buy-amt .per{font-size:15px;font-weight:600;color:var(--muted)}
.v-buy-card .v-btn{margin-top:18px;width:100%}
.v-buy-foot{font-size:12px;color:var(--faint);text-align:center;margin:12px 0 0}
.v-buy-opts{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:780px;margin:0 auto;text-align:left}
.v-buy-card h3{font-family:var(--display);font-size:18px;font-weight:800;color:var(--head);margin:0 0 3px}
.v-buy-card .v-buy-sub{font-size:13px;color:var(--muted);margin:0 0 14px}
.v-buy-card.feat{border-color:transparent;box-shadow:var(--shadow-lg)}
.v-buy-card.feat::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);padding:1.5px;background:var(--grad);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.v-buy-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);font-family:var(--display);font-size:10.5px;
  font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--grad);padding:5px 12px;border-radius:999px;white-space:nowrap}
@media(max-width:800px){.v-buy{grid-template-columns:1fr;gap:28px;padding:32px 26px}.v-buy-opts{grid-template-columns:1fr;max-width:420px}}

/* ============================================================
   DOCS — single article + category listing (Tickera-style)
   ============================================================ */
.v-doc-wrap{padding:38px 0 80px}
.v-doc-crumb{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:var(--display);font-size:13.5px;color:var(--muted);margin-bottom:26px}
.v-doc-crumb a{color:var(--muted)}
.v-doc-crumb a:hover{color:var(--purple)}
.v-doc-crumb .cur{color:var(--head);font-weight:600}
.v-doc-crumb span{color:var(--faint)}

.v-doc-grid{display:grid;grid-template-columns:262px 1fr;gap:56px;align-items:start}

/* Sidebar */
.v-doc-side-inner{position:sticky;top:100px;display:grid;gap:18px}
.v-doc-side-cat{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:800;font-size:15px;color:var(--head);padding-bottom:14px;border-bottom:1px solid var(--line)}
.v-doc-side-cat .di{display:inline-flex;width:30px;height:30px;align-items:center;justify-content:center;border-radius:9px;background:var(--tint);color:var(--purple-d)}
.v-doc-side-cat .di svg{width:17px;height:17px}
.v-doc-side-list{counter-reset:d;display:grid;gap:1px;margin:0;padding:0;list-style:none}
.v-doc-side-list li{counter-increment:d}
.v-doc-side-list a{display:flex;gap:10px;padding:8px 12px;border-radius:9px;font-family:var(--display);font-weight:600;font-size:14px;color:var(--text);line-height:1.4}
.v-doc-side-list a:before{content:counter(d);color:var(--faint);font-weight:700;font-size:12.5px;min-width:14px}
.v-doc-side-list a:hover{background:var(--bg-soft);color:var(--head)}
.v-doc-side-list li.cur a{background:var(--tint);color:var(--purple-dd)}
.v-doc-side-list li.cur a:before{color:var(--purple)}
.v-doc-side-help{margin-top:6px;padding:18px;border:1px solid var(--line);border-radius:var(--r);background:var(--bg-soft)}
.v-doc-side-help h4{margin:0 0 6px;font-family:var(--display);font-size:14.5px;color:var(--head)}
.v-doc-side-help p{margin:0 0 12px;font-size:13.5px;color:var(--text)}
.v-doc-side-help .v-btn{width:100%;justify-content:center;font-size:13.5px;padding:9px 14px}

/* Article */
.v-doc-article{max-width:760px;min-width:0}
.v-doc-head .v-h1{font-size:clamp(28px,3.4vw,40px);line-height:1.12;margin:0 0 14px}
.v-doc-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-family:var(--display);font-size:13.5px;color:var(--muted)}
.v-doc-meta a{color:var(--purple-d);font-weight:600}
.v-doc-meta span{color:var(--faint)}

.v-doc-because{display:flex;gap:14px;flex-direction:column;margin:26px 0;padding:18px 22px;border-radius:var(--r);background:var(--grad-soft);border:1px solid var(--line-2)}
.v-doc-because .lbl{font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--purple-d)}
.v-doc-because p{margin:0;font-size:16px;color:var(--head);line-height:1.6}

/* Prose */
.v-doc-body{font-size:16px;line-height:1.72;color:var(--text)}
.v-doc-body h2{font-family:var(--display);font-size:23px;font-weight:800;color:var(--head);margin:38px 0 12px;line-height:1.25}
.v-doc-body h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--head);margin:28px 0 10px}
.v-doc-body p{margin:0 0 16px}
.v-doc-body ul,.v-doc-body ol{margin:0 0 18px;padding-left:24px;display:grid;gap:8px}
.v-doc-body li{padding-left:4px}
.v-doc-body a{color:var(--purple-d);font-weight:600;text-decoration:underline;text-decoration-color:var(--line-2);text-underline-offset:2px}
.v-doc-body a:hover{text-decoration-color:var(--purple)}
.v-doc-body strong{color:var(--head);font-weight:700}
.v-doc-body code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.88em;background:var(--bg-tint);color:var(--purple-dd);padding:2px 6px;border-radius:6px}
.v-doc-body figure{margin:24px 0}
.v-doc-body figure img{width:100%;border:1px solid var(--line-2);border-radius:var(--r);box-shadow:var(--shadow-sm);display:block}
.v-doc-body figcaption{margin-top:10px;font-size:13.5px;color:var(--muted);text-align:center}
.v-doc-note{margin:22px 0;padding:16px 20px;border-left:3px solid var(--purple);background:var(--bg-soft);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:15px}
.v-doc-note strong{color:var(--purple-dd)}

/* Related / next / helpful */
.v-doc-related{margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.v-doc-related .v-h3{font-size:18px;margin:0 0 14px}
.v-doc-related ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.v-doc-related a{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:600;font-size:15px;color:var(--purple-d)}
.v-doc-related a:hover{color:var(--purple-dd)}
.v-doc-related .v-arrow{opacity:.6}
.v-doc-next{display:block;margin-top:26px;padding:18px 22px;border:1px solid var(--line-2);border-radius:var(--r);background:#fff;transition:border-color .15s,box-shadow .15s}
.v-doc-next:hover{border-color:var(--violet);box-shadow:var(--shadow-sm)}
.v-doc-next span{display:block;font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.v-doc-next strong{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-size:17px;color:var(--head)}
.v-doc-helpful{margin-top:30px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:6px 16px;align-items:center;font-size:14.5px;color:var(--text)}
.v-doc-helpful span{font-weight:600;color:var(--head)}
.v-doc-helpful a{color:var(--purple-d);font-weight:600}

/* Category listing */
.v-doc-cat-head{display:flex;gap:18px;align-items:flex-start;margin:6px 0 30px}
.v-doc-cat-head .v-docs-sec-ic{flex:0 0 auto;width:54px;height:54px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;background:var(--tint);color:var(--purple-d)}
.v-doc-cat-head .v-docs-sec-ic svg{width:27px;height:27px}
.v-doc-cat-tagline{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.v-doc-cat-tagline .v-h2{margin:0;font-size:clamp(26px,3vw,34px)}
.v-doc-cat-head p{margin:8px 0 0;font-size:16px;color:var(--text);max-width:640px}
.v-doc-cat-list{display:grid;gap:10px;max-width:780px}
.v-doc-cat-item{display:flex;align-items:center;gap:14px;padding:16px 20px;border:1px solid var(--line-2);border-radius:var(--r);background:#fff;transition:border-color .15s,box-shadow .15s,transform .15s}
.v-doc-cat-item:hover{border-color:var(--violet);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.v-doc-cat-item .num{flex:0 0 auto;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:var(--bg-soft);color:var(--muted);font-family:var(--display);font-weight:700;font-size:13px}
.v-doc-cat-item .ic{flex:0 0 auto;color:var(--purple-d)}
.v-doc-cat-item .ic svg{width:20px;height:20px}
.v-doc-cat-item .txt{flex:1 1 auto;display:flex;flex-direction:column;gap:2px}
.v-doc-cat-item .txt strong{font-family:var(--display);font-size:16px;color:var(--head);font-weight:700}
.v-doc-cat-item .txt em{font-style:normal;font-size:13px;color:var(--muted)}
.v-doc-cat-item .v-arrow{flex:0 0 auto;color:var(--faint)}
.v-doc-cat-item:hover .v-arrow{color:var(--purple)}
.v-doc-cat-back{margin-top:26px}
.v-doc-cat-back a{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;color:var(--text)}
.v-doc-cat-back a:hover{color:var(--purple-d)}
.v-doc-cat-back .v-arrow{transform:rotate(180deg)}

@media(max-width:900px){
  .v-doc-grid{grid-template-columns:1fr;gap:32px}
  .v-doc-side-inner{position:static}
  .v-doc-side-list{grid-template-columns:1fr 1fr;gap:2px 18px}
}
