/* =====================================================================
 * PillDaily — 단일 디자인 시스템 (테마 없음).
 *   모바일(html[data-mode=mobile]) / 웹(html[data-mode=web]) 공유.
 *   모든 페이지는 이 파일의 컴포넌트 클래스만 사용. 페이지별 인라인 스타일 금지.
 * ===================================================================== */
:root{
  --bg:#f4f5f7; --card:#fff; --ink:#16181d; --ink2:#3d4148; --mute:#868b94;
  --hair:#e7e9ee; --fill:#f1f3f5;
  --accent:#0e8a8a; --accent-bg:#e2f3f3; --accent-d:#0b6f6f;
  --indigo:#5b6cf0; --indigo-bg:#eaecfe; --amber:#c47d12; --amber-bg:#fbf0db;
  --violet:#6e6ad6; --violet-bg:#ecebfb; --green:#1f9d57; --green-bg:#e4f6ec; --rose:#d84b3f;
  --radius:16px; --radius-sm:12px; --shadow:0 1px 2px rgba(20,22,40,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Pretendard","Apple SD Gothic Neo",system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;max-width:100%}
a{color:inherit}
img,svg{max-width:100%}

/* ---------- 셸 ---------- */
.app{width:100%;margin:0 auto}
/* 모바일: 풀폭 단일 컬럼 + 하단 탭바 여백 */
html[data-mode="mobile"] .app{max-width:520px;padding:8px 16px 92px}
/* 웹: 상단 네비 + 중앙 콘텐츠 */
html[data-mode="web"] .app{max-width:1080px;padding:26px 28px 64px}

/* ---------- 페이지 헤더 ---------- */
.ph{padding:6px 2px 4px}
.ph .kick{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.2px;text-transform:uppercase}
.ph h1{font-size:28px;font-weight:800;letter-spacing:-.6px;margin-top:3px}
html[data-mode="web"] .ph h1{font-size:30px}
.ph .sub{font-size:14px;color:var(--mute);margin-top:4px}
.ph-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* ---------- 버튼 ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:inherit;
  font-size:14px;font-weight:700;padding:10px 15px;border-radius:11px;border:1px solid var(--hair);
  background:#fff;color:var(--ink2);cursor:pointer;text-decoration:none;white-space:nowrap}
.btn:hover{background:var(--fill)}
.btn-pri{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-pri:hover{background:var(--accent-d)}
.btn-sm{padding:7px 11px;font-size:13px;border-radius:9px}

/* ---------- 카드 ---------- */
.card{background:var(--card);border:1px solid var(--hair);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow)}
.card+.card{margin-top:12px}
.card h2{font-size:16px;font-weight:800;letter-spacing:-.3px;display:flex;align-items:center;
  justify-content:space-between;gap:10px}
.card h2 .more{font-size:12.5px;color:var(--accent);font-weight:700;text-decoration:none}
.card .cap{font-size:12.5px;color:var(--mute);margin-top:3px}

/* 섹션 헤더(카드 밖) */
.sec-h{font-size:12px;font-weight:700;color:var(--mute);text-transform:uppercase;letter-spacing:.08em;
  padding:20px 2px 9px;display:flex;align-items:center;justify-content:space-between}
.sec-h .more{font-size:12.5px;color:var(--accent);font-weight:700;text-transform:none;letter-spacing:0;text-decoration:none}

/* ---------- 스탯 타일 ---------- */
.stats{display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}
html[data-mode="web"] .stats{grid-template-columns:repeat(4,1fr)}
.stat{background:var(--card);border:1px solid var(--hair);border-radius:var(--radius-sm);padding:14px 16px;min-width:0}
.stat .l{font-size:12px;font-weight:700;color:var(--mute);text-transform:uppercase;letter-spacing:.03em}
.stat .v{font-size:26px;font-weight:800;letter-spacing:-1px;margin-top:6px;font-variant-numeric:tabular-nums}
.stat .v small{font-size:13px;color:var(--mute);font-weight:700}
.stat .bar{height:5px;border-radius:3px;background:var(--fill);margin-top:10px;overflow:hidden}
.stat .bar i{display:block;height:100%;background:var(--accent)}
.stat .d{font-size:12px;color:var(--mute);margin-top:7px}

/* ---------- 복용률 링 ---------- */
.ring{--p:0;width:84px;height:84px;flex:none;border-radius:50%;position:relative;
  background:conic-gradient(var(--accent) calc(var(--p)*1%),var(--accent-bg) 0)}
.ring::after{content:"";position:absolute;inset:9px;background:var(--card);border-radius:50%}
.ring b{position:absolute;inset:0;display:grid;place-items:center;font-size:21px;font-weight:800;letter-spacing:-.5px}
.ring b small{font-size:12px;color:var(--mute);font-weight:700}

/* ---------- 이니셜 배지 ---------- */
.ic{width:30px;height:30px;border-radius:9px;flex:none;display:grid;place-items:center;
  font-size:11px;font-weight:800;color:#fff;background:hsl(var(--h,185) 52% 47%)}
.ic-lg{width:38px;height:38px;border-radius:11px;font-size:13px}

/* ---------- 리스트(시간대/도즈) ---------- */
.group{background:var(--card);border:1px solid var(--hair);border-radius:var(--radius);overflow:hidden}
.slot-h{display:flex;align-items:center;gap:9px;padding:13px 4px 9px}
.slot-h .nm{font-size:14px;font-weight:700}
.slot-h .tm{font-size:13px;color:var(--mute);font-weight:600;margin-left:auto;font-variant-numeric:tabular-nums}
.row{display:flex;align-items:center;gap:12px;padding:13px 15px;position:relative;min-width:0}
.row+.row{border-top:1px solid var(--hair)}
.row .bd{min-width:0;flex:1}
.row .nm{font-size:15px;font-weight:600;letter-spacing:-.2px}
.row .ds{font-size:12.5px;color:var(--mute);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .amt{font-size:13px;font-weight:700;color:var(--ink2);font-variant-numeric:tabular-nums;white-space:nowrap;flex:none}
.row.tap{cursor:pointer}
.row.tap:hover{background:var(--fill)}
.chk{width:22px;height:22px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-size:12px;font-weight:900;color:#fff;background:var(--green)}
.chk.off{background:transparent;border:2px solid var(--hair);color:transparent}

.badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:7px;white-space:nowrap}
.b-empty{background:var(--indigo-bg);color:var(--indigo)}
.b-after{background:var(--amber-bg);color:var(--amber)}
.b-with{background:var(--green-bg);color:var(--green)}
.b-bed{background:var(--violet-bg);color:var(--violet)}

.synbar{display:flex;align-items:center;gap:7px;background:var(--accent-bg);color:var(--accent-d);
  font-size:12px;font-weight:700;padding:8px 14px}

.chip{display:inline-flex;align-items:center;font-size:12px;font-weight:700;padding:5px 11px;border-radius:20px;
  background:var(--fill);color:var(--ink2)}
.chip.ok{background:var(--green-bg);color:var(--green)}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}

/* ---------- 인사이트 / 경고 ---------- */
.insight{background:var(--card);border:1px solid var(--hair);border-radius:var(--radius);padding:15px 16px}
.insight .k{font-size:11px;font-weight:800;color:var(--accent);text-transform:uppercase;letter-spacing:.08em}
.insight .h{font-size:14px;font-weight:600;line-height:1.5;margin-top:6px}
.insight .h b{color:var(--accent-d)}
.insight .a{display:inline-block;margin-top:9px;font-size:12.5px;font-weight:700;color:var(--accent);text-decoration:none}
.warn{display:flex;gap:9px;background:#fdf1e3;border:1px solid #f1d4a8;border-radius:var(--radius-sm);
  padding:11px 13px;font-size:13px;font-weight:600;color:#8a5a12;line-height:1.5}
.warn .mk{flex:none;width:18px;height:18px;border-radius:50%;background:#d9942a;color:#fff;display:grid;place-items:center;font-size:11px;font-weight:900}

/* ---------- 상호작용 경고 카드 ---------- */
.ixcard{padding:13px 15px}
.ixh{font-size:13.5px;font-weight:800;color:var(--ink);margin-bottom:9px}
.ixrow{border-left:3px solid var(--hair);padding:7px 0 7px 11px;margin:7px 0}
.ixrow.crit{border-color:#d64545}
.ixrow.warn{border-color:#d9942a}
.ixrow.info{border-color:#3a86c8}
.ixp{font-size:13.5px;font-weight:700;color:var(--ink)}
.ixk{font-size:11px;font-weight:700;color:var(--ink2);background:var(--fill);border:1px solid var(--hair);border-radius:6px;padding:1px 6px;margin-left:4px;white-space:nowrap}
.ixrow.crit .ixk{color:#a32f2f;background:#fbeaea;border-color:#f0cccc}
.ixn{font-size:12.5px;color:var(--ink2);line-height:1.5;margin-top:3px}
.ixfoot{font-size:11.5px;color:var(--ink3,#9aa);margin-top:9px;padding-top:8px;border-top:1px solid var(--hair)}
.chip.warnchip{background:#fdf1e3;color:#8a5a12;border-color:#f1d4a8}

/* ---------- 궁합 지도(그래프) ---------- */
.gwrap{position:relative;border:1px solid var(--hair);border-radius:14px;background:#fff;overflow:hidden}
.gcanvas{display:block;width:100%;height:56vh;min-height:340px;touch-action:none}
html[data-mode="web"] .gcanvas{height:64vh}
.gbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:12px 0}
.gseg{display:inline-flex;border:1px solid var(--hair);border-radius:10px;overflow:hidden}
.gseg button{border:0;background:transparent;padding:7px 13px;font-size:13px;font-weight:700;color:var(--ink2);cursor:pointer}
.gseg button.on{background:var(--accent);color:#fff}
.gchip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--hair);border-radius:999px;padding:5px 11px;font-size:12.5px;font-weight:700;cursor:pointer;user-select:none}
.gchip .dot{width:9px;height:9px;border-radius:50%;flex:none}
.gchip.off{opacity:.38}
.gcount{font-size:12px;color:#9aa;margin-left:auto;font-variant-numeric:tabular-nums}
.ghint{font-size:12px;color:var(--ink2);margin-top:8px}

/* ---------- 폼 ---------- */
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink2);margin-bottom:6px}
.input{width:100%;border:1px solid var(--hair);border-radius:11px;padding:12px 14px;font-size:15px;
  font-family:inherit;background:var(--fill);outline:none}
.input:focus{border-color:var(--accent);background:#fff}

/* ---------- 추가 화면: 약장 행 컨트롤(스테퍼/함량) ---------- */
.add-ctrls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:9px}
.add-ctrls .step{display:inline-flex;align-items:center;gap:7px}
.add-ctrls .step b{font-size:13px;font-weight:700;color:var(--ink2);min-width:48px;text-align:center;
  font-variant-numeric:tabular-nums;white-space:nowrap}
.add-ctrls .btn-sm{padding:5px 10px;min-width:34px}
.add-ctrls .add-str{width:104px;flex:none;padding:7px 11px;font-size:13px;border-radius:9px}

/* 생활 시간대 편집 그리드 — 좁으면 줄바꿈, 넓으면 5열 */
.life-grid{display:grid;gap:10px;margin-top:12px;grid-template-columns:repeat(auto-fit,minmax(92px,1fr))}
.life-grid .field{margin-bottom:0;min-width:0}
.life-grid .input{padding:10px 11px;font-size:14px;font-variant-numeric:tabular-nums}

/* ---------- 모바일 하단 탭바 ---------- */
.tabbar{position:fixed;bottom:0;left:0;right:0;height:76px;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(18px);border-top:1px solid var(--hair);
  display:flex;justify-content:space-around;align-items:flex-start;padding-top:9px;z-index:40}
html[data-mode="web"] .tabbar{display:none}
.tabbar .tab{display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;
  font-size:10.5px;font-weight:600;color:var(--mute);flex:1 1 0;min-width:0}
.tabbar .tab.on{color:var(--accent)}
.tabbar .tab .g{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:12px;font-weight:800}
.tabbar .tab.on .g{background:var(--accent-bg)}

/* ---------- 사업자 정보 푸터(전 페이지 공용) ---------- */
.bizfoot{margin-top:28px;padding-top:16px;border-top:1px solid var(--hair);
  font-size:11.5px;line-height:1.7;color:var(--mute);text-align:center}
.bizfoot a{color:var(--mute);text-decoration:underline}
.bizfoot .pay{margin-top:4px}
.bizfoot .bizcopy{font-size:11px;font-weight:700;color:var(--accent);background:var(--accent-bg);
  border:0;border-radius:7px;padding:2px 8px;margin:0 2px;cursor:pointer;vertical-align:baseline}
.bizfoot .bizcopy:hover{background:var(--accent);color:#fff}

/* ---------- 웹 상단 네비 ---------- */
.topnav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--hair)}
html[data-mode="mobile"] .topnav{display:none}
.topnav .in{max-width:1080px;margin:0 auto;padding:0 28px;height:60px;display:flex;align-items:center;gap:18px}
.topnav .brand{font-size:18px;font-weight:800;letter-spacing:-.4px;text-decoration:none}
.topnav .brand .ko{font-size:11px;color:var(--mute);font-weight:600;margin-left:5px}
.topnav nav{display:flex;gap:2px}
.topnav nav a{font-size:14px;font-weight:600;color:var(--ink2);text-decoration:none;padding:8px 13px;border-radius:9px}
.topnav nav a:hover{background:var(--fill)}
.topnav nav a.on{background:var(--accent-bg);color:var(--accent)}
.topnav .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.topnav .av{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:13px;text-decoration:none}

/* ---------- 언어 토글 (EN/한국어) ---------- */
.lang-toggle{font-size:12.5px;font-weight:700;color:var(--ink2);text-decoration:none;
  padding:6px 11px;border-radius:8px;border:1px solid var(--hair);line-height:1;
  white-space:nowrap;cursor:pointer;background:transparent}
.lang-toggle:hover{background:var(--fill)}
/* 모바일: 탭바 위 우측에 떠 있는 작은 칩 */
.lang-toggle-float{position:fixed;right:14px;bottom:86px;z-index:41;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(12px);
  box-shadow:0 2px 10px rgba(0,0,0,.08)}
html[data-mode="web"] .lang-toggle-float{display:none}
/* 화면 전환(모바일/데스크톱) 토글 — 언어 토글과 동일 스타일 */
.view-toggle{font-size:12.5px;font-weight:700;color:var(--ink2);text-decoration:none;
  padding:6px 11px;border-radius:8px;border:1px solid var(--hair);line-height:1;
  white-space:nowrap;cursor:pointer;background:transparent}
.view-toggle:hover{background:var(--fill)}
.view-toggle-float{right:92px}   /* 모바일: 언어 칩 바로 왼쪽 */

/* ---------- 오늘 요약(링+메타) ---------- */
.summary{display:flex;align-items:center;gap:16px}
.summary .meta{flex:1;min-width:0}
.summary .big{font-size:16px;font-weight:800;letter-spacing:-.3px}
.summary .small{font-size:13px;color:var(--mute);margin-top:3px}

/* ---------- 레이아웃 유틸 ---------- */
.grid2{display:grid;gap:16px}
html[data-mode="web"] .grid2{grid-template-columns:1.55fr 1fr;align-items:start}
.stack{display:flex;flex-direction:column;gap:12px}

/* ---------- 근거(evidence) ---------- */
.ev-grid{display:grid;gap:12px}
html[data-mode="web"] .ev-grid{grid-template-columns:repeat(2,1fr);align-items:start}
.ev-grid .card+.card{margin-top:0}
.ev-rows{margin-top:11px;display:flex;flex-direction:column;gap:9px}
.ev-meta{display:grid;grid-template-columns:64px 1fr;gap:10px;align-items:baseline}
.ev-meta .ev-k{font-size:11px;font-weight:800;color:var(--mute);text-transform:uppercase;letter-spacing:.04em}
.ev-meta .ev-v{font-size:13.5px;color:var(--ink2);line-height:1.5}
.card.ev-muted{background:var(--fill);border-style:dashed}
.card.ev-muted h2 span:first-child{color:var(--ink2);font-weight:700}
.chip.ev-killed{background:#f6e1de;color:var(--rose)}
.ev-open{list-style:none;display:flex;flex-direction:column;gap:11px}
.ev-open li{position:relative;padding-left:16px;font-size:13.5px;color:var(--ink2);line-height:1.55}
.ev-open li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--accent)}

/* ---------- 토스트 ---------- */
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%) translateY(10px);background:#16181d;color:#fff;
  font-size:13px;font-weight:600;padding:11px 18px;border-radius:22px;opacity:0;pointer-events:none;transition:.2s;z-index:60}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
html[data-mode="web"] .toast{bottom:28px}

/* ---------- 규제·신뢰: 쿠키 동의 배너 / 의료 면책 (legal.js) ---------- */
/* 하단 고정 배너. PD.mount 탭바(z-index 40)·언어칩(41) 위로 올림(z-index 70). */
.consent-bar{position:fixed;left:0;right:0;bottom:0;z-index:70;
  background:var(--card);border-top:1px solid var(--hair);
  box-shadow:0 -2px 12px rgba(20,22,40,.08);
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:13px 16px;font-size:13px;line-height:1.5;color:var(--ink2)}
/* 모바일: 탭바(76px)·언어칩 위로 띄움 */
html[data-mode="mobile"] .consent-bar{bottom:76px;padding-bottom:14px}
.consent-bar .msg{flex:1;min-width:200px}
.consent-bar .msg a{color:var(--accent);font-weight:700;text-decoration:none}
.consent-bar .btns{display:flex;gap:8px;flex:none;margin-left:auto}

/* 의료 면책 1줄 — .app 하단. 작고 옅게. */
.disclaimer{font-size:11.5px;line-height:1.5;color:var(--mute);
  margin-top:22px;padding:12px 2px 0;border-top:1px solid var(--hair)}
