/* ═══════════════════════════════════════════════
   메디컬 이음 — Toss-clean 디자인
   밝은 화이트 · 토스 블루 · 굵은 고딕 · 둥근 카드
   ═══════════════════════════════════════════════ */
:root{
  --bg:#f4f6f8;
  --card:#ffffff;
  --ink:#191f28;        /* near-black */
  --ink-2:#4e5968;      /* gray text */
  --ink-3:#8b95a1;      /* light gray */
  --line:#edeff2;
  --line-2:#e1e4e8;
  --primary:#3182f6;    /* toss blue */
  --primary-deep:#2272eb;
  --primary-soft:#e8f1fe;
  --primary-tint:#f2f7ff;
  /* severity */
  --low:#12b886;      --low-bg:#e6f8f1;
  --mod:#f59f00;      --mod-bg:#fff6e3;
  --high:#fd7e14;     --high-bg:#fff0e2;
  --crit:#f03e5e;     --crit-bg:#ffe9ed;
  --info:#3182f6;     --info-bg:#e8f1fe;
  --r:16px; --r-lg:22px; --r-xl:28px;
  --sh:0 1px 3px rgba(25,31,40,.04),0 6px 20px rgba(25,31,40,.05);
  --sh-hover:0 4px 10px rgba(25,31,40,.06),0 16px 40px rgba(49,130,246,.1);
  --nav-h:62px; --maxw:1080px;
  --ease:cubic-bezier(.25,.6,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Pretendard Variable","Pretendard",system-ui,sans-serif;background:var(--bg);color:var(--ink);
  line-height:1.55;letter-spacing:-.02em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  display:flex;flex-direction:column;min-height:100vh}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.ic{flex-shrink:0}
::selection{background:var(--primary-soft)}
.tnum{font-variant-numeric:tabular-nums}

/* ── top nav ── */
.nav{position:sticky;top:0;z-index:50;height:var(--nav-h);background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--maxw);height:100%;margin:0 auto;padding:0 22px;display:flex;align-items:center;gap:18px}
.brand{display:flex;align-items:center;gap:9px;cursor:pointer;flex-shrink:0}
.brand .bm{width:32px;height:32px;border-radius:9px;background:var(--primary);display:grid;place-items:center}
.brand .bm svg{width:19px;height:19px}
.brand .bt{display:flex;flex-direction:column;align-items:center;line-height:1}
.brand .bt .k{font-weight:800;font-size:18px;letter-spacing:-.04em}
.brand .bt .s{font-size:10px;font-weight:600;color:var(--ink-3);margin-top:2px;letter-spacing:.02em}
.nav-links{display:flex;gap:4px;margin-left:6px}
.nav-links a{padding:8px 13px;border-radius:10px;font-size:14.5px;font-weight:600;color:var(--ink-2);transition:all .15s}
.nav-links a:hover{background:var(--bg);color:var(--ink)}
.nav-links a.on{color:var(--primary);background:var(--primary-tint)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-search{position:relative;display:flex;align-items:center}
.nav-search .ic{position:absolute;left:13px;color:var(--ink-3);pointer-events:none}
.nav-search input{width:210px;padding:9px 14px 9px 38px;border-radius:11px;border:1px solid transparent;background:var(--bg);
  font-size:14px;font-family:inherit;color:var(--ink);transition:all .18s var(--ease)}
.nav-search input::placeholder{color:var(--ink-3)}
.nav-search input:focus{outline:none;width:250px;background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
@media(max-width:760px){.nav-links{display:none}.nav-search input{width:130px}.nav-search input:focus{width:160px}}

/* auth */
.login-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:11px;background:var(--ink);color:#fff;
  font-size:14px;font-weight:700;transition:all .15s}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(25,31,40,.18)}
