:root{
  --ink:#07050f;--deep:#0e0a1a;--mid:#160f2e;
  --gold:#c9a84c;--gold2:#f0d080;--rose:#e07090;
  --text:#e8dfc8;--muted:rgba(232,223,200,.55);
  --border:rgba(201,168,76,.18);--r:16px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Crimson Pro','Times New Roman',serif;background:var(--ink);color:var(--text);min-height:100vh;overflow-x:hidden;position:relative}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(60,20,120,.55) 0%,transparent 70%),
    radial-gradient(ellipse 60% 40% at 10% 80%,rgba(30,10,80,.4) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 90% 60%,rgba(100,30,60,.25) 0%,transparent 60%),
    linear-gradient(180deg,#07050f 0%,#0e0a1a 40%,#160f2e 100%)}
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}
.wrap{position:relative;z-index:1;max-width:920px;margin:0 auto;padding:28px 16px 80px}

/* HEADER */
.hdr{text-align:center;padding:16px 0 30px}
.hdr-eye{font-family:'Philosopher',serif;font-size:10px;letter-spacing:.28em;color:var(--gold);opacity:.7;text-transform:uppercase;margin-bottom:12px}
.hdr h1{font-family:'Philosopher',serif;font-size:clamp(2rem,6vw,3.2rem);font-weight:700;letter-spacing:.04em;
  color:var(--gold);line-height:1.15;margin-bottom:10px}
.fonts-loaded .hdr h1{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 45%,var(--gold) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hdr p{font-size:15px;font-style:italic;color:var(--muted);line-height:1.7;max-width:420px;margin:0 auto}
.orn{display:flex;align-items:center;justify-content:center;gap:10px;margin:14px 0 0;color:var(--gold);opacity:.3;font-size:11px}
.orn::before,.orn::after{content:'';display:block;height:1px;width:80px;background:linear-gradient(90deg,transparent,var(--gold))}
.orn::after{transform:scaleX(-1)}

/* API BOX */
.api-box{display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  background:rgba(14,10,26,.88);border:1px solid var(--border);border-radius:var(--r);padding:15px 20px;margin-bottom:22px}
.api-box label{font-family:'Philosopher',serif;font-size:11px;letter-spacing:.1em;color:var(--gold);white-space:nowrap}
.api-box input{flex:1;min-width:180px;background:rgba(255,255,255,.05);border:1px solid rgba(201,168,76,.2);
  border-radius:8px;padding:9px 13px;font-family:'Crimson Pro','Times New Roman',serif;font-size:14px;color:var(--text);outline:none;transition:border-color .2s}
.api-box input:focus{border-color:var(--gold)}
.api-box input::placeholder{color:rgba(232,223,200,.28);font-style:italic}
.api-st{font-size:11px;padding:6px 13px;border-radius:20px;font-family:'Philosopher',serif;letter-spacing:.06em;
  background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.2);color:var(--gold);white-space:nowrap}
.api-st.ok{background:rgba(80,200,120,.1);border-color:rgba(80,200,120,.3);color:#6dd98a}

/* STEPS */
.steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:30px}
.step{display:flex;flex-direction:column;align-items:center;gap:5px}
.step-dot{width:34px;height:34px;border-radius:50%;border:1.5px solid rgba(201,168,76,.2);
  background:rgba(255,255,255,.02);display:flex;align-items:center;justify-content:center;
  font-family:'Philosopher',serif;font-size:11px;color:rgba(201,168,76,.3);transition:all .4s}
.step.active .step-dot{border-color:var(--gold);background:rgba(201,168,76,.12);color:var(--gold);box-shadow:0 0 18px rgba(201,168,76,.3)}
.step.done .step-dot{border-color:#6dd98a;background:rgba(109,217,138,.1);color:#6dd98a}
.step-lbl{font-family:'Philosopher',serif;font-size:9px;letter-spacing:.1em;color:rgba(201,168,76,.3);text-transform:uppercase}
.step.active .step-lbl{color:var(--gold)}
.step.done .step-lbl{color:#6dd98a}
.step-line{width:52px;height:1px;margin:0 4px 18px;background:rgba(201,168,76,.12);transition:background .4s}
.step-line.done{background:linear-gradient(90deg,#6dd98a,var(--gold))}

/* PANELS */
.panel{display:none}
.panel.active{display:block;animation:fadeUp .42s cubic-bezier(.22,1,.36,1) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.glass{background:linear-gradient(135deg,rgba(22,15,46,.92),rgba(14,10,26,.92));
  border:1px solid var(--border);border-radius:var(--r);padding:26px 24px;position:relative;overflow:visible}
.glass::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.45}

/* P1 QUESTION */
.q-lbl{font-family:'Philosopher',serif;font-size:11px;letter-spacing:.15em;color:var(--gold);text-transform:uppercase;margin-bottom:10px;opacity:.85}
textarea#qInput{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.18);
  border-radius:10px;padding:13px 15px;font-family:'Crimson Pro','Times New Roman',serif;font-size:16px;font-style:italic;
  color:var(--text);resize:none;outline:none;min-height:94px;line-height:1.65;transition:border-color .25s,box-shadow .25s}
textarea#qInput:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.1)}
textarea#qInput::placeholder{color:rgba(232,223,200,.24);font-style:italic}
.quick-qs{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.qq{background:transparent;border:1px solid rgba(201,168,76,.2);color:rgba(201,168,76,.65);
  font-family:'Crimson Pro','Times New Roman',serif;font-size:13px;padding:5px 13px;border-radius:20px;cursor:pointer;transition:all .18s}
.qq:hover{background:rgba(201,168,76,.1);color:var(--gold);border-color:var(--gold)}
/* CARD COUNT SELECTOR */
.spread-pick{display:flex;gap:10px;justify-content:center;margin-top:20px;flex-wrap:wrap}
.spread-opt{
  font-family:'Philosopher',serif;font-size:11px;letter-spacing:.1em;
  padding:10px 22px;border-radius:10px;border:1.5px solid rgba(201,168,76,.25);
  background:rgba(201,168,76,.04);color:rgba(201,168,76,.6);
  cursor:pointer;transition:all .22s;text-transform:uppercase;
}
.spread-opt:hover{background:rgba(201,168,76,.1);color:var(--gold);border-color:var(--gold)}
.spread-opt.selected{
  background:linear-gradient(135deg,rgba(122,92,16,.5),rgba(201,168,76,.25));
  border-color:var(--gold);color:var(--gold2);
  box-shadow:0 0 16px rgba(201,168,76,.25);
}
.spread-desc{text-align:center;font-size:13px;font-style:italic;color:var(--muted);
  margin-top:10px;min-height:20px;transition:opacity .3s}


/* BUTTONS */
.btn-row{display:flex;gap:11px;justify-content:center;margin-top:26px;flex-wrap:wrap;position:relative;z-index:10}
.btn{font-family:'Philosopher',serif;font-size:11px;letter-spacing:.1em;padding:12px 28px;
  border-radius:10px;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .22s;text-transform:uppercase}
.btn-gold{background:linear-gradient(135deg,#7a5c10,var(--gold));color:#0e0a1a;box-shadow:0 5px 24px rgba(201,168,76,.25)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(201,168,76,.4)}
.btn-ghost{background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.2);color:var(--muted)}
.btn-ghost:hover{background:rgba(201,168,76,.08);color:var(--text)}
.btn:disabled{opacity:.3;cursor:not-allowed;transform:none!important}

/* P2 FAN */
.shuffle-row{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:12px;flex-wrap:wrap;position:relative;z-index:10}
.sh-info{font-family:'Philosopher',serif;font-size:10px;letter-spacing:.07em;color:rgba(201,168,76,.5);text-align:center;transition:color .3s}
.pick-slots{display:flex;gap:9px;justify-content:center;margin-bottom:8px;position:relative;z-index:10}
.pslot{width:42px;height:60px;border-radius:6px;border:1.5px dashed rgba(201,168,76,.25);
  background:rgba(201,168,76,.03);display:flex;align-items:center;justify-content:center;
  font-family:'Philosopher',serif;font-size:11px;color:rgba(201,168,76,.3);transition:all .3s}
.pslot.filled{border-color:var(--gold);border-style:solid;background:rgba(201,168,76,.1);color:var(--gold)}

.fan-stage{position:relative;width:100%;height:430px;
  margin:0;overflow:visible;}
.fan-hint{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  font-family:'Philosopher',serif;font-size:9px;letter-spacing:.1em;
  color:rgba(201,168,76,.28);white-space:nowrap;pointer-events:none;z-index:0}

/* each fan card */
.fc{position:absolute;width:68px;height:115px;border-radius:7px;
  transform-origin:center 175px;cursor:pointer;
  transition:transform .3s cubic-bezier(.22,1,.36,1),filter .2s;
  user-select:none;will-change:transform}
.fc:hover:not(.fc-picked){
  filter:brightness(1.25) drop-shadow(0 0 10px rgba(201,168,76,.7));
  z-index:500!important}
.fc.fc-picked{pointer-events:none;filter:brightness(.22)!important;transition:filter .35s}
.fc.fc-flyout{transition:transform .6s cubic-bezier(.22,1,.36,1),opacity .45s ease;
  opacity:0;transform:translateY(-260px) scale(.7)!important;
  pointer-events:none;z-index:600!important}
.fc-inner{width:100%;height:100%;border-radius:7px;overflow:hidden;
  border:1px solid rgba(201,168,76,.3);
  box-shadow:0 2px 12px rgba(0,0,0,.7),0 0 0 1px rgba(201,168,76,.08)}
.fc-inner img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
/* fallback if matsau.png missing */
.fc-back-fallback{width:100%;height:100%;background:linear-gradient(160deg,#1a0f38,#0e0a1a);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;color:rgba(201,168,76,.4)}

.fc.fc-shuffle{animation:wobble .5s ease both}
@keyframes wobble{
  0%  {transform:var(--bt) translateY(0)}
  25% {transform:var(--bt) translateY(-20px) rotate(-6deg)}
  55% {transform:var(--bt) translateY(-12px) rotate(4deg)}
  80% {transform:var(--bt) translateY(-3px) rotate(-1.5deg)}
  100%{transform:var(--bt) translateY(0)}}

/* P3 REVEAL */
.reveal-area{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.rslot{display:flex;flex-direction:column;align-items:center;gap:9px;flex:1;min-width:140px;max-width:195px}
.rpos{font-family:'Philosopher',serif;font-size:9px;letter-spacing:.2em;color:var(--gold);text-transform:uppercase;opacity:.8}
.rsub{font-size:12px;color:var(--muted);font-style:italic;text-align:center}

.flip-card{width:128px;height:216px;perspective:700px}
.flip-inner{width:100%;height:100%;transform-style:preserve-3d;
  transition:transform .85s cubic-bezier(.4,0,.2,1);border-radius:10px}
.flip-card.flipped .flip-inner{transform:rotateY(180deg)}
.flip-f,.flip-b{position:absolute;inset:0;border-radius:10px;
  backface-visibility:hidden;-webkit-backface-visibility:hidden;overflow:hidden}

/* front face = card back image (shown before flip) */
.flip-f{border:1.5px solid rgba(201,168,76,.3);box-shadow:0 8px 28px rgba(0,0,0,.6)}
.flip-f img{width:100%;height:100%;object-fit:cover;display:block}
.flip-f-fallback{width:100%;height:100%;background:linear-gradient(160deg,#1a0f38,#0e0a1a);
  display:flex;align-items:center;justify-content:center;font-size:28px;
  color:rgba(201,168,76,.35);filter:drop-shadow(0 0 10px rgba(201,168,76,.5))}

/* back face = card front image (shown after flip) */
.flip-b{transform:rotateY(180deg);
  border:1.5px solid rgba(201,168,76,.5);
  box-shadow:0 10px 40px rgba(0,0,0,.75),0 0 0 1px rgba(201,168,76,.18);
  background:#0a0716;display:flex;flex-direction:column}
.flip-b.rev{border-color:rgba(224,112,144,.55);box-shadow:0 10px 40px rgba(0,0,0,.75),0 0 0 1px rgba(224,112,144,.2)}

.cimg{flex:1;position:relative;overflow:hidden;background:#080512}
.cimg img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
/* REVERSED: rotate image 180deg */
.flip-b.rev .cimg img{transform:rotate(180deg)}

.rev-badge{position:absolute;top:5px;right:6px;z-index:2;
  font-family:'Philosopher',serif;font-size:7px;letter-spacing:.1em;
  color:var(--rose);background:rgba(224,112,144,.14);
  border:1px solid rgba(224,112,144,.35);padding:2px 6px;border-radius:10px;text-transform:uppercase}

.cfooter{padding:6px 8px 8px;text-align:center;
  background:rgba(0,0,0,.42);border-top:1px solid rgba(201,168,76,.1);flex-shrink:0}
.cen{font-family:'Philosopher',serif;font-size:8px;letter-spacing:.08em;
  color:var(--gold);opacity:.75;display:block;margin-bottom:2px;text-transform:uppercase}
.cvi{font-size:12px;font-weight:600;color:var(--text);display:block}
.cvi.rev{color:var(--rose)}
.cfallback{width:100%;height:100%;display:none;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;
  background:linear-gradient(160deg,#1a0f38,#0e0a1a)}
.cfb-suit{font-family:'Philosopher',serif;font-size:10px;letter-spacing:.15em;color:rgba(201,168,76,.5)}
.cfb-emoji{font-size:44px}

/* AI */
.ai-box{background:linear-gradient(135deg,rgba(22,15,46,.95),rgba(14,10,26,.95));
  border:1px solid rgba(201,168,76,.18);border-radius:var(--r);padding:24px;
  position:relative;overflow:hidden;margin-top:6px}
.ai-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.55}
.ai-hdr{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.ai-av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#7a5c10,var(--gold));
  display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;
  box-shadow:0 0 18px rgba(201,168,76,.3)}
.ai-title{font-family:'Philosopher',serif;font-size:13px;color:var(--gold);letter-spacing:.06em}
.ai-sub{font-size:12px;color:var(--muted);font-style:italic;margin-top:2px}
#aiBody{font-size:15.5px;line-height:1.88;color:rgba(232,223,200,.88);white-space:pre-line}
.ai-dots{display:inline-flex;gap:5px;align-items:center}
.ai-dots span{width:6px;height:6px;border-radius:50%;background:var(--gold);
  display:inline-block;animation:aiD 1.2s ease-in-out infinite;opacity:.5}
.ai-dots span:nth-child(2){animation-delay:.2s}
.ai-dots span:nth-child(3){animation-delay:.4s}
@keyframes aiD{0%,80%,100%{transform:scale(1);opacity:.5}40%{transform:scale(1.5);opacity:1}}
.ai-err{background:rgba(224,112,144,.08);border:1px solid rgba(224,112,144,.22);
  border-radius:8px;padding:10px 14px;font-size:13px;color:rgba(224,112,144,.85);margin-bottom:10px}

.divider{height:1px;margin:26px 0;background:linear-gradient(90deg,transparent,rgba(201,168,76,.18),transparent)}
.reset-area{text-align:center;padding-bottom:8px}
.pt-host{position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden}
.pt{position:absolute;width:4px;height:4px;border-radius:50%;animation:ptFly 1.2s ease-out forwards}
@keyframes ptFly{0%{opacity:1;transform:translate(0,0) scale(1)}100%{opacity:0;transform:translate(var(--tx),var(--ty)) scale(.3)}}

@media(max-width:540px){
  .fan-stage{height:300px;}
  .fc{width:52px;height:88px;transform-origin:center 140px;}
  .flip-card{width:106px;height:180px}
  .reveal-area{gap:12px}
  .rslot{min-width:106px}
  .glass{padding:18px 14px}
  .step-line{width:30px}
}

/* ═══ SHARE ═══ */
.btn-share{
  background:linear-gradient(135deg,rgba(40,20,90,.9),rgba(60,30,120,.8));
  border:1.5px solid rgba(201,168,76,.4);color:var(--gold2);
  box-shadow:0 5px 24px rgba(100,50,200,.2),0 0 0 1px rgba(201,168,76,.08);
  font-size:12px;padding:13px 28px;letter-spacing:.12em;
}
.btn-share:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 32px rgba(100,50,200,.35),0 0 20px rgba(201,168,76,.2);
  border-color:var(--gold);color:var(--gold2);
}

.share-overlay{
  position:fixed;inset:0;background:rgba(7,5,15,.72);
  backdrop-filter:blur(10px);z-index:10000;
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.share-overlay.active{opacity:1;pointer-events:all;}
.share-overlay.active .share-sheet{transform:translateY(0);}

.share-sheet{
  width:min(560px,100vw);
  background:linear-gradient(160deg,rgba(22,15,46,.98),rgba(14,10,26,.98));
  border:1px solid rgba(201,168,76,.22);
  border-bottom:none;border-radius:22px 22px 0 0;
  padding:22px 22px 34px;
  box-shadow:0 -20px 60px rgba(0,0,0,.6),0 0 0 1px rgba(201,168,76,.06);
  transform:translateY(100%);transition:transform .38s cubic-bezier(.22,1,.36,1);
  position:relative;
}
.share-sheet::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.55;
}

.share-top{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
}
.share-icon{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(80,40,160,.7),rgba(201,168,76,.3));
  border:1px solid rgba(201,168,76,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--gold);
  box-shadow:0 0 20px rgba(201,168,76,.15);
}
.share-title{font-family:'Philosopher',serif;font-size:14px;color:var(--gold);letter-spacing:.06em;}
.share-sub{font-size:12px;color:var(--muted);font-style:italic;margin-top:2px;}
.share-close{
  margin-left:auto;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.15);
  color:var(--muted);width:32px;height:32px;border-radius:50%;cursor:pointer;
  font-size:13px;display:flex;align-items:center;justify-content:center;
  transition:all .18s;flex-shrink:0;
}
.share-close:hover{background:rgba(201,168,76,.1);color:var(--text);}

.share-cards-preview{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  margin-bottom:22px;padding:14px;
  background:rgba(255,255,255,.02);border-radius:12px;
  border:1px solid rgba(201,168,76,.08);
}
.share-card-item{display:flex;flex-direction:column;align-items:center;gap:5px;}
.share-card-img-wrap{width:60px;height:100px;border-radius:6px;overflow:hidden;
  border:1px solid rgba(201,168,76,.35);box-shadow:0 4px 16px rgba(0,0,0,.5);}
.share-card-img-wrap.rev{border-color:rgba(224,112,144,.45);}
.share-card-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;}
.share-card-img-wrap.rev img{transform:rotate(180deg);}
.share-fallback{width:100%;height:100%;background:linear-gradient(160deg,#1a0f38,#0e0a1a);
  display:flex;align-items:center;justify-content:center;font-size:24px;}
.share-card-name{font-size:10px;color:var(--text);text-align:center;max-width:68px;line-height:1.3;}
.share-card-pos{font-family:'Philosopher',serif;font-size:8px;letter-spacing:.12em;
  color:var(--gold);opacity:.65;text-transform:uppercase;}

.share-interp{
  margin-bottom:18px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(201,168,76,.12);
  border-radius:12px;overflow:hidden;
}
.share-interp-hdr{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;
  border-bottom:1px solid rgba(201,168,76,.1);
  background:rgba(201,168,76,.04);
}
.share-interp-icon{font-size:15px;}
.share-interp-label{
  font-family:'Philosopher',serif;font-size:11px;
  letter-spacing:.08em;color:var(--gold);opacity:.8;
  text-transform:uppercase;
}
.share-interp-body{
  padding:12px 14px;
  font-size:13px;line-height:1.75;
  color:rgba(232,223,200,.78);
  font-style:italic;white-space:pre-line;
  max-height:160px;overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:rgba(201,168,76,.2) transparent;
}
.share-interp-body::-webkit-scrollbar{width:4px;}
.share-interp-body::-webkit-scrollbar-thumb{background:rgba(201,168,76,.2);border-radius:4px;}

.share-actions{display:flex;gap:10px;justify-content:center;}
.share-btn{
  width:100%;padding:14px 10px;border-radius:12px;cursor:pointer;
  background:linear-gradient(135deg,rgba(40,20,90,.8),rgba(60,30,120,.7));
  border:1.5px solid rgba(201,168,76,.35);
  display:flex;flex-direction:column;align-items:center;gap:7px;
  transition:all .2s;
}
.share-btn:hover{background:linear-gradient(135deg,rgba(60,30,120,.9),rgba(80,40,160,.8));border-color:rgba(201,168,76,.6);transform:translateY(-2px);}
.share-btn-ico{font-size:26px;line-height:1;}
.share-btn-lbl{font-family:'Philosopher',serif;font-size:11px;letter-spacing:.1em;color:var(--gold);text-transform:uppercase;}

.share-toast{
  margin-top:14px;text-align:center;font-family:'Philosopher',serif;
  font-size:12px;letter-spacing:.06em;padding:8px 16px;border-radius:8px;
  border:1px solid transparent;transition:all .25s;
  opacity:0;transform:translateY(4px);max-height:0;overflow:hidden;
}
.share-toast.visible{opacity:1;transform:none;max-height:40px;}

/* ═══ MUSIC ═══ */
.music-popup{position:fixed;inset:0;background:rgba(7,5,15,.75);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;z-index:9999;padding:18px;}
.music-popup.show{display:flex;animation:fadeUp .35s cubic-bezier(.22,1,.36,1) both;}
.music-modal{width:min(420px,92vw);border-radius:20px;overflow:hidden;
  background:linear-gradient(160deg,rgba(22,15,46,.97),rgba(14,10,26,.97));
  border:1px solid rgba(201,168,76,.25);
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(201,168,76,.08),0 0 60px rgba(201,168,76,.06);}
.music-modal-top{padding:22px 22px 16px;
  background:radial-gradient(600px 200px at 20% 0%,rgba(201,168,76,.08),transparent 70%);
  border-bottom:1px solid rgba(201,168,76,.12);
  display:flex;align-items:center;gap:14px;}
.music-modal-icon{width:48px;height:48px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,rgba(122,92,16,.6),rgba(201,168,76,.3));
  border:1px solid rgba(201,168,76,.3);
  display:flex;align-items:center;justify-content:center;font-size:22px;
  box-shadow:0 0 20px rgba(201,168,76,.2);}
.music-modal-title{font-family:'Philosopher',serif;font-size:15px;font-weight:700;
  color:var(--gold);letter-spacing:.06em;}
.music-modal-sub{font-size:12px;color:var(--muted);font-style:italic;margin-top:3px;}
.music-modal-body{padding:14px 22px 8px;font-size:13.5px;color:rgba(232,223,200,.6);
  line-height:1.7;font-style:italic;}
.music-modal-actions{display:flex;gap:10px;padding:12px 22px 22px;}
.music-modal-actions .btn{flex:1;}

.music-fab{position:fixed;bottom:24px;right:24px;z-index:1000;
  width:50px;height:50px;border-radius:14px;
  background:linear-gradient(135deg,rgba(22,15,46,.95),rgba(14,10,26,.95));
  border:1px solid rgba(201,168,76,.3);
  box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 20px rgba(201,168,76,.1);
  display:none;align-items:center;justify-content:center;
  cursor:pointer;font-size:20px;transition:all .2s;user-select:none;}
.music-fab:hover{transform:translateY(-3px);border-color:var(--gold);
  box-shadow:0 12px 40px rgba(0,0,0,.5),0 0 28px rgba(201,168,76,.25);}

.music-toast{position:fixed;left:50%;transform:translateX(-50%);bottom:28px;
  padding:9px 18px;border-radius:999px;
  background:rgba(14,10,26,.92);border:1px solid rgba(201,168,76,.2);
  backdrop-filter:blur(12px);color:var(--muted);font-size:13px;
  display:none;z-index:9998;font-family:'Philosopher',serif;letter-spacing:.05em;
  box-shadow:0 8px 28px rgba(0,0,0,.3);}

/* ── Vietnamese Unicode range ── */
@font-face {
  font-family: 'Philosopher';
  font-display: swap;
  src: local('Philosopher');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,
                 U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB;
}
@font-face {
  font-family: 'Crimson Pro';
  font-display: swap;
  src: local('Crimson Pro'), local('Crimson Text');
  unicode-range: U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,
                 U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB;
}
