
/* ── CURSOR OVERRIDE ────────────────────────────────────────── */
/* Applying wait cursor to body alone doesn't override button/a cursor:pointer.
   The * selector with !important forces it on every element site-wide. */
body.cursor-wait,
body.cursor-wait * { cursor: wait !important; }

/* ── RESET ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;margin:0;padding:0;font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;font-size:14px;color:#1e2a3b;background:#f1f4f8}
#app{min-height:100vh;display:flex;flex-direction:column}

/* ── BRAND PALETTE (from logo) ──────────────────────────────── */
:root{
  --navy:#1a3466;
  --navy2:#22448a;
  --blue:#2d6bc4;
  --blue-lt:#e8f0fc;
  --red:#c0392b;
  --red-lt:#fdf0ef;
  --red-mid:#e74c3c;
  --gold:#f59e0b;
  --gold-lt:#fffbeb;
  --green:#16a34a;
  --green-lt:#f0fdf4;
  --gray-50:#f8fafc;
  --gray-100:#f1f4f8;
  --gray-200:#e2e8f0;
  --gray-300:#cbd5e1;
  --gray-400:#94a3b8;
  --gray-500:#64748b;
  --gray-700:#374151;
  --gray-900:#0f172a;
  --white:#ffffff;
  --sidebar:230px;
  --topbar:56px;
  --r:6px;--r2:10px;--r3:16px;
  --shadow-xs:0 1px 2px rgba(0,0,0,.06);
  --shadow-sm:0 1px 4px rgba(0,0,0,.09);
  --shadow:0 4px 12px rgba(0,0,0,.10);
  --shadow-lg:0 8px 28px rgba(0,0,0,.13);
}

