*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f5f7;--surface: #ffffff;--border: #e2e4e9;--text: #1a1d23;--text-2: #5a6070;--accent: #2563eb;--accent-h: #1d4ed8;--danger: #dc2626;--warn: #d97706;--ok: #16a34a;--sidebar-w: 220px;--radius: 6px;--shadow: 0 1px 3px rgba(0,0,0,.08)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #0f1117;--surface: #1a1d23;--border: #2a2d35;--text: #e8eaf0;--text-2: #8b90a0}}:root[data-theme=dark]{--bg: #0f1117;--surface: #1a1d23;--border: #2a2d35;--text: #e8eaf0;--text-2: #8b90a0}html{font-size:15px}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font:inherit;border:none;border-radius:var(--radius);padding:.45rem 1rem;transition:opacity .15s}button:hover{opacity:.88}button:disabled{opacity:.45;cursor:default}.btn-primary{background:var(--accent);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text)}input,select,textarea{font:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:.4rem .7rem;width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}table{border-collapse:collapse;width:100%}th,td{padding:.55rem .8rem;text-align:left;border-bottom:1px solid var(--border)}th{font-weight:600;font-size:.85rem;color:var(--text-2);background:var(--bg)}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.78rem;font-weight:600}.badge-danger{background:#fef2f2;color:var(--danger)}.badge-warn{background:#fffbeb;color:var(--warn)}.badge-ok{background:#f0fdf4;color:var(--ok)}.badge-neutral{background:var(--bg);color:var(--text-2)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .badge-danger{background:#450a0a}:root:not([data-theme=light]) .badge-warn{background:#451a03}:root:not([data-theme=light]) .badge-ok{background:#052e16}:root:not([data-theme=light]) .badge-neutral{background:var(--surface)}}:root[data-theme=dark] .badge-danger{background:#450a0a}:root[data-theme=dark] .badge-warn{background:#451a03}:root[data-theme=dark] .badge-ok{background:#052e16}:root[data-theme=dark] .badge-neutral{background:var(--surface)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.page-header h1{font-size:1.3rem;font-weight:700}.form-group{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.9rem}.form-group label{font-size:.85rem;font-weight:500;color:var(--text-2)}.alert-overdue{color:var(--danger)}.alert-soon{color:var(--warn)}.alert-coming{color:#92400e}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100;padding:.75rem}.modal-overlay>.card{width:100%;max-width:520px;max-height:92vh;overflow-y:auto}@media(max-width:768px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}td,th{white-space:normal;min-width:80px}td:first-child,th:first-child{min-width:120px}}@media(max-width:640px){.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.page-header>div,.page-header>div:last-child{flex-wrap:wrap;width:100%}[style*="grid-template-columns: 1fr 1fr"],[style*="gridTemplateColumns: '1fr 1fr'"]{grid-template-columns:1fr!important}}@media(max-width:768px){.sidebar{position:fixed!important;top:0;left:0;bottom:0;z-index:200;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 16px #00000026}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block!important}.topbar{display:flex!important}.main-content{padding-top:3.5rem!important}}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:199}.topbar{display:none;position:fixed;top:0;left:0;right:0;height:3rem;background:var(--surface);border-bottom:1px solid var(--border);align-items:center;padding:0 1rem;z-index:100;gap:.75rem}.topbar-title{font-weight:700;font-size:.95rem;flex:1}
