/* AutoSSL Portal – Common CSS (from latest-user-front-html mockup)
   BEM-friendly, class-based only, mobile-first.
   Theme: light (default) and dark via html[data-theme="dark"].
   Spacing/typography use CSS variables for consistency. */

/* ========== Layout & design tokens (mobile-first base) ========== */
:root,
html[data-theme="dark"]{
  /* Spacing */
  --space-xs: 6px;
  --space-sm: 10px;
  --space-md: 14px;
  --space-lg: 18px;
  --space-xl: 24px;
  /* Typography */
  --font-size-xs: 11px;
  --font-size-sm: 12px;
  --font-size-base: 13px;
  --font-size-md: 14px;
  --font-size-lg: 16px;
  --font-size-xl: 20px;
  --font-size-2xl: 26px;
  --line-height-tight: 1.3;
  --line-height-normal: 1.45;
  /* Colors & theme: Dark */
  --bg:#0b1220;
  --bg-grad-end:#060a13;
  --panel:#0f1930;
  --panel-2:#121f3d;
  --card:#0f1a33;
  --muted:#93a4c7;
  --text:#e9f0ff;
  --good:#2dd4bf;
  --warn:#fbbf24;
  --bad:#fb7185;
  --brand:#60a5fa;
  --brand-2:#a78bfa;
  --line:rgba(255,255,255,.09);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius:16px;
  --radius-lg:22px;
  --pad: var(--space-lg);
  --pad-lg:22px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  --body-bg: radial-gradient(1200px 600px at 20% -10%, rgba(96,165,250,.25), transparent 60%),
    radial-gradient(900px 500px at 110% 10%, rgba(167,139,250,.18), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-grad-end) 70%);
  --sidebar-bg: linear-gradient(180deg, rgba(15,25,48,.9), rgba(10,16,30,.6));
  --card-bg: linear-gradient(180deg, rgba(15,26,51,.95), rgba(10,16,30,.92));
  --nav-hover: rgba(255,255,255,.03);
  --nav-active-bg: rgba(96,165,250,.12);
  --nav-active-border: rgba(96,165,250,.25);
  --input-bg: rgba(255,255,255,.04);
  --btn-bg: rgba(255,255,255,.04);
  --modal-sheet-bg: linear-gradient(180deg, rgba(16,26,52,.98), rgba(9,14,26,.96));
}

/* ========== Theme: Light (default for portal) ========== */
html[data-theme="light"]{
  --bg:#f1f5f9;
  --bg-grad-end:#e2e8f0;
  --panel:#ffffff;
  --panel-2:#f8fafc;
  --card:#ffffff;
  --muted:#475569;
  --text:#0f172a;
  --good:#0d9488;
  --warn:#d97706;
  --bad:#e11d48;
  --brand:#2563eb;
  --brand-2:#7c3aed;
  --line: rgba(0,0,0,.08);
  --shadow: 0 10px 30px rgba(0,0,0,.08);
  --body-bg: radial-gradient(1200px 600px at 20% -10%, rgba(37,99,235,.08), transparent 60%),
    radial-gradient(900px 500px at 110% 10%, rgba(124,58,237,.06), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg-grad-end) 70%);
  --sidebar-bg: linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.95));
  --card-bg: linear-gradient(180deg, #ffffff, rgba(248,250,252,.98));
  --nav-hover: rgba(0,0,0,.04);
  --nav-active-bg: rgba(37,99,235,.1);
  --nav-active-border: rgba(37,99,235,.25);
  --input-bg: rgba(0,0,0,.03);
  --btn-bg: rgba(0,0,0,.04);
  --modal-sheet-bg: linear-gradient(180deg, #ffffff, rgba(248,250,252,.98));
}
html[data-theme="light"] .nav a{color:var(--text)}
html[data-theme="light"] .table th{color:var(--text)}
html[data-theme="light"] .domain-list-header{color:var(--text)}
html[data-theme="light"] .sidebar .sidebar-logout{color:var(--text)}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: var(--body-bg);
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-size: cover;
  min-height: 100vh;
  color:var(--text);
  font-family:var(--font);
  line-height:1.45;
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.95}
small{color:var(--muted)}
code,kbd{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace}

