/* ── RESET & ROOT ──────────────────────────────────────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  /* Backgrounds — navy profondo */
  --bg:#040C1A;--bg2:#060F22;--bg3:#09142B;--bg4:#0C1A35;
  /* Accent — blu lapis mediterraneo */
  --accent:#6B98C8;--accent2:#4A72A8;--accent-glow:rgba(107,152,200,.20);
  /* Gold/Cream — testo caldo */
  --gold:#E8D5A3;--gold2:#F4E4BC;--gold3:#C9A84C;
  /* Text */
  --text:#E8D5A3;--text2:rgba(232,213,163,.58);--text3:rgba(232,213,163,.32);
  /* Borders */
  --border:rgba(232,213,163,.07);--border2:rgba(232,213,163,.14);
  /* Radius */
  --r:6px;--r2:12px;--r3:20px;
  /* Gradients */
  --grad-primary:linear-gradient(135deg,#6B98C8 0%,#4A72A8 100%);
  --grad-text:linear-gradient(135deg,#E8D5A3,#6B98C8);
}

/* ── BASE ──────────────────────────────────────────────────────────────────── */
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter','Helvetica Neue',sans-serif;
  min-height:100vh;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.form-title,.pay-title,.user-header h2{
  font-family:'Sora','Inter',sans-serif;
}
.hero-headline,.modal-title{
  font-family:'Cormorant Garamond','Sora','Inter',serif;
}

/* ── SCREENS ───────────────────────────────────────────────────────────────── */
.screen{display:none;min-height:100vh;}
.screen.active{display:block;}
#formScreen.active{display:flex;align-items:center;justify-content:center;padding:2rem 0;}

/* ── UTILITIES ─────────────────────────────────────────────────────────────── */
.gradient-text{
  background:var(--grad-text);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.glass{
  background:rgba(107,152,200,.04);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(232,213,163,.08);
}

/* ── ANIMATIONS ────────────────────────────────────────────────────────────── */
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
@keyframes twinkle{0%,100%{opacity:.2;}50%{opacity:.9;}}
@keyframes orbPulse{
  0%  {box-shadow:0 0 50px rgba(107,152,200,.25),0 0 100px rgba(107,152,200,.08);}
  100%{box-shadow:0 0 90px rgba(107,152,200,.45),0 0 180px rgba(107,152,200,.18);}
}
@keyframes orbRingSpin1{to{transform:translate(-50%,-50%) rotate(360deg);}}
@keyframes orbRingSpin2{to{transform:translate(-50%,-50%) rotate(-360deg);}}
@keyframes orbPlanetOrbit1{from{transform:rotate(0deg) translateX(100px) rotate(0deg);}to{transform:rotate(360deg) translateX(100px) rotate(-360deg);}}
@keyframes orbPlanetOrbit2{from{transform:rotate(0deg) translateX(148px) rotate(0deg);}to{transform:rotate(360deg) translateX(148px) rotate(-360deg);}}
@keyframes orbPlanetOrbit3{from{transform:rotate(0deg) translateX(78px) rotate(0deg);}to{transform:rotate(360deg) translateX(78px) rotate(-360deg);}}
@keyframes orbPlanetOrbit4{from{transform:rotate(0deg) translateX(168px) rotate(0deg);}to{transform:rotate(360deg) translateX(168px) rotate(-360deg);}}
@keyframes orbPlanetOrbit5{from{transform:rotate(0deg) translateX(122px) rotate(0deg);}to{transform:rotate(-360deg) translateX(122px) rotate(360deg);}}
@keyframes orbPlanetOrbit6{from{transform:rotate(0deg) translateX(56px) rotate(0deg);}to{transform:rotate(360deg) translateX(56px) rotate(-360deg);}}
@keyframes starPulse{0%,100%{opacity:.15;transform:scale(1);}50%{opacity:.7;transform:scale(1.3);}}

/* ── NAV ───────────────────────────────────────────────────────────────────── */
nav{
  background:rgba(4,12,26,.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(232,213,163,.08);
  padding:0 2rem;
  display:flex;align-items:center;justify-content:space-between;
  height:60px;position:sticky;top:0;z-index:200;
}
.logo{
  font-size:18px;letter-spacing:.3em;color:var(--gold);
  cursor:pointer;font-family:'Sora',sans-serif;font-weight:300;
}
.logo span{color:var(--accent);font-weight:600;}
.nav-links{display:flex;gap:1.5rem;align-items:center;}
.nav-btn{
  background:none;border:none;color:var(--text3);
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  cursor:pointer;font-family:'Inter',sans-serif;padding:6px 0;transition:color .2s;
}
.nav-btn:hover,.nav-btn.active{color:var(--gold);}
.nav-right{display:flex;gap:.75rem;}

/* ── BUTTONS ───────────────────────────────────────────────────────────────── */
.btn-sm{
  padding:8px 18px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  cursor:pointer;border-radius:var(--r);font-family:'Inter',sans-serif;transition:all .2s;
}
.btn-outline{
  background:none;border:1px solid var(--border2);color:var(--text2);
}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);}

.btn-gold{
  background:linear-gradient(135deg,#E8D5A3 0%,#C9A84C 100%);
  border:none;color:#04080F;font-weight:600;
}
.btn-gold:hover{background:linear-gradient(135deg,#F4E4BC 0%,#E8D5A3 100%);transform:translateY(-1px);}

.btn-primary{
  background:var(--grad-primary);border:none;color:#fff;font-weight:600;
  box-shadow:0 0 0 0 var(--accent-glow);transition:all .25s;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px var(--accent-glow);}
.glow-btn{box-shadow:0 0 24px var(--accent-glow),0 4px 16px rgba(74,114,168,.3);}

/* ── HOME NAV ──────────────────────────────────────────────────────────────── */
.home-nav{
  background:rgba(4,12,26,.75);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(107,152,200,.08);
  padding:0 2.5rem;
  display:flex;align-items:center;justify-content:space-between;
  height:64px;position:sticky;top:0;z-index:200;
}

/* ── HERO ──────────────────────────────────────────────────────────────────── */
.hero{
  min-height:calc(100vh - 64px);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:4rem 2.5rem 3rem;
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 55% 10%,rgba(107,152,200,.14) 0%,transparent 65%),
    radial-gradient(ellipse 50% 45% at 5%  80%,rgba(74,114,168,.08)  0%,transparent 55%),
    radial-gradient(ellipse 35% 35% at 92% 88%,rgba(232,213,163,.05) 0%,transparent 50%),
    var(--bg);
}

/* Stars background */
.star-bg::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at  7% 12%,rgba(232,213,163,.7) 0%,transparent 100%),
    radial-gradient(1px 1px at 18% 35%,rgba(232,213,163,.4) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 30%  8%,rgba(232,213,163,.6) 0%,transparent 100%),
    radial-gradient(1px 1px at 43% 68%,rgba(232,213,163,.3) 0%,transparent 100%),
    radial-gradient(1px 1px at 57% 20%,rgba(232,213,163,.5) 0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 68% 78%,rgba(232,213,163,.35) 0%,transparent 100%),
    radial-gradient(1px 1px at 78% 44%,rgba(232,213,163,.6) 0%,transparent 100%),
    radial-gradient(1px 1px at 88% 15%,rgba(232,213,163,.45) 0%,transparent 100%),
    radial-gradient(1px 1px at 92% 60%,rgba(232,213,163,.25) 0%,transparent 100%),
    radial-gradient(2px 2px at 14% 72%,rgba(232,213,163,.2)  0%,transparent 100%),
    radial-gradient(1px 1px at 36% 88%,rgba(232,213,163,.2)  0%,transparent 100%),
    radial-gradient(1px 1px at 51% 52%,rgba(107,152,200,.5)   0%,transparent 100%),
    radial-gradient(1px 1px at 22% 58%,rgba(107,152,200,.3)   0%,transparent 100%),
    radial-gradient(1.5px 1.5px at 83% 10%,rgba(232,213,163,.4) 0%,transparent 100%),
    radial-gradient(1px 1px at 63% 92%,rgba(107,152,200,.25)  0%,transparent 100%),
    radial-gradient(1px 1px at  5% 48%,rgba(232,213,163,.35) 0%,transparent 100%),
    radial-gradient(1px 1px at 97% 82%,rgba(232,213,163,.3)  0%,transparent 100%);
  pointer-events:none;z-index:0;
}
.hero > *{position:relative;z-index:1;}

.hero-layout{
  display:grid;grid-template-columns:1.1fr 0.9fr;
  gap:5rem;align-items:center;max-width:1240px;width:100%;
}
.hero-left{display:flex;flex-direction:column;gap:1.75rem;}
.hero-right{display:flex;justify-content:center;align-items:center;}

/* ── HERO TEXT ─────────────────────────────────────────────────────────────── */
.hero-eyebrow{
  font-size:11px;letter-spacing:.5em;text-transform:uppercase;
  color:var(--accent);font-weight:400;
  display:inline-flex;align-items:center;gap:.6rem;
}
.hero-eyebrow::before{
  content:'';width:28px;height:1px;
  background:linear-gradient(90deg,var(--accent),transparent);
}

.hero-headline{
  font-family:'Cormorant Garamond','Sora',serif;
  font-size:clamp(3.4rem,8vw,6.5rem);font-weight:300;
  line-height:1.05;letter-spacing:-.01em;color:var(--text);
}
.hero-headline strong{font-weight:700;color:var(--gold2);}
.hero-headline em{font-style:normal;}

.hero-sub-desc{
  font-size:16px;color:var(--text2);line-height:1.8;max-width:480px;
  border-left:1px solid rgba(107,152,200,.3);padding-left:1.25rem;
}

.hero-trust{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;}
.trust-badge{font-size:11px;color:var(--text3);letter-spacing:.1em;font-family:'Inter',sans-serif;}
.trust-dot{color:rgba(232,213,163,.2);}

.btn-hero-cta{
  display:inline-flex;align-items:center;gap:.75rem;
  background:transparent;
  border:1px solid rgba(107,152,200,.5);
  color:var(--gold);
  font-family:'Sora',sans-serif;font-size:16px;font-weight:400;
  letter-spacing:.1em;text-transform:uppercase;
  padding:18px 44px;border-radius:var(--r);cursor:pointer;transition:all .3s;
  position:relative;overflow:hidden;
}
.btn-hero-cta::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(107,152,200,.08) 0%,transparent 60%);
  border-radius:inherit;
}
.btn-hero-cta:hover{
  border-color:var(--accent);color:var(--gold2);
  box-shadow:0 0 40px rgba(107,152,200,.2),inset 0 0 20px rgba(107,152,200,.04);
  transform:translateY(-2px);
}
.cta-arrow{font-size:18px;transition:transform .2s;opacity:.6;}
.btn-hero-cta:hover .cta-arrow{transform:translateX(5px);opacity:1;}
.hero-proof{font-size:11px;color:var(--text3);letter-spacing:.1em;margin-top:.75rem;}

