
:root{
  --bg:#0b1020;
  --panel:#101a33;
  --panel2:#0e1630;
  --text:#eaf0ff;
  --muted:#a9b6d6;
  --accent:#7c3aed;
  --accent2:#22c55e;
  --warning:#f59e0b;
  --danger:#ef4444;
  --line:rgba(255,255,255,.08);
  --radius:18px;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial;
  background: radial-gradient(1200px 600px at 20% 10%, rgba(124,58,237,.18), transparent 60%),
              radial-gradient(1200px 600px at 80% 30%, rgba(34,197,94,.12), transparent 55%),
              var(--bg);
  color:var(--text);
}

a{color:inherit;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:24px}

.btn{
  border:0; cursor:pointer; padding:12px 16px; border-radius:14px;
  background:rgba(255,255,255,.08); color:var(--text);
}
.btn.primary{background:linear-gradient(135deg, var(--accent), #4f46e5)}
.btn.green{background:linear-gradient(135deg, var(--accent2), #16a34a)}
.btn.outline{background:transparent;border:1px solid var(--line)}
.btn.small{padding:9px 12px;border-radius:12px;font-size:14px}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow: 0 12px 30px rgba(0,0,0,.35);
}

.input, select, textarea{
  width:100%;
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  color:var(--text);
  padding:12px 12px;
  border-radius:14px;
  outline:none;
}
label{font-size:13px;color:var(--muted)}
.row{display:grid;gap:14px}
.grid2{grid-template-columns:1fr 1fr}
.grid3{grid-template-columns:1fr 1fr 1fr}
.grid4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){ .grid4{grid-template-columns:1fr 1fr} }
@media(max-width:650px){ .grid2,.grid3,.grid4{grid-template-columns:1fr} }

.topbar{
  display:flex; justify-content:space-between; align-items:center;
  padding:16px 20px; border-bottom:1px solid var(--line);
}
.brand{font-weight:800;letter-spacing:.4px}
.badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border:1px solid var(--line);
  background:rgba(255,255,255,.05);
  border-radius:999px;color:var(--muted);font-size:13px;
}
.badge #meName{display:inline-block;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(max-width:650px){ .badge #meName{max-width:120px;} }

.app{
  display:grid;
  grid-template-columns:260px 1fr;
  min-height:100vh;
}
.sidebar{
  padding:18px; border-right:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent);
}
.nav a{
  display:flex; gap:10px; align-items:center;
  padding:12px 12px; border-radius:14px;
  color:var(--muted);
}
.nav a.active, .nav a:hover{
  background:rgba(124,58,237,.14);
  color:var(--text);
}
.main{padding:18px}
.kpis{display:grid;gap:14px}
.kpi{padding:16px}
.kpi h4{margin:0;color:var(--muted);font-weight:600;font-size:13px}
.kpi .v{font-size:22px;font-weight:800;margin-top:6px}

.table{
  width:100%; border-collapse:separate; border-spacing:0 10px;
}
.table th{font-size:12px;color:var(--muted);text-align:left;padding:0 10px}
.table td{
  padding:12px 10px; background:rgba(255,255,255,.05);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.table tr td:first-child{border-left:1px solid var(--line); border-radius:14px 0 0 14px}
.table tr td:last-child{border-right:1px solid var(--line); border-radius:0 14px 14px 0}

.pill{
  font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.04);
}
.pill.green{border-color:rgba(34,197,94,.35); background:rgba(34,197,94,.12)}
.pill.red{border-color:rgba(239,68,68,.35); background:rgba(239,68,68,.12)}
.pill.open{border-color:rgba(245,158,11,.35); background:rgba(245,158,11,.12)}

.tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-size:12px;
}

.hero{
  padding:64px 24px;
  text-align:center;
}
.hero h1{
  font-size:52px; margin:0 0 10px; line-height:1.05;
}
.hero p{color:var(--muted);max-width:780px;margin:14px auto 0}
.pricing{display:grid;gap:16px;grid-template-columns:1fr 1fr; margin-top:22px}
@media(max-width:780px){.pricing{grid-template-columns:1fr}}
.plan{padding:18px;text-align:left}
.plan h3{margin:0 0 8px}
.plan .price{font-size:34px;font-weight:900}
.plan ul{margin:14px 0 0;padding-left:18px;color:var(--muted)}