.container{max-width:1200px;margin:0 auto;padding:24px}
.shell{display:grid;grid-template-columns:1fr;min-height:100vh;position:relative}
/* Hamburger: fixed top-left, visible on mobile and when sidebar collapsed */
.sidebar-hamburger{
  display:none;
  z-index:12020;
  width:44px;
  height:44px;
  padding:0;
  border:none;
  cursor:pointer;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  transition:background .2s;
  
}
.sidebar-hamburger:hover{background:var(--nav-hover)}
.sidebar-hamburger span{
  display:block;
  width:20px;
  height:2px;
  background:var(--text);
  border-radius:1px;
  transition:transform .25s, opacity .25s;
}
.sidebar-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(90deg)}
.sidebar-hamburger[aria-expanded="true"] span:nth-child(2){transform:translateY(0) translateX(-7px) rotate(90deg)}
.sidebar-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) translateX(7px) rotate(90deg)}
.sidebar-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.4);
  z-index:12005;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s;
}
.sidebar-overlay.visible{opacity:1;pointer-events:auto}
.sidebar{
  position:sticky;top:0;align-self:start;
  height:100vh;
  padding:18px 14px;border-right:1px solid var(--line);
  background: var(--sidebar-bg);
  backdrop-filter: blur(10px);
  display:flex;
  flex-direction:column;
  width:260px;
  flex-shrink:0;
  transition:width .25s, transform .25s, margin .25s;
  z-index:999;
}
.sidebar.collapsed{
  width:60px;
  padding:10px 0;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
.sidebar.collapsed::-webkit-scrollbar{display:none}
.sidebar.collapsed .brand-text,
.sidebar.collapsed .footerNote,
.sidebar.collapsed .nav-group-title,
.sidebar.collapsed .nav-label,
.sidebar.collapsed .pill{display:none !important}
.sidebar.collapsed .brand{justify-content:center;margin:6px 0 16px 0}
.sidebar.collapsed .nav a{justify-content:center;padding:10px;margin:4px 0}
.sidebar.collapsed .nav .nav-group{margin:0 0 16px 0;border:none;padding:0}
.sidebar.collapsed .sidebar-logout-btn .nav-label{display:none}
.sidebar.collapsed .sidebar-logout-btn{justify-content:center;padding:12px}


.sidebar.collapsed .theme-toggle-wrap .theme-toggle-btn{ display:none !important}
.nav-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  width:24px;
  height:24px;
  position:relative;
}
.nav-icon svg{width:20px;height:20px}
.nav-alert-dot{
  position:absolute;
  top:0;
  right:0;
  width:8px;
  height:8px;
  border-radius:50%;
  background:#dc2626;
  flex-shrink:0;
}
/* Tooltip when collapsed */
.sidebar.collapsed .nav a[data-label]::after,
.sidebar.collapsed .sidebar-logout-btn[title]::after{
  position:absolute;
  left:100%;
  top:50%;
  transform:translateY(-50%);
  margin-left:7px;
  padding:8px 12px;
  background:#2563eb;
  color:#fff;
  font-size:13px;
  white-space:nowrap;
  border-radius:8px;
  
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  opacity:0;
  pointer-events:none;
  transition:opacity .15s;
  z-index:100;
}
.sidebar.collapsed .nav a[data-label]::before,
.sidebar.collapsed .sidebar-logout-btn[title]::before {
  content: '';
  position: absolute;
  top: 12px;
    left: 100%;
  margin-left: 0;
  width: 0;
  height: 0;
  border-right: 10px solid #2563eb;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  opacity:0;
  pointer-events:none;
  transition:opacity .15s;
}
.sidebar.collapsed .nav a:hover::before, .sidebar.collapsed .sidebar-logout-btn:hover::before {
  opacity: 1;
}
.sidebar.collapsed .nav a[data-label]::after{content:attr(data-label)}
.sidebar.collapsed .sidebar-logout-btn[title]::after{content:attr(title)}
.sidebar.collapsed .nav a:hover::after,
.sidebar.collapsed .sidebar-logout-btn:hover::after{opacity:1}
.sidebar.collapsed .nav a,
.sidebar.collapsed .sidebar-logout-btn{position:relative}
.brand{
  display:flex;gap:10px;align-items:center;margin:6px 10px 16px 10px;
}
.logo{
  width:38px;height:38px;
  background: url('../images/autossl.svg') no-repeat center center;
  background-size: contain;  
  flex-shrink:0;
}
.brand h1{font-size:16px;margin:0}
.brand p{margin:0;color:var(--muted);font-size:12px}
.nav{margin-top:14px}
.nav .nav-group{
  margin:0 6px 18px 6px;
  border:1px solid #ced9ee;
  border-radius:14px;
  padding-bottom: 5px;
}
.nav .nav-group:last-child{margin-bottom:5px;}
.nav .nav-group .nav-group-title + a{ margin-top: 0;}
.nav .nav-group-title{
  margin:0;
  padding: 0 12px;
  font-size:14px;
  letter-spacing:0;
  text-transform:none;
  color:#2563eb;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  transform: translateY(-12px);
   
}
.nav .nav-group-title span{ background: #fff; padding: 3px 5px;}
.nav a{
  display:flex;align-items:center;gap:10px;
  padding:2px 5px;color:var(--muted);
  margin:3px 6px;border:1px solid transparent;
}


.nav .nav-group a{
  margin: 4px 7px;
  font-size: 14px;
  border-radius: 5px;
}
.collapsed .nav .nav-group a{border-radius: 0;}

.nav a:hover{background:var(--nav-hover);color:var(--text)}
.nav a.active{
  background:var(--nav-active-bg);

  color:var(--text);

}
.nav .nav-group a.green-navi{ background: var(--good);}
.nav .nav-group a.green-navi .nav-icon svg{ color: #fff;}
html[data-theme="light"] .nav a.green-navi{ color: #fff;}
.nav .nav-group a.green-navi .pill{ color: #fff;}
.nav .pill{
  margin-left:auto;
  font-size:11px;
  padding:2px 8px;
  border-radius:999px;
  background:var(--input-bg);
  color:var(--muted);
}
.main{padding:24px 26px 80px 26px;min-width:0;overflow-x:auto}
.topbar{
  display:flex;gap:14px;align-items:center;justify-content:space-between;
  margin-bottom:18px;
}
.hgroup{width: 100%;}
.hgroup h2{margin:0;font-size:20px}
.hgroup p{margin:2px 0 0 0;color:var(--muted);font-size:13px}
.search{
  display:flex;gap:10px;align-items:center;
}
.input{
  background:var(--input-bg);
  border:1px solid var(--line);
  color:var(--text);
  border-radius:14px;
  padding:11px 12px;
  min-width:260px;
  outline:none;
}
.input::placeholder{color:var(--muted);opacity:.9}
.btn{
  display:inline-flex;gap:8px;align-items:center;justify-content:center;
  padding:10px 12px;border-radius:14px;border:1px solid var(--line);
  background:var(--btn-bg);color:var(--text);
  cursor:pointer;user-select:none; line-height: 1.2;
  font-family: var(--font);
  font-size: 14px;
}
.btn:hover{background:var(--nav-hover)}
.btn.primary{
  background: #2563eb;
  border-color: transparent;
  color:#fff;
  font-weight:600;
}
.dark-gray{background: #555; color:#fff; border-color: transparent;}
.dark-gray:hover{background: #2563eb;}
html[data-theme="dark"] .btn.primary{color:#071023}
.btn.danger{border-color:rgba(251,113,133,.35);background:rgba(251,113,133,.12)}
.btn.ghost{background:transparent}
.btn.small{padding:7px 10px;border-radius:12px;font-size:12px}
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:999px;border:1px solid var(--line);
  color:var(--muted);font-size:12px;background:var(--input-bg)
}
.badge.good{border-color:var(--good);background:rgba(45,212,191,.15);color:var(--good)}
.badge.warn{border-color:var(--warn);background:rgba(251,191,36,.15);color:var(--warn)}
.badge.bad{border-color:var(--bad);background:rgba(251,113,133,.15);color:var(--bad)}
.badge.muted{border-color:var(--muted);background:rgba(147,164,199,.12);color:var(--muted)}
/* DNS Automation status badges */
.badge.dns-status-verified{border-color:var(--good);background:rgba(45,212,191,.2);color:var(--good)}
.badge.dns-status-pending{border-color:var(--bad);background:rgba(251,113,133,.2);color:var(--bad)}
html[data-theme="light"] .badge.dns-status-verified{border-color:var(--good);background:rgba(13,148,136,.15);color:var(--good)}
html[data-theme="light"] .badge.dns-status-pending{border-color:var(--bad);background:rgba(225,29,72,.15);color:var(--bad)}
.grid{display:grid;gap:20px;padding-bottom:20px}
.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}

/* Copy buttons (shared across portal) – Cursor-style checkmark feedback when copied */
.kv-copy-btn, .cred-copy-btn {
  flex-shrink: 0; padding: 4px; border: none; background: transparent; color: var(--muted); cursor: pointer; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; transition: color .2s;
}
.kv-copy-btn:hover, .cred-copy-btn:hover { color: var(--text); background: rgba(255,255,255,0.06); }
html[data-theme="light"] .kv-copy-btn:hover, html[data-theme="light"] .cred-copy-btn:hover { background: rgba(0,0,0,0.06); }
.kv-copy-btn svg, .cred-copy-btn svg { width: 16px; height: 16px; }
/* Copied state: show checkmark + success color (like Cursor) */
.kv-copy-btn.copied, .cred-copy-btn.copied { color: var(--good) !important; }
.kv-copy-btn.copied svg, .cred-copy-btn.copied svg { display: none; }
.kv-copy-btn.copied::after, .cred-copy-btn.copied::after {
  content: '✓'; font-size: 15px; font-weight: 700; color: var(--good);
}

/* Visually hidden (WCAG: keep for screen readers) */
.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.visually-hidden--focusable:focus{
  position:static;width:auto;height:auto;padding:var(--space-sm) var(--space-md);margin:0;overflow:visible;clip:auto;white-space:normal;border:1px solid var(--line);background:var(--panel);color:var(--text);z-index:100;
}



@media (min-width: 641px){
  .topbar{flex-direction:row;align-items:center}
  .search{width:auto}
}
@media (min-width: 981px){
  .shell{grid-template-columns:auto 1fr;align-items:start}
  .sidebar-hamburger{display:flex}
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .input{min-width:180px}
  .main{padding-left:24px}
}
@media (min-width: 1024px){
  .grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width: 980px){
  .shell{grid-template-columns:1fr}
  .sidebar-hamburger{display:flex}
  .sidebar{
    position:fixed;
    top:0;
    left:0;
    height:100vh;
    transform:translateX(-100%);
    margin:0;
    border-right:1px solid var(--line);
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .sidebar::-webkit-scrollbar{display:none}
  .sidebar.open{transform:translateX(0)}
  .sidebar-overlay{display:block}
  .main{padding-top:60px;padding-left:26px}
  .grid.cols-3,.grid.cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .input{min-width:180px}
}
@media (max-width: 640px){
  .grid.cols-3,.grid.cols-4,.grid.cols-2{grid-template-columns:1fr}
  .topbar{flex-direction:column;align-items:flex-start}
  .search{width:100%}
  .input{width:100%;min-width:0}
}
.card{
  background: var(--card-bg);
  border:1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--pad-lg);
  box-shadow: var(--shadow);
}
.card.slim{padding:14px;border-radius:18px}
.card h3{margin:0 0 6px 0;font-size:16px}
.card p{margin:0;color:var(--muted);font-size:13px}
.kpi{display:flex;flex-direction:column;gap:6px}
.kpi .num{font-size:26px;font-weight:800;letter-spacing:-.02em}
.kpi .sub{color:var(--muted);font-size:12px}
.split{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.hr{height:1px;background:var(--line);margin:14px 0}
.table{
  width:100%;border-collapse:separate;border-spacing:0 10px;
}
.table th{
  text-align:left;font-size:12px;color:var(--muted);font-weight:600;padding:0 12px;
}
.table td{
  padding:12px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--input-bg);
  font-size:13px;color:var(--text);
}
.table tr td:first-child{
  border-left:1px solid var(--line);border-top-left-radius:14px;border-bottom-left-radius:14px
}
.table tr td:last-child{
  border-right:1px solid var(--line);border-top-right-radius:14px;border-bottom-right-radius:14px
}
.mini{font-size:12px;color:var(--muted)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
/* Tabs */
.tabs{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px dashed var(--line);
  background:var(--input-bg);
  color:var(--muted);
  display:flex;
  gap:19px;
  flex-wrap:wrap;
  align-items:center;
}
.tabs .tab,
.tab{
  padding:10px 13px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--btn-bg);
  color:var(--text);
  font-size:13px;
  cursor:pointer;
}
.tabs .tab:hover,
.tab:hover{background:var(--nav-hover)}
.tabs .tab.active,
.tab.active{background:var(--nav-active-bg);border-color:var(--nav-active-border);color:var(--text)}
.callout{
  padding:12px 14px;
  border:1px solid var(--line);
  border-color:var(--good);
  background:rgba(45, 212, 191, .15);
  color:var(--good);
  border-radius: 14px;
}
.callout.good{
  border:1px solid var(--line);
  border-color:var(--good) !important;
  background:rgba(45, 212, 191, .15) !important;
  color:var(--good) !important;
  border-radius: 14px;
}
.callout.bad{
  border:1px solid var(--line);
  border-color:var(--bad) !important;
  background:rgba(251, 113, 133, .15) !important;
  color:var(--bad) !important;
  border-radius: 14px;
}
.callout.info{
  border-color:rgba(59, 130, 246, .6) !important;
  background:rgba(59, 130, 246, .08) !important;
  color:var(--text);
}
.callout strong{color:var(--text)}

.callout.alert-msg-box{ margin-top: 0; background: var(--input-bg) !important; border-left-width: 4px; color: #000 !important;
   border-top-color: var(--line) !important; border-right-color: var(--line) !important; border-bottom-color: var(--line) !important;}
.page-scope-note{
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-left: 3px solid rgba(59, 130, 246, .85);
  border-radius: 10px;
  background: rgba(59, 130, 246, .06);
  color: var(--text);
}
.page-scope-note-kicker{
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #2563eb;
  font-weight: 700;
  margin-bottom: 3px;
}
.page-scope-note-text{
  font-size: 13px;
  line-height: 1.45;
  color: var(--muted);
}
.page-scope-note-text b{ color: var(--text); }
.steps{display:grid;gap:10px}
.step{
  display:flex;gap:10px;align-items:flex-start;
  padding:12px 14px;border-radius:18px;border:1px solid var(--line);
  background:var(--input-bg);
  border-radius: 14px;
}
.step .dot{
  width:26px;height:26px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  background:var(--nav-active-bg);border:1px solid var(--nav-active-border);
  color:var(--text);font-weight:800;
}
.step .meta{flex:1}
.step .meta b{display:block;margin-bottom:2px}
.step .meta small{display:block}
.toastbar{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px dashed var(--line);
  background:var(--input-bg);
  color:var(--muted);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
}
.toastbar .path{display:flex;gap:8px;flex-wrap:wrap}
.toastbar a{
  padding:10px 13px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--btn-bg);
  color:var(--text);
  font-size:13px;
}
.toastbar a:hover{background:var(--nav-hover)}
.toastbar a.active{background:var(--nav-active-bg);border-color:var(--nav-active-border);color:var(--text)}
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;
  align-items:center;justify-content:center;padding:18px;z-index:50;
}
.modal.open{display:flex}
.modal .sheet{
  width:min(860px, 100%);
  max-height:85vh;overflow:auto;
  background:var(--modal-sheet-bg);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow: var(--shadow);
  padding:18px;
}
.sheet .head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.sheet .head h3{margin:0}
.sheet .head p{margin:3px 0 0 0;color:var(--muted);font-size:13px}
.sheet .close{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:22px}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 720px){.formgrid{grid-template-columns:1fr}}
.label{font-size:12px;color:var(--muted);margin:6px 0}
.select,.textarea{
  width:100%;
  background:var(--input-bg);
  border:1px solid var(--line);
  color:var(--text);
  border-radius:14px;
  padding:10px 12px;
  outline:none;
  font-size:14px;
  line-height:1.5;
  font-family:inherit;
}
select.select,
select{
  cursor:pointer;
  appearance:auto;
}
select option,
.select option{
  background:var(--panel);
  color:var(--text);
  padding:10px 14px;
  font-size:14px;
  line-height:1.5;
}
.textarea{min-height:180px;resize:vertical}
.footerNote{margin: 0 6px 10px 6px;color:var(--muted);font-size:12px}

/* Theme toggle (sidebar bottom) */
.sidebar .theme-toggle-wrap{margin-top:auto;padding-top:5px;border-top:1px solid var(--line);}
.theme-toggle{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:8px 0;
}
.theme-toggle .theme-toggle-btn{border:none;background:transparent;cursor:pointer;padding:8px;border-radius:12px;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;}
.theme-toggle .theme-toggle-btn:hover{background:var(--nav-hover);color:var(--text)}
.theme-toggle .theme-toggle-btn.active{background:var(--nav-active-bg);color:var(--brand);border:1px solid var(--nav-active-border)}
.theme-toggle svg{width:20px;height:20px;fill:currentColor;stroke:currentColor}
.sidebar .sidebar-logout{display:block;margin-top:10px;text-align:center;font-size:13px;color:var(--muted);text-decoration:none;padding:8px;border-radius:8px;transition:background .15s,color .15s}
.sidebar .sidebar-logout:hover{background:var(--nav-hover);color:var(--text)}
.sidebar .sidebar-logout-btn{
  display:inline-flex;
  margin-bottom:10px;
  border-radius:0;
  justify-content: flex-start;
  padding: 12px;
}
.sidebar-logout-btn:hover{    background: var(--nav-hover); color: var(--text);}

/* Alerts page */
.alerts-filters{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:12px;
}
.alerts-filters select{
  min-width:130px;
  background:var(--input-bg);
  color:var(--text);
  border:1px solid var(--line);
  border-radius:10px;
  padding:7px 10px;
}
.alerts-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.alert-card{
  border:1px solid var(--line);
  background:var(--panel-2);
  border-radius:12px;
  padding:12px;
}
.alert-head{
  display:flex;
  justify-content:space-between;
  gap:10px;
  align-items:flex-start;
}
.alert-head h3{
  margin:0;
}
.alert-meta{
  margin:8px 0 0 0;
  color:var(--muted);
}
.alert-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
  align-items:center;
}
.alert-identity{ margin-top:16px; margin-bottom:14px; }
.alert-identity-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr)); gap:12px; }
.alert-identity-box{ background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:12px 14px; display:flex; flex-direction:column; gap:6px; }
.alert-identity-label{ font-size:10px; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-weight:600; }
.alert-identity-value{ font-size:13px; word-break:break-word; line-height:1.4; }
.alert-identity-value .alert-id-code{ font-size:11px; background:rgba(0,0,0,.12); padding:3px 6px; border-radius:6px; }
.alert-explain-row{ margin-top:8px; font-size:13px; line-height:1.5; }
.alert-explain-row .alert-explain-k{ font-weight:600; color:var(--muted); min-width:150px; display:inline-block; }
.alert-explain-steps{ margin-top:14px; padding-top:12px; border-top:1px dashed var(--line); }
.alert-explain-steps ol{ margin:0 0 0 4px; padding:0 0 0 20px; font-size:13px; line-height:1.55; }
.alert-explain-steps li{ margin-bottom:8px; }
.alert-history-section{ margin-top:18px; padding:14px 16px; background:var(--panel); border:1px solid var(--line); border-radius:12px; }
.alert-history-table{ width:100%; border-collapse:collapse; font-size:13px; }
.alert-history-table th,.alert-history-table td{ text-align:left; padding:10px 12px; border-bottom:1px solid var(--line); }
.alert-history-table th{ font-size:10px; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-weight:600; }
.alert-history-detail summary{ cursor:pointer; color:var(--brand); font-weight:500; }
.alert-history-detail-pre{ margin:8px 0 0 0; padding:12px; background:var(--input-bg); border:1px solid var(--line); border-radius:8px; font-size:11px; white-space:pre-wrap; word-break:break-word; max-height:180px; overflow:auto; }
.alerts-empty{
  border:1px dashed var(--line);
  border-radius:10px;
  padding:14px;
  color:var(--muted);
  background:var(--panel);
}