/* ── LAYOUT ─────────────────────────────────────────────────── */
.shell{display:flex;min-height:100vh}
.sidebar{
  width:230px;min-height:100vh;
  background:linear-gradient(160deg,#0d1f3c 0%,#1a3466 60%,#1e3d7a 100%);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:200;
  box-shadow:3px 0 20px rgba(0,0,0,.25);
  transition:width .2s ease;overflow:hidden;flex-shrink:0;
}
.main{margin-left:230px;flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .2s ease}
.shell.sb-collapsed .sidebar{width:56px}
.shell.sb-collapsed .main{margin-left:56px}

/* ── SIDEBAR ─────────────────────────────────────────────────── */
.sb-logo{
  padding:14px 16px 12px;
  border-bottom:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;gap:10px;
}
.sb-logo img{height:34px;width:auto;flex-shrink:0}
.sb-logo-text{color:#fff;font-size:12.5px;font-weight:700;line-height:1.25}
.sb-logo-domain{color:rgba(255,255,255,.45);font-size:11px;margin-top:2px}

.sb-nav{flex:1;padding:8px 0;overflow-y:auto}
.sb-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;color:rgba(255,255,255,.58);
  font-size:13px;font-weight:500;cursor:pointer;
  border-left:3px solid transparent;transition:all .15s;
  user-select:none;
}
.sb-item:hover{color:rgba(255,255,255,.9);background:rgba(255,255,255,.07)}
.sb-item.active{
  color:#fff;font-weight:600;
  border-left-color:#e74c3c;
  background:rgba(231,76,60,.18);
}
.sb-item svg{width:16px;height:16px;flex-shrink:0;opacity:.8}
.sb-item.active svg{opacity:1}

.sb-user{
  padding:12px 16px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;gap:10px;
}
.sb-avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--red);display:flex;align-items:center;
  justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0
}
.sb-uname{color:#fff;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
.sb-urole{color:rgba(255,255,255,.45);font-size:10.5px}
.sb-logout{margin-left:auto;color:rgba(255,255,255,.35);cursor:pointer;padding:4px;border-radius:4px;transition:color .15s;flex-shrink:0}
.sb-logout:hover{color:#fff}

/* Sidebar collapsed — icons only */
.shell.sb-collapsed .sb-label{display:none}
.shell.sb-collapsed .sb-logo-text,.shell.sb-collapsed .sb-logo-domain{display:none}
.shell.sb-collapsed .sb-logo{justify-content:center;padding:14px 0 12px}
.shell.sb-collapsed .sb-item{justify-content:center;padding:9px 4px}
.shell.sb-collapsed .sb-user{justify-content:center}
.shell.sb-collapsed .sb-uname,.shell.sb-collapsed .sb-urole,.shell.sb-collapsed .sb-logout{display:none}

/* ── HAMBURGER always-visible ─────────────────────────────────── */

/* ── TOPBAR ─────────────────────────────────────────────────── */
.topbar{
  height:var(--topbar);background:var(--white);
  border-bottom:1px solid var(--gray-200);
  display:flex;align-items:center;gap:10px;
  padding:0 16px;position:sticky;top:0;z-index:510;
  box-shadow:var(--shadow-xs);
}
.tb-hamburger{
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;border:none;background:var(--gray-100);
  cursor:pointer;color:var(--gray-700);border-radius:var(--r);flex-shrink:0;
  transition:background .15s,color .15s;
}
.tb-hamburger:hover{background:var(--gray-200);color:var(--gray-900)}
.tb-logo{height:26px;width:auto;flex-shrink:0}
.tb-title{font-size:15px;font-weight:700;color:var(--gray-900)}

/* ── PROFILE MENU ────────────────────────────────────────────── */
.profile-wrap{position:relative;margin-left:auto}
.profile-btn{
  display:flex;align-items:center;gap:7px;
  padding:5px 10px;border-radius:var(--r);
  background:transparent;border:1px solid var(--gray-200);
  cursor:pointer;font-size:13px;font-family:inherit;
  color:var(--gray-700);transition:all .15s;white-space:nowrap;
}
.profile-btn:hover{background:var(--gray-50)}
.profile-dropdown{
  position:absolute;right:0;top:calc(100% + 6px);
  background:var(--white);border:1px solid var(--gray-200);
  border-radius:var(--r2);box-shadow:var(--shadow-lg);
  min-width:215px;z-index:600;padding:6px 0;
}
.pd-header{padding:10px 14px 8px;border-bottom:1px solid var(--gray-100);margin-bottom:4px}
.pd-username{font-size:13px;font-weight:700;color:var(--gray-900)}
.pd-sub{font-size:11.5px;color:var(--gray-400);margin-top:1px}
.pd-section{
  padding:5px 14px 3px;font-size:10.5px;font-weight:700;
  color:var(--gray-400);text-transform:uppercase;letter-spacing:.6px;
}
.pd-item{
  padding:8px 14px;font-size:13px;cursor:pointer;
  display:flex;align-items:center;gap:8px;color:var(--gray-700);
}
.pd-item:hover{background:var(--gray-50);color:var(--gray-900)}
.pd-item.pd-active{font-weight:700;color:var(--navy)}
.pd-divider{border:none;border-top:1px solid var(--gray-200);margin:4px 0}

/* ── WARNING BANNERS ─────────────────────────────────────────── */
.warn-bar{
  background:var(--gold-lt);border-bottom:2px solid #fbbf24;
  padding:10px 22px;font-size:13px;color:#78350f;
  display:flex;align-items:center;gap:8px;
}
.warn-bar a{color:var(--navy2);font-weight:700;text-decoration:underline;cursor:pointer}
.warn-bar svg{width:15px;height:15px;flex-shrink:0;color:#d97706}

/* ── PAGE CONTENT ────────────────────────────────────────────── */
.pg-content{padding:20px 22px;flex:1}
.pg{display:none}.pg.active{display:block}

/* ── CARDS ───────────────────────────────────────────────────── */
.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r2);padding:18px 20px;box-shadow:var(--shadow-xs)}
.card+.card,.card+.grid,.grid+.card{margin-top:16px}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.card-title{font-size:10.5px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.7px}
.card-title2{font-size:14px;font-weight:700;color:var(--gray-900)}

/* ── STAT GRID ───────────────────────────────────────────────── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r2);padding:16px 18px;box-shadow:var(--shadow-xs)}
.stat-num{font-size:26px;font-weight:800;color:var(--navy);line-height:1}
.stat-label{font-size:11px;font-weight:600;color:var(--gray-400);margin-top:4px;text-transform:uppercase;letter-spacing:.4px}
.stat-card.g .stat-num{color:var(--green)}
.stat-card.r .stat-num{color:var(--red)}

/* ── DASHBOARD GRID ──────────────────────────────────────────── */
.dash-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px}

