@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700;900&family=EB+Garamond:wght@400;500;700&display=swap');

:root{
  --gold:#f4cf72;
  --gold-2:#fff2b7;
  --red:#b83d3d;
  --blue:#6f8cff;
  --violet:#9f6dff;
  --green:#67d899;
  --ink:#070606;
  --paper:#17120d;
  --glass:rgba(255,255,255,.075);
  --glass-2:rgba(255,255,255,.12);
  --line:rgba(244,207,114,.28);
  --shadow:0 30px 90px rgba(0,0,0,.55);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
body{font-family:'EB Garamond',serif;color:#fff;background:#070606;min-height:100vh;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:-3;background:radial-gradient(circle at 20% 15%,rgba(244,207,114,.16),transparent 28%),radial-gradient(circle at 82% 18%,rgba(111,140,255,.13),transparent 30%),radial-gradient(circle at 50% 90%,rgba(184,61,61,.12),transparent 32%),linear-gradient(135deg,#080605,#15100c 50%,#050506)}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:-2;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:58px 58px;mask-image:radial-gradient(circle at center,black,transparent 75%)}
a{color:inherit}.page-body,.home-body{position:relative;min-height:100vh;padding:34px}.home-body{display:grid;place-items:center;overflow:hidden}.home-body .embers,.page-body .embers{position:fixed;inset:0;pointer-events:none;z-index:-1;overflow:hidden}.ember{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--gold);box-shadow:0 0 18px var(--gold);opacity:.45;animation:floatUp linear infinite}.smoke{position:fixed;inset:-20%;pointer-events:none;z-index:-2;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.055),transparent 18%),radial-gradient(circle at 70% 70%,rgba(255,255,255,.04),transparent 22%);filter:blur(22px);animation:smoke 18s ease-in-out infinite alternate}@keyframes smoke{to{transform:translate3d(4%,-3%,0) scale(1.08)}}@keyframes floatUp{from{transform:translateY(105vh) scale(.3)}to{transform:translateY(-20vh) scale(1.4)}}

.hero{width:min(1150px,100%);text-align:center;padding:52px;border:1px solid var(--line);border-radius:34px;background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.035));box-shadow:var(--shadow);backdrop-filter:blur(14px);position:relative;overflow:hidden}.hero::before{content:"";position:absolute;inset:-2px;background:conic-gradient(from var(--angle),transparent,rgba(244,207,114,.7),transparent 25%);animation:spin 7s linear infinite;z-index:-2}.hero::after{content:"";position:absolute;inset:1px;border-radius:33px;background:linear-gradient(180deg,rgba(14,10,7,.95),rgba(7,6,6,.88));z-index:-1}@property --angle{syntax:'<angle>';initial-value:0deg;inherits:false}@keyframes spin{to{--angle:360deg}}
.hero h1,.page-title{font-family:'Cinzel',serif;color:var(--gold);letter-spacing:.08em;text-shadow:0 0 16px rgba(244,207,114,.35),0 0 55px rgba(244,207,114,.14)}.hero h1{font-size:clamp(48px,9vw,116px);line-height:.95;margin-bottom:22px}.subtitle{font-size:clamp(21px,2.7vw,31px);line-height:1.55;max-width:860px;margin:0 auto 42px;opacity:.92}.menu-buttons{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:18px}.menu-btn,.next-button,.home-button,.magic-btn{border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.045));backdrop-filter:blur(10px);text-decoration:none;cursor:pointer;transition:.35s ease;box-shadow:0 12px 32px rgba(0,0,0,.25);font-size:21px}.menu-btn{padding:22px 18px;position:relative;overflow:hidden}.menu-btn::before,.magic-btn::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(255,255,255,.18),transparent);transform:translateX(-120%);transition:.7s}.menu-btn:hover::before,.magic-btn:hover::before{transform:translateX(120%)}.menu-btn:hover,.next-button:hover,.home-button:hover,.magic-btn:hover{transform:translateY(-5px) scale(1.02);border-color:var(--gold);box-shadow:0 0 0 1px rgba(244,207,114,.22),0 18px 55px rgba(244,207,114,.17)}

