/* ============ NEO-BRUTALIST Tarot UI ============ */
:root{
  --bg:        #fef3c7;          /* 따뜻한 크림 */
  --bg-2:      #fef9e7;
  --ink:       #1a1325;          /* 본문 진한 보라-블랙 */
  --line:      #1a1325;          /* 외곽선 */
  --line-w:    1.5px;
  --shadow:    4px 4px 0 var(--line);
  --shadow-sm: 3px 3px 0 var(--line);
  --shadow-lg: 6px 6px 0 var(--line);
  --primary:   #a78bfa;          /* 보라 */
  --primary-d: #7c3aed;
  --pink:      #f472b6;
  --yellow:    #fde047;
  --lime:      #bef264;
  --teal:      #5eead4;
  --orange:    #fdba74;
  --rose:      #fda4af;
  --sky:       #93c5fd;
  --paper:     #ffffff;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;min-height:100vh;font-weight:500}
/* 미세 격자 패턴 (브루탈리즘 종이 느낌) */
body{background-image:
  linear-gradient(var(--ink) 1px, transparent 1px),
  linear-gradient(90deg, var(--ink) 1px, transparent 1px);
  background-size: 32px 32px;
  background-position: 0 0, 0 0;
  background-color:var(--bg);
}
body::before{content:"";position:fixed;inset:0;background:rgba(254,243,199,.93);pointer-events:none;z-index:0}

#app{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:24px 16px 80px}

/* ----------- Typography ----------- */
.title{text-align:center;font-size:2.4rem;font-weight:900;letter-spacing:-.02em;margin:8px auto 26px;display:inline-block;width:100%;color:var(--ink);text-transform:uppercase}
.title{position:relative}
.title::after{content:"";display:block;width:120px;height:8px;background:var(--pink);border:var(--line-w) solid var(--line);margin:8px auto 0;box-shadow:var(--shadow-sm)}
h2{font-weight:800;font-size:1.2rem;color:var(--ink);margin-top:0;letter-spacing:-.01em}
.muted{color:#6b5b85}
.center{text-align:center}
.hidden{display:none!important}

/* ----------- SPA state machine ----------- */
.step{display:none;animation:fade .35s ease}
#app[data-state="type"] [data-step="type"],
#app[data-state="question"] [data-step="question"],
#app[data-state="shuffle"] [data-step="shuffle"],
#app[data-state="spread"] [data-step="spread"],
#app[data-state="reading"] [data-step="reading"]{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ----------- Buttons ----------- */
.btn{display:inline-block;border:var(--line-w) solid var(--line);border-radius:10px;padding:12px 22px;font-size:.95rem;font-weight:700;cursor:pointer;color:var(--ink);background:var(--paper);box-shadow:var(--shadow);transition:transform .12s, box-shadow .12s;font-family:inherit;letter-spacing:.01em}
.btn:hover:not(:disabled){transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}
.btn:active:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--line)}
.btn.primary{background:var(--primary);color:#fff}
.btn.ghost{background:var(--yellow)}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:var(--shadow-sm)}
.row{display:flex;gap:12px;justify-content:center;margin-top:18px;flex-wrap:wrap}

/* ----------- Inputs ----------- */
textarea{width:100%;padding:14px 16px;background:var(--paper);color:var(--ink);border:var(--line-w) solid var(--line);border-radius:10px;font-size:1rem;resize:vertical;box-shadow:var(--shadow-sm);font-family:inherit;font-weight:500}
textarea::placeholder{color:#a89bbe}
textarea:focus{outline:none;background:#fffceb;box-shadow:var(--shadow)}

/* ----------- Type select ----------- */
.type-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.type-header h2{margin:0;flex:1}
.btn-link-rules{background:var(--yellow);color:var(--ink);border:var(--line-w) solid var(--line);padding:8px 14px;border-radius:999px;font-size:.85rem;cursor:pointer;font-weight:700;box-shadow:var(--shadow-sm);transition:transform .12s, box-shadow .12s}
.btn-link-rules:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}
.btn-link-rules:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--line)}

