/* HouseholdMoneyHQ - Reseller's Pro inspired command-center UI */
:root{
  --bg:#0b111d;
  --panel:#111827;
  --panel2:#0f172a;
  --panel3:#172033;
  --line:#22314f;
  --line2:#2d426b;
  --text:#f8fafc;
  --muted:#90a4c4;
  --dim:#5f7396;
  --blue:#3b82f6;
  --green:#10b981;
  --teal:#22d3ee;
  --orange:#f59e0b;
  --red:#f43f5e;
  --purple:#8b5cf6;
  --radius:12px;
  --shadow:0 18px 60px rgba(0,0,0,.28);
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:Inter,Arial,Helvetica,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  font-size:14px;
}
a{color:inherit;text-decoration:none}
.app-body{display:grid;grid-template-columns:260px 1fr;background:var(--bg)}
.sidebar{
  min-height:100vh;
  background:#0d1424;
  border-right:1px solid var(--line);
  position:sticky;
  top:0;
  display:flex;
  flex-direction:column;
}
.sidebar-brand{
  height:76px;
  display:flex;
  align-items:center;
  gap:12px;
  padding:16px 18px;
  border-bottom:1px solid var(--line);
}
.brand-icon{
  width:38px;height:38px;
  border-radius:9px;
  background:linear-gradient(135deg,var(--blue),#60a5fa);
  color:#07111f;
  font-weight:950;
  font-size:1.35rem;
  display:grid;
  place-items:center;
}
.sidebar-brand strong{
  display:block;
  font-size:1.05rem;
  line-height:1;
  letter-spacing:.02em;
}
.sidebar-brand span{color:var(--green)}
.sidebar-brand small{
  color:var(--muted);
  font-size:.72rem;
}
.side-section-label{
  color:#7d8eaf;
  font-size:.68rem;
  font-weight:900;
  letter-spacing:.12em;
  padding:18px 14px 8px;
}
.side-nav{display:grid;gap:5px;padding:0 10px}
.side-nav a{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  border-radius:9px;
  color:#b7c5dd;
  font-weight:750;
}
.side-nav a span{width:18px;text-align:center}
.side-nav a:hover,.side-nav a.active{
  background:#1b2942;
  color:#fff;
}
.side-nav a.active{
  box-shadow:inset 3px 0 0 var(--blue);
}
.sidebar-footer{
  margin-top:auto;
  border-top:1px solid var(--line);
  padding:12px 10px;
  display:grid;
  gap:10px;
}
.sync-pill{
  background:#142036;
  border:1px solid var(--line);
  border-radius:10px;
  color:#b7c5dd;
  padding:10px 12px;
}
.sync-pill span{
  width:9px;height:9px;background:#22c55e;border-radius:50%;
  display:inline-block;margin-right:8px;
}
.signout-btn{
  background:transparent;
  border:1px solid var(--line2);
  color:#cbd5e1;
  border-radius:10px;
  padding:10px 12px;
  cursor:pointer;
  font-weight:800;
}
.signout-btn:hover{border-color:var(--blue);color:#fff}
.app-main{padding:0;min-width:0}
.topbar{
  height:76px;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 24px;
  background:#0d1424;
}
.topbar h1{
  font-size:1.45rem;
  letter-spacing:.01em;
}
.user-pill,.live-pill{
  border:1px solid var(--line2);
  background:#111c31;
  border-radius:999px;
  padding:9px 13px;
  color:#cbd5e1;
  font-size:.86rem;
}
.live-pill span{color:#22c55e;margin-right:6px}
.content{padding:22px}
.page-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  margin-bottom:18px;
}
.page-head h2{
  font-size:1.35rem;
  letter-spacing:.01em;
}
.page-head p{
  color:var(--muted);
  margin-top:5px;
}
.period-tabs{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.period-tabs button,.action-btn{
  background:#0c1424;
  border:1px solid var(--line2);
  color:#dbeafe;
  border-radius:8px;
  padding:9px 13px;
  font-weight:850;
  cursor:pointer;
}
.period-tabs button.active,.action-btn.primary{
  background:var(--blue);
  border-color:var(--blue);
  color:white;
}
.action-row{display:flex;gap:8px;flex-wrap:wrap}
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-bottom:12px;
}
.kpi-card{
  background:var(--panel);
  border:1px solid var(--line2);
  border-top:2px solid var(--blue);
  border-radius:12px;
  padding:16px;
  min-height:96px;
  box-shadow:var(--shadow);
}
.kpi-card.green{border-top-color:var(--green)}
.kpi-card.orange{border-top-color:var(--orange)}
.kpi-card.red{border-top-color:var(--red)}
.kpi-card.purple{border-top-color:var(--purple)}
.kpi-card.teal{border-top-color:var(--teal)}
.kpi-card small{
  display:block;
  color:#7f95b8;
  text-transform:uppercase;
  font-size:.68rem;
  letter-spacing:.12em;
  font-weight:900;
}
.kpi-card strong{
  display:block;
  font-size:1.65rem;
  margin:9px 0 4px;
  line-height:1;
}
.kpi-card span{
  color:#7f95b8;
  font-size:.82rem;
}
.text-blue{color:var(--blue)}
.text-green{color:var(--green)}
.text-orange{color:var(--orange)}
.text-red{color:var(--red)}
.text-purple{color:var(--purple)}
.text-teal{color:var(--teal)}
.dashboard-grid{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:12px;
  margin-bottom:12px;
}
.panel{
  background:var(--panel);
  border:1px solid var(--line2);
  border-radius:12px;
  padding:16px;
  box-shadow:var(--shadow);
}
.panel-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:14px;
}
.panel-head h3{
  color:#bcd0ef;
  text-transform:uppercase;
  font-size:.72rem;
  letter-spacing:.13em;
}
.panel-head span{color:#8fb4e8;font-size:.82rem}
.chart-placeholder{
  height:220px;
  border-radius:8px;
  background:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:80px 44px;
  position:relative;
  overflow:hidden;
}
.chart-bars{
  position:absolute;
  inset:24px 28px 32px;
  display:flex;
  align-items:end;
  gap:14px;
}
.bar-group{display:flex;align-items:end;gap:4px;flex:1;height:100%}
.bar{width:18px;border-radius:5px 5px 2px 2px;background:var(--blue);opacity:.85}
.bar.expense{background:var(--purple)}
.donut{
  width:134px;height:134px;border-radius:50%;
  background:conic-gradient(var(--blue) 0 35%,var(--green) 35% 55%,var(--orange) 55% 72%,var(--purple) 72% 88%,var(--red) 88% 100%);
  display:grid;place-items:center;
  margin:12px auto;
}
.donut:after{
  content:"";
  width:72px;height:72px;background:var(--panel);border-radius:50%;
}
.legend{display:grid;gap:9px}
.legend-row{display:flex;justify-content:space-between;color:#cbd5e1;font-size:.86rem}
.legend-row i{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:8px}
.progress-list{display:grid;gap:12px}
.progress-row{display:grid;gap:5px}
.progress-label{display:flex;justify-content:space-between;color:#cbd5e1;font-size:.86rem}
.progress-track{height:7px;background:#1b2942;border-radius:999px;overflow:hidden}
.progress-fill{height:100%;border-radius:999px;background:var(--blue)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.form-grid .wide{grid-column:1/-1}
label{display:grid;gap:7px;color:#b7c5dd;font-size:.86rem;font-weight:700}
input,select,textarea{
  background:#0b1220;
  border:1px solid var(--line2);
  color:#fff;
  border-radius:8px;
  padding:11px 12px;
  font-family:inherit;
}
textarea{min-height:82px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:1px solid var(--blue)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:10px}
.data-table{width:100%;border-collapse:collapse;min-width:850px}
.data-table th,.data-table td{
  padding:12px 13px;
  border-bottom:1px solid var(--line);
  text-align:left;
  color:#b7c5dd;
  font-size:.86rem;
}
.data-table th{
  color:#8fa7cc;
  text-transform:uppercase;
  font-size:.68rem;
  letter-spacing:.12em;
  background:#0d1728;
}
.data-table tr:last-child td{border-bottom:0}
.table-actions{display:flex;gap:7px}
.small-btn{
  background:#0d1728;
  border:1px solid var(--line2);
  color:#dbeafe;
  border-radius:7px;
  padding:7px 9px;
  font-size:.76rem;
  cursor:pointer;
}
.small-btn.danger{color:#fecaca;border-color:rgba(244,63,94,.45)}
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.72);
  z-index:50;display:none;place-items:center;padding:20px;
}
.modal-backdrop.active{display:grid}
.modal-card{
  width:min(760px,100%);
  max-height:92vh;
  overflow:auto;
  background:var(--panel);
  border:1px solid var(--line2);
  border-radius:14px;
  box-shadow:0 30px 100px rgba(0,0,0,.65);
}
.modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px;
  border-bottom:1px solid var(--line);
}
.modal-head h3{font-size:1.05rem}
.modal-body{padding:16px}
.close-x{
  background:#0d1728;border:1px solid var(--line2);color:#fff;
  width:32px;height:32px;border-radius:8px;cursor:pointer;
}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.btn{
  border:0;border-radius:8px;padding:10px 14px;font-weight:850;cursor:pointer;
}
.btn-primary{background:var(--blue);color:white}
.btn-secondary{background:#0d1728;color:#dbeafe;border:1px solid var(--line2)}
.message{min-height:22px;margin-top:10px;color:#9db2d1}
.hustle-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:10px;
}
.hustle-tile{
  background:#0d1728;
  border:1px solid var(--line);
  border-radius:10px;
  padding:13px;
  display:flex;
  justify-content:space-between;
  gap:10px;
}
.hustle-tile strong{display:block;color:white}
.hustle-tile span{display:block;color:#8fa7cc;font-size:.8rem;margin-top:4px}
.tile-actions{display:flex;gap:6px;align-items:start}
.empty-state{
  color:#8fa7cc;
  border:1px dashed var(--line2);
  border-radius:10px;
  padding:16px;
}
.auth-message{min-height:22px;color:#9db2d1;margin-top:10px}
.landing-body{background:#0b111d;color:#fff;min-height:100vh}
.landing-header{height:72px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 5%;background:#0d1424}
.landing-hero{padding:80px 5%;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.landing-hero h1{font-size:clamp(2.5rem,5vw,4.8rem);line-height:1;letter-spacing:-.06em}
.landing-hero p{color:#b7c5dd;font-size:1.1rem;line-height:1.7;margin:18px 0}
.login-panel{background:var(--panel);border:1px solid var(--line2);border-radius:14px;padding:22px;width:min(460px,100%)}
.login-links{display:flex;justify-content:space-between;margin-top:14px;color:#93c5fd}
@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}}
@media(max-width:900px){.app-body{grid-template-columns:1fr}.sidebar{position:relative;min-height:auto}.form-grid,.landing-hero{grid-template-columns:1fr}.topbar,.page-head{flex-direction:column;align-items:flex-start;height:auto;padding:16px}.content{padding:14px}}
