/* ============================================================
   onep.css — 1+1사주 프론트 (화이트 · 게임 · 캔디)
   디자인 산출물(원플원/_ds) 토큰 기반. 모바일 우선.
   ============================================================ */
:root{
  --pink:#D4537E; --pink-deep:#993556; --pink-light:#FBEAF0;
  --mint:#1D9E75; --mint-deep:#0F6E56; --mint-light:#E1F5EE;
  --indigo:#534AB7; --indigo-deep:#3C3489; --indigo-light:#EEEDFE;
  --yellow:#FFD23F; --yellow-ink:#3A2E00;
  --ink:#1B1B1E; --ink-2:#55555B; --ink-3:#6E6E74; --ink-4:#9A9AA0;
  --canvas:#fff; --page:#EDECF0;
  --tile:#F7F7F9; --tile-2:#F4F4F6;
  --line:#EAEAEE; --line-2:#EDEDF0; --line-3:#F0F0F3;
  --el-mok:#639922; --el-hwa:#E24B4A; --el-to:#BA7517; --el-geum:#888780; --el-su:#378ADD;
  --r-pill:999px; --r-lg:20px; --r-md:16px; --r-sm:14px; --r-xs:11px;
  --shadow-cta:0 10px 24px -8px rgba(212,83,126,.6);
  --font:Pretendard,-apple-system,system-ui,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);background:var(--page);color:var(--ink);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  min-height:100vh;min-height:100dvh;
}
button{font-family:inherit}
.hidden{display:none !important}

/* ── 앱 셸: 모바일 폭 고정, 데스크톱 중앙 ── */
.app{
  position:relative;width:100%;max-width:430px;margin:0 auto;
  min-height:100vh;min-height:100dvh;background:var(--canvas);
  display:flex;flex-direction:column;overflow:hidden;
}
@media(min-width:480px){
  body{display:flex;align-items:center;justify-content:center;padding:24px 0}
  .app{min-height:auto;height:min(884px,calc(100dvh - 48px));border-radius:34px;
    box-shadow:0 40px 90px -30px rgba(60,52,90,.45);}
}

/* ── 상단바 ── */
.topbar{
  flex:none;display:flex;align-items:center;gap:10px;
  padding:14px 18px 8px;position:relative;z-index:20;
}
.tb-brand{display:flex;align-items:center;gap:8px;cursor:pointer}
.tb-logo{height:26px;padding:0 8px;border-radius:8px;background:var(--pink);color:#fff;
  display:flex;align-items:center;font-weight:800;font-size:13px;letter-spacing:-.5px}
.tb-name{font-size:15px;font-weight:700;color:var(--ink)}
.tb-spacer{flex:1}
.coin-chip{display:inline-flex;align-items:center;gap:5px;height:32px;padding:0 12px;border:none;
  border-radius:var(--r-pill);background:var(--pink-light);color:var(--pink-deep);
  font-size:13px;font-weight:700;cursor:pointer}
.icon-btn{width:34px;height:34px;border-radius:50%;border:none;background:var(--tile-2);color:var(--ink);
  font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .12s}
.icon-btn:active{transform:scale(.9)}

/* ── 진행 도트(스텝 인디케이터) ── */
.dots{flex:1;display:flex;gap:6px;align-items:center;justify-content:center}
.dot{width:7px;height:7px;border-radius:50%;background:var(--line);transition:all .3s}
.dot.done{background:#F0A9C2}
.dot.active{width:20px;border-radius:var(--r-pill);background:var(--pink)}

/* ── 메뉴 팝오버 ── */
.menu-pop{position:absolute;top:52px;right:14px;z-index:60;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-md);box-shadow:0 16px 40px -12px rgba(0,0,0,.22);padding:6px;min-width:180px}
.menu-pop button{display:flex;width:100%;gap:9px;align-items:center;padding:11px 12px;border:none;background:none;
  border-radius:10px;font-size:14px;color:var(--ink);cursor:pointer;text-align:left}
.menu-pop button:active,.menu-pop button:hover{background:var(--tile-2)}