.login-btn .glogo{width:17px;height:17px;background:#fff;border-radius:4px;padding:0}
#gbtn{display:flex;align-items:center}
.user-chip{display:flex;align-items:center;gap:8px;padding:4px 6px 4px 4px;border-radius:999px;border:1px solid var(--line-2);background:#fff;transition:box-shadow .15s}
.user-chip:hover{box-shadow:var(--sh)}
.user-chip .av{width:30px;height:30px;border-radius:50%;object-fit:cover;background:var(--primary-soft);display:grid;place-items:center;
  color:var(--primary-deep);font-weight:800;font-size:13px}
.user-chip .un{font-size:13.5px;font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-chip .lo,.user-chip .ci{display:grid;place-items:center;width:30px;height:30px;color:var(--ink-3);border-radius:50%}
.user-chip .lo:hover{color:var(--crit);background:var(--crit-bg)}
.user-chip .ci:hover{color:var(--primary);background:var(--primary-soft)}
@media(max-width:600px){.user-chip .un{display:none}.login-btn span{display:none}}

/* ── page ── */
.page{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 22px 60px;flex:1}
body[data-loading="1"] .page{opacity:0}

/* ── hero ── */
.hero{padding:46px 0 8px}
.hero .badge{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:999px;background:var(--primary-soft);
  color:var(--primary-deep);font-size:12.5px;font-weight:700;margin-bottom:18px}
.hero h1{font-size:clamp(28px,5vw,40px);font-weight:800;letter-spacing:-.045em;line-height:1.22}
.hero h1 .accent{color:var(--primary)}
.hero .sub{margin-top:14px;color:var(--ink-2);font-size:16px;font-weight:500;max-width:540px}
.hero .stats{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap}
.hero .stat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px 20px;min-width:104px}
.hero .stat .n{font-size:24px;font-weight:800;letter-spacing:-.03em}
.hero .stat .l{font-size:12.5px;color:var(--ink-3);font-weight:600;margin-top:1px}

/* ── category chips (filter) ── */
.chips{display:flex;gap:8px;overflow-x:auto;padding:24px 0 6px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.chips::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:999px;border:1.5px solid var(--line-2);
  background:var(--card);font-size:14px;font-weight:700;color:var(--ink-2);transition:all .15s var(--ease);white-space:nowrap}
.chip:hover{border-color:var(--ink-3)}
.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}
.chip .em{font-size:15px;line-height:1}

/* ── section ── */
.section{margin-top:34px}
.section .sh{display:flex;align-items:center;gap:11px;margin-bottom:15px}
.section .sh .tile{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;font-size:18px;background:var(--cat-bg)}
.section .sh h2{font-size:18px;font-weight:800;letter-spacing:-.03em}
.section .sh .cnt{margin-left:auto;font-size:13px;font-weight:700;color:var(--ink-3)}

.cards{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:820px){.cards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:540px){.cards{grid-template-columns:1fr}}
.tool{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px;cursor:pointer;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease);display:flex;flex-direction:column;min-height:140px;
  opacity:0;transform:translateY(8px);animation:up .45s var(--ease) forwards}
