@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap');

/* === RESET & VARIABLES === */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0a1214;
  --card:#111d22;
  --card-hover:#152028;
  --brd:#1a2e35;
  --acc:#00b894;
  --acc2:#00d9a6;
  --ok:#00b894;
  --no:#ef4444;
  --warn:#f59e0b;
  --txt:#f1f5f9;
  --mut:#a0b4bf;
  --dim:#8899a4;
  --purple:#a5b4fc;
  --radius:12px;
  --shadow:0 2px 12px rgba(0,0,0,.3);
}
[data-theme="light"]{--bg:#f5f7fa;--card:#fff;--card-hover:#f0f2f5;--brd:#e2e8f0;--txt:#1a202c;--mut:#64748b;--dim:#94a3b8;--shadow:0 2px 12px rgba(0,0,0,.08);}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--bg);
  color:var(--txt);
  min-height:100vh;
  -webkit-tap-highlight-color:transparent;
}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
a{color:var(--acc);text-decoration:none}
a:hover{color:var(--acc2)}

/* === LAYOUT === */
#app{display:flex;min-height:100vh}

/* Sidebar */
.sb{
  width:220px;
  background:var(--card);
  border-right:1px solid var(--brd);
  padding:20px 12px;
  flex-shrink:0;
  display:flex;
  flex-direction:column;
  position:fixed;
  top:0;bottom:0;left:0;
  z-index:100;
  overflow-y:auto;
}
.sb-logo{padding:10px;margin-bottom:20px;text-align:center}
.sb-logo img{width:140px;height:auto}
.sb-section{margin-bottom:16px}
.sb-section-title{
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:2px;
  color:var(--dim);
  padding:0 12px;
  margin-bottom:6px;
}
.sb-btn{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  border:none;border-radius:10px;
  background:transparent;
  color:var(--mut);
  font-size:13px;font-weight:500;
  text-align:left;width:100%;
  margin-bottom:2px;
  transition:all .15s ease;
}
.sb-btn:hover{background:rgba(0,184,148,.08);color:var(--txt)}
.sb-btn.active{background:rgba(0,184,148,.15);color:var(--acc);font-weight:600}
.sb-btn .icon{font-size:16px;width:22px;text-align:center}
.sb-bottom{
  margin-top:auto;
  padding:12px;
  border-top:1px solid var(--brd);
}
.sb-user{font-size:11px;color:var(--dim);margin-bottom:8px;word-break:break-all}
.sb-logout{
  display:flex;align-items:center;gap:6px;
  padding:8px 10px;
  border:none;border-radius:8px;
  background:rgba(239,68,68,.08);
  color:var(--no);
  font-size:12px;font-weight:500;
  width:100%;
  transition:background .15s;
}
.sb-logout:hover{background:rgba(239,68,68,.15)}

/* Main content */
.main{
  flex:1;
  margin-left:220px;
  overflow-y:auto;
  max-height:100vh;
  padding:28px 32px;
}
.main-inner{max-width:1100px}

/* === COMPONENTS === */

/* Cards */
.card{
  background:var(--card);
  border:1px solid var(--brd);
  border-radius:var(--radius);
  padding:20px;
  margin-bottom:12px;
  transition:border-color .15s;
}
.card:hover{border-color:rgba(0,184,148,.2)}
.card-flat{box-shadow:none}