.page-title{text-align:center;font-size:clamp(42px,7vw,76px);margin:38px auto 32px}.home-button{position:fixed;top:22px;left:22px;z-index:20;padding:13px 18px}.content-box{max-width:1180px;margin:0 auto 28px;padding:34px;border:1px solid var(--line);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.095),rgba(255,255,255,.045));box-shadow:var(--shadow);backdrop-filter:blur(14px);font-size:22px;line-height:1.75}.content-box h2{font-family:'Cinzel',serif;color:var(--gold);margin:18px 0 10px}.content-box ul{padding-left:28px}.content-box li{margin:10px 0}.reveal{opacity:0;transform:translateY(20px);transition:.7s}.reveal.visible{opacity:1;transform:translateY(0)}

.cards-toolbar{max-width:1500px;margin:0 auto 24px;display:grid;grid-template-columns:1.3fr repeat(4,auto);gap:12px;align-items:center}.search-input,.select-input,input,select,textarea{background:rgba(0,0,0,.32);border:1px solid var(--line);border-radius:16px;color:white;padding:14px 16px;font-size:18px;font-family:inherit}.search-input::placeholder{color:rgba(255,255,255,.58)}.magic-btn,.next-button{position:relative;overflow:hidden;color:white;padding:14px 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:24px;max-width:1500px;margin:0 auto}.card{height:390px;border-radius:24px;position:relative;overflow:hidden;cursor:pointer;background:#16100c;border:1px solid rgba(244,207,114,.22);box-shadow:0 20px 45px rgba(0,0,0,.38);transform-style:preserve-3d;transition:transform .18s ease,box-shadow .35s,border-color .35s}.card:hover{border-color:rgba(244,207,114,.8);box-shadow:0 24px 70px rgba(244,207,114,.13),0 20px 45px rgba(0,0,0,.55)}.card img{width:100%;height:100%;object-fit:cover;transition:.55s;filter:saturate(1.08) contrast(1.04)}.card:hover img{transform:scale(1.1)}.card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,245,190,.28),transparent 28%),linear-gradient(180deg,transparent 35%,rgba(0,0,0,.95));opacity:.9;z-index:1}.card::after{content:"✦";position:absolute;top:12px;right:15px;color:var(--gold);font-size:27px;z-index:2;text-shadow:0 0 18px var(--gold);animation:pulse 2.5s infinite}@keyframes pulse{50%{opacity:.35;transform:scale(.82)}}.card-info{position:absolute;left:0;right:0;bottom:0;padding:20px;z-index:3}.card-info h2{font-family:'Cinzel',serif;font-size:27px;color:var(--gold);line-height:1.1}.card-info p{font-size:17px;letter-spacing:.09em;opacity:.86;text-transform:uppercase}.card-badges{position:absolute;left:14px;top:14px;z-index:3;display:flex;gap:8px;flex-wrap:wrap}.badge{font-size:13px;letter-spacing:.08em;text-transform:uppercase;padding:6px 9px;border:1px solid var(--line);border-radius:999px;background:rgba(0,0,0,.48);backdrop-filter:blur(8px)}.power-peek{position:absolute;left:14px;right:14px;bottom:96px;z-index:3;padding:12px;border:1px solid rgba(244,207,114,.25);border-radius:16px;background:rgba(0,0,0,.48);backdrop-filter:blur(10px);transform:translateY(18px);opacity:0;transition:.35s;font-size:17px}.card:hover .power-peek{opacity:1;transform:translateY(0)}

.popup{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(0,0,0,.78);backdrop-filter:blur(12px)}.popup.active{display:flex}.popup-content{width:min(1120px,100%);max-height:92vh;overflow:auto;border-radius:34px;border:1px solid rgba(244,207,114,.45);background:linear-gradient(135deg,rgba(24,17,11,.97),rgba(10,8,8,.98));box-shadow:0 40px 120px rgba(0,0,0,.75);display:grid;grid-template-columns:minmax(300px,430px) 1fr;animation:pop .26s ease}.popup-image{min-height:620px;position:relative;overflow:hidden}.popup-image img{width:100%;height:100%;object-fit:cover}.popup-image::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(0,0,0,.45))}.popup-text{padding:38px}.popup-text h2{font-family:'Cinzel',serif;font-size:clamp(38px,6vw,64px);color:var(--gold);line-height:1}.popup-text h3{font-size:25px;opacity:.8;margin:8px 0 22px}.popup-text p{font-size:22px;line-height:1.65}.power-panel{margin-top:24px;display:grid;gap:12px}.power-card{border:1px solid rgba(244,207,114,.25);border-radius:18px;background:rgba(255,255,255,.06);overflow:hidden}.power-head{padding:16px 18px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:21px;color:var(--gold)}.power-body{display:grid;grid-template-rows:0fr;transition:.35s}.power-card.open .power-body{grid-template-rows:1fr}.power-body div{overflow:hidden}.power-body p{padding:0 18px 18px;font-size:19px}.close-popup{position:fixed;top:22px;right:28px;z-index:1001;font-size:48px;cursor:pointer;color:white;text-shadow:0 0 20px #000;transition:.25s}.close-popup:hover{color:var(--gold);transform:rotate(90deg)}@keyframes pop{from{opacity:0;transform:scale(.94) translateY(18px)}to{opacity:1;transform:scale(1) translateY(0)}}

.roles-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin:20px 0}.role-button{padding:16px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.06);cursor:pointer;text-align:center;font-size:20px;transition:.25s}.role-button:hover,.role-button.active{background:rgba(244,207,114,.14);border-color:var(--gold);transform:translateY(-3px)}.role-button.active{box-shadow:0 0 25px rgba(244,207,114,.16)}.timeline{max-width:1180px;margin:30px auto}.timeline-card,.night-step{background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:22px;padding:24px;margin-bottom:18px;animation:fade .4s ease}.timeline-card h2,.night-step h2{font-family:'Cinzel',serif;color:var(--gold);margin-bottom:14px}.step-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.timer-box{text-align:center}.timer-display{font-family:'Cinzel',serif;font-size:clamp(52px,10vw,94px);color:var(--gold);text-shadow:0 0 25px rgba(244,207,114,.3)}.timer-controls{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin:18px 0}.day-night{width:180px;height:180px;border-radius:50%;margin:18px auto;background:radial-gradient(circle,#fff6ad 0 18%,#f6b233 42%,#e16e20 70%);box-shadow:0 0 65px rgba(246,178,51,.45);transition:1s}.day-night.night{background:radial-gradient(circle,#e8e8ff 0 18%,#6d76d8 42%,#101a4a 70%);box-shadow:0 0 65px rgba(109,118,216,.42)}

.vote-arena{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}.vote-card{border:1px solid var(--line);border-radius:22px;padding:20px;background:rgba(255,255,255,.06)}.vote-list{margin-top:14px;display:grid;gap:10px}.coin-container{display:flex;justify-content:center;gap:36px;flex-wrap:wrap;margin-top:35px;perspective:900px}.coin{width:190px;height:190px;position:relative;transform-style:preserve-3d;transition:.8s;cursor:pointer}.coin.flip{transform:rotateY(180deg)}.coin-face{position:absolute;inset:0;border-radius:50%;overflow:hidden;backface-visibility:hidden;border:4px solid var(--gold);box-shadow:0 0 35px rgba(244,207,114,.26)}.coin-face img{width:100%;height:100%;object-fit:cover}.coin-back{transform:rotateY(180deg)}.secret-button{position:fixed;bottom:18px;right:18px;width:64px;height:64px;border-radius:50%;display:grid;place-items:center;text-decoration:none;font-size:27px;color:transparent;border:1px solid transparent;background:transparent;z-index:50;transition:1s}.secret-button:hover{color:var(--gold);border-color:var(--line);background:rgba(255,255,255,.06);box-shadow:0 0 26px rgba(244,207,114,.22)}.photo-container{position:relative;width:240px;margin:0 auto 30px}.creator-photo{width:240px;height:240px;border-radius:50%;object-fit:cover;border:3px solid var(--gold);box-shadow:0 0 35px rgba(244,207,114,.25)}.beautiful-box{position:absolute;right:-28px;bottom:6px;padding:12px 18px;border:1px solid var(--line);border-radius:14px;background:rgba(244,207,114,.15);transform:rotate(-8deg);color:var(--gold)}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(30px);opacity:0;z-index:2000;background:rgba(0,0,0,.78);border:1px solid var(--line);border-radius:999px;padding:13px 20px;backdrop-filter:blur(10px);transition:.35s;font-size:18px}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}@keyframes fade{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

@media(max-width:850px){.page-body,.home-body{padding:22px}.menu-buttons{grid-template-columns:1fr 1fr}.cards-toolbar{grid-template-columns:1fr 1fr}.search-input{grid-column:1/-1}.popup-content{grid-template-columns:1fr}.popup-image{min-height:380px}.step-grid{grid-template-columns:1fr}.content-box{padding:24px;font-size:20px}.home-button{position:static;display:inline-flex;margin-bottom:12px}.cards-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px}.card{height:300px}.card-info h2{font-size:22px}}
@media(max-width:520px){.menu-buttons,.cards-toolbar{grid-template-columns:1fr}.hero{padding:34px 22px}.card{height:285px}.popup{padding:10px}.popup-text{padding:24px}.close-popup{top:8px;right:15px}}