/* ── 스크롤 영역 ── */
.scroll{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{width:0}
.screen{animation:screenIn .42s cubic-bezier(.34,1.4,.64,1) both}
.pad{padding:6px 24px 30px}

/* ── 타이포 ── */
.eyebrow{font-size:12px;font-weight:600;letter-spacing:.4px;color:var(--pink)}
.h2{margin:8px 0 4px;font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.5px;line-height:1.3}
.sub{margin:0 0 18px;font-size:13.5px;color:var(--ink-3);line-height:1.5}
.muted{color:var(--ink-4)}

/* ── 버튼 ── */
.btn{width:100%;padding:16px;border:none;border-radius:var(--r-md);background:var(--pink);color:#fff;
  font-size:15px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-cta);transition:transform .12s,opacity .2s}
.btn:active{transform:scale(.97)}
.btn[disabled]{opacity:.4;box-shadow:none;cursor:default}
.btn.lg{font-size:16px}
.btn.ghost{background:#fff;color:var(--ink-2);border:1.5px solid var(--line);box-shadow:none}
.btn.yellow{background:var(--yellow);color:var(--yellow-ink);font-weight:700;box-shadow:0 10px 24px -8px rgba(255,210,63,.6);
  display:flex;align-items:center;justify-content:center;gap:8px}
.btn.mint{background:var(--mint);box-shadow:0 10px 24px -8px rgba(29,158,117,.5)}
.btn+.btn{margin-top:10px}
.btn-row{display:flex;gap:9px}
.btn-row .btn{margin-top:0}
.link-btn{width:100%;padding:6px;border:none;background:none;color:var(--ink-4);font-size:13px;cursor:pointer;text-decoration:underline}

/* ── S1 랜딩 ── */
.landing{min-height:100%;display:flex;flex-direction:column;padding:22px 24px 30px}
.land-mid{flex:1;display:flex;flex-direction:column;justify-content:center;padding:24px 0}
.pill-badge{align-self:flex-start;display:inline-flex;align-items:center;gap:7px;background:var(--pink-light);
  color:var(--pink-deep);padding:8px 15px;border-radius:var(--r-pill);font-size:13px;font-weight:600;
  margin-bottom:20px;animation:floatY 3.4s ease-in-out infinite}
.pill-badge b{font-size:17px;font-weight:700;color:var(--pink)}
.land-h1{margin:0;font-size:33px;line-height:1.24;font-weight:700;color:var(--ink);letter-spacing:-1px}
.land-h1 .em{color:var(--pink)}
.land-p{margin:16px 0 0;font-size:15px;color:var(--ink-3);line-height:1.5}
.feat-row{display:flex;gap:8px;margin-top:26px}
.feat{flex:1;background:var(--tile);border-radius:var(--r-sm);padding:13px 10px;text-align:center}
.feat .fi{font-size:20px}
.feat .ft{font-size:11.5px;color:var(--ink-3);margin-top:5px;font-weight:500}
.land-note{text-align:center;margin:12px 0 0;font-size:12.5px;color:var(--ink-4)}

/* ── 세그 토글 ── */
.seg{display:flex;background:var(--tile-2);border-radius:var(--r-sm);padding:4px;gap:2px}
.seg button{flex:1;padding:9px;border:none;border-radius:11px;cursor:pointer;font-size:14px;font-weight:400;
  background:transparent;color:var(--ink);transition:all .18s}
.seg button.on{background:#fff;font-weight:600;box-shadow:0 1px 4px rgba(0,0,0,.08)}
.seg-label{font-size:12px;color:var(--ink-4);margin-bottom:8px}

/* ── S2 캐릭터 카드 ── */
.char-list{display:flex;flex-direction:column;gap:11px}
.char-card{display:flex;align-items:stretch;gap:14px;width:100%;text-align:left;padding:12px;
  border-radius:var(--r-lg);background:#fff;border:2px solid var(--line-2);transition:all .18s;cursor:pointer}
.char-card.on{/* bg/border set inline by char color */}
.char-ill{width:96px;height:118px;flex:none;border-radius:var(--r-sm);overflow:hidden;position:relative;
  display:flex;align-items:center;justify-content:center;font-size:40px}
.char-ill img{width:100%;height:100%;object-fit:cover;display:block}
.char-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:7px}
.char-top{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.char-name{font-size:18px;font-weight:700;color:var(--ink)}
.char-tag{font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:var(--r-pill)}
.char-line{font-size:12.5px;color:var(--ink-3);line-height:1.4}
.char-metrics{display:flex;align-items:flex-end;gap:13px;margin-top:1px}
.metric{flex:1;min-width:0}
.metric-head{display:flex;justify-content:space-between;font-size:10.5px;color:var(--ink-4);margin-bottom:4px}
.metric-head b{font-weight:700;color:var(--ink-3)}
.metric-bar{height:5px;background:var(--line-3);border-radius:var(--r-pill);overflow:hidden}
.metric-bar i{display:block;height:100%;border-radius:var(--r-pill);transition:width .5s}
.metric.sat{flex:none;text-align:right}
.metric.sat .sl{font-size:10.5px;color:var(--ink-4);margin-bottom:2px}
.metric.sat .sv{font-size:13px;font-weight:700;line-height:1}
.char-pill{align-self:flex-start;white-space:nowrap;font-size:11px;font-weight:600;padding:5px 11px;
  border-radius:var(--r-pill);background:var(--tile-2);color:var(--ink-4)}
.char-hint{margin:14px 2px 0;font-size:12px;color:var(--ink-4);line-height:1.5}

/* ── S3 입력(챗) ── */
.chat{flex:1;display:flex;flex-direction:column;gap:11px;padding:14px 4px;min-height:180px}
.chat-row{display:flex;gap:8px;align-items:flex-end;animation:bubbleIn .34s cubic-bezier(.34,1.5,.64,1) both}
.chat-row.char{justify-content:flex-start}
.chat-row.user{justify-content:flex-end}
.chat-av{width:34px;height:34px;flex:none;border-radius:50%;overflow:hidden;display:flex;align-items:center;
  justify-content:center;font-size:18px}
.chat-av img{width:100%;height:100%;object-fit:cover}
.bubble{max-width:76%;padding:11px 14px;font-size:14px;line-height:1.45}
.bubble.char{background:var(--tile-2);color:var(--ink);border-radius:16px 16px 16px 5px}
.bubble.user{background:var(--pink-light);color:var(--pink-deep);border-radius:16px 16px 5px 16px}
.input-widgets{border-top:1px solid var(--line-2);padding-top:14px}
.date-row{display:flex;gap:7px;margin-bottom:12px}
.date-row select{flex:1;padding:12px 8px;border:1.5px solid var(--line);border-radius:12px;font-size:13px;
  font-family:inherit;background:#fff;color:var(--ink);-webkit-appearance:none;appearance:none}
.date-row select.y{flex:1.3}
.chip-wrap{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:10px 14px;border-radius:var(--r-pill);border:1.5px solid var(--line);background:#fff;
  color:var(--ink-2);font-size:13px;cursor:pointer;transition:transform .1s}
.chip:active{transform:scale(.95)}
.chip.on{border-color:var(--pink);background:var(--pink-light);color:var(--pink-deep)}

/* ── S4 카드 뽑기 ── */
.draw-deck{position:relative;height:220px;margin:4px -8px 8px}
.deck-card{position:absolute;left:50%;top:14px;width:54px;height:82px;margin-left:-27px;border-radius:9px;
  transform-origin:50% 300px;transition:transform .32s cubic-bezier(.34,1.56,.64,1);cursor:pointer;
  background:var(--indigo);border:2px solid #6f66c9;box-shadow:0 3px 8px rgba(60,52,137,.28);
  display:flex;align-items:center;justify-content:center;color:var(--indigo-light);font-size:20px}
.deck-card.sel{border-color:var(--pink);box-shadow:0 8px 18px -4px rgba(212,83,126,.5)}
.slot-row{display:flex;gap:9px;margin-bottom:8px}
.slot{flex:1;height:74px;border-radius:12px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:4px;border:1.5px dashed #C9C9D0;background:var(--tile);color:var(--ink-4);font-size:10.5px}
.slot.filled{border:none;background:var(--indigo);color:var(--indigo-light)}

/* ── S5 결과 ── */
.res-intro{display:flex;gap:12px;align-items:center;margin-bottom:18px}
.res-portrait{width:84px;height:106px;flex:none;border-radius:18px;overflow:hidden;display:flex;
  align-items:center;justify-content:center;font-size:36px;animation:floatY 3.2s ease-in-out infinite}
.res-portrait img{width:100%;height:100%;object-fit:cover}
.res-intro-body{flex:1}
.res-intro-name{font-size:12px;color:var(--ink-4);margin-bottom:7px}
.res-intro-bubble{padding:11px 14px;background:var(--tile-2);border-radius:16px 16px 16px 5px;font-size:14px;
  color:var(--ink);line-height:1.45}
.card-block{background:var(--tile);border-radius:var(--r-lg);padding:18px 17px;margin-bottom:14px}
.block-eyebrow{font-size:12px;font-weight:600;letter-spacing:.4px;color:var(--ink-4);margin-bottom:14px}
.oheng-row{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.oheng-row:last-child{margin-bottom:0}
.oheng-key{width:22px;height:22px;border-radius:7px;flex:none;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:#fff}
.oheng-track{flex:1;height:9px;background:#EAEAED;border-radius:var(--r-pill);overflow:hidden}
.oheng-track i{display:block;height:100%;border-radius:var(--r-pill);width:0;transition:width 1s cubic-bezier(.2,.8,.2,1)}
.oheng-val{width:30px;text-align:right;font-size:12px;font-weight:600;color:var(--ink-3)}
.res-duo{display:flex;gap:12px;margin-bottom:14px}
.res-love{flex:1.2;background:var(--pink-light);border-radius:18px;padding:16px}
.res-love-t{font-size:12px;font-weight:600;color:var(--pink-deep);margin-bottom:9px}
.stars{display:flex;gap:3px}
.stars span{font-size:20px;animation:starPop .4s backwards}
.res-shinsal{flex:1;background:var(--tile);border-radius:18px;padding:16px}
.res-shinsal-t{font-size:12px;font-weight:600;color:var(--ink-4);margin-bottom:9px}
.shinsal-tags{display:flex;flex-wrap:wrap;gap:6px}
.shinsal-tag{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:5px 9px;
  border-radius:var(--r-pill);background:#fff;border:1px solid var(--line);color:var(--ink-2);animation:badgePop .4s backwards}
.tarot-lead{font-size:12px;font-weight:600;letter-spacing:.4px;color:var(--ink-4);margin:6px 2px 10px}
.tarot-3{display:flex;gap:9px;margin-bottom:16px}
.tcard{flex:1;border-radius:var(--r-sm);background:#fff;border:1px solid var(--line-2);overflow:hidden;text-align:center}
.tcard-top{height:78px;background:var(--indigo);color:var(--indigo-light);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px}
.tcard-h{font-size:22px;font-weight:700}
.tcard-n{font-size:11px}
.tcard-body{padding:8px 4px}
.tcard-pos{font-size:10px;color:var(--ink-4)}
.tcard-k{font-size:11px;font-weight:600;color:var(--indigo);margin-top:2px}
.cross-box{background:var(--indigo-light);border-radius:18px;padding:16px 17px;margin-bottom:18px}
.cross-t{font-size:12px;font-weight:600;color:var(--indigo-deep);margin-bottom:8px}
.cross-box p{margin:0;font-size:13.5px;line-height:1.6;color:var(--indigo-deep)}
.paywall-note{background:var(--tile);border-radius:var(--r-sm);padding:11px 14px;font-size:12px;color:var(--ink-4);
  text-align:center;margin-bottom:14px}

/* ── 딥 리포트 확장 ── */
.deep-sec{background:var(--tile);border-radius:var(--r-lg);padding:16px 17px;margin-bottom:14px}
.deep-sec h3{margin:0 0 8px;font-size:14px;font-weight:700;color:var(--ink)}
.deep-sec p{margin:0 0 8px;font-size:13.5px;line-height:1.6;color:var(--ink-2)}
.deep-sec p:last-child{margin-bottom:0}
.deep-sec p strong{color:var(--pink-deep)}
.verdict-hero{text-align:center;background:linear-gradient(135deg,var(--pink-light),var(--indigo-light));
  border-radius:var(--r-lg);padding:22px 18px;margin-bottom:14px}
.verdict-hero .vnum{font-size:44px;font-weight:800;color:var(--pink);line-height:1}
.verdict-hero .vlab{font-size:12px;color:var(--ink-4);margin-top:4px}
.verdict-hero h3{margin:12px 0 6px;font-size:17px;font-weight:700;color:var(--ink)}
.verdict-hero p{margin:0;font-size:13.5px;line-height:1.6;color:var(--ink-2)}

/* ── S6 1+1 선물 ── */
.gift{padding:10px 24px 28px;text-align:center}
.gift-badge{display:inline-flex;align-items:center;gap:8px;background:var(--pink-light);color:var(--pink-deep);
  padding:10px 18px;border-radius:var(--r-pill);font-size:14px;font-weight:600;margin:8px 0 4px;animation:popIn .5s}
.gift-badge b{font-size:19px;font-weight:700;color:var(--pink)}
.gift-h{margin:14px 0 6px;font-size:23px;font-weight:700;color:var(--ink);letter-spacing:-.5px;line-height:1.3}
.gift-h .em{color:var(--pink)}
.gift-p{margin:0 0 22px;font-size:13.5px;color:var(--ink-3)}
.ticket{position:relative;background:#fff;border:2px dashed var(--pink);border-radius:var(--r-lg);padding:22px 20px;
  margin-bottom:22px;text-align:left;display:flex;align-items:center;gap:16px;animation:popIn .55s .1s backwards}
.ticket-ico{width:52px;height:52px;border-radius:var(--r-sm);flex:none;background:var(--pink-light);
  display:flex;align-items:center;justify-content:center;font-size:26px}
.ticket-body{flex:1}
.ticket-title{font-size:16px;font-weight:700;color:var(--ink)}
.ticket-sub{font-size:12px;color:var(--ink-4);margin-top:3px}
.ticket-vert{writing-mode:vertical-rl;font-size:11px;font-weight:700;color:var(--pink);letter-spacing:1px}
.gift-preview{background:var(--tile);border-radius:var(--r-md);padding:13px 15px;margin-bottom:22px;display:flex;
  align-items:center;gap:11px;text-align:left}
.gift-preview .av{width:44px;height:44px;flex:none;border-radius:50%;overflow:hidden;display:flex;align-items:center;
  justify-content:center;font-size:20px}
.gift-preview .av img{width:100%;height:100%;object-fit:cover}
.gift-preview .txt{font-size:12.5px;color:var(--ink-3);line-height:1.4}
.gift-preview .txt b{color:var(--ink)}

/* ── 로그인 ── */
.login-pad{padding:20px 24px 30px}
.fld{display:block;font-size:12px;color:var(--ink-4);margin:14px 0 6px}
.input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:14px;
  font-family:inherit;background:#fff;color:var(--ink);-webkit-appearance:none}
.input:focus{outline:none;border-color:var(--pink)}
.err{color:var(--pink-deep);font-size:12px;margin-top:8px;min-height:15px}
.or-line{display:flex;align-items:center;gap:10px;color:var(--ink-4);font-size:12px;margin:16px 0}
.or-line::before,.or-line::after{content:"";flex:1;height:1px;background:var(--line)}

/* ── 지갑 / 기록 ── */
.wallet-hero{display:flex;align-items:center;justify-content:space-between;background:var(--pink-light);
  border-radius:var(--r-lg);padding:18px 20px;margin-bottom:16px}
.wallet-bal{font-size:26px;font-weight:800;color:var(--pink-deep)}
.wallet-bal span{font-size:13px;font-weight:600;margin-left:4px}
.wallet-hero .btn{width:auto;padding:11px 18px;font-size:14px}
.ledger-row{display:flex;justify-content:space-between;align-items:center;padding:12px 2px;border-bottom:1px solid var(--line-2)}
.ledger-row b.up{color:var(--mint)}.ledger-row b.dn{color:var(--pink)}
.ld-date{font-size:11px;color:var(--ink-4);margin-left:8px}
.hist-item{display:flex;align-items:center;gap:12px;padding:13px 12px;border:1px solid var(--line-2);
  border-radius:var(--r-md);margin-bottom:10px;cursor:pointer}
.hist-g{width:44px;height:44px;flex:none;border-radius:12px;background:var(--pink-light);color:var(--pink-deep);
  display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800}
.hist-b{flex:1}.hist-t{font-size:14px;font-weight:600;color:var(--ink)}.hist-d{font-size:12px;color:var(--ink-4)}
.hist-empty{padding:36px 12px;text-align:center;color:var(--ink-4);font-size:13px;line-height:1.6}
.divider{height:1px;background:var(--line-2);margin:14px 0}

/* ── 충전 바텀시트 ── */
.sheet{position:fixed;inset:0;z-index:100;display:flex;align-items:flex-end;justify-content:center}
.sheet-dim{position:absolute;inset:0;background:rgba(0,0,0,.42);animation:fadeIn .2s}
.sheet-panel{position:relative;width:100%;max-width:430px;background:#fff;border-radius:24px 24px 0 0;
  padding:10px 22px 26px;animation:sheetUp .3s cubic-bezier(.34,1.4,.64,1)}
.sheet-grab{width:40px;height:5px;border-radius:var(--r-pill);background:var(--line);margin:0 auto 14px}
.sheet-title{margin:0 0 4px;font-size:18px;font-weight:700}
.pkg-list{display:flex;flex-direction:column;gap:9px;margin:14px 0}
.pkg{position:relative;display:flex;justify-content:space-between;align-items:center;padding:15px 16px;
  border:1.5px solid var(--line);border-radius:var(--r-md);background:#fff;cursor:pointer;text-align:left}
.pkg.sel{border-color:var(--pink);background:var(--pink-light)}
.pkg-coins{font-size:15px;font-weight:700;color:var(--ink)}
.pkg-coins em{font-style:normal;color:var(--pink);font-size:12px;margin-left:4px}
.pkg-price{font-size:14px;font-weight:600;color:var(--ink-3)}
.pkg-badge{position:absolute;top:-8px;left:14px;background:var(--pink);color:#fff;font-size:10px;font-weight:700;
  padding:2px 8px;border-radius:var(--r-pill)}

/* ── 공유 캔버스 ── */
.share-wrap{border-radius:var(--r-md);overflow:hidden;margin:12px 0;background:var(--tile)}
.share-wrap canvas{width:100%;display:block}

.foot{flex:none;text-align:center;font-size:11px;color:var(--ink-4);padding:12px 0 16px}

/* ── 일간 성향 카드 ── */
.dm-title{font-size:19px;font-weight:700;color:var(--ink);margin-bottom:4px}
.dm-trait{font-size:13px;color:var(--ink-3);line-height:1.5}
.dm-trait b{color:var(--pink-deep);font-weight:600}

/* ── 핵심 기운 ── */
.res-core{flex:1.2;background:var(--indigo-light);border-radius:18px;padding:16px;display:flex;flex-direction:column;gap:9px}
.res-core-t{font-size:12px;font-weight:600;color:var(--indigo-deep)}
.res-core-el{align-self:flex-start;color:#fff;font-size:15px;font-weight:800;padding:8px 14px;border-radius:12px;letter-spacing:1px}

/* ── 채팅 상담 ── */
.consult{margin-top:6px;background:var(--tile);border-radius:var(--r-lg);padding:16px 15px}
.consult-head{font-size:16px;font-weight:700;color:var(--ink)}
.consult-sub{font-size:12.5px;color:var(--ink-3);margin:4px 0 12px;line-height:1.5}
.consult-topics{margin-bottom:12px}
.consult-topics .chip{padding:8px 12px;font-size:12.5px;background:#fff}
.consult-log{min-height:0;max-height:340px;overflow-y:auto;background:transparent;padding:2px 0;gap:10px}
.consult-log::-webkit-scrollbar{width:0}
.consult-log:empty{display:none}
.consult-input{display:flex;gap:8px;align-items:center;margin-top:12px;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-pill);padding:4px 4px 4px 16px}
.consult-input input{flex:1;border:none;outline:none;font-family:inherit;font-size:14px;color:var(--ink);background:transparent;padding:8px 0}
.consult-input button{flex:none;width:38px;height:38px;border-radius:50%;border:none;background:var(--pink);color:#fff;font-size:17px;font-weight:700;cursor:pointer;transition:transform .12s,opacity .2s}
.consult-input button:active{transform:scale(.9)}
.consult-input button:disabled{opacity:.45;cursor:default}
.typing{display:inline-flex;gap:4px;align-items:center;padding:2px 0}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--ink-4);display:inline-block;animation:typingBlink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}

/* ── 애니메이션 ── */
@keyframes typingBlink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
@keyframes screenIn{from{opacity:0;transform:translateY(14px) scale(.985)}to{opacity:1;transform:none}}
@keyframes popIn{0%{opacity:0;transform:scale(.7)}60%{transform:scale(1.06)}100%{opacity:1;transform:scale(1)}}
@keyframes bubbleIn{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes starPop{0%{opacity:0;transform:scale(.2)}70%{transform:scale(1.25)}100%{opacity:1;transform:scale(1)}}
@keyframes badgePop{0%{opacity:0;transform:scale(.4) rotate(-12deg)}100%{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:none}}
