/* Pad 프로토타입 공용 스타일 */
:root{
  --accent:#0f766e; --accent2:#14b8a6; --tint:#f0fdfa; --ink:#1f2937; --muted:#6b7280;
  --line:#e5e7eb; --bg:#f8fafc; --card:#fff; --amber:#b45309; --amberbg:#fffbeb;
  --green:#15803d; --greenbg:#f0fdf4; --slate:#0f172a; --blue:#1457b8;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Pretendard","Segoe UI",sans-serif;
  color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6}
button{font-family:inherit;cursor:pointer}
.badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;vertical-align:middle}
.b-new{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}
.b-intake{background:var(--greenbg);color:var(--green);border:1px solid #bbf7d0}
.b-prog{background:var(--amberbg);color:var(--amber);border:1px solid #fde68a}
.b-done{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}
.b-cover{background:#eef2ff;color:#4338ca;border:1px solid #c7d2fe}
.b-noncover{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa}

/* ───────── 한의원 콘솔 ───────── */
.clinic-top{background:var(--slate);color:#fff;padding:12px 22px;display:flex;align-items:center;gap:14px}
.clinic-top h1{font-size:16px;margin:0;font-weight:700}
.clinic-top .sub{color:#94a3b8;font-size:12.5px}
.clinic-top .spacer{flex:1}
.clinic-top a.viewbtn{background:var(--accent2);color:#062f2b;font-weight:700;text-decoration:none;padding:7px 13px;border-radius:8px;font-size:13px}
.clinic-wrap{display:grid;grid-template-columns:300px 1fr;height:calc(100vh - 49px)}
.plist{border-right:1px solid var(--line);background:#fff;overflow-y:auto}
.plist .search{padding:12px;position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line)}
.plist .search input{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px}
.prow{padding:12px 14px;border-bottom:1px solid #f1f5f9;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px}
.prow:hover{background:var(--tint)}
.prow.active{background:var(--tint);box-shadow:inset 4px 0 0 var(--accent)}
.prow .nm{font-weight:700;font-size:14.5px}
.prow .meta{color:var(--muted);font-size:12px}
.detail{overflow-y:auto;padding:0}
.detail-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted);font-size:15px}
.chart-head{background:#fff;border-bottom:1px solid var(--line);padding:18px 26px;position:sticky;top:0;z-index:5}
.chart-head h2{margin:0 0 4px;font-size:20px}
.chart-head .ids{color:var(--muted);font-size:13px}
.tabs{display:flex;gap:4px;margin-top:14px}
.tab{border:none;background:#f1f5f9;color:#475569;padding:8px 16px;border-radius:8px 8px 0 0;font-size:13.5px;font-weight:600}
.tab.active{background:var(--accent);color:#fff}
.pane{padding:22px 26px;display:none}
.pane.active{display:block}
.kv{display:grid;grid-template-columns:120px 1fr;gap:8px 14px;font-size:14px}
.kv dt{color:var(--muted);font-weight:600}
.kv dd{margin:0}
.field{margin:0 0 16px}
.field label{display:block;font-weight:700;font-size:13.5px;margin-bottom:6px;color:var(--slate)}
.field textarea,.field input[type=text]{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:9px;font-size:14px;font-family:inherit}
.field textarea{min-height:64px;resize:vertical}
.rxopt,.lifeopt{display:flex;align-items:flex-start;gap:9px;padding:9px 11px;border:1px solid var(--line);border-radius:9px;margin-bottom:7px;cursor:pointer;font-size:13.5px}
.rxopt:hover,.lifeopt:hover{border-color:var(--accent2);background:var(--tint)}
.rxopt input,.lifeopt input{margin-top:3px}
.rxopt .rxname{font-weight:700}
.rxopt .rxind{color:var(--muted);font-size:12.5px}
.road-box{border:1px dashed var(--accent2);border-radius:11px;padding:14px 16px;background:var(--tint);margin-top:6px}
.road-box h4{margin:0 0 10px;color:var(--accent);font-size:13.5px}
.genbtn{background:var(--accent);color:#fff;border:none;padding:12px 22px;border-radius:10px;font-size:15px;font-weight:700;margin-top:8px}
.genbtn:hover{background:#0b5e57}
.preview{border:1px solid var(--line);border-radius:12px;padding:18px;margin-top:18px;background:#fff}
.msgbox{background:#fef9c3;border:1px solid #fde68a;border-radius:11px;padding:14px 16px;margin-top:16px;font-size:13.5px}
.msgbox .mtxt{background:#fff;border:1px solid #fde68a;border-radius:8px;padding:10px 12px;margin:8px 0;color:#374151}
.msgbox .lnk{font-family:ui-monospace,Menlo,monospace;font-size:12px;color:var(--blue);word-break:break-all}
.sendbtns{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.sendbtns button{border:1px solid var(--line);background:#fff;padding:8px 13px;border-radius:8px;font-size:13px;font-weight:600}
.sendbtns button.prim{background:#fee500;border-color:#fee500}
.sendbtns button.tg{background:#229ed9;color:#fff;border-color:#229ed9}
.note{color:var(--muted);font-size:12.5px;margin-top:6px}

/* ───────── 환자 앱(모바일) ───────── */
.app-patient{max-width:430px;margin:0 auto;background:#fff;min-height:100vh;box-shadow:0 0 40px rgba(0,0,0,.06)}
.ph-head{background:linear-gradient(135deg,#0f766e,#14b8a6);color:#fff;padding:22px 20px 26px}
.ph-head .brand{font-size:13px;opacity:.9;font-weight:600}
.ph-head .hi{font-size:21px;font-weight:800;margin-top:4px}
.ph-head .hi small{font-weight:500;opacity:.92;font-size:14px}
.ph-body{padding:16px 16px 90px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px 17px;margin-bottom:14px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.pcard h3{margin:0 0 10px;font-size:15.5px;display:flex;align-items:center;gap:7px}
.pcard .lab{color:var(--muted);font-size:12.5px;font-weight:600;margin-top:10px}
.pcard .val{font-size:14.5px}
.goal{background:var(--tint);border-radius:10px;padding:11px 13px;font-size:14px;margin-top:8px}
/* 로드맵 stepper */
.road{position:relative;margin-top:6px}
.step{display:flex;gap:12px;padding-bottom:16px;position:relative}
.step:last-child{padding-bottom:0}
.step .dot{flex:0 0 28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;z-index:1}
.step.cur .dot{background:var(--green);color:#fff}
.step.next .dot{background:#fff;border:2px dashed var(--accent2);color:var(--accent)}
.step .line{position:absolute;left:13px;top:28px;bottom:0;width:2px;background:var(--line)}
.step:last-child .line{display:none}
.step .scon{flex:1}
.step .stitle{font-weight:700;font-size:14.5px}
.step.next .stitle{color:var(--accent)}
.step .stx{font-size:13.5px;margin-top:2px}
.step .strig{background:var(--amberbg);border:1px solid #fde68a;border-radius:8px;padding:7px 10px;font-size:12.5px;margin-top:7px;color:#92400e}
.step .sexp{font-size:12.5px;color:var(--muted);margin-top:5px}
.step .lockbadge{font-size:11px;color:var(--accent);font-weight:700}
/* 복약 */
.med{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid #f1f5f9}
.med:last-child{border-bottom:none}
.med .chk{width:26px;height:26px;border:2px solid var(--accent2);border-radius:50%;flex:0 0 26px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;cursor:pointer}
.med .chk.on{background:var(--green);border-color:var(--green)}
.med .mname{font-weight:600;font-size:14px}
.med .mdose{color:var(--muted);font-size:12.5px}
.prog{height:8px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin:10px 0 4px}
.prog i{display:block;height:100%;background:var(--accent2)}
.qrow{display:flex;justify-content:space-between;font-size:13.5px;padding:6px 0;border-bottom:1px dashed #eef2f7}
.qrow:last-child{border-bottom:none}
.qrow .qn{font-weight:600}
.qrow .qo{color:var(--muted)}
.btn-soft{display:block;width:100%;text-align:center;background:var(--tint);color:var(--accent);border:1px solid #99f6e4;border-radius:10px;padding:11px;font-size:14px;font-weight:700;margin-top:10px;text-decoration:none}
.bottomnav{position:fixed;bottom:0;left:0;right:0;max-width:430px;margin:0 auto;background:#fff;border-top:1px solid var(--line);display:flex;padding:8px 0}
.bottomnav a{flex:1;text-align:center;color:var(--muted);font-size:11px;text-decoration:none}
.bottomnav a.on{color:var(--accent);font-weight:700}
.empty-pat{max-width:430px;margin:60px auto;text-align:center;color:var(--muted);padding:0 24px}
.empty-pat a{color:var(--accent);font-weight:700}
