


@font-face { font-family:'W95FA'; src:url('https://cdn.jsdelivr.net/npm/windows-95-font@1.0.2/w95fa.woff2') format('woff2'); font-display:swap; }
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
button { -webkit-appearance:none; appearance:none; border-radius:0; font-family:inherit; }

html, body { width:100%;height:100svh;overflow:hidden;font-family:var(--font-system);font-size:var(--text-lg);color:var(--w95-text);background:var(--w95-desktop); }

#desktop { width:100%;height:100svh;display:flex;align-items:center;justify-content:center;padding:14px;position:relative;box-sizing:border-box; }
#main { width:100%;max-width:1600px;height:100%;display:flex;gap:0; }

/* Icon image utilities — pixelated W95 icons at standard sizes */
.w95-icon-16 { width:16px;height:16px;flex-shrink:0;image-rendering:pixelated; }
.w95-icon-22 { width:22px;height:22px;flex-shrink:0;image-rendering:pixelated; }
.w95-icon-32 { width:32px;height:32px;flex-shrink:0;image-rendering:pixelated; }
.flex-spacer { flex:1; }
#explorer-content { flex:1;position:relative;min-height:0;display:flex;flex-direction:column; }
#login-ok-btn, #login-cancel-btn { min-width:70px; }
#taskbar-fg-tab { align-items:center;gap:4px;padding:2px 40px 2px 4px;font-size:var(--text-md);cursor:default;margin-left:4px; }
#booth-logo { width:100%;height:100%; }

