/* erp.css — 크라우니 스쿨 ERP (모바일 우선, 큰 탭) */
body.erp #app{max-width:560px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:0}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.topbar b{font-size:19px}
.muted{color:var(--sub);font-size:14px}
.setupLink{font-size:22px;text-decoration:none}
main#view{flex:1;padding:16px 16px 90px;overflow:auto}
.tabbar{position:fixed;bottom:0;left:0;right:0;max-width:560px;margin:0 auto;display:flex;background:var(--card);border-top:1px solid var(--line)}
.tab{flex:1;border:none;background:none;padding:10px 0 8px;font-size:22px;display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--sub);cursor:pointer}
.tab span{font-size:12px;font-weight:700}
.tab.on{color:var(--accent)}
/* 카드 그리드 */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;text-align:center}
.stat .num{font-size:34px;font-weight:800;color:var(--accent)}
.stat .lab{color:var(--sub);font-size:14px;margin-top:4px}
.stat.warn .num{color:var(--danger)}
.stat.ok .num{color:var(--ok)}
.sect{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:16px;margin-bottom:14px}
.sect h3{margin:0 0 12px;font-size:17px}
.hi{font-size:15px;color:var(--sub);margin:2px 0 14px}
/* 리스트 행 */
.row-item{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:14px;margin-bottom:8px;background:var(--card)}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--line);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover}
.row-item .info{flex:1;min-width:0}
.row-item .nm{font-weight:700}
.row-item .sub2{font-size:13px;color:var(--sub)}
/* 출석 원탭 버튼 */
.att-btns{display:flex;gap:6px}
.att{padding:8px 10px;border-radius:12px;border:2px solid var(--line);background:var(--bg);font-size:14px;font-weight:700;cursor:pointer}
.att.on1{background:#e3f3ea;border-color:var(--ok);color:var(--ok)}
.att.on2{background:#fdf3e0;border-color:var(--accent2);color:var(--accent)}
.att.on3{background:#fae3e3;border-color:var(--danger);color:var(--danger)}
.att.on4{background:#eee7f5;border-color:#8a6bb5;color:#6f4ea5}
/* 토글(수납) */
.toggle{padding:10px 16px;border-radius:20px;border:2px solid var(--line);background:var(--bg);font-weight:700;cursor:pointer;font-size:14px}
.toggle.paid{background:var(--ok);color:#fff;border-color:var(--ok)}
.toggle.unpaid{background:var(--card);color:var(--danger);border-color:#f0d8d8}
.fab{position:fixed;bottom:84px;right:calc(50% - 280px + 18px);width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;font-size:30px;border:none;box-shadow:0 4px 16px rgba(58,110,165,.4);cursor:pointer;z-index:6}
@media(max-width:600px){.fab{right:18px}}
.banner{background:var(--card);border:1px solid var(--accent2);border-radius:16px;padding:14px 16px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center;gap:10px}
.banner a{color:var(--accent);font-weight:800;text-decoration:none;white-space:nowrap}
.notice-item{padding:12px;border:1px solid var(--line);border-radius:14px;margin-bottom:8px;background:var(--card)}
.notice-item .nt{font-weight:700}
.notice-item .nb{font-size:14px;color:var(--sub);margin-top:4px;white-space:pre-wrap}
.notice-item .nd{font-size:12px;color:var(--sub);margin-top:6px}
.empty{text-align:center;color:var(--sub);padding:40px 10px}
.date-nav{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px}
.date-nav button{border:none;background:var(--card);border:1px solid var(--line);border-radius:10px;width:40px;height:40px;font-size:18px;cursor:pointer}
.date-nav .d{font-weight:800;font-size:17px}
input,textarea,select{font-family:inherit}
textarea{width:100%;padding:14px;border:2px solid var(--line);border-radius:14px;font-size:17px;background:var(--bg);min-height:90px}
.field{margin-bottom:10px}
.field label{display:block;font-size:14px;color:var(--sub);margin-bottom:4px;font-weight:700}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:flex-end;justify-content:center;z-index:20}
.modal .sheet{background:var(--card);border-radius:22px 22px 0 0;padding:22px 20px 30px;width:100%;max-width:560px;max-height:88vh;overflow:auto}
