/* ============================================================ Cross-component rules. Per-theme palettes live in frontend/themes//theme.css and are loaded dynamically by js/system/theme-registry.js (plus the inline bootstrap in index.html for the current theme on first paint). Anything in this file should consume tokens via var(--token) so it adapts to whichever theme is active. ============================================================ */ /* Danger zone banner: red-tinted glass card with a solid red left edge. Same recipe as the Traefik "not installed" notice but tinted with var(--status-danger). Reads cleanly on every theme thanks to alpha overlays driven by --status-danger-rgb. */ .danger-zone-section { margin-top: 14px; margin-bottom: 14px; padding: 20px 24px; background: rgba(var(--status-danger-rgb), 0.10); border: 1px solid rgba(var(--status-danger-rgb), 0.30); border-left: 4px solid var(--status-danger); border-radius: 12px; color: var(--text-primary); box-shadow: inset 0 1px 0 rgba(var(--text-rgb), 0.06); } .danger-zone-header { margin-bottom: 20px; text-align: center; } .danger-zone-header h3 { margin: 0 0 8px 0; color: var(--status-danger); font-size: 20px; font-weight: 600; display: flex; align-items: center; justify-content: center; gap: 8px; } .danger-zone-header p { margin: 0; color: var(--text-secondary); font-size: 14px; font-style: italic; } /* Header-only variant used as a page-level banner (e.g. config?=features). Without inner content below the header, the header's bottom margin is wasted whitespace, and the section needs its own bottom margin to separate from whatever follows. */ .danger-zone-section--header-only { margin-bottom: 24px; } .danger-zone-section--header-only .danger-zone-header { margin-bottom: 0; } .danger-zone-section--header-only .danger-zone-header p { margin-top: 4px; } /* Inline variant — same recipe as .danger-zone-section, smaller padding. */ .danger-zone-banner { background: rgba(var(--status-danger-rgb), 0.10); border: 1px solid rgba(var(--status-danger-rgb), 0.30); border-left: 4px solid var(--status-danger); border-radius: 12px; padding: 14px 18px; margin-bottom: 18px; display: flex; align-items: flex-start; gap: 12px; color: var(--text-primary); box-shadow: inset 0 1px 0 rgba(var(--text-rgb), 0.06); } .danger-zone-content { display: flex; align-items: center; gap: 12px; } .danger-zone-icon { color: var(--status-danger); flex-shrink: 0; font-size: 20px; } .danger-zone-text { color: var(--text-primary); font-size: 14px; line-height: 1.4; } .danger-zone-text strong { color: var(--status-danger); align-items: flex-start; } /* Solid status / accent buttons — the default look used by dark-blue and light. Nebula overrides these below to get the welcome-button gradient + glow recipe. */ .install-btn, .btn-install, .app-card .install-btn { background: var(--status-success) !important; color: #ffffff !important; border: 1px solid var(--status-success) !important; } .install-btn:hover:not(:disabled), .btn-install:hover:not(:disabled), .app-card .install-btn:hover:not(:disabled) { background: var(--status-success-hover) !important; border-color: var(--status-success-hover) !important; } .uninstall-btn, .btn-uninstall { background: var(--status-danger) !important; color: #ffffff !important; border: 1px solid var(--status-danger) !important; } .uninstall-btn:hover:not(:disabled), .btn-uninstall:hover:not(:disabled) { background: var(--status-danger-hover) !important; border-color: var(--status-danger-hover) !important; } .manage-btn, .btn-manage, .btn-primary, .app-card .manage-btn, .app-card-actions .manage-btn { background: var(--accent) !important; color: var(--text-on-accent) !important; border: 1px solid var(--accent) !important; } .manage-btn:hover:not(:disabled), .btn-manage:hover:not(:disabled), .btn-primary:hover:not(:disabled), .app-card .manage-btn:hover:not(:disabled), .app-card-actions .manage-btn:hover:not(:disabled) { background: var(--accent-hover) !important; border-color: var(--accent-hover) !important; } /* "Back to Apps" — same solid pill as Update Configuration (btn-manage), but in amber so it reads as a distinct secondary action. */ .config-actions .btn-secondary, .console-actions .btn-secondary { background: var(--status-warning) !important; color: #1a1200 !important; border: 1px solid var(--status-warning) !important; } .config-actions .btn-secondary:hover:not(:disabled), .console-actions .btn-secondary:hover:not(:disabled) { background: #e0a800 !important; border-color: #e0a800 !important; } /* ------------------------------------------------------------------ Nebula-only: outline + tint buttons — copied from the .service-button "Welcome" recipe (rgba(, 0.10) bg + rgba(, 0.30) border + neutral text). Topbar pills use that exact alpha for the light feel; in-content CTAs (Install/Manage/Uninstall) bump the alphas a bit and add a subtle coloured outer glow so they feel weightier without becoming solid. ------------------------------------------------------------------ */ /* --- Topbar pills (light, transparent) --------------------------- */ [data-theme="nebula"] .topbar .donate-btn { background: rgba(var(--accent-rgb), 0.10) !important; color: var(--text-primary) !important; border: 1px solid rgba(var(--accent-rgb), 0.30) !important; box-shadow: none !important; text-shadow: none; font-weight: 600; transition: background 0.18s ease, border-color 0.18s ease, transform 0.15s ease, box-shadow 0.2s ease !important; } [data-theme="nebula"] .topbar .donate-btn:hover:not(:disabled) { background: rgba(var(--accent-rgb), 0.20) !important; border-color: rgba(var(--accent-rgb), 0.55) !important; transform: translateY(-1px); } [data-theme="nebula"] .topbar .logout-btn { background: rgba(var(--status-danger-rgb), 0.10) !important; color: var(--text-primary) !important; border: 1px solid rgba(var(--status-danger-rgb), 0.30) !important; box-shadow: none !important; text-shadow: none; font-weight: 600; transition: background 0.18s ease, border-color 0.18s ease, transform 0.15s ease, box-shadow 0.2s ease !important; } [data-theme="nebula"] .topbar .logout-btn:hover:not(:disabled) { background: rgba(var(--status-danger-rgb), 0.20) !important; border-color: rgba(var(--status-danger-rgb), 0.55) !important; transform: translateY(-1px); } /* --- Topbar active nav (App Center / etc.) — translucent pill ---- Replaces the solid var(--primary-color) fill so the active page indicator matches the Donate / Logout pill style. */ [data-theme="nebula"] .topbar-nav .nav-item.nav-active, [data-theme="nebula"] .topbar-nav .nav-item.active { background: rgba(var(--accent-rgb), 0.18) !important; color: var(--text-primary) !important; border-color: rgba(var(--accent-rgb), 0.50) !important; } [data-theme="nebula"] .topbar-nav .nav-item.nav-active:hover, [data-theme="nebula"] .topbar-nav .nav-item.active:hover { background: rgba(var(--accent-rgb), 0.28) !important; color: var(--text-primary) !important; border-color: rgba(var(--accent-rgb), 0.70) !important; } /* --- In-content CTAs (more solid than the topbar but still transparent — alpha set above the body's accent-glow so the brand colour reads clearly against Nebula's gradient.) ------- */ [data-theme="nebula"] .install-btn, [data-theme="nebula"] .btn-install, [data-theme="nebula"] .app-card .install-btn { background: rgba(var(--status-success-rgb), 0.55) !important; color: var(--text-primary) !important; border: 1px solid rgba(var(--status-success-rgb), 0.90) !important; text-shadow: none; font-weight: 600 !important; transition: background 0.18s ease, border-color 0.18s ease, transform 0.15s ease !important; } [data-theme="nebula"] .install-btn:hover:not(:disabled), [data-theme="nebula"] .btn-install:hover:not(:disabled), [data-theme="nebula"] .app-card .install-btn:hover:not(:disabled) { background: rgba(var(--status-success-rgb), 0.70) !important; border-color: rgba(var(--status-success-rgb), 1.00) !important; transform: translateY(-1px); } /* "Open" button on installed app cards — same success recipe. */ [data-theme="nebula"] .service-trigger-icon { background: rgba(var(--status-success-rgb), 0.35) !important; color: var(--text-primary) !important; border: 1px solid rgba(var(--status-success-rgb), 0.65) !important; } [data-theme="nebula"] .service-trigger:hover .service-trigger-icon, [data-theme="nebula"] .service-trigger.open .service-trigger-icon { background: rgba(var(--status-success-rgb), 0.50) !important; border-color: rgba(var(--status-success-rgb), 0.85) !important; } [data-theme="nebula"] .uninstall-btn, [data-theme="nebula"] .btn-uninstall, [data-theme="nebula"] .btn-danger { background: rgba(var(--status-danger-rgb), 0.35) !important; color: var(--text-primary) !important; border: 1px solid rgba(var(--status-danger-rgb), 0.65) !important; text-shadow: none; font-weight: 600 !important; transition: background 0.18s ease, border-color 0.18s ease, transform 0.15s ease !important; } [data-theme="nebula"] .uninstall-btn:hover:not(:disabled), [data-theme="nebula"] .btn-uninstall:hover:not(:disabled), [data-theme="nebula"] .btn-danger:hover:not(:disabled) { background: rgba(var(--status-danger-rgb), 0.50) !important; border-color: rgba(var(--status-danger-rgb), 0.85) !important; transform: translateY(-1px); } [data-theme="nebula"] .manage-btn, [data-theme="nebula"] .btn-manage, [data-theme="nebula"] .btn-primary, [data-theme="nebula"] .app-card .manage-btn, [data-theme="nebula"] .app-card-actions .manage-btn { background: rgba(var(--accent-rgb), 0.35) !important; color: var(--text-primary) !important; border: 1px solid rgba(var(--accent-rgb), 0.65) !important; text-shadow: none; font-weight: 600 !important; transition: background 0.18s ease, border-color 0.18s ease, transform 0.15s ease !important; } [data-theme="nebula"] .manage-btn:hover:not(:disabled), [data-theme="nebula"] .btn-manage:hover:not(:disabled), [data-theme="nebula"] .btn-primary:hover:not(:disabled), [data-theme="nebula"] .app-card .manage-btn:hover:not(:disabled), [data-theme="nebula"] .app-card-actions .manage-btn:hover:not(:disabled) { background: rgba(var(--accent-rgb), 0.50) !important; border-color: rgba(var(--accent-rgb), 0.85) !important; transform: translateY(-1px); } [data-theme="nebula"] .install-btn:disabled, [data-theme="nebula"] .btn-install:disabled, [data-theme="nebula"] .uninstall-btn:disabled, [data-theme="nebula"] .btn-uninstall:disabled, [data-theme="nebula"] .manage-btn:disabled, [data-theme="nebula"] .btn-manage:disabled, [data-theme="nebula"] .btn-primary:disabled, [data-theme="nebula"] .btn-danger:disabled, [data-theme="nebula"] .topbar .donate-btn:disabled, [data-theme="nebula"] .topbar .logout-btn:disabled { opacity: 0.50; cursor: not-allowed; } /* Warning banner — amber tint that reads in every theme. */ .warning-banner { background: rgba(var(--status-warning-rgb), 0.12); border: 1px solid rgba(var(--status-warning-rgb), 0.35); color: var(--text-primary); } /* Nebula: the cyan accent is bright enough that a dark glyph (the theme's text-on-accent = #0a1426) still reads, but white reads better with the rest of nebula's white-text-on-glass system. */ [data-theme="nebula"] .tooltip::after { color: #ffffff; }