/* Public header (for pages without sidebar) */
.publicHeader{
  position:sticky; top:0; z-index:20;
  background: var(--panel);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--line);
}
.publicHeader .inner{
  max-width:1200px; margin:0 auto; padding:14px 24px;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
}
.publicNav{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.publicNav a{padding:8px 10px;border-radius:10px;color:var(--muted);border:1px solid transparent}
.publicNav a:hover{background:var(--nav-hover); color:var(--text)}
.publicNav a.active{background:var(--nav-active-bg); border-color:var(--nav-active-border); color:var(--text)}
.container.narrow{max-width:980px}
.brand.hero{margin:22px 0 16px 0}
.brand.hero h1{margin:0}
.brand.hero p{margin:2px 0 0 0; color:var(--muted)}
.tabs[data-server-tabs]{margin:0 0 16px 0}


/* Roadmap steps */
.steps{margin:12px 0 0 18px; padding:0;}
.steps li{margin:8px 0; color:var(--text);}
.steps a{color:var(--brand); text-decoration:none;}
.steps a:hover{text-decoration:underline;}
/* List bar */
.list-bar{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  gap:14px;
  padding:12px 0;
}
.list-bar .list-bar-group{display:flex;align-items:center;gap:10px;}
.list-bar .list-bar-group.labeled{gap:6px;}
.list-bar .list-bar-group .label{font-size:12px;color:var(--muted);white-space:nowrap;}
.list-bar .list-bar-divider{width:1px;height:24px;background:var(--line);flex-shrink:0;}
.list-bar .list-bar-search{min-width:160px;max-width:220px;font-size:13px;}
.list-bar select.list-bar-select{
  min-width:100px;
  padding:8px 32px 8px 12px;
  font-size:13px;
  line-height:1.4;
  color:var(--text);
  background:var(--input-bg);
  border:1px solid var(--line);
  border-radius:var(--radius);
  cursor:pointer;
  appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2393a4c7' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 10px center;
}
.list-bar select.list-bar-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px rgba(96,165,250,0.2);}
.list-bar select.list-bar-select option{background:var(--panel);color:var(--text)}
.list-bar .list-bar-summary{font-size:13px;color:var(--muted);}
.list-bar .list-bar-pagenum{font-size:13px;color:var(--muted);min-width:70px;text-align:center;}

