/* ──────────────────────────────────────────────────────────────────── */
/* Cyberlux — shared design tokens + reusable components                */
/* (Task #382)                                                          */
/* Imported by admin.html, work-with-pub.html, and the PUB Continuum   */
/* guide page so every Continuum-touching surface consumes the same     */
/* palette, fonts, notch sizes, glow values, and scanline overlay.      */
/* ──────────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;500;600;700;800;900&family=Rajdhani:wght@300;400;500;600;700&display=swap');

:root {
    /* Palette */
    --cx-gold:          #FFD700;
    --cx-gold-dim:      #b89400;
    --cx-gold-soft:     rgba(255, 215, 0, 0.10);
    --cx-gold-hair:     rgba(255, 215, 0, 0.28);
    --cx-gold-mid:      rgba(255, 215, 0, 0.45);
    --cx-gold-glow:     rgba(255, 215, 0, 0.55);
    --cx-void:          #050505;
    --cx-void-1:        #0a0a0e;
    --cx-void-2:        #0e0e16;
    --cx-void-3:        #14141f;
    --cx-text:          #f4f4ff;
    --cx-text-dim:      rgba(244, 244, 255, 0.62);
    --cx-text-mute:     rgba(244, 244, 255, 0.42);

    /* Persona accents (drawn from the existing cyberlux variables) */
    --cx-signal:        #5ab0ff;
    --cx-architect:     #ffb547;
    --cx-continuum:     #c88cff;
    --cx-trio:          #cfcfd6;
    --cx-bad:           #ff6b6b;
    --cx-good:          #4ecdc4;

    /* Shape language */
    --cx-notch:         14px;
    --cx-notch-sm:      8px;
    --cx-clip-notch:    polygon(var(--cx-notch) 0, 100% 0, 100% calc(100% - var(--cx-notch)), calc(100% - var(--cx-notch)) 100%, 0 100%, 0 var(--cx-notch));
    --cx-clip-notch-sm: polygon(var(--cx-notch-sm) 0, 100% 0, 100% calc(100% - var(--cx-notch-sm)), calc(100% - var(--cx-notch-sm)) 100%, 0 100%, 0 var(--cx-notch-sm));

    /* Glow / shadows */
    --cx-glow-soft:     0 0 18px rgba(255, 215, 0, 0.22);
    --cx-glow-strong:   0 0 38px rgba(255, 215, 0, 0.45);

    /* Fonts */
    --cx-font-display:  'Orbitron', sans-serif;
    --cx-font-body:     'Rajdhani', sans-serif;

    /* Scanline overlay */
    --cx-scanlines:     repeating-linear-gradient(0deg,
                            transparent 0 2px,
                            rgba(255, 215, 0, 0.025) 2px 3px);

    /* ─── Legacy aliases ─────────────────────────────────────────── */
    /* Existing surfaces (submission-flow.css, admin-continuum-cyberlux.css)
       were authored against `--cs-*` tokens before consolidation.
       Aliasing here keeps every selector pointed at one canonical
       palette so a colour tweak in `--cx-*` propagates everywhere. */
    --cs-gold:          var(--cx-gold);
    --cs-gold-dim:      var(--cx-gold-dim);
    --cs-gold-soft:     var(--cx-gold-soft);
    --cs-gold-hair:     var(--cx-gold-hair);
    --cs-amber-10:      var(--cx-gold-soft);
    --cs-amber-25:      var(--cx-gold-hair);
    --cs-amber-40:      var(--cx-gold-mid);
    --cs-amber-60:      var(--cx-gold-glow);
    --cs-glow-soft:     var(--cx-glow-soft);
    --cs-glow-strong:   var(--cx-glow-strong);
    --cs-void:          var(--cx-void);
    --cs-void-1:        var(--cx-void-1);
    --cs-void-2:        var(--cx-void-2);
    --cs-ink:           var(--cx-void-1);
    --cs-ink-2:         var(--cx-void-2);
    --cs-ink-3:         var(--cx-void-3);
    --cs-text:          var(--cx-text);
    --cs-text-dim:      var(--cx-text-dim);
    --cs-signal:        var(--cx-signal);
    --cs-architect:     var(--cx-architect);
    --cs-continuum:     var(--cx-continuum);
    --cs-good:          var(--cx-good);
    --cs-warn:          var(--cx-gold);
    --cs-bad:           var(--cx-bad);
    --cs-radius-sharp:  4px;
    --cs-radius-mid:    8px;
    --cs-notch:         var(--cx-notch);
    --cs-clip-notch:    var(--cx-clip-notch);
    --cs-font-display:  var(--cx-font-display);
    --cs-font-body:     var(--cx-font-body);
    --cs-gold-mid:      var(--cx-gold-mid);
    --cs-scanlines:     var(--cx-scanlines);
}

