/* ============================================================
   style.css – Gedeelde stijlen (publiek + admin)
   ============================================================ */
:root {
  --bg:          #0a0a0f;
  --surface:     #111118;
  --surface2:    #1a1a24;
  --border:      #2a2a3a;
  --border2:     #3a3a50;
  --text:        #e8e8f0;
  --muted:       #6a6a88;
  --accent:      #4fffb0;
  --accent2:     #7c6dff;
  --up:          #4fffb0;
  --down:        #ff4f6d;
  --maintenance: #ffb74f;
  --warn:        #ffb74f;
  --partial:     #ffd94f;
  --glow:        rgba(79,255,176,0.15);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: 'Syne', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
}
body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: linear-gradient(var(--border) 1px, transparent 1px),
                    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.22;
  pointer-events: none;
  z-index: 0;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; font-weight: 600;
  padding: 9px 18px; border-radius: 7px; border: none;
  cursor: pointer; transition: all 0.18s;
  text-decoration: none; display: inline-flex;
  align-items: center; gap: 6px; letter-spacing: 0.4px; position: relative; z-index: 1;
}
.btn-ghost  { background: transparent; border: 1px solid var(--border2); color: var(--muted); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); }
.btn-accent { background: var(--accent); color: #0a0a0f; font-weight: 700; }
.btn-accent:hover { background: #6fffc0; box-shadow: 0 0 20px var(--glow); }
.btn-danger { background: var(--down); color: #fff; font-weight: 700; }
.btn-danger:hover { background: #ff6b85; }
.btn-warn   { background: var(--maintenance); color: #0a0a0f; font-weight: 700; }
.btn-warn:hover { background: #ffc76f; }
.btn-purple { background: var(--accent2); color: #fff; font-weight: 700; }
.btn-purple:hover { background: #9585ff; }
.btn-sm     { padding: 5px 11px; font-size: 11px; }

/* ── Inputs ──────────────────────────────────────────────── */
.input, .input-full {
  width: 100%; background: var(--bg); border: 1px solid var(--border2);
  border-radius: 8px; padding: 10px 14px; color: var(--text);
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  outline: none; transition: border-color 0.2s, box-shadow 0.2s;
}
.input { width: auto; flex: 1; }
.input:focus, .input-full:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--glow); }
.input::placeholder, .input-full::placeholder { color: var(--muted); }
select.input-full {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236a6a88' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
  padding-right: 34px; cursor: pointer;
}
select.input-full option { background: var(--surface2); }
textarea.input-full { resize: vertical; min-height: 90px; }

/* ── Forms ───────────────────────────────────────────────── */
.form-group  { margin-bottom: 16px; }
.form-label  { display: block; font-size: 10px; font-family: 'JetBrains Mono', monospace; color: var(--muted); margin-bottom: 5px; text-transform: uppercase; letter-spacing: 1px; }
.form-row    { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 14px; }
.modal-actions { display: flex; gap: 10px; margin-top: 22px; justify-content: flex-end; flex-wrap: wrap; }
.checkbox-group { display: flex; align-items: center; gap: 10px; margin: 12px 0 4px; }
.checkbox-group input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--accent); cursor: pointer; flex-shrink: 0; }
.checkbox-group label { font-size: 13px; cursor: pointer; }
.checkbox-grid { display: flex; flex-wrap: wrap; gap: 8px; padding: 10px; background: var(--bg); border: 1px solid var(--border2); border-radius: 8px; min-height: 48px; }
.checkbox-item { display: flex; align-items: center; gap: 6px; padding: 5px 12px; background: var(--surface2); border: 1px solid var(--border); border-radius: 6px; cursor: pointer; font-size: 13px; white-space: nowrap; transition: border-color 0.15s; }
.checkbox-item:hover { border-color: var(--border2); }
.checkbox-item input { accent-color: var(--accent); }

/* ── Alerts ──────────────────────────────────────────────── */
.alert { border-radius: 8px; padding: 12px 16px; margin-bottom: 20px; font-size: 13px; font-family: 'JetBrains Mono', monospace; border: 1px solid; }
.alert-success { background: rgba(79,255,176,.07); border-color: var(--up); color: var(--up); }
.alert-error   { background: rgba(255,79,109,.07); border-color: var(--down); color: var(--down); }
.alert-info    { background: rgba(124,109,255,.07); border-color: var(--accent2); color: var(--accent2); }

/* ── Status badges ───────────────────────────────────────── */
.status-badge { font-family: 'JetBrains Mono', monospace; font-size: 11px; font-weight: 500; padding: 4px 10px; border-radius: 20px; display: inline-flex; align-items: center; gap: 5px; letter-spacing: 0.4px; white-space: nowrap; }
.status-badge.up          { background: rgba(79,255,176,.1);  color: var(--up);          border: 1px solid rgba(79,255,176,.2); }
.status-badge.down        { background: rgba(255,79,109,.1);  color: var(--down);        border: 1px solid rgba(255,79,109,.2); }
.status-badge.maintenance { background: rgba(255,183,79,.1);  color: var(--maintenance); border: 1px solid rgba(255,183,79,.2); }
.status-badge.partial     { background: rgba(255,217,79,.1);  color: var(--partial);     border: 1px solid rgba(255,217,79,.2); }
.badge-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* ── PUBLIC PAGE ─────────────────────────────────────────── */
.pub-wrap { position: relative; z-index: 1; }
.pub-header { padding: 40px 24px 28px; max-width: 900px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.logo       { display: flex; align-items: center; gap: 12px; }
.logo-mark  { width: 38px; height: 38px; border: 2px solid var(--accent); border-radius: 8px; display: flex; align-items: center; justify-content: center; box-shadow: 0 0 20px var(--glow); }
.logo-dot   { width: 14px; height: 14px; background: var(--accent); border-radius: 50%; animation: pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.55;transform:scale(.82)} }
.logo-name  { font-size: 20px; font-weight: 800; letter-spacing: -.5px; }
.logo-sub   { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--muted); margin-top: 1px; }

.status-banner { max-width: 900px; margin: 0 auto 32px; padding: 0 24px; }
.banner-inner  { border-radius: 12px; padding: 18px 26px; border: 1px solid; display: flex; align-items: center; gap: 14px; font-size: 16px; font-weight: 700; transition: all .4s; }
.banner-inner.up          { background: rgba(79,255,176,.05); border-color: var(--accent); color: var(--accent); box-shadow: 0 0 40px rgba(79,255,176,.07); }
.banner-inner.down        { background: rgba(255,79,109,.05); border-color: var(--down); color: var(--down); box-shadow: 0 0 40px rgba(255,79,109,.07); }
.banner-inner.maintenance { background: rgba(255,183,79,.05); border-color: var(--maintenance); color: var(--maintenance); }
.banner-inner.partial     { background: rgba(255,217,79,.05); border-color: var(--partial); color: var(--partial); }
.banner-dot { width: 10px; height: 10px; border-radius: 50%; background: currentColor; flex-shrink: 0; animation: blink 1.6s ease-in-out infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }

.section       { max-width: 900px; margin: 0 auto 36px; padding: 0 24px; }
.section-title { font-family: 'JetBrains Mono', monospace; font-size: 10px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.section-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.service-group { margin-bottom: 22px; }
.group-label   { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 8px; padding-left: 2px; display: flex; align-items: center; gap: 8px; }
.group-label::after { content: ''; flex: 1; height: 1px; background: var(--border); opacity: .5; }
.service-list  { display: flex; flex-direction: column; gap: 6px; }
.service-row   { background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 14px 18px; display: flex; align-items: center; justify-content: space-between; transition: all .18s; }
.service-row:hover { border-color: var(--border2); background: var(--surface2); }
.service-info  { display: flex; align-items: center; gap: 12px; }
.service-icon  { width: 34px; height: 34px; border-radius: 7px; background: var(--surface2); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 17px; flex-shrink: 0; }
.service-name  { font-size: 15px; font-weight: 700; }
.service-desc  { font-size: 11px; color: var(--muted); font-family: 'JetBrains Mono', monospace; margin-top: 1px; }

.announced-maintenance { background: rgba(255,183,79,.05); border: 1px solid rgba(255,183,79,.2); border-radius: 10px; padding: 14px 18px; margin-bottom: 8px; display: flex; align-items: flex-start; gap: 12px; }
.announced-icon    { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.announced-content { flex: 1; }
.announced-title   { font-size: 14px; font-weight: 700; color: var(--maintenance); }
.announced-body    { font-size: 12px; color: var(--muted); font-family: 'JetBrains Mono', monospace; margin-top: 3px; line-height: 1.5; }
.announced-when    { font-size: 11px; color: var(--maintenance); font-family: 'JetBrains Mono', monospace; margin-top: 5px; }

.history-list     { display: flex; flex-direction: column; gap: 10px; }
.history-item     { background: var(--surface); border: 1px solid var(--border); border-left: 3px solid; border-radius: 0 10px 10px 0; padding: 16px 20px; }
.history-item.down        { border-left-color: var(--down); }
.history-item.maintenance { border-left-color: var(--maintenance); }
.history-item.up          { border-left-color: var(--up); }
.history-item.partial     { border-left-color: var(--partial); }
.history-top   { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 6px; }
.history-title { font-size: 14px; font-weight: 700; }
.history-meta  { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--muted); white-space: nowrap; }
.history-body  { font-size: 13px; color: var(--muted); line-height: 1.55; margin-bottom: 8px; }
.history-tags  { display: flex; gap: 6px; flex-wrap: wrap; }
.history-tag   { font-family: 'JetBrains Mono', monospace; font-size: 10px; padding: 2px 8px; border-radius: 4px; background: var(--surface2); color: var(--muted); border: 1px solid var(--border); }

.subscribe-box  { background: var(--surface); border: 1px solid var(--border2); border-radius: 14px; padding: 32px; text-align: center; position: relative; overflow: hidden; }
.subscribe-box::before { content: ''; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 200px; height: 1px; background: linear-gradient(90deg, transparent, var(--accent), transparent); }
.subscribe-title { font-size: 20px; font-weight: 800; margin-bottom: 6px; }
.subscribe-sub   { font-size: 13px; color: var(--muted); margin-bottom: 18px; font-family: 'JetBrains Mono', monospace; }
.subscribe-form  { display: flex; gap: 10px; max-width: 440px; margin: 0 auto 12px; }
.subscribe-note  { font-size: 11px; color: var(--muted); font-family: 'JetBrains Mono', monospace; }

.pub-footer { max-width: 900px; margin: 0 auto; padding: 20px 24px 40px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--border); font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--muted); flex-wrap: wrap; gap: 8px; }

.empty { text-align: center; padding: 32px; color: var(--muted); font-family: 'JetBrains Mono', monospace; font-size: 12px; border: 1px dashed var(--border); border-radius: 10px; }
.unsub-card  { background: var(--surface); border: 1px solid var(--border2); border-radius: 16px; padding: 48px 40px; width: 100%; max-width: 440px; text-align: center; position: relative; z-index: 1; }
.unsub-title { font-size: 22px; font-weight: 800; margin-bottom: 8px; }
.unsub-body  { font-size: 13px; color: var(--muted); font-family: 'JetBrains Mono', monospace; line-height: 1.6; }

.login-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; position: relative; z-index: 1; }
.login-card { background: var(--surface); border: 1px solid var(--border2); border-radius: 16px; padding: 46px 38px; width: 100%; max-width: 400px; position: relative; overflow: hidden; }
.login-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--accent2), var(--accent)); }
.login-title { font-size: 24px; font-weight: 800; margin-bottom: 4px; }
.login-sub   { font-size: 12px; color: var(--muted); font-family: 'JetBrains Mono', monospace; margin-bottom: 28px; }

.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.72); backdrop-filter: blur(5px); z-index: 1000; display: none; align-items: center; justify-content: center; padding: 24px; }
.modal-overlay.open { display: flex; }
.modal       { background: var(--surface); border: 1px solid var(--border2); border-radius: 16px; padding: 32px; width: 100%; max-width: 520px; max-height: 90vh; overflow-y: auto; position: relative; }
.modal-title { font-size: 20px; font-weight: 800; margin-bottom: 4px; }
.modal-sub   { font-size: 12px; color: var(--muted); font-family: 'JetBrains Mono', monospace; margin-bottom: 22px; }
.modal-close { position: absolute; top: 14px; right: 14px; background: var(--surface2); border: 1px solid var(--border); color: var(--muted); width: 28px; height: 28px; border-radius: 6px; cursor: pointer; font-size: 15px; display: flex; align-items: center; justify-content: center; transition: all .15s; }
.modal-close:hover { color: var(--text); border-color: var(--border2); }

@media (max-width: 640px) {
  .subscribe-form { flex-direction: column; }
  .form-row { grid-template-columns: 1fr; }
  .pub-header { flex-direction: column; align-items: flex-start; }
  .login-card { padding: 32px 24px; }
}