/* === Upgrade carte vive: modalità cinematografica === */
html, body, .no-select, .card, .card-stage, .menu-btn, .magic-btn, .next-button, .role-button, .coin, .home-button{
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
  caret-color:transparent;
}
input, textarea, select{
  -webkit-user-select:text;
  user-select:text;
  caret-color:auto;
}
button, a, .card, .power-chip, .extra-trigger{ -webkit-tap-highlight-color: transparent; }
body.stage-open{overflow:hidden;}
.magic-btn.active-filter{border-color:var(--gold);box-shadow:0 0 28px rgba(244,207,114,.22), inset 0 0 18px rgba(244,207,114,.08);transform:translateY(-2px)}
.cinematic-grid{align-items:stretch;}
.cinematic-card.light{border-color:rgba(244,207,114,.32)}
.cinematic-card.shadow{border-color:rgba(169,82,255,.42);box-shadow:0 20px 48px rgba(0,0,0,.45),0 0 28px rgba(125,50,190,.08)}
.cinematic-card.neutral{border-color:rgba(210,210,210,.32)}
.card-glow-symbol{position:absolute;top:46%;left:50%;z-index:3;transform:translate(-50%,-50%) scale(.7);font-family:'Cinzel',serif;font-size:76px;color:rgba(255,242,183,.72);text-shadow:0 0 26px rgba(244,207,114,.65);opacity:0;transition:.45s;pointer-events:none}.cinematic-card:hover .card-glow-symbol{opacity:1;transform:translate(-50%,-50%) scale(1)}.cinematic-card.shadow .card-glow-symbol{color:rgba(205,166,255,.75);text-shadow:0 0 28px rgba(159,109,255,.75)}.empty-cards{grid-column:1/-1;text-align:center;padding:50px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,.06);font-size:24px;color:var(--gold)}
.card-stage{position:fixed;inset:0;z-index:3000;display:none;overflow:hidden;background:#030202;color:white}.card-stage.active{display:block}.stage-bg{position:absolute;inset:-38px;background-size:cover;background-position:center;filter:blur(22px) brightness(.42) saturate(1.25);transform:scale(1.08);transition:1s}.stage-shade{position:absolute;inset:0;background:radial-gradient(circle at 30% 45%,rgba(255,231,150,.18),transparent 34%),linear-gradient(90deg,rgba(0,0,0,.12),rgba(0,0,0,.84) 62%),linear-gradient(0deg,rgba(0,0,0,.82),transparent 42%)}.card-stage.shadow .stage-shade{background:radial-gradient(circle at 30% 45%,rgba(130,58,255,.26),transparent 34%),linear-gradient(90deg,rgba(0,0,0,.12),rgba(0,0,0,.88) 62%),linear-gradient(0deg,rgba(0,0,0,.86),transparent 42%)}.stage-card-shell{position:relative;z-index:2;width:100%;height:100%;display:grid;grid-template-columns:minmax(320px,46vw) 1fr;align-items:center}.stage-hero{height:100vh;position:relative;overflow:hidden;box-shadow:30px 0 80px rgba(0,0,0,.45)}.stage-hero img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(1.08) contrast(1.04);transform:scale(1);transition:1.1s cubic-bezier(.2,.9,.2,1)}.card-stage.revealed .stage-hero img{transform:scale(1.09)}.stage-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.95)),linear-gradient(90deg,transparent 65%,rgba(0,0,0,.55))}.stage-nameplate{position:absolute;left:clamp(18px,4vw,54px);right:clamp(18px,4vw,54px);bottom:clamp(26px,6vw,70px);z-index:3;text-align:center;transition:.65s}.stage-nameplate strong{display:block;font-family:'Cinzel',serif;color:var(--gold);font-size:clamp(44px,7vw,96px);line-height:.9;text-shadow:0 0 30px #000}.stage-nameplate span{display:block;text-transform:uppercase;letter-spacing:.25em;font-size:clamp(15px,2vw,24px);margin-top:12px;color:#fff2b7}.stage-tap{position:absolute;z-index:4;left:50%;bottom:18px;transform:translateX(-50%);border:1px solid rgba(244,207,114,.45);background:rgba(0,0,0,.48);backdrop-filter:blur(10px);color:var(--gold);border-radius:999px;padding:12px 18px;font-size:17px;cursor:pointer}.stage-reveal{position:relative;z-index:3;padding:clamp(24px,5vw,72px);max-width:790px;opacity:0;transform:translateX(60px);transition:.7s cubic-bezier(.2,.9,.2,1);pointer-events:none}.card-stage.revealed .stage-reveal{opacity:1;transform:translateX(0);pointer-events:auto}.relic{width:116px;height:116px;display:grid;place-items:center;border-radius:30px;border:1px solid rgba(244,207,114,.6);background:radial-gradient(circle,rgba(244,207,114,.26),rgba(0,0,0,.32));box-shadow:0 0 60px rgba(244,207,114,.28);font-family:'Cinzel',serif;font-size:66px;color:var(--gold);margin-bottom:20px;transform:scale(.4) rotate(-18deg);opacity:0;transition:.7s .1s}.card-stage.revealed .relic{opacity:1;transform:scale(1) rotate(0)}.card-stage.shadow .relic{border-color:rgba(159,109,255,.7);color:#d9c2ff;box-shadow:0 0 70px rgba(159,109,255,.32);background:radial-gradient(circle,rgba(159,109,255,.28),rgba(0,0,0,.34))}.stage-kicker{text-transform:uppercase;letter-spacing:.45em;color:var(--gold-2);opacity:.8;font-size:14px;margin-bottom:6px}.stage-reveal h2{font-family:'Cinzel',serif;font-size:clamp(52px,8vw,104px);line-height:.9;color:var(--gold);text-shadow:0 0 32px rgba(244,207,114,.18)}.stage-reveal h3{font-size:clamp(22px,3vw,34px);opacity:.86;margin:8px 0 22px;text-transform:uppercase;letter-spacing:.08em}.stage-reveal p{font-size:clamp(19px,2.2vw,25px);line-height:1.45}.main-power{margin:24px 0 18px;border:1px solid rgba(244,207,114,.32);background:linear-gradient(135deg,rgba(244,207,114,.14),rgba(255,255,255,.05));border-radius:24px;padding:20px;box-shadow:0 20px 60px rgba(0,0,0,.24)}.main-power span{display:block;color:var(--gold);font-family:'Cinzel',serif;font-size:20px;margin-bottom:8px}.main-power p{font-size:21px}.powers-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.power-chip{min-height:118px;border:1px solid rgba(255,255,255,.16);border-radius:20px;background:rgba(255,255,255,.07);color:white;padding:16px;cursor:pointer;text-align:left;transition:.35s;overflow:hidden}.power-chip b{display:block;color:var(--gold);font-family:'Cinzel',serif;font-size:19px;margin-bottom:7px}.power-chip small{font-size:16px;line-height:1.3;opacity:.82}.power-chip.active{grid-column:span 2;transform:translateY(-5px) scale(1.02);border-color:rgba(244,207,114,.68);box-shadow:0 0 38px rgba(244,207,114,.14);background:linear-gradient(135deg,rgba(244,207,114,.16),rgba(255,255,255,.08))}.power-chip.active b{font-size:27px}.power-chip.active small{font-size:19px}.card-stage.shadow .power-chip.active{border-color:rgba(159,109,255,.82);box-shadow:0 0 42px rgba(159,109,255,.22);background:linear-gradient(135deg,rgba(159,109,255,.18),rgba(255,255,255,.07))}.secret-extra{margin-top:14px}.extra-trigger{width:100%;border:1px solid rgba(244,207,114,.32);background:rgba(0,0,0,.28);color:var(--gold);border-radius:18px;padding:16px 18px;font-family:'Cinzel',serif;font-size:19px;cursor:pointer;text-align:left}.extra-text{display:grid;grid-template-rows:0fr;transition:.35s}.extra-text p{overflow:hidden;padding:0 18px;border-left:1px solid rgba(244,207,114,.32);margin-left:18px}.secret-extra.open .extra-text{grid-template-rows:1fr}.secret-extra.open .extra-text p{padding-top:14px;padding-bottom:6px}.stage-close{position:fixed;right:24px;top:18px;z-index:5;width:58px;height:58px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.42);backdrop-filter:blur(10px);color:white;font-size:42px;line-height:1;cursor:pointer;transition:.25s}.stage-close:hover{color:var(--gold);transform:rotate(90deg);border-color:var(--gold)}
@media(max-width:900px){.stage-card-shell{grid-template-columns:1fr;overflow:auto}.stage-hero{height:58vh}.stage-reveal{padding:24px;transform:translateY(30px);max-width:none}.card-stage.revealed .stage-reveal{transform:translateY(0)}.powers-strip{grid-template-columns:1fr}.power-chip.active{grid-column:auto}.stage-shade{background:linear-gradient(180deg,rgba(0,0,0,.1),rgba(0,0,0,.88) 56%)}}
@media(max-width:520px){.stage-hero{height:55vh}.stage-nameplate strong{font-size:42px}.stage-nameplate span{letter-spacing:.12em}.relic{width:82px;height:82px;font-size:48px}.stage-reveal h2{font-size:48px}.stage-close{right:12px;top:10px;width:48px;height:48px;font-size:34px}.power-chip{min-height:auto}.stage-tap{white-space:nowrap}}


/* === V3: proporzioni corrette, carte più pulite, mobile safe === */
*{box-sizing:border-box}
html{touch-action:manipulation;-webkit-text-size-adjust:100%}
body{overscroll-behavior:none}
.cards-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));align-items:start}
.card{height:auto;aspect-ratio:2/3;min-height:0;display:block;background:radial-gradient(circle at 50% 30%,rgba(244,207,114,.13),rgba(0,0,0,.45) 45%),#120d0a}
.cinematic-card.shadow{background:radial-gradient(circle at 50% 30%,rgba(136,73,255,.16),rgba(0,0,0,.48) 46%),#100a16}
.card img{object-fit:contain;padding:8px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(0,0,0,.36))}
.card:hover img{transform:scale(1.025)}
.power-peek{opacity:1;transform:none;bottom:88px;text-align:center;font-weight:800;letter-spacing:.03em;background:rgba(0,0,0,.56)}
.cinematic-card.shadow .power-peek{border-color:rgba(159,109,255,.36);color:#eadcff}
.card-info{background:linear-gradient(180deg,transparent,rgba(0,0,0,.94) 20%)}
.card-stage.active{display:grid;place-items:center}
.stage-card-shell{width:min(1500px,100vw);height:100dvh;grid-template-columns:minmax(340px,42%) minmax(320px,1fr)}
.stage-hero{height:100dvh;background:radial-gradient(circle at center,rgba(244,207,114,.14),rgba(0,0,0,.88) 64%);display:grid;place-items:center}
.card-stage.shadow .stage-hero{background:radial-gradient(circle at center,rgba(142,76,255,.18),rgba(0,0,0,.9) 64%)}
.stage-hero img{width:100%;height:100%;object-fit:contain;object-position:center;padding:clamp(8px,1.6vw,24px);filter:saturate(1.06) contrast(1.03) drop-shadow(0 30px 45px rgba(0,0,0,.55))}
.card-stage.revealed .stage-hero img{transform:scale(1.025)}
.stage-hero::after{background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.92)),linear-gradient(90deg,transparent 74%,rgba(0,0,0,.5))}
.stage-nameplate{bottom:clamp(60px,7vw,92px)}
.stage-nameplate strong{font-size:clamp(40px,5.8vw,82px)}
.stage-tap{bottom:18px;max-width:calc(100% - 28px);white-space:normal;text-align:center;font-weight:800}
.stage-reveal{max-height:100dvh;overflow:auto;scrollbar-width:thin}
.stage-reveal h2{font-size:clamp(42px,6vw,86px)}
.main-power p{font-size:clamp(17px,1.6vw,21px)}
.stage-reveal p{font-size:clamp(17px,1.7vw,23px)}
.power-chip{min-height:104px}
.lucifer-chip.active{grid-column:1/-1;min-height:150px;background:radial-gradient(circle at 25% 20%,rgba(159,109,255,.25),rgba(255,255,255,.07))}
.extra-trigger::after{content:' tocca per aprire';font-family:inherit;font-size:13px;opacity:.65;margin-left:8px;text-transform:none;letter-spacing:0}
@media(max-width:900px){
  .cards-grid{grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:14px}
  .stage-card-shell{display:block;overflow:auto;height:100dvh}
  .stage-hero{height:58dvh;min-height:390px;box-shadow:none}
  .stage-hero img{padding:8px 12px 54px}
  .stage-nameplate{bottom:58px}.stage-tap{bottom:10px}
  .stage-reveal{max-height:none;overflow:visible;padding-bottom:80px;background:linear-gradient(180deg,rgba(0,0,0,.2),rgba(0,0,0,.72))}
}
@media(max-width:520px){
  .page-body,.home-body{padding:16px}.cards-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.card{border-radius:18px}.card img{padding:5px}.card-info{padding:14px}.card-info h2{font-size:20px}.card-info p{font-size:12px}.power-peek{font-size:12px;bottom:72px;padding:8px}
  .stage-hero{height:56dvh;min-height:340px}.stage-nameplate strong{font-size:38px}.stage-nameplate span{font-size:13px}.stage-reveal{padding:20px}.powers-strip{gap:10px}.power-chip b{font-size:18px}.power-chip small{font-size:15px}
}
@media(hover:none){.card:hover img{transform:none}.card-glow-symbol{opacity:.75;transform:translate(-50%,-50%) scale(.85)}}


