/* ============================================================
   영양갱 리디자인 — 모노 + 보라 포인트 디자인 시스템
   가독성·밀도 양립: 고정폭 숫자, 헤어라인, 절제된 포인트
   ============================================================ */
:root{
  --ink:#16161A; --ink2:#3D3D45; --ink3:#7C7C86; --ink4:#ABABB4;
  --line:#ECECEF; --line2:#DDDDE2; --hair:#F1F1F3;
  --bg:#FBFBFC; --surface:#FFFFFF; --raise:#F4F4F6; --raise2:#EEEEF1;
  --accent:#5B3FD4; --accent-ink:#4A2FB8; --accent-weak:#EFEBFB; --accent-line:#D9D0F6;
  --r1:10px; --r2:14px; --r3:20px; --r4:28px;
  --fz-name:16px;
  --shadow:0 18px 50px -24px rgba(20,20,26,.30), 0 2px 8px -2px rgba(20,20,26,.06);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:'Pretendard','Pretendard Variable',-apple-system,BlinkMacSystemFont,sans-serif;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  background:transparent;
}
.num{ font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1; letter-spacing:-.01em; }

/* ---- canvas page furniture ---- */
.pagehead{ position:absolute; left:100px; top:36px; width:1480px; }
.pagehead h1{ font-size:30px; font-weight:800; letter-spacing:-.03em; margin:0 0 8px; }
.pagehead p{ font-size:15px; color:var(--ink3); margin:0; line-height:1.6; max-width:760px; }
.colhead{ position:absolute; width:420px; }
.colhead .k{ font-size:12px; font-weight:800; letter-spacing:.14em; color:var(--accent); margin:0 0 7px; }
.colhead .t{ font-size:21px; font-weight:800; letter-spacing:-.02em; margin:0 0 8px; }
.colhead .d{ font-size:13.5px; color:var(--ink3); line-height:1.62; margin:0; }
.cap{ position:absolute; font-size:12px; font-weight:700; color:var(--ink4); letter-spacing:.02em; }

/* ---- device frame ---- */
.frame{ position:absolute; width:420px; background:var(--surface);
  border:1px solid var(--line2); border-radius:var(--r4); box-shadow:var(--shadow);
  overflow:hidden; }
.statusbar{ height:42px; display:flex; align-items:center; justify-content:space-between;
  padding:0 24px; background:var(--surface); }
.statusbar .t{ font-size:13.5px; font-weight:700; }
.statusbar .island{ width:74px; height:20px; background:var(--ink); border-radius:12px; }
.statusbar .ic{ display:flex; gap:5px; align-items:center; color:var(--ink); }
.statusbar .ic i{ width:16px; height:11px; border-radius:2px; background:var(--ink2); display:inline-block; }

