:root{--bg:#f4f4f7;--card:#fff;--text:#111114;--muted:#6b7280;--accent:#5a2a82;--accent-600:#4a235f;--gold:#d4af37;--danger:#b00020;--radius:16px;--shadow:0 10px 30px rgba(17,17,20,.06);--btn-h:44px}*{box-sizing:border-box}#root,body,html{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:clip}.container{max-width:1200px;margin:20px auto;padding:18px}.header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.header h1{margin:0;font-size:22px;font-weight:700;color:var(--text)}.card{background:var(--card);padding:18px;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:18px}.grid{display:grid;grid-gap:16px;gap:16px}@media(min-width:1024px){.layout{display:grid;grid-template-columns:1fr 420px;grid-gap:20px;gap:20px}.left{display:grid;grid-template-rows:auto auto 1fr;grid-gap:16px;gap:16px}}.btn{min-height:56px;padding:12px 16px;border-radius:12px;border:none;background:linear-gradient(90deg,var(--accent),var(--accent-600));color:var(--bg);font-weight:700;font-size:16px;box-shadow:0 10px 24px rgba(90,42,130,.12);transition:transform .08s,box-shadow .12s,opacity .12s}.btn:hover{opacity:.98;box-shadow:0 14px 30px rgba(90,42,130,.12),0 0 0 4px rgba(212,175,55,.06)}.btn.secondary{background:var(--bg);color:var(--accent);border:1px solid rgba(90,42,130,.12);box-shadow:none}.btn.danger{background:var(--danger);color:#fff}.btn.large{min-height:60px;font-size:17px;border-radius:14px}.btn.icon{min-height:48px;width:48px;border-radius:12px}.small{font-size:13px;color:var(--muted)}.stat{display:flex;flex-direction:column}.stat .num{font-size:34px;font-weight:900;color:var(--text)}.range-controls{display:flex;gap:8px}.range-controls button{padding:10px 12px;border-radius:12px;border:1px solid transparent;background:var(--bg);min-height:44px}.range-controls button.active{border-color:var(--accent);background:#f7f2fb}.table{width:100%;border-collapse:collapse}.table td,.table th{padding:10px;border-bottom:1px solid #eef2f7;text-align:left;vertical-align:middle}.table td,.table th{font-size:14px}.table td{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table td.date{max-width:160px}.table td.note{max-width:180px}.table-wrap{overflow:auto}.mobile-cta{position:fixed;left:0;right:0;bottom:12px;display:flex;justify-content:center}.mobile-cta .btn{width:92%;border-radius:12px}.modal-backdrop{position:fixed;inset:0;background:rgba(11,18,32,.5);display:flex;align-items:center;justify-content:center}.modal-card{background:var(--card);padding:16px;border-radius:12px;min-width:320px}.notice{font-size:13px;color:var(--muted);margin-top:8px}.empty{padding:18px;text-align:center;border-radius:12px;background:linear-gradient(90deg,#fff,#fbfdff)}.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}.chart-legend{display:flex;gap:10px;align-items:center;margin-top:8px}.card h3{margin:0;font-size:18px;font-weight:700}.card h2{margin:0;font-size:20px;font-weight:800}.legend-item{font-size:13px;color:var(--muted);display:flex;gap:8px;align-items:center}.legend-swatch{width:12px;height:12px;border-radius:3px}.legend-swatch.sys{background:var(--accent)}.legend-swatch.dia{background:var(--gold)}.chart-tooltip{position:absolute;pointer-events:none;background:#fff;padding:8px;border-radius:8px;border:1px solid rgba(17,17,20,.06);box-shadow:0 8px 20px rgba(17,17,20,.08);font-size:13px;display:none}.chart-tooltip[data-show=true]{display:block}.alert{padding:12px;border-radius:10px;margin-bottom:8px}.alert.urgent{background:linear-gradient(90deg,#fff0f0,#ffecec);border-left:6px solid var(--danger);color:var(--danger)}.alert.caution{background:linear-gradient(90deg,#fffaf0,#fff6ec);border-left:6px solid var(--gold);color:var(--text)}input,select,textarea{min-height:50px;padding:12px;border-radius:12px;border:1px solid #eef2f7;background:#fff;font-size:15px;box-sizing:border-box;width:100%}label{font-size:14px}.form-grid{display:grid;grid-template-columns:1fr;grid-gap:10px;gap:10px}.form-grid .full{grid-column:1/-1}@media(min-width:520px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.form-grid{grid-template-columns:repeat(3,1fr)}.form-grid .full{grid-column:1/-1}}@media(max-width:720px){.card .btn{width:100%;display:block}.card .btn.secondary{width:100%}.top-actions>*{flex:1 1 48%}.mobile-cta .btn{min-height:56px}.card-history .table-wrap{padding:6px}.card-history td.actions,.table td{white-space:normal}.table td{font-size:14px}.table td.date,.table td.note{white-space:normal}}.card-history td.actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.btn.icon{min-height:40px;width:40px;border-radius:10px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--accent);border:1px solid rgba(90,42,130,.06)}.btn.icon:hover{background:rgba(90,42,130,.04)}.btn.icon.danger{background:var(--danger);color:#fff;border:none}.btn.icon svg{display:block}.btn:focus-visible{outline:3px solid rgba(212,175,55,.18);outline-offset:3px}.btn:hover{box-shadow:0 14px 30px rgba(90,42,130,.12),0 0 0 6px rgba(212,175,55,.08)}.btn.large:hover{box-shadow:0 18px 38px rgba(90,42,130,.14),0 0 0 8px rgba(212,175,55,.12)}.btn:active{transform:translateY(1px);box-shadow:0 6px 16px rgba(90,42,130,.1)}