@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap');

:root,[data-theme="light"]{
  --bg:#f8fafc;--bg2:#fff;--bg3:#f1f5f9;--tx:#1e293b;--tx2:#64748b;--tx3:#94a3b8;
  --brd:#e2e8f0;--brd2:#f1f5f9;
  --acc:#e67e22;--acc2:#d35400;--accL:#fef3e2;
  --red:#dc2626;--redL:#fee2e2;--grn:#10b981;--grnL:#d1fae5;
  --wrn:#f59e0b;--wrnL:#fef3c7;--blue:#3b82f6;--blueL:#dbeafe;
  --s1:0 1px 3px rgba(30,41,59,.06);--s2:0 4px 12px rgba(30,41,59,.08);--s3:0 10px 30px rgba(30,41,59,.12);
  --nav:#ffffff;--navT:#1e293b;--navBorder:#e2e8f0;--navHover:rgba(30,41,59,.06);--card:#fff;--inp:#fff;--inpB:#cbd5e1;
  --r:12px;--rs:8px;--fr:0 0 0 3px rgba(230,126,34,.2);
}
[data-theme="dark"]{
  --bg:#0f1117;--bg2:#181a23;--bg3:#1f2231;--tx:#e2e8f0;--tx2:#94a3b8;--tx3:#64748b;
  --brd:#2a2d3a;--brd2:#1f2231;
  --acc:#e67e22;--acc2:#f0923e;--accL:#3d2a14;
  --red:#ef4444;--redL:#3f1212;--grn:#10b981;--grnL:#0a2e1f;
  --wrn:#f59e0b;--wrnL:#3d2e00;--blue:#60a5fa;--blueL:#1e3a5f;
  --s1:0 1px 3px rgba(0,0,0,.3);--s2:0 4px 12px rgba(0,0,0,.4);--s3:0 10px 30px rgba(0,0,0,.5);
  --nav:#0a0c12;--navT:#94a3b8;--navBorder:rgba(255,255,255,.12);--navHover:rgba(255,255,255,.08);--card:#181a23;--inp:#1f2231;--inpB:#333749;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--tx);line-height:1.6;min-height:100vh}
h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6,.nav-brand{font-family:'Outfit',sans-serif;font-weight:700}
a{color:var(--acc);text-decoration:none}a:hover{color:var(--acc2)}
hr{border:none;border-top:1px solid var(--brd);margin:1.25rem 0}

@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.anim{animation:slideUp .35s ease both}
.d1{animation-delay:.05s}.d2{animation-delay:.1s}.d3{animation-delay:.15s}.d4{animation-delay:.2s}.d5{animation-delay:.25s}

/* ── Navbar ── */
.navbar{background:var(--nav);padding:0 1.5rem;position:sticky;top:0;z-index:300;box-shadow:var(--s2);border-bottom:1px solid var(--navBorder)}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;height:62px;gap:1.5rem}
.nav-brand{font-size:1.15rem;font-weight:800;color:#fff;display:flex;align-items:center;gap:.5rem;white-space:nowrap}
.nav-brand i{color:var(--acc)}
.nav-brand span{color:var(--acc)}
.nav-links{display:flex;gap:.2rem;flex:1}
.nav-link{color:var(--navT);padding:.42rem .8rem;border-radius:var(--rs);font-size:.84rem;font-weight:500;display:flex;align-items:center;gap:.35rem;transition:all .2s;white-space:nowrap}
.nav-link:hover{background:var(--navHover);color:var(--tx)}
.nav-link.active{background:var(--acc);color:#fff}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:.5rem}
.nav-user{color:var(--navT);font-size:.82rem;display:flex;align-items:center;gap:.4rem}
.nav-btn{background:none;border:1px solid var(--navBorder);color:var(--navT);padding:.38rem .8rem;border-radius:var(--rs);cursor:pointer;font-size:.82rem;font-family:inherit;display:flex;align-items:center;gap:.3rem;transition:.2s}
.nav-btn:hover{background:var(--navHover);color:var(--tx)}

/* ── Layout ── */
.wrap{max-width:1200px;margin:0 auto;padding:1.75rem 1.25rem 3rem}
.wrap-sm{max-width:780px;margin:0 auto;padding:1.75rem 1.25rem 3rem}
.wrap-xs{max-width:480px;margin:0 auto;padding:2rem 1.25rem}

/* ── Page header ── */
.page-hdr{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.page-hdr h1{font-size:1.35rem;font-weight:800;display:flex;align-items:center;gap:.45rem}
.page-hdr h1 i{color:var(--acc)}
.breadcrumb{font-size:.8rem;color:var(--tx3);margin-bottom:.35rem}
.breadcrumb a{color:var(--tx3)}
.breadcrumb a:hover{color:var(--acc)}

/* ── Cards ── */
.card{background:var(--card);border:1px solid var(--brd);border-radius:var(--r);box-shadow:var(--s1)}
.card-body{padding:1.5rem}
.card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.card-header h3{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:.4rem}
.card-header h3 i{color:var(--acc)}

/* ── Stat cards ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--card);border:1px solid var(--brd);border-radius:var(--r);padding:1.1rem 1.3rem;box-shadow:var(--s1);transition:transform .2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--s2)}
.stat-card i{font-size:1.1rem;color:var(--acc);margin-bottom:.4rem;display:block}
.stat-value{font-size:1.9rem;font-weight:900;line-height:1;color:var(--tx)}
.stat-value.green{color:var(--grn)}.stat-value.red{color:var(--red)}.stat-value.orange{color:var(--acc)}
.stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:var(--tx3);margin-top:.25rem}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.52rem 1rem;border:1px solid transparent;border-radius:var(--rs);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit;min-height:40px;line-height:1.4;white-space:nowrap}
.btn:focus-visible{outline:none;box-shadow:var(--fr)}
.btn-primary{background:var(--acc);color:#fff}.btn-primary:hover{background:var(--acc2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(230,126,34,.3)}
.btn-secondary{background:var(--bg3);color:var(--tx);border-color:var(--brd)}.btn-secondary:hover{background:var(--brd)}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}
.btn-success{background:var(--grn);color:#fff}.btn-success:hover{background:#059669}
.btn-ghost{background:none;border:none;color:var(--tx2);padding:.3rem .5rem;cursor:pointer;font-size:.88rem;font-family:inherit;display:inline-flex;align-items:center;gap:.3rem;transition:.15s}.btn-ghost:hover{color:var(--acc)}
.btn-sm{padding:.32rem .7rem;font-size:.8rem;min-height:34px}
.btn-lg{padding:.7rem 1.5rem;font-size:1rem;min-height:48px}
.btn-block{width:100%;justify-content:center}

/* ── Forms ── */
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:.82rem;font-weight:600;color:var(--tx2);margin-bottom:.3rem}
.form-control{width:100%;padding:.58rem .85rem;border:1px solid var(--inpB);border-radius:var(--rs);background:var(--inp);color:var(--tx);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;min-height:42px}
.form-control:focus{outline:none;border-color:var(--acc);box-shadow:var(--fr)}
/* Chrome autofill override — forces our background/text colour instead of the blue tint */
.form-control:-webkit-autofill,
.form-control:-webkit-autofill:hover,
.form-control:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 1000px var(--inp) inset;
  -webkit-text-fill-color:var(--tx);
  caret-color:var(--tx);
  border-color:var(--inpB);
  transition:background-color 9999s ease-in-out 0s;
}
select.form-control{cursor:pointer}
textarea.form-control{resize:vertical;min-height:90px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
.form-actions{display:flex;gap:.6rem;margin-top:1.4rem;flex-wrap:wrap}
.help{font-size:.76rem;color:var(--tx3);margin-top:.2rem}
.input-group{display:flex}
.input-group .prefix{background:var(--bg3);border:1px solid var(--inpB);border-right:none;padding:.58rem .8rem;border-radius:var(--rs) 0 0 var(--rs);color:var(--tx3);font-size:.9rem;display:flex;align-items:center;min-height:42px}
.input-group .form-control{border-radius:0 var(--rs) var(--rs) 0}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;padding:.15rem .6rem;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.badge-paid{background:var(--grnL);color:var(--grn)}
.badge-sent{background:var(--blueL);color:var(--blue)}
.badge-overdue{background:var(--redL);color:var(--red)}
.badge-draft{background:var(--bg3);color:var(--tx3)}
.badge-cancelled{background:var(--bg3);color:var(--tx3)}
.badge-active{background:var(--grnL);color:var(--grn)}
.badge-orange{background:var(--accL);color:var(--acc)}

/* ── Table ── */
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--brd)}
table.tbl{width:100%;border-collapse:collapse}
table.tbl thead th{background:var(--bg3);color:var(--tx2);padding:.75rem 1rem;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;border-bottom:1px solid var(--brd);text-align:left}
table.tbl tbody td{padding:.8rem 1rem;border-bottom:1px solid var(--brd2);font-size:.9rem;vertical-align:middle}
table.tbl tbody tr:last-child td{border-bottom:none}
table.tbl tbody tr:hover td{background:var(--bg3)}
table.tbl .td-amount{font-weight:700;font-size:.95rem}
table.tbl .td-actions{white-space:nowrap;text-align:right}