/* ---- app bar ---- */
.appbar{ display:flex; align-items:center; gap:10px; padding:8px 18px 14px; border-bottom:1px solid var(--hair); }
.brand-mark{ width:30px; height:30px; border-radius:8px; flex:none; }
.brand-name{ font-size:15.5px; font-weight:800; letter-spacing:-.02em; white-space:nowrap; }
.brand-sub{ font-size:10.5px; color:var(--ink4); font-weight:600; white-space:nowrap; }
.appbar .sp{ flex:1; }
.cmp-pill{ display:flex; align-items:center; gap:6px; height:32px; padding:0 12px; border-radius:999px;
  background:var(--ink); color:#fff; font-size:12.5px; font-weight:700; white-space:nowrap; }
.cmp-pill b{ background:var(--accent); color:#fff; border-radius:999px; padding:1px 7px; font-size:11.5px; }

/* ---- section header in screen ---- */
.shead{ display:flex; align-items:baseline; justify-content:space-between; padding:16px 18px 10px; }
.shead .h{ font-size:18px; font-weight:800; letter-spacing:-.025em; }
.shead .h small{ font-size:13px; color:var(--ink4); font-weight:700; margin-left:6px; }
.shead .more{ font-size:12.5px; color:var(--ink3); font-weight:700; }
.toolbar{ display:flex; gap:7px; padding:2px 18px 12px; flex-wrap:nowrap; overflow:hidden; }
.tchip{ height:30px; padding:0 12px; border-radius:999px; border:1px solid var(--line2);
  display:flex; align-items:center; gap:5px; font-size:12.5px; font-weight:700; color:var(--ink2); white-space:nowrap; background:var(--surface); }
.tchip.on{ background:var(--ink); color:#fff; border-color:var(--ink); }

/* ---- category symbol tile ---- */
.sym{ width:46px; height:46px; border-radius:13px; background:var(--raise); color:var(--ink);
  display:flex; align-items:center; justify-content:center; font-size:21px; font-weight:700; flex:none;
  font-family:'Apple SD Gothic Neo',serif; }
.sym.sm{ width:34px; height:34px; border-radius:10px; font-size:16px; }

/* ===========================================================
   A. 스펙시트 (정렬형)
   =========================================================== */
.A .lrow{ display:grid; grid-template-columns:46px 1fr auto; gap:12px; align-items:start;
  padding:14px 18px; border-bottom:1px solid var(--hair); }
.A .lname{ font-size:var(--fz-name); font-weight:700; letter-spacing:-.02em; line-height:1.3; }
.A .lbrand{ font-size:11.5px; color:var(--ink3); font-weight:600; margin-bottom:5px; }
.A .specline{ display:flex; flex-direction:column; gap:3px; margin-top:8px; }
.A .sp-ig{ display:grid; grid-template-columns:1fr auto auto; gap:8px; align-items:baseline;
  padding:3px 0; border-top:1px dashed var(--line); }
.A .sp-ig:first-child{ border-top:none; }
.A .sp-n{ font-size:12.5px; color:var(--ink2); font-weight:600; }
.A .sp-n.f::before{ content:"●"; color:var(--accent); font-size:8px; vertical-align:middle; margin-right:5px; }
.A .sp-a{ font-size:14px; font-weight:800; text-align:right; }
.A .sp-u{ font-size:11px; color:var(--ink3); width:30px; text-align:left; font-weight:600; }
.A .fns{ display:flex; flex-wrap:wrap; gap:4px; margin-top:7px; }
.A .fchip{ font-size:11px; color:var(--ink3); font-weight:600; }
.A .fchip::after{ content:"·"; margin-left:4px; color:var(--line2); }
.A .fchip:last-child::after{ content:""; }
.A .lright{ text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:2px; min-width:84px; }
.A .pday{ font-size:15px; font-weight:800; color:var(--accent-ink); }
.A .pday small{ font-size:10.5px; color:var(--ink4); font-weight:700; }
.A .ptot{ font-size:12.5px; color:var(--ink2); font-weight:700; }
.A .pstore{ font-size:10.5px; color:var(--ink4); font-weight:600; }
.A .addbtn{ margin-top:6px; width:26px; height:26px; border-radius:8px; border:1px solid var(--line2);
  display:flex; align-items:center; justify-content:center; color:var(--ink3); font-size:15px; }

/* ===========================================================
   B. 헤드라인 + 펼치기 (층위형)
   =========================================================== */
.B .lcard{ padding:16px 18px; border-bottom:1px solid var(--hair); }
.B .ltop{ display:flex; gap:12px; align-items:flex-start; }
.B .lname{ font-size:var(--fz-name); font-weight:700; letter-spacing:-.02em; line-height:1.3; }
.B .lbrand{ font-size:11.5px; color:var(--ink3); font-weight:600; margin-bottom:6px; }
.B .head-ig{ display:flex; align-items:baseline; gap:7px; margin-top:9px; }
.B .head-ig .n{ font-size:12.5px; color:var(--ink3); font-weight:700; }
.B .head-ig .a{ font-size:20px; font-weight:800; letter-spacing:-.02em; }
.B .head-ig .u{ font-size:12px; color:var(--ink3); font-weight:700; }
.B .lright{ text-align:right; flex:none; }
.B .pday{ font-size:17px; font-weight:800; color:var(--accent-ink); }
.B .pday small{ font-size:10.5px; color:var(--ink4); font-weight:700; display:block; margin-top:1px; }
.B .ptot{ font-size:12px; color:var(--ink3); font-weight:700; margin-top:4px; }
.B .summ{ display:flex; align-items:center; gap:8px; margin-top:12px; padding-top:11px; border-top:1px solid var(--hair); }
.B .summ .txt{ font-size:12.5px; color:var(--ink3); font-weight:600; flex:1; }
.B .summ .txt b{ color:var(--ink); font-weight:800; }
.B .expand{ display:flex; align-items:center; gap:5px; font-size:12px; font-weight:800; color:var(--accent);
  background:var(--accent-weak); border:1px solid var(--accent-line); border-radius:999px; padding:5px 11px; }
.B .chev{ transition:transform .25s; }
.B .lcard.open .chev{ transform:rotate(180deg); }
.B .drawer{ overflow:hidden; max-height:0; transition:max-height .3s ease; }
.B .lcard.open .drawer{ max-height:420px; }
.B .draw-in{ padding:12px 0 2px; }
.B .drow{ display:grid; grid-template-columns:1fr auto auto; gap:10px; align-items:baseline;
  padding:8px 12px; background:var(--raise); border-radius:var(--r1); margin-bottom:6px; }
.B .drow .n{ font-size:12.5px; font-weight:700; color:var(--ink2); }
.B .drow .a{ font-size:14px; font-weight:800; text-align:right; }
.B .drow .u{ font-size:11px; color:var(--ink3); width:28px; font-weight:600; }
.B .draw-fns{ display:flex; flex-wrap:wrap; gap:5px; padding:4px 2px 2px; }
.B .draw-fns .c{ font-size:11.5px; font-weight:700; color:var(--ink2); background:var(--raise2); border-radius:7px; padding:3px 9px; }

/* ===========================================================
   C. 한눈 비교 (정규화 시각화형)
   =========================================================== */
.C .lcard{ padding:15px 18px; border-bottom:1px solid var(--hair); }
.C .ltop{ display:flex; gap:12px; align-items:flex-start; }
.C .lname{ font-size:var(--fz-name); font-weight:700; letter-spacing:-.02em; line-height:1.3; }
.C .lbrand{ font-size:11.5px; color:var(--ink3); font-weight:600; margin-bottom:4px; }
.C .lright{ text-align:right; flex:none; }
.C .pday{ font-size:16px; font-weight:800; color:var(--accent-ink); }
.C .pday small{ font-size:10px; color:var(--ink4); font-weight:700; display:block; }
.C .valbar{ height:4px; width:74px; background:var(--raise2); border-radius:2px; margin:5px 0 0 auto; overflow:hidden; }
.C .valbar i{ display:block; height:100%; background:var(--accent); border-radius:2px; }
.C .igs{ margin-top:12px; display:flex; flex-direction:column; gap:11px; }
.C .ig{ }
.C .ig-top{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:5px; }
.C .ig-n{ font-size:12.5px; font-weight:700; color:var(--ink2); }
.C .ig-n .f{ color:var(--accent); font-weight:800; }
.C .ig-v{ font-size:13px; font-weight:800; }
.C .ig-v .u{ font-size:10.5px; color:var(--ink3); font-weight:700; margin-left:2px; }
.C .bar{ position:relative; height:7px; background:var(--raise2); border-radius:4px; }
.C .bar-fill{ position:absolute; left:0; top:0; bottom:0; background:linear-gradient(90deg,var(--accent-line),var(--accent)); border-radius:4px; }
.C .bar-mark{ position:absolute; top:50%; width:11px; height:11px; border-radius:50%; background:var(--surface);
  border:2.5px solid var(--accent); transform:translate(-50%,-50%); box-shadow:0 1px 3px rgba(0,0,0,.18); }
.C .bar-ticks{ display:flex; justify-content:space-between; margin-top:3px; }
.C .bar-ticks span{ font-size:9.5px; color:var(--ink4); font-weight:600; }
.C .note{ font-size:10px; font-weight:700; color:var(--accent-ink); }
.C .fns{ display:flex; flex-wrap:wrap; gap:5px; margin-top:11px; }
.C .fns .c{ font-size:11px; font-weight:700; color:var(--ink2); background:var(--raise); border-radius:7px; padding:3px 8px; }

/* ---- detail shared ---- */
.dhero{ padding:18px; border-bottom:1px solid var(--line); }
.dhero .top{ display:flex; gap:13px; align-items:flex-start; }
.dhero .name{ font-size:21px; font-weight:800; letter-spacing:-.03em; line-height:1.25; }
.dhero .brand{ font-size:12.5px; color:var(--ink3); font-weight:700; margin-bottom:6px; }
.dhero .meta{ display:flex; gap:7px; margin-top:11px; flex-wrap:wrap; }
.dhero .mchip{ font-size:11.5px; font-weight:700; color:var(--ink2); background:var(--raise); border-radius:8px; padding:5px 10px; }
.dhero .pricerow{ display:flex; align-items:flex-end; justify-content:space-between; margin-top:15px; padding-top:14px; border-top:1px solid var(--hair); }
.dhero .pday{ font-size:24px; font-weight:800; color:var(--accent-ink); letter-spacing:-.02em; }
.dhero .pday small{ font-size:12px; color:var(--ink4); font-weight:700; }
.dhero .ptot{ font-size:14px; font-weight:700; color:var(--ink2); text-align:right; }
.dhero .ptot small{ display:block; font-size:11px; color:var(--ink4); }
.dsec{ padding:15px 18px; border-bottom:1px solid var(--hair); }
.dsec .lab{ font-size:11.5px; font-weight:800; letter-spacing:.06em; color:var(--ink4); margin-bottom:11px; }

/* ---- compare table ---- */
.ctbl{ width:100%; }
.crow{ display:grid; align-items:stretch; border-bottom:1px solid var(--hair); }
.crow .rl{ font-size:11px; font-weight:700; color:var(--ink4); padding:11px 10px; display:flex; align-items:center;
  background:var(--raise); border-right:1px solid var(--line); position:sticky; left:0; }
.ccell{ padding:11px 9px; border-right:1px solid var(--hair); font-size:12px; }
.ccell:last-child{ border-right:none; }
.ccell .nm{ font-size:12.5px; font-weight:800; letter-spacing:-.02em; line-height:1.25; }
.ccell .br{ font-size:10.5px; color:var(--ink3); font-weight:600; }
.ccell .big{ font-size:15px; font-weight:800; }
.ccell .u{ font-size:10px; color:var(--ink3); font-weight:700; }
.ccell.best{ background:var(--accent-weak); }
.ccell.best .big{ color:var(--accent-ink); }
.ccell .tag{ display:inline-block; font-size:9px; font-weight:800; color:var(--accent); }
.cbar{ position:relative; height:6px; background:var(--raise2); border-radius:3px; margin-top:5px; }
.cbar i{ position:absolute; top:50%; width:9px; height:9px; border-radius:50%; background:var(--surface); border:2px solid var(--accent); transform:translate(-50%,-50%); }
.cbar u{ position:absolute; left:0; top:0; bottom:0; border-radius:3px; background:var(--accent-line); }