.hero-quotes{display:flex;flex-direction:column;gap:.75rem;padding-top:.5rem;}
.hero-quote-item{display:flex;flex-direction:column;gap:.2rem;}
.hero-quote-text{font-style:italic;font-size:13px;color:var(--text2);line-height:1.6;}
.hero-quote-text::before{content:'\201C';}
.hero-quote-text::after{content:'\201D';}
.hero-quote-author{font-size:11px;color:var(--accent);letter-spacing:.08em;opacity:.75;}
.fadeInUp{animation:fadeInUp .7s cubic-bezier(.22,.61,.36,1) both;}

/* ── HERO ORB ──────────────────────────────────────────────────────────────── */
.hero-orb-wrap{width:420px;height:420px;display:flex;align-items:center;justify-content:center;position:relative;}
.hero-orb{
  width:240px;height:240px;border-radius:50%;
  background:radial-gradient(ellipse at 38% 32%,rgba(120,180,255,.28) 0%,rgba(74,114,168,.18) 40%,transparent 100%);
  position:relative;
  animation:orbPulse 4s ease-in-out infinite alternate;
  box-shadow:0 0 50px rgba(107,152,200,.22),0 0 100px rgba(107,152,200,.08),inset 0 0 25px rgba(107,152,200,.06);
}
.orb-ring{
  position:absolute;top:50%;left:50%;
  border-radius:50%;border:1px solid rgba(232,213,163,.1);
  transform:translate(-50%,-50%);
}
.orb-ring-1{width:310px;height:310px;border-color:rgba(107,152,200,.28);animation:orbRingSpin1 22s linear infinite;}
.orb-ring-2{width:390px;height:390px;border-color:rgba(232,213,163,.18);animation:orbRingSpin2 35s linear infinite;}
.orb-ring-3{width:200px;height:200px;border-color:rgba(107,152,200,.35);animation:orbRingSpin1 15s linear infinite reverse;}
.orb-core{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  font-size:48px;
  filter:drop-shadow(0 0 28px rgba(107,152,200,.8)) drop-shadow(0 0 60px rgba(107,152,200,.3));
  z-index:2;
}
.orb-planet{
  position:absolute;top:50%;left:50%;
  width:26px;height:26px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:12px;
  background:rgba(4,12,26,.9);
  border:1px solid rgba(107,152,200,.25);
  backdrop-filter:blur(6px);
  margin-top:-13px;margin-left:-13px;z-index:3;
}
.orb-p1{color:#E8D5A3;animation:orbPlanetOrbit1 14s linear infinite;}
.orb-p2{color:#4A9EFF;animation:orbPlanetOrbit2 22s linear infinite;}
.orb-p3{color:#E07070;animation:orbPlanetOrbit3 10s linear infinite;}
.orb-p4{color:#6DC895;animation:orbPlanetOrbit4 30s linear infinite;}
.orb-p5{color:#B87FD4;animation:orbPlanetOrbit5 18s linear infinite;}
.orb-p6{color:#F4D06F;animation:orbPlanetOrbit6 8s linear infinite;}

/* ── INSIGHT SECTION ───────────────────────────────────────────────────────── */
.insight-section{
  max-width:1100px;margin:0 auto;padding:6rem 2.5rem 4rem;
  border-top:1px solid rgba(232,213,163,.05);
}
.insight-label{
  font-size:11px;letter-spacing:.45em;text-transform:uppercase;
  color:var(--accent);margin-bottom:.75rem;text-align:center;
}
.insight-h2{
  font-family:'Sora',sans-serif;font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-weight:300;color:var(--text);text-align:center;margin-bottom:3.5rem;line-height:1.3;
}
.insight-h2 strong{font-weight:700;}
.insight-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.insight-card{
  padding:2.5rem 2rem;border-radius:var(--r2);
  background:rgba(107,152,200,.03);
  border:1px solid rgba(232,213,163,.06);
  transition:all .35s;position:relative;overflow:hidden;
}
.insight-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(107,152,200,.4),transparent);
  opacity:0;transition:opacity .35s;
}
.insight-card:hover{border-color:rgba(107,152,200,.2);background:rgba(107,152,200,.05);transform:translateY(-4px);box-shadow:0 20px 60px rgba(4,12,26,.5);}
.insight-card:hover::before{opacity:1;}
.insight-number{
  font-family:'Sora',sans-serif;font-size:2.8rem;font-weight:200;
  color:rgba(107,152,200,.35);line-height:1;margin-bottom:1.25rem;
  letter-spacing:.05em;
}
.insight-body{font-size:14px;color:var(--text2);line-height:1.85;}
.insight-body strong{color:var(--text);font-weight:500;display:block;margin-bottom:.6rem;font-size:15px;}

/* ── PRICING ───────────────────────────────────────────────────────────────── */
.pricing-section{padding:4rem 2rem 5rem;border-top:1px solid rgba(232,213,163,.05);}
.pricing-section-title{
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent);text-align:center;margin-bottom:.5rem;
}
.pricing-section-h2{
  font-family:'Sora',sans-serif;font-size:clamp(1.6rem,3vw,2rem);
  font-weight:300;color:var(--text);text-align:center;margin-bottom:3rem;
}
.pricing-cards{display:flex;gap:1.5rem;flex-wrap:wrap;justify-content:center;margin-bottom:3rem;}
.price-card{
  background:rgba(107,152,200,.03);
  border:1px solid rgba(232,213,163,.07);
  border-radius:var(--r2);padding:2rem 1.75rem;width:280px;text-align:left;
  transition:border-color .3s,transform .3s,box-shadow .3s;
}
.price-card:hover{border-color:rgba(232,213,163,.15);transform:translateY(-4px);box-shadow:0 16px 48px rgba(4,12,26,.5);}
.price-card.featured{border-color:rgba(107,152,200,.3);background:rgba(107,152,200,.05);box-shadow:0 0 40px rgba(107,152,200,.08);}
.price-card.featured:hover{border-color:rgba(107,152,200,.5);box-shadow:0 16px 48px rgba(107,152,200,.15);}
.price-card-badge{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--text3);margin-bottom:.75rem;}
.price-card.featured .price-card-badge{color:var(--accent);}
.price-card h3{font-size:18px;font-weight:400;margin-bottom:.5rem;font-family:'Sora',sans-serif;color:var(--text);}
.price-card .amount{font-size:36px;color:var(--gold);margin:1rem 0 .25rem;font-family:'Sora',sans-serif;font-weight:300;}
.price-card .period{font-size:11px;color:var(--text3);margin-bottom:1.5rem;}
.price-card ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin-bottom:2rem;}
.price-card ul li{font-size:13px;color:var(--text2);display:flex;gap:.6rem;align-items:flex-start;}
.price-card ul li::before{content:'✦';color:var(--accent);font-size:9px;margin-top:4px;flex-shrink:0;}
.price-card .btn-gold,.price-card .btn-outline,.price-card .btn-primary{width:100%;padding:11px;text-align:center;display:block;}

.home-footer{
  text-align:center;padding:2.5rem 1rem 2rem;
  font-size:12px;color:var(--text3);
  border-top:1px solid rgba(232,213,163,.05);margin-top:2rem;line-height:2;
}
.home-footer a{color:var(--text3);text-decoration:none;transition:color .2s;}
.home-footer a:hover{color:var(--accent);}

/* ── FORM ──────────────────────────────────────────────────────────────────── */
.form-screen{max-width:580px;margin:0 auto;padding:4rem 2rem;}
.form-title{font-size:26px;font-weight:300;color:var(--text);margin-bottom:.5rem;text-align:center;letter-spacing:.05em;}
.form-sub{font-size:13px;color:var(--text2);text-align:center;margin-bottom:3rem;line-height:1.7;}
.form-group{margin-bottom:1.25rem;}
.form-group label{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text3);display:block;margin-bottom:.5rem;
}
.form-group input,.form-group select{
  width:100%;background:rgba(107,152,200,.04);
  border:1px solid var(--border2);color:var(--text);
  padding:12px 14px;border-radius:var(--r);
  font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:border .2s;
}
.form-group input::placeholder{color:var(--text3);}
.form-group input:focus,.form-group select:focus{border-color:rgba(107,152,200,.5);}
.form-group select option{background:var(--bg3);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-err{
  display:none;font-size:12px;color:#E07070;
  background:rgba(224,112,112,.06);border:1px solid rgba(224,112,112,.18);
  border-radius:var(--r);padding:.75rem 1rem;margin-bottom:1.25rem;line-height:1.6;
}
.form-err.show{display:block;}

/* ── PLAN SELECT ───────────────────────────────────────────────────────────── */
.plan-select{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem;}
.plan-opt{border:1px solid var(--border2);border-radius:var(--r);padding:1rem;cursor:pointer;transition:all .2s;text-align:center;}
.plan-opt:hover{border-color:rgba(107,152,200,.3);background:rgba(107,152,200,.04);}
.plan-opt.sel{border-color:rgba(107,152,200,.5);background:rgba(107,152,200,.07);}
.plan-opt h4{font-size:14px;font-weight:500;color:var(--text);margin-bottom:.3rem;}
.plan-opt .p-price{font-size:20px;color:var(--gold);font-family:'Sora',sans-serif;font-weight:300;}
.plan-opt .p-desc{font-size:11px;color:var(--text3);margin-top:.3rem;}

/* ── CHART LAYOUT ──────────────────────────────────────────────────────────── */
.chart-layout{display:grid;grid-template-columns:1fr 380px;min-height:calc(100vh - 60px);}
.chart-left{
  padding:2rem;
  border-right:1px solid rgba(232,213,163,.06);
  background:var(--bg);
}
.chart-right{
  background:var(--bg2);
  overflow-y:auto;max-height:calc(100vh - 60px);
  border-left:1px solid rgba(232,213,163,.05);
}
.section-title{
  font-size:10px;letter-spacing:.35em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.25rem;opacity:.8;
}
.chart-tabs-wrap{
  margin-bottom:1.75rem;
  border-bottom:1px solid rgba(232,213,163,.08);
}
.chart-tabs{display:flex;gap:0;flex-wrap:wrap;}
.tab-btn{
  background:transparent;
  border:none;border-bottom:2px solid transparent;
  color:var(--text3);
  padding:8px 16px;margin-bottom:-1px;font-size:11px;
  cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;
  letter-spacing:.08em;text-transform:uppercase;
}
.tab-btn:hover{color:var(--text2);border-bottom-color:rgba(232,213,163,.2);}
.tab-btn.active{
  color:var(--gold);
  border-bottom-color:var(--gold3);
}
/* ── INTENT OVERLAY ─────────────────────────────────────────────────────────── */
.intent-opt{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.5rem;padding:1.1rem .75rem;
  background:rgba(255,255,255,.03);border:1px solid var(--border2);
  border-radius:10px;color:var(--text2);font-family:'Inter',sans-serif;
  font-size:12px;letter-spacing:.04em;cursor:pointer;
  transition:all .2s;text-align:center;line-height:1.4;
}
.intent-opt:hover,.intent-opt.sel{
  background:rgba(107,152,200,.1);border-color:rgba(107,152,200,.4);color:var(--accent);
}
/* ── CHART ───────────────────────────────────────────────────────────────────── */
#chartSvg{width:100%;max-width:520px;display:block;margin:0 auto;}
.panel-section{border-bottom:1px solid rgba(232,213,163,.05);padding:1.25rem 1.5rem;}
.panel-section:last-child{border-bottom:none;}

/* ── PLANET LIST ───────────────────────────────────────────────────────────── */
.planet-list{display:flex;flex-direction:column;gap:.4rem;}
.planet-row{
  display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;
  border-radius:var(--r);cursor:pointer;transition:all .2s;border:1px solid transparent;
}
.planet-row:hover{background:rgba(107,152,200,.05);border-color:rgba(107,152,200,.15);}
.planet-glyph{font-size:18px;width:28px;text-align:center;}
.planet-info{flex:1;}
.planet-name{font-size:13px;color:var(--text);font-weight:400;}
.planet-pos{font-size:11px;color:var(--text3);margin-top:2px;letter-spacing:.03em;}
.planet-chevron{color:var(--text3);font-size:10px;opacity:.5;}

/* ── ASPECT LIST ───────────────────────────────────────────────────────────── */
.aspect-list{display:flex;flex-direction:column;gap:.35rem;}
.aspect-row{
  display:flex;align-items:center;gap:.75rem;padding:.55rem .75rem;
  border-radius:var(--r);cursor:pointer;transition:all .2s;border:1px solid transparent;
}
.aspect-row:hover{background:rgba(107,152,200,.05);border-color:rgba(107,152,200,.15);}
.aspect-symbol{font-size:14px;width:22px;text-align:center;}
.aspect-info{flex:1;}
.aspect-planets{color:var(--text);font-size:12px;}
.aspect-type{font-size:10px;color:var(--text3);margin-top:2px;letter-spacing:.04em;}
.aspect-orb{font-size:11px;color:var(--text3);}

/* ── TRANSIT LIST ──────────────────────────────────────────────────────────── */
.transit-row{
  display:flex;align-items:flex-start;gap:.75rem;padding:.65rem .75rem;
  border-radius:var(--r);cursor:pointer;transition:all .2s;
  border:1px solid transparent;margin-bottom:.4rem;
}
.transit-row:hover{background:rgba(107,152,200,.05);border-color:rgba(107,152,200,.15);}
.t-glyph{font-size:16px;width:24px;text-align:center;flex-shrink:0;margin-top:2px;}
.t-info{flex:1;}
.t-title{font-size:12px;color:var(--text);line-height:1.4;}
.t-sub{font-size:10px;color:var(--text3);margin-top:2px;letter-spacing:.03em;}
.t-badge{
  font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  padding:2px 7px;border-radius:10px;white-space:nowrap;flex-shrink:0;margin-top:3px;
}
.t-conj{background:rgba(232,213,163,.1);color:var(--gold);border:1px solid rgba(232,213,163,.2);}
.t-opp{background:rgba(224,112,112,.1);color:#E07070;border:1px solid rgba(224,112,112,.2);}
.t-sq{background:rgba(200,140,80,.1);color:#D4956A;border:1px solid rgba(200,140,80,.2);}
.t-tri{background:rgba(50,160,100,.1);color:#6DC895;border:1px solid rgba(50,160,100,.2);}
.t-sex{background:rgba(107,152,200,.1);color:#7AABFD;border:1px solid rgba(107,152,200,.2);}
.t-quin{background:rgba(160,80,210,.1);color:#B87FD4;border:1px solid rgba(160,80,210,.2);}

/* ── MODAL ─────────────────────────────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(4,12,26,.85);backdrop-filter:blur(4px);
  z-index:500;align-items:flex-start;justify-content:flex-end;
}
.modal-overlay.open{display:flex;}
.modal-panel{
  --modal-planet-color: 107,152,200;
  background:var(--bg2);
  border-left:1px solid rgba(var(--modal-planet-color),.12);
  width:min(560px,100vw);height:100vh;overflow-y:auto;
  display:flex;flex-direction:column;
}
.modal-header{
  padding:1.5rem 1.5rem 1.25rem;
  background:linear-gradient(160deg,
    rgba(var(--modal-planet-color),.12) 0%,
    rgba(var(--modal-planet-color),.04) 50%,
    var(--bg2) 100%);
  border-bottom:1px solid rgba(var(--modal-planet-color),.1);
  position:sticky;top:0;z-index:10;
}
.modal-header-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem;}
.modal-glyph{font-size:38px;line-height:1;letter-spacing:.05em;}
.modal-header-actions{display:flex;align-items:center;gap:.5rem;}
.modal-title{font-size:24px;font-weight:300;color:var(--text);line-height:1.2;letter-spacing:.02em;margin-bottom:.4rem;}
.modal-sub{font-size:12px;color:rgba(var(--modal-planet-color),0.9);letter-spacing:.08em;text-transform:uppercase;}
.modal-close{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text3);
  cursor:pointer;font-size:16px;width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.modal-close:hover{background:rgba(255,255,255,.12);color:var(--text);}
.modal-share-btn{
  background:rgba(var(--modal-planet-color),.08);
  border:1px solid rgba(var(--modal-planet-color),.25);
  color:rgb(var(--modal-planet-color));cursor:pointer;font-size:14px;
  padding:5px 10px;border-radius:var(--r);transition:all .2s;line-height:1;
}
.modal-share-btn:hover{background:rgba(var(--modal-planet-color),.15);}
.modal-body{padding:1.75rem;flex:1;}
.modal-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1rem;color:var(--text3);font-size:13px;padding:4rem 0;text-align:center;
  letter-spacing:.05em;
}
.modal-loading .spin{animation:spin 2s linear infinite;display:inline-block;font-size:28px;color:rgb(var(--modal-planet-color));opacity:.7;}
.modal-content{font-size:15px;color:var(--text2);line-height:2;}
.modal-content h3{
  font-size:11px;font-weight:500;color:rgb(var(--modal-planet-color));
  margin:2.25rem 0 .875rem;letter-spacing:.15em;text-transform:uppercase;
  font-family:'Inter',sans-serif;opacity:.85;
}
.modal-content h3:first-child{margin-top:.25rem;}
.modal-content p{margin-bottom:1.1rem;color:var(--text2);}
.modal-content strong{color:var(--text);font-weight:400;}
.drill-btns{
  display:flex;flex-direction:column;gap:.4rem;
  margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.05);
}
.drill-label{
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text3);margin-bottom:.3rem;opacity:.6;
}
.drill-btn{
  background:transparent;
  border:1px solid rgba(var(--modal-planet-color),.12);
  color:var(--text3);
  padding:10px 14px;border-radius:var(--r);cursor:pointer;font-size:12px;
  font-family:'Inter',sans-serif;text-align:left;transition:all .2s;
  display:flex;align-items:center;gap:.6rem;letter-spacing:.04em;
}
.drill-btn:hover{border-color:rgba(var(--modal-planet-color),.35);color:var(--text);}
.drill-btn::before{content:'↳';color:rgb(var(--modal-planet-color));font-size:13px;opacity:.7;}
/* Campo domanda libera */
.drill-ask{
  margin-top:.8rem;display:flex;gap:.5rem;
}
.drill-ask-input{
  flex:1;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--r);color:var(--text);font-size:12px;font-family:'Inter',sans-serif;
  padding:9px 12px;outline:none;transition:border-color .2s;
}
.drill-ask-input:focus{border-color:rgba(var(--modal-planet-color),.3);}
.drill-ask-input::placeholder{color:var(--text3);opacity:.6;}
.drill-ask-btn{
  background:none;border:1px solid rgba(var(--modal-planet-color),.2);
  color:var(--text3);border-radius:var(--r);padding:9px 14px;cursor:pointer;
  font-size:11px;font-family:'Inter',sans-serif;white-space:nowrap;transition:all .2s;
}
.drill-ask-btn:hover{border-color:rgba(var(--modal-planet-color),.45);color:var(--text);}

/* ── GRAFICO TAB — brief nascosto, chart hero ───────────────────────────────── */
.tab-grafico-active #natalBriefSection{ display:none !important; }
.tab-grafico-active #chartSvg{ max-width:680px; }
.tab-grafico-active .chart-left{ padding-top:1rem; }

/* ── MODAL title serif ──────────────────────────────────────────────────────── */
.modal-title{
  font-family:'Cormorant Garamond','Sora',serif;
  font-size:28px;font-weight:300;letter-spacing:.03em;
}

/* ── ASPECT SVG STROKES ────────────────────────────────────────────────────── */
.asp-conj{stroke:rgba(200,169,110,.45);}.asp-opp{stroke:rgba(180,80,70,.45);}
.asp-sq{stroke:rgba(180,80,70,.38);}.asp-tri{stroke:rgba(110,160,110,.4);}
.asp-sex{stroke:rgba(100,140,180,.35);}.asp-quin{stroke:rgba(160,140,100,.28);}

/* ── PAYMENT ───────────────────────────────────────────────────────────────── */
.pay-screen{max-width:480px;margin:0 auto;padding:4rem 2rem;}
.pay-title{font-size:24px;font-weight:300;color:var(--text);margin-bottom:.5rem;text-align:center;letter-spacing:.05em;}
.pay-sub{font-size:13px;color:var(--text2);text-align:center;margin-bottom:2.5rem;line-height:1.7;}
.pay-summary{background:rgba(107,152,200,.03);border:1px solid var(--border2);border-radius:var(--r2);padding:1.5rem;margin-bottom:2rem;}
.pay-row{display:flex;justify-content:space-between;font-size:13px;padding:.4rem 0;color:var(--text2);}
.pay-row.total{border-top:1px solid var(--border2);margin-top:.75rem;padding-top:.75rem;color:var(--gold);font-size:17px;font-weight:400;}

/* ── USER AREA ─────────────────────────────────────────────────────────────── */
.user-screen{max-width:680px;margin:0 auto;padding:3rem 2rem;}
.user-header{text-align:center;margin-bottom:3rem;}
.user-header h2{font-size:28px;font-weight:300;color:var(--text);margin-bottom:.5rem;letter-spacing:.04em;}
.user-header p{color:var(--text2);font-size:14px;}
.sub-card{
  background:rgba(107,152,200,.03);border:1px solid rgba(232,213,163,.07);
  border-radius:var(--r2);padding:1.5rem;margin-bottom:1.5rem;
}
.sub-card h3{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;font-weight:400;
}
.notif-item{display:flex;gap:1rem;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid rgba(232,213,163,.05);}
.notif-item:last-child{border-bottom:none;}
.notif-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);margin-top:6px;flex-shrink:0;}
.notif-text{font-size:13px;color:var(--text2);line-height:1.6;}
.notif-date{font-size:11px;color:var(--text3);margin-top:.2rem;}

/* ── LANG TOGGLE ───────────────────────────────────────────────────────────── */
.lang-toggle{display:flex;gap:.5rem;}
.lang-btn{
  background:none;border:1px solid var(--border);color:var(--text3);
  padding:4px 10px;border-radius:var(--r);font-size:11px;
  cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;
}
.lang-btn:hover,.lang-btn.active{border-color:rgba(107,152,200,.3);color:var(--accent);}

/* ── AUTH ──────────────────────────────────────────────────────────────────── */
.auth-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(4,12,26,.9);backdrop-filter:blur(8px);
  z-index:700;align-items:center;justify-content:center;
}
.auth-overlay.open{display:flex;}
.auth-box{
  background:var(--bg3);border:1px solid rgba(107,152,200,.15);
  border-radius:var(--r2);padding:2.5rem;width:min(420px,92vw);
  box-shadow:0 0 60px rgba(107,152,200,.08);
}
.auth-box h2{
  font-size:22px;font-weight:300;color:var(--text);
  margin-bottom:.4rem;font-family:'Sora',sans-serif;letter-spacing:.04em;
}
.auth-box p{font-size:13px;color:var(--text2);margin-bottom:2rem;}
.auth-tabs{display:flex;gap:.4rem;margin-bottom:2rem;}
.auth-tab{
  flex:1;background:none;border:1px solid var(--border2);
  color:var(--text3);padding:8px;border-radius:var(--r);
  cursor:pointer;font-family:'Inter',sans-serif;font-size:12px;transition:all .2s;letter-spacing:.05em;
}
.auth-tab.active{background:rgba(107,152,200,.08);border-color:rgba(107,152,200,.35);color:var(--accent);}
.auth-err{font-size:12px;color:#E07070;margin-bottom:1rem;display:none;}
.auth-err.show{display:block;}

/* ── USER PILL ─────────────────────────────────────────────────────────────── */
.user-pill{
  display:flex;align-items:center;gap:.5rem;
  background:transparent;border:1px solid var(--border2);
  border-radius:20px;padding:5px 14px;cursor:pointer;transition:border-color .2s;
}
.user-pill:hover{border-color:rgba(107,152,200,.3);}
.user-pill-name{font-size:12px;color:var(--text2);}
.user-pill-plan{font-size:10px;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;}

/* ── REPORT ────────────────────────────────────────────────────────────────── */
#reportContent h2{font-size:20px;font-weight:300;color:var(--text);line-height:1.4;margin-bottom:1.5rem;font-family:'Sora',sans-serif;}
#reportContent h3{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin:2rem 0 .75rem;font-weight:400;}
#reportContent p{margin-bottom:1.1rem;color:var(--text2);}
#reportContent strong{color:var(--text);font-weight:400;}
#reportContent .report-meta{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--text3);margin-bottom:2rem;}

/* ── CALC OVERLAY ──────────────────────────────────────────────────────────── */
#calcOverlay{
  display:none;position:fixed;inset:0;
  background:rgba(4,12,26,.95);z-index:600;
  flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;
}
#calcOverlay.show{display:flex;}
#calcOverlay .spin{font-size:2.5rem;animation:spin 2s linear infinite;color:var(--accent);opacity:.7;}
#calcOverlay p{color:var(--text3);font-size:13px;letter-spacing:.12em;text-transform:uppercase;}

/* ── HOME MISC ─────────────────────────────────────────────────────────────── */
.hero-badge{font-size:10px;letter-spacing:.45em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;opacity:.8;}

/* ── MOBILE ────────────────────────────────────────────────────────────────── */
@media (max-width:768px){
  /* Layout */
  .chart-layout{grid-template-columns:1fr;}
  .chart-right{max-height:0;overflow:hidden;transition:max-height .3s ease;border-left:none;border-top:1px solid rgba(232,213,163,.06);position:relative;}
  .chart-right.open{max-height:600px;overflow-y:auto;}
  .chart-left{padding:1rem;}

  /* Nav — compatta su mobile */
  nav{padding:0 .75rem;}
  .nav-links{display:none;}
  .lang-toggle{display:none;}
  #devProBtn{display:none !important;}
  #pdfTopBtn{display:none !important;}
  .nav-right{gap:.4rem;}
  .user-pill-name{display:none;}
  .user-pill{padding:4px 10px;}
  .user-pill-plan{font-size:11px;}

  /* Tabs — scorrevoli orizzontalmente */
  .chart-tabs-wrap{position:relative;margin-bottom:1.75rem;}
  .chart-tabs-wrap::after{
    content:'';position:absolute;right:0;top:0;bottom:0;width:40px;
    background:linear-gradient(to right,transparent,var(--bg));
    pointer-events:none;
  }
  .chart-tabs{
    display:flex;flex-wrap:nowrap;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    gap:.3rem;padding-bottom:.4rem;
    scrollbar-width:none;
    margin-bottom:0;
  }
  .chart-tabs::-webkit-scrollbar{display:none;}
  .tab-btn{padding:5px 11px;font-size:11px;white-space:nowrap;flex-shrink:0;}

  /* Planet grid — 1 colonna su mobile */
  #tabPianeti > div{grid-template-columns:1fr !important;max-width:100% !important;}

  /* chart-left non trabocca orizzontalmente */
  .chart-left{overflow-x:hidden;}

  /* Modal */
  .modal-panel{width:100vw;max-height:92vh;}

  /* Home */
  .home-nav{padding:0 1.25rem;}
  .hero{padding:3rem 1.25rem 2rem;min-height:auto;}
  .hero-headline{font-size:clamp(2rem,8.5vw,3rem);}
  .hero-layout{grid-template-columns:1fr;gap:2rem;}
  .hero-left{align-items:flex-start;}
  .hero-right{display:flex;justify-content:center;overflow:hidden;height:200px;margin-top:-.5rem;}
  .hero-orb-wrap{transform:scale(.48);flex-shrink:0;}
  .hero-sub-desc{max-width:100%;}
  .hero-trust{flex-wrap:wrap;}
  .btn-hero-cta{width:100%;justify-content:center;}
  .insight-grid{grid-template-columns:1fr;}
  .insight-section{padding:3rem 1.25rem 2rem;}
  .pricing-cards{flex-direction:column;align-items:center;}
  .price-card{width:100%;max-width:400px;}

  /* Form */
  .form-screen{padding:1.5rem 1.25rem;}
  .pay-screen{padding:2rem 1.25rem;}
  .user-screen{padding:2rem 1.25rem;}

  /* Cookie banner più compatto */
  #cookieBanner{flex-direction:column;gap:.5rem;padding:.75rem 1.25rem;text-align:center;}
  #chartHint{flex-wrap:wrap;}
  #chartHint span{flex:1;min-width:0;}
}
