/* eSéances status page — brand stylesheet
 * Inspired by insider.eseances.ch / app.eseances.ch.
 * Loaded once via <link> from the header override.
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Fraunces:opsz,wght@9..144,600;9..144,700;9..144,800&display=swap');

:root {
    --es-brand: #003da5;
    --es-brand-deep: #002a73;
    --es-brand-soft: rgba(0, 61, 165, 0.06);
    --es-brand-mid: rgba(0, 61, 165, 0.15);
    --es-bg: #f7f8fc;
    --es-card: #ffffff;
    --es-text: #1f2937;
    --es-text-soft: #6b7280;
    --es-text-mute: #9ca3af;
    --es-border: #e5e7eb;
    --es-radius: 18px;
}
@media (prefers-color-scheme: dark) {
    :root {
        --es-bg: #0b0d12;
        --es-card: #14171d;
        --es-text: #f3f4f6;
        --es-text-soft: #9ca3af;
        --es-text-mute: #6b7280;
        --es-border: #1f242b;
    }
}

body { background: var(--es-bg) !important; }
body, body *:not(svg):not(path):not(circle):not(line):not(polyline):not(rect) { font-family: 'Inter', ui-sans-serif, system-ui, sans-serif; }
.es-display { font-family: 'Fraunces', Georgia, 'Times New Roman', serif; font-feature-settings: "ss01", "ss02"; letter-spacing: -0.02em; }

/* ─────── Header ─────── */
.es-header { background: var(--es-card); border-bottom: 1px solid var(--es-border); }
.es-header-inner { max-width: 1100px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 24px; min-height: 72px; }
.es-logo-link { display: inline-flex; align-items: center; gap: 14px; text-decoration: none; line-height: 1; }
.es-logo-link picture { display: inline-flex; align-items: center; height: 44px; }
.es-logo-img { height: 44px; width: auto; display: block; }
.es-logo-tag { display: inline-flex; align-items: center; font-size: 11px; color: var(--es-text-soft); font-weight: 500; letter-spacing: 0.02em; padding-left: 14px; border-left: 1px solid var(--es-border); line-height: 1; align-self: stretch; }
@media (max-width: 640px) { .es-logo-tag { display: none; } }

.es-subscribe-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px; border-radius: 999px;
    background: linear-gradient(135deg, var(--es-brand), var(--es-brand-deep));
    color: #ffffff; text-decoration: none;
    font-size: 14px; font-weight: 600;
    box-shadow: 0 4px 14px -4px rgba(0, 61, 165, 0.55), inset 0 1px 0 rgba(255,255,255,0.2);
    transition: transform 120ms ease-out, box-shadow 120ms ease-out;
    border: 0; cursor: pointer;
}
.es-subscribe-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -4px rgba(0, 61, 165, 0.6); color: #fff; }
.es-subscribe-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
@media (max-width: 540px) { .es-subscribe-btn span { display: none; } .es-subscribe-btn { padding: 10px 12px; } }

/* ─────── Shell ─────── */
.es-shell { max-width: 1100px; margin: 0 auto; padding: 32px 24px 80px; color: var(--es-text); }
@media (max-width: 640px) { .es-shell { padding: 24px 16px 64px; } }
.es-shell-narrow { max-width: 720px; }

/* ─────── Hero ─────── */
.es-hero {
    position: relative; border-radius: 18px; padding: 22px 26px;
    color: #fff; overflow: hidden;
    background:
        radial-gradient(circle at 100% 0%, rgba(255,255,255,0.16), transparent 50%),
        radial-gradient(circle at 0% 100%, rgba(0,0,0,0.18), transparent 60%),
        linear-gradient(135deg, var(--es-hero-color, var(--es-brand)) 0%, var(--es-hero-color-soft, var(--es-brand-deep)) 100%);
    box-shadow: 0 12px 32px -16px var(--es-hero-color-shadow, rgba(0, 61, 165, 0.4));
}
.es-hero-row { display: flex; align-items: center; gap: 16px; }
.es-hero-icon {
    width: 44px; height: 44px; border-radius: 12px;
    background: rgba(255,255,255,0.18); backdrop-filter: blur(10px);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0; border: 1px solid rgba(255,255,255,0.3);
}
.es-hero-icon svg { width: 22px; height: 22px; }
.es-hero-title { margin: 0; font-size: 20px; font-weight: 700; line-height: 1.15; }
@media (min-width: 640px) { .es-hero-title { font-size: 24px; } }
.es-hero-sub { margin: 4px 0 0; font-size: 13px; opacity: 0.85; }

