:root{
  --bg:#f5f4ef; --surface:#fff; --surface-2:#faf9f5;
  --text:#2c2c2a; --text-2:#5f5e5a; --muted:#8a8980;
  --border:#e7e5dc; --border-strong:#d3d1c7;
  --accent:#185fa5; --accent-bg:#e6f1fb; --accent-border:#85b7eb;
  --warn:#854f0b; --warn-bg:#faeeda; --warn-border:#ef9f27;
  --succ:#3b6d11; --succ-bg:#eaf3de; --succ-border:#97c459;
  --danger:#a32d2d; --danger-bg:#fcebeb;
  --radius:10px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Malgun Gothic","맑은 고딕",sans-serif;
  background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:460px;margin:0 auto;padding:16px}
.wrap-wide{max-width:760px;margin:0 auto;padding:16px}

.appbar{display:flex;align-items:center;justify-content:space-between;
  background:var(--surface);border-bottom:1px solid var(--border);padding:14px 16px;position:sticky;top:0;z-index:5}
.appbar .brand{display:flex;align-items:center;gap:9px;font-weight:600;font-size:16px}
.appbar .logo{width:28px;height:28px;border-radius:8px;background:var(--accent-bg);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:16px}
.appbar .sub{font-size:13px;color:var(--text-2)}

.hero{background:#15643B;color:#fff;border-radius:12px;padding:16px;margin-bottom:14px}
.hero-brand{display:inline-block;font-size:12px;font-weight:700;color:#F0D9A8;letter-spacing:.5px;margin-bottom:2px}
.hero-title{margin:0;font-size:23px;font-weight:800;letter-spacing:-1px;color:#fff;line-height:1.15}
.hero-sub{margin:4px 0 0;font-size:13px;color:#cfe6d8;font-weight:700}

.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:14px}
.card h3{margin:0 0 12px;font-size:15px;font-weight:600}
.muted{color:var(--muted)}
.label{font-size:13px;color:var(--text-2);margin-bottom:6px;display:block}
.row{display:flex;gap:10px}
.row>*{flex:1}

input[type=text],input[type=date],select{width:100%;height:42px;padding:0 12px;font-size:15px;
  border:1px solid var(--border-strong);border-radius:var(--radius);background:var(--surface);color:var(--text);outline:none}
input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
input.locked{background:var(--surface-2);color:var(--text-2);cursor:not-allowed}
.who-result{margin-top:10px}
.who-ok{display:flex;align-items:center;gap:8px;background:var(--succ-bg);color:var(--succ);border-radius:10px;padding:11px 13px;font-size:15px;font-weight:600}
.who-none{color:var(--danger);font-size:13px;padding:2px}
.who-pick{display:flex;flex-direction:column;gap:6px}
.who-pick button{text-align:left;padding:11px 13px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);cursor:pointer;font-size:14px}
.who-pick button:hover{background:var(--surface-2)}

.seg{display:flex;gap:6px;background:var(--surface-2);border-radius:10px;padding:4px}
.seg button{flex:1;height:38px;border:none;border-radius:7px;background:transparent;font-size:14px;color:var(--text-2);cursor:pointer}
.seg button.on{background:var(--surface);color:var(--text);font-weight:600;box-shadow:0 0 0 1px var(--border)}

.banner{display:flex;align-items:center;gap:9px;border-radius:10px;padding:11px 13px;font-size:13px;margin-bottom:14px}
.banner.warn{background:var(--warn-bg);color:var(--warn)}
.banner.accent{background:var(--accent-bg);color:var(--accent)}

.opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:14px;
  border:1px solid var(--border);border-radius:12px;background:var(--surface);cursor:pointer;margin-bottom:10px;transition:.12s}
.opt:hover{border-color:var(--border-strong)}
.opt .ic{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.opt .nm{font-size:16px;font-weight:600}
.opt .ds{font-size:13px;color:var(--text-2)}
.opt .ck{margin-left:auto;font-size:20px;color:var(--muted)}
.ic.korean,.bg-korean{background:var(--accent-bg);color:var(--accent)}
.ic.chinese,.bg-chinese{background:var(--warn-bg);color:var(--warn)}
.ic.haejang,.bg-haejang{background:var(--succ-bg);color:var(--succ)}
.opt.sel.korean{border:2px solid var(--accent-border);background:var(--accent-bg)}
.opt.sel.chinese{border:2px solid var(--warn-border);background:var(--warn-bg)}
.opt.sel.haejang{border:2px solid var(--succ-border);background:var(--succ-bg)}
.opt.sel .ck{color:var(--text)}

.menu-box{margin-top:12px}
.menu-hl{display:flex;gap:8px;margin-bottom:10px}
.menu-hl>div{flex:1;border-radius:10px;padding:10px}
.menu-hl .t{font-size:11px;margin-bottom:2px}
.menu-hl .v{font-size:15px;font-weight:600}
.sides{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.side{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:7px 4px;font-size:12px;color:var(--text-2);text-align:center}

.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:13px;padding:8px 13px;border-radius:20px;background:var(--surface-2);
  border:1px solid var(--border);color:var(--text-2);cursor:pointer;user-select:none}
.chip.on{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent);font-weight:600}
.chip.add{background:transparent;border:1px dashed var(--border-strong);color:var(--muted)}

.btn{width:100%;height:50px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;
  background:var(--surface);border:1px solid var(--border-strong);color:var(--text)}
.btn-primary{background:#2c2c2a;color:#fff;border:none}
.btn-primary:disabled{background:#c9c7bf;cursor:default}
.btn-ok{background:var(--succ);color:#fff;border:none}

.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:560px){.grid4{grid-template-columns:repeat(2,1fr)}}
.metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px}
.metric .h{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;margin-bottom:8px}
.metric .badge{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px}
.metric .big{font-size:30px;font-weight:700;line-height:1.1}
.metric .unit{font-size:13px;color:var(--text-2);font-weight:400}
.bar{margin-top:10px;height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}
.bar>i{display:block;height:100%}
.bar>i.korean{background:var(--accent)} .bar>i.chinese{background:var(--warn)} .bar>i.haejang{background:var(--succ)}
.mini{font-size:11px;color:var(--muted);margin-top:5px}
.k-big{font-size:22px;font-weight:700;margin-top:3px}

.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:#2c2c2a;color:#fff;
  padding:12px 20px;border-radius:24px;font-size:14px;opacity:0;transition:.2s;pointer-events:none;z-index:20}
.toast.show{opacity:1}
.nav-links{display:flex;flex-direction:column;gap:10px}
.nav-links a{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface);
  border:1px solid var(--border);border-radius:12px;color:var(--text)}
