:root{
  /* Redesign demo-first — palette viola/oro (token rimappati: tutte le
     `var(--x)` esistenti si spostano sulla nuova identità in un colpo solo).
     --yellow = oro accento primario, --violet/--pink/--cyan = famiglia viola. */
  --black:#14101f;--white:#f6f3fc;--yellow:#e8c87a;
  --pink:#9d72ff;--violet:#8b5cff;--cyan:#cdbbff;--orange:#e8c87a;
  --card-bg:#16111f;--surface:#1d1530;
  /* Token redesign (mockup) — testo, bordi, ombre, font */
  --nav-bg:#100c1c;--shadow-deep:#050308;
  --text-2:#b6acce;--text-3:#7d7596;--text-faint:#6f6790;--lilac-nav:#a89fc0;
  --success:#6fd6a0;--grad-cta:linear-gradient(180deg,#9d72ff,#7b3dff);
  --border-soft:rgba(255,255,255,.08);--border-soft-2:rgba(255,255,255,.1);
  --border-violet:rgba(157,114,255,.3);
  --shadow-cta:0 10px 26px rgba(123,61,255,.4);--shadow-card:0 24px 50px -28px rgba(40,30,70,.6);
  --font-display:'Cormorant Garamond',Georgia,serif;--font-ui:'Manrope',system-ui,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--black);color:var(--white);font-family:'Manrope',sans-serif;overflow-x:hidden;cursor:none;}
.cursor{width:18px;height:18px;background:var(--yellow);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,background .2s;mix-blend-mode:difference;}
.cursor.big{transform:translate(-50%,-50%) scale(3);background:var(--pink);}
@media (pointer: coarse) {
  body { cursor: auto !important; }
  .cursor { display: none !important; }
}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:.4;}