/* Auth pages (login/register) */
.auth-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.auth-card{
  width:min(520px, 100%);
  padding:18px;
}

/* Make hero section look centered on large screens and not too tall */
.hero{
  padding:56px 24px;
}
@media (min-width: 1200px){
  .hero{padding:72px 24px;}
}

/* Prevent horizontal scroll on small screens */
html, body { overflow-x:hidden; }


/* Sidebar sections */
.side-section{margin-top:14px}
.side-title{
  font-size:12px;
  color:var(--muted);
  letter-spacing:.12em;
  text-transform:uppercase;
  margin:10px 8px;
}
.nav .sub a{
  padding:10px 12px 10px 34px;
  font-size:14px;
}
.nav .sub{margin-top:4px}
.nav a .dot{
  width:8px;height:8px;border-radius:999px;background:rgba(255,255,255,.25);
  display:inline-block;
}
.nav a.active .dot, .nav a:hover .dot{background:rgba(124,58,237,.9)}
.canvas-wrap{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:10px;
}


/* ===== Mobile sidebar drawer ===== */
.mobile-topbar{
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:12px 12px;
  margin:-6px -6px 10px;
}
.iconbtn{
  width:42px;height:42px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:var(--text);
  font-size:18px;
}
.mobile-title{font-weight:800;letter-spacing:.2px}
.sidebar-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,.55);
  opacity:0; pointer-events:none;
  transition:.15s ease;
  z-index:40;
}
body.sidebar-open .sidebar-overlay{opacity:1; pointer-events:auto;}

@media (max-width: 1024px){
  .app{grid-template-columns:1fr;}
  .sidebar{
    position:fixed; left:0; top:0; bottom:0;
    width:min(320px, 86vw);
    transform:translateX(-105%);
    transition:transform .18s ease;
    z-index:50;
    border-right:1px solid var(--line);
    backdrop-filter: blur(10px);
  }
  body.sidebar-open .sidebar{transform:translateX(0);}
  .main{padding:12px;}
  .mobile-topbar{display:flex;}
}

/* ===== Better form layout ===== */
.field{display:flex; flex-direction:column; gap:6px;}
.field label{font-size:12px; color:var(--muted);}
.input, select.input, textarea.input{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(0,0,0,.12);
  color:var(--text);
  outline:none;
}
.input:focus{border-color: rgba(124,58,237,.55); box-shadow:0 0 0 3px rgba(124,58,237,.18);}
.row{display:grid; gap:12px;}
.grid2{grid-template-columns:1fr 1fr;}
.grid3{grid-template-columns:repeat(3,1fr);}
@media(max-width:650px){ .grid2,.grid3{grid-template-columns:1fr;} }