/* === V4: mix apertura v2 + spettacolo v3 + mobile/proporzioni definitive === */
html,body{min-height:100%;}
body{overflow-x:hidden;overflow-y:auto;}
.home-body{overflow-y:auto;overflow-x:hidden;align-items:center;justify-items:center;min-height:100svh;min-height:100dvh;}
@supports not (height:100dvh){.home-body{min-height:100vh}.stage-card-shell{height:100vh}.stage-hero{height:100vh}}

/* Le scritte di aiuto non restano fisse: compaiono solo al passaggio del mouse */
.power-peek{opacity:0!important;transform:translateY(14px)!important;pointer-events:none;bottom:92px!important;}
.cinematic-card:hover .power-peek,.cinematic-card:focus-visible .power-peek{opacity:1!important;transform:translateY(0)!important;}
@media(hover:none){.power-peek{display:none!important}}

/* Carte tutte uguali, incluse Ombra/Neutro: niente tagli o deformazioni */
.cards-grid{grid-template-columns:repeat(auto-fit,minmax(205px,1fr));align-items:start;}
.card,.cinematic-card,.cinematic-card.shadow,.cinematic-card.neutral{aspect-ratio:2/3!important;height:auto!important;min-height:0!important;max-height:none!important;display:block;border-radius:24px;}
.card img,.cinematic-card img,.cinematic-card.shadow img{width:100%!important;height:100%!important;object-fit:contain!important;object-position:center!important;padding:8px!important;background:radial-gradient(circle at 50% 34%,rgba(255,255,255,.045),rgba(0,0,0,.34) 62%);}
.cinematic-card.shadow{border-color:rgba(159,109,255,.28)!important;box-shadow:0 20px 45px rgba(0,0,0,.42), inset 0 0 0 1px rgba(159,109,255,.08);}
.cinematic-card.shadow::before{background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(174,127,255,.30),transparent 29%),linear-gradient(180deg,transparent 35%,rgba(0,0,0,.96));}
.cinematic-card.neutral{border-color:rgba(210,210,210,.24)!important;}
.card-info{pointer-events:none;background:linear-gradient(180deg,transparent,rgba(0,0,0,.96) 30%)!important;}
.card-badges{pointer-events:none;}
.card:hover img{transform:scale(1.018)!important;}

