@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700;900&family=Noto+Serif+SC:wght@500;700;900&display=swap');

:root{
  --bg:#03040a;
  --gold:#d9b46a;
  --gold2:#fff1b8;
  --gold3:#7d5a1d;
  --glass:rgba(255,255,255,.06);
  --line:rgba(217,180,106,.52);
  --ink:#f6ead0;
  --muted:rgba(246,234,208,.68);
  --blue:#091628;
  --card-w:132px;
  --card-h:210px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;min-height:100%;background:#02030a;color:var(--ink)}
body{
  overflow-x:hidden;
  font-family:"Noto Serif SC",serif;
  background:
    radial-gradient(circle at top,#12213d 0%,#050812 42%,#010207 100%);
}

#starCanvas,#fxCanvas{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
}
#starCanvas{z-index:0}
#fxCanvas{z-index:30}

#camera{
  position:fixed;
  right:18px;
  bottom:18px;
  width:150px;
  max-width:28vw;
  border:1px solid var(--line);
  border-radius:16px;
  opacity:.28;
  transform:scaleX(-1);
  z-index:10;
  display:none;
  box-shadow:0 0 28px rgba(0,0,0,.65),0 0 18px rgba(217,180,106,.22);
}

.app{
  position:relative;
  z-index:2;
  width:min(1500px,100%);
  min-height:100vh;
  margin:auto;
  padding:34px 44px 44px;
}

.topbar{
  display:grid;
  grid-template-columns:170px 1fr 170px;
  align-items:center;
  gap:20px;
}
.brand{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
}
.brand h1,.reading-title h2{
  font-family:Cinzel,"Noto Serif SC",serif;
  font-size:clamp(38px,5.6vw,72px);
  letter-spacing:.18em;
  color:var(--gold2);
  text-shadow:0 0 22px rgba(217,180,106,.72),0 0 64px rgba(217,180,106,.25);
}
.spark{
  color:var(--gold);
  font-size:28px;
  filter:drop-shadow(0 0 12px var(--gold));
}
.small-btn,.ghost-btn,.main-btn,.spread{
  cursor:pointer;
  border:1px solid var(--line);
  color:var(--gold2);
  font-family:Cinzel,"Noto Serif SC",serif;
  letter-spacing:.08em;
  border-radius:8px;
  background:
    linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.02)),
    linear-gradient(90deg,rgba(217,180,106,.18),transparent,rgba(217,180,106,.18));
  box-shadow:inset 0 0 16px rgba(255,255,255,.035),0 0 18px rgba(217,180,106,.14);
  transition:.25s ease;
}
.small-btn{padding:11px 18px}
.spread{padding:9px 28px;font-size:17px}
.spread.active,.main-btn{
  background:linear-gradient(135deg,#6e4b12,#ffe8a2 48%,#8f641d);
  color:#1b1208;
  font-weight:900;
  box-shadow:0 0 28px rgba(217,180,106,.55),inset 0 0 0 1px rgba(255,255,255,.45);
}
.ghost-btn,.main-btn{padding:14px 38px;font-size:18px}
button:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.12)}
button:disabled{opacity:.42;cursor:not-allowed}

.hero{
  position:relative;
  min-height:calc(100vh - 130px);
  padding-top:12px;
}
.subtitle{
  margin-top:10px;
  text-align:center;
  color:var(--gold2);
  font-weight:700;
  letter-spacing:.12em;
  text-shadow:0 0 18px rgba(217,180,106,.45);
}
.spread-picker{
  margin:28px auto 34px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
  color:var(--muted);
}

.deck-stage{
  position:relative;
  height:300px;
  margin:0 -44px;
  overflow:hidden;
  display:flex;
  align-items:center;
}
.deck-stage::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:
    radial-gradient(circle at center,rgba(217,180,106,.14),transparent 25%),
    conic-gradient(from 0deg,transparent,rgba(217,180,106,.08),transparent,rgba(105,165,255,.07),transparent);
  animation:slowSpin 50s linear infinite;
  opacity:.6;
}
.deck-stage::after{
  content:"";
  position:absolute;
  z-index:3;
  left:50%;
  top:58px;
  bottom:34px;
  width:1px;
  transform:translateX(-50%);
  background:linear-gradient(180deg,transparent,rgba(255,241,184,.36),transparent);
  box-shadow:0 0 12px rgba(255,241,184,.28);
  pointer-events:none;
}
@keyframes slowSpin{to{transform:rotate(360deg)}}

