/* ================================================================
   gv-design.css — Design system condiviso Genera Video
   Fonte unica di verità per: variabili, shell, componenti UI.
   Modificare qui per aggiornare tutte le pagine del sito.
   ================================================================ */

/* ── CSS Variables ── */
:root {
  --ink-900:#0B0712; --ink-850:#120B1E; --ink-800:#1A1428; --ink-750:#221733; --ink-700:#2B1E3F; --ink-600:#3A2952;
  --warm-500:#FF5A5F; --warm-450:#FF7A59; --warm-400:#FF9159; --warm-300:#FFB347; --warm-200:#FFD089;
  --text-100:#F7F2EA; --text-200:#E6DFD3; --text-300:#B9AFC2; --text-400:#877C97; --text-500:#5D5470;
  --line-soft:rgba(255,218,184,0.08); --line-mid:rgba(255,218,184,0.14); --line-strong:rgba(255,218,184,0.22);
  --radius-sm:10px; --radius-md:14px; --radius-lg:18px; --radius-xl:24px;
  --shadow-card:0 1px 0 rgba(255,255,255,0.04) inset, 0 30px 60px -20px rgba(0,0,0,0.6);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{min-height:100vh;overflow-x:hidden}
body{font-family:'Geist','Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;background:var(--ink-900);color:var(--text-100);-webkit-font-smoothing:antialiased;letter-spacing:-0.005em}

/* ── Ambient ── */
.backdrop{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(900px 600px at 8% -10%,rgba(255,122,89,0.18),transparent 60%),radial-gradient(700px 500px at 100% 0%,rgba(255,179,71,0.12),transparent 65%),radial-gradient(800px 700px at 50% 100%,rgba(180,70,200,0.10),transparent 60%),linear-gradient(180deg,#0B0712 0%,#100A1A 60%,#0B0712 100%)}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:0.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='0.6'/></svg>")}

/* ── App shell ── */
.app{position:relative;z-index:2;display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ── Sidebar ── */
.sidebar{position:sticky;top:0;height:100vh;padding:22px 18px;border-right:1px solid var(--line-soft);background:linear-gradient(180deg,rgba(26,20,40,0.6),rgba(11,7,18,0.6));backdrop-filter:blur(20px);display:flex;flex-direction:column;gap:22px;overflow-y:auto}
.brand{display:flex;align-items:center;gap:12px;padding:4px 6px}.brand-logo{height:80px;width:auto;object-fit:contain}
.brand-mark{width:36px;height:36px;border-radius:10px;flex-shrink:0;background:radial-gradient(circle at 30% 30%,#FFB347,transparent 60%),linear-gradient(135deg,#FF5A5F,#FF7A59 60%,#FFB347);box-shadow:0 0 0 1px rgba(255,255,255,0.12),0 10px 30px -5px rgba(255,90,95,0.5);display:flex;align-items:center;justify-content:center;color:white;font-size:14px}
.brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand-name strong{font-weight:600;font-size:15px;letter-spacing:-0.01em;color:var(--text-100)}
.brand-name span{font-size:11px;color:var(--text-400);margin-top:3px;display:flex;align-items:center;gap:6px}
.brand-name span::before{content:"";width:6px;height:6px;border-radius:50%;background:#4ADE80;box-shadow:0 0 8px #4ADE80}
.nav{display:flex;flex-direction:column;gap:4px}
.nav-section{font-size:10.5px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-500);padding:14px 10px 6px}
.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);color:var(--text-300);font-size:13.5px;font-weight:500;cursor:pointer;transition:all 180ms ease;border:1px solid transparent;text-decoration:none;position:relative}
.nav-item:hover{background:rgba(255,218,184,0.04);color:var(--text-100)}
.nav-item.active{background:linear-gradient(180deg,rgba(255,122,89,0.14),rgba(255,90,95,0.08));border-color:rgba(255,122,89,0.25);color:var(--text-100);box-shadow:inset 0 1px 0 rgba(255,255,255,0.05)}
.nav-item.active::before{content:"";position:absolute;left:-18px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#FFB347,#FF5A5F);box-shadow:0 0 12px #FF7A59}
.credits-card{margin-top:auto;padding:18px;border-radius:var(--radius-lg);background:radial-gradient(120% 100% at 0% 0%,rgba(255,179,71,0.18),transparent 55%),linear-gradient(160deg,rgba(43,30,63,0.7),rgba(11,7,18,0.7));border:1px solid var(--line-mid)}
.credits-label{font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-400)}
.credits-value{font-size:26px;font-weight:600;letter-spacing:-0.03em;margin-top:4px;background:linear-gradient(180deg,#FFE6CC 0%,#FF9159 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.credits-sub{font-size:11px;color:var(--text-400);margin-top:2px}
.credits-label,.credits-value,.credits-sub{position:relative}
.credits-bar{position:relative;margin-top:14px;height:4px;border-radius:999px;background:rgba(255,255,255,0.06);overflow:hidden}
.credits-bar>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#FFB347,#FF5A5F);box-shadow:0 0 12px rgba(255,122,89,0.6)}
.credits-cta{position:relative;margin-top:14px;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;font-size:12.5px;font-weight:500;background:rgba(255,255,255,0.04);border:1px solid var(--line-mid);border-radius:10px;cursor:pointer;color:var(--text-100);transition:all 160ms ease;font-family:inherit}
.credits-cta:hover:not(:disabled){background:rgba(255,255,255,0.08);border-color:var(--line-strong)}
.credits-cta:disabled{opacity:0.55;cursor:not-allowed}
.badge{display:inline-flex;align-items:center;gap:5px}
.badge .ico{flex-shrink:0}
.meta>span{display:inline-flex;align-items:center;gap:4px}
.btn{display:inline-flex;align-items:center;gap:6px}
.btn .ico{flex-shrink:0}

/* ── Main col ── */
.main-col{padding:28px 36px 60px;max-width:1480px;width:100%;margin:0 auto}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:20px}
.crumbs{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-400)}
.crumbs strong{color:var(--text-200);font-weight:500}
.crumbs .sep{opacity:0.5}

/* ── Page head ── */
.page-head{margin-bottom:24px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;border-radius:999px;background:linear-gradient(120deg,rgba(255,122,89,0.18),rgba(255,179,71,0.10));border:1px solid rgba(255,122,89,0.3);font-size:12px;font-weight:500;color:var(--warm-200);margin-bottom:14px}
.hero-badge .pulse{width:7px;height:7px;border-radius:50%;background:#FFB347;box-shadow:0 0 0 0 rgba(255,179,71,0.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,179,71,0.7)}70%{box-shadow:0 0 0 8px rgba(255,179,71,0)}100%{box-shadow:0 0 0 0 rgba(255,179,71,0)}}
.hero-title{font-size:30px;font-weight:600;letter-spacing:-0.025em;line-height:1.1;margin:0 0 8px;color:var(--text-100)}
.hero-title em{font-style:normal;background:linear-gradient(120deg,#FFD089,#FF7A59 50%,#FF5A5F);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{font-size:14px;color:var(--text-300);line-height:1.55;margin:0}

/* ── Page tabs ── */
.page-tabs{display:flex;align-items:center;gap:4px;padding:6px;border-radius:14px;background:linear-gradient(180deg,rgba(26,20,40,0.55),rgba(11,7,18,0.45));border:1px solid var(--line-soft);margin-bottom:24px;overflow-x:auto;scrollbar-width:none}
.page-tabs::-webkit-scrollbar{display:none}
.page-tab{position:relative;display:inline-flex;align-items:center;gap:9px;padding:10px 14px;border-radius:10px;color:var(--text-400);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all 180ms ease;font-family:inherit;background:transparent;border:1px solid transparent}
.page-tab:hover{color:var(--text-100);background:rgba(255,255,255,0.03)}
.page-tab.active{color:var(--text-100);background:linear-gradient(180deg,rgba(255,122,89,0.18),rgba(255,90,95,0.08));border-color:rgba(255,122,89,0.32);box-shadow:inset 0 1px 0 rgba(255,255,255,0.07),0 8px 24px -10px rgba(255,90,95,0.4)}
.page-tab.active::after{content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;border-radius:2px;background:linear-gradient(90deg,transparent,#FFB347,#FF5A5F,transparent);box-shadow:0 0 8px rgba(255,122,89,0.6)}

/* ── Tab panes ── */
.tab-pane{display:none}
.tab-pane.active{display:block}

/* ── Workspace ── */
.workspace{display:grid;grid-template-columns:minmax(0,1fr) 400px;gap:24px;align-items:start}
.fields-col{min-width:0}
.preview-col{min-width:0}
.preview-col>.preview-card{position:sticky;top:80px}

/* ── Section card accordion ── */
.section-card{position:relative;border-radius:var(--radius-xl);background:linear-gradient(180deg,rgba(43,30,63,0.45),rgba(26,20,40,0.45));border:1px solid var(--line-soft);box-shadow:var(--shadow-card);overflow:hidden;transition:border-color 200ms ease}
.section-card+.section-card{margin-top:14px}
.section-card:hover{border-color:var(--line-mid)}
.section-head{display:flex;align-items:center;gap:12px;padding:16px 20px;cursor:pointer;user-select:none}
.section-num{width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(255,122,89,0.22),rgba(255,90,95,0.10));border:1px solid rgba(255,122,89,0.3);color:var(--warm-200);font-size:11.5px;font-weight:600;flex-shrink:0}
.section-head h3{font-size:14.5px;font-weight:600;margin:0;letter-spacing:-0.005em;color:var(--text-100)}
.section-head .section-sub{font-size:11px;color:var(--text-400);margin-top:2px}
.section-head .s-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.section-head .chev{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-400);transition:transform 220ms ease;font-size:11px}
.section-card.open .section-head .chev{transform:rotate(90deg);color:var(--warm-300)}
.section-card.open .section-head{border-bottom:1px solid var(--line-soft)}
.section-body{padding:18px 20px 22px;display:none}
.section-card.open .section-body{display:block}
.group-label{font-size:10.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-500);font-weight:600;margin:16px 0 9px}
.group-label:first-child{margin-top:0}

/* ── Fields ── */
.fg{margin-bottom:14px}
.fg:last-child{margin-bottom:0}
.field-label{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-200);margin-bottom:7px}
.req-dot{width:5px;height:5px;border-radius:50%;background:var(--warm-500);box-shadow:0 0 6px var(--warm-500);flex-shrink:0}
.gv-input,.gv-select,.gv-textarea{width:100%;padding:11px 14px;background:rgba(11,7,18,0.5);border:1px solid var(--line-mid);border-radius:11px;color:var(--text-100);font-size:13.5px;font-family:inherit;outline:none;transition:all 160ms ease}
.gv-input::placeholder,.gv-textarea::placeholder{color:var(--text-500)}
.gv-input:hover,.gv-select:hover,.gv-textarea:hover{border-color:var(--line-strong)}
.gv-input:focus,.gv-select:focus,.gv-textarea:focus{border-color:rgba(255,122,89,0.5);box-shadow:0 0 0 4px rgba(255,122,89,0.12);background:rgba(11,7,18,0.7)}
.gv-textarea{resize:vertical;min-height:80px;line-height:1.5}
.select-wrap{position:relative}
.gv-select{appearance:none;-webkit-appearance:none;padding-right:38px;cursor:pointer}
.select-wrap::after{content:"";position:absolute;right:14px;top:50%;width:8px;height:8px;border-right:1.5px solid var(--text-400);border-bottom:1.5px solid var(--text-400);transform:translateY(-70%) rotate(45deg);pointer-events:none}
.hint{display:block;font-size:11.5px;color:var(--text-500);margin-top:6px;line-height:1.5}
.info-banner{display:block;font-size:12px;color:var(--text-300);padding:10px 13px;background:rgba(255,255,255,0.04);border:1px solid var(--line-soft);border-radius:10px;line-height:1.6;margin-bottom:12px}
.info-banner.amber{background:rgba(255,160,50,0.08);border-color:rgba(255,160,50,0.2);color:rgba(255,200,100,0.9)}
/* ── Section desc (paragrafo intro nelle section-body) ── */
.section-desc{font-size:12px;color:var(--text-400);line-height:1.6;margin-bottom:14px}

/* ── Opt cards (radio visivi) ── */
.opt-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.opt-row.three{grid-template-columns:repeat(3,1fr)}
.opt-card{position:relative;padding:14px;border-radius:var(--radius-md);background:rgba(255,255,255,0.025);border:1px solid var(--line-soft);cursor:pointer;transition:all 200ms ease;overflow:hidden}
.opt-card:hover{background:rgba(255,255,255,0.045);border-color:var(--line-mid)}
.opt-card.selected{background:linear-gradient(180deg,rgba(255,122,89,0.14),rgba(255,90,95,0.06));border-color:rgba(255,122,89,0.45);box-shadow:inset 0 1px 0 rgba(255,255,255,0.05),0 10px 30px -10px rgba(255,90,95,0.4)}
.opt-card.selected::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,179,71,0.7),transparent)}
.opt-card .opt-glyph{font-size:20px;margin-bottom:8px;display:block}
.opt-card h4{font-size:13px;font-weight:600;margin:0 0 3px;color:var(--text-200)}
.opt-card.selected h4{color:var(--text-100)}
.opt-card p{margin:0;font-size:11px;color:var(--text-400);line-height:1.5}
.opt-card .opt-tick{position:absolute;top:10px;right:10px;width:16px;height:16px;border-radius:50%;border:1.5px solid var(--line-mid);display:flex;align-items:center;justify-content:center;font-size:9px;color:transparent}
.opt-card.selected .opt-tick{background:linear-gradient(135deg,#FF7A59,#FF5A5F);border-color:transparent;color:white}
.opt-card input[type=radio]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}

/* ── Swatch row ── */
.swatch-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:12px;background:rgba(11,7,18,0.4);border:1px solid var(--line-mid)}
.swatch-row+.swatch-row{margin-top:8px}
.sw-circle{width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,0.12);flex-shrink:0;cursor:pointer;position:relative;overflow:hidden}
.sw-meta{flex:1;min-width:0}
.sw-label{font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-500);font-weight:600}
.sw-input-color{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.sw-hex{font-family:'Geist Mono',ui-monospace,monospace;font-size:13px;color:var(--text-100);background:transparent;border:none;outline:none;padding:0;width:100%;margin-top:1px}

/* ── Range field ── */
.range-field{display:flex;flex-direction:column;margin-bottom:14px}
.range-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.range-head label{font-size:12.5px;font-weight:500;color:var(--text-200)}
.range-val{font-family:'Geist Mono',ui-monospace,monospace;font-size:12px;color:var(--warm-200);padding:2px 8px;border-radius:6px;background:rgba(255,122,89,0.10);border:1px solid rgba(255,122,89,0.25)}
.range-input{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:linear-gradient(to right,rgba(255,179,71,0.5) 0%,rgba(255,122,89,0.5) var(--val,50%),rgba(255,255,255,0.06) var(--val,50%));outline:none;cursor:pointer}
.range-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#FFD089,#FF5A5F);border:2px solid #0B0712;box-shadow:0 0 14px rgba(255,122,89,0.7),0 2px 8px rgba(0,0,0,0.4);cursor:grab}
.range-input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#FFD089,#FF5A5F);border:2px solid #0B0712;box-shadow:0 0 14px rgba(255,122,89,0.7)}
.range-ticks{display:flex;justify-content:space-between;margin-top:6px;font-size:10px;color:var(--text-500);font-family:'Geist Mono',ui-monospace,monospace}

/* ── Voice cards ── */
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:8px}
.voice-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:rgba(11,7,18,0.4);border:1px solid var(--line-mid);cursor:pointer;transition:all 180ms ease;text-align:left;width:100%}
.voice-card:hover{border-color:var(--line-strong);background:rgba(255,255,255,0.03)}
.voice-card.active,.voice-card.on{background:linear-gradient(180deg,rgba(255,122,89,0.14),rgba(255,90,95,0.06));border-color:rgba(255,122,89,0.45);box-shadow:inset 0 1px 0 rgba(255,255,255,0.05)}
.vpc-play{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,0.04);border:1px solid var(--line-mid);color:var(--text-300);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 180ms ease;font-size:10px;cursor:pointer}
.voice-card:hover .vpc-play{color:var(--warm-200);border-color:rgba(255,122,89,0.4)}
.voice-card.active .vpc-play,.voice-card.on .vpc-play{background:linear-gradient(135deg,#FF7A59,#FF5A5F);color:white;border-color:transparent;box-shadow:0 0 16px rgba(255,122,89,0.5)}
.vpc-play.loading{opacity:0.6;cursor:not-allowed}
.vpc-info{flex:1;min-width:0}
.vpc-name{font-size:12.5px;font-weight:600;color:var(--text-100)}
.vpc-tag{font-size:9.5px;background:rgba(255,122,89,0.15);color:var(--warm-200);border-radius:4px;padding:1px 5px;font-weight:500;margin-left:4px}
.vpc-desc{font-size:10.5px;color:var(--text-400);margin-top:1px}
.voice-wave{display:flex;align-items:center;gap:2px;height:18px;flex-shrink:0}
.voice-wave i{display:block;width:2px;border-radius:2px;background:var(--text-500)}
.voice-card.active .voice-wave i,.voice-card.on .voice-wave i{background:var(--warm-300)}
.voice-section-label{font-size:10.5px;color:var(--text-500);text-transform:uppercase;letter-spacing:0.08em;font-weight:600;margin:12px 0 6px}

/* ── Varianti mascotte ── */
.variant-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.vc{position:relative;border-radius:12px;border:1px solid var(--line-mid);background:radial-gradient(80% 60% at 30% 30%,rgba(255,122,89,0.12),transparent 65%),linear-gradient(180deg,#2B1E3F,#1A1428);aspect-ratio:1;overflow:hidden;cursor:pointer;transition:all 200ms ease;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:8px;font-size:11px;color:var(--text-400);text-align:center}
.vc:hover{border-color:var(--line-strong);transform:translateY(-1px)}
.vc.sel{border-color:rgba(255,122,89,0.6);box-shadow:0 0 0 1px rgba(255,122,89,0.5),0 0 30px rgba(255,122,89,0.25);color:var(--warm-200)}
.vc-img{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem}
.vc-img img{width:100%;height:100%;object-fit:cover}
.vc span{position:relative;font-size:9.5px;color:var(--text-500)}
.vc.sel span{color:var(--warm-300)}

/* ── Character sheet ── */
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.cs-item{aspect-ratio:3/4;background:rgba(255,255,255,0.03);border:1px solid var(--line-soft);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:1.4rem;overflow:hidden}
.cs-item img{width:100%;height:100%;object-fit:cover}
.cs-label{font-size:.6rem;color:var(--text-500);text-align:center}
.cs-grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:6px}
.cs-item-sm{aspect-ratio:1;background:rgba(255,255,255,0.03);border:1px solid var(--line-soft);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:1.1rem;overflow:hidden}

/* ── Preview panels ── */
.preview-stack{position:sticky;top:22px;display:flex;flex-direction:column;gap:16px}
.preview-card{border-radius:var(--radius-xl);background:linear-gradient(180deg,rgba(43,30,63,0.55),rgba(11,7,18,0.7));border:1px solid var(--line-mid);box-shadow:var(--shadow-card);overflow:hidden}
.preview-head{display:flex;align-items:center;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line-soft)}
.preview-head h3{font-size:13.5px;font-weight:600;margin:0;color:var(--text-100)}
.live-dot{display:inline-flex;align-items:center;gap:6px;margin-left:auto;font-size:10px;font-weight:600;letter-spacing:0.08em;color:var(--warm-200);text-transform:uppercase}
.live-dot::before{content:"";width:7px;height:7px;border-radius:50%;background:#FF5A5F;box-shadow:0 0 8px #FF5A5F;animation:blink 1.6s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.4}}
.player{position:relative;aspect-ratio:9/16;max-height:440px;margin:14px;border-radius:16px;overflow:hidden;background:radial-gradient(80% 60% at 50% 30%,rgba(255,122,89,0.2),transparent 70%),linear-gradient(180deg,#2B1E3F 0%,#1A1428 50%,#0B0712 100%);border:1px solid var(--line-mid)}
.player-shimmer{position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,0.05) 50%,transparent 70%);background-size:200% 100%;animation:shimmer 3s infinite;mix-blend-mode:screen;pointer-events:none}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
.ai-frame{position:absolute;inset:20px;border-radius:10px;border:1px dashed rgba(255,255,255,0.10);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-300);text-align:center;padding:20px}
.ai-orb{width:56px;height:56px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#FFD089,transparent 50%),radial-gradient(circle at 70% 70%,#FF5A5F,transparent 60%),linear-gradient(135deg,#FF7A59,#FF5A5F);box-shadow:0 0 40px rgba(255,122,89,0.6),inset 0 0 20px rgba(255,255,255,0.2);animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.ai-frame p{margin:0;font-size:12px;color:var(--text-400);line-height:1.55}
.ai-frame b{color:var(--text-200)}
.preview-footer{padding:12px 18px;display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-400)}

/* ── Buttons ── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:11px;background:linear-gradient(180deg,#FF8A66,#FF5A5F 90%);color:white;border:1px solid rgba(255,255,255,0.1);font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 10px 24px -8px rgba(255,90,95,0.5);transition:all 180ms ease;width:100%}
.btn-primary:hover{transform:translateY(-1px)}
.btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.btn-gold{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border-radius:11px;background:linear-gradient(180deg,#FFE08A,#d4af37 90%);color:#0a0a0f;border:1px solid rgba(255,255,255,0.15);font-family:inherit;font-size:14px;font-weight:800;cursor:pointer;letter-spacing:0.3px;transition:all 180ms ease;width:100%}
.btn-gold:hover{background:linear-gradient(180deg,#ffe99d,#e0c040)}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 14px;border-radius:11px;background:rgba(255,255,255,0.04);border:1px solid var(--line-mid);color:var(--text-200);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all 160ms ease}
.btn-secondary:hover{background:rgba(255,255,255,0.07);color:var(--text-100);border-color:var(--line-strong)}
.btn-secondary:disabled{opacity:0.5;cursor:not-allowed}
.btn-green{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;border-radius:11px;background:linear-gradient(180deg,#22c55e,#059669);color:white;border:1px solid rgba(255,255,255,0.1);font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;transition:all 180ms ease;width:100%}
.btn-green:hover{background:linear-gradient(180deg,#4ade80,#16a34a)}
.btn-sm{padding:7px 12px!important;font-size:12px!important;width:auto!important}
.btn-row{display:flex;gap:8px;margin-top:10px}
.reroll-all{margin-top:10px;background:rgba(255,255,255,0.04);color:var(--text-200);border:1px solid var(--line-mid);border-radius:11px;padding:10px 14px;font-size:13px;cursor:pointer;font-family:inherit;font-weight:600;width:100%;transition:all 160ms ease;display:flex;align-items:center;justify-content:center;gap:8px}
.reroll-all:hover{background:rgba(255,255,255,0.07);border-color:var(--line-strong)}

/* ── Info / utilities ── */
.info{padding:11px 14px;background:rgba(30,58,138,0.2);border:1px solid rgba(30,58,138,0.4);border-radius:10px;color:#bfdbfe;font-size:12.5px;line-height:1.5;margin-bottom:14px}
.info.green{background:rgba(15,46,30,0.4);border-color:rgba(6,95,70,0.5);color:#6ee7b7}
.info.amber{background:rgba(46,30,10,0.4);border-color:rgba(146,64,14,0.5);color:#fcd34d}
.saved-note{font-size:12px;color:#34d399;margin-top:6px}
/* ── Upload zone ── */
.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:22px 16px;border:1.5px dashed var(--line-mid);border-radius:11px;cursor:pointer;transition:border-color 180ms,background 180ms;text-align:center;user-select:none}
.upload-zone:hover{border-color:var(--warm-500);background:rgba(255,122,89,0.05)}
.upload-zone.uz-loaded{border-color:#34d399;border-style:solid}
.upload-zone.uz-busy{opacity:0.6;pointer-events:none}
.uz-ico{font-size:22px;line-height:1;color:var(--text-400)}
.upload-zone:hover .uz-ico{color:var(--warm-400)}
.uz-label{font-size:13px;font-weight:500;color:var(--text-200)}
.uz-hint{font-size:11px;color:var(--text-500)}
.err{background:rgba(58,15,15,0.8);border:1px solid #8b2020;color:#ff8888;border-radius:10px;padding:11px 14px;font-size:12.5px;margin-top:10px}
.spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,0.15);border-top-color:white;border-radius:50%;animation:sp .65s linear infinite;vertical-align:middle;margin-right:7px}
@keyframes sp{to{transform:rotate(360deg)}}
.wip-note{padding:10px 14px;background:rgba(46,30,10,0.4);border:1px solid rgba(146,64,14,0.5);border-radius:10px;color:#fcd34d;font-size:12.5px;line-height:1.5;margin-top:10px;text-align:center}
.pv-box{background:transparent}
.pv-placeholder{width:100%;aspect-ratio:3/4;background:rgba(255,255,255,0.03);border:1px solid var(--line-soft);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:12.5px;color:var(--text-400);text-align:center;line-height:1.6;padding:20px}

/* ── Backward compat ── */
/* .t-photo: visibilità gestita da brand-card.js / bcOptTpl (inline display), non da CSS globale */
/* pv-status usato da brand-card.js */
#pv-status{display:flex;align-items:center;justify-content:center;min-height:100%;padding:24px;color:var(--text-400);text-align:center;font-size:13px;line-height:1.55}
#pv-status a{color:var(--warm-300)}
.step-pill{display:inline-block;padding:3px 9px;background:rgba(255,255,255,0.05);border:1px solid var(--line-mid);border-radius:99px;font-size:11px;color:var(--text-400)}
.step-pill.active{background:rgba(255,122,89,0.15);border-color:rgba(255,122,89,0.4);color:var(--warm-200)}
.job-step{font-size:12px;color:#888;margin-top:4px;padding:0 16px 8px;display:block;line-height:1.4}

/* ── Ricarica crediti (Stripe) ── */
.gv-recharge-modal{position:fixed;inset:0;z-index:10050;display:flex;align-items:center;justify-content:center;padding:24px}
.gv-recharge-modal[hidden]{display:none!important}
.gv-recharge-backdrop{position:absolute;inset:0;background:rgba(5,3,10,0.82);backdrop-filter:blur(6px)}
.gv-recharge-panel{position:relative;z-index:1;width:min(920px,100%);max-height:90vh;overflow:auto;padding:28px 28px 24px;border-radius:var(--radius-xl);background:linear-gradient(165deg,rgba(34,23,51,0.98),rgba(11,7,18,0.98));border:1px solid var(--line-mid);box-shadow:var(--shadow-card)}
.gv-recharge-close{position:absolute;top:14px;right:16px;width:36px;height:36px;border:none;border-radius:10px;background:rgba(255,255,255,0.06);color:var(--text-200);font-size:22px;line-height:1;cursor:pointer;font-family:inherit}
.gv-recharge-close:hover{background:rgba(255,255,255,0.12);color:var(--text-100)}
.gv-recharge-title{margin:0 0 6px;font-size:22px;font-weight:600;letter-spacing:-0.02em;color:var(--text-100)}
.gv-recharge-sub{margin:0 0 18px;font-size:13px;color:var(--text-400)}
.gv-recharge-error{margin:0 0 14px;padding:10px 12px;border-radius:10px;background:rgba(58,15,15,0.55);border:1px solid rgba(139,32,32,0.65);color:#ff9f9f;font-size:13px;line-height:1.45}
.gv-recharge-error[hidden]{display:none!important}
.gv-recharge-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media (min-width:760px){.gv-recharge-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
.gv-recharge-card{position:relative;display:flex;flex-direction:column;gap:8px;padding:16px 14px 14px;border-radius:var(--radius-md);background:rgba(255,255,255,0.03);border:1px solid var(--line-soft);min-height:168px}
.gv-recharge-card.is-highlight{border-color:rgba(255,179,71,0.45);background:radial-gradient(120% 80% at 0% 0%,rgba(255,179,71,0.14),transparent 60%),rgba(255,255,255,0.04);box-shadow:0 12px 32px -16px rgba(255,122,89,0.45)}
.gv-recharge-badge{position:absolute;top:10px;right:10px;padding:4px 8px;border-radius:999px;font-size:10px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase;background:linear-gradient(120deg,rgba(255,179,71,0.35),rgba(255,90,95,0.25));border:1px solid rgba(255,179,71,0.45);color:var(--warm-200)}
.gv-recharge-card-label{margin:0;font-size:15px;font-weight:600;color:var(--text-100)}
.gv-recharge-card-credits{margin:0;font-size:12px;color:var(--text-300)}
.gv-recharge-card-price{margin:4px 0 8px;font-size:24px;font-weight:600;letter-spacing:-0.03em;color:var(--text-100)}
.gv-recharge-buy{margin-top:auto;width:100%;padding:9px 12px;border-radius:10px;border:1px solid rgba(255,122,89,0.35);background:linear-gradient(180deg,rgba(255,122,89,0.22),rgba(255,90,95,0.12));color:var(--text-100);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 160ms ease}
.gv-recharge-buy:hover:not(:disabled){border-color:rgba(255,179,71,0.55);background:linear-gradient(180deg,rgba(255,122,89,0.32),rgba(255,90,95,0.18))}
.gv-recharge-buy:disabled{opacity:0.55;cursor:not-allowed}
a.gv-recharge-buy{display:flex;align-items:center;justify-content:center;text-decoration:none;text-align:center;box-sizing:border-box}

/* ── Public pricing page (Att-08) ── */
.gv-pricing-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.gv-pricing-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:1040px;margin:0 auto;padding:20px 24px 0}
.gv-pricing-logo img{display:block;height:56px;width:auto;object-fit:contain}
.gv-pricing-nav{display:flex;align-items:center;gap:14px;font-size:14px}
.gv-pricing-nav a{color:var(--text-300);text-decoration:none;transition:color 160ms ease}
.gv-pricing-nav a:hover{color:var(--text-100)}
.gv-pricing-nav-cta{padding:8px 14px;border-radius:10px;border:1px solid rgba(255,122,89,0.35);background:linear-gradient(180deg,rgba(255,122,89,0.22),rgba(255,90,95,0.12));color:var(--text-100)!important;font-weight:600}
.gv-pricing-page{position:relative;z-index:2;max-width:1040px;margin:0 auto;padding:8px 24px 48px}
.gv-pricing-hero{text-align:center;padding:28px 0 32px}
.gv-pricing-hero h1{margin:0 0 10px;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:600;letter-spacing:-0.03em;color:var(--text-100)}
.gv-pricing-hero-sub{margin:0;font-size:15px;color:var(--text-400);line-height:1.5}
.gv-pricing-packages{margin-bottom:40px}
.gv-pricing-note{margin:18px 0 0;text-align:center;font-size:13px;color:var(--text-300);line-height:1.5}
.gv-pricing-usage{margin-bottom:40px}
.gv-pricing-usage h2,.gv-pricing-faq h2{margin:0 0 14px;font-size:1.25rem;font-weight:600;color:var(--text-100);letter-spacing:-0.02em}
.gv-pricing-usage-hint{margin:0 0 16px;font-size:13px;color:var(--text-400);line-height:1.55}
.gv-pricing-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--line-soft)}
.gv-pricing-table{width:100%;border-collapse:collapse;font-size:14px}
.gv-pricing-table th,.gv-pricing-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line-soft)}
.gv-pricing-table th{font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-400);background:rgba(255,255,255,0.02)}
.gv-pricing-table tbody tr:last-child td{border-bottom:none}
.gv-pricing-table td{color:var(--text-200)}
.gv-pricing-faq{margin-bottom:40px}
.gv-pricing-faq-list{display:flex;flex-direction:column;gap:8px}
.gv-pricing-faq-item{border-radius:var(--radius-md);border:1px solid var(--line-soft);background:rgba(255,255,255,0.02);overflow:hidden}
.gv-pricing-faq-item summary{padding:14px 16px;font-size:14px;font-weight:600;color:var(--text-100);cursor:pointer;list-style:none}
.gv-pricing-faq-item summary::-webkit-details-marker{display:none}
.gv-pricing-faq-item summary::after{content:"+";float:right;font-weight:400;color:var(--text-400)}
.gv-pricing-faq-item[open] summary::after{content:"−"}
.gv-pricing-faq-item p{margin:0;padding:0 16px 14px;font-size:13px;line-height:1.55;color:var(--text-300)}
.gv-pricing-faq-item p strong{color:var(--text-200);font-weight:600}
.gv-pricing-cta{text-align:center;padding:32px 20px;border-radius:var(--radius-xl);background:radial-gradient(120% 100% at 50% 0%,rgba(255,179,71,0.12),transparent 55%),linear-gradient(165deg,rgba(34,23,51,0.6),rgba(11,7,18,0.5));border:1px solid var(--line-mid)}
.gv-pricing-cta-text{margin:0 0 16px;font-size:15px;color:var(--text-200)}
.gv-pricing-cta-btn{display:inline-block;padding:12px 28px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#ff7a59,#ff5a5f);color:#fff;font-size:15px;font-weight:600;text-decoration:none;transition:filter 160ms ease}
.gv-pricing-cta-btn:hover{filter:brightness(1.06)}
.gv-pricing-footer{position:relative;z-index:2;text-align:center;padding:0 24px 32px;font-size:13px;color:var(--text-500)}
.gv-pricing-footer a{color:var(--text-400);text-decoration:none}
.gv-pricing-footer a:hover{color:var(--text-200)}
@media (max-width:480px){
  .gv-pricing-header{flex-wrap:wrap;padding-top:16px}
  .gv-pricing-page .gv-recharge-grid{grid-template-columns:1fr}
  .gv-pricing-table th,.gv-pricing-table td{padding:10px 12px;font-size:13px}
}

/* ── Transactions history (Att-09) ── */
.credits-history-link{display:block;margin-top:10px;text-align:center;font-size:12px;font-weight:500;color:var(--text-400);text-decoration:none;padding:6px 8px;border-radius:8px;transition:color 160ms ease,background 160ms ease}
.credits-history-link:hover{color:var(--text-100);background:rgba(255,255,255,0.04)}
.credits-history-link.is-active{color:var(--warm-200);background:rgba(255,122,89,0.1)}
.gv-tx-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.gv-tx-page .btn-secondary,.gv-tx-page .btn-primary{text-decoration:none;width:auto}
.gv-tx-page .page-title{margin:0 0 6px;font-size:1.5rem;font-weight:600;letter-spacing:-0.02em;color:var(--text-100)}
.gv-tx-page .page-sub{margin:0;font-size:14px;color:var(--text-400);line-height:1.5}
.gv-tx-balance-card{margin-bottom:24px;padding:20px 22px;border-radius:var(--radius-lg);background:radial-gradient(120% 100% at 0% 0%,rgba(255,179,71,0.14),transparent 55%),linear-gradient(160deg,rgba(43,30,63,0.7),rgba(11,7,18,0.7));border:1px solid var(--line-mid)}
.gv-tx-balance-label{font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-400)}
.gv-tx-balance-value{margin-top:6px;font-size:28px;font-weight:600;letter-spacing:-0.03em;color:var(--text-100)}
.gv-tx-balance-sub{margin-top:4px;font-size:13px;color:var(--text-400)}
.gv-tx-empty{text-align:center;padding:48px 24px;border:1px dashed var(--line-mid);border-radius:var(--radius-lg);color:var(--text-400)}
.gv-tx-empty p{margin:0 0 16px;font-size:15px}
.gv-tx-table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--line-soft);background:rgba(255,255,255,0.02)}
.gv-tx-table{width:100%;border-collapse:collapse;font-size:14px}
.gv-tx-table th,.gv-tx-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top}
.gv-tx-table th{font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-400);background:rgba(255,255,255,0.02)}
.gv-tx-table tbody tr:last-child td{border-bottom:none}
.gv-tx-date{white-space:nowrap;color:var(--text-300);font-size:13px}
.gv-tx-badge{display:inline-block;font-size:13px;color:var(--text-200)}
.gv-tx-detail{font-size:13px;color:var(--text-300)}
.gv-tx-receipt-link{color:var(--warm-300);font-weight:600;text-decoration:none}
.gv-tx-receipt-link:hover{text-decoration:underline;color:var(--warm-200)}
.gv-tx-receipt-eur{color:var(--text-400)}
.gv-tx-ref{font-size:11px;color:var(--text-400);word-break:break-all}
.gv-tx-amount{font-weight:600;white-space:nowrap}
.gv-tx-amount--plus{color:#4ade80}
.gv-tx-amount--minus{color:#f87171}
.gv-tx-balance-after{color:var(--text-200);white-space:nowrap}
.gv-tx-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px;flex-wrap:wrap}
.gv-tx-page-link{font-size:14px;color:var(--warm-300);text-decoration:none;padding:8px 12px;border-radius:8px;border:1px solid var(--line-soft)}
.gv-tx-page-link:hover{background:rgba(255,255,255,0.04);color:var(--warm-200)}
.gv-tx-page-link--disabled{opacity:0.45;cursor:default}
.gv-tx-page-info{font-size:13px;color:var(--text-400)}
@media (max-width:720px){
  .gv-tx-table thead{display:none}
  .gv-tx-table tr{display:block;padding:14px;border-bottom:1px solid var(--line-soft)}
  .gv-tx-table td{display:block;padding:4px 0;border:none}
  .gv-tx-table td::before{content:attr(data-label);display:block;font-size:10px;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-500);margin-bottom:2px}
}