.tabs{
  display:flex; gap:10px; flex-wrap:wrap;
  padding:10px; border:1px solid var(--line);
  border-radius:16px; background:rgba(255,255,255,.03);
}
.tabbtn{
  padding:10px 12px; border-radius:14px;
  border:1px solid transparent;
  background:rgba(255,255,255,.06);
  color:var(--text); cursor:pointer;
}
.tabbtn.active{background:rgba(124,58,237,.16); border-color:rgba(124,58,237,.35);}
.hidden{display:none !important;}
/* sportsbook cards */
.sb-search{display:flex; gap:10px; flex-wrap:wrap; align-items:center;}
.sb-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:12px;
}
.sb-head{display:flex; justify-content:space-between; gap:10px; align-items:center; flex-wrap:wrap;}
.sb-grid{display:grid; gap:10px; grid-template-columns:repeat(3,1fr);}
@media(max-width:920px){ .sb-grid{grid-template-columns:repeat(2,1fr);} }
@media(max-width:650px){ .sb-grid{grid-template-columns:1fr;} }
.sb-pill{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid var(--line);color:var(--muted);}
.sb-domain{font-weight:700;}
.sb-group{position:relative; overflow:hidden;}
.sb-group summary{list-style:none;}
.sb-group summary::-webkit-details-marker{display:none;}
.sb-group summary{padding-right:4px;}
.sb-group::before{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:4px;
  border-radius:16px 0 0 16px;
  background:rgba(124,58,237,.85);
}
.sb-group-tag{font-weight:700; letter-spacing:.02em;}
.sb-group-count{color:var(--muted);font-size:13px}
.sb-group-action{min-width:64px; text-align:center; text-transform:uppercase; letter-spacing:.04em;}
.sb-group--solo::before{background:linear-gradient(180deg, rgba(16,185,129,.95), rgba(5,150,105,.85));}
.sb-group--solo .sb-group-tag{background:rgba(16,185,129,.14); border-color:rgba(16,185,129,.28); color:#d1fae5;}
.sb-group--violet::before{background:linear-gradient(180deg, rgba(124,58,237,.95), rgba(91,33,182,.85));}
.sb-group--violet .sb-group-tag{background:rgba(124,58,237,.14); border-color:rgba(124,58,237,.28); color:#ede9fe;}
.sb-group--cyan::before{background:linear-gradient(180deg, rgba(6,182,212,.95), rgba(8,145,178,.85));}
.sb-group--cyan .sb-group-tag{background:rgba(6,182,212,.14); border-color:rgba(6,182,212,.28); color:#cffafe;}
.sb-group--amber::before{background:linear-gradient(180deg, rgba(245,158,11,.95), rgba(217,119,6,.85));}
.sb-group--amber .sb-group-tag{background:rgba(245,158,11,.14); border-color:rgba(245,158,11,.28); color:#fef3c7;}
.sb-group--pink::before{background:linear-gradient(180deg, rgba(236,72,153,.95), rgba(190,24,93,.85));}
.sb-group--pink .sb-group-tag{background:rgba(236,72,153,.14); border-color:rgba(236,72,153,.28); color:#fce7f3;}
.sb-group--other::before{background:linear-gradient(180deg, rgba(148,163,184,.95), rgba(100,116,139,.85));}
.sb-group--other .sb-group-tag{background:rgba(148,163,184,.14); border-color:rgba(148,163,184,.28); color:#e2e8f0;}

/* ===== Dashboard chart ===== */
.chart-card{padding:16px;margin-top:14px}
.chart-wrap{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  border-radius:16px;
  padding:10px;
}
.chart-caption{margin:10px 0 0;color:var(--muted);font-size:13px}

/* ===== Pretty cashout toggle (prejuízos) ===== */
.segmented{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.segmented input{position:absolute;opacity:0;pointer-events:none}
.segbtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:var(--text);
  cursor:pointer;
  user-select:none;
  min-width:92px;
}
.segmented input:checked + .segbtn{
  background:rgba(124,58,237,.18);
  border-color:rgba(124,58,237,.45);
}
.loss-preview{
  padding:10px 12px;
  border-radius:14px;
  border:1px dashed rgba(255,255,255,.16);
  background:rgba(0,0,0,.10);
  color:rgba(255,255,255,.85);
}

.billing-grid{
  display:grid;
  grid-template-columns:minmax(220px,300px) 1fr;
  gap:18px;
}
@media(max-width:820px){
  .billing-grid{grid-template-columns:1fr;}
}


/* ===== Toast / flash ===== */
.toast{
  position:fixed;
  z-index:9999;
  padding:12px 16px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(12px);
  box-shadow:0 18px 40px rgba(0,0,0,.35);
  color:#fff;
  max-width:min(420px, calc(100vw - 24px));
  transition:opacity .18s ease, transform .18s ease;
}
.toast-default{
  background:rgba(9,12,24,.86);
}
.toast-success{
  background:linear-gradient(135deg, rgba(34,197,94,.95), rgba(22,163,74,.92));
}
.toast-error{
  background:linear-gradient(135deg, rgba(239,68,68,.95), rgba(220,38,38,.92));
}
.toast-bottom-center{
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
}
.toast-top-right{
  top:18px;
  right:18px;
}

/* ===== Auth polish ===== */
.auth-card{
  padding:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
}
.auth-card h2{font-size:28px;}

/* ===== Entries search / section polish ===== */
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.section-kicker{
  display:inline-flex;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(124,58,237,.30);
  background:rgba(124,58,237,.14);
  color:#d8c8ff;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.house-picker{position:relative;}
.house-suggestions{
  display:none;
  margin-top:10px;
  padding:10px;
  border-radius:16px;
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(13,18,38,.98), rgba(12,18,34,.94));
  box-shadow:0 18px 34px rgba(0,0,0,.34);
  max-height:290px;
  overflow:auto;
}
.house-suggestions.show{display:grid;gap:8px;}
.house-option{
  width:100%;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  text-align:left;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:var(--text);
  cursor:pointer;
}
.house-option:hover{
  border-color:rgba(124,58,237,.38);
  background:rgba(124,58,237,.14);
}
.house-option small{color:var(--muted);font-size:12px;}
.field-help,
.muted-inline{
  color:var(--muted);
  font-size:12px;
}
.muted-inline{display:inline-flex;align-items:center;}

/* ===== Dashboard month controls ===== */
.chart-topbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  flex-wrap:wrap;
}
.chart-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}
.month-input{
  width:170px;
  min-height:44px;
}
.chart-days{
  display:flex;
  gap:8px;
  overflow:auto;
  padding:12px 2px 0;
  margin-top:6px;
}
.chart-day{
  min-width:42px;
  text-align:center;
  padding:8px 0;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.04);
  color:var(--muted);
  font-size:12px;
}
.chart-day.pos{
  border-color:rgba(34,197,94,.25);
  color:#c7f9d6;
}
.chart-day.neg{
  border-color:rgba(239,68,68,.25);
  color:#ffd0d0;
}
.chart-day.today{
  background:rgba(124,58,237,.18);
  border-color:rgba(124,58,237,.45);
  color:#f5f0ff;
}
@media(max-width:720px){
  .chart-actions{width:100%;}
  .month-input{width:100%;}
  .toast-top-right{left:12px;right:12px;top:12px;}
}


/* ===== Casas (.bet.br) ===== */
.sb-filters{align-items:stretch}
.sb-filter-card{
  padding:12px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.sb-filter-card label{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#c8d4f4;
}
.sb-select,
select.sb-select,
#sbGroup,
#sbStats,
#sbCashout{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background-image:linear-gradient(45deg, transparent 50%, #b9c7ea 50%), linear-gradient(135deg, #b9c7ea 50%, transparent 50%);
  background-position:calc(100% - 18px) calc(50% - 3px), calc(100% - 12px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
  padding-right:34px;
}
#sbGroup option,
#sbStats option,
#sbCashout option{
  background:#0f1831;
  color:#eaf0ff;
}
#sbGroup:focus,
#sbStats:focus,
#sbCashout:focus,
#sbQ:focus{
  border-color:rgba(124,58,237,.55);
  box-shadow:0 0 0 3px rgba(124,58,237,.16);
}
.sb-group--forest::before{background:linear-gradient(180deg, rgba(34,197,94,.95), rgba(21,128,61,.85));}
.sb-group--forest .sb-group-tag{background:rgba(34,197,94,.14); border-color:rgba(34,197,94,.28); color:#dcfce7;}
.sb-group[open] .sb-group-action{background:rgba(124,58,237,.16); color:#f5f3ff; border-color:rgba(124,58,237,.28);}

/* ===== Mobile polish only (preserve desktop) ===== */
.mobile-brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}
.mobile-brand img{
  width:42px;
  height:42px;
  border-radius:12px;
  object-fit:cover;
  box-shadow:0 8px 22px rgba(0,0,0,.28);
}
.mobile-brand .mobile-title{
  font-weight:900;
  letter-spacing:.02em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

@media (max-width: 1024px){
  body{
    background:
      radial-gradient(900px 420px at 10% 0%, rgba(124,58,237,.2), transparent 60%),
      radial-gradient(900px 420px at 100% 16%, rgba(34,197,94,.12), transparent 55%),
      var(--bg);
  }
  .mobile-topbar{
    position:sticky;
    top:0;
    z-index:25;
    margin:0 0 12px;
    padding:10px 12px;
    border:1px solid var(--line);
    border-radius:18px;
    background:rgba(10,16,32,.86);
    backdrop-filter:blur(12px);
    box-shadow:0 12px 26px rgba(0,0,0,.25);
  }
  .sidebar{
    padding:16px 14px 20px;
    background:linear-gradient(180deg, rgba(17,26,51,.98), rgba(10,16,32,.97));
    box-shadow:18px 0 40px rgba(0,0,0,.32);
  }
  .side-title{margin:14px 8px 8px}
  .nav a{
    padding:13px 12px;
    border:1px solid transparent;
    background:rgba(255,255,255,.025);
    margin-bottom:8px;
  }
  .nav a.active, .nav a:hover{
    border-color:rgba(124,58,237,.22);
    box-shadow:0 10px 24px rgba(124,58,237,.12);
  }
  .main{padding:12px 12px 18px;}
  .card{border-radius:16px;}
  .topbar{
    flex-direction:column;
    align-items:flex-start !important;
    gap:12px;
  }
  .topbar > div:last-child{width:100%;}
  .topbar > div:last-child .btn{width:100%; justify-content:center;}
  .topbar > div:last-child[style*='display:flex']{
    display:grid !important;
    grid-template-columns:1fr 1fr;
    width:100%;
  }
  .chart-topbar{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
  }
  .chart-actions{
    width:100%;
    display:grid;
    grid-template-columns:1fr;
  }
  .month-input{min-width:0;width:100%;}
  .chart-wrap canvas{height:260px !important;}
  .chart-days{
    gap:6px;
    overflow:auto hidden;
    padding-bottom:4px;
    scrollbar-width:none;
  }
  .chart-days::-webkit-scrollbar{display:none;}
  .chart-day{
    min-width:34px;
    padding:8px 0;
    border-radius:12px;
    font-size:12px;
  }
  .kpi .v{font-size:20px;}
  .table{min-width:880px;}
  .house-picker{position:relative;}
  .house-suggestions{
    position:static !important;
    margin-top:8px;
    max-height:240px;
    border-radius:16px;
    background:rgba(12,18,34,.96);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:0 14px 30px rgba(0,0,0,.22);
  }
  .house-suggestions .house-option,
  .house-suggestions button,
  .house-suggestions div{
    min-height:46px;
  }
  .sb-filters{
    grid-template-columns:1fr !important;
  }
  .sb-filter-card{
    padding:12px;
    border:1px solid var(--line);
    border-radius:16px;
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.03));
  }
  .sb-select,
  .sb-filter-card .input,
  .sb-filter-card select{
    background:rgba(9,14,28,.95) !important;
    color:var(--text) !important;
    border-color:rgba(255,255,255,.1);
  }
  .sb-select option,
  select option{
    background:#101a33;
    color:#eaf0ff;
  }
  #sbGroups{
    display:grid;
    gap:12px;
  }
  #sbGroups .card,
  .sportsbook-group,
  .group-card{
    border-radius:18px;
  }
  .auth-page{padding:16px; align-items:flex-start;}
  .auth-card{
    margin-top:14px;
    padding:16px;
    border-radius:18px;
  }
  .hero{
    padding:26px 12px 34px;
  }
  .hero h1{
    font-size:34px;
    line-height:1.08;
  }
  .hero p{font-size:15px;}
  .pricing{grid-template-columns:1fr;}
}

@media (max-width: 640px){
  .container{padding:14px;}
  .topbar.card{
    padding:14px;
    border-radius:18px;
  }
  .topbar.card > div:last-child{
    width:100%;
    display:grid !important;
    grid-template-columns:1fr;
  }
  .topbar.card .badge{
    width:100%;
    justify-content:center;
    text-align:center;
  }
  .btn{padding:12px 14px;}
  .section-head{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }
  .muted-inline{display:block; width:100%;}
}


/* ===== Real mobile fix ===== */
.app, .main, .card, .chart-wrap, .canvas-wrap { min-width: 0; }
img, canvas { max-width: 100%; }

@media (max-width: 768px){
  html, body { width:100%; overflow-x:hidden; }
  .app{ display:block; width:100%; }
  .main{ width:100%; min-width:0; padding:10px 10px 18px; }
  .sidebar{ width:min(340px, 92vw); }
  .mobile-topbar{ display:flex; }
  .mobile-brand img{ width:40px; height:40px; border-radius:10px; }
  .mobile-brand .mobile-title{ font-size:15px; }
  .kpis{ grid-template-columns:1fr !important; }
  .kpi{ padding:14px; }
  .kpi .v{ font-size:18px; }
  .card{ width:100%; }
  .section-head h3, .topbar h2, .topbar h3 { word-break:break-word; }
  .topbar{ gap:10px; }
  .topbar > div, .topbar > form { width:100%; min-width:0; }
  .topbar .btn, .chart-actions .btn, .billing-grid .btn{ width:100%; }
  .chart-wrap{ padding:8px; overflow:hidden; }
  #monthChart{ height:240px !important; }
  .chart-wrap canvas{ height:240px !important; display:block; }
  .chart-day{ min-width:32px; font-size:11px; }
  .house-picker, .field, .row, .grid2, .grid3, .grid4, .pricing, .billing-grid, .sb-grid, .sb-filters{ width:100%; }
  .field{ min-width:0; }
  textarea.input{ min-height:96px; }
  .billing-grid{ grid-template-columns:1fr !important; gap:12px; }
  .billing-grid .card{ min-width:0 !important; }
  .sb-head{ align-items:flex-start; }
  .sb-head > div:last-child, .sb-head > a, .sb-head > button{ width:100%; }
  .sb-group-action{ min-width:0; }

  .table{
    width:100%;
    min-width:0 !important;
    border-spacing:0;
    display:block;
  }
  .table thead{ display:none; }
  .table tbody, .table tr{ display:block; width:100%; }
  .table tr{
    margin:0 0 12px;
    border:1px solid var(--line);
    border-radius:16px;
    background:rgba(255,255,255,.04);
    overflow:hidden;
  }
  .table td{
    display:block;
    width:100%;
    position:relative;
    padding:10px 10px 10px 44%;
    min-height:40px;
    text-align:right;
    background:transparent;
    border:0;
    border-top:1px solid rgba(255,255,255,.06);
    word-break:break-word;
  }
  .table tr td:first-child,
  .table tr td:last-child{
    border-radius:0;
    border-left:0;
    border-right:0;
  }
  .table tr td:first-child{ border-top:0; }
  .table td::before{
    content:attr(data-label);
    position:absolute;
    left:10px;
    top:50%;
    transform:translateY(-50%);
    width:38%;
    text-align:left;
    color:var(--muted);
    font-size:12px;
    font-weight:700;
    letter-spacing:.01em;
  }
  .table td[style*="white-space:nowrap"]{ white-space:normal !important; }
  .table td .btn{ width:auto; min-width:72px; }
}

@media (max-width: 480px){
  .container{ padding:12px; }
  .main{ padding:8px 8px 16px; }
  .mobile-topbar{ padding:10px; border-radius:16px; }
  .iconbtn{ width:40px; height:40px; border-radius:12px; }
  .hero{ padding:22px 10px 28px; }
  .hero h1{ font-size:28px; }
  .auth-page{ padding:12px; }
  .auth-card{ padding:14px; }
  .toast{ max-width:calc(100vw - 16px); }
  .table td{ padding-left:42%; }
  .table td::before{ width:36%; font-size:11px; }
}
