*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f3f6f4;--surface:#fff;--text:#1a2e2a;--text-muted:#5f7a73;--border:#dce8e4;--accent:#4eb88a;--accent-hover:#3da377;--accent-light:#4eb88a1a;--green:#4eb88a;--red:#dc2626;--radius:12px;--radius-sm:8px;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 12px 40px #1e3c3226;--font:"Inter", system-ui, -apple-system, sans-serif}html{font-size:15px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}#root{min-height:100vh}.login-page{background:linear-gradient(160deg,#1a2e2a 0%,#1f3f36 40%,#264d3f 100%);flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;min-height:100vh;padding:1.5rem;display:flex}.login-brand{flex-direction:column;align-items:center;gap:.6rem;display:flex}.brand-tagline{color:#a3c4b8;letter-spacing:.02em;font-size:.9rem}.brand-logo-lg{width:auto;height:48px}.login-card{background:var(--surface);border-radius:var(--radius);width:min(420px,100%);box-shadow:var(--shadow-lg);text-align:center;padding:2.5rem 2rem}.login-header{text-align:center;margin-bottom:1.75rem}.brand{color:var(--accent);justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1rem;font-weight:600;display:flex}.brand-logo{width:auto;height:32px}.brand-logo-sm{width:auto;height:24px}.login-header h1{margin-bottom:.35rem;font-size:1.5rem;font-weight:700}.login-header p{color:var(--text-muted);font-size:.9rem}.login-form{text-align:left;gap:1rem;display:grid}.field{gap:.35rem;display:grid}.field label{color:var(--text);font-size:.85rem;font-weight:500}.field input{border:1px solid var(--border);border-radius:var(--radius-sm);font:inherit;padding:.7rem .85rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.field input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4eb88a26}.field-hint{color:var(--red);font-size:.78rem}.otp-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:1.75rem;display:flex}.otp-icon{background:var(--accent-light);width:52px;height:52px;color:var(--accent);border-radius:50%;place-items:center;margin-bottom:1rem;display:grid}.otp-header h1{margin-bottom:.35rem;font-size:1.4rem;font-weight:700}.otp-header p{color:var(--text-muted);font-size:.9rem}.otp-email{color:var(--text);margin-top:.15rem;font-size:.9rem;font-weight:600}.otp-input{text-align:center;letter-spacing:.5em;font-variant-numeric:tabular-nums;padding-left:.5em;font-size:1.5rem;font-weight:600}.otp-input::placeholder{color:var(--border);letter-spacing:.5em}.otp-footer{justify-content:center;align-items:center;gap:.6rem;margin-top:.25rem;display:flex}.link-btn{appearance:none;font:inherit;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-size:.85rem;font-weight:500;transition:color .15s}.link-btn:hover:not(:disabled){color:var(--accent-hover);text-decoration:underline}.link-btn:disabled{color:var(--text-muted);cursor:not-allowed}.otp-sep{color:var(--border);font-size:.7rem}.alert{border-radius:var(--radius-sm);padding:.65rem .85rem;font-size:.85rem}.alert-info{background:var(--accent-light);color:#1a5c42;border:1px solid #4eb88a59}.alert-error{color:var(--red);background:#fef2f2;border:1px solid #fecaca}.btn-primary{appearance:none;background:var(--accent);color:#fff;font:inherit;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:.75rem;font-size:.95rem;font-weight:600;transition:background .15s,transform .1s}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.login-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.78rem}.dashboard{flex-direction:column;min-height:100vh;display:flex}.topbar{z-index:50;background:#1a2e2a;border-bottom:1px solid #2a4a40;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.topbar-brand{align-items:center;gap:.5rem;display:flex}.topbar-brand .brand-logo-sm{width:auto;height:28px}.topbar-user{align-items:center;gap:.75rem;display:flex}.avatar{background:var(--accent);color:#fff;border-radius:50%;place-items:center;width:32px;height:32px;font-size:.7rem;font-weight:700;display:grid}.user-email{color:#a3c4b8;font-size:.85rem}.btn-ghost{appearance:none;color:#a3c4b8;font:inherit;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #2a4a40;padding:.35rem .75rem;font-size:.8rem;transition:background .15s}.btn-ghost:hover{background:#2a4a40}.dashboard-main{flex:1;align-content:start;gap:1.5rem;width:100%;max-width:960px;margin:0 auto;padding:2rem;display:grid}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;padding:2.5rem 1.5rem;transition:border-color .2s,background .2s}.dropzone:hover,.dropzone-active{border-color:var(--accent);background:var(--accent-light)}.dropzone-busy{opacity:.6;pointer-events:none}.dropzone-icon{color:var(--text-muted);margin-bottom:.75rem}.dropzone-title{margin-bottom:.25rem;font-size:1rem;font-weight:600}.dropzone-hint{color:var(--text-muted);font-size:.82rem}.invoices-section{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}.invoices-header{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:1rem 1.25rem;display:flex}.invoices-header h2{font-size:1rem;font-weight:600}.badge{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:.1rem .55rem;font-size:.75rem;font-weight:600}.invoices-table-wrap{overflow-x:auto}.invoices-table{border-collapse:collapse;width:100%;font-size:.88rem}.invoices-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;background:var(--bg);padding:.6rem 1.25rem;font-size:.78rem;font-weight:500}.invoices-table td{border-top:1px solid var(--border);padding:.7rem 1.25rem}.invoices-table tbody tr:hover{background:#f8fafc}.cell-file{align-items:center;gap:.5rem;font-weight:500;display:flex}.cell-file svg{color:var(--text-muted);flex-shrink:0}.status{border-radius:999px;padding:.15rem .55rem;font-size:.75rem;font-weight:600;display:inline-block}.status-uploaded{color:#1a5c42;background:#4eb88a1f}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1.5rem}.empty-state svg{opacity:.4;margin-bottom:.75rem}.empty-state p{font-size:.9rem}.empty-sub{margin-top:.25rem;font-size:.8rem}.toast{border-radius:var(--radius-sm);box-shadow:var(--shadow-md);z-index:100;padding:.7rem 1.25rem;font-size:.88rem;font-weight:500;animation:.25s slideUp;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.toast-ok{color:#1a5c42;background:#ecfdf5;border:1px solid #a7f3d0}.toast-err{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}@media (width<=640px){.topbar{padding:.6rem 1rem}.user-email{display:none}.dashboard-main{padding:1rem}.dropzone{padding:1.5rem 1rem}.invoices-table th,.invoices-table td{padding:.5rem .75rem}}
