/* SitePuls shell (ex-base.html). Bump ?v= in templates/base.html when this file changes. */
:root{
  --bg:#0b0f1a;--bg2:#111827;--bg3:#1a2235;--bg4:#1f2b40;
  --border:#1e2d4a;--border2:#2a3d5e;
  --text:#f0f4ff;--text2:#8ba4cc;--text3:#4a6080;
  --yellow:#facc15;--yellow2:#eab308;--yellow3:#fde047;
  --yellowBg:rgba(250,204,21,.08);--yellowBorder:rgba(250,204,21,.2);
  --blue:#3b82f6;--blue2:#2563eb;--blue3:#60a5fa;
  --blueBg:rgba(59,130,246,.08);--blueBorder:rgba(59,130,246,.2);
  --up:#22c55e;--down:#ef4444;--warn:#facc15;
  --font:'Inter',sans-serif;--mono:'JetBrains Mono',monospace;
  --r:8px;--shadow:0 4px 20px rgba(0,0,0,.3);
  --fs-base:18px;
}
html[data-theme="light"]{
  --bg:#f6f8fa;--bg2:#ffffff;--bg3:#f6f8fa;
  --text:#24292f;--text2:#57606a;--text3:#6e7781;
  --border:#d0d7de;--border2:#b6bec7;
  --blue:#0969da;--blueBg:rgba(9,105,218,.10);--blue2:#0969da;--blue3:#0550ae;--blueBorder:rgba(9,105,218,.25);
  --yellow:#f5c542;--yellowBg:rgba(245,197,66,.18);--yellow2:#e0b030;--yellow3:#fad054;--yellowBorder:rgba(245,197,66,.35);
  --up:#1a7f37;--down:#cf222e;--warn:#f5c542;
  --shadow:0 8px 24px rgba(140,149,159,.20);
  --bg4:#eaeef2;
}
[data-theme="light"] .card{
  background: var(--bg2);
  border-color: var(--border);
  box-shadow: var(--shadow);
}
[data-theme="light"] .finput,
[data-theme="light"] .fselect,
[data-theme="light"] textarea{
  background: #fff;
  border-color: var(--border);
  color: var(--text);
}
/* Light theme: topbar always readable (light bg, dark text) */
html[data-theme="light"] .topbar{
  background:rgba(246,248,250,.98);
  border-bottom-color:#d0d7de;
}
html[data-theme="light"] .topbar .logo{
  color:#24292f;
}
html[data-theme="light"] .topbar .logo:hover{
  color:#0969da;
}
html[data-theme="light"] .topbar .logo-name{
  color:#24292f;
}
html[data-theme="light"] .topbar .logo:hover .logo-name{
  color:#0969da;
}
html[data-theme="light"] .topbar .logo-dot{
  color:#0969da;
}
html[data-theme="light"] .topbar .nav-link,
html[data-theme="light"] .topbar .nav-dd-btn{
  color:#24292f;
}
html[data-theme="light"] .topbar .nav-link:hover,
html[data-theme="light"] .topbar .nav-dd-btn:hover{
  color:#0969da;
  background:rgba(9,105,218,.08);
}
html[data-theme="light"] .topbar .nav-link.active,
html[data-theme="light"] .topbar .nav-dd-btn.active,
html[data-theme="light"] .topbar .nav-dd.open .nav-dd-btn{
  color:#0969da;
  background:rgba(9,105,218,.08);
}
html[data-theme="light"] .topbar .lang-btn{color:#57606a;}
html[data-theme="light"] .topbar .lang-btn.on{color:#000;background:#f5c542;}
html[data-theme="light"] .topbar .lang-btn:hover:not(.on){color:#24292f;}
html[data-theme="light"] .topbar .nav-ico,
html[data-theme="light"] .topbar .theme-btn i{color:inherit;}

*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100vh}
body{font-family:var(--font);font-size:var(--fs-base);background:var(--bg);color:var(--text);line-height:1.6}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── TOPBAR ── */
.topbar{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(11,15,26,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);height:52px;overflow:visible;}
.topbar-inner{max-width:1200px;margin:0 auto;height:100%;padding:0 24px;display:flex;align-items:center;gap:8px;flex-wrap:nowrap;overflow:visible;}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none;margin-right:8px;flex-shrink:0;}
.logo-box{width:32px;height:32px;border-radius:7px;background:var(--yellow);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;color:#000;font-family:var(--mono);letter-spacing:-1px;}
.brand-logo{background:transparent;height:28px;width:auto;display:block;}
@media (min-width:900px){.brand-logo{height:30px;}}
.logo-name{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.3px;}
.logo-dot{color:var(--yellow);}
.topbar-nav-wrap{display:flex;align-items:center;flex:1;min-width:0;gap:8px;}
.topnav{display:flex;align-items:center;flex:1;min-width:0;flex-wrap:nowrap;white-space:nowrap;overflow-x:auto;overflow-y:visible;gap:8px;-ms-overflow-style:none;scrollbar-width:none;}
.topnav::-webkit-scrollbar{display:none;}
.topbar .nav-link{color:var(--text);opacity:.95;}
.topbar .nav-link:hover{opacity:1;}
.nav-link{color:var(--text);text-decoration:none;padding:0 8px;border-radius:6px;font-size:15px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;line-height:1;height:36px;box-sizing:border-box;margin:0;flex-shrink:0;opacity:.95;}
.nav-link:hover{color:var(--yellow);background:var(--yellowBg);opacity:1;}
.nav-link.active{color:var(--yellow);background:var(--yellowBg);opacity:1;}
.nav-dd{position:relative;display:inline-flex;align-items:center;flex-shrink:0;}
.nav-dd-btn{background:transparent;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:6px;height:36px;padding:0 10px;color:var(--text2);font-size:15px;font-weight:500;font-family:var(--font);border-radius:6px;transition:all .15s;white-space:nowrap;}
.nav-dd-btn:hover{color:var(--text);background:var(--bg3);}
.nav-dd-btn.active,.nav-dd.open .nav-dd-btn{color:var(--yellow);background:var(--yellowBg);}
.nav-dd-btn .dd-caret{font-size:12px;opacity:.8;}
.nav-dd-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;max-width:min(320px,calc(100vw - 24px));background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:6px;display:none;z-index:10001;box-shadow:var(--shadow);overflow-y:auto;}
.nav-dd.open .nav-dd-menu{display:block;}
.nav-dd-item{display:flex;align-items:center;padding:10px 12px;border-radius:8px;text-decoration:none;color:var(--text);font-weight:600;font-size:14px;white-space:nowrap;}
.nav-dd-item:hover{background:var(--bg2);}
.nav-ico{display:inline-block;font-size:17px;line-height:1;flex:0 0 auto;}
.nav-text{line-height:1;flex:0 0 auto;white-space:nowrap;}
.tnav{color:var(--text2);text-decoration:none;padding:0 12px;border-radius:6px;font-size:15px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;line-height:1;height:36px;box-sizing:border-box;margin:0;}
.tnav:hover{color:var(--text);background:var(--bg3);}
.tnav.active{color:var(--yellow);background:var(--yellowBg);}
.tnav-badge{font-size:12px;background:var(--down);color:#fff;padding:1px 5px;border-radius:10px;font-family:var(--mono);font-weight:700;flex-shrink:0;}
.top-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0;flex-wrap:nowrap;}
/* Language switcher */
.lang-sw{display:flex;align-items:center;gap:2px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:2px;height:36px;box-sizing:border-box;}
.lang-btn{padding:3px 9px;border-radius:4px;font-size:13px;font-weight:700;text-decoration:none;color:var(--text3);font-family:var(--mono);transition:all .15s;display:inline-flex;align-items:center;height:28px;line-height:1;box-sizing:border-box;}
.lang-btn.on{background:var(--yellow);color:#000;}
.lang-btn:hover:not(.on){color:var(--text);background:var(--bg4);}
.theme-btn{border:0;background:transparent;cursor:pointer;}
.theme-btn i{font-size:15px;line-height:1;}

/* User chip */
.user-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:4px 10px 4px 6px;height:36px;box-sizing:border-box;}
.user-av{width:24px;height:24px;border-radius:5px;background:var(--blue2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;}
.plan-tag{font-size:12px;font-weight:700;font-family:var(--mono);text-transform:uppercase;padding:2px 6px;border-radius:4px;display:inline-flex;align-items:center;line-height:1;height:22px;box-sizing:border-box;flex-shrink:0;}
.plan-agency{background:var(--yellowBg);color:var(--yellow);border:1px solid var(--yellowBorder);}
.plan-pro{background:var(--blueBg);color:var(--blue3);border:1px solid var(--blueBorder);}
.plan-starter{background:rgba(74,96,128,.15);color:var(--text3);border:1px solid var(--border);}
html[data-theme="light"] .topbar .plan-tag.plan-agency{background:rgba(245,197,66,.25);color:#b38600;border-color:rgba(245,197,66,.5);}
html[data-theme="light"] .topbar .plan-tag.plan-starter{background:rgba(110,119,129,.15);color:#424a53;border-color:#d0d7de;}

/* Mobile: two-row header; nav uses inline accordion (no overlay dropdowns) for reliable touch on iPhone */
@media (max-width: 768px){
  .topbar{min-height:52px;height:auto;}
  .topbar-inner{flex-wrap:wrap;align-content:flex-start;padding:0 12px 8px;gap:6px;min-height:52px;}
  .logo{order:1;}
  .top-right{order:2;margin-left:auto;}
  .topbar-nav-wrap{order:3;width:100%;flex:none;display:flex;flex-direction:column;align-items:stretch;gap:0;padding-top:6px;overflow:visible;}
  .topbar-nav-wrap .topnav{flex:0 0 auto;flex-wrap:wrap;gap:8px;padding-bottom:4px;}
  .topbar-nav-wrap .nav-dd{display:block;width:100%;flex-shrink:0;position:static;}
  .topbar-nav-wrap .nav-dd-btn{width:100%;justify-content:space-between;padding:10px 12px;text-align:left;border-radius:8px;margin-bottom:4px;}
  .topbar-nav-wrap .nav-dd-menu{position:static;top:auto;left:auto;min-width:0;max-width:none;width:100%;box-shadow:none;border-radius:8px;border:1px solid var(--border);margin:0 0 8px 0;padding:4px;display:none;overflow:visible;}
  .topbar-nav-wrap .nav-dd.open .nav-dd-menu{display:block;}
  .topbar-nav-wrap .nav-dd-item{display:flex;padding:12px 14px;border-radius:6px;min-height:44px;align-items:center;}
}
@media (max-width: 480px){
  .topbar-inner{padding:0 10px 8px;}
  .logo-name{font-size:17px;}
  .nav-link{padding:0 6px;font-size:14px;}
  .nav-dd-btn{padding:0 8px;font-size:14px;}
}
@media (max-width:420px){
  .topbar-inner{padding:0 8px 6px;}
  .top-right{gap:4px;}
  .top-right .nav-link-profile .nav-text{display:none;}
  .top-right .btn-logout .btn-logout-text{display:none;}
}

/* ── LAYOUT ── */
:root{--topbar-height:52px;}
.page-wrap{padding-top:var(--topbar-height);min-height:100vh;display:flex;flex-direction:column;}
.page-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:32px 24px;}
.page-content.narrow{max-width:900px;}
.page-content.center{max-width:480px;}
@media (max-width:480px){.page-content{padding:24px 16px;}.flash-zone{padding:12px 16px 0;}}
/* Mobile: topbar height set by JS (--topbar-height); bottom safe area so chat doesn't cover footer */
@media (max-width:768px){.page-wrap{padding-bottom:88px;}}
@media (max-width:480px){.page-wrap{padding-bottom:80px;}}

/* ── FLASH ── */
.flash-zone{max-width:1200px;margin:0 auto;padding:12px 24px 0;}
.flash{display:flex;align-items:center;gap:10px;padding:11px 16px;border-radius:var(--r);margin-bottom:8px;font-size:15px;border:1px solid;}
.flash.success{background:rgba(34,197,94,.07);border-color:rgba(34,197,94,.2);color:#4ade80;}
.flash.danger{background:rgba(239,68,68,.07);border-color:rgba(239,68,68,.2);color:#f87171;}
.flash.warning{background:var(--yellowBg);border-color:var(--yellowBorder);color:var(--yellow);}
.flash.info{background:var(--blueBg);border-color:var(--blueBorder);color:var(--blue3);}
.flash-x{margin-left:auto;cursor:pointer;background:none;border:none;color:inherit;font-size:16px;opacity:.6;padding:0;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--r);font-size:15px;font-weight:600;font-family:var(--font);text-decoration:none;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;margin:0;}
.btn-yellow{background:var(--yellow);color:#000;}.btn-yellow:hover{background:var(--yellow3);color:#000;}
.btn-blue{background:var(--blue2);color:#fff;border:1px solid var(--blue);}.btn-blue:hover{background:var(--blue);}
.btn-outline{background:transparent;color:var(--text2);border:1px solid var(--border2);}.btn-outline:hover{color:var(--text);border-color:var(--text3);background:var(--bg3);}
.btn-red{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.2);}.btn-red:hover{background:rgba(239,68,68,.18);}
.btn-sm{padding:5px 12px;font-size:14px;height:36px;line-height:1;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;}.btn-xs{padding:3px 8px;font-size:13px;}.btn-icon{padding:7px;}

/* ── CARD ── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);}
.card-hdr{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.card-body{padding:18px 20px;}
.card-label{font-size:12px;font-weight:700;font-family:var(--mono);text-transform:uppercase;letter-spacing:.6px;color:var(--text3);margin:0;}

/* ── STATUS INDICATORS ── */
.sdot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.sdot.up{background:var(--up);box-shadow:0 0 6px var(--up);}
.sdot.down{background:var(--down);box-shadow:0 0 6px var(--down);animation:sdBlink .8s steps(1) infinite;}
.sdot.paused{background:var(--warn);}
.sdot.unknown{background:var(--text3);}
@keyframes sdBlink{50%{opacity:0;}}
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:700;font-family:var(--mono);}
.badge-up{background:rgba(34,197,94,.1);color:#4ade80;border:1px solid rgba(34,197,94,.2);}
.badge-down{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.2);}
.badge-warn{background:var(--yellowBg);color:var(--yellow);border:1px solid var(--yellowBorder);}
.badge-info{background:var(--blueBg);color:var(--blue3);border:1px solid var(--blueBorder);}
.badge-neutral{background:var(--bg3);color:var(--text3);border:1px solid var(--border);}
.type-badge{font-size:12px;font-weight:700;font-family:var(--mono);text-transform:uppercase;letter-spacing:.4px;padding:2px 6px;border-radius:4px;background:var(--blueBg);color:var(--blue3);border:1px solid var(--blueBorder);}

/* ── FORM ── */
.fg{margin-bottom:14px;}
.flabel{display:block;font-size:14px;font-weight:600;color:var(--text2);margin-bottom:5px;}
.fhint{font-size:13px;color:var(--text3);margin-top:4px;}
.finput{width:100%;padding:9px 13px;background:var(--bg3);border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-size:15px;font-family:var(--font);outline:none;transition:border-color .15s;}
.finput:focus{border-color:var(--yellow);box-shadow:0 0 0 3px rgba(250,204,21,.07);}
.fselect{width:100%;padding:9px 32px 9px 13px;background:var(--bg3) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%234a6080' d='M5 6L0 0h10z'/%3E%3C/svg%3E") no-repeat right 13px center;border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-size:15px;font-family:var(--font);appearance:none;outline:none;cursor:pointer;}
.fselect:focus{border-color:var(--yellow);}

/* ── TABLE ── */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
table{width:100%;border-collapse:collapse;font-size:15px;}
th{text-align:left;padding:9px 16px;font-size:12px;font-weight:700;font-family:var(--mono);letter-spacing:.5px;text-transform:uppercase;color:var(--text3);border-bottom:1px solid var(--border);}
td{padding:11px 16px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:rgba(255,255,255,.015);}
@media (max-width:768px){
  .tbl-wrap table{font-size:14px;}
  .tbl-wrap th,.tbl-wrap td{padding:8px 10px;}
}

/* ── STAT BOXES ── */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:18px;}
.stat-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:14px;}
.slabel{font-size:12px;font-weight:700;font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:4px;}
.sval{font-size:24px;font-weight:800;font-family:var(--mono);}
.sv-up{color:var(--up);}.sv-down{color:var(--down);}.sv-warn{color:var(--warn);}
.sv-blue{color:var(--blue3);}.sv-text{color:var(--text);}

/* ── HELPERS ── */
.mono{font-family:var(--mono);}
.text-up{color:var(--up);}.text-down{color:var(--down);}.text-warn{color:var(--warn);}
.text-muted{color:var(--text2);}.text-xs{font-size:13px;}.text-sm{font-size:14px;}
.g2{display:flex;align-items:center;gap:8px;}.g3{display:flex;align-items:center;gap:12px;}
.between{display:flex;justify-content:space-between;align-items:center;}
.mb-4{margin-bottom:16px;}.mb-6{margin-bottom:24px;}.mt-4{margin-top:16px;}
.divider{border:none;border-top:1px solid var(--border);margin:16px 0;}
.empty{text-align:center;padding:56px 24px;color:var(--text2);}
.empty-icon{font-size:44px;margin-bottom:14px;color:var(--text3);}
.empty-title{font-size:19px;font-weight:700;color:var(--text);margin-bottom:8px;}
.ssl-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;font-size:14px;font-weight:600;font-family:var(--mono);}
.ssl-ok{background:rgba(34,197,94,.1);color:#4ade80;border:1px solid rgba(34,197,94,.2);}
.ssl-warn{background:var(--yellowBg);color:var(--warn);border:1px solid var(--yellowBorder);}
.ssl-bad{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.2);}

/* ── FOOTER ── */
.site-footer{border-top:1px solid var(--border);background:var(--bg2);margin-top:auto;}
.footer-inner{max-width:1200px;margin:0 auto;padding:28px 24px;display:grid;grid-template-columns:1fr 1fr;gap:32px 48px;align-items:start;}
.footer-col-brand{display:flex;flex-direction:column;gap:8px;min-width:0;align-items:flex-end;text-align:right;}
.footer-logo{display:inline-flex;align-items:center;gap:6px;font-size:15px;font-weight:700;color:var(--text2);text-decoration:none;}
.footer-logo img{height:20px;width:auto;background:transparent;}
.footer-tagline{font-size:13px;color:var(--text3);line-height:1.5;margin:0;}
.footer-copyright{font-size:13px;color:var(--text3);}
.footer-col{display:flex;flex-direction:column;gap:10px;min-width:0;}
.footer-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin:0;}
.footer-col ul{list-style:none;margin:0;padding:0;}
.footer-col li{margin:0;}
.footer-col a{font-size:14px;color:var(--text3);text-decoration:none;transition:color .15s;}
.footer-col a:hover{color:var(--yellow);}
@media (max-width:900px){
  .footer-inner{grid-template-columns:1fr 1fr;gap:28px 32px;}
}
@media (max-width:600px){
  .footer-inner{grid-template-columns:1fr;padding:24px 16px 28px;gap:24px;text-align:center;}
  .footer-col-brand{align-items:center;}
  .footer-col{align-items:center;}
  .footer-col ul{display:flex;flex-direction:column;align-items:center;}
  .site-footer{padding-bottom:env(safe-area-inset-bottom,0);}
}