/* Apertura: foto corretta, non troppo zoomata, ma con gli effetti scenici della v3 */
.card-stage.active{display:grid!important;place-items:center;overflow:hidden;}
.stage-card-shell{width:min(1540px,100vw);height:100svh;height:100dvh;grid-template-columns:minmax(330px,41%) minmax(320px,1fr);}
.stage-hero{height:100svh;height:100dvh;display:grid;place-items:center;overflow:hidden;background:radial-gradient(circle at center,rgba(244,207,114,.14),rgba(0,0,0,.9) 66%);}
.card-stage.shadow .stage-hero{background:radial-gradient(circle at center,rgba(150,84,255,.20),rgba(0,0,0,.92) 66%);}
.stage-hero img{width:100%!important;height:100%!important;object-fit:contain!important;object-position:center!important;padding:clamp(10px,2vw,28px) clamp(10px,1.8vw,24px) clamp(76px,7vw,104px)!important;transform:scale(1)!important;filter:saturate(1.07) contrast(1.04) drop-shadow(0 30px 42px rgba(0,0,0,.58))!important;}
.card-stage.revealed .stage-hero img{transform:scale(1.018)!important;}
.stage-nameplate{bottom:clamp(58px,7vw,94px);}
.stage-tap{bottom:18px;max-width:min(92%,420px);white-space:normal;line-height:1.15;}
.stage-reveal{max-height:100svh;max-height:100dvh;overflow:auto;-webkit-overflow-scrolling:touch;}
.power-chip{touch-action:manipulation;}
.power-chip.active{transform:translateY(-4px) scale(1.015);}
.lucifer-chip.active{grid-column:1/-1;min-height:150px;}