.deck-row{
  position:relative;
  z-index:2;
  display:flex;
  gap:42px;
  padding:42px 120px 24px;
  min-width:max-content;
  transform:translateX(0);
  transition:transform .08s linear;
}
.deck-card{
  width:var(--card-w);
  height:var(--card-h);
  flex:0 0 auto;
  border-radius:12px;
  border:1px solid rgba(217,180,106,.55);
  background:
    radial-gradient(circle at center,rgba(255,237,183,.2),transparent 22%),
    linear-gradient(135deg,#0b1122,#070810 55%,#15101b);
  box-shadow:0 0 22px rgba(0,0,0,.65),inset 0 0 0 5px rgba(255,255,255,.025);
  position:relative;
  transform-style:preserve-3d;
  transition:.28s ease;
  overflow:hidden;
}
.deck-card::before{
  content:"";
  position:absolute;
  inset:8px;
  border:1px solid rgba(217,180,106,.42);
  border-radius:8px;
  background:
    radial-gradient(circle at center,transparent 31%,rgba(217,180,106,.28) 32%,transparent 33%),
    radial-gradient(circle at center,rgba(217,180,106,.36) 0 5%,transparent 6%),
    linear-gradient(90deg,transparent 48%,rgba(217,180,106,.25) 49% 51%,transparent 52%),
    linear-gradient(0deg,transparent 48%,rgba(217,180,106,.25) 49% 51%,transparent 52%);
}
.deck-card::after{
  content:"☽ ✦ ☾";
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:rgba(255,238,181,.62);
  font-size:26px;
  letter-spacing:.08em;
  text-shadow:0 0 16px var(--gold);
}
.deck-card.focus{
  transform:translateY(-14px) scale(1.1);
  border-color:var(--gold2);
  box-shadow:0 0 34px rgba(255,228,154,.8),0 0 78px rgba(217,180,106,.35);
}
.deck-card.pinched{
  transform:translateY(-18px) scale(var(--pinch-scale,1.16)) rotateZ(-1deg);
  box-shadow:0 0 40px rgba(255,241,184,.82),0 0 82px rgba(217,180,106,.34);
}
.deck-card.picked{
  pointer-events:none;
  animation:vanish .55s forwards ease-in;
}
@keyframes vanish{
  to{transform:translateY(-40px) scale(.15) rotate(24deg);opacity:0;filter:blur(8px)}
}

.hand-cursor{
  position:absolute;
  z-index:8;
  width:78px;
  height:78px;
  left:50%;
  top:50%;
  pointer-events:none;
  transform:translate(-50%,-50%);
  opacity:0;
  transition:opacity .2s ease;
}
.hand-cursor.visible{opacity:1}
.hand-cursor span{
  display:block;
  width:100%;
  height:100%;
  border:2px solid rgba(255,238,181,.82);
  border-radius:50%;
  box-shadow:0 0 24px rgba(255,238,181,.7), inset 0 0 18px rgba(255,238,181,.12);
}
.hand-cursor.pinched span{
  transform:scale(.68);
  background:rgba(217,180,106,.12);
}

.selected-panel{
  position:absolute;
  left:0;
  bottom:74px;
  width:270px;
  min-height:145px;
  border:1px solid rgba(217,180,106,.34);
  background:rgba(4,6,12,.72);
  backdrop-filter:blur(14px);
  border-radius:6px;
  padding:18px;
  box-shadow:0 0 22px rgba(0,0,0,.45);
}
.selected-panel::before{
  content:"";
  position:absolute;
  inset:7px;
  border:1px solid rgba(217,180,106,.13);
  pointer-events:none;
}
.selected-panel h3{
  color:var(--gold2);
  margin-bottom:14px;
}
.selected-list{
  display:flex;
  align-items:flex-end;
  gap:10px;
  min-height:70px;
  color:rgba(246,234,208,.45);
}
.mini-card{
  width:46px;
  height:68px;
  border-radius:5px;
  border:1px solid var(--line);
  background:linear-gradient(135deg,#071022,#1a1220);
  display:grid;
  place-items:center;
  color:var(--gold2);
  font-size:19px;
  box-shadow:0 0 14px rgba(217,180,106,.18);
}
.gesture-guide{
  width:max-content;
  max-width:min(720px,92%);
  margin:22px auto 0;
  padding:8px 16px;
  text-align:center;
  color:rgba(246,234,208,.52);
  font-size:13px;
  font-weight:500;
  letter-spacing:.04em;
  border:1px solid rgba(217,180,106,.14);
  border-radius:999px;
  background:rgba(4,6,12,.28);
  text-shadow:none;
}
.controls,.bottom-actions{
  display:flex;
  justify-content:center;
  gap:24px;
  flex-wrap:wrap;
  margin-top:28px;
}
.status{
  text-align:center;
  color:rgba(246,234,208,.55);
  margin-top:14px;
  font-size:13px;
}

.hidden{display:none!important}

.reading{padding-top:20px}
.reading-title{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:22px;
  margin-bottom:30px;
}
.reading-title span{
  width:160px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.reading-title h2{font-size:clamp(30px,4vw,48px);letter-spacing:.12em}

.reading-layout{
  display:grid;
  grid-template-columns:120px minmax(430px,1fr) minmax(340px,420px);
  gap:20px;
  align-items:start;
  max-width:100%;
}
.mini-spread,.result-panel{
  min-width:0;
  border:1px solid rgba(217,180,106,.34);
  background:linear-gradient(145deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  backdrop-filter:blur(16px);
  border-radius:10px;
  padding:22px;
  box-shadow:0 0 28px rgba(0,0,0,.35);
}
.mini-spread h3,.result-panel h3{
  color:var(--gold2);
  margin-bottom:16px;
  text-align:center;
}
#miniCards{
  display:flex;
  flex-direction:column;
  gap:15px;
  align-items:center;
}
.mini-slot{
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--gold2);
  font-size:13px;
}
.big-cards{
  min-height:430px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:clamp(10px,1.6vw,24px);
  position:relative;
  flex-wrap:nowrap;
  overflow:visible;
}
.big-cards::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:8px;
  transform:translateX(-50%);
  width:min(620px,88%);
  height:90px;
  background:radial-gradient(ellipse at center,rgba(255,229,153,.44),transparent 66%);
  filter:blur(10px);
  pointer-events:none;
}
.tarot-face{
  width:clamp(128px,10vw,180px);
  height:clamp(230px,17.4vw,315px);
  border-radius:13px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,#172643,#d8c08b 52%,#171017 53%,#060608);
  box-shadow:0 0 28px rgba(217,180,106,.28),0 24px 60px rgba(0,0,0,.5);
  overflow:hidden;
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:12px;
  animation:cardRise .8s both ease;
}
@keyframes cardRise{
  from{opacity:0;transform:translateY(34px) rotateY(80deg)}
  to{opacity:1;transform:none}
}
.tarot-face.reversed{transform:rotate(180deg)}
.tarot-num{
  font-family:Cinzel,serif;
  color:var(--gold2);
  text-align:center;
  font-size:17px;
  text-shadow:0 0 10px rgba(0,0,0,.5);
}
.tarot-art{
  flex:1;
  display:grid;
  place-items:center;
  font-size:clamp(52px,5vw,78px);
  filter:drop-shadow(0 0 14px rgba(255,232,161,.45));
}
.tarot-name{
  font-family:Cinzel,"Noto Serif SC",serif;
  text-align:center;
  color:#ffe7a2;
  font-size:clamp(13px,1.05vw,17px);
  min-height:48px;
  display:grid;
  place-items:center;
}
.card-caption{
  position:absolute;
  bottom:-46px;
  left:0;
  right:0;
  text-align:center;
  color:var(--gold2);
  font-weight:800;
}
.result-panel{
  min-height:440px;
  max-height:min(68vh,620px);
  overflow:auto;
  scrollbar-width:thin;
}
.reading-block{
  border-bottom:1px solid rgba(217,180,106,.18);
  padding:12px 0;
}
.reading-block:last-child{border-bottom:0}
.reading-block h4{
  color:var(--gold2);
  margin-bottom:8px;
}
.reading-block p{
  line-height:1.72;
  color:rgba(246,234,208,.75);
  font-size:13.5px;
}

.modal{
  position:fixed;
  inset:0;
  z-index:100;
  background:rgba(0,0,0,.72);
  display:grid;
  place-items:center;
  padding:20px;
}
.modal-card{
  width:min(560px,100%);
  border:1px solid var(--line);
  background:linear-gradient(145deg,#0b1020,#05050a);
  border-radius:18px;
  padding:30px;
  position:relative;
  box-shadow:0 0 42px rgba(217,180,106,.22);
}
.modal-card h2{color:var(--gold2);margin-bottom:16px}
.modal-card p{line-height:1.9;color:var(--muted)}
.close{
  position:absolute;
  top:14px;
  right:14px;
  width:34px;
  height:34px;
  border-radius:50%;
  border:1px solid var(--line);
  background:transparent;
  color:var(--gold2);
  font-size:20px;
}

@media(max-width:1050px){
  .app{padding:24px 18px 34px}
  .topbar{grid-template-columns:1fr;gap:14px}
  .small-btn{width:max-content;margin:auto}
  .deck-stage{margin:0 -18px}
  .selected-panel{position:relative;left:auto;bottom:auto;margin:20px auto 0;width:min(360px,100%)}
  .reading-layout{grid-template-columns:1fr}
  #miniCards{flex-direction:row;flex-wrap:wrap;justify-content:center}
  .big-cards{flex-wrap:wrap;min-height:auto}
  .result-panel{max-height:none}
}
@media(max-width:640px){
  :root{--card-w:92px;--card-h:150px}
  .brand h1{font-size:36px}
  .deck-row{gap:22px;padding:20px 90px}
  .deck-stage{height:260px;padding-top:24px}
  .gesture-guide{font-size:12px;line-height:1.5;border-radius:14px}
  .tarot-face{width:145px;height:250px}
  .tarot-art{font-size:58px}
  .result-panel{min-height:auto}
}