/* Buttons */
.btn{
  border:none;
  border-radius:8px;
  padding:9px 18px;
  font-size:13px;
  font-weight:600;
  transition:all .15s;
}
.btn-primary{background:var(--acc);color:#fff}
.btn-primary:hover{background:var(--acc2);box-shadow:0 2px 12px rgba(0,184,148,.25)}
.btn-secondary{background:var(--brd);color:var(--txt)}
.btn-secondary:hover{background:rgba(0,184,148,.1)}
.btn-danger{background:var(--no);color:#fff}
.btn-danger:hover{background:#dc2626}
.btn-ghost{background:transparent;color:var(--mut);padding:6px 10px}
.btn-ghost:hover{color:var(--txt)}
.btn-sm{padding:5px 12px;font-size:11px}

/* Inputs */
.input{
  background:var(--bg);
  border:1px solid var(--brd);
  border-radius:8px;
  padding:9px 14px;
  color:var(--txt);
  font-size:13px;
  outline:none;
  width:100%;
  transition:border-color .15s;
}
.input:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(0,184,148,.1)}
.label{
  font-size:12px;
  color:var(--mut);
  font-weight:500;
  display:block;
  margin-bottom:5px;
}

/* Badge */
.badge{
  font-size:11px;
  font-weight:600;
  padding:3px 10px;
  border-radius:20px;
  display:inline-block;
}
.badge-green{background:rgba(0,184,148,.12);color:var(--ok)}
.badge-red{background:rgba(239,68,68,.12);color:var(--no)}
.badge-yellow{background:rgba(245,158,11,.12);color:var(--warn)}
.badge-purple{background:rgba(129,140,248,.12);color:var(--purple)}

/* Table */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--brd);background:var(--card)}
.table-head{
  padding:10px 16px;
  background:var(--bg);
  font-size:10px;
  font-weight:600;
  color:var(--dim);
  text-transform:uppercase;
  letter-spacing:1px;
  display:grid;
}
.table-row{
  padding:10px 16px;
  border-top:1px solid var(--brd);
  font-size:12px;
  display:grid;
  align-items:center;
  transition:background .1s;
}
.table-row:hover{background:rgba(0,184,148,.02)}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}
.kpi{padding:18px;border-left:3px solid var(--acc)}
.kpi-label{font-size:11px;color:var(--mut);margin-bottom:6px}
.kpi-value{font-family:'DM Mono',monospace;font-size:24px;font-weight:700}

/* Modal — Apple-style */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:center;
  z-index:1000;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
.modal-overlay.open{
  opacity:1;
  pointer-events:auto;
}
.modal-box{
  background:var(--card);
  border:1px solid var(--brd);
  border-radius:20px;
  padding:28px;
  min-width:400px;
  max-width:520px;
  max-height:80vh;
  overflow:auto;
  box-shadow:0 24px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06) inset;
  transform:scale(.92) translateY(12px);
  opacity:0;
  transition:transform .35s cubic-bezier(.2,.9,.3,1), opacity .3s ease;
}
.modal-overlay.open .modal-box{
  transform:scale(1) translateY(0);
  opacity:1;
}

/* Page header */
.page-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:24px;
}
.page-title{font-size:24px;font-weight:700}
.page-subtitle{color:var(--mut);font-size:13px;margin-top:4px}

/* Mono */
.mono{font-family:'DM Mono',monospace}

/* Delete button */
.del-btn{
  background:none;border:none;
  color:var(--dim);cursor:pointer;
  font-size:14px;padding:2px;
  transition:color .15s;
}
.del-btn:hover{color:var(--no)}

