:root{--primary:#6366f1;--primary-hover:#4f46e5;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--bg:#f8fafc;--card-bg:#fff;--text:#1e293b;--text-muted:#64748b;--border:#e2e8f0;--radius:8px;--shadow:0 1px 3px #00000014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.loading-page{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading,.empty{text-align:center;color:var(--text-muted);padding:2rem}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);width:100%;max-width:400px;padding:2.5rem}.auth-card.wide{max-width:560px}.auth-card h1{margin-bottom:.25rem;font-size:1.5rem}.auth-card .subtitle{color:var(--text-muted);margin-bottom:1.5rem}.auth-card .hint{color:var(--text-muted);margin-bottom:1rem;font-size:.875rem}.auth-links{text-align:center;flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.auth-links a{color:var(--primary);font-size:.875rem;text-decoration:none}.auth-links a:hover{text-decoration:underline}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.25rem;font-size:.875rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);outline:none;width:100%;padding:.5rem .75rem;font-size:.875rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:var(--primary)}.form-group input:disabled{color:var(--text-muted);background:#f1f5f9}.form-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background-color .2s,opacity .2s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{background:var(--primary);color:#fff}.btn.primary:hover:not(:disabled){background:var(--primary-hover)}.btn.secondary{background:var(--border);color:var(--text)}.btn.success{background:var(--success);color:#fff}.btn.warning{background:var(--warning);color:#fff}.btn.danger{background:var(--danger);color:#fff}.btn.small{padding:.3rem .6rem;font-size:.75rem}.btn.full{width:100%}.alert{border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.alert.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.alert.success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.alert.warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.portal-nav{background:var(--card-bg);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;display:flex}.nav-brand a{color:var(--primary);font-size:1.125rem;font-weight:700;text-decoration:none}.nav-links{gap:.5rem;display:flex}.nav-links a{border-radius:var(--radius);color:var(--text-muted);padding:.4rem .75rem;font-size:.875rem;text-decoration:none;transition:background .2s,color .2s}.nav-links a:hover{color:var(--text);background:#f1f5f9}.nav-links a.active{background:var(--primary);color:#fff}.nav-right{align-items:center;gap:.75rem;margin-left:auto;display:flex}.nav-user{color:var(--text-muted);font-size:.875rem}.main-content{max-width:1100px;margin:0 auto;padding:1.5rem}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1rem;padding:1.5rem}.card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.card-header h2{font-size:1.125rem}.portal-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.span-full{grid-column:1/-1}.welcome-card{flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:1rem;display:flex}.welcome-card h2{flex:1}.online-btn{min-width:120px}.online-status{font-size:.875rem;font-weight:500}.online-status.online{color:var(--success)}.online-status.offline{color:var(--text-muted)}.wallet-balance{margin:.5rem 0;font-size:2rem;font-weight:700}.wallet-balance .currency{color:var(--text-muted);font-size:1rem;font-weight:400}.wallet-stats{color:var(--text-muted);gap:1rem;font-size:.875rem;display:flex}.location-form{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:end;gap:1rem;display:grid}.job-actions{flex-wrap:wrap;justify-content:flex-end;gap:.4rem;display:flex}.muted-small{color:var(--text-muted);font-size:.75rem}.portal-modal-overlay{z-index:1000;background:#0f172a73;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.portal-modal{background:var(--card-bg);border-radius:var(--radius);width:min(560px,100%);max-height:calc(100vh - 2rem);padding:1.25rem;overflow:auto;box-shadow:0 24px 60px #0f172a38}.portal-modal-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.wallet-topup-summary,.receipt-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.wallet-topup-summary div,.receipt-panel{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.wallet-topup-summary span,.receipt-grid span{color:var(--text-muted);font-size:.75rem;display:block}.wallet-topup-summary strong,.receipt-grid strong{font-size:1rem;display:block}.span-two{grid-column:1/-1}.modal-actions{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.receipt-panel h4{margin-bottom:.75rem}.receipt-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:0}.finance-summary-strip{flex-wrap:wrap;justify-content:space-between;align-items:center}.money-action-buttons{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.finance-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.finance-metric,.settlement-preview div{border:1px solid var(--border);border-radius:var(--radius);background:#fff;padding:.8rem}.finance-metric span,.settlement-preview span{color:var(--text-muted);text-transform:uppercase;font-size:.75rem;display:block}.finance-metric strong,.settlement-preview strong{margin-top:.2rem;font-size:1.1rem;display:block}.finance-metric small{color:var(--text-muted);margin-top:.3rem;font-size:.78rem;display:block}.finance-metric.warning{background:#fffbeb;border-color:#fcd34d}.finance-metric.success{background:#f0fdf4;border-color:#bbf7d0}.finance-sync-status{border-radius:var(--radius);background:#f0fdf4;border:1px solid #bbf7d0;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.85rem;padding:.75rem .9rem;display:flex}.finance-sync-status.pending{background:#fffbeb;border-color:#fcd34d}.finance-sync-status strong{color:var(--text)}.finance-sync-status span{color:var(--text-muted);font-size:.85rem}.finance-block-alert{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.money-form,.finance-statement-panel{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}.form-header-row{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.settlement-preview{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.finance-statement-panel h4{margin-bottom:.75rem}.finance-history-panel{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}.history-tabs{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.history-tabs button{border:1px solid var(--border);color:var(--text);border-radius:var(--radius);cursor:pointer;background:#fff;padding:.45rem .75rem;font-weight:600}.history-tabs button.active{border-color:var(--primary);background:var(--primary);color:#fff}.small-empty{padding:.75rem 0}.stat-grid{flex-wrap:wrap;gap:1.5rem;display:flex}.stat-item{text-align:center}.stat-value{font-size:1.5rem;font-weight:700;display:block}.stat-label{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.earnings-summary{gap:2rem;margin-bottom:1.5rem;display:flex}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th,.table td{text-align:left;border-bottom:1px solid var(--border);padding:.6rem .75rem}.table th{color:var(--text-muted);text-transform:uppercase;font-size:.75rem;font-weight:600}.positive{color:var(--success);font-weight:500}.negative{color:var(--danger);font-weight:500}.tx-type{background:#f1f5f9;border-radius:4px;padding:.15rem .4rem;font-size:.75rem}.status{border-radius:999px;padding:.15rem .5rem;font-size:.75rem}.status.completed,.status.delivered,.status.active,.status.approved,.status.paid,.status.available{color:#166534;background:#dcfce7}.status.pending,.status.payout_pending{color:#854d0e;background:#fef9c3}.status.cancelled,.status.rejected{color:#991b1b;background:#fef2f2}.filters{gap:.5rem;display:flex}.filters select{border:1px solid var(--border);border-radius:var(--radius);padding:.4rem .6rem;font-size:.8rem}.documents-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.doc-card{border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.doc-type{text-transform:capitalize;margin-bottom:.25rem;font-size:.875rem;font-weight:600}.doc-name{color:var(--text-muted);word-break:break-all;margin-bottom:.5rem;font-size:.8rem}.doc-status{margin-bottom:.25rem}.doc-date{color:var(--text-muted);font-size:.75rem}.upload-btn{cursor:pointer}.profile-card{max-width:700px}.info-section{margin:1.5rem 0}.info-section h3{border-bottom:1px solid var(--border);margin-bottom:.5rem;padding-bottom:.5rem;font-size:1rem}.info-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;font-size:.875rem;display:grid}@media (width<=768px){.portal-nav{padding:.5rem 1rem}.nav-links{order:3;width:100%}.portal-grid,.form-grid,.wallet-topup-summary,.receipt-grid{grid-template-columns:1fr}.stat-grid{justify-content:center}.earnings-summary{flex-direction:column;gap:1rem}}
