/* =============================================
   WebStatus — assets/css/style.css
   Premium Dark Theme
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:#0a0c12; --bg-2:#0f111a; --bg-3:#161827;
  --border:rgba(255,255,255,0.07); --border-hi:rgba(255,255,255,0.14);
  --text:#e8eaf6; --text-muted:#8892b0;
  --accent:#6366f1; --accent-2:#8b5cf6;
  --accent-glow:rgba(99,102,241,0.4);
  --online:#22c55e; --offline:#ef4444; --warning:#f59e0b; --redirect:#3b82f6; --error:#ef4444;
  --radius:14px; --radius-sm:8px;
  --shadow:0 4px 32px rgba(0,0,0,0.4); --shadow-lg:0 8px 64px rgba(0,0,0,0.6);
  --transition:0.22s cubic-bezier(0.4,0,0.2,1);
}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;line-height:1.6;}
/* BG */
.bg-grid{position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(99,102,241,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,0.04) 1px,transparent 1px);
  background-size:48px 48px;}
.bg-orb{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;opacity:0.5;animation:orbFloat 12s ease-in-out infinite;}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,0.15),transparent 70%);top:-200px;left:-150px;}
.orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(139,92,246,0.12),transparent 70%);top:30%;right:-200px;animation-delay:-4s;}
.orb-3{width:400px;height:400px;background:radial-gradient(circle,rgba(34,197,94,0.08),transparent 70%);bottom:0;left:30%;animation-delay:-8s;}
@keyframes orbFloat{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-30px) scale(1.05);}}
/* TOPBAR */
.topbar{position:sticky;top:0;z-index:100;background:rgba(10,12,18,0.9);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);padding:0 2rem;height:62px;
  display:flex;align-items:center;justify-content:space-between;}
.topbar-logo{display:flex;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;letter-spacing:-0.3px;}
.topbar-logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  border-radius:9px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 16px var(--accent-glow);}
.topbar-logo-icon svg{width:16px;height:16px;color:white;}
.accent{color:var(--accent);}
.topbar-right{display:flex;align-items:center;gap:.75rem;}
.user-chip{display:flex;align-items:center;gap:8px;background:var(--bg-3);
  border:1px solid var(--border);border-radius:100px;padding:5px 14px 5px 8px;font-size:.82rem;color:var(--text-muted);}
.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  display:flex;align-items:center;justify-content:center;color:white;font-size:.7rem;font-weight:700;flex-shrink:0;}
.btn-icon-top{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid var(--border);
  background:transparent;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all var(--transition);text-decoration:none;}
.btn-icon-top:hover{border-color:var(--border-hi);color:var(--text);background:rgba(255,255,255,0.04);}
.btn-icon-top.danger:hover{border-color:rgba(239,68,68,0.4);color:#fca5a5;background:rgba(239,68,68,0.06);}
/* MAIN */
.dash-main{flex:1;max-width:1180px;margin:0 auto;padding:2.5rem 1.5rem;width:100%;position:relative;z-index:1;}
/* HEADER */
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem;}
.dash-title{font-size:1.5rem;font-weight:800;letter-spacing:-.5px;}
.dash-title-sub{font-size:.88rem;color:var(--text-muted);font-weight:400;margin-top:2px;}
.btn-primary{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:white;
  font-size:.88rem;font-weight:600;cursor:pointer;box-shadow:0 3px 14px rgba(99,102,241,0.4);
  transition:transform var(--transition),box-shadow var(--transition);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 5px 20px rgba(99,102,241,0.55);}
/* STATS */
.summary-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;}
.summary-card{background:var(--bg-2);border:1px solid var(--border);border-radius:16px;padding:1.25rem;
  display:flex;flex-direction:column;gap:4px;transition:border-color var(--transition);}
.summary-card:hover{border-color:var(--border-hi);}
.sc-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);}
.sc-value{font-size:1.7rem;font-weight:700;letter-spacing:-1px;line-height:1;}
.sc-value.g{color:var(--online);} .sc-value.r{color:var(--offline);} .sc-value.b{color:var(--redirect);}
/* TABS */
.dash-tabs{display:flex;gap:2px;background:var(--bg-2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:4px;width:fit-content;margin-bottom:1.5rem;}
.dash-tab{padding:7px 18px;border-radius:6px;border:none;background:transparent;
  color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition);}
.dash-tab.active{background:var(--bg-3);color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,.3);}
/* MONITOR GRID */
.monitor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem;}
.empty-block{grid-column:1/-1;text-align:center;padding:4rem 2rem;
  background:var(--bg-2);border:1px dashed var(--border-hi);border-radius:20px;}