/* Grid helpers */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.accounts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px;margin-bottom:16px}
.account-card{transition:border-color .2s,transform .15s}
.account-card:hover{border-color:rgba(0,184,148,.3);transform:translateY(-1px)}
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}
.cat-item{background:var(--bg);border:1px solid var(--brd);border-radius:8px;padding:8px 12px;transition:border-color .15s}
.cat-item:hover{border-color:rgba(0,184,148,.2)}
.sortable{cursor:pointer;user-select:none}
.sortable:hover{color:var(--acc)}
.cost-tab{flex:1;padding:14px;border:none;background:transparent;color:var(--mut);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border-bottom:2px solid transparent}
.cost-tab:hover{color:var(--txt);background:rgba(0,184,148,.04)}
.cost-tab.active{color:var(--acc);border-bottom-color:var(--acc);font-weight:600}
.loans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px;margin-bottom:16px}
.loan-card{transition:border-color .2s}
.loan-card:hover{border-color:rgba(0,184,148,.3)}
.loan-card.selected{border-color:var(--acc)}
.inv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px;margin-bottom:8px}
.inv-card{transition:border-color .2s}
.inv-card:hover{border-color:rgba(0,184,148,.3)}
.inv-card.selected{border-color:var(--acc)}
.ai-typing{display:flex;gap:4px;padding:4px 0}
.ai-typing span{width:6px;height:6px;background:var(--dim);border-radius:50%;animation:aiDot 1.2s infinite}
.ai-typing span:nth-child(2){animation-delay:.2s}
.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes aiDot{0%,60%,100%{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1.1)}}
.ai-response strong{color:var(--acc)}
.kpi.clickable{cursor:pointer;transition:border-color .2s,transform .15s}
.kpi.clickable:hover{border-color:rgba(0,184,148,.4);transform:translateY(-2px)}
.company-filter{display:flex;gap:4px;margin-bottom:16px;padding:4px;background:var(--card);border:1px solid var(--brd);border-radius:10px;overflow-x:auto}
.cf-btn{padding:8px 16px;border:none;background:transparent;color:var(--mut);font-size:12px;font-weight:500;border-radius:8px;cursor:pointer;white-space:nowrap;transition:all .15s}
.cf-btn:hover{background:rgba(0,184,148,.08);color:var(--txt)}
.cf-btn.active{background:var(--acc);color:#fff;font-weight:600}
.badge-company{font-size:9px;padding:2px 6px;border-radius:4px;font-weight:600;letter-spacing:.5px}
.badge-gev{background:rgba(0,184,148,.15);color:#00b894}
.badge-resilia{background:rgba(108,92,231,.15);color:#6c5ce7}
.badge-doesa{background:rgba(253,203,110,.2);color:#d4a017}
.badge-reddoak{background:rgba(225,112,85,.15);color:#e17055}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.flex-gap{display:flex;gap:8px;align-items:center}
.flex-wrap{flex-wrap:wrap}
.text-right{text-align:right}
.text-center{text-align:center}
.mb-sm{margin-bottom:8px}
.mb-md{margin-bottom:16px}
.mb-lg{margin-bottom:24px}

/* Loading */
.loading{
  display:flex;align-items:center;justify-content:center;
  min-height:60vh;
  flex-direction:column;gap:16px;
}
.spinner{
  width:36px;height:36px;
  border:3px solid var(--brd);
  border-top-color:var(--acc);
  border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pinShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-8px)}40%,80%{transform:translateX(8px)}}

/* Login */
.login-wrap{
  width:100%;min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg);
}
.login-box{
  background:var(--card);
  border:1px solid var(--brd);
  border-radius:20px;
  padding:48px;
  width:420px;
  text-align:center;
  box-shadow:var(--shadow);
}
.login-box img{width:180px;margin-bottom:24px}
.login-title{font-size:20px;font-weight:700;margin-bottom:8px}
.login-sub{font-size:13px;color:var(--mut);margin-bottom:28px}
.login-error{color:var(--no);font-size:12px;margin-top:16px}
.login-separator{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--dim);font-size:12px}
.login-separator::before,.login-separator::after{content:'';flex:1;height:1px;background:var(--brd)}
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;height:46px;padding:10px 24px;
  font-size:14px;font-weight:500;font-family:inherit;
  color:var(--txt);background:rgba(255,255,255,.04);
  border:1px solid var(--brd);border-radius:12px;
  cursor:pointer;transition:all .2s;
}
.btn-google:hover{background:rgba(255,255,255,.08);border-color:var(--acc);transform:translateY(-1px)}
.btn-google:active{transform:scale(.97)}
.btn-google:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-google svg{flex-shrink:0}

/* Toast */
.toast{
  position:fixed;bottom:24px;right:24px;
  background:var(--card);
  border:1px solid var(--brd);
  border-radius:12px;
  padding:14px 20px;
  font-size:13px;
  box-shadow:0 8px 30px rgba(0,0,0,.4);
  z-index:2000;
  transform:translateY(80px);
  opacity:0;
  transition:all .3s ease;
}
.toast.show{transform:translateY(0);opacity:1}
.toast-ok{border-left:3px solid var(--ok)}
.toast-err{border-left:3px solid var(--no)}

/* Hamburger */
.hamburger{
  display:none;
  position:fixed;top:12px;left:12px;z-index:1001;
  background:var(--card);border:1px solid var(--brd);
  border-radius:10px;padding:8px 12px;
  font-size:20px;color:var(--acc);
  cursor:pointer;line-height:1;
}
.sb-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:99;
}
.sb-overlay.open{display:block}