/* ── NAV ── */
nav{display:flex;justify-content:space-between;align-items:center;padding:1.2rem 3rem;border-bottom:1px solid #222;position:sticky;top:0;background:rgba(20,16,31,.96);backdrop-filter:blur(10px);z-index:200;}
.logo{font-family:'Cormorant Garamond',sans-serif;font-size:1.8rem;letter-spacing:3px;background:linear-gradient(90deg,var(--yellow),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}
.nav-right{display:flex;gap:1rem;align-items:center;}
/* BUG #5 QA 09GIU2026: hamburger menu mobile (mancava completamente).
   Visibile solo <600px; apre un drawer con link primari (Chi Siamo,
   Come Funziona, Grandi Arcani, Classifica, Contattaci). */
.nav-hamburger{display:none;background:transparent;border:1px solid #333;color:var(--white);width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer;font-size:1.4rem;border-radius:6px;padding:0;}
.nav-hamburger:focus-visible{outline:2px solid var(--yellow);outline-offset:2px;}
.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(80vw,300px);background:var(--card-bg);border-left:1px solid #333;z-index:600;transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column;padding:1.5rem 1.25rem;gap:.5rem;overflow-y:auto;box-shadow:-12px 0 40px rgba(0,0,0,.6);}
.mobile-drawer.open{transform:translateX(0);}
.mobile-drawer .md-close{align-self:flex-end;background:transparent;border:none;color:#aaa;font-size:1.6rem;line-height:1;cursor:pointer;min-width:44px;min-height:44px;}
.mobile-drawer a{color:var(--white);font-family:'Cormorant Garamond',sans-serif;font-size:1.2rem;letter-spacing:2px;text-decoration:none;padding:.85rem .5rem;border-bottom:1px solid #222;min-height:44px;display:flex;align-items:center;}
.mobile-drawer a:hover,.mobile-drawer a:focus-visible{color:var(--yellow);outline:none;}
.mobile-drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:550;display:none;}
.mobile-drawer-backdrop.open{display:block;}
@media(max-width:720px){
  /* Header mobile: padding compatto, logo ridotto, gap stretti, CTA principali
     nascosti (l'hamburger li espone). Prima a 3rem laterali → su iPhone SE
     usciva quasi fuori viewport e il lang select restava illeggibile. */
  nav{padding:.85rem 1rem;gap:.5rem;}
  .logo{font-size:1.35rem;letter-spacing:2px;}
  .nav-right{gap:.5rem;}
  .nav-hamburger{display:flex;}
  #guestNav{display:none;}
  /* Per l'utente loggato (incluso admin): ADMIN e ESCI vanno nel drawer mobile.
     Senza questo l'utente admin vedeva 4 elementi accanto al lang select e i
     bottoni scrollavano orizzontalmente fuori viewport. */
  .desktop-only{display:none!important;}
  #langBtn{font-size:.75rem;min-height:38px;padding:.4rem .55rem;}
}
@media(max-width:480px){
  /* iPhone SE / display ultracompatto: nascondi anche notifBell + name per
     evitare wrap della nav, mantenendo logo+lang+hamburger sempre visibili. */
  #navName{display:none;}
}
.btn{font-family:var(--font-ui);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.6rem 1.2rem;border:none;border-radius:11px;cursor:pointer;transition:all .2s;outline:2px solid transparent;outline-offset:2px;}
.btn:focus-visible{outline-color:var(--cyan);outline-width:2px;}
.btn-outline{background:transparent;border:1px solid rgba(157,114,255,.4);color:var(--white);}
.btn-outline:hover{border-color:var(--violet);color:var(--cyan);background:rgba(139,93,255,.08);}
.btn-outline:focus-visible{border-color:var(--cyan);background:rgba(139,93,255,.12);}
.btn-primary{background:var(--grad-cta);color:#fff;box-shadow:var(--shadow-cta);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 32px rgba(123,61,255,.5);}
.btn-primary:focus-visible{outline-color:var(--cyan);}
.btn-ghost{background:transparent;border:1px solid var(--violet);color:var(--cyan);}
.btn-ghost:hover{background:var(--violet);color:white;}
.btn-ghost:focus-visible{outline-color:var(--cyan);}
.cta-big{outline:2px solid transparent;outline-offset:2px;}
.cta-big:focus-visible{outline-color:var(--cyan);}
#langBtn{outline:2px solid transparent;outline-offset:2px;transition:all .2s;}
#langBtn:focus-visible{outline-color:var(--cyan);border-color:var(--cyan);}
#langBtn{font-family:'Manrope',sans-serif;font-size:.7rem;letter-spacing:2px;background:transparent;border:1px solid #333;color:var(--white);padding:.4rem .8rem;cursor:pointer;}

/* ── HERO (redesign editoriale — mockup TarotVibes Redesign) ── */
.hero{min-height:88vh;display:flex;align-items:center;padding:4rem 3rem;position:relative;background:radial-gradient(120% 90% at 18% -10%,rgba(139,93,255,.22) 0%,transparent 50%),radial-gradient(90% 80% at 95% 110%,rgba(232,200,122,.10) 0%,transparent 55%),var(--black);}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;max-width:1120px;margin:0 auto;width:100%;}
.hero-copy{text-align:left;}
.hero-eyebrow{display:inline-block;font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);border:1px solid rgba(157,114,255,.3);background:rgba(139,93,255,.08);border-radius:999px;padding:.42rem .95rem;margin-bottom:1.4rem;animation:fadeUp .8s ease both;}
.hero-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:clamp(3rem,6.6vw,4.25rem);line-height:.98;color:var(--white);letter-spacing:-.5px;margin-bottom:1.4rem;animation:fadeUp .8s .1s ease both;}
.hero-title em{font-style:italic;color:var(--yellow);}
.hero-sub{font-family:'Manrope',sans-serif;font-size:1.18rem;line-height:1.6;color:#b6acce;max-width:450px;margin:0 0 1.7rem;opacity:1;animation:fadeUp .8s .2s ease both;}
.hero-actions{display:flex;gap:1.2rem;flex-wrap:wrap;align-items:center;margin-top:0;animation:fadeUp .8s .3s ease both;}
.hero-login{font-family:'Manrope',sans-serif;font-size:.95rem;color:#b6acce;margin-top:1rem;}
.hero-login a{color:var(--cyan);font-weight:700;text-decoration:underline;text-underline-offset:3px;cursor:pointer;}
.hero-micro{font-family:'Manrope',sans-serif;font-size:.82rem;color:#7d7596;margin-top:1.2rem;letter-spacing:.2px;}
.hero-teaser{font-family:'Manrope',sans-serif;font-size:.85rem;color:#6f6790;line-height:1.6;margin-top:2.2rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.06);max-width:480px;}
.hero-teaser .gl{color:var(--cyan);}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:420px;}
.tv-card{width:250px;height:386px;border-radius:18px;border:1.5px solid rgba(232,200,122,.5);background:repeating-linear-gradient(135deg,#241b3a,#241b3a 7px,#1d1530 7px,#1d1530 14px);box-shadow:0 28px 60px -22px var(--shadow-deep,#050308);transform:rotate(-5deg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;}
.tv-card-glyph{font-size:3.4rem;color:var(--yellow);line-height:1;}
.tv-card-name{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.5rem;letter-spacing:3px;color:var(--yellow);}
.hero-spark{position:absolute;color:var(--yellow);font-size:1.3rem;animation:tvShimmer 3s ease-in-out infinite;pointer-events:none;}
.hero-spark.s1{top:8%;left:14%;color:var(--cyan);}
.hero-spark.s2{bottom:12%;right:10%;font-size:1.6rem;animation-delay:1s;}
.hero-spark.s3{top:42%;right:24%;font-size:.9rem;animation-delay:.5s;}
@keyframes tvShimmer{0%{opacity:.5}50%{opacity:1}100%{opacity:.5}}
/* CTA primaria a gradiente (mockup) — riusabile su landing + area loggata */
.btn-cta{font-family:'Manrope',sans-serif;font-size:1rem;font-weight:700;letter-spacing:.2px;color:#fff;background:linear-gradient(180deg,#9d72ff,#7b3dff);border:none;border-radius:12px;padding:.95rem 1.8rem;cursor:pointer;box-shadow:0 10px 26px rgba(123,61,255,.4);transition:transform .2s,box-shadow .2s;}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(123,61,255,.5);}
.btn-cta:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;}
/* Pulsanti nav redesign: primaria gradiente + "Accedi" link testuale */
.btn-nav-cta{font-family:'Manrope',sans-serif;font-size:.88rem;font-weight:700;color:#fff;background:linear-gradient(180deg,#9d72ff,#7b3dff);border:none;border-radius:11px;padding:.6rem 1.15rem;cursor:pointer;box-shadow:0 8px 20px rgba(123,61,255,.35);transition:transform .2s,box-shadow .2s;}
.btn-nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 26px rgba(123,61,255,.45);}
.btn-nav-cta:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;}
.btn-nav-link{font-family:'Manrope',sans-serif;font-size:.9rem;font-weight:600;background:transparent;border:none;color:var(--cyan);cursor:pointer;padding:.5rem .6rem;letter-spacing:.2px;}
.btn-nav-link:hover{color:var(--white);text-decoration:underline;text-underline-offset:3px;}
.btn-nav-link:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:6px;}
/* Legacy .cta-big mantenuto per eventuali altri usi, ritematizzato a gradiente */
.cta-big{font-family:'Manrope',sans-serif;font-weight:700;font-size:1rem;letter-spacing:.2px;padding:.95rem 1.8rem;background:linear-gradient(180deg,#9d72ff,#7b3dff);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 10px 26px rgba(123,61,255,.4);transition:transform .2s,box-shadow .2s;}
.cta-big:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(123,61,255,.5);}
.cta-big.sec{background:transparent;border:none;color:var(--cyan);box-shadow:none;font-weight:600;text-decoration:underline;text-underline-offset:3px;padding:.95rem .6rem;}
.cta-big.sec:hover{background:transparent;color:var(--white);box-shadow:none;transform:none;}
@media(max-width:860px){
  .hero{padding:3rem 1.4rem;}
  .hero-grid{grid-template-columns:1fr;gap:2.2rem;text-align:center;}
  .hero-copy{text-align:center;}
  .hero-title{font-size:clamp(2.6rem,11vw,3.2rem);}
  .hero-sub{margin-left:auto;margin-right:auto;}
  .hero-actions{justify-content:center;}
  .hero-login,.hero-micro,.hero-teaser{margin-left:auto;margin-right:auto;}
  .hero-visual{order:-1;min-height:340px;}
  .tv-card{width:210px;height:324px;}
  .tv-card-glyph{font-size:3rem;}
  .tv-card-name{font-size:1.3rem;}
}

/* ── Demo-first: chip argomento nel modal demo (palette viola/oro redesign) ── */
.demo-chip{font-family:'Manrope',sans-serif;font-size:.85rem;font-weight:500;color:#b6acce;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:.55rem .95rem;border-radius:10px;cursor:pointer;transition:all .15s;}
.demo-chip:hover{border-color:rgba(157,114,255,.6);color:#f6f3fc;}
.demo-chip.active{background:rgba(139,93,255,.9);border-color:transparent;color:#fff;font-weight:600;}
.demo-chip:focus-visible{outline:2px solid #9d72ff;outline-offset:2px;}
#demoQuestion:focus{border-color:rgba(157,114,255,.7);}

/* ── FLOATING CARDS ── */
.floating-cards{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.fc{position:absolute;width:55px;height:90px;border-radius:6px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,#1d1530,#241b3a);display:flex;align-items:center;justify-content:center;font-size:1.8rem;animation:floatUp linear infinite;opacity:.2;}
@keyframes floatUp{0%{transform:translateY(100vh) rotate(var(--r));opacity:0;}10%{opacity:.2;}90%{opacity:.2;}100%{transform:translateY(-200px) rotate(var(--r));opacity:0;}}
@media(max-width:768px){.floating-cards{opacity:.1;}}

/* ── MARQUEE ── */
.marquee-wrap{overflow:hidden;border-top:1px solid #222;border-bottom:1px solid #222;padding:.8rem 0;background:rgba(255,225,0,.04);}
.marquee-track{display:flex;gap:3rem;animation:marquee 20s linear infinite;white-space:nowrap;}
/* BUG #6 QA 09GIU2026: il ticker aveva opacity:.6 su giallo => contrasto
   insufficiente al sole / per ipovedenti. Portato a .92 e rinforzato peso. */
.marquee-track span{font-family:'Cormorant Garamond',sans-serif;font-size:1.1rem;letter-spacing:3px;color:var(--yellow);opacity:.92;font-weight:700;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ── MODAL OVERLAY ── */
/* BUG #1 QA 09GIU2026: su mobile il modal era centrato e il titolo + tasto ✕
   uscivano dalla viewport in alto (X non cliccabile, titolo troncato).
   Fix: overlay scrollabile verticalmente, modal con max-height interno e
   close button con tap target 44x44. Allineamento al centro su desktop,
   in alto su mobile (vedi media query). */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:500;display:none;align-items:center;justify-content:center;padding:1rem;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.modal-overlay.active{display:flex;}
.modal{background:var(--card-bg);border:1px solid var(--border-soft);border-radius:24px;width:100%;max-width:460px;padding:2.5rem;position:relative;animation:fadeUp .4s ease;max-height:calc(100vh - 2rem);overflow-y:auto;overscroll-behavior:contain;margin:auto;box-shadow:var(--shadow-card);}
.modal-close{position:absolute;top:.5rem;right:.5rem;background:rgba(19,18,26,.85);border:none;color:#bbb;font-size:1.5rem;cursor:pointer;line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:8px;z-index:2;}
.modal-close:hover,.modal-close:focus-visible{color:var(--pink);background:rgba(255,60,172,.15);outline:none;}
/* Sotto 720px di altezza viewport (e su phone) allinea in alto + scroll
   nell'overlay per evitare il taglio del titolo. */
@media(max-height:720px),(max-width:600px){
  .modal-overlay{align-items:flex-start;padding:.75rem;}
  .modal{margin:.5rem auto;max-height:none;padding:2.75rem 1.25rem 1.5rem;}
  .modal h2{font-size:1.7rem;}
}
.modal h2{font-family:'Cormorant Garamond',sans-serif;font-size:2rem;letter-spacing:2px;margin-bottom:.3rem;}
.modal-sub{font-size:.9rem;color:var(--text-2);margin-bottom:1.5rem;font-family:var(--font-ui);}
.form-group{margin-bottom:1.1rem;}
.form-group label{display:block;font-family:var(--font-ui);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin-bottom:.45rem;}
.form-input{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:var(--white);font-family:var(--font-ui);font-size:1rem;padding:.8rem 1rem;outline:none;transition:border-color .2s,box-shadow .2s;}
.form-input::placeholder{color:var(--text-faint);}
.form-input:focus{border-color:rgba(157,114,255,.7);box-shadow:0 0 0 3px rgba(139,93,255,.18);}
select.form-input{appearance:none;cursor:pointer;}
.form-error{color:var(--pink);font-size:.8rem;margin-top:.3rem;display:none;}
.form-submit{width:100%;padding:.95rem 1rem;background:var(--grad-cta);color:#fff;border:none;border-radius:12px;font-family:var(--font-ui);font-weight:700;font-size:1.05rem;letter-spacing:.2px;cursor:pointer;margin-top:.5rem;box-shadow:var(--shadow-cta);transition:transform .2s,box-shadow .2s;}
.form-submit:hover{transform:translateY(-1px);box-shadow:0 14px 32px rgba(123,61,255,.5);}
.form-switch{text-align:center;margin-top:1rem;font-size:.9rem;color:var(--text-2);}
.form-switch a{color:var(--cyan);cursor:pointer;text-decoration:underline;text-underline-offset:3px;}
.password-wrap{position:relative;}
.eye-btn{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#666;cursor:pointer;font-size:1rem;}

/* ── MAIN APP (logged in) ── */
#app{display:none;}

/* ── USER BAR ── */
.user-bar{background:var(--surface);border-bottom:1px solid #222;padding:.8rem 3rem;display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap;}
.stat-pill{display:flex;align-items:center;gap:.4rem;font-family:'Manrope',sans-serif;font-size:.75rem;letter-spacing:1px;background:rgba(255,255,255,.04);padding:.4rem .9rem;border:1px solid #333;}
.stat-pill .val{color:var(--yellow);font-weight:700;}
.streak-fire{color:var(--orange);}
.level-badge{font-family:'Cormorant Garamond',sans-serif;font-size:.9rem;letter-spacing:2px;background:linear-gradient(90deg,var(--violet),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;}

/* ── TABS ── */
.tabs{display:flex;border-bottom:1px solid #222;background:rgba(20,16,31,.9);position:sticky;top:62px;z-index:100;}
.tab{font-family:'Manrope',sans-serif;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;padding:1rem 1.4rem;background:transparent;border:none;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;min-height:44px;display:inline-flex;align-items:center;gap:.5rem;}
/* Set di icone coerente (de-emojizzazione): glifi lineari monocromatici che
   ereditano il colore del testo via currentColor, così seguono lo stato
   attivo/hover delle tab e qualunque tema viola/oro. */
.tv-ico{width:16px;height:16px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;vertical-align:-3px;}
.tab.active{color:var(--yellow);border-bottom-color:var(--yellow);}
.tab:hover:not(.active){color:var(--white);}

/* ── TAB PANELS ── */
.panel{display:none;padding:3rem 2rem;max-width:860px;margin:0 auto;}
.panel.active{display:block;}

/* ── READING PANEL ── */
.section-label{font-family:'Manrope',sans-serif;font-size:.65rem;letter-spacing:4px;text-transform:uppercase;color:var(--pink);margin-bottom:.6rem;}
.section-title{font-family:'Cormorant Garamond',sans-serif;font-size:clamp(2.2rem,5vw,3.5rem);line-height:1;margin-bottom:2rem;}
.section-title span{color:var(--yellow);}
.topic-selector{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.2rem;}
.topic-btn{font-family:'Manrope',sans-serif;font-size:.62rem;letter-spacing:1px;background:transparent;border:1px solid #333;color:#888;padding:.4rem .9rem;cursor:pointer;transition:all .2s;}
.topic-btn.active,.topic-btn:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(0,245,255,.06);}
.question-input{width:100%;background:var(--card-bg);border:2px solid #333;color:var(--white);font-family:'Manrope',sans-serif;font-size:1rem;padding:1rem 1.2rem;outline:none;resize:none;height:90px;transition:border-color .3s;}
.question-input::placeholder{opacity:.35;}
.question-input:focus{border-color:var(--yellow);}
.spread-row{display:flex;gap:.8rem;margin:1rem 0;flex-wrap:wrap;}
.spread-btn{font-family:'Manrope',sans-serif;font-size:.62rem;letter-spacing:2px;background:transparent;border:1px solid #444;color:var(--white);padding:.5rem 1.2rem;cursor:pointer;transition:all .2s;}
.spread-btn.active,.spread-btn:hover{border-color:var(--pink);color:var(--pink);background:rgba(255,60,172,.08);}
.draw-btn{width:100%;padding:1.1rem;background:linear-gradient(90deg,var(--violet),var(--pink));color:white;border:none;font-family:'Cormorant Garamond',sans-serif;font-size:1.4rem;letter-spacing:3px;cursor:pointer;transition:opacity .2s,transform .2s;margin-top:.8rem;}
.draw-btn:hover{opacity:.88;transform:translateY(-2px);}
.draw-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;}
.reads-counter{font-family:'Manrope',sans-serif;font-size:.65rem;letter-spacing:2px;text-align:right;margin-top:.5rem;opacity:.5;}
.reads-counter .hi{color:var(--yellow);}

/* ── CARDS DISPLAY ── */
.cards-display{display:flex;justify-content:center;gap:1rem;flex-wrap:nowrap;margin:2.5rem 0;min-height:180px;align-items:center;overflow-x:auto;}
.tarot-card{width:90px;height:155px;background:linear-gradient(135deg,#1d1530,#241b3a);border:1px solid #333;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;font-size:2.2rem;opacity:0;transition:opacity .4s,transform .6s,box-shadow .4s;transform:translateY(20px) rotateY(90deg);flex-shrink:0;}
.tarot-card.revealed{opacity:1;transform:translateY(0) rotateY(0deg);box-shadow:0 0 28px rgba(123,47,255,.35);}
.tarot-card.reversed{transform:translateY(0) rotateY(0deg) rotate(180deg);}
.card-name{position:absolute;bottom:8px;font-family:'Manrope',sans-serif;font-size:.5rem;text-align:center;letter-spacing:.5px;opacity:.75;padding:0 4px;}

/* ── READING OUTPUT ── */
.reading-output{background:var(--card-bg);border:1px solid #222;border-left:4px solid var(--violet);padding:1.8rem;margin-top:1.5rem;display:none;animation:fadeUp .5s ease;}
.reading-output.visible{display:block;}
.reading-output h3{font-family:'Cormorant Garamond',sans-serif;font-size:1.3rem;color:var(--yellow);margin-bottom:.8rem;letter-spacing:2px;}
.reading-output p{line-height:1.8;opacity:.88;}
.reading-meta{font-family:'Manrope',sans-serif;font-size:.6rem;opacity:.4;margin-bottom:.8rem;letter-spacing:1px;}
.disclaimer{font-size:.75rem;opacity:.35;margin-top:1.2rem;font-family:'Manrope',sans-serif;}

/* ── GAMIFICATION TOAST ── */
.gm-toast{position:fixed;bottom:2rem;right:2rem;background:var(--surface);border:1px solid var(--violet);padding:1rem 1.5rem;z-index:800;transform:translateY(80px);opacity:0;transition:all .4s;max-width:300px;}
.gm-toast.show{transform:translateY(0);opacity:1;}
.gm-toast .badge-icon{font-size:2rem;display:block;margin-bottom:.3rem;}
.gm-toast .badge-name{font-family:'Cormorant Garamond',sans-serif;font-size:1.1rem;color:var(--yellow);letter-spacing:2px;}
.gm-toast .badge-desc{font-size:.8rem;opacity:.7;margin-top:.2rem;}
.points-flash{font-family:'Cormorant Garamond',sans-serif;font-size:1.3rem;color:var(--yellow);text-align:center;margin-top:.8rem;display:none;animation:pointsPop .6s ease;}
@keyframes pointsPop{0%{transform:scale(.5);opacity:0;}60%{transform:scale(1.2);}100%{transform:scale(1);opacity:1;}}

/* ── LOADING DOTS ── */
.dots{display:inline-flex;gap:4px;align-items:center;}
.dots span{width:7px;height:7px;background:var(--pink);border-radius:50%;animation:bounce 1.4s infinite ease-in-out;}
.dots span:nth-child(2){animation-delay:.2s;}
.dots span:nth-child(3){animation-delay:.4s;}
@keyframes bounce{0%,80%,100%{transform:scale(0);}40%{transform:scale(1);}}

/* ── PROFILE PANEL ── */
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;}
@media(max-width:600px){.profile-grid{grid-template-columns:1fr;}}
.profile-card{background:var(--card-bg);border:1px solid #222;padding:1.5rem;}
.profile-card h3{font-family:'Cormorant Garamond',sans-serif;font-size:1.2rem;letter-spacing:2px;color:var(--yellow);margin-bottom:1rem;}
.stat-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #1a1a1a;font-size:.9rem;}
.stat-row:last-child{border:none;}
.stat-row .label{opacity:.5;font-family:'Manrope',sans-serif;font-size:.65rem;letter-spacing:1px;}
.stat-row .value{font-family:'Cormorant Garamond',sans-serif;font-size:1.1rem;color:var(--white);}

/* PROGRESS BAR */
.progress-wrap{margin:1rem 0;}
.progress-label{display:flex;justify-content:space-between;font-family:'Manrope',sans-serif;font-size:.62rem;opacity:.5;margin-bottom:.4rem;}
.progress-bar{height:6px;background:#222;border-radius:3px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--violet),var(--pink));border-radius:3px;transition:width .8s ease;}

/* LEVELS */
.levels-row{display:flex;gap:.5rem;margin:1rem 0;flex-wrap:wrap;}
.lv{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem;flex:1;min-width:60px;background:var(--nav-bg);border:1px solid var(--border-soft);border-radius:10px;}
.lv.reached{border-color:var(--violet);}
.lv .lv-icon{font-size:1.4rem;color:var(--yellow);line-height:1;}
.lv .lv-name{font-family:var(--font-ui);font-weight:600;font-size:.58rem;letter-spacing:.06em;text-align:center;color:var(--text-3);}

/* BADGES GRID */
.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.8rem;margin-top:.8rem;}
.badge-item{background:#0f0f1a;border:1px solid #222;padding:.8rem;text-align:center;transition:border-color .2s;}
.badge-item.earned{border-color:var(--violet);}
.badge-item .bi{font-size:1.8rem;}
.badge-item .bn{font-family:'Manrope',sans-serif;font-size:.6rem;letter-spacing:.5px;margin-top:.3rem;opacity:.7;}
.badge-item.locked{opacity:.3;filter:grayscale(1);}

/* ── HISTORY PANEL ── */
.history-item{background:var(--card-bg);border:1px solid #222;border-left:3px solid var(--violet);padding:1.2rem;margin-bottom:1rem;cursor:pointer;transition:border-color .2s;}
.history-item:hover{border-left-color:var(--pink);}
.history-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;}
.history-cards{font-size:1.2rem;letter-spacing:2px;}
.history-date{font-family:'Manrope',sans-serif;font-size:.6rem;opacity:.4;}
.history-q{font-size:.9rem;opacity:.7;font-style:italic;}
.history-pts{font-family:'Cormorant Garamond',sans-serif;font-size:.9rem;color:var(--yellow);margin-top:.3rem;}
.reading-expand{display:none;margin-top:1rem;padding-top:1rem;border-top:1px solid #222;font-size:.9rem;line-height:1.7;opacity:.8;}
.history-item.open .reading-expand{display:block;}
/* BUG #8 QA 09GIU2026: indicatore visivo per chiarire che la card è
   un toggle espandibile (i tester non capivano che il click la apriva). */
.history-item{position:relative;padding-right:2.5rem;}
.history-item::after{content:'▾';position:absolute;bottom:1.2rem;right:1rem;font-size:1rem;opacity:.4;transition:transform .2s,opacity .2s;pointer-events:none;}
.history-item.open::after{transform:rotate(180deg);opacity:.9;color:var(--yellow);}
.history-item.open{border-left-color:var(--yellow);}

/* ── LEADERBOARD ── */
.lb-row{display:flex;align-items:center;gap:1rem;padding:.9rem 1rem;border-bottom:1px solid #1a1a1a;transition:background .2s;}
.lb-row:hover{background:rgba(255,255,255,.02);}
.lb-rank{font-family:'Cormorant Garamond',sans-serif;font-size:1.4rem;width:36px;color:#444;}
.lb-rank.top{color:var(--yellow);}
.lb-name{flex:1;font-weight:600;}
.lb-zodiac{opacity:.5;font-size:.85rem;}
.lb-pts{font-family:'Manrope',sans-serif;font-size:.75rem;color:var(--yellow);}
.lb-streak{color:var(--orange);font-size:.85rem;}

/* ── DAILY LIMIT BANNER ── */
.daily-banner{background:rgba(123,47,255,.15);border:1px solid var(--violet);padding:1.2rem;text-align:center;margin-bottom:1.5rem;display:none;}
.daily-banner.show{display:block;}
.daily-banner p{font-family:'Manrope',sans-serif;font-size:.75rem;letter-spacing:1px;}
.daily-banner .next{color:var(--yellow);font-family:'Cormorant Garamond',sans-serif;font-size:1.1rem;margin-top:.3rem;}

/* ── UTILS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.hidden{display:none!important;}
html,body{min-height:100vh;}
#heroSection:not([style*="display: none"]) ~ #app{display:none;}
footer{margin-top:auto;}
@media(max-width:768px){
  nav{padding:1rem 1.2rem;}
  .user-bar{padding:.6rem 1.2rem;gap:.8rem;font-size:.72rem;}
  .panel{padding:2rem 1rem;}
  .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none;}
  .tabs::-webkit-scrollbar{display:none;}
  .tab{white-space:nowrap;scroll-snap-align:start;min-height:48px;padding:.85rem 1.1rem;}
  .user-bar .stat-pill{font-size:.72rem;padding:.35rem .7rem;}
  /* BUG #2 QA 09GIU2026: hero e contenitori usavano padding 2rem laterali
     stretti, che lasciavano una banda nera a destra sui phone più piccoli.
     Riduce i padding e forza max-width:100% sui contenitori inline. */
  .hero{padding:3rem 1rem;}
  /* BUG #4 QA 09GIU2026: la sezione "Come Funziona" usava un grid
     auto-fit minmax(200px,1fr): a 375px le 4 colonne diventavano una sola
     ma con padding 2rem laterali si comprimevano. Forziamo singola
     colonna e riduciamo padding orizzontale. */
  section#heroSection > div[style*="max-width:860px"],
  section#seoContent > div[style*="max-width:860px"]{padding:1rem!important;}
  section#heroSection > div[style*="max-width:860px"] > div[style*="grid"]{grid-template-columns:1fr!important;}
}
/* BUG #2/#5 QA 09GIU2026: regola universale per evitare overflow orizzontale
   da elementi inline-styled che superano la viewport mobile. */
@media(max-width:600px){
  .hero-title{letter-spacing:1px;}
  .hero-actions .cta-big{width:100%;max-width:320px;font-size:1.1rem;padding:.85rem 1.5rem;}
  /* BUG #3 QA 09GIU2026: cookie banner — i 4 bottoni 2x2 avevano testo
     compresso e tap target < 44px. Su mobile li stackiamo a piena larghezza
     con min-height 44px (Apple/Google HIG). */
  #cookieBanner{padding:1rem!important;}
  #cookieBanner > div > div{flex-direction:column!important;align-items:stretch!important;}
  #cookieBanner .btn,#cookieBanner a.btn{width:100%;min-height:44px;display:flex;align-items:center;justify-content:center;font-size:.7rem!important;padding:.6rem 1rem;}
  /* BUG #8 QA 09GIU2026: il toast gamification era posizionato right:2rem
     bottom:2rem con max-width:300px — su 375px usciva o copriva CTA. */
  .gm-toast{bottom:1rem;right:.75rem;left:.75rem;max-width:none;}
}

/* ── FASE 2: EMOTION WIDGET ── */
.emotion-widget{background:var(--card-bg);border:1px solid #222;border-left:4px solid var(--cyan);padding:1.2rem;margin-top:1rem;display:none;animation:fadeUp .5s ease;}
.emotion-widget.visible{display:block;}
.emotion-widget h4{font-family:'Cormorant Garamond',sans-serif;font-size:1.1rem;letter-spacing:1px;color:var(--cyan);margin-bottom:.5rem;}
.emotion-row{display:flex;flex-wrap:wrap;gap:.4rem;margin:.5rem 0 1rem;}
.emo-btn{font-size:1.3rem;background:#0f0f1a;border:1px solid #333;border-radius:8px;width:42px;height:42px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;}
.emo-btn:hover{border-color:var(--cyan);}
.emo-btn.sel{border-color:var(--yellow);background:rgba(255,225,0,.12);transform:scale(1.1);}
.emo-label{font-family:'Manrope',sans-serif;font-size:.6rem;letter-spacing:1px;opacity:.6;text-transform:uppercase;margin-bottom:.3rem;}
.emotion-widget textarea{width:100%;background:#0f0f1a;border:1px solid #333;color:var(--white);font-family:'Manrope',sans-serif;font-size:.85rem;padding:.6rem;outline:none;resize:none;height:48px;margin-bottom:.6rem;}
.emotion-saved{color:var(--cyan);font-family:'Manrope',sans-serif;font-size:.7rem;display:none;}

/* ── FASE 2: DASHBOARD ── */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem;}
.dash-stat{background:var(--card-bg);border:1px solid #222;padding:1.2rem;text-align:center;}
.dash-stat .num{font-family:'Cormorant Garamond',sans-serif;font-size:2.4rem;color:var(--yellow);line-height:1;}
.dash-stat .lbl{font-family:'Manrope',sans-serif;font-size:.6rem;letter-spacing:1px;opacity:.5;margin-top:.3rem;text-transform:uppercase;}
.dash-card{background:var(--card-bg);border:1px solid #222;padding:1.3rem;margin-bottom:1.2rem;}
.dash-card h3{font-family:'Cormorant Garamond',sans-serif;font-size:1.2rem;letter-spacing:1px;color:var(--cyan);margin-bottom:.8rem;}
/* ── Feature request card (dashboard) ── */
.fr-card{position:relative;overflow:hidden;background:linear-gradient(160deg,#181327,#16111f);border:1px solid #2a2440;border-radius:14px;}
.fr-card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 0% 0%,rgba(123,47,255,.20),transparent 58%);pointer-events:none;}
.fr-card>*{position:relative;}
.fr-head{display:flex;align-items:center;gap:.7rem;}
.fr-icon{font-size:1.5rem;line-height:1;filter:drop-shadow(0 0 10px rgba(255,225,0,.45));}
.fr-title{font-family:'Cormorant Garamond',sans-serif;font-size:1.35rem;letter-spacing:1px;color:var(--white);line-height:1.1;}
.fr-sub{opacity:.55;font-size:.82rem;line-height:1.5;margin:.35rem 0 1.1rem;}
.fr-label{font-family:'Manrope',sans-serif;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;opacity:.5;display:block;margin-bottom:.55rem;}
.fr-chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.1rem;}
.fr-chip{font-family:'Manrope',sans-serif;font-size:.72rem;letter-spacing:.5px;color:var(--white);background:#0f0f1a;border:1px solid #2e2a40;border-radius:999px;padding:.42rem .85rem;cursor:pointer;transition:all .18s;}
.fr-chip:hover{border-color:var(--violet);transform:translateY(-1px);}
.fr-chip.active{background:linear-gradient(90deg,var(--violet),var(--pink));border-color:transparent;color:#fff;box-shadow:0 4px 14px rgba(123,47,255,.35);}
.fr-textarea{width:100%;background:#0d0d16;border:1px solid #2e2a40;border-radius:10px;color:var(--white);font-family:'Manrope',sans-serif;font-size:.95rem;line-height:1.5;padding:.85rem 1rem;outline:none;resize:vertical;min-height:92px;transition:border-color .2s,box-shadow .2s;}
.fr-textarea::placeholder{color:#6a6580;}
.fr-textarea:focus{border-color:var(--violet);box-shadow:0 0 0 3px rgba(123,47,255,.18);}
.fr-foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-top:.7rem;}
.fr-count{font-family:'Manrope',sans-serif;font-size:.65rem;opacity:.4;}
.fr-send{font-family:'Cormorant Garamond',sans-serif;font-size:1.05rem;letter-spacing:2px;color:#fff;background:linear-gradient(90deg,var(--violet),var(--pink));border:none;border-radius:10px;padding:.7rem 1.7rem;cursor:pointer;transition:transform .15s,box-shadow .2s,opacity .2s;}
.fr-send:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(255,60,172,.32);}
.fr-send:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;}
.fr-msg{font-family:'Manrope',sans-serif;font-size:.78rem;line-height:1.4;margin-top:.85rem;padding:.6rem .85rem;border-radius:8px;}
.fr-msg.ok{background:rgba(0,245,255,.08);border:1px solid rgba(0,245,255,.4);color:var(--cyan);}
.fr-msg.err{background:rgba(255,60,172,.08);border:1px solid rgba(255,60,172,.4);color:var(--pink);}
.dash-charts{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;}
@media(max-width:680px){.dash-charts{grid-template-columns:1fr;}}

/* Mobile: controlli GDPR del tab Percorso stackano in colonna full-width.
   Su mobile uno accanto all'altro inline-block usciva dal viewport. */
@media(max-width:480px){
  .journey-controls{flex-direction:column;align-items:stretch;}
  .journey-controls .btn{width:100%;justify-content:center;text-align:center;min-height:44px;}
}
.dash-insights li{font-size:.9rem;opacity:.85;margin:.4rem 0;line-height:1.5;list-style:none;padding-left:1.2rem;position:relative;}
.dash-insights li::before{content:'✦';position:absolute;left:0;color:var(--pink);}
.heatmap{display:grid;grid-template-columns:repeat(15,1fr);gap:3px;}
.heat-cell{aspect-ratio:1;border-radius:2px;background:#1d1530;}

/* ── FASE 2: HISTORY FILTERS ── */
.hist-filters{background:var(--card-bg);border:1px solid #222;padding:1rem;margin-bottom:1.2rem;display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;}
.hist-filters input,.hist-filters select{background:#0f0f1a;border:1px solid #333;color:var(--white);font-family:'Manrope',sans-serif;font-size:.82rem;padding:.5rem .7rem;outline:none;}
.hist-filters input:focus,.hist-filters select:focus{border-color:var(--yellow);}
.hist-search{flex:1;min-width:160px;}
.hist-count{font-family:'Manrope',sans-serif;font-size:.65rem;opacity:.5;margin-bottom:.8rem;}
.reflection-box{margin-top:1rem;padding-top:1rem;border-top:1px solid #222;}
.reflection-box textarea{width:100%;background:#0f0f1a;border:1px solid #333;color:var(--white);font-family:'Manrope',sans-serif;font-size:.85rem;padding:.6rem;outline:none;resize:vertical;min-height:60px;}
.hist-actions{display:flex;gap:.5rem;margin-top:.6rem;flex-wrap:wrap;}
.emo-mini{font-size:.95rem;}

/* ── FASE 3: MAZZI ── */
.decks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;}
.deck-card{background:var(--card-bg);border:1px solid #333;border-top:4px solid var(--violet);padding:1.3rem;position:relative;transition:transform .2s,border-color .2s;}
.deck-card:hover{transform:translateY(-3px);}
.deck-card.locked{opacity:.55;filter:grayscale(.6);}
.deck-card.active{border-color:var(--yellow);box-shadow:0 0 24px rgba(255,225,0,.18);}
.deck-emoji{font-size:2.4rem;}
.deck-name{font-family:'Cormorant Garamond',sans-serif;font-size:1.3rem;letter-spacing:1px;margin:.4rem 0;}
.deck-desc{font-size:.82rem;opacity:.7;line-height:1.5;min-height:3.6em;}
.deck-status{font-family:'Manrope',sans-serif;font-size:.62rem;letter-spacing:1px;margin-top:.8rem;text-transform:uppercase;}
.deck-progress{height:5px;background:#222;border-radius:3px;overflow:hidden;margin-top:.4rem;}
.deck-progress > div{height:100%;background:linear-gradient(90deg,var(--violet),var(--pink));}
.deck-btn{margin-top:.8rem;width:100%;padding:.5rem;font-family:'Manrope',sans-serif;font-size:.62rem;letter-spacing:1px;text-transform:uppercase;border:1px solid var(--violet);background:transparent;color:var(--violet);cursor:pointer;transition:all .2s;}
.deck-btn:hover:not(:disabled){background:var(--violet);color:#fff;}
.deck-btn:disabled{opacity:.4;cursor:not-allowed;border-color:#444;color:#888;}
.deck-active-badge{position:absolute;top:.6rem;right:.6rem;font-size:.6rem;font-family:'Manrope',sans-serif;letter-spacing:1px;background:var(--yellow);color:#000;padding:.15rem .4rem;}
.deck-switch{display:flex;gap:.4rem;flex-wrap:wrap;align-items:center;justify-content:center;margin-top:.8rem;}
.deck-chip{font-size:1.2rem;width:38px;height:38px;border-radius:8px;border:1px solid #333;background:#0f0f1a;cursor:pointer;transition:all .15s;}
.deck-chip:hover{border-color:var(--cyan);}
.deck-chip.on{border-color:var(--yellow);background:rgba(255,225,0,.12);}
.deck-chip.lck{opacity:.35;cursor:not-allowed;}