.empty-block svg{opacity:.15;margin-bottom:1rem;}
.empty-block h3{font-size:1.1rem;font-weight:600;margin-bottom:.4rem;}
.empty-block p{color:var(--text-muted);font-size:.88rem;}
/* MONITOR CARD */
.monitor-card{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;overflow:hidden;
  display:flex;flex-direction:column;animation:cardIn .3s ease both;
  transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition);}
.monitor-card:hover{border-color:var(--border-hi);transform:translateY(-3px);box-shadow:var(--shadow);}
.monitor-card.inactive{opacity:.55;}
@keyframes cardIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.card-screenshot{position:relative;height:170px;overflow:hidden;background:var(--bg-3);border-bottom:1px solid var(--border);flex-shrink:0;}
.card-screenshot img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.monitor-card:hover .card-screenshot img{transform:scale(1.05);}
.ss-no-img{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--text-muted);font-size:.75rem;gap:6px;}
.ss-no-img svg{opacity:.2;}
.screenshot-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(10,12,18,.75));}
.ss-status{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:5px;
  padding:4px 10px;border-radius:100px;font-size:.72rem;font-weight:600;
  backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);}
.ss-status.online {background:rgba(34,197,94,.2);color:var(--online);}
.ss-status.offline{background:rgba(239,68,68,.2);color:var(--offline);}
.ss-status.error  {background:rgba(239,68,68,.2);color:var(--error);}
.ss-status.warning{background:rgba(245,158,11,.2);color:var(--warning);}
.ss-status.redirect{background:rgba(59,130,246,.2);color:var(--redirect);}
.ss-status.pending{background:rgba(255,255,255,.08);color:var(--text-muted);}
.ss-interval{position:absolute;top:10px;left:10px;padding:3px 9px;border-radius:100px;
  background:rgba(10,12,18,.7);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.1);
  font-size:.7rem;color:var(--text-muted);}
.card-body{padding:1.1rem 1.25rem;flex:1;display:flex;flex-direction:column;gap:.8rem;}
.card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;}
.card-label{font-size:.95rem;font-weight:600;line-height:1.2;word-break:break-word;}
.card-url-hint{font-size:.72rem;color:var(--text-muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px;}
.card-actions{display:flex;gap:4px;flex-shrink:0;}
.icon-btn{width:28px;height:28px;border-radius:7px;border:1px solid var(--border);background:transparent;
  color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition);}
.icon-btn:hover{border-color:var(--border-hi);background:rgba(255,255,255,.06);color:var(--text);}
.icon-btn.danger:hover{border-color:rgba(239,68,68,.4);color:var(--offline);background:rgba(239,68,68,.08);}
.card-metrics{display:flex;gap:1.25rem;}
.metric{display:flex;flex-direction:column;gap:1px;}
.metric-val{font-size:.88rem;font-weight:600;}
.metric-lbl{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;}
.metric-val.g{color:var(--online);} .metric-val.r{color:var(--offline);} .metric-val.y{color:var(--warning);}
.metric-val.accent{color:var(--accent);}
/* PERF ROW (Ø ms + LCP) */
.card-metrics-perf{display:flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,0.03);border:1px solid var(--border);
  border-radius:8px;padding:.35rem .7rem;margin-top:.1rem;}
.perf-item{display:flex;align-items:center;gap:.4rem;flex:1;}
.perf-lbl{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;}
.perf-val{font-size:.8rem;font-weight:600;color:var(--text);}
.perf-sep{width:1px;height:1rem;background:var(--border);}
/* LCP */
.lcp-val{display:flex;align-items:center;min-height:1em;}
.lcp-good{color:var(--online);}
.lcp-mid{color:var(--warning);}
.lcp-poor{color:var(--offline);}
.lcp-spinner{display:inline-block;width:9px;height:9px;border:2px solid var(--border-hi);
  border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
/* SPARKLINE */
.card-history{display:flex;align-items:flex-end;gap:2px;height:28px;}
.spark-bar{flex:1;min-width:4px;border-radius:2px;}
.spark-bar.online {background:var(--online);}  .spark-bar.offline{background:var(--offline);}
.spark-bar.error  {background:var(--error);}   .spark-bar.warning{background:var(--warning);}
.spark-bar.redirect{background:var(--redirect);}
/* CRON HINT */
.cron-hint{display:flex;align-items:center;gap:5px;font-size:.71rem;color:var(--text-muted);
  padding:5px 8px;background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.12);
  border-radius:8px;width:fit-content;}
/* LIVE INDICATOR */
.live-indicator{display:flex;align-items:center;gap:6px;font-size:.73rem;color:var(--text-muted);
  padding:4px 10px;background:rgba(99,102,241,.07);border:1px solid rgba(99,102,241,.15);border-radius:100px;}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--online);flex-shrink:0;
  box-shadow:0 0 0 0 rgba(34,197,94,.4);}