.type-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;margin-top:18px}
.type-card{background:var(--paper);border:var(--line-w) solid var(--line);border-radius:14px;padding:18px;cursor:pointer;transition:transform .15s, box-shadow .15s;box-shadow:var(--shadow);position:relative;overflow:hidden}
.type-card:nth-child(8n+1){background:#fce7f3}
.type-card:nth-child(8n+2){background:#dcfce7}
.type-card:nth-child(8n+3){background:#fef9c3}
.type-card:nth-child(8n+4){background:#dbeafe}
.type-card:nth-child(8n+5){background:#fed7aa}
.type-card:nth-child(8n+6){background:#e9d5ff}
.type-card:nth-child(8n+7){background:#ccfbf1}
.type-card:nth-child(8n+0){background:#fecaca}
.type-card:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}
.type-card:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--line)}
.type-card h3{margin:0 0 6px;font-size:1.05rem;font-weight:800;color:var(--ink)}
.type-card p{margin:0;color:var(--ink);opacity:.7;font-size:.84rem;font-weight:500}

/* ----------- Shuffle stage ----------- */
.shuffle-stage{position:relative;height:380px;display:flex;align-items:center;justify-content:center;perspective:1200px;overflow:hidden;background:var(--paper);border:var(--line-w) solid var(--line);border-radius:18px;box-shadow:var(--shadow-lg)}
.shuffle-stage::before{content:"";position:absolute;left:50%;top:50%;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.45),rgba(244,114,182,.15) 50%,transparent 70%);transform:translate(-50%,-50%);animation:auraPulse 3s ease-in-out infinite;pointer-events:none}
.shuffle-stage::after{content:"";position:absolute;left:50%;top:50%;width:280px;height:280px;border-radius:50%;border:var(--line-w) dashed var(--ink);transform:translate(-50%,-50%);animation:auraSpin 8s linear infinite;pointer-events:none;opacity:.45}
@keyframes auraPulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(.9)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}
@keyframes auraSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* 슬라이드 셔플 — 실제 카드 뒷면 이미지 + 좌우 부드러운 왕복 (느린 속도, 단순) */
.shuffle-deck{position:relative;width:140px;height:220px}
.shuffle-deck .card{position:absolute;inset:0;border-radius:12px;border:var(--line-w) solid var(--line);box-shadow:var(--shadow);overflow:hidden;background:#1a1330;animation:slideShuffleR 3s ease-in-out infinite;will-change:transform}
.shuffle-deck .card img{width:100%;height:100%;display:block;object-fit:cover;pointer-events:none}
/* 좌/우 — JS 가 data-side 로 지정 */
.shuffle-deck .card[data-side="L"]{animation-name:slideShuffleL}
.shuffle-deck .card[data-side="R"]{animation-name:slideShuffleR}
@keyframes slideShuffleL{
  0%,100%{transform:translateX(0)}
  50%   {transform:translateX(-150px)}
}
@keyframes slideShuffleR{
  0%,100%{transform:translateX(0)}
  50%   {transform:translateX(150px)}
}

.spark{position:absolute;top:50%;left:50%;width:10px;height:10px;border-radius:50%;background:var(--yellow);border:1.5px solid var(--ink);animation:sparkPath 2.6s infinite ease-out;pointer-events:none}
.spark.purple{background:var(--primary)}
.spark.pink{background:var(--pink)}
@keyframes sparkPath{0%{transform:translate(-50%,-50%) scale(0);opacity:0}20%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}100%{transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) scale(.2);opacity:0}}
.rune{position:absolute;font-size:1.4rem;color:var(--ink);font-weight:900;animation:runeFloat 4s infinite ease-in-out;pointer-events:none}
@keyframes runeFloat{0%,100%{transform:translateY(0) rotate(0);opacity:0}25%{opacity:1}75%{opacity:1}50%{transform:translateY(-30px) rotate(180deg)}}

/* ----------- Spread fan + mat ----------- */
.fan{position:relative;z-index:10;height:340px;display:flex;justify-content:center;align-items:flex-end;margin:18px 0 0;background:transparent;border:none;box-shadow:none;overflow:visible}
.fan .card{position:absolute;width:90px;height:150px;border-radius:10px;background:var(--primary);border:var(--line-w) solid var(--line);cursor:pointer;transition:transform .35s cubic-bezier(.4,.05,.2,1), box-shadow .25s;box-shadow:var(--shadow);transform-origin:50% 360px;will-change:transform}
.fan .card::before{content:"✦";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--yellow);font-size:1.7rem}
.fan .card:hover:not(.placed){filter:brightness(1.1);box-shadow:var(--shadow-lg);z-index:5}
.fan .card.placed{cursor:pointer;pointer-events:auto;transition:transform .85s cubic-bezier(.45,.05,.2,1), box-shadow .25s;background:var(--pink);box-shadow:var(--shadow-lg)}
.fan .card.placed:hover{filter:brightness(1.06)}
.fan .card.placed::after{content:"⤴ 클릭해 되돌리기";position:absolute;left:50%;bottom:-30px;transform:translateX(-50%);font-size:.7rem;color:var(--ink);background:var(--yellow);padding:4px 10px;border-radius:999px;border:var(--line-w) solid var(--line);white-space:nowrap;opacity:0;transition:opacity .25s;pointer-events:none;font-weight:700}
.fan .card.placed:hover::after{opacity:1}