/* ─── Screen with glare ─────────────────────────────────────────── */
/* Wraps the persona dialog / message thread on both member-side    */
/* (.cs-dialog) and admin-side (#cs-qq-thread) so they read like a  */
/* slightly curved monitor with a soft, animated glare across the   */
/* glass. Glare is decorative-only and never blocks text or input.  */
.cx-screen {
    position: relative;
    margin-top: 14px;
    padding: 6px;
    background: linear-gradient(135deg, #050505 0%, #0d0d12 65%, #050505 100%);
    border: 1px solid var(--cx-gold-hair);
    box-shadow:
        0 0 0 1px rgba(255, 215, 0, 0.08) inset,
        0 18px 60px -28px rgba(255, 215, 0, 0.25);
    clip-path: var(--cx-clip-notch);
    isolation: isolate;
}
.cx-screen-eyebrow {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: var(--cx-font-display);
    font-size: 0.7em;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--cx-gold);
    padding: 6px 12px 4px;
    opacity: 0.85;
}
.cx-screen-eyebrow::before {
    content: '';
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--cx-gold);
    box-shadow: 0 0 10px var(--cx-gold);
    animation: cx-screen-pulse 2.2s ease-in-out infinite;
}
@keyframes cx-screen-pulse {
    0%, 100% { opacity: 0.5; box-shadow: 0 0 6px var(--cx-gold); }
    50%      { opacity: 1;   box-shadow: 0 0 14px var(--cx-gold); }
}
.cx-screen-glass {
    position: relative;
    background:
        radial-gradient(ellipse 140% 100% at 50% 110%, rgba(255, 215, 0, 0.04), transparent 70%),
        linear-gradient(180deg, #07070d 0%, #0a0a14 100%);
    border: 1px solid rgba(255, 215, 0, 0.14);
    border-radius: 2px;
    padding: 16px 18px;
    overflow: hidden;
    /* gentle screen curvature */
    box-shadow:
        inset 0 0 90px rgba(0, 0, 0, 0.55),
        inset 0 0 22px rgba(255, 215, 0, 0.04);
}
/* Scanline + grid texture sits below text (z-index 0 of children) */
.cx-screen-glass::before {
    content: '';
    position: absolute; inset: 0;
    background:
        repeating-linear-gradient(0deg, transparent 0 2px, rgba(255, 215, 0, 0.035) 2px 3px),
        repeating-linear-gradient(90deg, transparent 0 24px, rgba(255, 215, 0, 0.018) 24px 25px);
    pointer-events: none;
    z-index: 0;
    mix-blend-mode: screen;
    opacity: 0.85;
}
/* Animated diagonal glare strip — purely decorative */
.cx-screen-glass::after {
    content: '';
    position: absolute;
    top: -40%; left: -30%;
    width: 60%; height: 220%;
    background: linear-gradient(105deg,
        transparent 0%,
        rgba(255, 255, 255, 0.0) 35%,
        rgba(255, 240, 200, 0.06) 48%,
        rgba(255, 255, 255, 0.10) 50%,
        rgba(255, 240, 200, 0.06) 52%,
        rgba(255, 255, 255, 0.0) 65%,
        transparent 100%);
    transform: rotate(8deg) translateX(0);
    pointer-events: none;
    z-index: 1;
    animation: cx-screen-glare 11s ease-in-out infinite;
    filter: blur(2px);
    mix-blend-mode: screen;
    opacity: 0.7;
}
@keyframes cx-screen-glare {
    0%   { transform: rotate(8deg) translateX(-30%); opacity: 0; }
    20%  { opacity: 0.55; }
    50%  { transform: rotate(8deg) translateX(120%); opacity: 0.8; }
    70%  { opacity: 0.4; }
    100% { transform: rotate(8deg) translateX(260%); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
    .cx-screen-glass::after {
        animation: none;
        transform: rotate(8deg) translateX(60%);
        opacity: 0.35;
    }
    .cx-screen-eyebrow::before {
        animation: none;
        opacity: 0.85;
        box-shadow: 0 0 10px var(--cx-gold);
    }
}
/* All real content sits above the glare layer */
.cx-screen-glass > * { position: relative; z-index: 2; }

/* Persona-coded message bubble — used inside .cx-screen-glass for     */
/* the member dialog and the admin quick-question thread. The eyebrow  */
/* label uses Orbitron uppercase so each entry reads like a monitor    */
/* timestamp instead of a chat bubble.                                 */
.cx-msg {
    --cx-msg-accent: var(--cx-gold);
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 14px;
    padding: 12px 14px;
    margin: 8px 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.015), rgba(0, 0, 0, 0.3));
    border-left: 2px solid var(--cx-msg-accent);
    border-radius: 2px;
}
.cx-msg + .cx-msg { margin-top: 10px; }
.cx-msg-who {
    font-family: var(--cx-font-display);
    font-size: 0.7em;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--cx-msg-accent);
    padding-top: 2px;
    text-shadow: 0 0 8px rgba(255, 215, 0, 0.15);
}
.cx-msg-body {
    color: #e8e0c8;
    font-family: var(--cx-font-body);
    font-size: 0.96em;
    line-height: 1.55;
}
.cx-msg.persona-signal    { --cx-msg-accent: var(--cx-signal); }
.cx-msg.persona-architect { --cx-msg-accent: var(--cx-architect); }
.cx-msg.persona-continuum { --cx-msg-accent: var(--cx-continuum); }
.cx-msg.persona-director  { --cx-msg-accent: #ffd966; }
.cx-msg.persona-producer  { --cx-msg-accent: var(--cx-gold); }
.cx-msg.persona-trio      { --cx-msg-accent: var(--cx-trio); }
.cx-msg.persona-user      { --cx-msg-accent: #9adcb1; }
.cx-msg.persona-system    { --cx-msg-accent: rgba(255, 215, 0, 0.4); }

@media (max-width: 640px) {
    .cx-msg { grid-template-columns: 1fr; gap: 4px; }
    .cx-msg-who { padding-top: 0; }
}

/* ─── Modal (csConfirm / csAlert / csPrompt parity) ─────────────── */
/* Single shared modal language used by both the member-side prompts */
/* (submission-flow.js) and the admin queue confirm                  */
/* (admin-continuum-queue.js: csQueueConfirm). Notched panel, gold   */
/* border + glow, scanline backdrop, Orbitron eyebrow.               */
.cx-modal-overlay {
    position: fixed; inset: 0; z-index: 10000;
    background:
        radial-gradient(ellipse 80% 60% at 50% 30%, rgba(255, 215, 0, 0.06), transparent 60%),
        rgba(0, 0, 0, 0.72);
    display: flex; align-items: center; justify-content: center;
    padding: 24px;
    backdrop-filter: blur(2px);
}
.cx-modal-overlay::before {
    content: ''; position: absolute; inset: 0;
    background: var(--cx-scanlines);
    pointer-events: none; opacity: 0.4;
}
.cx-modal-panel {
    position: relative;
    background: linear-gradient(180deg, var(--cx-void-2), var(--cx-void-1));
    border: 1px solid var(--cx-gold-mid);
    border-left: 3px solid var(--cx-gold);
    max-width: 480px; width: 100%;
    padding: 22px 24px;
    color: var(--cx-text);
    box-shadow:
        var(--cx-glow-soft),
        inset 0 0 60px rgba(0, 0, 0, 0.55);
    clip-path: var(--cx-clip-notch);
}
.cx-modal-eyebrow {
    color: var(--cx-gold);
    font-family: var(--cx-font-display);
    font-size: 0.78em; letter-spacing: 0.22em; text-transform: uppercase;
    font-weight: 700; margin-bottom: 12px;
    text-shadow: 0 0 10px rgba(255, 215, 0, 0.25);
}
.cx-modal-body {
    color: var(--cx-text);
    font-family: var(--cx-font-body);
    font-size: 0.98em; line-height: 1.55;
    white-space: pre-wrap;
    margin-bottom: 18px;
}
.cx-modal-actions {
    display: flex; gap: 10px; justify-content: flex-end; flex-wrap: wrap;
}
.cx-modal-btn {
    font-family: var(--cx-font-display);
    font-size: 0.78em; letter-spacing: 0.18em; text-transform: uppercase;
    padding: 9px 18px;
    cursor: pointer;
    border: 1px solid var(--cx-gold-mid);
    background: rgba(255, 215, 0, 0.08);
    color: var(--cx-gold);
    clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px);
    transition: background 0.15s, box-shadow 0.15s, transform 0.05s;
}
.cx-modal-btn:hover { background: rgba(255, 215, 0, 0.18); box-shadow: var(--cx-glow-soft); }
.cx-modal-btn:active { transform: translateY(1px); }
.cx-modal-btn:focus-visible { outline: 2px solid var(--cx-gold); outline-offset: 2px; }
.cx-modal-btn-primary {
    background: linear-gradient(135deg, var(--cx-gold), var(--cx-gold-dim));
    color: #000;
    border-color: var(--cx-gold);
    text-shadow: none;
}
.cx-modal-btn-primary:hover { box-shadow: var(--cx-glow-strong); background: var(--cx-gold); }
.cx-modal-btn-secondary {
    background: rgba(255, 215, 0, 0.04);
    color: var(--cx-text-dim);
    border-color: var(--cx-gold-hair);
}
.cx-modal-btn-secondary:hover { color: var(--cx-text); border-color: var(--cx-gold-mid); }
/* Danger variant — still gold framing, with a red title accent + a
   red glow ring so destructive confirms read distinctly without
   leaving the cyberlux palette. */
.cx-modal-overlay.cx-modal-danger .cx-modal-panel {
    border-left-color: var(--cx-bad);
    box-shadow:
        0 0 28px rgba(255, 107, 107, 0.35),
        inset 0 0 60px rgba(0, 0, 0, 0.55);
}
.cx-modal-overlay.cx-modal-danger .cx-modal-eyebrow {
    color: #ff9898;
    text-shadow: 0 0 10px rgba(255, 107, 107, 0.35);
}
.cx-modal-overlay.cx-modal-danger .cx-modal-btn-primary {
    background: linear-gradient(135deg, #ff5b5b, #c63a3a);
    color: #fff; border-color: #c63a3a;
}
.cx-modal-overlay.cx-modal-danger .cx-modal-btn-primary:hover {
    box-shadow: 0 0 28px rgba(255, 107, 107, 0.55);
}

/* ─── Inputs / textareas / pill buttons ─────────────────────────── */
.cx-input, .cx-textarea {
    width: 100%;
    background: rgba(0, 0, 0, 0.55);
    color: var(--cx-text);
    border: 1px solid var(--cx-gold-hair);
    border-radius: 2px;
    padding: 10px 12px;
    font-family: var(--cx-font-body);
    font-size: 0.96em;
    transition: border-color 0.15s, box-shadow 0.15s;
}
.cx-textarea { min-height: 60px; resize: vertical; }
.cx-input:focus, .cx-textarea:focus {
    outline: none;
    border-color: var(--cx-gold-mid);
    box-shadow: 0 0 12px rgba(255, 215, 0, 0.18);
}
.cx-pill-btn {
    font-family: var(--cx-font-display);
    font-size: 0.78em; letter-spacing: 0.18em; text-transform: uppercase;
    padding: 8px 16px;
    background: rgba(255, 215, 0, 0.12);
    border: 1px solid var(--cx-gold-mid);
    color: var(--cx-gold);
    cursor: pointer;
    clip-path: polygon(8px 0, 100% 0, 100% calc(100% - 8px), calc(100% - 8px) 100%, 0 100%, 0 8px);
    transition: background 0.15s, box-shadow 0.15s;
}
.cx-pill-btn:hover { background: rgba(255, 215, 0, 0.22); box-shadow: var(--cx-glow-soft); }
.cx-pill-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* ─── Status banner (gold-tinted, used by member status surface) ─ */
.cx-status-banner {
    margin: 18px 0;
    padding: 18px 22px;
    background: rgba(255, 215, 0, 0.06);
    border: 1px solid var(--cx-gold-mid);
    border-left: 3px solid var(--cx-gold);
    color: #f0e8c8;
    clip-path: var(--cx-clip-notch);
}
.cx-status-banner h3 {
    margin: 0 0 6px;
    color: var(--cx-gold);
    font-family: var(--cx-font-display);
    font-size: 0.95em;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 700;
}
.cx-status-banner p {
    margin: 0;
    font-family: var(--cx-font-body);
    font-size: 0.98em;
    line-height: 1.5;
}

/* Admin quick-question screen — local spacing for the textarea + */
/* pill button + status line that sit below the persona thread.  */
.cx-qq-input { margin-top: 10px; }
.cx-qq-btn   { margin-top: 10px; }
.cx-qq-out   {
    margin-top: 10px;
    color: var(--cx-text-dim);
    font-family: var(--cx-font-body);
    font-size: 0.94em;
    white-space: pre-wrap;
    min-height: 1em;
}
.cx-qq-out.is-error   { color: #ff8888; }
.cx-qq-out.is-pending { color: var(--cx-signal); }
.cx-qq-out.is-ok      { color: #82e0aa; }

/* Tighter sub-banner used for queue/place-in-line rows under a   */
/* primary status banner.                                          */
.cx-status-banner-sub {
    margin: 12px 0;
    padding: 12px 14px;
}
.cx-status-banner-sub h3 { font-size: 0.85em; margin-bottom: 4px; }
.cx-status-banner-sub p  { font-size: 0.92em; line-height: 1.4; }

/* Small reusable text utilities */
.cx-eyebrow {
    color: var(--cx-gold);
    font-family: var(--cx-font-display);
    font-size: 0.78em;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 600;
}
.cx-meta {
    color: var(--cx-text-dim);
    font-family: var(--cx-font-body);
    font-size: 0.82em;
}
