:root{--bg: #f5f3ea;--surface: #ffffff;--surface-alt: #efecdf;--border: #ddd8c3;--border-strong: #c7c0a4;--ink: #22261e;--ink-dim: #5c6350;--ink-faint: #8d9280;--ink-on-primary: #f5f6ee;--primary: #365c3d;--primary-dim: #24401f;--primary-soft: #e3ecde;--clay: #b4602f;--clay-soft: #f4e2d3;--gold: #a9791f;--gold-soft: #f3ecd6;--danger: #a83b32;--danger-soft: #f5e1dd;--success: #3b7a45;--success-soft: #e1eedf;--warn: #a9791f;--warn-soft: #f3ecd8;--font-display: "Fraunces", ui-serif, Georgia, serif;--font-body: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, monospace;--sidebar-w: 232px;--topbar-h: 60px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(34, 38, 30, .06), 0 1px 1px rgba(34, 38, 30, .04);--shadow-md: 0 4px 14px rgba(34, 38, 30, .08), 0 2px 6px rgba(34, 38, 30, .05);--shadow-lg: 0 12px 32px rgba(34, 38, 30, .14)}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;margin:0 0 4px;color:var(--ink)}h1{font-size:28px;letter-spacing:-.01em}h2{font-size:21px}h3{font-size:17px}p{margin:0 0 12px}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}ul{margin:0;padding:0;list-style:none}table{border-collapse:collapse;width:100%}.num,.money,td.num,td.money{font-family:var(--font-mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}.money.positive{color:var(--success)}.money.negative{color:var(--danger)}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--primary-dim);color:var(--ink-on-primary);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:40;transform:translate(0);transition:transform .22s ease}.sidebar-brand{padding:20px 20px 16px;font-family:var(--font-display);font-weight:700;font-size:20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(245,246,238,.12)}.sidebar-brand-mark{width:30px;height:30px;border-radius:8px;background:var(--gold);color:var(--primary-dim);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--font-display);flex-shrink:0}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px}.sidebar-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#f5f6ee73;padding:14px 10px 6px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#f5f6eed1;font-size:14px;font-weight:500;cursor:pointer}.sidebar-link:hover{background:#f5f6ee14;text-decoration:none}.sidebar-link.active{background:var(--gold);color:var(--primary-dim);font-weight:600}.sidebar-icon{width:18px;text-align:center;flex-shrink:0}.sidebar-footer{padding:14px 16px;border-top:1px solid rgba(245,246,238,.12);font-size:13px}.sidebar-user{font-weight:600}.sidebar-logout{margin-top:8px;background:none;border:1px solid rgba(245,246,238,.3);color:#f5f6eed9;border-radius:var(--radius-sm);padding:7px 10px;cursor:pointer;width:100%;font-size:13px}.sidebar-logout:hover{background:#f5f6ee1a}.sidebar-scrim{display:none}.app-main{flex:1;margin-left:var(--sidebar-w);min-width:0;display:flex;flex-direction:column}.topbar{display:none}.page{padding:28px 32px 60px;max-width:1180px;width:100%}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}.page-header p.subtitle{color:var(--ink-dim);margin:0;font-size:14px}.page-actions{display:flex;gap:10px;flex-wrap:wrap}@media (max-width: 900px){.sidebar{transform:translate(-100%);width:260px;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-scrim.open{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#14161073;z-index:35}.app-main{margin-left:0}.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-h);padding:0 14px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.topbar-brand{font-family:var(--font-display);font-weight:700;font-size:17px;display:flex;align-items:center;gap:8px}.hamburger{width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:center;cursor:pointer}.page{padding:18px 16px 90px}.page-header{flex-direction:column;align-items:stretch}.page-actions{width:100%}.page-actions .btn{flex:1}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14px;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--primary);background:var(--primary);color:var(--ink-on-primary);cursor:pointer;transition:background .15s,color .15s,border-color .15s,opacity .15s;white-space:nowrap}.btn:hover:not(:disabled){background:var(--primary-dim);border-color:var(--primary-dim);text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--primary);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--surface-alt);border-color:var(--primary)}.btn-ghost{background:transparent;color:var(--ink-dim);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--surface-alt);color:var(--ink)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#8a2f28;border-color:#8a2f28}.btn-sm{padding:6px 11px;font-size:13px}.btn-icon{padding:8px;width:36px;height:36px}.field{margin-bottom:16px}.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-dim);margin-bottom:6px}.field .hint{font-size:12px;color:var(--ink-faint);margin-top:4px}.field .error-text{font-size:12px;color:var(--danger);margin-top:4px}.input,select.input,textarea.input{width:100%;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--ink)}.input:focus,select.input:focus,textarea.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.input.has-error{border-color:var(--danger)}textarea.input{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.checkbox-row{display:flex;align-items:center;gap:8px}.checkbox-row input{width:16px;height:16px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card-pad{padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 18px;box-shadow:var(--shadow-sm)}.stat-label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);font-weight:600}.stat-value{font-family:var(--font-mono);font-size:26px;font-weight:500;margin-top:6px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table thead th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-faint);font-weight:600;padding:12px 16px;background:var(--surface-alt);border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:13px 16px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-alt)}.data-table td.actions{text-align:right;white-space:nowrap}.data-table td.actions .btn{margin-left:6px}@media (max-width: 760px){.table-wrap{border:none;background:transparent;box-shadow:none;overflow:visible}.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tr{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px;padding:6px 4px;box-shadow:var(--shadow-sm)}.data-table td{display:flex;justify-content:space-between;gap:12px;border-bottom:1px dashed var(--border);padding:9px 12px;text-align:right}.data-table td:last-child{border-bottom:none}.data-table td:before{content:attr(data-label);font-size:12px;font-weight:600;color:var(--ink-faint);text-align:left;text-transform:uppercase;letter-spacing:.04em}.data-table td.actions{justify-content:flex-end}.data-table td.actions:before{content:none}}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600}.badge-success{background:var(--success-soft);color:var(--success)}.badge-danger{background:var(--danger-soft);color:var(--danger)}.badge-warn{background:var(--warn-soft);color:var(--warn)}.badge-clay{background:var(--clay-soft);color:var(--clay)}.badge-neutral{background:var(--surface-alt);color:var(--ink-dim)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#14161073;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;z-index:60}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;box-shadow:var(--shadow-lg);margin:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:18px}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--ink-faint);line-height:1;padding:4px}.modal-body{padding:20px 22px;max-height:70vh;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}.alert{padding:12px 14px;border-radius:var(--radius-sm);font-size:13.5px;margin-bottom:16px}.alert-error{background:var(--danger-soft);color:var(--danger)}.alert-success{background:var(--success-soft);color:var(--success)}.empty-state{text-align:center;padding:50px 20px;color:var(--ink-dim)}.empty-state h3{color:var(--ink);margin-bottom:6px}.loading-block{display:flex;align-items:center;justify-content:center;padding:60px 0;color:var(--ink-faint)}.spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto}.tab{padding:10px 16px;font-size:14px;font-weight:600;color:var(--ink-dim);cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--primary-dim),var(--primary) 60%,#4c7a52)}.auth-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;padding:32px 28px}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px;font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--primary-dim)}.auth-brand-mark{width:34px;height:34px;border-radius:9px;background:var(--gold);color:var(--primary-dim);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--font-display)}.auth-footer-link{text-align:center;margin-top:16px;font-size:13.5px;color:var(--ink-dim)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}.gap-12{gap:12px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.text-dim{color:var(--ink-dim)}.text-faint{color:var(--ink-faint)}.text-sm{font-size:13px}.w-full{width:100%}