.counter{text-align:center;color:var(--ink);margin-top:10px;font-size:.95rem;font-weight:700}
.counter span{font-weight:900;color:var(--primary-d);font-size:1.2rem}

.mat{position:relative;z-index:1;display:flex;justify-content:center;align-items:center;gap:22px;margin-top:24px;padding:8px 0;flex-wrap:wrap;background:transparent;border:none;box-shadow:none;min-height:0}
.slot{width:100px;height:164px;box-sizing:border-box;border-radius:12px;border:var(--line-w) dashed var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--ink);transition:all .35s;position:relative;background:var(--paper)}
.slot.filled{border-style:solid;background:#fce7f3;box-shadow:var(--shadow)}
.slot-num{font-size:1.7rem;font-weight:900;color:var(--ink);opacity:.5;letter-spacing:.05em;line-height:1}
.slot-label{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-top:6px;font-weight:800}
.slot.filled .slot-num,.slot.filled .slot-label{visibility:hidden}

/* ----------- Picked & flip ----------- */
#picked-cards{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin:20px 0;padding:0;background:transparent;border:none}
.pc{width:150px;text-align:center}
.pc .label{color:var(--ink);font-size:.85rem;margin-bottom:8px;letter-spacing:.1em;text-transform:uppercase;font-weight:800}
.pc .flipper{position:relative;width:150px;height:240px;perspective:1200px;margin:0 auto}
.pc .face{position:absolute;inset:0;backface-visibility:hidden;border-radius:12px;transition:transform .8s;overflow:hidden;border:var(--line-w) solid var(--line);box-shadow:var(--shadow-lg);background:var(--paper)}
.pc .face img{width:100%;height:100%;display:block;object-fit:cover;transition:transform 1.1s cubic-bezier(.5,.05,.2,1);transform-origin:center center}
.pc .back{background:var(--primary)}
.pc .front{transform:rotateY(180deg)}
.pc.flipped .back{transform:rotateY(180deg)}
.pc.flipped .front{transform:rotateY(360deg)}
.pc.reversing .front img{animation:cardReverseSpin 1.1s cubic-bezier(.5,.05,.2,1) forwards}
.pc.reversed:not(.reversing) .front img{transform:rotate(180deg)}
@keyframes cardReverseSpin{
  0%{transform:rotate(0deg) scale(1)}
  35%{transform:rotate(90deg) scale(.92)}
  65%{transform:rotate(140deg) scale(.95)}
  100%{transform:rotate(180deg) scale(1)}
}
.pc .name{font-weight:900;margin-top:12px;font-size:1rem;color:var(--ink);letter-spacing:.01em}
.pc .theme{color:var(--ink);opacity:.65;font-size:.8rem;margin-top:3px;font-weight:600}
.pc .dir{margin-top:5px}
.dir-badge{display:inline-block;padding:3px 12px;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.08em;border:var(--line-w) solid var(--line)}
.dir-up{background:var(--lime);color:var(--ink)}
.dir-rev{background:var(--rose);color:var(--ink)}

/* ----------- Mystical Seer ----------- */
.seer{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;margin:-12px auto 8px;padding:0;animation:fade .5s ease;text-align:center}
.seer-text{margin:0 auto 6px;padding:8px 18px;color:var(--ink);font-size:.98rem;letter-spacing:.04em;text-align:center;background:var(--yellow);border:var(--line-w) solid var(--line);border-radius:999px;box-shadow:var(--shadow-sm);font-weight:800;display:inline-block}
.seer-stage{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:140px;margin-top:8px;perspective:900px}
.seer-svg{display:none}
.seer-side-card{position:relative;width:90px;height:auto;border-radius:10px;display:block;border:var(--line-w) solid var(--line);box-shadow:var(--shadow);transform-origin:center}
.seer-side-center{animation:seerCardCenter 3.2s ease-in-out infinite}
@keyframes seerCardCenter{
  0%,100%{transform:rotate(-10deg) rotateY(0deg) translateY(0)}
  50%   {transform:rotate(10deg)  rotateY(180deg) translateY(-10px)}
}
.seer-aura{transform-origin:120px 140px;animation:seerAura 4s ease-in-out infinite}
@keyframes seerAura{0%,100%{opacity:.55;transform:scale(.92)}50%{opacity:1;transform:scale(1.08)}}
.seer-body{transform-origin:120px 200px;animation:seerBreath 4.5s ease-in-out infinite}
@keyframes seerBreath{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-3px) rotate(1.5deg)}}
.seer-eye{animation:seerBlink 5.5s infinite}
@keyframes seerBlink{0%,46%,52%,96%,100%{opacity:1}48%,50%,98%{opacity:0}}
.seer-hands{transform-origin:120px 200px;animation:seerHands 5s ease-in-out infinite}
@keyframes seerHands{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.seer-ball{transform-origin:120px 215px;animation:seerBall 3.8s ease-in-out infinite}
@keyframes seerBall{0%,100%{filter:brightness(1)}50%{filter:brightness(1.25)}}
.seer-ball-spark{transform-origin:120px 210px;animation:seerSpark 6s linear infinite}
@keyframes seerSpark{to{transform:rotate(360deg)}}
.seer-stars circle{animation:seerStarTwinkle 3s ease-in-out infinite}
.seer-stars circle:nth-child(2n){animation-delay:-1s;animation-duration:4s}
.seer-stars circle:nth-child(3n){animation-delay:-2s;animation-duration:5s}
@keyframes seerStarTwinkle{0%,100%{opacity:.3}50%{opacity:1}}
.seer-rune{animation:seerRuneFloat 4.5s ease-in-out infinite;transform-origin:center}
.seer-rune.r1{animation-delay:-0.3s}.seer-rune.r2{animation-delay:-1.2s}.seer-rune.r3{animation-delay:-2.1s}.seer-rune.r4{animation-delay:-3s}
@keyframes seerRuneFloat{0%,100%{transform:translateY(0) rotate(0);opacity:.5}50%{transform:translateY(-12px) rotate(180deg);opacity:1}}
.seer-dots{display:inline-block;margin-right:6px}
.seer-dots i{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ink);margin:0 2px;animation:seerDot 1.4s ease-in-out infinite;vertical-align:middle}
.seer-dots i:nth-child(2){animation-delay:.2s}
.seer-dots i:nth-child(3){animation-delay:.4s}
@keyframes seerDot{0%,80%,100%{transform:scale(.55);opacity:.4}40%{transform:scale(1.15);opacity:1}}

