/* 사주로그 디자인 시스템 컴포넌트 (P1-3) */

/* 버튼 */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-weight:var(--fw-bold);border-radius:var(--r-pill);padding:11px 22px;cursor:pointer;border:0;font-size:var(--fs-body)}
.btn-gold{background:var(--grad-gold);color:var(--c-ink-900)}
.btn-ink{background:var(--c-ink-700);color:#fff}
.btn-ghost{background:#fff;color:var(--c-ink-700);border:1px solid var(--c-line)}
.btn-kakao{background:#FEE500;color:#191600}
.btn-sm{padding:7px 14px;font-size:var(--fs-cap)}
.btn-block{display:flex;width:100%}

/* 배지/칩 */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:var(--fw-semi);
  padding:3px 9px;border-radius:var(--r-pill)}
.badge-rank{background:var(--grad-gold);color:var(--c-ink-900)}
.badge-free{background:var(--c-accent-jade);color:#fff}
.badge-hot{background:var(--c-danger);color:#fff}
.badge-new{background:var(--c-ink-700);color:var(--c-gold-300)}

/* 카테고리 탭(가로 스크롤) */
.tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 0;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab{white-space:nowrap;font-size:var(--fs-cap);font-weight:var(--fw-semi);color:var(--c-text-sub);
  padding:8px 16px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--c-line)}
.tab.active{background:var(--c-ink-800);color:var(--c-gold-300);border-color:var(--c-ink-800)}

/* 캐러셀(가로 스냅) */
.carousel{display:flex;gap:var(--sp-3);overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;padding-bottom:4px}
.carousel::-webkit-scrollbar{display:none}
.carousel>*{scroll-snap-align:start;flex:0 0 auto}
/* 슬라이드 — 잘림 없이: 모바일 1장 온전, PC(980px+) 2장 정확히 */
.slide{width:100%;border-radius:var(--r-lg);overflow:hidden;
  background:var(--grad-night);color:#fff;padding:var(--sp-5);position:relative;min-height:170px}
@media(min-width:980px){.carousel>.slide{width:calc(50% - (var(--sp-3) / 2))}}
/* 캐러셀 도트 — 다음 장 존재 안내 */
.cdots{display:flex;gap:7px;justify-content:center;margin-top:10px}
.cdots i{width:8px;height:8px;border-radius:50%;background:rgba(42,33,80,.18);transition:background .2s,transform .2s}
.cdots i.on{background:var(--c-gold-500);transform:scale(1.2)}
.slide .badge-rank{position:absolute;top:14px;left:14px}
/* 히어로 — 미니멀(배지·제목·한 줄·CTA + 캐릭터) */
.hero-slide{position:relative;display:block;padding:0;height:215px;background:var(--grad-night);text-decoration:none;overflow:hidden}
.hero-txt{position:relative;z-index:2;width:60%;height:100%;padding:18px 0 18px 22px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;min-width:0;gap:2px}
.hero-txt .badge-rank{position:static;margin-bottom:8px}
.hero-txt h2{font-family:var(--font-head);font-size:clamp(20px,5vw,27px);font-weight:800;margin:0;line-height:1.25}
.hero-desc{color:#cfc7f0;margin:6px 0 0;font-size:13.5px}
/* 캐릭터 — 우측 풀하이트 */
.hero-chr-img{position:absolute;right:0;bottom:0;height:96%;width:auto;max-width:44%;object-fit:contain;object-position:bottom right;z-index:1;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 14%);mask-image:linear-gradient(90deg,transparent 0,#000 14%)}
@media (prefers-reduced-motion: reduce){.hero-chr-img{animation:none}}

/* 리뷰 롤링 칩 */
.review{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--r-md);padding:12px 14px}
.review .avatar{width:36px;height:36px;border-radius:50%;background:var(--grad-tarot);flex:0 0 auto}
.review .stars{color:var(--c-gold-500);font-size:12px}
.review .txt{font-size:var(--fs-cap);color:var(--c-text)}

/* 스켈레톤 로더 */
.skel{background:linear-gradient(90deg,#eee 25%,#f6f6f6 37%,#eee 63%);
  background-size:400% 100%;animation:skel 1.3s ease infinite;border-radius:8px}
@keyframes skel{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* 신뢰 배너 */
.trust{background:var(--c-ink-900);color:#fff;border-radius:var(--r-lg);padding:var(--sp-5);text-align:center}
.trust strong{color:var(--c-gold-400)}
/* 오늘의 운세 배너 */
.today-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:14px 16px;text-decoration:none;color:var(--c-text);font-size:14px}
/* 채팅 USP 배너 */
.chat-usp{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#2c2768,#5B21B6);color:#fff;border-radius:var(--r-lg);padding:16px 18px;text-decoration:none}
.chat-usp-t{font-size:14px;line-height:1.5}
.chat-usp strong{color:var(--c-gold-300)}
/* 신뢰 지표 바 */
.statbar{display:flex;gap:10px;background:var(--c-ink-900);border-radius:var(--r-md);padding:14px 10px;text-align:center}
.statbar>div{flex:1;min-width:0}
.statbar b{display:block;color:var(--c-gold-300);font-size:17px;font-weight:800;line-height:1.2}
.statbar span{font-size:11px;color:#bbb}
/* 카드 도사 라벨 */
.card-dosa{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.55);color:#f1e6c8;font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px}
/* 19+ 배지 */
.badge-adult{background:#d2342f;color:#fff}
.card-19{position:absolute;top:8px;left:8px;background:#d2342f;color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:999px;z-index:2}
/* S4-C 동적 배경 — 사용자 사주(계절×시간) 레이어 합성 */
.story.has-dynbg .story-step.data{background-image:linear-gradient(rgba(10,8,32,.88),rgba(10,8,32,.92)),var(--dynbg);background-size:cover;background-position:center}
.jeolgi-stamp{position:absolute;top:10px;right:12px;font-family:var(--font-head),serif;color:rgba(220,80,70,.85);font-size:13px;border:1.5px solid currentColor;border-radius:4px;padding:2px 6px;letter-spacing:2px;writing-mode:vertical-rl;opacity:.9}
/* S4-D 도사 등장 모션 */
@keyframes dosa-in{from{opacity:0;transform:translateX(-18px)}to{opacity:1;transform:none}}
.story-step.scene.in .story-scene-img{animation:dosa-in 1.1s ease-out both}
.story-rail-img{transition:opacity .5s ease}
@media (prefers-reduced-motion: reduce){
  .story-step.scene.in .story-scene-img{animation:none}
  .story-step{transition:none}
}
/* S3-A 사용자 캐릭터 — 빛의 강도 = 신강신약 7단계 */
.uchar{width:140px;height:140px;border-radius:18px;object-fit:cover;display:inline-block;background:var(--grad-night)}
.ustr-0{filter:brightness(.5) saturate(.5)}
.ustr-1{filter:brightness(.65) saturate(.7)}
.ustr-2{filter:brightness(.82) saturate(.85)}
.ustr-3{filter:none}
.ustr-4{filter:brightness(1.08) saturate(1.1);box-shadow:0 0 14px rgba(231,198,107,.35)}
.ustr-5{filter:brightness(1.16) saturate(1.2);box-shadow:0 0 20px rgba(231,198,107,.55)}
.ustr-6{filter:brightness(1.28) saturate(1.3);box-shadow:0 0 28px rgba(255,217,122,.8)}
/* 책자 생성 풀스크린 로딩 */
.book-loading{position:fixed;inset:0;z-index:999;background:rgba(13,10,40,.96);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;text-align:center}
.book-loading img{width:130px;height:130px;border-radius:50%;object-fit:cover;object-position:center top;border:3px solid var(--c-gold-400)}
.bl-spin{width:34px;height:34px;border:3px solid rgba(231,198,107,.25);border-top-color:var(--c-gold-400);border-radius:50%;animation:blspin 1s linear infinite}
@keyframes blspin{to{transform:rotate(360deg)}}
.bl-step{color:#fff;font-size:16px;font-weight:700;margin:0;font-family:var(--font-head)}
.bl-sub{color:#b9b0e0;font-size:13px;margin:0}
@media (prefers-reduced-motion: reduce){.bl-spin{animation:none}}
/* S5-D 도사 보이스 바 */
.voice-bar{display:flex;gap:12px;align-items:center;background:var(--c-ink-900);border:1px solid #3a356a;border-radius:var(--r-md);padding:12px 14px;margin-bottom:12px;color:#eee}
.voice-btn{width:46px;height:46px;border-radius:50%;border:0;font-size:20px;background:var(--c-gold-400);cursor:pointer;flex:0 0 auto}
.voice-bar.playing .voice-btn{box-shadow:0 0 0 4px rgba(231,198,107,.3);animation:vpulse 1.2s ease infinite}
@keyframes vpulse{50%{box-shadow:0 0 0 8px rgba(231,198,107,.15)}}
.voice-bar b{font-size:13px;color:var(--c-gold-300)}
.voice-cap{margin:2px 0 0;font-size:13.5px;color:#cfc7f0;font-style:italic}
@media (prefers-reduced-motion: reduce){.voice-bar.playing .voice-btn{animation:none}}
/* S5-C 교차 추천 카드 */
.xrec{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:12px 14px;margin-bottom:8px;text-decoration:none;color:var(--c-text)}
.xrec img{width:52px;height:52px;border-radius:50%;object-fit:cover;object-position:center top;flex:0 0 auto;background:var(--grad-night)}
.xrec b{font-size:13px}.xrec p{margin:2px 0;font-size:13.5px;color:#5a4a78;font-style:italic}
.xrec-p{font-size:13px;color:var(--c-gold-500);font-weight:700}
/* 한 줄 후기 폼(결과 끝) */
.rv-form{background:var(--c-ink-900);border:1px solid #3a356a;border-radius:var(--r-md);padding:var(--sp-4);color:#eee}
.rv-form h3{color:var(--c-gold-400);font-family:var(--font-head)}
/* 도사 한마디 카드(상품 상세) */
.dosa-quote{display:flex;align-items:center;gap:12px;margin-top:14px;padding:14px 16px;background:linear-gradient(135deg,#fbf6ee,#f3ead7);border:1px solid var(--paper-edge,rgba(176,138,74,.18));border-radius:var(--r-md)}
.dq-ava{width:48px;height:48px;border-radius:50%;object-fit:cover;object-position:center top;flex:0 0 auto;background:var(--grad-night)}
.dosa-quote p{margin:0;font-size:14px;line-height:1.6;color:#4a3a78;font-style:italic}

/* 푸터 */
.site-footer{margin-top:var(--sp-8);padding:var(--sp-6) var(--gutter);background:var(--c-ink-900);color:#9a93bd;font-size:var(--fs-cap)}
.site-footer a{color:#c4bce6}
.site-footer .cols{display:flex;flex-wrap:wrap;gap:var(--sp-5);max-width:var(--container);margin:0 auto}
.site-footer .biz{margin-top:var(--sp-4);line-height:1.7;opacity:.8}

/* 사주 입력 폼 / 결과 (P2-4) */
.reading-form label{display:flex;flex-direction:column;gap:4px;font-size:var(--fs-cap);color:var(--c-text-sub)}
.reading-form input[type=number]{padding:10px;border:1px solid var(--c-line);border-radius:var(--r-sm);font-size:15px;width:100%}
.result-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);padding:var(--sp-5);box-shadow:var(--shadow-card)}
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0}
.pillar{background:var(--c-hanji);border-radius:var(--r-sm);padding:12px 4px;text-align:center;display:flex;flex-direction:column;gap:3px}
.pillar .pk{font-size:11px;color:var(--c-text-sub)}
.pillar .ps,.pillar .pb{font-family:var(--font-head);font-size:26px;font-weight:800;line-height:1.1}
.pillar .pkr{font-size:11px;color:var(--c-text-sub)}
.kv{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--c-line);font-size:14px}
.ohaeng{display:grid;gap:6px;margin-top:8px}
.ob{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:8px;font-size:13px}
.ob>span{white-space:nowrap}
.ob>b{white-space:nowrap;min-width:86px;text-align:right;font-size:12.5px}
.ob .obar{background:#eee;border-radius:6px;height:10px;overflow:hidden}
.ob .obar i{display:block;height:100%;border-radius:6px}

/* 대화형 스토리텔링 (Phase 6) */
.story{display:grid;gap:18px;padding-top:8px}
.story-step{opacity:0;transform:translateY(14px);transition:opacity .5s,transform .5s}
.story-step.in{opacity:1;transform:none}
.story-step.scene{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:62vh;background:var(--c-ink-900)}
.story-scene-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.story-step.scene .story-bubble{position:absolute;left:14px;right:24px;bottom:18px}
.story-bubble{background:#fff;border-radius:18px;padding:14px 16px;box-shadow:var(--shadow-card);font-size:15px;line-height:1.55;max-width:340px}
.story-bubble p{margin:0}.story-bubble p+p{margin-top:4px}
.story-say{display:flex;gap:10px;align-items:flex-start}
.story-ava{width:44px;height:44px;border-radius:50%;object-fit:cover;object-position:top;flex:0 0 auto;background:var(--grad-tarot)}
.story-panel{background:var(--c-ink-900);color:#eee;border-radius:var(--r-md);padding:var(--sp-5)}
.story-panel h3{color:var(--c-gold-400);font-family:var(--font-head);margin-bottom:10px}
.story-nav{position:sticky;bottom:calc(var(--bottomnav-h) + 6px);padding-top:10px;background:linear-gradient(transparent,var(--c-paper) 40%)}
/* 성향 바 */
.trait{margin:10px 0}
.trait .tl{display:flex;justify-content:space-between;font-size:12px;color:#bbb;margin-bottom:4px}
.trait .tbar{height:8px;border-radius:5px;background:#332f5a;overflow:hidden}
.trait .tbar i{display:block;height:100%;background:var(--grad-gold)}
/* 대운 타임라인 */
/* 대운 — 모바일에서 잘리지 않게 grid 줄바꿈(가로 스크롤 제거) */
.daewoon{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px;padding:6px 0}
.dw{text-align:center;background:#241f47;border:1px solid #3a356a;border-radius:12px;padding:9px 6px;min-width:0}
.dw.now{border-color:var(--c-gold-400);background:#2c2768}
.dw b{display:block;font-family:var(--font-head);color:var(--c-gold-300);font-size:15px;line-height:1.2}
.dw b small{display:block;font-size:10px;color:#9a93c8;font-weight:400}
.dw span{font-size:10.5px;color:#aaa}
/* 명식표 4중(십성·운성·신살·귀인) */
.ms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}
.ms-col{background:#241f47;border:1px solid #3a356a;border-radius:10px;padding:8px 4px;text-align:center}
.ms-pos{font-size:11px;color:#9a93c8;margin-bottom:3px}
.ms-gz{font-family:var(--font-head);font-size:19px;line-height:1.15}
.ms-kr{font-size:10.5px;color:#cfc7f0;margin:2px 0 5px}
.ms-meta{display:flex;flex-direction:column;gap:1px;font-size:10px;color:#bdb6e0;border-top:1px solid #3a356a;padding-top:4px}
.ms-meta .ms-gui{color:var(--c-gold-300)}
/* 신강·신약 7단계 */
.st-bar{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-top:8px}
.st-cell{font-size:10.5px;text-align:center;padding:7px 2px;border-radius:7px;background:#241f47;border:1px solid #3a356a;color:#9a93c8}
.st-cell.on{background:var(--c-gold-400);color:#1a1233;font-weight:800;border-color:var(--c-gold-400)}
/* 시기별 재물 흐름 그래프 */
.wf-chart{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;align-items:end;margin-top:8px}
.wf-col{display:flex;flex-direction:column;align-items:center}
.wf-bar{width:100%;height:96px;display:flex;align-items:flex-end;background:#241f47;border-radius:6px 6px 0 0;overflow:hidden}
.wf-bar i{width:100%;background:linear-gradient(#e7c66b,#caa24e);display:block}
.wf-bar.now i{background:linear-gradient(#ffd97a,#e7b73a)}
.wf-col span{font-size:10px;color:#aaa;margin-top:4px}
/* 미니 페이게이트(섹션별 결제 유도) */
.paygate-mini{margin-top:10px;background:rgba(202,162,78,.10);border:1px dashed rgba(202,162,78,.45);border-radius:10px;padding:10px 12px;font-size:13px;color:#e9d9a8;text-align:center}
.paygate-mini b{color:var(--c-gold-300)}
/* 무료 풀이 — 각 부분 간략 설명 노트 */
.rd-note{font-size:12.5px;color:#b9b0e0;line-height:1.6;margin:0 0 10px;padding-left:10px;border-left:2px solid var(--c-gold-400)}
.dw-note{font-size:13px;color:#e9e3ff;line-height:1.7;margin-top:12px;background:rgba(202,162,78,.08);border:1px solid rgba(202,162,78,.25);border-radius:10px;padding:10px 12px}
.dw-note b{color:var(--c-gold-300)}
/* 타로 — 카드 뒷면 덱(선택) + 공개(플립) */
.tdeck{display:grid;grid-template-columns:repeat(auto-fill,minmax(54px,1fr));gap:8px}
.tback{aspect-ratio:2/3.4;border-radius:8px;border:1.5px solid rgba(231,198,107,.55);cursor:pointer;
  background:radial-gradient(circle at 50% 28%, #4a3f8f 0%, #241f47 65%, #15123a 100%);
  color:rgba(231,198,107,.8);font-size:16px;display:flex;align-items:center;justify-content:center;
  transition:transform .18s,box-shadow .18s;animation:tdeal .4s ease-out both}
@keyframes tdeal{from{opacity:0;transform:translateY(10px)}to{opacity:1}}
.tback:hover{transform:translateY(-4px)}
.tback.sel{transform:translateY(-8px) scale(1.06);box-shadow:0 0 0 2.5px var(--c-gold-400),0 8px 18px rgba(0,0,0,.45);color:#fff}
.treveal{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.tflip{perspective:600px;text-align:center;animation:tflipin .8s ease-out both}
@keyframes tflipin{from{opacity:0;transform:rotateY(90deg)}to{opacity:1;transform:rotateY(0)}}
.tflip img{width:100%;border-radius:10px;border:1.5px solid rgba(231,198,107,.5);box-shadow:0 6px 16px rgba(0,0,0,.4);transform:rotate(var(--rot,0deg))}
.tflip span{display:block;font-size:11.5px;color:#e9d9a8;margin-top:5px}
.tcard{display:flex;gap:10px;align-items:flex-start}
.tcimg{width:64px;border-radius:6px;border:1px solid rgba(231,198,107,.4);flex:0 0 auto}
@media (prefers-reduced-motion: reduce){.tback,.tflip{animation:none}}
/* 토정 월별 운세 그리드 */
.mfgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;margin-top:8px}
.mfo{background:#241f47;border:1px solid #3a356a;border-radius:10px;padding:9px 10px}
.mfo b{color:var(--c-gold-300);font-family:var(--font-head);margin-right:6px}
.mfo .mg{font-weight:700;font-size:13px}
.mfo p{margin:5px 0 0;font-size:11.5px;color:#cfc7f0;line-height:1.5}
/* 타로 카드 */
.tgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:8px}
.tcard{background:#241f47;border:1px solid #3a356a;border-radius:12px;padding:11px 12px}
.tpos{font-size:11px;color:#9a93c8}
.tname{font-family:var(--font-head);color:var(--c-gold-300);font-size:16px;margin:3px 0 5px}
.tmean{font-size:12.5px;color:#cfc7f0;line-height:1.55}
/* 결제 게이트 */
.paygate{border:1.5px dashed var(--c-gold-400);border-radius:var(--r-md);padding:var(--sp-5);text-align:center;background:#1d1a45;color:#eee;margin-top:8px}
.paygate .lock{font-size:30px}
.paygate .cd{color:var(--c-gold-300);font-weight:700;font-variant-numeric:tabular-nums}

/* 입력 셀렉트(시진 등) */
.reading-form .ipt-sel{padding:11px;border:1px solid var(--c-line);border-radius:var(--r-sm);font-size:15px;width:100%;background:#fff;color:var(--c-text)}

/* 자미두수 명반표 */
.myeongban{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}
.palace{background:#241f47;border:1px solid #3a356a;border-radius:8px;padding:8px;font-size:12px}
.palace.ming{border-color:var(--c-gold-400);background:#2c2768}
.palace .pname{color:#cbb8ff;font-weight:600;font-size:11px}
.palace .pname span{color:#8a86a8}
.palace .pstar{color:#fff;margin-top:3px}
.palace .pstar em{color:var(--c-gold-300);font-style:normal;font-size:10px}
.palace .paux{color:#9a93bd;font-size:10px;margin-top:2px}

/* 입력폼 웹툰 배경 */
.reading-bg{border-radius:var(--r-lg);padding:var(--sp-5);background-size:cover;background-position:center top;box-shadow:var(--shadow-card);margin:0 var(--gutter)}
.reading-form.on-dark label{color:#d9d2f5}
/* 남/여 선택 — 크고 또렷한 세그먼트 버튼 */
.gender-seg{display:inline-flex}
.gender-seg label{position:relative;display:inline-flex;margin:0}
.gender-seg input{position:absolute;opacity:0;width:0;height:0}
.gender-seg span{display:inline-flex;align-items:center;justify-content:center;min-width:54px;padding:12px 22px;font-size:16px;font-weight:700;color:#cfc7f0;background:rgba(255,255,255,.06);border:1px solid #4a4570;cursor:pointer;user-select:none}
.gender-seg label:first-child span{border-radius:10px 0 0 10px}
.gender-seg label:last-child span{border-radius:0 10px 10px 0;border-left:0}
.gender-seg input:checked + span{background:var(--c-gold-400);color:#1a1233;border-color:var(--c-gold-400)}
.gender-seg input:focus-visible + span{outline:2px solid var(--c-gold-300);outline-offset:1px}
.lunar-chk{flex-direction:row !important;gap:6px;align-items:center;padding-bottom:13px;font-size:14px;cursor:pointer}
.lunar-chk input{width:17px;height:17px}
.reading-form.on-dark input[type=number],.reading-form.on-dark input[type=text],.reading-form.on-dark textarea,.reading-form.on-dark .ipt-sel{background:rgba(255,255,255,.96);border-color:transparent}
.reading-form.on-dark input[type=text],.reading-form.on-dark textarea{width:100%;border-radius:10px;padding:10px 12px;border:1px solid transparent;font-size:14px}
/* 웹툰 패널 — 말풍선 위/아래 배치 */
.story-step.scene .story-bubble.b-top{top:16px;left:16px;right:auto;bottom:auto;max-width:64%}
.story-step.scene .story-bubble.b-bot{bottom:20px;right:16px;left:auto;top:auto;max-width:60%}

/* ===== 연속 웹툰 모드 (override) ===== */
.story{display:block;gap:0;padding-top:0;margin:0 calc(-1 * var(--gutter))}
.story-step{margin:0}
.story-step.scene{border-radius:0;min-height:auto;background:#0a0820;overflow:hidden}
.story-scene-img{position:relative;inset:auto;width:100%;height:auto;object-fit:initial;display:block}
/* 말풍선은 하단에 모아 얼굴(상단)을 가리지 않게 — 좌/우 정렬 유지 */
.story-step.scene .story-bubbles{position:absolute;left:0;right:0;bottom:14px;display:flex;flex-direction:column;gap:8px;padding:0 14px;z-index:2}
.story-step.scene .story-bubble{position:static;left:auto;right:auto;top:auto;bottom:auto;max-width:82%;margin:0}
.story-step.scene .story-bubble.b-top{align-self:flex-start}
.story-step.scene .story-bubble.b-bot{align-self:flex-end}
.story-step.data{background:var(--c-ink-900);color:#eee;padding:var(--sp-5) var(--gutter)}
.story-step.data h3{color:var(--c-gold-400);font-family:var(--font-head);margin-bottom:10px}
.story-step.data .result-card,.story-step.data .paygate{background:transparent;border:0;box-shadow:none;padding:0;margin:0}
.story-nav{margin:0 var(--gutter)}
.story-rail{display:none}

/* ===== 데스크탑 2단: 좌측 캐릭터 sticky + 우측 콘텐츠 흐름 (정보 밀도 ↑) ===== */
@media(min-width:980px){
  .story{display:grid;grid-template-columns:40% 60%;column-gap:44px;max-width:1180px;margin:0 auto;padding:12px 24px 0}
  .story-rail{display:block}
  .story-rail-inner{position:sticky;top:80px}
  .story-rail-img{width:100%;height:auto;display:block;border-radius:20px;box-shadow:var(--shadow-card)}
  .story-flow{min-width:0}
  /* 인라인 캐릭터 이미지는 숨기고(좌측 레일이 대신), 말풍선은 우측 칼럼 대사 블록으로 */
  .story-step.scene .story-scene-img{display:none}
  .story-step.scene .story-bubbles{position:static;display:block;padding:0}
  .story-step.scene{position:static;min-height:0;background:transparent;border-radius:0;overflow:visible;margin:0 0 16px}
  .story-step.scene .story-bubble,
  .story-step.scene .story-bubble.b-top,
  .story-step.scene .story-bubble.b-bot{position:static;inset:auto;max-width:none;margin:0 0 12px;font-size:16.5px;line-height:1.7}
  .story-step.scene .story-bubble::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--c-gold-400);margin-right:8px;vertical-align:middle}
  /* 데이터 패널 — 우측 칼럼, 카드 느낌 + 글자 살짝 키움 */
  .story-step.data{margin:0 0 18px;padding:var(--sp-5);border-radius:var(--r-md);font-size:15.5px;line-height:1.7}
  .story-step.data h3{font-size:1.15rem}
  .story-nav{max-width:1180px;margin:0 auto;padding:12px 24px 0}
}