@media(max-width:900px){
  body.stage-open{overflow:hidden!important;}
  .home-body{display:block;padding:18px;}
  .hero{margin:0 auto;max-height:none;}
  .menu-buttons{grid-template-columns:1fr 1fr;}
  .cards-toolbar{position:sticky;top:0;z-index:20;padding:10px 0;background:linear-gradient(180deg,rgba(7,6,6,.96),rgba(7,6,6,.78));backdrop-filter:blur(10px);}
  .cards-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;}
  .stage-card-shell{display:block;height:100svh;height:100dvh;overflow:auto;-webkit-overflow-scrolling:touch;}
  .stage-hero{height:58svh;height:58dvh;min-height:360px;box-shadow:none;}
  .stage-hero img{padding:10px 12px 74px!important;}
  .stage-nameplate{bottom:54px;}
  .stage-tap{bottom:10px;font-size:15px;padding:10px 14px;}
  .stage-reveal{max-height:none;overflow:visible;padding:24px 20px 88px;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.78));}
  .stage-reveal h2{font-size:clamp(40px,12vw,62px);}
  .powers-strip{grid-template-columns:1fr;}
  .power-chip.active,.lucifer-chip.active{grid-column:auto;min-height:auto;}
}
@media(max-width:520px){
  .page-body,.home-body{padding:14px;}
  .hero{padding:30px 18px;border-radius:26px;}
  .hero h1{font-size:clamp(44px,14vw,72px);}
  .subtitle{font-size:20px;margin-bottom:28px;}
  .menu-buttons{grid-template-columns:1fr;gap:12px;}
  .menu-btn{padding:18px 14px;font-size:20px;}
  .cards-toolbar{grid-template-columns:1fr 1fr;gap:9px;}
  .search-input{grid-column:1/-1;}
  .magic-btn{font-size:16px;padding:12px 10px;}
  .cards-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
  .card,.cinematic-card{border-radius:18px;}
  .card img{padding:5px!important;}
  .card-info{padding:12px!important;}
  .card-info h2{font-size:19px!important;}
  .card-info p{font-size:11px!important;letter-spacing:.06em;}
  .badge{font-size:10px;padding:5px 7px;}
  .card-glow-symbol{font-size:56px;}
  .stage-hero{height:56svh;height:56dvh;min-height:320px;}
  .stage-nameplate strong{font-size:36px!important;}
  .stage-nameplate span{font-size:12px!important;letter-spacing:.1em!important;}
  .stage-close{right:10px;top:10px;width:46px;height:46px;font-size:34px;}
  .relic{width:80px;height:80px;font-size:46px;}
}