@media (max-width:640px){.seer-stage{min-height:110px}.seer-side-card{width:72px}}
@media (max-width:380px){.seer-stage{min-height:96px}.seer-side-card{width:60px}}

/* ----------- Loading + summary loader ----------- */
.loading{text-align:center;margin:36px 0;color:var(--ink)}
.spinner{width:48px;height:48px;border:3px solid var(--ink);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}
.summary-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;margin:24px 0;animation:fade .4s ease}
.summary-card-spin{width:100px;height:160px;perspective:900px;margin-bottom:14px;filter:drop-shadow(4px 4px 0 var(--line))}
.summary-card-back{width:100%;height:100%;border-radius:10px;display:block;animation:summarySpin 2.6s cubic-bezier(.5,.05,.5,.95) infinite;transform-style:preserve-3d;border:var(--line-w) solid var(--line)}
@keyframes summarySpin{0%{transform:rotateY(0) scale(1)}50%{transform:rotateY(180deg) scale(1.06)}100%{transform:rotateY(360deg) scale(1)}}
.summary-loader-text{margin:0;color:var(--ink);font-size:1rem;letter-spacing:.04em;text-align:center;font-weight:800}
.summary-loader-text::after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ink);margin-left:6px;animation:summaryDot 1.2s ease-in-out infinite;vertical-align:middle}
@keyframes summaryDot{0%,100%{opacity:.3;transform:scale(.7)}50%{opacity:1;transform:scale(1.2)}}
@media (max-width:640px){.summary-card-spin{width:80px;height:128px}}