/* ── TABLES ──────────────────────────────────────────────────── */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead tr{background:var(--gray-50)}
th{padding:9px 11px;text-align:left;font-size:11.5px;font-weight:700;color:var(--gray-500);border-bottom:2px solid var(--gray-200);white-space:nowrap}
td{padding:8px 11px;border-bottom:1px solid var(--gray-100);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--gray-50)}
tbody tr.row-sel td{background:#dbeafe}
tbody tr.row-sel:hover td{background:#bfdbfe}
tbody tr.row-clickable{cursor:pointer}
td.mono{font-family:'Consolas','Courier New',monospace;font-size:12px}

/* ── BADGES ──────────────────────────────────────────────────── */
.badge{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:700;white-space:nowrap}
.b-pass{background:#dcfce7;color:#166534}
.b-fail{background:#fee2e2;color:#991b1b}
.b-none{background:#f1f5f9;color:#475569}
.b-permerr{background:#fef3c7;color:#92400e}
.b-blue{background:var(--blue-lt);color:var(--navy2)}
.b-navy{background:var(--navy);color:#fff}
.b-green{background:#dcfce7;color:#166534}
.b-red{background:#fee2e2;color:#991b1b}
.b-gray{background:#f1f5f9;color:#475569}

/* ── PIE ─────────────────────────────────────────────────────── */
.pie-wrap{display:flex;flex-direction:column;align-items:center;gap:14px}
.legend{width:100%;font-size:12.5px}
.leg-row{display:flex;align-items:center;gap:7px;padding:3px 0}
.leg-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* ── FORMS ───────────────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.lbl{font-size:12.5px;font-weight:600;color:var(--gray-700)}
input[type=text],input[type=email],input[type=password],select,textarea{
  padding:7px 10px;font-size:13.5px;border:1px solid var(--gray-300);
  border-radius:var(--r);background:var(--white);color:var(--gray-900);
  transition:border-color .15s,box-shadow .15s;font-family:inherit;width:100%
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(45,107,196,.12)}
input[readonly]{background:var(--gray-50);color:var(--gray-500);cursor:default}
input[type=checkbox]{width:15px;height:15px;accent-color:var(--blue);cursor:pointer}
select.sm{padding:5px 8px;font-size:12.5px;width:auto}
.filter-lbl{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--gray-700)}
.filter-lbl input{width:220px;margin:0}

/* ── BUTTONS ─────────────────────────────────────────────────── */
/* touch-action:manipulation removes the 300 ms tap delay on mobile
   and prevents double-tap zoom on interactive elements.           */
button,a,[role="button"],.btn,.btn-icon,.pg-btn,.domain-opt{touch-action:manipulation}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:inherit;white-space:nowrap}
.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover{background:var(--navy2)}
.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-50)}
.btn-danger{background:var(--white);color:var(--red);border:1px solid var(--red)}.btn-danger:hover{background:var(--red-lt)}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--gray-200);border-radius:var(--r);background:var(--white);cursor:pointer;color:var(--gray-500);transition:all .15s;flex-shrink:0}
.btn-icon:hover{background:var(--blue-lt);color:var(--blue);border-color:var(--blue)}
.btn-icon.r:hover{background:var(--red-lt);color:var(--red);border-color:var(--red)}
.btn-icon svg{width:13px;height:13px}

/* ── SERVICE CARDS ───────────────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
.svc-card{border:2px solid var(--gray-200);border-radius:var(--r3);padding:18px 16px;background:var(--white);position:relative;display:flex;flex-direction:column}
.svc-card.current{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue)}
.svc-name{font-size:14px;font-weight:800;color:var(--gray-900);margin-bottom:6px}
.svc-detail{font-size:12.5px;color:var(--gray-500);margin-bottom:0;line-height:1.5}
.svc-cost{font-size:22px;font-weight:800;color:var(--navy);margin-bottom:0}
.svc-cost span{font-size:12px;font-weight:400;color:var(--gray-400)}
.svc-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.curr-badge{position:absolute;top:10px;right:10px;background:var(--blue);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px}
.red-border{border:2px solid var(--red);border-radius:var(--r2);padding:16px;margin-bottom:18px}
.addon-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}

/* ── GROUP EDITOR ────────────────────────────────────────────── */
.grp-table{width:100%;border-collapse:collapse}
.grp-table th{padding:9px 12px;background:var(--gray-50);border-bottom:2px solid var(--gray-200);font-size:11.5px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}
.grp-table td{padding:8px 12px;border-bottom:1px solid var(--gray-100);vertical-align:middle}
.grp-table tr:hover td{background:var(--gray-50)}

/* ── PERMISSIONS ─────────────────────────────────────────────── */
.perm-table{width:100%;border-collapse:collapse}
.perm-table th{padding:10px 14px;text-align:center;font-size:11.5px;font-weight:700;color:var(--gray-500);border-bottom:2px solid var(--gray-200);background:var(--gray-50);text-transform:uppercase;letter-spacing:.5px}
.perm-table th:first-child{text-align:left}
.perm-table td{padding:9px 14px;border-bottom:1px solid var(--gray-100);text-align:center}
.perm-table td:first-child{text-align:left;font-weight:600;color:var(--gray-700)}
.perm-table tr:hover td{background:var(--gray-50)}

/* ── DNS ─────────────────────────────────────────────────────── */
.dns-label{font-size:14px;font-weight:700;color:var(--gray-700);margin-bottom:10px}
.dns-static{
  padding:10px 13px;border-radius:var(--r);border:1px solid var(--gray-200);
  background:var(--gray-50);font-family:'Consolas','Courier New',monospace;
  font-size:12px;color:var(--gray-500);word-break:break-all;margin-bottom:10px
}
.dns-result{
  margin-top:10px;padding:11px 14px;border-radius:var(--r);
  font-size:13px;border:1px solid var(--gray-200);display:none
}
.dns-result.ok{background:var(--green-lt);border-color:#86efac;color:#166534}
.dns-result.err{background:var(--red-lt);border-color:#fca5a5;color:#991b1b}
.dns-result.warn{background:var(--gold-lt);border-color:#fbbf24;color:#78350f}
.dns-result.info{background:var(--blue-lt);border-color:#93c5fd;color:var(--navy2)}
.dns-result.show{display:block}
.dns-verify{border:1px solid var(--gray-200);border-radius:var(--r2);padding:14px;margin-bottom:16px}
.dns-verify.ok{background:var(--green-lt);border-color:#86efac}
.dns-verify.err{background:var(--red-lt);border-color:#fca5a5}
.dns-verify.warn{background:var(--gold-lt);border-color:#fbbf24}

/* ── PAGINATION ──────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;justify-content:center;gap:5px;padding:10px 0}
.pg-btn{padding:5px 9px;border:1px solid var(--gray-200);border-radius:var(--r);background:var(--white);cursor:pointer;color:var(--gray-500);font-size:12.5px;transition:all .15s}
.pg-btn:hover:not([disabled]){background:var(--blue-lt);border-color:var(--blue);color:var(--blue)}
.pg-btn[disabled]{opacity:.35;cursor:default}
.pg-btn.active{background:var(--navy);border-color:var(--navy);color:#fff}
.pg-info{font-size:12px;color:var(--gray-400);padding:0 8px}

/* ── MODALS ──────────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(10,20,40,.5);z-index:500;display:flex;align-items:center;justify-content:center}
.modal{background:var(--white);border-radius:var(--r2);padding:26px 28px;width:420px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}
.modal-title{font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:18px}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:14px;border-top:1px solid var(--gray-100)}
.modal-desc{font-size:13px;color:var(--gray-500);margin-bottom:16px;line-height:1.6}

/* ── LOGIN / DOMAIN PAGES ────────────────────────────────────── */
.login-page,.domain-page{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;width:100%;
  background:linear-gradient(135deg,#0d1f3c 0%,#1a3466 50%,#0d1f3c 100%);
}
.login-box{
  background:var(--white);border-radius:var(--r3);
  padding:38px 36px;width:380px;box-shadow:var(--shadow-lg);
}
.login-logo{text-align:center;margin-bottom:26px}
.login-logo img{max-width:210px;height:auto}
.login-err{
  background:var(--red-lt);color:var(--red);
  border:1px solid #fecaca;border-radius:var(--r);
  padding:9px 13px;font-size:13px;margin-bottom:12px;
}
.login-row{display:flex;align-items:center;margin-bottom:12px}
.login-row label{width:90px;font-size:13.5px;font-weight:600;color:var(--gray-700);flex-shrink:0}
.login-row input{flex:1;width:auto}
.login-submit{display:flex;justify-content:center;margin-top:8px}
.forgot{text-align:center;margin-top:12px;font-size:12.5px;color:var(--gray-400)}
.forgot a{color:var(--blue);font-weight:600}
.domain-box{
  background:var(--white);border-radius:var(--r3);
  padding:32px 30px;width:440px;box-shadow:var(--shadow-lg);
}
.domain-msg{
  font-size:13.5px;color:var(--gray-700);border:1px solid var(--gray-200);
  border-radius:var(--r);padding:11px 14px;margin-bottom:16px;background:var(--gray-50)
}
.domain-opt{
  padding:12px 16px;border:1px solid var(--gray-200);border-radius:var(--r2);
  margin-bottom:8px;cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:space-between;
  font-size:13.5px;font-weight:600;color:var(--navy)
}
.domain-opt:hover{border-color:var(--blue);background:var(--blue-lt)}
.domain-opt small{font-weight:400;color:var(--gray-400);font-size:12px}

/* ── BILLING ─────────────────────────────────────────────────── */
.payment-card{
  background:linear-gradient(135deg,#1a3466,#2d6bc4);
  border-radius:12px;padding:18px 20px;color:#fff;
  display:inline-flex;flex-direction:column;gap:10px;
  min-width:240px;box-shadow:var(--shadow)
}
.pay-card-num{font-size:16px;letter-spacing:3px;font-family:'Consolas',monospace}
.pay-card-name{font-size:12px;opacity:.7}

/* ── MISC UTILITIES ──────────────────────────────────────────── */
.flex{display:flex}.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-center{display:flex;align-items:center}.gap8{gap:8px}.gap12{gap:12px}.gap16{gap:16px}
.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}
.text-muted{color:var(--gray-400);font-size:13px}
.text-danger{color:var(--red)}
.divider{border:none;border-top:1px solid var(--gray-200);margin:18px 0}
.w100{width:100%}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ── TOAST ───────────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:22px;right:22px;
  background:#0f172a;color:#fff;padding:11px 18px;
  border-radius:var(--r2);font-size:13px;z-index:999;
  opacity:0;transform:translateY(14px);transition:all .22s;
  box-shadow:var(--shadow-lg);pointer-events:none;max-width:300px
}
#toast.show{opacity:1;transform:translateY(0)}
#toast.ok{background:#166534}
#toast.err{background:var(--red)}

/* ── PASSWORD RULES CHECKLIST ───────────────────────────────── */
.pw-rules{
  background:var(--gray-50);border:1px solid var(--gray-200);
  border-radius:var(--r);padding:10px 14px;margin:10px 0 4px;
  font-size:12.5px;
}
.pw-rules-title{
  font-size:11.5px;font-weight:700;color:var(--gray-500);
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;
}
.pw-rules-subhead{
  font-size:11.5px;font-weight:600;color:var(--gray-400);
  margin:7px 0 3px;padding-left:23px;
}
.pw-rule{
  display:flex;align-items:center;gap:7px;
  padding:3px 0;color:var(--gray-400);transition:color .2s;
}
.pw-rule.met{color:var(--green)}
.pw-check{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:50%;
  border:1.5px solid var(--gray-300);font-size:10px;flex-shrink:0;
  transition:all .2s;
}
.pw-check.met{
  background:var(--green);border-color:var(--green);color:#fff;
}

/* ── BLAZOR RECONNECT MODAL ─────────────────────────────────── */
/* Blazor toggles .components-reconnect-show / -hide / -failed / -rejected
   on the #components-reconnect-modal element.  The inner divs are shown
   selectively so the user sees a visible message instead of a silent
   location.reload() that would create a new circuit and force re-login. */
#components-reconnect-modal{
  position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;
  display:none;align-items:center;justify-content:center;
  background:rgba(0,0,0,.45);backdrop-filter:blur(2px);
}
#components-reconnect-modal .reconnect-show,
#components-reconnect-modal .reconnect-failed,
#components-reconnect-modal .reconnect-rejected{ display:none }

/* Blazor adds .components-reconnect-show while retrying */
#components-reconnect-modal.components-reconnect-show{display:flex}
#components-reconnect-modal.components-reconnect-show .reconnect-show{
  display:flex;align-items:center;gap:12px;
  background:#fff;border-radius:8px;padding:20px 28px;
  box-shadow:0 4px 24px rgba(0,0,0,.18);font-size:15px;color:#1e2a3b;
}
/* Blazor adds .components-reconnect-failed after all retries exhausted */
#components-reconnect-modal.components-reconnect-failed{display:flex}
#components-reconnect-modal.components-reconnect-failed .reconnect-failed{
  display:flex;align-items:center;gap:12px;
  background:#fff;border-radius:8px;padding:20px 28px;
  box-shadow:0 4px 24px rgba(0,0,0,.18);font-size:15px;color:#1e2a3b;
}
/* Blazor adds .components-reconnect-rejected when server rejects (e.g. redeployed) */
#components-reconnect-modal.components-reconnect-rejected{display:flex}
#components-reconnect-modal.components-reconnect-rejected .reconnect-rejected{
  display:flex;align-items:center;gap:12px;
  background:#fff;border-radius:8px;padding:20px 28px;
  box-shadow:0 4px 24px rgba(0,0,0,.18);font-size:15px;color:#1e2a3b;
}
#components-reconnect-modal button{
  margin-left:8px;padding:6px 14px;
  background:var(--blue);color:#fff;border:none;border-radius:6px;
  cursor:pointer;font-size:13.5px;
}
#components-reconnect-modal button:hover{opacity:.88}
.reconnect-spinner{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;
  border:3px solid var(--gray-200);border-top-color:var(--blue);
  animation:spin .75s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─────────────────────────────────────────────────────────────
   RESPONSIVE — TABLET + MOBILE
   Breakpoints:
     900 px  tablet   – two-col stats, collapse multi-col grids
     640 px  mobile   – sidebar becomes slide-in overlay, single-col layout
     400 px  xs-phone – further simplify topbar and login form
───────────────────────────────────────────────────────────────*/

/* Sidebar mobile backdrop rendered by Blazor (MainLayout.razor).
   On desktop it stays invisible; on mobile it dims the page and
   lets the user tap outside the sidebar to close it.             */
.sb-backdrop { display:none }

/* ── Tablet (≤ 900 px) ──────────────────────────────────────── */
@media (max-width:900px){
  /* Stats: 2 across instead of 4 */
  .stat-grid{ grid-template-columns:repeat(2,1fr) }
  /* Dashboard panels: stack vertically */
  .dash-grid{ grid-template-columns:1fr }
  /* Service plan cards: 2 across */
  .svc-grid { grid-template-columns:repeat(2,1fr) }
}

/* ── Mobile (≤ 640 px) ──────────────────────────────────────── */
@media (max-width:640px){

  /* ── Sidebar: fixed slide-in overlay ──────────────────────── */
  .sidebar{
    width:230px !important;         /* always full-width drawer  */
    transform:translateX(-240px);   /* hide off-screen left      */
    transition:transform .25s ease;
    z-index:502;                    /* above content, above backdrop */
  }
  /* Sidebar visible when shell does NOT have sb-collapsed */
  .shell:not(.sb-collapsed) .sidebar{
    transform:translateX(0);
    box-shadow:4px 0 24px rgba(0,0,0,.35);
  }
  /* Main area always fills full width */
  .main{ margin-left:0 !important; transition:none }

  /* ── Backdrop ──────────────────────────────────────────────── */
  .sb-backdrop{
    display:block;
    position:fixed;inset:0;
    background:rgba(0,0,0,.42);
    z-index:501;
  }

  /* ── Topbar ────────────────────────────────────────────────── */
  /* Hide page title — leaves room for hamburger + profile btn   */
  .tb-title{ display:none }
  /* Profile button: show avatar + chevron, hide username text   */
  .profile-btn > span{ display:none }

  /* ── Page content ──────────────────────────────────────────── */
  .pg-content{ padding:12px 14px }

  /* ── Grids: collapse to 1 column ───────────────────────────── */
  .stat-grid { grid-template-columns:1fr 1fr }
  .dash-grid { grid-template-columns:1fr }
  .svc-grid  { grid-template-columns:1fr }
  .addon-grid{ grid-template-columns:1fr }
  .grid2     { grid-template-columns:1fr }

  /* ── Flex rows: allow wrapping ─────────────────────────────── */
  .flex-center{ flex-wrap:wrap }
  .warn-bar   { flex-wrap:wrap }

  /* ── Login / domain boxes ──────────────────────────────────── */
  .login-box { width:90vw; padding:26px 20px }
  .domain-box{ width:90vw; padding:22px 18px }

  /* ── Modals ─────────────────────────────────────────────────── */
  .modal{ width:92vw; padding:20px 18px }

  /* ── Tables ─────────────────────────────────────────────────── */
  /* Smooth momentum scroll on iOS for horizontally-scrollable tables */
  .tbl-wrap{ -webkit-overflow-scrolling:touch }
}

/* ── Extra-small phone (≤ 400 px) ──────────────────────────── */
@media (max-width:400px){
  /* Stats: single column */
  .stat-grid{ grid-template-columns:1fr }
  /* Drop the logo from the topbar — hamburger + profile is enough */
  .tb-logo  { display:none }
  /* Stack login label + input vertically */
  .login-row{ flex-direction:column; align-items:flex-start }
  .login-row label{ width:auto; margin-bottom:4px }
  .login-row input{ width:100% }
}