.row-active{outline:2px solid rgba(96,165,250,.35); outline-offset:-2px;}
.table-wrap{overflow:auto;-webkit-overflow-scrolling:touch;}
.hidden{display:none !important;}

/* ========== Responsive (media queries only) ========== */
@media (max-width: 640px) {
  html, body { overflow-x: hidden; }
  .split { flex-direction: column; }
  .formgrid { grid-template-columns: 1fr; }
  .container { padding-left: 16px; padding-right: 16px; }
  .main { padding-left: 16px; padding-right: 16px; }
  .card { padding: 14px; }
  .card.slim { padding: 12px; }
  .modal { padding: 12px; align-items: flex-start; padding-top: max(12px, env(safe-area-inset-top)); }
  .modal .sheet { width: 100%; max-width: 100%; max-height: calc(100vh - 24px); padding: 14px; }
  .sheet .head { flex-wrap: wrap; gap: 8px; }
  .publicHeader .inner { padding: 12px 16px; flex-wrap: wrap; }
  .list-bar { justify-content: flex-start; gap: 10px; }
  .list-bar .list-bar-search { min-width: 120px; max-width: 100%; }
  .alerts-filters { flex-direction: column; align-items: stretch; }
  .alerts-filters select { min-width: 0; width: 100%; }
  .alert-head { flex-direction: column; align-items: flex-start; }
  .alert-actions { flex-direction: column; align-items: flex-start; }
  .toastbar { flex-direction: column; align-items: stretch; }
  .toastbar .path { flex-direction: column; }
  .step { flex-direction: column; gap: 8px; }
  .callout { padding: 10px 12px; font-size: 13px; }
  .page-scope-note { padding: 8px 10px; font-size: 12px; }
  .domain-chip { font-size: 11px; padding: 2px 6px; max-width: 100%; }
  .kv-card .kv-row { flex-wrap: wrap; gap: 6px; }
  .kv-card .k { min-width: 0; }
  .kv-card .v { word-break: break-word; }
  .table th, .table td { font-size: 12px; padding: 10px; }
  .table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 0 -16px; padding: 0 16px; }
  .tabs { flex-wrap: wrap; gap: 8px; }
  .tabs .tab, .tab { padding: 8px 12px; font-size: 12px; }
  .servers-table th, .servers-table td { font-size: 12px; padding: 8px 10px; }
  .cred-card .cred-row { flex-direction: column; align-items: flex-start; gap: 6px; }
  .cred-card .cred-v-wrap { width: 100%; justify-content: flex-start; }
  .install-cmd-block { font-size: 11px; padding: 10px 12px; }
}
@media (max-width: 480px) {
  .container { padding-left: 12px; padding-right: 12px; }
  .main { padding-left: 12px; padding-right: 12px; }
  .hgroup h2 { font-size: 17px; }
  .btn { width: 100%; justify-content: center; min-height: 44px; padding: 10px 14px; }
  .btn.small { min-height: 36px; padding: 8px 12px; }
  .billing-card-actions .btn { width: 100%; }
  .kv-card .kv-row { flex-direction: column; align-items: flex-start; }
}
@media (min-width: 641px) {
  .container { padding: 20px; }
  .main { padding: 20px 22px 60px 22px; }
  .card { padding: 18px; }
  .table th, .table td { font-size: 13px; padding: 12px; }
}
@media (min-width: 768px) {
  .container { max-width: 1200px; margin-left: auto; margin-right: auto; padding: 24px; }
  .main { padding: 24px 26px 80px 26px; }
  .card { padding: var(--pad-lg); }
  .modal .sheet { width: min(860px, 100%); padding: 18px; }
}
@media (min-width: 981px) {
  .main { padding-left: 24px; }
}