.nav-links .ic{width:40px;height:40px;border-radius:10px;background:var(--accent-bg);color:var(--accent);
  display:flex;align-items:center;justify-content:center;font-size:20px}

/* 도장 적립 카드 */
.stamp-card{background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:12px;padding:14px;margin-bottom:14px}
.stamp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.stamp-title{font-size:13px;font-weight:600;color:var(--accent)}
.stamp-count{font-size:12px;color:var(--accent)}
.stamp-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:5px}
.stamp{height:26px;border-radius:6px;background:var(--surface);border:1px solid var(--accent-border);
  display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--muted)}
.stamp.on{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.stamp.gift{background:var(--warn-bg);border-color:var(--warn-border);color:var(--warn)}
.stamp-foot{font-size:12px;color:var(--accent);margin-top:9px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.stamp-voucher{background:var(--warn-bg);color:var(--warn);border-radius:14px;padding:2px 10px;font-weight:600}

/* 배식판 사진 */
.sbars{display:flex;align-items:flex-end;gap:12px;height:130px}
.sbar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:5px}
.sbar .b{width:100%;max-width:56px;min-height:3px;border-radius:6px 6px 0 0;background:var(--succ)}
.sbar.overtime .b{background:var(--warn)}
.sbar.night .b{background:var(--danger)}
.sbar.unset .b{background:var(--border-strong)}
.sbar .v{font-size:15px;font-weight:700}
.sbar .l{font-size:12px;color:var(--text-2);text-align:center;line-height:1.25}

.shift-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.shift-opt{display:flex;flex-direction:column;align-items:center;gap:2px;padding:11px 4px;
  border:1px solid var(--border-strong);border-radius:10px;background:var(--surface);cursor:pointer}
.shift-opt b{font-size:15px;color:var(--text);font-weight:600}
.shift-opt span{font-size:11px;color:var(--muted)}
.shift-opt.on{border:2px solid var(--succ-border);background:var(--succ-bg)}
.shift-opt.on b,.shift-opt.on span{color:var(--succ)}

.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-title{font-size:15px;font-weight:600}
.cal-nav{width:32px;height:32px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface);cursor:pointer;font-size:18px;line-height:1;color:var(--text)}
.cal-nav:hover{background:var(--surface-2)}
.cal-legend{display:flex;gap:14px;font-size:12px;color:var(--text-2);margin-bottom:10px}
.cal-legend i{margin-right:5px;vertical-align:middle}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-dow{text-align:center;font-size:11px;color:var(--muted);padding:2px 0}
.cal-dow.sun{color:#c0392b}
.cal-dow.sat{color:#2d6cdf}
.cal-cell{min-height:50px;border:1px solid var(--border);border-radius:7px;padding:3px 2px;display:flex;flex-direction:column;align-items:center;gap:2px}
.cal-cell.empty{border:none;background:transparent;min-height:0}
.cal-day{font-size:11px;color:var(--text-2)}
.cal-dots{display:flex;gap:3px;flex-wrap:wrap;justify-content:center}
.cal-dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.cal-dot.korean{background:var(--accent)}
.cal-dot.chinese{background:var(--warn)}
.cal-dot.haejang{background:var(--succ)}
.cal-sh{font-size:9px;line-height:1;padding:2px 4px;border-radius:5px;font-weight:600}
.cal-sh.regular{background:var(--succ-bg);color:var(--succ)}
.cal-sh.overtime{background:var(--warn-bg);color:var(--warn)}
.cal-sh.night{background:var(--danger-bg);color:var(--danger)}
.cal-work{margin-top:12px;padding-top:10px;border-top:1px solid var(--border);font-size:12px;color:var(--text-2)}
.cal-work b{color:var(--text);font-weight:600}
.cal-cum{float:right;color:var(--accent);font-weight:600}

.menu-photo{margin-bottom:10px}
.menu-photo img{width:100%;max-height:220px;object-fit:cover;border-radius:10px;display:block}
.photo-preview{border-radius:10px;overflow:hidden}
.photo-preview img{width:100%;max-height:260px;object-fit:cover;display:block;border-radius:10px}
.photo-preview.empty{border:1px dashed var(--border-strong);background:var(--surface-2);
  color:var(--muted);font-size:13px;text-align:center;padding:28px 16px}