.live-dot.pulse{animation:livePulse .6s ease-out;}
@keyframes livePulse{
  0%  {box-shadow:0 0 0 0 rgba(34,197,94,.7);}
  70% {box-shadow:0 0 0 8px rgba(34,197,94,0);}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0);}
}
/* USER TABLE */
.user-table-wrap{background:var(--bg-2);border:1px solid var(--border);border-radius:20px;overflow:hidden;}
.user-table{width:100%;border-collapse:collapse;}
.user-table th{padding:12px 20px;text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.6px;
  color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-3);}
.user-table td{padding:13px 20px;font-size:.85rem;border-bottom:1px solid var(--border);}
.user-table tr:last-child td{border-bottom:none;}
.user-table tr:hover td{background:rgba(255,255,255,.02);}
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:100px;font-size:.7rem;font-weight:600;}
.badge-admin{background:rgba(99,102,241,.15);color:#a5b4fc;border:1px solid rgba(99,102,241,.25);}
.badge-user{background:rgba(255,255,255,.05);color:var(--text-muted);border:1px solid var(--border);}
/* MODAL */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(10,12,18,.8);backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .2s;}
.modal-overlay.open{opacity:1;pointer-events:auto;}
.modal{background:var(--bg-2);border:1px solid var(--border);border-radius:24px;padding:2rem;
  width:100%;max-width:480px;box-shadow:var(--shadow-lg);transform:scale(.95);
  transition:transform .25s cubic-bezier(0.34,1.56,0.64,1);}
.modal-overlay.open .modal{transform:scale(1);}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;}
.modal-title{font-size:1.05rem;font-weight:700;}
.modal-close{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;
  color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition);}
.modal-close:hover{background:rgba(239,68,68,.1);color:var(--offline);border-color:rgba(239,68,68,.3);}
.mform-group{display:flex;flex-direction:column;gap:6px;margin-bottom:1rem;}
.mform-label{font-size:.82rem;font-weight:500;color:var(--text-muted);}
.mform-input{padding:10px 14px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border-color var(--transition),box-shadow var(--transition);}
.mform-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(99,102,241,.15);}
.mform-hint{font-size:.73rem;color:var(--text-muted);margin-top:2px;}
.mform-check{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted);}
.mform-check input{width:16px;height:16px;accent-color:var(--accent);}
.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;}
.btn-modal-save{flex:1;padding:11px;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:white;
  font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 3px 14px rgba(99,102,241,.35);
  transition:transform var(--transition),box-shadow var(--transition);}
.btn-modal-save:hover{transform:translateY(-1px);}
.btn-modal-save:disabled{opacity:.5;cursor:not-allowed;}
.btn-modal-cancel{padding:11px 20px;border-radius:var(--radius-sm);border:1px solid var(--border);
  background:transparent;color:var(--text-muted);font-size:.9rem;cursor:pointer;transition:all var(--transition);}
.btn-modal-cancel:hover{border-color:var(--border-hi);color:var(--text);}
/* TOAST */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:300;background:var(--bg-2);
  border:1px solid var(--border);border-radius:12px;padding:.8rem 1.2rem;font-size:.83rem;
  box-shadow:var(--shadow-lg);max-width:320px;
  animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;}
@keyframes toastIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
@keyframes toastOut{from{opacity:1;}to{opacity:0;transform:translateY(16px);}}
/* DIVIDER */
.section-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin-bottom:1rem;}
/* LOG TABLE */
.log-table{width:100%;border-collapse:collapse;font-size:.78rem;}
.log-table thead th{padding:.55rem .75rem;text-align:left;color:var(--text-muted);font-weight:500;
  border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-2);z-index:1;
  white-space:nowrap;}
.log-table tbody tr{border-bottom:1px solid var(--border);transition:background var(--transition);}
.log-table tbody tr:last-child{border-bottom:none;}
.log-table tbody tr:hover{background:rgba(255,255,255,0.03);}
.log-table td{padding:.5rem .75rem;vertical-align:middle;}
.log-time{color:var(--text-muted);white-space:nowrap;font-family:monospace;font-size:.74rem;}
.log-code{font-family:monospace;color:var(--text);}
.log-ms{font-weight:600;color:var(--accent);}
.log-ssl-ok{color:var(--online);font-weight:500;}
.log-ssl-no{color:var(--text-muted);}
.log-ip{font-family:monospace;font-size:.72rem;color:var(--text-muted);}
.log-err{color:var(--offline);font-size:.74rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.gallery-time{font-size:.72rem;color:var(--text-muted);}
.gallery-resp{font-size:.7rem;color:var(--text-muted);}
@media(max-width:680px){
  .summary-stats{grid-template-columns:repeat(2,1fr);}
  .monitor-grid{grid-template-columns:1fr;}
  .topbar{padding:0 1rem;}
}