@keyframes es-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(255,255,255,0.6); }
    50% { box-shadow: 0 0 0 12px rgba(255,255,255,0); }
}
.es-hero-icon.is-active { animation: es-pulse 2.4s infinite; }

/* ─────── Welcome text ─────── */
.es-welcome { margin-top: 28px; padding: 0 4px; }
.es-welcome p { margin: 0 0 12px; font-size: 14px; line-height: 1.65; color: var(--es-text-soft); }
.es-welcome p:first-child { font-size: 15px; color: var(--es-text); font-weight: 500; }
.es-welcome p:last-child { margin-bottom: 0; }

/* ─────── Stats ─────── */
.es-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 16px; }
@media (min-width: 768px) { .es-stats { grid-template-columns: repeat(4, 1fr); } }
.es-stat-card { background: rgba(255,255,255,0.92); border-radius: 12px; padding: 12px 14px; border: 1px solid rgba(255,255,255,0.6); }
@media (prefers-color-scheme: dark) { .es-stat-card { background: rgba(20,23,29,0.85); border-color: rgba(255,255,255,0.08); } }
.es-stat-label { margin: 0 0 4px; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--es-text-soft); }
.es-stat-value { margin: 0; font-size: 22px; font-weight: 700; line-height: 1; color: var(--es-text); letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.es-stat-unit { font-size: 12px; font-weight: 500; color: var(--es-text-soft); margin-left: 3px; }

/* ─────── Sections ─────── */
.es-section { margin-top: 48px; }
.es-section-title { display: flex; align-items: baseline; justify-content: space-between; margin: 0 0 18px; font-family: 'Fraunces', serif; font-size: 22px; font-weight: 700; color: var(--es-text); letter-spacing: -0.01em; }
.es-section-meta { font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 600; color: var(--es-text-mute); text-transform: uppercase; letter-spacing: 0.06em; }

/* ─────── Cards / incidents ─────── */
.es-card {
    background: var(--es-card); border-radius: var(--es-radius);
    box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 12px 32px -16px rgba(0,0,0,0.10);
    border: 1px solid var(--es-border);
    padding: 24px;
}
.es-incident-card { position: relative; margin-bottom: 16px; overflow: hidden; }
.es-incident-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--es-card-color, var(--es-brand)); }
.es-incident-header { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.es-incident-title { margin: 0; font-family: 'Fraunces', serif; font-size: 18px; font-weight: 700; color: var(--es-text); text-decoration: none; letter-spacing: -0.01em; }
.es-incident-title:hover { text-decoration: underline; }

.es-pill { display: inline-flex; align-items: center; gap: 6px; padding: 5px 12px; border-radius: 999px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: #fff; }

.es-incident-impact { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.es-impact-tag {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--es-brand-soft); color: var(--es-brand);
    padding: 6px 12px; border-radius: 999px;
    font-size: 13px; font-weight: 500; border: 1px solid var(--es-brand-mid);
}
.es-impact-tag img { width: 16px; height: 16px; border-radius: 4px; flex-shrink: 0; }
.es-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }

.es-timeline { margin: 22px 0 0; padding: 0 0 0 26px; list-style: none; border-left: 2px solid var(--es-border); }
.es-timeline-item { position: relative; padding-bottom: 18px; }
.es-timeline-item:last-child { padding-bottom: 0; }
.es-timeline-dot { position: absolute; left: -34px; top: 4px; width: 16px; height: 16px; border-radius: 50%; border: 4px solid var(--es-card); background: var(--es-dot-color, var(--es-brand)); }
.es-timeline-head { display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }
.es-timeline-status { font-size: 14px; font-weight: 600; color: var(--es-text); }
.es-timeline-time { font-size: 12px; color: var(--es-text-soft); font-variant-numeric: tabular-nums; }
.es-timeline-tag { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; background: var(--es-brand-soft); color: var(--es-brand); padding: 3px 8px; border-radius: 999px; }
.es-timeline-body { margin: 6px 0 0; font-size: 14px; line-height: 1.6; color: var(--es-text-soft); }
.es-timeline-body p { margin: 0 0 8px; }
.es-timeline-body p:last-child { margin: 0; }

/* ─────── Maintenance ─────── */
.es-maint-card { background: linear-gradient(135deg, rgba(0,61,165,0.08), rgba(0,61,165,0.02)); border: 1px solid var(--es-brand-mid); border-radius: var(--es-radius); padding: 22px 24px; margin-bottom: 12px; }
.es-maint-title { display: inline-flex; align-items: center; gap: 10px; margin: 0; font-family: 'Fraunces', serif; font-size: 17px; font-weight: 700; color: var(--es-brand); text-decoration: none; letter-spacing: -0.01em; }
.es-maint-title:hover { text-decoration: underline; color: var(--es-brand); }
.es-maint-meta { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-top: 14px; font-size: 13px; color: var(--es-text); }
.es-maint-body { margin-top: 14px; font-size: 14px; line-height: 1.6; color: var(--es-text-soft); }

/* ─────── Components ─────── */
.es-comp-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.es-comp-group { background: var(--es-card); border: 1px solid var(--es-border); border-radius: var(--es-radius); box-shadow: 0 1px 3px rgba(0,0,0,0.04); overflow: hidden; }
.es-comp-group-head { padding: 14px 20px; font-family: 'Fraunces', serif; font-size: 15px; font-weight: 700; color: var(--es-text); border-bottom: 1px solid var(--es-border); background: var(--es-brand-soft); }
.es-comp-list { list-style: none; padding: 0; margin: 0; }
.es-comp-item { padding: 18px 20px; border-bottom: 1px solid var(--es-border); }
.es-comp-item:last-child { border-bottom: 0; }
.es-comp-row { display: flex; align-items: center; gap: 12px; }
.es-comp-icon { width: 36px; height: 36px; border-radius: 10px; background: var(--es-brand-soft); flex-shrink: 0; display: flex; align-items: center; justify-content: center; overflow: hidden; border: 1px solid var(--es-brand-mid); }
.es-comp-icon img { width: 100%; height: 100%; object-fit: contain; padding: 4px; }
.es-comp-icon-fallback { width: 12px; height: 12px; border-radius: 50%; background: var(--es-brand); }
.es-comp-text { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.es-comp-name { font-size: 15px; font-weight: 600; color: var(--es-text); }
.es-comp-desc { font-size: 12px; color: var(--es-text-soft); line-height: 1.4; }
.es-comp-status { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; }
.es-comp-uptime { font-size: 20px; font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: -0.02em; color: var(--es-text); }
.es-comp-uptime-suffix { font-size: 11px; font-weight: 500; color: var(--es-text-mute); margin-left: 2px; }

.es-spark { width: 100%; height: 38px; margin-top: 12px; display: block; }
.es-bars90 { display: flex; gap: 1px; margin-top: 8px; height: 30px; border-radius: 4px; overflow: hidden; }
.es-bars90 span { flex: 1; min-width: 1px; transition: transform 100ms ease-out; }
.es-bars90 span:hover { transform: scaleY(1.15); }
.es-bars90-axis { display: flex; justify-content: space-between; margin-top: 6px; font-size: 10px; color: var(--es-text-mute); font-weight: 500; }

/* ─────── History ─────── */
.es-history-day { margin-bottom: 18px; }
.es-history-day-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--es-text-mute); margin-bottom: 8px; }
.es-history-list { list-style: none; padding: 0; margin: 0; }
.es-history-item { display: flex; align-items: center; gap: 12px; padding: 14px 18px; margin-bottom: 6px; background: var(--es-card); border: 1px solid var(--es-border); border-radius: 12px; font-size: 14px; text-decoration: none; color: var(--es-text); transition: background 100ms; }
.es-history-item:hover { background: var(--es-brand-soft); }
.es-history-item-resolved { font-size: 11px; color: #10b981; font-weight: 700; margin-left: auto; text-transform: uppercase; letter-spacing: 0.06em; }

/* ─────── Forms (subscribe / manage) ─────── */
.es-form-card { background: var(--es-card); border: 1px solid var(--es-border); border-radius: var(--es-radius); padding: 28px; box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 12px 32px -16px rgba(0,0,0,0.10); }
.es-page-title { font-family: 'Fraunces', serif; font-size: 30px; font-weight: 700; color: var(--es-text); letter-spacing: -0.02em; margin: 0 0 8px; }
.es-page-intro { color: var(--es-text-soft); margin: 0 0 24px; font-size: 15px; }
.es-flash { padding: 14px 16px; border-radius: 12px; margin-bottom: 20px; font-size: 14px; }
.es-flash-success { background: rgba(16, 185, 129, 0.08); border: 1px solid rgba(16, 185, 129, 0.25); color: #047857; }
.es-flash-error { background: rgba(239, 68, 68, 0.08); border: 1px solid rgba(239, 68, 68, 0.25); color: #b91c1c; }
.es-field { margin-bottom: 18px; }
.es-label { display: block; font-size: 13px; font-weight: 600; color: var(--es-text); margin-bottom: 6px; }
.es-input { display: block; width: 100%; padding: 10px 14px; border-radius: 10px; border: 1px solid var(--es-border); background: var(--es-card); color: var(--es-text); font-size: 14px; transition: border-color 120ms, box-shadow 120ms; box-sizing: border-box; }
.es-input:focus { outline: none; border-color: var(--es-brand); box-shadow: 0 0 0 3px rgba(0,61,165,0.12); }
.es-input-code { font-family: 'JetBrains Mono', ui-monospace, monospace; text-align: center; font-size: 28px; letter-spacing: 0.4em; padding: 12px; }
.es-help { font-size: 12px; color: var(--es-text-mute); margin: 6px 0 0; }
.es-fieldset { border: 0; padding: 0; margin: 0 0 18px; }
.es-legend { font-size: 13px; font-weight: 600; color: var(--es-text); margin: 0 0 10px; padding: 0; }
.es-checkbox { display: flex; align-items: center; gap: 10px; padding: 6px 0; cursor: pointer; font-size: 14px; }
.es-checkbox input { width: 16px; height: 16px; accent-color: var(--es-brand); cursor: pointer; }
.es-group-card { border: 1px solid var(--es-border); border-radius: 12px; overflow: hidden; margin-bottom: 12px; }
.es-group-head { padding: 10px 14px; background: var(--es-brand-soft); font-size: 13px; font-weight: 600; color: var(--es-text); border-bottom: 1px solid var(--es-border); }
.es-group-body { padding: 12px 14px; display: grid; grid-template-columns: 1fr; gap: 6px; }
@media (min-width: 640px) { .es-group-body { grid-template-columns: 1fr 1fr; } }
.es-form-actions { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--es-border); }
.es-btn-primary {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 10px 22px; border-radius: 999px; border: 0;
    background: linear-gradient(135deg, var(--es-brand), var(--es-brand-deep));
    color: #ffffff; font-size: 14px; font-weight: 600; cursor: pointer;
    box-shadow: 0 4px 14px -4px rgba(0, 61, 165, 0.55), inset 0 1px 0 rgba(255,255,255,0.2);
    transition: transform 120ms, box-shadow 120ms;
    text-decoration: none;
}
.es-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px -4px rgba(0, 61, 165, 0.6); color: #fff; }
.es-btn-danger { background: linear-gradient(135deg, #ef4444, #b91c1c); box-shadow: 0 4px 14px -4px rgba(239, 68, 68, 0.55), inset 0 1px 0 rgba(255,255,255,0.2); }
.es-btn-danger:hover { box-shadow: 0 8px 20px -4px rgba(239, 68, 68, 0.6); }
.es-link-danger { color: #b91c1c; font-size: 13px; font-weight: 500; text-decoration: none; }
.es-link-danger:hover { text-decoration: underline; }
.es-link-soft { color: var(--es-text-soft); font-size: 13px; text-decoration: none; }
.es-link-soft:hover { color: var(--es-text); }

/* Sub-info row in manage */
.es-info-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; margin-bottom: 24px; }
.es-info-item { background: var(--es-brand-soft); border: 1px solid var(--es-brand-mid); border-radius: 12px; padding: 12px 14px; font-size: 13px; }
.es-info-label { font-size: 11px; font-weight: 700; color: var(--es-text-soft); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 2px; }
.es-info-value { font-weight: 600; color: var(--es-text); }
.es-info-value-meta { color: #10b981; font-size: 11px; font-weight: 700; margin-left: 6px; text-transform: uppercase; }
.es-info-value-meta-warn { color: #d97706; }