@keyframes up{to{opacity:1;transform:none}}
.tool:hover{transform:translateY(-4px);box-shadow:var(--sh-hover)}
.tool:active{transform:translateY(-1px) scale(.99)}
.tool .tile{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-size:24px;background:var(--cat-bg);margin-bottom:14px}
.tool .nm{font-size:16.5px;font-weight:800;letter-spacing:-.03em;line-height:1.3}
.tool .en{font-size:12px;color:var(--ink-3);font-weight:600;margin-top:3px}
.tool .ds{font-size:13px;color:var(--ink-2);font-weight:500;margin-top:9px;flex:1;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tool .foot{display:flex;align-items:center;gap:6px;margin-top:13px;font-size:12.5px;font-weight:700;color:var(--low)}
.tool .foot .arr{margin-left:auto;color:var(--ink-3);transition:transform .18s,color .18s}
.tool:hover .foot .arr{color:var(--primary);transform:translateX(3px)}
.tool .foot.warn{color:var(--mod)}

.empty{text-align:center;padding:72px 20px;color:var(--ink-3)}
.empty .big{font-size:18px;color:var(--ink-2);font-weight:700;margin-bottom:6px}
.empty .em{font-size:40px;margin-bottom:12px}

/* ── calculator ── */
.calc-top{padding:24px 0 0}
.back{display:inline-flex;align-items:center;gap:5px;color:var(--ink-2);font-size:14px;font-weight:700;margin-bottom:18px;transition:color .15s}
.back:hover{color:var(--primary)}
.calc-hd{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.calc-hd .tile{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;font-size:28px;background:var(--cat-bg);flex-shrink:0}
.calc-hd h1{font-size:25px;font-weight:800;letter-spacing:-.04em;line-height:1.15}
.calc-hd .meta{display:flex;align-items:center;gap:8px;margin-top:5px;flex-wrap:wrap}
.calc-hd .en{font-size:12.5px;color:var(--ink-3);font-weight:600}
.vchip{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:700;color:var(--low);background:var(--low-bg);border-radius:999px;padding:3px 9px}
.vchip.warn{color:var(--mod);background:var(--mod-bg)}
.purpose{font-size:14.5px;color:var(--ink-2);font-weight:500;line-height:1.6;padding:15px 18px;background:var(--primary-tint);
  border-radius:var(--r);margin-bottom:20px}

.calc-grid{display:grid;grid-template-columns:1fr 384px;gap:20px;align-items:start}
@media(max-width:980px){.calc-grid{grid-template-columns:1fr}}

.box{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px}
.box-h{font-size:15px;font-weight:800;letter-spacing:-.02em;margin-bottom:18px;display:flex;align-items:center;gap:7px}

/* fields */
.field{margin-bottom:20px}
.field:last-child{margin-bottom:0}
.field .lab{font-size:14px;font-weight:700;margin-bottom:9px;display:flex;align-items:baseline;gap:6px}
.field .lab .u{font-size:12px;color:var(--ink-3);font-weight:600}
.field .lab .rq{color:var(--primary)}
.field .help{font-size:12px;color:var(--ink-3);font-weight:500;margin:-4px 0 9px;line-height:1.45}
.in-num{position:relative;display:flex;align-items:center}
.in-num input{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid var(--line-2);font-size:17px;font-weight:600;
  font-family:inherit;background:var(--bg);color:var(--ink);transition:all .15s;font-variant-numeric:tabular-nums}
.in-num input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3.5px var(--primary-soft)}
.in-num .suf{position:absolute;right:16px;font-size:13px;color:var(--ink-3);font-weight:600;pointer-events:none}
select.fld{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid var(--line-2);font-size:15px;font-weight:600;
  font-family:inherit;background:var(--bg);color:var(--ink);cursor:pointer;appearance:none;padding-right:42px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238b95a1' stroke-width='2.2' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:18px}
select.fld:focus{outline:none;border-color:var(--primary);background-color:#fff;box-shadow:0 0 0 3.5px var(--primary-soft)}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opts.col{flex-direction:column}
.opt{flex:1 1 auto;min-width:fit-content}
.opt input{position:absolute;opacity:0;pointer-events:none}
.opt label{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:13px 16px;border-radius:13px;
  border:1.5px solid var(--line-2);background:var(--bg);font-size:14.5px;font-weight:600;color:var(--ink-2);cursor:pointer;
  transition:all .14s var(--ease);line-height:1.3}
.opt label .pt{font-size:12px;font-weight:800;color:var(--ink-3);background:var(--card);border-radius:7px;padding:2px 8px}
.opt input:checked+label{border-color:var(--primary);background:var(--primary-tint);color:var(--primary-deep);box-shadow:0 0 0 1.5px var(--primary)}
.opt input:checked+label .pt{color:#fff;background:var(--primary)}
.opt input:focus-visible+label{box-shadow:0 0 0 3.5px var(--primary-soft)}
.memo input,.memo textarea{width:100%;padding:13px 16px;border-radius:13px;border:1.5px dashed var(--line-2);font-size:14.5px;font-weight:500;
  font-family:inherit;background:transparent;color:var(--ink)}
.memo textarea{resize:vertical;line-height:1.5;min-height:48px}
.memo select.fld{border-style:dashed;background-color:transparent}
.memo input:focus,.memo textarea:focus,.memo select.fld:focus{outline:none;border-style:solid;border-color:var(--primary);box-shadow:0 0 0 3.5px var(--primary-soft)}
.pt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.pt-grid{grid-template-columns:1fr}}

/* ── result ── */
.aside{position:sticky;top:calc(var(--nav-h) + 16px);display:flex;flex-direction:column;gap:14px}
@media(max-width:980px){.aside{position:static}}
.result{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);overflow:hidden}
.result .rh{padding:15px 20px 0;display:flex;align-items:center;justify-content:space-between}
.result .rh .t{font-size:13px;font-weight:800;color:var(--ink-3)}
.result .rh .live{display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--primary)}
.result .rh .live .d{width:6px;height:6px;border-radius:50%;background:var(--primary);animation:blink 1.8s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.rbody{padding:18px 22px 22px}
.res-empty{text-align:center;padding:34px 12px;color:var(--ink-3);font-size:14px;font-weight:500}
.res-empty .em{font-size:34px;margin-bottom:10px;opacity:.5}
.res-val .lbl{font-size:13px;color:var(--ink-3);font-weight:600}
.res-val .big{display:flex;align-items:baseline;gap:8px;margin-top:4px}
.res-val .num{font-size:52px;font-weight:800;letter-spacing:-.05em;line-height:1;font-variant-numeric:tabular-nums}
.res-val .unit{font-size:15px;color:var(--ink-3);font-weight:700}
.res-pill{display:inline-flex;align-items:center;gap:7px;margin-top:14px;padding:9px 14px;border-radius:12px;font-size:15px;font-weight:800}
.res-pill .s{font-size:12px;font-weight:700;opacity:.75}

.gauge{margin-top:20px;display:flex;gap:4px}
.gauge .seg{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}
.gauge .seg .bar{width:100%;height:7px;border-radius:99px;background:var(--seg-bg);transition:all .35s var(--ease)}
.gauge .seg.on .bar{height:11px;background:var(--seg-c)}
.gauge .seg .rg{font-size:10px;font-weight:700;color:var(--ink-3);text-align:center;line-height:1.15}
.gauge .seg.on .rg{color:var(--ink)}

.res-note{margin-top:18px;font-size:13.5px;color:var(--ink-2);font-weight:500;line-height:1.6;padding-top:16px;border-top:1px solid var(--line)}
.res-act{display:flex;gap:8px;margin-top:18px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:14px 16px;border-radius:14px;font-size:15px;font-weight:800;transition:all .15s var(--ease)}
.btn-p{flex:1;background:var(--primary);color:#fff}
.btn-p:hover{background:var(--primary-deep);transform:translateY(-1px);box-shadow:0 8px 20px rgba(49,130,246,.3)}
.btn-p:active{transform:translateY(0)}
.btn-g{border:1.5px solid var(--line-2);color:var(--ink-2);background:var(--card)}
.btn-g:hover{border-color:var(--primary);color:var(--primary)}
.flash{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--low);margin-top:13px;opacity:0;transition:opacity .2s}
.flash.show{opacity:1}

/* interp / caveats / refs */
.stack{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.irow{display:flex;gap:14px;padding:13px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.irow:last-child{border-bottom:none}
.irow.on{background:var(--primary-tint);margin:0 -22px;padding:13px 22px;border-radius:12px;border-bottom-color:transparent}
.irow .rg{font-size:13px;font-weight:800;min-width:92px;display:flex;align-items:center;gap:8px;color:var(--ink)}
.irow .rg .d{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.irow .lb{font-size:14px;font-weight:700}
.irow .nt{font-size:13px;color:var(--ink-2);font-weight:500;margin-top:3px;line-height:1.5}
.caveats{list-style:none}
.caveats li{font-size:13.5px;color:var(--ink-2);font-weight:500;padding-left:22px;position:relative;margin-bottom:9px;line-height:1.55}
.caveats li:last-child{margin-bottom:0}
.caveats li::before{content:"!";position:absolute;left:6px;top:0;color:var(--mod);font-weight:800}
.refs{list-style:none}
.refs li{font-size:12.5px;color:var(--ink-3);font-weight:500;padding-left:16px;position:relative;margin-bottom:7px;line-height:1.5;word-break:break-word}
.refs li::before{content:"·";position:absolute;left:5px;color:var(--primary);font-weight:800}
.refs a{color:var(--primary);font-weight:700}
.disclaimer{font-size:12px;color:var(--ink-3);font-weight:500;line-height:1.65;padding:16px 18px;background:var(--card);
  border:1px solid var(--line);border-radius:var(--r);margin-top:16px}

/* history */
.local-tag{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--primary-deep);
  background:var(--primary-soft);padding:8px 14px;border-radius:999px;margin-bottom:18px}
.htools{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.htools .btn-g{padding:10px 15px;border-radius:12px;font-size:13.5px}
.hrow{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px 17px;margin-bottom:10px;
  display:flex;align-items:center;gap:14px;transition:box-shadow .15s}
.hrow:hover{box-shadow:var(--sh)}
.hrow .tile{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:20px;background:var(--cat-bg);flex-shrink:0}
.hrow .m{flex:1;min-width:0}
.hrow .nm{font-weight:800;font-size:14.5px;display:flex;align-items:center;gap:8px}
.hrow .lb{font-size:11.5px;font-weight:700;color:var(--primary-deep);background:var(--primary-soft);padding:2px 9px;border-radius:999px}
.hrow .dt{font-size:12px;color:var(--ink-3);font-weight:600;margin-top:3px}
.hrow .v{text-align:right}
.hrow .v .vv{font-size:20px;font-weight:800;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.hrow .v .bb{font-size:11px;font-weight:800;padding:2px 8px;border-radius:7px;display:inline-block;margin-top:2px}
.hrow .del{display:grid;place-items:center;width:34px;height:34px;color:var(--ink-3);border-radius:10px}
.hrow .del:hover{color:var(--crit);background:var(--crit-bg)}

/* severity utils */
.bg-low{background:var(--low-bg);color:var(--low)} .bg-moderate{background:var(--mod-bg);color:var(--mod)}
.bg-high{background:var(--high-bg);color:var(--high)} .bg-critical{background:var(--crit-bg);color:var(--crit)}
.bg-info{background:var(--info-bg);color:var(--info)}

/* privacy note (메인) */
.privacy-note{display:flex;align-items:center;gap:12px;margin-top:22px;padding:15px 18px;border-radius:16px;
  background:linear-gradient(100deg,#eef5ff,#f3f9f4);border:1px solid #e2ecfb;font-size:13.5px;color:var(--ink-2);font-weight:500;line-height:1.5}
.privacy-note .ic{color:var(--primary);flex-shrink:0}
.privacy-note b{color:var(--ink);font-weight:700}

/* login gate */
.gate{display:flex;justify-content:center;padding:60px 20px 40px}
.gate-card{background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:var(--sh);
  padding:44px 36px;max-width:420px;width:100%;text-align:center}
.gate-ic{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;margin:0 auto 18px;
  background:var(--primary-soft);color:var(--primary)}
.gate-card h2{font-size:22px;font-weight:800;letter-spacing:-.03em}
.gate-card p{font-size:14.5px;color:var(--ink-2);font-weight:500;margin-top:10px;line-height:1.6}
.gate-card p b{color:var(--ink);font-weight:700}
.gate-btn{display:flex;justify-content:center;margin:24px 0 8px;min-height:44px}
.gate-back{display:inline-block;margin-top:6px;font-size:13.5px;font-weight:600;color:var(--ink-3)}
.gate-back:hover{color:var(--primary)}
.gate-note{display:flex;align-items:center;justify-content:center;gap:7px;margin-top:24px;padding-top:18px;
  border-top:1px solid var(--line);font-size:12px;color:var(--ink-3);font-weight:500;line-height:1.5}
.gate-note .ic{color:var(--primary);flex-shrink:0}
.gate-note b{color:var(--ink-2);font-weight:700}

/* rich result (날짜·텍스트·해석형) */
.res-rich .rr-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.rr-lbl{font-size:13px;color:var(--ink-3);font-weight:600}
.rr-val{font-size:24px;font-weight:800;letter-spacing:-.03em;margin-top:5px;line-height:1.28;word-break:keep-all}
.rr-u{font-size:14px;color:var(--ink-3);font-weight:700;margin-left:5px}
.rr-rows{margin-top:18px;display:flex;flex-direction:column}
.rr-row{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13px;align-items:flex-start}
.rr-row:last-child{border-bottom:none}
.rr-row .k{color:var(--ink-3);font-weight:600;flex-shrink:0;white-space:nowrap}
.rr-row .v{color:var(--ink);font-weight:600;text-align:right;line-height:1.5}
.in-num input[type=date]{font-family:inherit;color:var(--ink);min-height:52px}

/* 환자 이름/차트번호 2칸 */
.memo-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.memo-grid{grid-template-columns:1fr}}

/* footer (사업자 정보) */
.site-footer{border-top:1px solid var(--line);background:var(--card)}
.ft-in{max-width:var(--maxw);margin:0 auto;padding:30px 22px 40px;display:flex;justify-content:space-between;gap:34px;flex-wrap:wrap}
.ft-left{max-width:540px;flex:1;min-width:260px}
.ft-co{font-weight:800;font-size:16px;letter-spacing:-.02em}
.ft-disc{font-size:11.5px;color:var(--ink-3);line-height:1.65;margin-top:10px;font-weight:500}
.ft-right{font-size:12.5px}
.ft-info{display:flex;flex-direction:column;gap:6px}
.ft-info>div{display:flex;gap:10px}
.ft-info dt{color:var(--ink-3);font-weight:600;min-width:96px}
.ft-info dd{color:var(--ink-2);font-weight:600}
.ft-info a{color:var(--ink-2)}
.ft-info a:hover{color:var(--primary)}
.ft-copy{font-size:11px;color:var(--ink-3);margin-top:16px;font-weight:500}
@media(max-width:640px){.ft-in{flex-direction:column;gap:22px}}

/* nav 설정 기어 + 기록 출력 버튼 */
.nav-gear{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;border:1px solid var(--line-2);background:var(--card);color:var(--ink-2);flex-shrink:0}
.nav-gear:hover{border-color:var(--primary);color:var(--primary)}
.hprint{display:grid;place-items:center;width:34px;height:34px;color:var(--ink-3);border-radius:10px}
.hprint:hover{color:var(--primary);background:var(--primary-soft)}

/* 발급기관 설정 모달 */
.modal-ov{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:20px;
  background:rgba(25,31,40,.45);backdrop-filter:blur(3px);opacity:0;transition:opacity .2s}
.modal-ov.open{display:flex;opacity:1}
.modal-card{background:var(--card);width:100%;max-width:400px;border-radius:20px;padding:24px;box-shadow:var(--sh-hover);
  transform:translateY(10px);transition:transform .22s var(--ease)}
.modal-ov.open .modal-card{transform:none}
.modal-h{display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:800;letter-spacing:-.02em}
.modal-x{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;color:var(--ink-3)}
.modal-x:hover{background:var(--bg);color:var(--ink)}
.modal-desc{font-size:13px;color:var(--ink-2);font-weight:500;margin:8px 0 18px;line-height:1.5}
.modal-desc b{color:var(--ink);font-weight:700}
.mf{margin-bottom:14px}
.mf-l{font-size:13px;font-weight:700;margin-bottom:7px}
.mf input{width:100%;padding:12px 14px;border-radius:12px;border:1.5px solid var(--line-2);font-size:15px;font-family:inherit;background:var(--bg);color:var(--ink)}
.mf input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3.5px var(--primary-soft)}
.mf-l .rq{color:var(--primary)}
.modal-logout{display:block;width:100%;text-align:center;margin-top:12px;font-size:13px;font-weight:600;color:var(--ink-3);padding:7px}
.modal-logout:hover{color:var(--ink-2)}

/* PDF 미리보기 모달 */
.pdf-ov{position:fixed;inset:0;z-index:130;display:none;align-items:center;justify-content:center;padding:18px;
  background:rgba(25,31,40,.55);backdrop-filter:blur(2px);opacity:0;transition:opacity .2s}
.pdf-ov.open{display:flex;opacity:1}
.pdf-card{background:var(--card);width:100%;max-width:800px;height:90vh;border-radius:18px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh-hover)}
.pdf-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px 11px 18px;border-bottom:1px solid var(--line);flex-shrink:0}
.pdf-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:800}
.pdf-acts{display:flex;align-items:center;gap:8px}
.pdf-acts .btn-p{padding:9px 15px;border-radius:11px;font-size:13.5px}
.pdf-x{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;color:var(--ink-3)}
.pdf-x:hover{background:var(--bg);color:var(--ink)}
.pdf-frame{flex:1;width:100%;border:none;background:#525659}
@media(max-width:560px){.pdf-card{height:94vh}.pdf-acts .btn-p span{display:none}}

/* ── 결과지 인쇄(PDF) ── */
#printSheet{display:none}
@media print{
  body{display:block!important;background:#fff}
  body>*{display:none!important}
  body>#printSheet{display:block!important}
  @page{size:A4;margin:0}   /* 0 → 브라우저 자동 머리글/바닥글(시간·제목·URL·페이지번호) 제거 */
}
.ps-doc{font-family:"Pretendard","Pretendard Variable",sans-serif;color:#1a1a1a;font-size:9.5pt;line-height:1.42;
  -webkit-print-color-adjust:exact;print-color-adjust:exact;padding:6mm 8mm}   /* 컴팩트 + 여백 최소화 */
.ps-tbl tr,.ps-ul li{break-inside:avoid;page-break-inside:avoid}   /* 표 행·항목이 페이지 경계에서 안 잘리게 */
.ps-head{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:2px solid #1a1a1a;padding-bottom:9px}
.ps-brand{display:flex;align-items:baseline;gap:9px}
.ps-clinic{font-size:16pt;font-weight:800;letter-spacing:-.02em}
.ps-logo{background:#1a1a1a;color:#fff;padding:2px 9px;border-radius:5px;font-weight:800;font-size:13pt}
.ps-brand small{font-size:9.5pt;color:#666;font-weight:600}
.ps-meta{text-align:right;font-size:9pt;color:#555;font-weight:600;line-height:1.4}
.ps-meta span{color:#999;font-weight:500}
.ps-pt{display:flex;flex-wrap:wrap;gap:5px 26px;margin:10px 0;font-size:10pt;font-weight:600}
.ps-pt span{color:#999;font-weight:600;margin-right:7px}
.ps-title{font-size:14pt;font-weight:800;margin:11px 0 5px;letter-spacing:-.02em}
.ps-title em{font-style:normal;font-size:9pt;color:#999;font-weight:500;margin-left:6px}
.ps-result{display:flex;align-items:center;gap:14px;margin:3px 0 11px;padding:10px 14px;background:#f4f6f8;border-radius:9px}
.ps-val{font-size:20pt;font-weight:800;letter-spacing:-.03em}
.ps-val span{font-size:10.5pt;color:#666;font-weight:600}
.ps-band{font-size:11pt;font-weight:800;padding:3px 12px;border-radius:7px;background:#eaeaea}
.ps-low{background:#e6f8f1;color:#0a8a5f}.ps-moderate{background:#fff4e0;color:#a9730a}.ps-high{background:#fff0e2;color:#bc5410}.ps-critical{background:#ffe9ed;color:#c41e3a}.ps-info{background:#e8f1fe;color:#2069dd}
.ps-sec{margin:11px 0}
.ps-sec h2{font-size:10.5pt;font-weight:800;border-left:3px solid #1a1a1a;padding-left:9px;margin-bottom:6px}
.ps-tbl{width:100%;border-collapse:collapse;font-size:9pt}
.ps-tbl td{padding:4px 8px;border-bottom:1px solid #e8e8e8;vertical-align:top}
.ps-tbl td:first-child{color:#777;width:36%;font-weight:600}
.ps-bands td:first-child{width:24%;white-space:nowrap}
.ps-bands tr.on td{background:#eef4ff;font-weight:700;color:#111}
.ps-note{font-size:9pt;color:#333;margin:6px 0;line-height:1.5}
.ps-opbox{border:1px solid #ccc;border-radius:6px;min-height:38px;padding:7px 10px;font-size:9pt;color:#222;line-height:1.5;white-space:pre-wrap}
.ps-ul{margin:0;padding-left:16px;font-size:8.5pt;color:#555}
.ps-ul li{margin-bottom:3px;line-height:1.4}
.ps-foot{margin-top:14px;border-top:1px solid #ccc;padding-top:9px;font-size:8pt;color:#888;line-height:1.5}
.ps-co{margin-top:6px;font-weight:700;color:#555}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,16px);background:var(--ink);color:#fff;padding:13px 20px;
  border-radius:14px;font-size:14px;font-weight:700;box-shadow:0 12px 32px rgba(25,31,40,.25);opacity:0;
  transition:all .25s var(--ease);z-index:200;pointer-events:none;display:flex;align-items:center;gap:8px}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast .ic{color:#69db7c}
