:root{--bg: #f4f6f9;--card: #ffffff;--text: #1a1a1a;--muted: #5b6470;--line: #d9dee6;--primary: #1565c0;--primary-dark: #0d47a1;--green: #2e7d32;--red: #c62828;--orange: #e65100;--blue: #1565c0;--tabbar-h: 76px}@media (prefers-color-scheme: dark){:root{--bg: #14181f;--card: #1f262f;--text: #f1f3f6;--muted: #9aa4b2;--line: #333c47;--primary: #4f9bf0;--primary-dark: #2f7fe0;--green: #66bb6a;--red: #ef5350;--orange: #ffa726;--blue: #64b5f6}}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,Apple SD Gothic Neo,Malgun Gothic,Noto Sans KR,sans-serif;background:var(--bg);color:var(--text);font-size:18px;line-height:1.5}.app{max-width:480px;margin:0 auto;min-height:100%;background:var(--bg);position:relative;padding-bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom))}.header{position:sticky;top:0;z-index:10;background:var(--primary);color:#fff;padding:16px 18px;padding-top:calc(16px + env(safe-area-inset-top));display:flex;align-items:center;justify-content:space-between}.header h1{font-size:22px;margin:0;font-weight:800}.header .sub{font-size:14px;opacity:.9}.content{padding:16px}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:14px}.card h2{font-size:19px;margin:0 0 12px}.row{display:flex;align-items:center;justify-content:space-between;gap:10px}.muted{color:var(--muted);font-size:15px}.big-num{font-size:26px;font-weight:800}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:54px;padding:0 20px;width:100%;font-size:19px;font-weight:700;border-radius:14px;border:none;cursor:pointer;background:var(--primary);color:#fff}.btn:active{transform:scale(.98)}.btn.secondary{background:var(--card);color:var(--primary);border:2px solid var(--primary)}.btn.danger{background:var(--red)}.btn.ghost{background:transparent;color:var(--muted);border:2px solid var(--line);min-height:46px;font-size:17px}.btn.onhead{width:auto;min-height:40px;font-size:15px;font-weight:800;padding:0 13px;background:#ffffff2e;color:#fff;border:1.5px solid rgba(255,255,255,.85)}.btn.small{width:auto;min-height:44px;font-size:16px;padding:0 16px}label{display:block;font-size:16px;color:var(--muted);margin:12px 0 6px;font-weight:600}input,select,textarea{width:100%;min-height:54px;padding:12px 14px;font-size:19px;font-family:inherit;font-weight:400;border:2px solid var(--line);border-radius:12px;background:var(--card);color:var(--text)}input[type=date],input[type=date]::-webkit-datetime-edit{font-family:inherit}textarea{min-height:120px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}.badge{display:inline-block;font-size:13px;font-weight:700;padding:3px 10px;border-radius:999px}.badge.green{background:#2e7d3226;color:var(--green)}.badge.red{background:#c6282826;color:var(--red)}.badge.orange{background:#e6510026;color:var(--orange)}.badge.blue{background:#1565c026;color:var(--blue)}.badge.gray{background:var(--line);color:var(--muted)}.badge.violet{background:#8e44ad2e;color:#8e44ad}.banner{border-radius:14px;padding:14px 16px;margin-bottom:14px;font-weight:700}.banner.today{background:var(--orange);color:#fff}.banner.info{background:#1565c01f;color:var(--blue)}.list-item{padding:14px 0;border-bottom:1px solid var(--line)}.list-item:last-child{border-bottom:none}.progress{height:16px;background:var(--line);border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;background:var(--green);border-radius:999px}.home-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:10px}.home-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--card);border:2px solid var(--line);border-radius:20px;padding:30px 10px;min-height:140px;cursor:pointer;font-size:21px;font-weight:800;color:var(--text)}.home-tile .ico{font-size:46px;line-height:1}.home-tile:active{transform:scale(.97);border-color:var(--primary);background:#1565c00f}.homebar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;z-index:20;background:var(--card);border-top:1px solid var(--line);padding:12px 16px calc(12px + env(safe-area-inset-bottom))}.homebar .btn{min-height:52px;font-size:18px}.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:calc(var(--tabbar-h) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:var(--card);border-top:1px solid var(--line);display:flex;z-index:20}.tabbar button{flex:1;background:none;border:none;cursor:pointer;color:var(--muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:13px;font-weight:700}.tabbar button .ico{font-size:24px}.tabbar button.active{color:var(--primary)}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:30;display:flex;align-items:flex-end}.modal{background:var(--card);width:100%;max-width:480px;margin:0 auto;border-radius:20px 20px 0 0;padding:20px;max-height:90vh;overflow-y:auto}.modal h2{margin-top:0}.login-wrap{display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:24px;max-width:480px;margin:0 auto}.login-logo{text-align:center;margin-bottom:28px}.login-logo img{width:96px;height:96px}.login-logo h1{font-size:26px;margin:14px 0 4px}.error-text{color:var(--red);font-weight:700;margin-top:10px}.chk{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:var(--text);cursor:pointer}.chk input{width:24px;height:24px}.zonetabs{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;-webkit-overflow-scrolling:touch}.zonetab{flex:0 0 auto;padding:9px 16px;border-radius:999px;border:2px solid var(--line);background:var(--card);color:var(--muted);font-weight:700;font-size:15px;cursor:pointer;white-space:nowrap}.zonetab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.zonetabs.sub{padding-top:0}.zonetabs.sub .zonetab{padding:6px 14px;font-size:14px}.center{text-align:center}.spacer{height:8px}.empty{text-align:center;color:var(--muted);padding:40px 0}