/* ── Alert ── */
.alert{padding:.7rem 1rem;border-radius:var(--rs);font-size:.88rem;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.alert-danger{background:var(--redL);color:var(--red);border:1px solid var(--red)}
.alert-success{background:var(--grnL);color:var(--grn);border:1px solid var(--grn)}
.alert-info{background:var(--blueL);color:var(--blue);border:1px solid var(--blue)}
.alert-warning{background:var(--wrnL);color:var(--wrn);border:1px solid var(--wrn)}

/* ── Login ── */
.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b 0%,#0f172a 60%,#1a1523 100%);padding:1rem;flex-direction:column;gap:1.5rem}
.login-card{background:var(--card);border-radius:var(--r);box-shadow:var(--s3);padding:2.2rem;width:100%;max-width:420px}
.login-footer{text-align:center;color:var(--tx3);font-size:.8rem}
.login-logo{text-align:center;margin-bottom:1.75rem}
.login-logo .logo-icon{font-size:2.2rem;color:var(--acc);margin-bottom:.5rem}
.login-logo h1{font-size:1.5rem;font-weight:800}
.login-logo p{color:var(--tx3);font-size:.85rem;margin-top:.2rem}
.login-tabs{display:flex;gap:0;background:var(--bg3);border-radius:var(--rs);padding:3px;margin-bottom:1.5rem}
.login-tab{flex:1;padding:.45rem;text-align:center;border-radius:7px;font-size:.85rem;font-weight:600;cursor:pointer;transition:.2s;color:var(--tx2);border:none;background:none;font-family:inherit}
.login-tab.active{background:var(--card);color:var(--tx);box-shadow:var(--s1)}

/* ── Section divider ── */
.section-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--tx3);margin-bottom:.65rem;display:flex;align-items:center;gap:.4rem}
.section-label::after{content:'';flex:1;border-top:1px solid var(--brd)}