/* === MOBILE === */
@media(max-width:768px){
  .hamburger{display:block}
  .sb{
    left:-260px;width:250px;
    transition:left .25s ease;
    box-shadow:4px 0 20px rgba(0,0,0,.5);
  }
  .sb.open{left:0}
  .main{margin-left:0;padding:60px 14px 24px}
  .card{padding:14px}
  .table-head,.table-row{min-width:500px;font-size:10px}
  .modal-box{min-width:90vw;max-width:95vw;padding:20px}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .kpi-value{font-size:18px}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .accounts-grid{grid-template-columns:1fr}
  .loans-grid{grid-template-columns:1fr}
  .inv-grid{grid-template-columns:1fr}
  .page-header{flex-direction:column;align-items:flex-start;gap:12px}
  .login-box{width:90vw;padding:32px 24px}
  h1,.page-title{font-size:20px!important}
}
@media(max-width:480px){
  .main{padding:56px 10px 20px}
  .kpi-grid{grid-template-columns:1fr}
}

/* Range preset chips */
.range-preset{
  padding:7px 14px;font-size:12px;font-weight:500;
  border-radius:20px;border:1px solid var(--brd);
  background:transparent;color:var(--dim);cursor:pointer;
  transition:all .15s;white-space:nowrap;
}
.range-preset:hover{background:rgba(0,184,148,.08);color:var(--txt);border-color:var(--acc)}
.rp-active{background:rgba(0,184,148,.15)!important;color:var(--acc)!important;border-color:var(--acc)!important;font-weight:600}

/* === SERVICES & PLANS === */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
.service-card{
  background:var(--card);
  border:1px solid var(--brd);
  border-radius:var(--radius);
  padding:18px;
  border-left:3px solid var(--acc);
  transition:border-color .2s,transform .15s;
}
.service-card:hover{border-color:rgba(0,184,148,.4);transform:translateY(-2px)}
.service-card-warning{border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.03)}
.service-card-warning:hover{border-color:rgba(239,68,68,.5)}
.service-alert{font-size:10px;font-weight:600;color:var(--no);background:rgba(239,68,68,.08);border-radius:6px;padding:4px 8px;margin-bottom:10px}
.service-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.service-card-actions{display:flex;gap:4px}
.service-card-actions .del-btn{font-size:12px;opacity:.5;transition:opacity .15s}
.service-card-actions .del-btn:hover{opacity:1}
.service-icon{font-size:28px}
.service-card h4{font-size:14px;font-weight:600;margin-bottom:12px}
.service-progress{
  background:var(--bg);
  border-radius:4px;
  height:8px;
  overflow:hidden;
  margin-bottom:10px;
  cursor:pointer;
}
.service-progress-fill{
  height:100%;
  border-radius:4px;
  transition:width .4s ease;
}
.service-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:11px;
  color:var(--dim);
  margin-bottom:12px;
  cursor:pointer;
  border-radius:6px;
  padding:2px 4px;
  margin-left:-4px;margin-right:-4px;
  transition:background .15s;
}
.service-meta:hover{background:rgba(255,255,255,.04)}
.service-meta .mono{font-weight:600;color:var(--txt);font-size:12px}
.btn-manage{
  padding:5px 14px;
  font-size:11px;
  font-weight:600;
  border-radius:6px;
  border:1px solid var(--brd);
  background:transparent;
  color:var(--mut);
  transition:all .15s;
}
.btn-manage:hover{border-color:var(--acc);color:var(--acc);background:rgba(0,184,148,.06)}
.btn-upgrade{
  padding:5px 14px;
  font-size:11px;
  font-weight:600;
  border-radius:6px;
  border:1px solid rgba(165,180,252,.3);
  background:rgba(165,180,252,.08);
  color:var(--purple);
  transition:all .15s;
}
.btn-upgrade:hover{border-color:var(--purple);background:rgba(165,180,252,.18)}
.service-updated{font-size:9px;color:var(--dim);margin-bottom:10px}
@media(max-width:768px){
  .services-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .services-grid{grid-template-columns:1fr}
}