/* ── Printable receipt (Att-09) ── */
body.receipt-page{margin:0;min-height:100vh;background:#f4f0eb;color:#1a1428;font-family:'Geist','Inter',system-ui,sans-serif}
.receipt-wrap{max-width:640px;margin:0 auto;padding:32px 24px 48px}
.receipt-header{text-align:center;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #ddd6ce}
.receipt-logo{display:block;margin:0 auto 16px;height:48px;width:auto}
.receipt-title{margin:0 0 6px;font-size:1.5rem;font-weight:600}
.receipt-sub{margin:0;font-size:13px;color:#5d5470}
.receipt-body{margin-bottom:28px}
.receipt-section-title{margin:20px 0 10px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:#5d5470}
.receipt-dl{display:grid;grid-template-columns:minmax(120px,38%) 1fr;gap:8px 16px;margin:0;font-size:14px}
.receipt-dl dt{margin:0;color:#5d5470;font-weight:500}
.receipt-dl dd{margin:0;color:#1a1428}
.receipt-code{font-size:12px;word-break:break-all}
.receipt-disclaimer{margin-top:24px;padding:12px 14px;font-size:12px;line-height:1.5;color:#5d5470;background:#ebe6df;border-radius:8px}
.receipt-footer{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:center;padding-top:16px;border-top:1px solid #ddd6ce}
.receipt-print-btn{padding:10px 20px;border:none;border-radius:8px;background:linear-gradient(135deg,#ff7a59,#ff5a5f);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.receipt-print-btn:hover{filter:brightness(1.05)}
.receipt-back-link{font-size:14px;color:#c45a3a;text-decoration:none}
.receipt-back-link:hover{text-decoration:underline}
@media print{
  body.receipt-page{background:#fff}
  .receipt-footer .receipt-print-btn,.receipt-footer .receipt-back-link{display:none!important}
  .receipt-wrap{padding:0;max-width:none}
}
a.gv-recharge-buy{display:flex;align-items:center;justify-content:center;text-decoration:none;box-sizing:border-box}

/* ── Public pricing page (Att-08) ── */
.gv-pricing-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.gv-pricing-header{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:1040px;margin:0 auto;padding:20px 24px 0}
.gv-pricing-logo img{display:block;height:56px;width:auto}
.gv-pricing-nav{display:flex;align-items:center;gap:14px;font-size:14px}
.gv-pricing-nav a{color:var(--text-300);text-decoration:none}
.gv-pricing-nav a:hover{color:var(--text-100)}
.gv-pricing-nav-cta{padding:8px 14px;border-radius:10px;border:1px solid rgba(255,122,89,0.35);background:linear-gradient(180deg,rgba(255,122,89,0.22),rgba(255,90,95,0.12));color:var(--text-100)!important;font-weight:600}
.gv-pricing-page{position:relative;z-index:2;max-width:1040px;margin:0 auto;padding:24px 24px 48px}
.gv-pricing-hero{text-align:center;padding:28px 0 36px}
.gv-pricing-hero h1{margin:0 0 10px;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:600;letter-spacing:-0.03em;color:var(--text-100)}
.gv-pricing-hero-sub{margin:0;font-size:15px;color:var(--text-400);line-height:1.5}
.gv-pricing-packages{margin-bottom:40px}
.gv-pricing-note{margin:18px 0 0;text-align:center;font-size:13px;color:var(--text-300)}
.gv-pricing-usage{margin-bottom:40px}
.gv-pricing-usage h2,.gv-pricing-faq h2{margin:0 0 14px;font-size:1.25rem;font-weight:600;color:var(--text-100)}
.gv-pricing-usage-hint{margin:0 0 16px;font-size:13px;color:var(--text-400);line-height:1.5}
.gv-pricing-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--line-soft)}
.gv-pricing-table{width:100%;border-collapse:collapse;font-size:14px}
.gv-pricing-table th,.gv-pricing-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line-soft)}
.gv-pricing-table th{font-size:11px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-400);background:rgba(255,255,255,0.02)}
.gv-pricing-table tbody tr:last-child td{border-bottom:none}
.gv-pricing-table td{color:var(--text-200)}
.gv-pricing-faq{margin-bottom:40px}
.gv-pricing-faq-list{display:flex;flex-direction:column;gap:10px}
.gv-pricing-faq-item{border:1px solid var(--line-soft);border-radius:var(--radius-md);background:rgba(255,255,255,0.02);overflow:hidden}
.gv-pricing-faq-item summary{padding:14px 16px;font-size:14px;font-weight:600;color:var(--text-100);cursor:pointer;list-style:none}
.gv-pricing-faq-item summary::-webkit-details-marker{display:none}
.gv-pricing-faq-item summary::after{content:"+";float:right;color:var(--text-400);font-weight:400}
.gv-pricing-faq-item[open] summary::after{content:"−"}
.gv-pricing-faq-item p{margin:0;padding:0 16px 14px;font-size:13px;line-height:1.55;color:var(--text-300)}
.gv-pricing-cta{text-align:center;padding:32px 20px;border-radius:var(--radius-xl);background:radial-gradient(120% 100% at 50% 0%,rgba(255,179,71,0.12),transparent 55%),rgba(255,255,255,0.02);border:1px solid var(--line-mid)}
.gv-pricing-cta-text{margin:0 0 16px;font-size:15px;color:var(--text-200)}
.gv-pricing-cta-btn{display:inline-block;padding:12px 28px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#ff7a59,#ff5a5f);color:#fff;font-size:15px;font-weight:600;text-decoration:none}
.gv-pricing-cta-btn:hover{filter:brightness(1.06)}
.gv-pricing-footer{position:relative;z-index:2;text-align:center;padding:0 24px 32px;font-size:13px;color:var(--text-400)}
.gv-pricing-footer a{color:var(--text-300);text-decoration:none}
.gv-pricing-footer a:hover{color:var(--text-100)}
.gv-pricing-footer span{margin:0 8px}
@media (max-width:480px){
  .gv-pricing-packages .gv-recharge-grid{grid-template-columns:1fr}
  .gv-pricing-header{padding:16px 16px 0}
  .gv-pricing-page{padding:16px 16px 40px}
}

