:root{--bg:#f5f7fa;--surface:#fff;--text:#1f2937;--muted:#6b7280;--border:#e5e7eb;--primary:#1f3a5f;--primary-hover:#14253d;--danger:#b91c1c;--warning:#d97706}*{box-sizing:border-box}body,html{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-text-size-adjust:100%}body{max-width:100vw}img,table{max-width:100%}a{color:var(--primary)}button,input,select{font:inherit}.btn{display:inline-block;padding:.5rem 1rem;border-radius:6px;border:0;cursor:pointer;background:var(--primary);color:#fff;white-space:nowrap}.btn:hover{background:var(--primary-hover)}.btn.secondary{background:#6b7280}.btn.danger{background:var(--danger)}.btn:disabled{opacity:.5;cursor:not-allowed}.input,select.input{width:100%;padding:.5rem .7rem;border:1px solid var(--border);border-radius:6px;background:#fff;max-width:100%}.header{background:var(--primary);color:#fff;padding:.75rem 1rem;justify-content:space-between;gap:.5rem}.header,.header>div{display:flex;align-items:center;flex-wrap:wrap}.header>div{gap:.6rem;min-width:0}.header a{color:#fff;text-decoration:none;padding:.25rem .4rem;border-radius:4px}.header a.active{background:hsla(0,0%,100%,.18);font-weight:600}.header .user-info{opacity:.85;font-size:.9rem;max-width:100%;overflow:hidden;text-overflow:ellipsis}.container{width:100%;max-width:1400px;margin:0 auto;padding:1rem}.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--surface);border:1px solid var(--border);border-radius:8px}table.data{width:100%;border-collapse:collapse;min-width:700px}table.data td,table.data th{padding:.5rem .75rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top;font-size:.92rem}table.data th{background:#f3f4f6;font-weight:600;white-space:nowrap;position:-webkit-sticky;position:sticky;top:0;z-index:1}table.data tr.filter-row th{background:#fafafa;padding:.3rem .4rem;top:36px}.filter-input{width:100%;min-width:80px;padding:.25rem .4rem;font-size:.82rem;border:1px solid var(--border);border-radius:4px;background:#fff;font-weight:400}.filter-input::placeholder{color:#9ca3af;font-style:italic}table.data tr:hover{background:#fafbfd}table.data td.num{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap}table.data td.overdue{color:var(--danger);font-weight:600}table.data td.due-soon{color:var(--warning)}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:1rem}.muted{color:var(--muted);font-size:.9rem}.field{margin-bottom:.75rem}.field label{display:block;font-weight:500;margin-bottom:.25rem;font-size:.9rem}.row{display:flex;gap:1rem;flex-wrap:wrap}.row>*{flex:1 1 220px;min-width:0}.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:space-between;margin-bottom:1rem}.toolbar h2{margin:0;font-size:1.25rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(120deg,#1f3a5f,#14253d);padding:1rem}.login-box{background:#fff;padding:1.75rem;border-radius:10px;width:100%;max-width:360px;box-shadow:0 20px 50px rgba(0,0,0,.2)}.login-box h1{margin-top:0;color:var(--primary)}.error{color:var(--danger);padding:.5rem;background:#fee2e2;margin-bottom:.75rem}.error,.notice{border-radius:4px}.notice{padding:.75rem;background:#fef3c7;margin-bottom:1rem;color:#92400e}@media (max-width:900px){.header .user-info{display:none!important}}@media (max-width:640px){.container{padding:.75rem}.header{padding:.6rem .75rem}.header strong{font-size:1rem}.header>div{gap:.4rem}.header a{padding:.2rem .3rem;font-size:.9rem}table.data td,table.data th{padding:.4rem .5rem;font-size:.82rem}.toolbar h2{font-size:1.05rem}.btn{padding:.4rem .7rem;font-size:.88rem}}