/* ----------- Result/error ----------- */
.result, .error{background:var(--paper);border:var(--line-w) solid var(--line);border-radius:14px;padding:22px;margin-top:20px;animation:fade .4s;box-shadow:var(--shadow-lg)}
.result h3{margin-top:0;color:var(--ink);font-weight:900;letter-spacing:-.01em}
#reading-text{line-height:1.85}
.error{background:#fecaca}
.error p{color:var(--ink);margin:0 0 12px;font-weight:700}

.result-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.result-header h3{margin:0}
.view-toggle{display:inline-flex;background:var(--bg-2);border:var(--line-w) solid var(--line);border-radius:999px;padding:3px;gap:0;box-shadow:var(--shadow-sm)}
.btn-toggle{background:transparent;border:none;color:var(--ink);padding:7px 16px;border-radius:999px;cursor:pointer;font-size:.86rem;transition:all .15s;font-weight:700;font-family:inherit}
.btn-toggle:hover{background:rgba(0,0,0,.05)}
.btn-toggle.active{background:var(--primary);color:#fff;font-weight:800}

#summary-text{white-space:pre-wrap;line-height:1.85;font-size:1rem}

/* ----------- Reading sections ----------- */
.sec{position:relative;padding:0;border-radius:14px;margin-bottom:14px;background:var(--paper);border:var(--line-w) solid var(--line);box-shadow:var(--shadow);overflow:hidden;animation:secIn .4s ease}
@keyframes secIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.sec-head{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:var(--line-w) solid var(--line);position:relative}
.sec-badge{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--paper);display:flex;align-items:center;justify-content:center;font-size:1.3rem;border:var(--line-w) solid var(--line);box-shadow:2px 2px 0 var(--line)}
.sec-titlewrap{flex:1}
.sec-pretitle{font-size:.7rem;letter-spacing:.22em;color:var(--ink);font-weight:800;text-transform:uppercase;display:block;margin-bottom:1px;opacity:.7}
.sec-title{font-size:1.08rem;font-weight:900;color:var(--ink);letter-spacing:-.01em}
.sec-time{font-size:.92rem;font-weight:900;color:var(--ink);letter-spacing:.15em;flex-shrink:0;font-family:Georgia,serif;opacity:.65}
.sec-body{white-space:pre-wrap;line-height:1.85;color:var(--ink);font-size:.97rem;padding:16px 20px;background:var(--paper);font-weight:500}

/* 섹션별 헤더 컬러 (브루탈리스트 색 블록) */
.sec-overall .sec-head{background:#e9d5ff}
.sec-past    .sec-head{background:#fed7aa}
.sec-present .sec-head{background:#bbf7d0}
.sec-future  .sec-head{background:#bfdbfe}
.sec-advice  .sec-head{background:var(--yellow)}
.sec-default .sec-head{background:#e5e7eb}

/* ----------- Rules overlay ----------- */
.rules-overlay{position:fixed;inset:0;background:rgba(26,19,37,.6);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;animation:fade .3s}
.rules-modal{background:var(--paper);border:var(--line-w) solid var(--line);border-radius:18px;max-width:680px;width:100%;max-height:92vh;overflow:auto;padding:30px 28px 24px;position:relative;box-shadow:8px 8px 0 var(--line)}
.rules-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:8px;background:var(--pink);border:var(--line-w) solid var(--line);color:var(--ink);font-size:1rem;cursor:pointer;font-weight:900;box-shadow:var(--shadow-sm);transition:transform .12s, box-shadow .12s}
.rules-close:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}
.rules-close:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--line)}
.rules-modal h2{margin:0 0 6px;font-size:1.5rem;color:var(--ink);font-weight:900;letter-spacing:-.01em;text-transform:uppercase}
.rules-sub{color:var(--ink);opacity:.7;margin:0 0 22px;font-size:.92rem;font-weight:600}
.rules-steps{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:14px}
.rules-steps li{display:flex;gap:14px;background:var(--bg-2);border:var(--line-w) solid var(--line);border-radius:12px;padding:14px 16px;transition:transform .12s, box-shadow .12s;box-shadow:var(--shadow-sm)}
.rules-steps li:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}
.rules-steps li:nth-child(1){background:#fce7f3}
.rules-steps li:nth-child(2){background:#dbeafe}
.rules-steps li:nth-child(3){background:#fef9c3}
.rules-steps li:nth-child(4){background:#dcfce7}
.rules-steps li:nth-child(5){background:#e9d5ff}
.rules-num{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--ink);color:var(--paper);font-weight:900;display:flex;align-items:center;justify-content:center;font-size:1.1rem;border:var(--line-w) solid var(--line)}
.rules-text h3{margin:0 0 4px;font-size:1.02rem;color:var(--ink);font-weight:800}
.rules-text p{margin:0;color:var(--ink);font-size:.88rem;line-height:1.6;font-weight:500}
.rules-text b{color:var(--primary-d);font-weight:800}
.rules-tips{background:var(--yellow);border:var(--line-w) solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:22px;box-shadow:var(--shadow-sm)}
.rules-tips h4{margin:0 0 10px;color:var(--ink);font-size:.95rem;font-weight:900}
.rules-tips ul{margin:0;padding-left:18px;color:var(--ink);font-size:.85rem;line-height:1.7;font-weight:500}
.rules-tips ul li{margin-bottom:4px}

/* Rules — 카드 이미지 출처 박스 */
.rules-credits{background:rgba(167,139,250,.12);border:var(--line-w) solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:22px;box-shadow:2px 2px 0 var(--line)}
.rules-credits h4{margin:0 0 10px;color:var(--ink);font-size:.97rem;font-weight:900}
.rules-credits p{margin:0 0 10px;color:var(--ink);font-size:.86rem;line-height:1.65;font-weight:500}
.rules-credits ul{margin:0 0 10px;padding-left:18px;color:var(--ink);font-size:.84rem;line-height:1.7;font-weight:500}
.rules-credits ul li{margin-bottom:3px}
.rules-credits b{color:#7c3aed;font-weight:800}
.rules-credits .rules-fineprint{font-size:.76rem;opacity:.72;line-height:1.6;margin-top:8px;font-weight:500;font-style:italic}
.tip-up{color:#15803d;font-weight:800}
.tip-rev{color:#b91c1c;font-weight:800}
.rules-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.rules-check{display:flex;align-items:center;gap:8px;color:var(--ink);font-size:.85rem;cursor:pointer;user-select:none;font-weight:600}
.rules-check input{accent-color:var(--primary)}

/* ----------- Ad slots ----------- */
.ad-slot{max-width:1100px;margin:0 auto;padding:8px 16px;text-align:center;min-height:0;position:relative;z-index:1}
.ad-slot:empty{padding:0}
.ad-slot ins.adsbygoogle{display:block;margin:0 auto}

/* ----------- Mobile ----------- */
@media (max-width:640px){
  body{background-size:24px 24px}
  #app{padding:18px 12px 70px}
  .title{font-size:1.7rem;margin-bottom:18px}
  .title::after{width:80px;height:6px}
  h2{font-size:1.05rem}
  .type-list{grid-template-columns:1fr 1fr;gap:12px}
  .type-card{padding:14px;border-radius:12px}
  .type-card h3{font-size:1rem}
  .type-card p{font-size:.78rem}
  textarea{font-size:16px;border-radius:10px}    /* iOS 포커스 시 자동확대 방지 */
  .btn{padding:10px 16px;font-size:.9rem;border-radius:10px}
  .shuffle-stage{height:280px;border-radius:14px}
  .shuffle-deck{width:104px;height:166px}
  .shuffle-deck .card::before{font-size:1.3rem}
  .fan{height:280px;margin:14px 0 0}
  .fan .card{width:56px;height:96px;transform-origin:50% 280px}
  .fan .card::before{font-size:1.2rem}
  .mat{gap:10px;padding:6px 0;margin-top:14px}
  .slot{width:64px;height:108px;border-radius:9px}
  .slot-num{font-size:1.2rem}
  .slot-label{font-size:.66rem;margin-top:3px}
  #picked-cards{gap:10px;padding:0}
  .pc{width:104px}
  .pc .flipper{width:104px;height:166px}
  .pc .name{font-size:.9rem;margin-top:8px}
  .pc .theme{font-size:.74rem}
  .result, .error{padding:18px;border-radius:12px}
  #reading-text{font-size:.92rem;line-height:1.75}
  .sec{border-radius:12px}
  .sec-head{padding:10px 14px;gap:10px}
  .sec-badge{width:34px;height:34px;font-size:1.15rem}
  .sec-title{font-size:1rem}
  .sec-time{font-size:.82rem}
  .sec-body{padding:14px 16px;font-size:.92rem;line-height:1.78}
  .rules-modal{padding:24px 18px 20px;border-radius:14px}
  .rules-modal h2{font-size:1.3rem}
  .rules-num{width:34px;height:34px;font-size:1rem}
  .rules-steps li{padding:12px;border-radius:10px}
  .rules-text h3{font-size:.95rem}
  .rules-text p,.rules-tips ul{font-size:.82rem}
  .rules-actions{flex-direction:column;align-items:stretch}
  .rules-actions .btn{width:100%}
}

@media (max-width:380px){
  .type-list{grid-template-columns:1fr}
  .fan .card{width:48px;height:80px;transform-origin:50% 220px}
  #picked-cards{gap:8px}
  .pc{width:90px}
  .pc .flipper{width:90px;height:144px}
}