/* ── Invoice detail ── */
.invoice-detail-header{background:linear-gradient(135deg,var(--nav),#1a2035);color:#fff;border-radius:var(--r);padding:1.75rem;margin-bottom:1.25rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.invoice-number-display{font-size:1.5rem;font-weight:900;color:#fff}
.invoice-amount-display{font-size:2.5rem;font-weight:900;color:var(--acc);text-align:right}
.line-item-row{display:flex;gap:1rem;margin-bottom:.75rem;align-items:flex-end}
.line-item-row .form-group{margin:0}

/* ── Customer avatar ── */
.cust-avatar{width:38px;height:38px;border-radius:50%;background:var(--accL);color:var(--acc);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;flex-shrink:0}

/* ── Empty state ── */
.empty{text-align:center;padding:3rem 1rem;color:var(--tx3)}
.empty i{font-size:2.5rem;opacity:.3;color:var(--acc);display:block;margin-bottom:.8rem}
.empty h3{color:var(--tx2);margin-bottom:.3rem}

/* ── Signature ── */
.rl-sig{color:transparent;font-size:0;user-select:none;pointer-events:none;position:absolute}

@media(max-width:640px){
  .form-row,.form-row-3{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .wrap,.wrap-sm{padding:1.2rem .85rem 3rem}
}