/* W95 COMPONENTS — shared base classes (explorer uses as-is, booth overrides below) */
.w95-window { background:var(--w95-bg);display:flex;flex-direction:column;box-shadow:var(--shadow-raised);border:none; }
.w95-window-inner { flex:1;display:flex;flex-direction:column;min-height:0; }
.w95-titlebar { background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));color:var(--w95-title-text);padding:6px 8px;display:flex;align-items:center;gap:6px;font-weight:bold;font-size:var(--text-lg);flex-shrink:0;user-select:none;min-height:32px; }
.w95-titlebar-text { flex:1;white-space:nowrap;overflow:hidden;padding-left:2px; }
#explorer-titlebar-text { font-family:var(--font-display); }
.w95-login-titlebar { font-family:var(--font-display); }
.w95-title-btn { width:22px;height:20px;background:var(--w95-btn-face);box-shadow:var(--shadow-raised);border:none;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);cursor:default;color:var(--w95-text); }
.w95-title-btn:active { box-shadow:var(--shadow-pressed); }
.w95-btn { background-color:var(--w95-btn-face);background-image:none;box-shadow:var(--shadow-raised);border:none;padding:4px 14px;font-family:inherit;font-size:var(--text-md);color:var(--w95-text);cursor:default;white-space:nowrap;outline:none;-webkit-appearance:none;appearance:none;border-radius:0;}
.w95-btn:active { box-shadow:var(--shadow-pressed); }
.w95-capsule { display:flex;align-items:center;gap:6px;background-color:var(--w95-btn-face);background-image:none;box-shadow:var(--shadow-raised);border:none;padding:4px 10px;font-family:inherit;font-size:var(--text-base);color:var(--w95-text);cursor:default;white-space:nowrap;outline:none;-webkit-appearance:none;appearance:none;border-radius:0;box-sizing:border-box;}
.w95-capsule:active { box-shadow:var(--shadow-pressed); }
.w95-capsule svg { width:16px;height:16px;flex-shrink:0;fill:var(--w95-text); }
.w95-capsule.recording { background:var(--sec-red);color:#fff; }
.w95-capsule.recording svg { fill:var(--w95-border-light); }
.w95-status-section { box-shadow:var(--shadow-sunken);border:none;padding:2px 8px; }
.secure-indicator { display:flex;align-items:center;gap:6px;font-size:var(--text-base);letter-spacing:.5px; }
.secure-dot { width:8px;height:8px;border-radius:0;background:var(--w95-border-dark);box-shadow:none;image-rendering:pixelated; }
.secure-dot.state-locked { background:var(--w95-secure-green);animation:sblink 2s infinite;box-shadow:none; }
@keyframes sblink { 0%,70%{background:var(--w95-secure-green)}80%,90%{background:var(--w95-secure-dim)} }
.access-badge { font-size:var(--text-sm);letter-spacing:1px;padding:3px 8px;border:1px solid #333;background:#111;color:#f2f2f2;text-transform:uppercase;font-family:var(--font-display); }
.mono-readout { font-size:var(--text-lg);font-family:var(--font-display);letter-spacing:1px; }

/* ═══════════════════════════════════════════════════════════════
   LEFT SIDE — BOOTH PANEL (Terminal aesthetic)
   Dark bitmap terminal: #0a0a0a bg, #33ff33 accents, CRT scanlines
   100% independent from the W95 explorer on the right.
   All booth elements scoped under #booth-panel or .booth-*
   ═══════════════════════════════════════════════════════════════ */
#booth-panel { width:42%;flex-shrink:0; }
#booth-panel.w95-window { background:transparent;border:none; }
#booth-panel>.w95-window-inner { background:#0a0a0a;border:3px solid #33ff33;position:relative;overflow:hidden; }
#booth-panel>.w95-window-inner::after { content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(0deg,rgba(51,255,51,0.04) 50%,transparent 50%);background-size:100% 3px;pointer-events:none;z-index:var(--z-icons); }
#booth-panel>.w95-window-inner>.w95-titlebar { background:linear-gradient(90deg,#0a3a0a,#0a1a0a);border-bottom:1px solid #1a3a1a;padding:6px 8px;min-height:32px; }
#booth-panel .w95-titlebar-text { color:#33ff33;font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:1px; }
#booth-panel .w95-title-btn { background:#0a1a0a;border:1px solid #1a5a1a;box-shadow:none;color:#33ff33; }
#booth-panel .w95-title-btn:hover { border-color:#33ff33;background:#0a2a0a; }
#booth-panel .w95-title-btn:active { background:#0a3a0a; }
#booth-panel .w95-capsule,#booth-panel .w95-btn { background:#0a1a0a;border:1px solid #1a5a1a;box-shadow:none;padding:4px 10px;font-family:var(--font-terminal);color:#33ff33;transition:border-color .15s,background .15s; }
#booth-panel .w95-capsule:hover,#booth-panel .w95-btn:hover { border-color:#33ff33;background:#0a2a0a; }
#booth-panel .w95-capsule:active,#booth-panel .w95-btn:active { background:#0a3a0a; }
#booth-panel .w95-capsule svg { fill:#33ff33; }
#booth-panel .w95-capsule.recording { background:var(--sec-red);color:#fff; }
#booth-panel .w95-capsule.recording svg { fill:#f2f2f2; }

.booth-top-actions { display:flex;gap:6px;padding:3px 6px;background:transparent;border-bottom:1px solid #1a3a1a;flex-shrink:0;flex-wrap:wrap;position:relative;z-index:var(--z-base); }
.booth-scroll-area { flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden; }
.booth-chat-container { flex:1;position:relative;min-height:0;overflow:hidden;margin:0; }
#booth-chat { position:absolute;top:0;left:0;right:0;bottom:0;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;background:transparent;color:var(--w95-dos-text);font-family:var(--font-terminal);font-size:var(--text-md);line-height:1.5;border:none;z-index:var(--z-base); }
#booth-chat::before { content:'';flex:1 0 0; }
.booth-msg { max-width:90%;padding:2px 0;font-size:var(--text-md);line-height:1.5;font-family:var(--font-terminal);animation:bmi .15s steps(2); }
@keyframes bmi { from{opacity:0}to{opacity:1} }
.booth-msg.bot { align-self:flex-start;color:#f2f2f2;background:transparent;border:none; }
.booth-msg.usr { align-self:flex-start;color:var(--w95-dos-text);background:transparent;border:none;text-align:left; }
.booth-separator { align-self:center;text-align:center;font-family:var(--font-terminal);font-size:11px;line-height:1.4;margin:12px 0;white-space:pre;opacity:0.6; }
.uptime-wrap { display:none;align-items:center;gap:6px; }
.uptime-label { font-size:var(--text-base);letter-spacing:.5px;color:var(--w95-text); }
.uptime-led { background:#000;border:1px solid #1a5a1a;width:60px;height:22px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden; }
.uptime-ghost,.uptime-val { font-family:var(--font-terminal);font-size:14px;letter-spacing:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap; }
.uptime-ghost { color:#3a0800;opacity:0.5; }
.uptime-val { color:#e83000; }
.booth-separator .sep-border { color:var(--w95-dos-text);opacity:0.3;display:block; }
.booth-separator .sep-label { color:var(--w95-dos-text);letter-spacing:2px;display:block; }
.booth-separator.sep-cmd { align-self:flex-end;text-align:right;opacity:1; }
.booth-separator.sep-cmd .sep-border { color:var(--w95-dos-text);opacity:1;display:block; }
.booth-big-bubble-wrap { padding:0 8px 8px;flex-shrink:0;position:relative;z-index:var(--z-base); }
#booth-big-bubble { background:rgba(0,0,0,0.95);border:2px solid #33ff33;padding:12px 14px;font-size:calc(var(--text-md) + 2px);font-weight:500;color:#f2f2f2;position:relative;display:none;min-height:32px; }
#booth-big-bubble::after { display:none; }
.booth-cursor { display:inline-block;width:9px;height:17px;background:var(--w95-cursor-color);margin-left:4px;animation:bbk .6s step-end infinite;vertical-align:middle; }
@keyframes bbk { 0%,100%{opacity:1}50%{opacity:0} }
.booth-dots::after { content:'.';animation:bda 1.5s infinite; }
@keyframes bda { 0%,20%{content:'.'}40%{content:'..'}60%,100%{content:'...'} }
.booth-bottom-bar { display:flex;border-top:1px solid #33ff33;background:transparent;flex-shrink:0;align-items:stretch;position:relative;z-index:var(--z-base); }
.booth-avatar-box { width:18%;min-width:108px;max-width:165px;flex-shrink:0;background:#0a0a0a;border-right:1px solid #33ff33;display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden;position:relative;outline:1px solid #33ff33;outline-offset:-1px; }
.booth-avatar-frame { width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden; }
#booth-logo { width:100%;height:100%;display:block; }
.booth-input-col { flex:1;display:flex;flex-direction:column;justify-content:center;padding:6px 8px;gap:5px;min-width:0; }
.booth-input-row { display:flex;gap:6px;align-items:center; }
#booth-send-btn { padding:4px 14px;box-sizing:border-box;background:#0a1a0a;border:1px solid #1a5a1a;box-shadow:none;color:#33ff33;font-family:var(--font-terminal);font-size:var(--text-md);transition:border-color .15s,background .15s; }
#booth-send-btn:hover { border-color:#33ff33;background:#0a2a0a; }
#booth-send-btn:active { background:#0a3a0a; }
#booth-input { flex:1;border:1px solid #33ff33;box-shadow:none;padding:4px 10px;font-family:var(--font-terminal);font-size:var(--text-md);background:#0a0a0a;color:#33ff33;outline:none;min-width:0;box-sizing:border-box; }
#booth-input::placeholder { color:#1a5a1a;font-style:normal; }
.booth-mic-circle { padding:4px;box-sizing:border-box;flex-shrink:0;border-radius:0;background:#0a1a0a;border:1px solid #1a5a1a;box-shadow:none;display:flex;align-items:center;justify-content:center;cursor:default;outline:none;transition:border-color .15s,background .15s; }
.booth-mic-circle:hover { border-color:#33ff33;background:#0a2a0a; }
.booth-mic-circle:active { background:#0a3a0a; }
.booth-mic-circle svg { width:16px;height:16px;fill:#33ff33; }
.booth-mic-circle.recording { background:var(--sec-red); }
.booth-mic-circle.recording svg { fill:#f2f2f2; }
.booth-suggestions-wrap { display:flex;flex-direction:column;gap:2px; }
.booth-suggestions { display:flex;overflow:hidden;align-items:center;height:28px;padding:0; }
.booth-sug-track { display:flex;gap:5px;width:max-content;animation:sug-scroll 120s linear infinite; }
.booth-sug-track-reverse { display:flex;gap:5px;width:max-content;animation:sug-scroll-rev 130s linear infinite; }
@keyframes sug-scroll { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes sug-scroll-rev { 0%{transform:translateX(-50%)} 100%{transform:translateX(0)} }
.booth-sug-btn { background:#0a1a0a;border:1px solid #1a5a1a;box-shadow:none;padding:3px 10px;font-family:var(--font-terminal);font-size:var(--text-base);color:#33ff33;cursor:default;white-space:nowrap;outline:none;letter-spacing:.5px;opacity:0.6;transition:opacity .15s,border-color .15s,background .15s; }
.booth-sug-btn:hover { opacity:1;border-color:#33ff33;background:#0a2a0a; }
.booth-sug-btn.fresh { opacity:1;border-color:#33ff33;background:#0a2a0a;transition:none; }
.booth-suggestions:hover .booth-sug-track,
.booth-suggestions:hover .booth-sug-track-reverse { animation-play-state:paused; }

/* W95 resize grip — 13x13 diagonal ridges in bottom-right of statusbar */
.w95-resize-grip { position:absolute;bottom:0;right:0;width:13px;height:13px;cursor:default; }

/* ═══════════════════════════════════════════════════════════════
   RIGHT SIDE — EXPLORER PANEL (W95 aesthetic)
   Classic Windows 95: #c0c0c0 bg, beveled borders
   All explorer elements follow the standard W95 component system
   ═══════════════════════════════════════════════════════════════ */
#explorer-panel { flex:1;position:relative; }
#explorer-panel.w95-window { padding:3px;gap:0; }
#explorer-panel>.w95-window-inner { gap:0; }
.explorer-address { display:flex;align-items:center;gap:6px;padding:4px 4px;background:var(--w95-bg);border-top:1px solid #fff;border-bottom:1px solid var(--w95-bg-dark);flex-shrink:0; }
.explorer-address-label { font-size:var(--text-md);flex-shrink:0; }
.explorer-address-input { flex:1;box-shadow:var(--shadow-sunken);border:none;padding:3px 8px;font-family:inherit;font-size:var(--text-md);background:var(--w95-field);color:var(--w95-field-text); }
.explorer-back-bar{padding:3px 6px;background:var(--w95-bg);border-bottom:1px solid var(--w95-bg-dark);box-shadow:0 1px 0 #fff;flex-shrink:0}

/* ── Menu bar ── */
.explorer-menubar{display:flex;align-items:center;padding:4px 4px;background:var(--w95-bg);border-bottom:1px solid var(--w95-bg-dark);flex-shrink:0;position:relative;z-index:var(--z-menubar)}
.explorer-menubar.locked{pointer-events:none;opacity:0.5}
.explorer-menu-left{display:flex;gap:0;align-items:center}
.explorer-menu-right{margin-left:auto;display:flex;gap:2px;align-items:center}
.explorer-menu-trigger{position:relative;padding:2px 6px;cursor:default;font-size:var(--text-md);font-family:var(--font-system)}
.explorer-menu-trigger:hover{background:var(--w95-highlight);color:var(--w95-highlight-text)}
.explorer-menu-trigger .menu-key{text-decoration:underline}
.explorer-menu-drop{display:none;position:absolute;top:100%;left:0;background:var(--w95-bg);box-shadow:var(--shadow-raised),2px 2px 0 rgba(0,0,0,0.3);padding:2px;min-width:200px;z-index:var(--z-menu-drop);color:var(--w95-text)}
.explorer-menu-drop.open{display:block}
.explorer-menu-item{display:flex;align-items:center;gap:8px;padding:3px 20px;cursor:default;white-space:nowrap;font-size:var(--text-base);font-family:var(--font-system)}
.explorer-menu-item:hover{background:var(--w95-highlight);color:var(--w95-highlight-text)}
.explorer-menu-item.disabled{color:#808080}
.explorer-menu-item.disabled:hover{background:var(--w95-highlight);color:#808080}
.explorer-menu-sep{height:1px;background:var(--w95-bg-dark);margin:2px 4px;box-shadow:0 1px 0 #fff}
.explorer-menu-icon{padding:1px;cursor:pointer;display:flex;align-items:center;justify-content:center;width:22px;height:22px;box-shadow:inset -1px -1px 0 #818181,inset 1px 1px 0 #fff}
.explorer-menu-icon:hover{box-shadow:var(--shadow-tab-raised)}
.explorer-menu-icon:active{box-shadow:var(--shadow-tab-pressed)}
.explorer-menu-icon-sep{width:1px;height:18px;background:var(--w95-bg-dark);box-shadow:1px 0 0 #fff;margin:0 3px}

/* W95 Scrollbar — Figma-accurate 4-layer shadow, stippled track */
/* Hide all scrollbars globally */
* { scrollbar-width:none; }
*::-webkit-scrollbar { display:none; }

#explorer-body { flex:1;background:var(--w95-field);border:none;margin:2px 4px 3px;overflow:hidden;padding:0;position:relative; }
#explorer-body::after { content:'';position:absolute;top:0;left:0;width:100%;height:100%;box-shadow:var(--shadow-sunken);pointer-events:none;z-index:var(--z-loading); }
#explorer-taskbar { display:none;height:32px;background:var(--w95-bg);box-shadow:none;border:none;padding:2px 4px 2px;flex-shrink:0;position:relative;z-index:var(--z-taskbar); }
#explorer-taskbar::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:#fff;pointer-events:none;}
#start-btn { display:none;align-items:center;gap:4px;padding:2px 6px 2px 4px;font-size:var(--text-md);font-weight:bold;height:auto;cursor:default; }
#start-btn svg { flex-shrink:0; }
#start-menu { display:none;position:absolute;bottom:32px;left:4px;background:var(--w95-bg);box-shadow:var(--shadow-raised),2px 2px 0 rgba(0,0,0,0.3);border:none;padding:2px;min-width:220px;z-index:var(--z-start-menu); }
#start-menu.open { display:flex; }
.start-menu-sidebar{width:22px;background:linear-gradient(180deg,#000080,#1084d0);display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px}
.start-menu-sidebar span{color:#c1c1c1;font-size:9px;font-weight:bold;writing-mode:vertical-lr;transform:rotate(180deg);letter-spacing:1px;font-family:var(--font-system)}
.start-menu-items{flex:1}
.start-menu-divider{height:1px;background:var(--w95-bg-dark);margin:2px 4px;box-shadow:0 1px 0 #fff}
.start-menu-item { display:flex;align-items:center;gap:10px;padding:4px 16px 4px 6px;font-size:var(--text-md);cursor:default;white-space:nowrap;position:relative;}
.start-menu-item:hover { background:var(--w95-highlight);color:var(--w95-highlight-text); }
.start-menu-item:hover .start-menu-arrow{color:var(--w95-highlight-text)}

/* Taskbar secrets counter */
.taskbar-secrets{display:flex;align-items:center;gap:6px;font-size:var(--text-sm);font-family:var(--font-system);color:var(--w95-text);white-space:nowrap}
.taskbar-secrets-count{box-shadow:inset 1px 1px 0 #818181,inset -1px -1px 0 #fff;padding:2px 8px;font-size:var(--text-sm);font-family:var(--font-system);min-width:28px;text-align:center}

/* Taskbar window tabs */
.taskbar-tab{display:flex;align-items:center;gap:6px;padding:3px 24px 3px 10px;font-size:var(--text-sm);font-family:var(--font-system);cursor:default;white-space:nowrap;box-shadow:var(--shadow-tab-raised);background:var(--w95-bg);margin-left:4px;min-width:140px;overflow:hidden;text-overflow:ellipsis}
.taskbar-tab:active,.taskbar-tab.active{box-shadow:var(--shadow-tab-pressed);background:var(--w95-bg)}
.start-menu-item svg { flex-shrink:0; }
#explorer-body.proj-view { overflow-y:auto;position:relative;padding:0; }
#explorer-body.proj-view::after { display:none; }
.explorer-icon { display:flex;flex-direction:column;align-items:center;gap:5px;width:100px;padding:8px 4px;cursor:default;text-align:center;user-select:none;position:absolute;z-index:var(--z-base);transition:none; }
.explorer-icon:hover,.explorer-icon.active { background:var(--w95-highlight);color:var(--w95-highlight-text); }
.explorer-icon.dragging { z-index:100;opacity:0.85;cursor:grabbing; }

/* Logo glitch — CSS class-based, works on all sizes */
.logo-ghost { position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;opacity:0; }
.booth-avatar-box.glitching {
  animation:w95-logo-shake .45s steps(1) both;
}
.booth-avatar-box.glitching::before {
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:10;opacity:0;
  box-shadow:inset 0 0 0 2000px rgba(255,0,0,0.15);
}
.booth-avatar-box.glitching::after {
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  pointer-events:none;z-index:10;opacity:0;
  box-shadow:inset 0 0 0 2000px rgba(0,50,255,0.15);
}
.booth-avatar-box.glitching::before { animation:w95-logo-red .45s steps(1) both; }
.booth-avatar-box.glitching::after { animation:w95-logo-blue .45s steps(1) both; }

@keyframes w95-logo-shake {
  0%,75%,100% { transform:translateX(0); }
  15%         { transform:translateX(-3px); }
  35%         { transform:translateX(2px); }
  55%         { transform:translateX(-1px); }
}
@keyframes w95-logo-red {
  0%,75%,100% { opacity:0; transform:translateX(0); clip-path:inset(0 0 100% 0); }
  15%         { opacity:1; transform:translateX(3px); clip-path:inset(15% 0 55% 0); }
  35%         { opacity:1; transform:translateX(-4px); clip-path:inset(50% 0 15% 0); }
  55%         { opacity:1; transform:translateX(2px); clip-path:inset(25% 0 45% 0); }
}
@keyframes w95-logo-blue {
  0%,75%,100% { opacity:0; transform:translateX(0); clip-path:inset(0 0 100% 0); }
  15%         { opacity:1; transform:translateX(-3px); clip-path:inset(50% 0 20% 0); }
  35%         { opacity:1; transform:translateX(5px); clip-path:inset(10% 0 60% 0); }
  55%         { opacity:1; transform:translateX(-2px); clip-path:inset(60% 0 10% 0); }
}
.explorer-icon canvas { image-rendering:pixelated; }
.explorer-icon-label { font-size:var(--text-md);line-height:1.2;word-break:break-word; }

#explorer-list { display:none; }
.explorer-list-header { display:flex;background:var(--w95-bg);border-bottom:1px solid var(--w95-dark);padding:3px 8px;font-size:var(--text-md);font-weight:bold; }
.explorer-list-header span:nth-child(1){flex:1;padding-left:24px} .explorer-list-header span:nth-child(2){flex:0 0 auto;text-align:center;padding-right:8px}
.explorer-list-item { display:flex;align-items:center;gap:8px;padding:5px 8px;border-bottom:1px solid var(--w95-light);font-size:var(--text-md);cursor:default; }
.explorer-list-item:hover,.explorer-list-item.active { background:var(--w95-highlight);color:var(--w95-highlight-text); }
.explorer-list-item canvas { image-rendering:pixelated;flex-shrink:0; }
.explorer-list-name { flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis; }
.explorer-list-type { flex:0 0 auto;font-size:var(--text-base);color:var(--w95-dark);text-align:center;padding-right:8px;white-space:nowrap; }
.explorer-list-item:hover .explorer-list-type,.explorer-list-item.active .explorer-list-type { color:var(--w95-highlight-text);opacity:.7; }

/* Theme buttons in statusbar — same style as suggestion buttons */

/* POPUP — large preview, full-width 16:9 image */
#explorer-popup { position:absolute;z-index:var(--z-loading);background:var(--w95-bg);box-shadow:var(--shadow-raised);border:none;width:480px;font-size:var(--text-md);display:none;flex-direction:column;animation:pin .25s ease-out;padding:3px; }
@keyframes pin { from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)} }
.popup-titlebar { background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));color:var(--w95-title-text);padding:6px 10px;display:flex;align-items:center;gap:4px;font-weight:bold;font-size:15px; }
.popup-titlebar-text { flex:1;white-space:nowrap;overflow:hidden; }
.popup-thumb { width:calc(100% - 20px);aspect-ratio:16/9;background:var(--w95-text);box-shadow:var(--shadow-sunken);border:none;display:flex;align-items:center;justify-content:center;overflow:hidden;margin:10px 10px 8px; }
.popup-info { padding:0 10px 10px;display:flex;flex-direction:column;gap:4px; }
.popup-info-title { font-weight:bold;font-size:var(--text-lg); }
.popup-info-type { font-size:var(--text-md);color:var(--w95-dark); }
.popup-info-desc { font-size:var(--text-md);line-height:1.4; }

/* FILE POPUP — W95-style window for text files (About, Contact, etc.) */
#file-popup-overlay { position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.15);z-index:var(--z-file-popup);display:none; }
#file-popup-overlay.active { display:block; }
#file-popup { position:absolute;background:var(--w95-bg);box-shadow:var(--shadow-raised);border:none;display:flex;flex-direction:column;animation:pin .2s ease-out;padding:3px; }
.file-popup-titlebar { background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));color:var(--w95-title-text);padding:4px 8px;display:flex;align-items:center;gap:6px;font-weight:bold;font-size:var(--text-md);flex-shrink:0; }
.file-popup-titlebar-text { flex:1;white-space:nowrap;overflow:hidden; }
.file-popup-titlebar-icon { display:flex;align-items:center; }
.file-popup-titlebar-icon svg { width:14px;height:14px;fill:var(--w95-title-text); }
.file-popup-close { background-color:var(--w95-btn-face);background-image:none;box-shadow:var(--shadow-raised);border:none;width:20px;height:18px;display:flex;align-items:center;justify-content:center;cursor:default;font-size:var(--text-sm);font-weight:bold;padding:0;line-height:1;color:var(--w95-text);flex-shrink:0;-webkit-appearance:none;appearance:none;border-radius:0; }
.file-popup-body { flex:1;overflow-y:auto;padding:12px 14px;font-size:var(--text-md);line-height:1.6;color:var(--w95-text);background:var(--w95-field);margin:3px;box-shadow:var(--shadow-sunken);border:none;white-space:pre-wrap;font-family:var(--font-terminal); }
/* Game window frame */
.game-win-frame{background:var(--w95-bg);border:none;box-shadow:var(--shadow-raised),3px 3px 0 rgba(0,0,0,0.3);padding:3px;display:flex;flex-direction:column;max-width:95%;max-height:95%;}
.game-win-titlebar{background:linear-gradient(90deg,var(--w95-title-active-start),var(--w95-title-active-end));height:22px;display:flex;align-items:center;padding:0 3px;gap:3px;flex-shrink:0;}
.game-win-title{color:var(--w95-text-white);font-size:var(--text-sm);font-weight:bold;font-family:var(--font-display);flex:1;white-space:nowrap;}
.game-win-close{width:16px;height:14px;background:var(--w95-bg);border:none;box-shadow:var(--shadow-raised);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;}
.game-win-close:active{box-shadow:var(--shadow-pressed);}
.game-content-box{background:var(--w95-bg);overflow:hidden;}

/* D_V only: show taskbar */
@media (min-width:992px) {
  #explorer-taskbar { display:flex;align-items:center; }
  .explorer-menu-mv-only { display:none; }
}

/* ═══ W95 LOADING DIALOG — positioned over explorer panel ═══ */
#w95-loading-overlay { position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.15);z-index:var(--z-loading-full);display:none; }
#w95-loading-overlay.active { display:block; }
#w95-loading-dialog {
  position:absolute;
  background:var(--w95-bg);
  box-shadow:var(--shadow-raised);border:none;
  width:320px;max-width:90%;padding:3px;
}
#w95-loading-dialog .w95-ld-titlebar {
  background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));
  color:var(--w95-title-text);padding:3px 6px;font-weight:bold;font-size:var(--text-base);
  position:relative;z-index:1;
}
#w95-loading-dialog .w95-ld-body { padding:12px 14px 14px;position:relative;z-index:1; }
#w95-loading-dialog .w95-ld-status { font-size:var(--text-base);color:var(--w95-text);height:18px;overflow:hidden;margin-bottom:10px;line-height:18px; }
#w95-loading-dialog .w95-ld-bar {
  height:20px;background:var(--w95-field);
  box-shadow:var(--shadow-sunken);border:none;
  padding:2px;display:flex;gap:2px;align-items:stretch;
}
#w95-loading-dialog .w95-ld-block { width:12px;flex-shrink:0;background:transparent; }
#w95-loading-dialog .w95-ld-block.filled { background:var(--w95-bar-fill,#000080); }
/* Loading dialog scan/tear overlays */
#w95-loading-dialog .ld-scan { position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20;opacity:0;background:repeating-linear-gradient(0deg,transparent,transparent 1px,rgba(0,0,0,0.06) 1px,rgba(0,0,0,0.06) 2px); }
#w95-loading-dialog .ld-tear { position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:15;opacity:0; }
#w95-loading-dialog .ld-tear::before { content:'';position:absolute;left:-8px;width:calc(100% + 16px);height:3px;background:var(--w95-bg);top:30%; }
#w95-loading-dialog .ld-tear::after { content:'';position:absolute;left:-5px;width:calc(100% + 10px);height:2px;background:var(--w95-bg);top:68%; }
/* Glitch animation on loading dialog */
#w95-loading-dialog.glitching { animation:w95shake .45s steps(1) both; }
#w95-loading-dialog::before { content:'';position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;opacity:0;box-shadow:inset 0 0 0 2000px rgba(255,0,0,0.12); }
#w95-loading-dialog::after { content:'';position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;opacity:0;box-shadow:inset 0 0 0 2000px rgba(0,50,255,0.12); }
#w95-loading-dialog.glitching::before { animation:w95red .45s steps(1) both; }
#w95-loading-dialog.glitching::after { animation:w95blue .45s steps(1) both; }
#w95-loading-dialog.glitching .ld-scan { animation:w95scan .45s steps(1) both; }
#w95-loading-dialog.glitching .ld-tear { animation:w95tear .45s steps(1) both; }
/* Shared glitch keyframes (also used by loading dialog) */
@keyframes w95shake {
  0%,75%,100% { transform:translateX(0); }
  15%         { transform:translateX(-6px); }
  35%         { transform:translateX(5px); }
  55%         { transform:translateX(-3px); }
}
@keyframes w95red {
  0%,75%,100% { opacity:0; transform:translateX(0); clip-path:inset(0 0 100% 0); }
  15%         { opacity:1; transform:translateX(4px); clip-path:inset(20% 0 50% 0); }
  35%         { opacity:1; transform:translateX(-5px); clip-path:inset(55% 0 10% 0); }
  55%         { opacity:1; transform:translateX(3px); clip-path:inset(10% 0 65% 0); }
}
@keyframes w95blue {
  0%,75%,100% { opacity:0; transform:translateX(0); clip-path:inset(0 0 100% 0); }
  15%         { opacity:1; transform:translateX(-4px); clip-path:inset(55% 0 15% 0); }
  35%         { opacity:1; transform:translateX(6px); clip-path:inset(5% 0 65% 0); }
  55%         { opacity:1; transform:translateX(-3px); clip-path:inset(40% 0 25% 0); }
}
@keyframes w95scan {
  0%,75%,100% { opacity:0; }
  15%         { opacity:1; }
  35%         { opacity:0.7; }
  55%         { opacity:0.4; }
}
@keyframes w95tear {
  0%,75%,100% { opacity:0; transform:translateX(0); }
  15%         { opacity:1; transform:translateX(10px); }
  35%         { opacity:1; transform:translateX(-12px); }
  55%         { opacity:0.6; transform:translateX(6px); }
}

/* W95 MEDIA PLAYER */
.w95-media-player { background:var(--w95-bg);box-shadow:var(--shadow-raised);border:none;display:flex;flex-direction:column;margin-bottom:12px;padding:3px; }
.mp-titlebar { background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));color:var(--w95-title-text);padding:3px 8px;display:flex;align-items:center;gap:6px;font-weight:bold;font-size:var(--text-base); }
.mp-titlebar-icon { font-size:var(--text-sm); }
.mp-titlebar-text { flex:1;white-space:nowrap;overflow:hidden; }
.mp-screen { background:var(--w95-text);margin:3px;box-shadow:var(--shadow-sunken);border:none;overflow:visible;line-height:0; }
.mp-screen video, .mp-screen iframe { display:block;width:100%;aspect-ratio:16/9;object-fit:contain;background:var(--w95-text); }
.mp-screen img { display:block;width:100%;height:auto;background:var(--w95-text); }
.mp-screen canvas { display:block;width:100%;aspect-ratio:16/9;image-rendering:pixelated; }
.mp-progress { height:14px;margin:0 3px;background:var(--w95-bg);box-shadow:var(--shadow-sunken);border:none; }
.mp-progress-fill { height:100%;background:var(--w95-title-active);width:0%;transition:width 0.3s; }
.mp-controls { display:flex;align-items:center;gap:3px;padding:4px 4px; }
.mp-btn { background-color:var(--w95-btn-face);background-image:none;box-shadow:var(--shadow-raised);border:none;width:28px;height:24px;display:flex;align-items:center;justify-content:center;cursor:default;font-size:var(--text-sm);outline:none;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-appearance:none;appearance:none;border-radius:0;color:var(--w95-text); }
.mp-btn:focus { outline:none; }
@media (hover:hover) { .mp-btn:active { box-shadow:var(--shadow-pressed); } }
.mp-btn-play { width:34px; }
.mp-btn-play svg { width:12px;height:12px;fill:var(--w95-text); }
.mp-btn-stop svg { width:12px;height:12px;fill:var(--w95-text); }
.mp-btn-nav svg { width:12px;height:12px;fill:var(--w95-text); }
.mp-btn-fs { margin-left:2px; }
.mp-btn-fs svg { width:12px;height:12px;fill:var(--w95-text); }
.mp-time { font-size:var(--text-sm);margin-left:6px;color:var(--w95-text);background:var(--w95-field);border:1px solid var(--w95-dark);padding:2px 6px;font-family:var(--font-display);letter-spacing:1px; }
.mp-vol-icon { display:flex;align-items:center;margin-left:6px; }
.mp-vol-icon svg { width:16px;height:16px;fill:var(--w95-text); }
.mp-vol-fill { height:100%;background:var(--w95-title-active); }

.mp-gallery-counter { font-size:var(--text-sm);color:var(--w95-text);white-space:nowrap;margin-right:4px;background:var(--w95-field);border:1px solid var(--w95-dark);padding:2px 6px;font-family:var(--font-display);letter-spacing:1px; }

/* FULLSCREEN — handled by native browser fullscreen API */
/* FULLSCREEN — native browser fullscreen API */
video:fullscreen, video:-webkit-full-screen { background:var(--w95-text);width:100%;height:100%;object-fit:contain; }
.mp-screen:fullscreen, .mp-screen:-webkit-full-screen { background:var(--w95-text);width:100%;height:100%;overflow-y:auto;overflow-x:hidden;display:block; }
.mp-screen:fullscreen img, .mp-screen:-webkit-full-screen img { width:100%;height:auto;max-width:100%; }
.mp-screen:fullscreen video, .mp-screen:-webkit-full-screen video { width:100%;height:100%;object-fit:contain;aspect-ratio:auto; }

/* PROJECT DETAIL PAGE */
.proj-detail { width:100%;padding:12px;display:flex;flex-direction:column;gap:0; }
.proj-info-group { background:var(--w95-bg);box-shadow:var(--shadow-raised);border:none;margin-bottom:10px;padding:3px; }
.proj-info-header { background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));color:var(--w95-title-text);padding:4px 10px;font-weight:bold;font-size:15px; }
.proj-info-row { display:flex;padding:4px 10px;border-bottom:1px solid var(--w95-light);font-size:var(--text-md); }
.proj-info-row:last-child { border-bottom:none; }
.proj-info-label { width:60px;flex-shrink:0;font-weight:bold;color:var(--w95-dark);font-size:var(--text-base); }
.proj-info-value { flex:1;color:var(--w95-text); }
.proj-files-group { background:var(--w95-bg);box-shadow:var(--shadow-raised);border:none;margin-bottom:10px;padding:3px; }
.proj-files-header { background:var(--w95-bg);padding:4px 10px;font-weight:bold;font-size:var(--text-base);border-bottom:1px solid var(--w95-dark); }
.proj-file-item { padding:3px 10px;font-size:var(--text-base);border-bottom:1px solid var(--w95-light);cursor:pointer; }
.proj-file-item.active { background:var(--w95-highlight);color:var(--w95-highlight-text); }
.proj-file-item:last-child { border-bottom:none; }

/* RESPONSIVE */
@media (max-width:991px) {
  #desktop{padding:4px;height:100svh} #main{flex-direction:column;height:100svh}
  #explorer-panel{flex:1;order:1;min-height:0}
  /* Booth titlebar hidden on M_V — more room for chat */
  #booth-panel>.w95-window-inner>.w95-titlebar{display:none}
  #explorer-body{display:none}
  #explorer-body:has(#login-screen:not(.hidden)){display:flex;flex:1;min-height:0;overflow:visible}
  #explorer-body:has(#login-boot.active){display:block;flex:1;min-height:0;overflow:visible}
  #explorer-list{display:flex;flex-direction:column;flex:1;min-height:0}
  #explorer-content:has(#login-screen:not(.hidden)) #explorer-list{display:none}
  #explorer-content:has(#login-boot.active) #explorer-list{display:none}
  #explorer-list-items{flex:1;overflow-y:auto;background:var(--w95-field);border:none;margin:0 4px 4px;position:relative}
  #explorer-list-items::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;box-shadow:var(--shadow-sunken);pointer-events:none;z-index:var(--z-loading)}
  #explorer-list-header{border-bottom:none;border-top:1px solid var(--w95-bg-dark);box-shadow:inset 0 1px 0 #fff}
  #explorer-popup{display:none!important}
  #booth-panel{width:100%;flex:0 0 40%;min-height:200px;order:2}
  .explorer-address{display:flex;padding:2px 4px;gap:4px}
  .explorer-address-label{display:none}
  .explorer-address-input{font-size:var(--text-sm);padding:2px 6px}
  .explorer-menubar{padding:1px 3px}
  .explorer-menu-trigger{font-size:var(--text-sm);padding:2px 5px}
  .explorer-menu-drop{min-width:150px}
  .explorer-menu-item{font-size:var(--text-sm);padding:3px 12px;gap:6px}
  .explorer-menu-icon{width:16px;height:16px}
  .explorer-menu-icon svg{width:12px;height:12px}
  .explorer-menu-dv-only{display:none}
  .explorer-back-bar{padding:2px 4px}
  .explorer-back-bar .w95-btn{font-size:var(--text-sm);padding:2px 8px}
  .secure-indicator{font-size:var(--text-sm);gap:4px}
  .access-badge{font-size:var(--text-xs);padding:2px 6px}
  .booth-top-actions{gap:6px}
  /* Tighter chat */
  #booth-chat{padding:6px;gap:4px;font-size:var(--text-sm);line-height:1.3}
  .booth-msg{font-size:var(--text-sm);line-height:1.3;padding:1px 0}
  #booth-big-bubble{font-size:var(--text-sm);padding:6px 8px}
  #booth-big-bubble::after{display:none}
  .booth-big-bubble-wrap{padding:0 6px 6px}
  .booth-avatar-box{min-width:84px;max-width:108px}
  #session-time{display:none}
  /* Login screen on M_V — compact, top-aligned, no centering */
  #login-screen{padding:4px;padding-top:4px}
  .w95-login-dialog{width:100%;max-width:calc(100% - 20px)}
  .w95-login-body{padding:8px 8px 6px;gap:6px}
  .w95-login-icon{width:24px}
  .w95-login-icon svg{width:22px;height:22px}
  .w95-login-prompt{font-size:var(--text-sm);line-height:1.3;margin-bottom:0}
  .w95-login-label{font-size:var(--text-sm);width:55px}
  .w95-login-input{font-size:var(--text-md);padding:3px 4px}
  .w95-login-row{gap:6px}
  .w95-login-buttons{margin-top:0}
  .w95-login-buttons .w95-btn{font-size:var(--text-sm);padding:3px 10px;min-width:55px}
  .w95-login-error{font-size:var(--text-xs);min-height:0}
  .w95-login-titlebar{font-size:var(--text-sm);padding:2px 5px}
  /* DOS boot on M_V — scrollable */
  #login-boot{padding:8px;font-size:var(--text-xs);line-height:1.5;overflow-y:auto}
  .explorer-list-item{padding:8px 10px;gap:10px}
  .explorer-list-header{padding:5px 10px}
  .explorer-list-header span:nth-child(1){padding-left:26px}
  .w95-capsule{padding:2px 5px;font-size:var(--text-xs)}
  .w95-capsule svg{width:12px;height:12px}
  #booth-panel .w95-capsule{opacity:1;font-size:var(--text-xs)}
  #booth-panel .w95-capsule svg{fill:#33ff33}
  #booth-send-btn{font-size:var(--text-xs);padding:3px 8px}
  .booth-mic-circle{display:none}
  #booth-mic-capsule{display:flex!important}
  .booth-top-actions{justify-content:center}
  .w95-titlebar{padding:3px 6px;font-size:var(--text-base);min-height:26px}
  /* Compact project detail for M_V */
  .proj-detail{padding:6px}
  .proj-detail-mobile .w95-media-player{margin-bottom:4px}
  .proj-detail-mobile .mp-titlebar{padding:2px 6px;font-size:var(--text-sm)}
  .proj-detail-mobile .mp-screen{margin:2px}
  .proj-detail-mobile .mp-controls{padding:3px 4px;gap:4px}
  .proj-detail-mobile .mp-btn{width:28px;height:24px;font-size:var(--text-xs);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
  .proj-detail-mobile .mp-btn-play{width:32px}
  .proj-detail-mobile .mp-btn-nav svg{width:10px;height:10px}
  .proj-detail-mobile .mp-btn-fs svg{width:10px;height:10px}
  .proj-detail-mobile .mp-gallery-counter{font-size:var(--text-xs)}
  .proj-detail-mobile .mp-time{font-size:var(--text-xs)}
  .proj-detail-mobile .proj-info-header{padding:3px 8px;font-size:var(--text-sm)}
  .proj-detail-mobile .proj-info-row{padding:3px 8px;font-size:var(--text-sm);align-items:baseline}
  .proj-detail-mobile .proj-info-label{width:50px;font-size:var(--text-sm);flex-shrink:0}
  .proj-detail-mobile .proj-info-value{font-size:var(--text-sm)}
  .proj-detail-mobile .proj-files-header{padding:3px 8px;font-size:var(--text-xs)}
  .proj-detail-mobile .proj-file-item{padding:1px 6px;font-size:var(--text-xs)}
  .proj-detail-mobile .proj-files-group,.proj-detail-mobile .proj-info-group{margin-bottom:3px}
  .proj-detail-mobile .proj-files-grid{display:flex;flex-wrap:wrap}
  .proj-detail-mobile .proj-files-grid .proj-file-item{width:50%;border-bottom:1px solid var(--w95-light)}
}
@media (max-width:480px) {
  #desktop{padding:3px}
  .booth-msg{font-size:var(--text-sm);max-width:95%}
  #booth-big-bubble{font-size:var(--text-sm);padding:6px 8px}
  #booth-big-bubble::after{display:none}
  /* Capsule buttons: icon only, hide text labels */
  .w95-capsule span{display:none}
  .w95-capsule{padding:8px 10px}
  .w95-capsule svg{width:18px;height:18px}
  .booth-top-actions{gap:6px;padding:4px 6px}
  /* More booth space */
  #booth-panel{flex:0 0 50%;min-height:200px}
  /* Input area matches capsule size */
  .booth-input-col{padding:4px 6px 0;gap:4px}
  #booth-input{padding:6px 8px;font-size:var(--text-md)}
  #booth-send-btn{padding:6px 14px;font-size:var(--text-md)}
  .booth-mic-circle{padding:6px}
  .booth-mic-circle svg{width:18px;height:18px}
  /* List view: shrink type */
  .explorer-list-type{font-size:var(--text-sm)}
  .explorer-list-name{font-size:var(--text-sm)}
  .explorer-list-header{font-size:var(--text-sm)}
  /* Smaller titlebar */
  .w95-titlebar{padding:3px 6px;font-size:var(--text-base);min-height:26px}
  /* Smaller address bar */
  .explorer-address{padding:2px 4px}
  .explorer-address-input{font-size:var(--text-sm);padding:2px 6px}
  .explorer-address-label{font-size:var(--text-sm)}
  /* Hide fullscreen button on phone — does nothing useful */
  .mp-btn-fs{display:none}
  /* Login — tighter on phone */
  .w95-login-icon{display:none}
  .w95-login-body{padding:10px 8px 8px;gap:0}
  .w95-login-titlebar{font-size:var(--text-sm);padding:2px 5px}
}
@media (max-width:375px) {
  /* Hide top actions entirely — put into titlebar as tiny icons */
  .booth-top-actions{display:none}
  #booth-panel{flex:0 0 47%}
  .booth-avatar-box{min-width:72px;max-width:84px}
  .booth-input-col{padding:2px 4px 0;gap:2px}
  #booth-input{font-size:var(--text-sm);padding:2px 5px}
  .booth-sug-btn{font-size:var(--text-xs);padding:2px 6px}
  .booth-suggestions{height:24px}
  .booth-suggestions-row2{display:none}
}
/* ═══ W95 LOGIN / PASSWORD — inside explorer panel ═══ */
#login-screen {
  position:absolute;top:0;left:0;width:100%;height:100%;
  background:var(--w95-field);z-index:var(--z-boot);
  display:flex;align-items:safe center;justify-content:center;
  padding:20px;overflow-y:auto;
}
#login-screen.hidden { display:none; }

.w95-login-dialog {
  background:var(--w95-bg);
  box-shadow:var(--shadow-raised);border:none;
  width:360px;max-width:100%;padding:3px;
}
.w95-login-titlebar {
  background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));
  color:var(--w95-title-text);padding:3px 6px;font-weight:bold;font-size:var(--text-base);
  display:flex;align-items:center;gap:4px;
}
.w95-login-titlebar svg { width:14px;height:14px;fill:var(--w95-title-text);flex-shrink:0; }
.w95-login-titlebar span { flex:1; }
.w95-login-body { padding:16px 14px 14px;display:flex;gap:14px; }
.w95-login-icon { flex-shrink:0;width:44px;display:flex;align-items:flex-start;justify-content:center;padding-top:2px; }
.w95-login-form { flex:1;display:flex;flex-direction:column;gap:10px; }
.w95-login-prompt { font-size:var(--text-base);line-height:1.4;color:var(--w95-text);margin-bottom:2px; }
.w95-login-row { display:flex;align-items:center;gap:8px; }
.w95-login-label { font-size:var(--text-base);width:68px;flex-shrink:0;text-align:right; }
.w95-login-input {
  flex:1;box-shadow:var(--shadow-sunken);border:none;
  padding:3px 6px;font-family:inherit;font-size:var(--text-base);background:var(--w95-field);
  color:var(--w95-field-text);outline:none;
}
.w95-login-buttons { display:flex;gap:6px;justify-content:flex-end;margin-top:4px; }
.w95-login-error { font-size:var(--text-sm);color:var(--sol-card-red);font-weight:bold;min-height:16px;margin-top:-4px; }

/* DOS boot sequence — inside explorer panel */
#login-boot {
  position:absolute;top:0;left:0;width:100%;height:100%;
  background:var(--w95-dos-bg);z-index:99;
  display:none;padding:20px;overflow-y:auto;overflow-x:hidden;
  font-family:var(--font-terminal);font-size:calc(var(--text-base) + 2px);
  color:var(--w95-dos-text);line-height:1.7;
}
#login-boot .boot-hl { color:var(--w95-dos-text);font-weight:normal;font-size:inherit; }
#login-boot.active { display:block; }
#explorer-body:has(#login-boot.active) { overflow:visible; }
#explorer-body:has(#login-screen:not(.hidden)) { overflow:visible; }
#login-boot-text { white-space:pre-wrap; }

/* Security bar states */
.secure-dot.state-locked { background:var(--w95-secure-green);box-shadow:none; }

/* ═══ INITIAL PAGE LOAD — shows before anything else ═══ */
#page-load-overlay {
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:var(--w95-desktop);z-index:var(--z-page-load);
  display:flex;align-items:center;justify-content:center;
}
#page-load-overlay.hidden { display:none; }
#page-load-dialog {
  background:var(--w95-bg);
  box-shadow:var(--shadow-raised);border:none;
  width:300px;max-width:85%;padding:3px;
}
#page-load-dialog .pld-titlebar {
  background:linear-gradient(90deg,var(--w95-title-active),var(--w95-title-grad-end));
  color:var(--w95-title-text);padding:3px 6px;font-weight:bold;font-size:var(--text-base);
}
#page-load-dialog .pld-body { padding:12px 14px 14px; }
#page-load-dialog .pld-status { font-size:var(--text-base);color:var(--w95-text);margin-bottom:8px;height:18px; }
#page-load-dialog .pld-bar {
  height:20px;background:var(--w95-field);
  box-shadow:var(--shadow-sunken);border:none;
  padding:2px;display:flex;gap:2px;align-items:stretch;
}
#page-load-dialog .pld-block { width:12px;flex-shrink:0;background:transparent; }
#page-load-dialog .pld-block.filled { background:var(--w95-bar-fill,#000080); }

/* W95 window open animation — login pops up after page loads */
@keyframes w95windowOpen {
  0% { transform:scale(0.3);opacity:0; }
  50% { transform:scale(1.02);opacity:1; }
  100% { transform:scale(1);opacity:1; }
}

/* Hidden folder reveal — glitch into existence */
@keyframes folderReveal {
  0% { transform:scale(0);opacity:0;filter:hue-rotate(0deg); }
  20% { transform:scale(1.1);opacity:0.7;filter:hue-rotate(90deg); }
  35% { transform:scale(0.95);opacity:0.4;filter:hue-rotate(-45deg); }
  50% { transform:scale(1.05);opacity:0.9;filter:hue-rotate(30deg); }
  70% { transform:scale(0.98);opacity:1;filter:hue-rotate(-10deg); }
  100% { transform:scale(1);opacity:1;filter:hue-rotate(0deg); }
}
.folder-revealing { animation:folderReveal .6s ease-out; }
.hidden-folder .explorer-icon-label { color:#ff4444;text-shadow:0 1px 2px rgba(0,0,0,0.7); }

/* system32 special view — files shown as desktop icons */
.sys32-view { position:relative;width:100%;height:100%; }
.sys32-icon {
  position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px;
  cursor:pointer;padding:4px 6px;border:1px solid transparent;width:80px;text-align:center;
}
.sys32-icon:hover { background:var(--w95-hilight);border:1px dotted var(--w95-btn-text); }
.sys32-icon-img { width:32px;height:32px;image-rendering:pixelated; }
.sys32-icon-label { font-size:var(--text-xs);color:var(--w95-btn-text);word-break:break-all;line-height:1.2; }

/* In-explorer popup window for system32 files */
.sys32-popup {
  position:absolute;background:var(--w95-btn-face);border:2px solid;
  border-color:var(--w95-btn-hilight) var(--w95-btn-shadow) var(--w95-btn-shadow) var(--w95-btn-hilight);
  z-index:var(--z-modal);display:flex;flex-direction:column;
  min-width:200px;max-width:90%;max-height:85%;
}
.sys32-popup-titlebar {
  background:var(--w95-hilight);color:var(--w95-text-white);padding:2px 4px;font-size:var(--text-sm);font-weight:700;
  display:flex;justify-content:space-between;align-items:center;flex-shrink:0;
}
.sys32-popup-close {
  background:var(--w95-btn-face);border:2px solid;
  border-color:var(--w95-btn-hilight) var(--w95-btn-shadow) var(--w95-btn-shadow) var(--w95-btn-hilight);
  width:16px;height:14px;font-size:var(--text-2xs);line-height:10px;text-align:center;cursor:pointer;color:var(--w95-btn-text);
}
.sys32-popup-close:active {
  border-color:var(--w95-btn-shadow) var(--w95-btn-hilight) var(--w95-btn-hilight) var(--w95-btn-shadow);
}
.sys32-popup-body {
  padding:4px;overflow:auto;flex:1;background:var(--w95-window);
}
.sys32-popup-body img { max-width:100%;height:auto;display:block; }
.sys32-popup-body video { max-width:100%;height:auto;display:block;background:var(--w95-text); }
.sys32-popup-body .sys32-text {
  font-family:'W95FA',monospace;font-size:var(--text-sm);color:var(--w95-btn-text);
  white-space:pre-wrap;line-height:1.5;padding:8px;
}
.sys32-video-controls {
  display:flex;gap:4px;padding:3px 4px;background:var(--w95-btn-face);
  border-top:1px solid var(--w95-btn-shadow);
}
.sys32-video-controls button {
  background:var(--w95-btn-face);border:2px solid;
  border-color:var(--w95-btn-hilight) var(--w95-btn-shadow) var(--w95-btn-shadow) var(--w95-btn-hilight);
  font-family:'W95FA',monospace;font-size:var(--text-xs);padding:1px 8px;cursor:pointer;color:var(--w95-btn-text);
}
.sys32-video-controls button:active {
  border-color:var(--w95-btn-shadow) var(--w95-btn-hilight) var(--w95-btn-hilight) var(--w95-btn-shadow);
}
#login-screen .w95-login-dialog {
  animation:w95windowOpen .3s ease-out;
}
/* Whole desktop appears with a quick fade */
#desktop.booting { animation:w95desktopFade .4s ease-out; }
@keyframes w95desktopFade {
  0% { opacity:0; }
  100% { opacity:1; }
}

/* Layer 2: System interrupt flash in chat */
.system-interrupt {
  color:var(--sol-card-red);font-family:var(--font-terminal);font-size:var(--text-sm);
  opacity:0.7;display:inline;
  animation:sysFlash .6s steps(1) forwards;
}
@keyframes sysFlash {
  0%,70% { opacity:0.7; }
  71%,100% { opacity:0;display:none;height:0;overflow:hidden; }
}
.secure-dot.state-compromised { background:var(--w95-secure-green);box-shadow:none; }
.secure-dot.state-unauth { background:var(--sec-orange);animation:oblink 2s step-end infinite;box-shadow:none; }
@keyframes oblink{0%,70%{background:var(--sec-orange)}80%,90%{background:#663300}}
/* Red glitch applied briefly by JS at random intervals */
.secure-dot.glitch-red { background:var(--sol-card-red)!important;box-shadow:0 0 6px #cc0000!important; }

.secure-dot.state-breach { animation:dotBreachFlash 0.8s step-end infinite!important;background:var(--sol-card-red)!important; }
@keyframes dotBreachFlash {
  0%,100% { background:var(--sol-card-red); }
  50% { background:var(--sec-red); }
}
/* Badge styles per state */
.badge-unauth { background:#111;color:#e89640;border-color:#e8964080; }
.access-badge.badge-breach { background:var(--sol-card-red);color:var(--w95-bg-light);border-color:#990000;animation:breach-flash 0.8s step-end infinite; }
.access-badge.badge-breach.scrambling { animation:none;background:var(--sol-card-red);color:var(--w95-bg-light); }
@keyframes breach-flash { 0%,100%{background:var(--sol-card-red);color:var(--w95-bg-light)} 50%{background:var(--sec-red);color:#cc9999} }
/* State 3: secure text stays normal, badge gets the glitch */
/* ═══ VN INTRO DIALOG ═══ */
#vn-overlay { position:fixed;top:0;left:0;width:100%;height:100%;z-index:var(--z-vn);background:rgba(0,0,0,0.85);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 0.4s ease;pointer-events:auto;cursor:pointer;transform-origin:bottom left; }
#vn-overlay.visible { opacity:1; }
#vn-overlay.fadeout { opacity:0;transform:scale(0.15);transition:opacity 0.5s ease, transform 0.5s cubic-bezier(0.4,0,0.2,1);transform-origin:bottom left; }
#vn-box { display:flex;align-items:stretch;gap:0;max-width:800px;width:92%;position:relative; }
#vn-portrait { width:140px;flex-shrink:0;background:#0d0d0d;border:3px solid #33ff33;border-right:none;display:flex;align-items:center;justify-content:center;overflow:hidden;image-rendering:pixelated;position:relative; }
#vn-portrait svg { width:100%;height:auto; }
#vn-portrait::after { content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(0deg,rgba(51,255,51,0.08) 50%,transparent 50%);background-size:100% 4px;pointer-events:none; }
#vn-dialog { flex:1;background:#0d0d0d;border:3px solid #33ff33;padding:20px 24px;display:flex;flex-direction:column;justify-content:center;position:relative; }
#vn-name { font-family:'Silkscreen',monospace;font-size:11px;color:#33ff33;text-transform:uppercase;letter-spacing:2px;margin-bottom:8px;opacity:0.7; }
#vn-text { font-family:'Courier New',monospace;font-size:16px;color:#f2f2f2;line-height:1.5;min-height:48px; }
#vn-text .vn-cursor { display:inline-block;width:8px;height:16px;background:#33ff33;animation:bbk 0.7s step-end infinite;vertical-align:text-bottom;margin-left:2px; }
#vn-skip { position:absolute;bottom:8px;right:12px;font-family:'Silkscreen',monospace;font-size:9px;color:#33ff33;opacity:0.4;letter-spacing:1px; }
#vn-scanline { position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(0deg,rgba(51,255,51,0.03) 50%,transparent 50%);background-size:100% 3px;pointer-events:none; }
@media (max-width:991px) {
  .file-popup-body { font-size:var(--text-base);padding:10px 12px; }
  #vn-box { max-width:600px; }
  #vn-portrait { width:100px; }
  #vn-text { font-size:14px; }
}
@media (max-width:480px) {
  #vn-overlay { align-items:center; }
  #vn-box { flex-direction:column-reverse;align-items:stretch;margin-bottom:5vh; }
  #vn-portrait { width:100%;height:80px;border:3px solid #33ff33;border-top:none; }
  #vn-portrait svg { width:80px;height:auto; }
  #vn-dialog { padding:14px 16px; }
  #vn-text { font-size:13px; }
}

