1575 lines
33 KiB
CSS
1575 lines
33 KiB
CSS
@font-face {
|
|
font-family: "Red Hat Text";
|
|
src: url("fonts/RedHatText-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Red Hat Text";
|
|
src: url("fonts/RedHatText-Medium.woff2") format("woff2");
|
|
font-weight: 500;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Red Hat Display";
|
|
src: url("fonts/RedHatDisplay-SemiBold.woff2") format("woff2");
|
|
font-weight: 600;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Red Hat Display";
|
|
src: url("fonts/RedHatDisplay-Bold.woff2") format("woff2");
|
|
font-weight: 700;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Space Grotesk";
|
|
src: url("fonts/SpaceGrotesk-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Space Grotesk";
|
|
src: url("fonts/SpaceGrotesk-Medium.woff2") format("woff2");
|
|
font-weight: 500;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Space Grotesk";
|
|
src: url("fonts/SpaceGrotesk-SemiBold.woff2") format("woff2");
|
|
font-weight: 600;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Manrope";
|
|
src: url("fonts/Manrope-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Manrope";
|
|
src: url("fonts/Manrope-SemiBold.woff2") format("woff2");
|
|
font-weight: 600;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "DM Sans";
|
|
src: url("fonts/DMSans-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "DM Sans";
|
|
src: url("fonts/DMSans-Medium.woff2") format("woff2");
|
|
font-weight: 500;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "DM Sans";
|
|
src: url("fonts/DMSans-Bold.woff2") format("woff2");
|
|
font-weight: 700;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Sora";
|
|
src: url("fonts/Sora-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Sora";
|
|
src: url("fonts/Sora-SemiBold.woff2") format("woff2");
|
|
font-weight: 600;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Chivo";
|
|
src: url("fonts/Chivo-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Chivo";
|
|
src: url("fonts/Chivo-Bold.woff2") format("woff2");
|
|
font-weight: 700;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Atkinson Hyperlegible";
|
|
src: url("fonts/Atkinson-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "Atkinson Hyperlegible";
|
|
src: url("fonts/Atkinson-Bold.woff2") format("woff2");
|
|
font-weight: 700;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "IBM Plex Sans";
|
|
src: url("fonts/PlexSans-Regular.woff2") format("woff2");
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
@font-face {
|
|
font-family: "IBM Plex Sans";
|
|
src: url("fonts/PlexSans-SemiBold.woff2") format("woff2");
|
|
font-weight: 600;
|
|
font-style: normal;
|
|
font-display: swap;
|
|
}
|
|
|
|
:root {
|
|
--bg: #0f1117;
|
|
--panel: #161a23;
|
|
--panel-overlay: rgba(255, 255, 255, 0.02);
|
|
--card-overlay: rgba(255, 255, 255, 0.03);
|
|
--muted: #9ca3af;
|
|
--text: #e5e7eb;
|
|
--accent: #7dd3fc;
|
|
--accent-2: #22c55e;
|
|
--warning: #f59e0b;
|
|
--border: #1f2430;
|
|
--shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
|
|
--topbar-bg: rgba(15, 17, 23, 0.8);
|
|
--toggle-track: #374151;
|
|
--input-bg: #0c0e14;
|
|
--input-border: var(--border);
|
|
--disabled-bg: #141a22;
|
|
--disabled-border: #2a313c;
|
|
--disabled-text: #7c8696;
|
|
--disabled-strong: #0b0f18;
|
|
--input-disabled-bg: #141a22;
|
|
--input-disabled-text: #7c8696;
|
|
--input-disabled-border: #2a313c;
|
|
--font-body: "Red Hat Text", "Inter", "Segoe UI", system-ui, -apple-system,
|
|
sans-serif;
|
|
--font-heading: "Red Hat Display", "Red Hat Text", system-ui, -apple-system,
|
|
sans-serif;
|
|
font-family: var(--font-body);
|
|
}
|
|
:root[data-font="space"] {
|
|
--font-body: "Space Grotesk", "Inter", "Segoe UI", system-ui, -apple-system,
|
|
sans-serif;
|
|
--font-heading: "Space Grotesk", "Red Hat Text", system-ui, -apple-system,
|
|
sans-serif;
|
|
}
|
|
:root[data-font="manrope"] {
|
|
--font-body: "Manrope", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
|
|
--font-heading: "Manrope", "Manrope", system-ui, -apple-system, sans-serif;
|
|
}
|
|
:root[data-font="dmsans"] {
|
|
--font-body: "DM Sans", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
|
|
--font-heading: "DM Sans", "Red Hat Display", system-ui, -apple-system, sans-serif;
|
|
}
|
|
:root[data-font="sora"] {
|
|
--font-body: "Sora", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
|
|
--font-heading: "Sora", "Sora", system-ui, -apple-system, sans-serif;
|
|
}
|
|
:root[data-font="chivo"] {
|
|
--font-body: "Chivo", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
|
|
--font-heading: "Chivo", "Chivo", system-ui, -apple-system, sans-serif;
|
|
}
|
|
:root[data-font="atkinson"] {
|
|
--font-body: "Atkinson Hyperlegible", "Inter", "Segoe UI", system-ui, -apple-system,
|
|
sans-serif;
|
|
--font-heading: "Atkinson Hyperlegible", "Atkinson Hyperlegible", system-ui,
|
|
-apple-system, sans-serif;
|
|
}
|
|
:root[data-font="plex"] {
|
|
--font-body: "IBM Plex Sans", "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
|
|
--font-heading: "IBM Plex Sans", "IBM Plex Sans", system-ui, -apple-system, sans-serif;
|
|
}
|
|
:root[data-theme="light"] {
|
|
--bg: #dfe4ee;
|
|
--panel: #f6f8fd;
|
|
--panel-overlay: rgba(10, 12, 18, 0.06);
|
|
--card-overlay: rgba(10, 12, 18, 0.11);
|
|
--muted: #4b5563;
|
|
--text: #0b1224;
|
|
--accent: #0077c2;
|
|
--accent-2: #15803d;
|
|
--warning: #b45309;
|
|
--border: #bcc5d6;
|
|
--shadow: 0 12px 30px rgba(12, 18, 32, 0.12);
|
|
--topbar-bg: rgba(249, 251, 255, 0.92);
|
|
--toggle-track: #d1d5db;
|
|
--input-bg: #f0f2f7;
|
|
--input-border: #c5ccd9;
|
|
--disabled-bg: #f4f6fb;
|
|
--disabled-border: #c8d0df;
|
|
--disabled-text: #7a8292;
|
|
--disabled-strong: #eef1f7;
|
|
--input-disabled-bg: #f8fafc;
|
|
--input-disabled-text: #6a6f7b;
|
|
--input-disabled-border: #c9d1df;
|
|
}
|
|
|
|
* {
|
|
box-sizing: border-box;
|
|
}
|
|
body {
|
|
margin: 0;
|
|
background:
|
|
radial-gradient(
|
|
circle at 20% 20%,
|
|
rgba(125, 211, 252, 0.08),
|
|
transparent 32%
|
|
),
|
|
radial-gradient(circle at 80% 0%, rgba(34, 197, 94, 0.06), transparent 28%),
|
|
linear-gradient(180deg, #0f1117 0%, #0e1119 55%, #0b0f15 100%);
|
|
background-attachment: fixed;
|
|
background-repeat: no-repeat;
|
|
color: var(--text);
|
|
line-height: 1.5;
|
|
transition: background 240ms ease, color 240ms ease;
|
|
}
|
|
:root[data-theme="light"] body {
|
|
background:
|
|
radial-gradient(
|
|
circle at 25% 18%,
|
|
rgba(0, 119, 194, 0.14),
|
|
transparent 34%
|
|
),
|
|
radial-gradient(circle at 78% 8%, rgba(21, 128, 61, 0.12), transparent 30%),
|
|
linear-gradient(180deg, #f6f8fd 0%, #e8edf7 52%, #d6dde9 100%);
|
|
background-attachment: fixed;
|
|
background-repeat: no-repeat;
|
|
}
|
|
|
|
.topbar {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
padding: 14px 22px;
|
|
border-bottom: 1px solid var(--border);
|
|
backdrop-filter: blur(10px);
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 10;
|
|
background: var(--topbar-bg);
|
|
}
|
|
.brand {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 10px;
|
|
font-weight: 700;
|
|
letter-spacing: 0.3px;
|
|
font-family: var(--font-heading);
|
|
}
|
|
.brand .dot {
|
|
width: 12px;
|
|
height: 12px;
|
|
border-radius: 50%;
|
|
background: linear-gradient(135deg, #22c55e, #7dd3fc);
|
|
box-shadow: 0 0 10px rgba(125, 211, 252, 0.6);
|
|
cursor: help;
|
|
}
|
|
.top-actions {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 10px;
|
|
flex-wrap: wrap;
|
|
justify-content: flex-end;
|
|
}
|
|
.top-indicators {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 10px;
|
|
flex-wrap: wrap;
|
|
}
|
|
.chip-label {
|
|
font-size: 0.85rem;
|
|
color: var(--muted);
|
|
margin-right: 4px;
|
|
}
|
|
.status-chip {
|
|
padding: 6px 12px;
|
|
border-radius: 999px;
|
|
border: 1px solid var(--border);
|
|
color: var(--muted);
|
|
font-size: 0.9rem;
|
|
background: rgba(0, 0, 0, 0.06);
|
|
}
|
|
.status-chip.quiet {
|
|
opacity: 0.75;
|
|
font-size: 0.85rem;
|
|
background: rgba(0, 0, 0, 0.04);
|
|
}
|
|
.status-chip.chip-on {
|
|
color: var(--accent-2);
|
|
border-color: rgba(22, 163, 74, 0.4);
|
|
background: rgba(22, 163, 74, 0.08);
|
|
}
|
|
.status-chip.chip-off {
|
|
color: #e11d48;
|
|
border-color: rgba(225, 29, 72, 0.4);
|
|
background: rgba(225, 29, 72, 0.08);
|
|
}
|
|
.status-chip.chip-warm {
|
|
color: #d97706;
|
|
border-color: rgba(217, 119, 6, 0.35);
|
|
background: rgba(217, 119, 6, 0.12);
|
|
}
|
|
:root[data-theme="light"] .status-chip {
|
|
background: rgba(12, 18, 32, 0.06);
|
|
border-color: rgba(12, 18, 32, 0.14);
|
|
color: #1f2a3d;
|
|
}
|
|
:root[data-theme="light"] .status-chip.quiet {
|
|
background: rgba(12, 18, 32, 0.05);
|
|
color: #243247;
|
|
opacity: 0.92;
|
|
}
|
|
:root[data-theme="light"] .status-chip.chip-on {
|
|
background: rgba(34, 197, 94, 0.16);
|
|
border-color: rgba(34, 197, 94, 0.5);
|
|
color: #0f5132;
|
|
}
|
|
:root[data-theme="light"] .status-chip.chip-warm {
|
|
background: rgba(217, 119, 6, 0.16);
|
|
border-color: rgba(217, 119, 6, 0.5);
|
|
color: #8a4b08;
|
|
}
|
|
:root[data-theme="light"] .status-chip.chip-off {
|
|
background: rgba(225, 29, 72, 0.18);
|
|
border-color: rgba(225, 29, 72, 0.55);
|
|
color: #7a1028;
|
|
}
|
|
.toast-container {
|
|
position: fixed;
|
|
bottom: 16px;
|
|
left: 50%;
|
|
transform: translateX(-50%);
|
|
z-index: 40;
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: flex-end;
|
|
align-items: center;
|
|
gap: 10px;
|
|
pointer-events: none;
|
|
}
|
|
.toast {
|
|
min-width: 200px;
|
|
max-width: 320px;
|
|
max-height: 240px;
|
|
overflow: hidden;
|
|
padding: 10px 12px;
|
|
border-radius: 10px;
|
|
border: 1px solid var(--border);
|
|
background: var(--panel);
|
|
color: var(--text);
|
|
box-shadow: var(--shadow);
|
|
font-weight: 600;
|
|
pointer-events: auto;
|
|
opacity: 0;
|
|
transform: translateY(var(--toast-slide-offset, 14px));
|
|
transition:
|
|
opacity var(--toast-speed, 0.28s) ease,
|
|
transform var(--toast-speed, 0.28s) ease,
|
|
max-height var(--toast-speed, 0.28s) ease,
|
|
padding var(--toast-speed, 0.28s) ease,
|
|
margin var(--toast-speed, 0.28s) ease;
|
|
}
|
|
.toast.show {
|
|
opacity: 1;
|
|
transform: translateY(0);
|
|
}
|
|
.toast.success {
|
|
border-color: rgba(34, 197, 94, 0.5);
|
|
}
|
|
.toast.warn {
|
|
border-color: rgba(217, 119, 6, 0.5);
|
|
}
|
|
.toast.error {
|
|
border-color: rgba(225, 29, 72, 0.6);
|
|
}
|
|
.toast.info {
|
|
border-color: rgba(125, 211, 252, 0.4);
|
|
}
|
|
html[data-anim="off"] .toast {
|
|
transition: none !important;
|
|
}
|
|
|
|
.toast.anim-slide-in {
|
|
transform: translate(var(--toast-slide-x, 0px), var(--toast-slide-y, 24px));
|
|
opacity: 0;
|
|
}
|
|
.toast.anim-slide-in.show {
|
|
transform: translate(0, 0);
|
|
opacity: 1;
|
|
}
|
|
.toast.anim-fade {
|
|
transform: none;
|
|
opacity: 0;
|
|
}
|
|
.toast.anim-fade.show {
|
|
opacity: 1;
|
|
}
|
|
.toast.anim-pop {
|
|
transform: scale(0.9);
|
|
opacity: 0;
|
|
}
|
|
.toast.anim-pop.show {
|
|
transform: scale(1);
|
|
opacity: 1;
|
|
}
|
|
.toast.anim-bounce {
|
|
opacity: 0;
|
|
transform: translateY(calc(var(--toast-dir, 1) * 20px));
|
|
}
|
|
.toast.anim-bounce.show {
|
|
opacity: 1;
|
|
animation: toast-bounce var(--toast-speed, 0.46s) cubic-bezier(0.22, 1, 0.36, 1) forwards;
|
|
}
|
|
.toast.anim-drop {
|
|
opacity: 0;
|
|
transform: translateY(calc(var(--toast-dir, 1) * -24px)) scale(0.98);
|
|
}
|
|
.toast.anim-drop.show {
|
|
transform: translateY(0) scale(1);
|
|
opacity: 1;
|
|
}
|
|
.toast.anim-grow {
|
|
transform: scale(0.85);
|
|
opacity: 0;
|
|
}
|
|
.toast.anim-grow.show {
|
|
transform: scale(1);
|
|
opacity: 1;
|
|
}
|
|
.toast.leaving {
|
|
opacity: 0 !important;
|
|
transform: translateY(12px) !important;
|
|
max-height: 0 !important;
|
|
margin: 0 !important;
|
|
padding-top: 0 !important;
|
|
padding-bottom: 0 !important;
|
|
}
|
|
|
|
@keyframes toast-bounce {
|
|
0% {
|
|
opacity: 0;
|
|
transform: translateY(calc(var(--toast-dir, 1) * 20px)) scale(0.96);
|
|
}
|
|
55% {
|
|
opacity: 1;
|
|
transform: translateY(calc(var(--toast-dir, 1) * -8px)) scale(1.03);
|
|
}
|
|
100% {
|
|
opacity: 1;
|
|
transform: translateY(0) scale(1);
|
|
}
|
|
}
|
|
|
|
.toast-container.pos-bottom-center {
|
|
bottom: 16px;
|
|
left: 50%;
|
|
right: auto;
|
|
top: auto;
|
|
transform: translateX(-50%);
|
|
flex-direction: column-reverse;
|
|
align-items: center;
|
|
}
|
|
.toast-container.pos-bottom-right {
|
|
bottom: 16px;
|
|
right: 16px;
|
|
left: auto;
|
|
top: auto;
|
|
transform: none;
|
|
flex-direction: column-reverse;
|
|
align-items: flex-end;
|
|
}
|
|
.toast-container.pos-bottom-left {
|
|
bottom: 16px;
|
|
left: 16px;
|
|
right: auto;
|
|
top: auto;
|
|
transform: none;
|
|
flex-direction: column-reverse;
|
|
align-items: flex-start;
|
|
}
|
|
.toast-container.pos-top-right {
|
|
top: 16px;
|
|
right: 16px;
|
|
bottom: auto;
|
|
left: auto;
|
|
transform: none;
|
|
flex-direction: column;
|
|
align-items: flex-end;
|
|
}
|
|
.toast-container.pos-top-left {
|
|
top: 16px;
|
|
left: 16px;
|
|
bottom: auto;
|
|
right: auto;
|
|
transform: none;
|
|
flex-direction: column;
|
|
align-items: flex-start;
|
|
}
|
|
.toast-container.pos-top-center {
|
|
top: 16px;
|
|
left: 50%;
|
|
right: auto;
|
|
bottom: auto;
|
|
transform: translateX(-50%);
|
|
flex-direction: column;
|
|
align-items: center;
|
|
}
|
|
.host-chip {
|
|
border-radius: 10px;
|
|
background: rgba(255, 255, 255, 0.04);
|
|
color: var(--text);
|
|
}
|
|
.layout {
|
|
max-width: 1200px;
|
|
margin: 0 auto;
|
|
padding: 32px 18px 80px;
|
|
}
|
|
|
|
.hero {
|
|
display: grid;
|
|
grid-template-columns: 1.1fr 0.9fr;
|
|
gap: 20px;
|
|
align-items: center;
|
|
margin-bottom: 24px;
|
|
}
|
|
.eyebrow {
|
|
text-transform: uppercase;
|
|
font-size: 0.75rem;
|
|
letter-spacing: 0.12rem;
|
|
color: var(--muted);
|
|
margin: 0 0 6px;
|
|
font-family: var(--font-heading);
|
|
}
|
|
.eyebrow.warning {
|
|
color: var(--warning);
|
|
}
|
|
h1 {
|
|
margin: 0 0 10px;
|
|
line-height: 1.2;
|
|
font-family: var(--font-heading);
|
|
font-weight: 700;
|
|
}
|
|
h2 {
|
|
margin: 0 0 6px;
|
|
line-height: 1.2;
|
|
font-family: var(--font-heading);
|
|
font-weight: 600;
|
|
}
|
|
.lede {
|
|
color: var(--muted);
|
|
margin: 0 0 14px;
|
|
}
|
|
.hint {
|
|
color: var(--muted);
|
|
margin: 0;
|
|
font-size: 0.95rem;
|
|
}
|
|
.hint.quiet {
|
|
opacity: 0.8;
|
|
font-size: 0.85rem;
|
|
}
|
|
|
|
|
|
.actions {
|
|
display: flex;
|
|
gap: 10px;
|
|
flex-wrap: wrap;
|
|
}
|
|
button {
|
|
background: linear-gradient(135deg, #22c55e, #7dd3fc);
|
|
color: #041012;
|
|
border: none;
|
|
padding: 10px 16px;
|
|
border-radius: 10px;
|
|
cursor: pointer;
|
|
font-weight: 600;
|
|
box-shadow: var(--shadow);
|
|
}
|
|
button.ghost {
|
|
background: transparent;
|
|
color: var(--text);
|
|
border: 1px solid var(--border);
|
|
box-shadow: none;
|
|
}
|
|
button.icon-btn {
|
|
width: 40px;
|
|
height: 40px;
|
|
padding: 0;
|
|
display: grid;
|
|
place-items: center;
|
|
font-size: 1.1rem;
|
|
box-shadow: none;
|
|
}
|
|
:root[data-theme="light"] button.icon-btn {
|
|
box-shadow: inset 0 0 0 1px var(--border);
|
|
border-radius: 10px;
|
|
}
|
|
button:active {
|
|
transform: translateY(1px);
|
|
}
|
|
button.danger-btn {
|
|
background: linear-gradient(135deg, #f87171, #ef4444);
|
|
color: #0f1117;
|
|
}
|
|
.menu-btn {
|
|
font-size: 1rem;
|
|
padding: 4px 8px;
|
|
border-radius: 8px;
|
|
}
|
|
.service-menu {
|
|
position: absolute;
|
|
top: 8px;
|
|
right: 8px;
|
|
display: flex;
|
|
gap: 6px;
|
|
}
|
|
.service-menu .ghost {
|
|
border: 1px solid color-mix(in srgb, var(--border) 60%, var(--text) 20%);
|
|
}
|
|
label.toggle {
|
|
position: relative;
|
|
display: inline-block;
|
|
width: 46px;
|
|
height: 24px;
|
|
}
|
|
label.toggle input {
|
|
display: none;
|
|
}
|
|
label.toggle .slider {
|
|
position: absolute;
|
|
cursor: pointer;
|
|
inset: 0;
|
|
background: var(--toggle-track);
|
|
border-radius: 24px;
|
|
transition: 0.2s;
|
|
}
|
|
label.toggle .slider:before {
|
|
position: absolute;
|
|
content: "";
|
|
height: 18px;
|
|
width: 18px;
|
|
left: 3px;
|
|
bottom: 3px;
|
|
background: white;
|
|
border-radius: 50%;
|
|
transition: 0.2s;
|
|
}
|
|
label.toggle input:checked + .slider {
|
|
background: linear-gradient(135deg, #22c55e, #7dd3fc);
|
|
}
|
|
label.toggle input:checked + .slider:before {
|
|
transform: translateX(22px);
|
|
}
|
|
|
|
.hero-stats {
|
|
background: var(--panel);
|
|
border: 1px solid var(--border);
|
|
border-radius: 14px;
|
|
padding: 14px;
|
|
box-shadow: var(--shadow);
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
|
|
gap: 12px;
|
|
}
|
|
.stat {
|
|
background: var(--card-overlay);
|
|
border: 1px solid var(--border);
|
|
border-radius: 12px;
|
|
padding: 9px;
|
|
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
|
|
}
|
|
.stat .label {
|
|
color: var(--muted);
|
|
font-size: 0.85rem;
|
|
}
|
|
.stat .value {
|
|
font-size: 1.15rem;
|
|
font-weight: 700;
|
|
line-height: 1.25;
|
|
white-space: nowrap;
|
|
font-variant-numeric: tabular-nums;
|
|
}
|
|
|
|
.panel {
|
|
background: var(--panel);
|
|
border: 1px solid var(--border);
|
|
border-radius: 16px;
|
|
padding: 18px;
|
|
margin-bottom: 18px;
|
|
box-shadow: var(--shadow);
|
|
}
|
|
.panel-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
gap: 12px;
|
|
flex-wrap: wrap;
|
|
margin-bottom: 12px;
|
|
font-family: var(--font-heading);
|
|
}
|
|
.panel-actions {
|
|
display: flex;
|
|
gap: 8px;
|
|
align-items: center;
|
|
margin-left: auto;
|
|
}
|
|
.panel-actions .icon-btn {
|
|
font-size: 1.15rem;
|
|
width: 38px;
|
|
height: 38px;
|
|
padding: 0;
|
|
}
|
|
.panel-header.small-gap {
|
|
margin-top: 12px;
|
|
}
|
|
|
|
.grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
|
|
gap: 12px;
|
|
}
|
|
.grid.empty {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
min-height: 220px;
|
|
width: 100%;
|
|
}
|
|
.empty-state {
|
|
text-align: center;
|
|
color: var(--muted);
|
|
padding: 16px;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
gap: 10px;
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
.empty-state button {
|
|
margin-top: 6px;
|
|
box-shadow: none;
|
|
}
|
|
.card {
|
|
border: 1px solid var(--border);
|
|
background: var(--card-overlay);
|
|
padding: 12px;
|
|
padding-right: 68px; /* reserve room for action buttons */
|
|
padding-bottom: 34px; /* reserve room for bottom badges */
|
|
border-radius: 12px;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 6px;
|
|
position: relative;
|
|
}
|
|
.card.clickable {
|
|
cursor: pointer;
|
|
}
|
|
.card.offline {
|
|
border-color: rgba(225, 29, 72, 0.45);
|
|
}
|
|
.card a {
|
|
color: var(--accent);
|
|
text-decoration: none;
|
|
word-break: break-all;
|
|
}
|
|
.service-url {
|
|
color: var(--text);
|
|
font-weight: 600;
|
|
word-break: break-all;
|
|
}
|
|
.pill {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 6px;
|
|
padding: 4px 8px;
|
|
border-radius: 999px;
|
|
background: color-mix(in srgb, var(--accent) 18%, var(--panel) 82%);
|
|
border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--border) 65%);
|
|
color: var(--text);
|
|
font-size: 0.85rem;
|
|
max-width: 100%;
|
|
white-space: nowrap;
|
|
overflow: hidden;
|
|
text-overflow: ellipsis;
|
|
}
|
|
.pill-small {
|
|
font-size: 0.8rem;
|
|
}
|
|
.notice-pill {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
padding: 2px 8px;
|
|
border-radius: 999px;
|
|
border: 1px dashed #6b7280;
|
|
color: #6b7280;
|
|
font-size: 0.78rem;
|
|
margin-left: 6px;
|
|
}
|
|
.self-signed-pill {
|
|
position: absolute;
|
|
right: 10px;
|
|
bottom: 10px;
|
|
margin-left: 0;
|
|
}
|
|
.notice-link {
|
|
display: inline-block;
|
|
margin-top: 8px;
|
|
color: var(--accent);
|
|
text-decoration: underline;
|
|
}
|
|
.info-btn {
|
|
width: 30px;
|
|
height: 30px;
|
|
padding: 0;
|
|
border: 1px solid color-mix(in srgb, var(--border) 60%, var(--text) 20%);
|
|
border-radius: 10px;
|
|
font-size: 1rem;
|
|
color: var(--text);
|
|
background: var(--card-overlay);
|
|
line-height: 1;
|
|
}
|
|
.control-actions.column > .checkbox-row.inline {
|
|
margin-top: 6px;
|
|
}
|
|
.status-dot {
|
|
width: 10px;
|
|
height: 10px;
|
|
border-radius: 50%;
|
|
background: #e11d48;
|
|
box-shadow: 0 0 8px rgba(225, 29, 72, 0.5);
|
|
}
|
|
.status-dot.on {
|
|
background: #22c55e;
|
|
box-shadow: 0 0 8px rgba(34, 197, 94, 0.6);
|
|
}
|
|
html[data-anim="on"] .status-dot.on {
|
|
animation: pulse 2s ease-in-out infinite;
|
|
}
|
|
@keyframes pulse {
|
|
0% {
|
|
box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.35);
|
|
}
|
|
70% {
|
|
box-shadow: 0 0 0 10px rgba(34, 197, 94, 0);
|
|
}
|
|
100% {
|
|
box-shadow: 0 0 0 0 rgba(34, 197, 94, 0);
|
|
}
|
|
}
|
|
.status-dot.off {
|
|
background: #f87171;
|
|
box-shadow: 0 0 8px rgba(248, 113, 113, 0.5);
|
|
}
|
|
.service-header {
|
|
display: grid;
|
|
grid-template-columns: auto minmax(0, 1fr) auto auto;
|
|
align-items: center;
|
|
gap: 8px;
|
|
width: 100%;
|
|
}
|
|
.service-header .pill {
|
|
min-width: 0;
|
|
max-width: 100%;
|
|
}
|
|
.service-header .status-dot,
|
|
.service-header .menu-btn,
|
|
.service-header .notice-pill {
|
|
justify-self: start;
|
|
}
|
|
.service-header .menu-btn {
|
|
justify-self: end;
|
|
}
|
|
#servicesGrid {
|
|
grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
|
|
}
|
|
@media (min-width: 1180px) {
|
|
#servicesGrid {
|
|
grid-template-columns: repeat(3, 1fr);
|
|
}
|
|
}
|
|
@media (max-width: 560px) {
|
|
#servicesGrid {
|
|
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
|
|
}
|
|
}
|
|
|
|
.controls {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 10px;
|
|
}
|
|
|
|
.accordion {
|
|
border: 1px solid var(--border);
|
|
border-radius: 12px;
|
|
overflow: hidden;
|
|
background: var(--panel-overlay);
|
|
}
|
|
.accordion + .accordion {
|
|
margin-top: 8px;
|
|
}
|
|
.accordion-toggle {
|
|
width: 100%;
|
|
text-align: left;
|
|
background: transparent;
|
|
color: var(--text);
|
|
border: none;
|
|
padding: 12px 14px;
|
|
font-weight: 700;
|
|
cursor: pointer;
|
|
}
|
|
.accordion-toggle.danger-btn {
|
|
color: #0f1117;
|
|
}
|
|
.accordion-body {
|
|
padding: 0 14px 0;
|
|
max-height: 0;
|
|
overflow: hidden;
|
|
opacity: 0;
|
|
transition:
|
|
max-height 0.24s ease,
|
|
opacity 0.18s ease,
|
|
padding-bottom 0.18s ease,
|
|
padding-top 0.18s ease;
|
|
}
|
|
.accordion.open .accordion-body {
|
|
max-height: 1200px;
|
|
opacity: 1;
|
|
padding: 8px 12px 6px;
|
|
}
|
|
.accordion-body p {
|
|
margin: 0 0 6px;
|
|
}
|
|
.control-card {
|
|
border: 1px solid var(--border);
|
|
border-radius: 12px;
|
|
padding: 12px;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
gap: 12px;
|
|
flex-wrap: wrap;
|
|
}
|
|
.control-actions {
|
|
display: flex;
|
|
gap: 10px;
|
|
align-items: center;
|
|
flex-wrap: wrap;
|
|
}
|
|
.control-actions.split-row {
|
|
justify-content: flex-start;
|
|
gap: 10px;
|
|
align-items: center;
|
|
margin-top: 4px;
|
|
flex-wrap: wrap;
|
|
}
|
|
.control-actions.column.tight {
|
|
gap: 6px;
|
|
align-items: flex-start;
|
|
}
|
|
.control-actions.column {
|
|
flex-direction: column;
|
|
align-items: stretch;
|
|
}
|
|
select,
|
|
input {
|
|
background: var(--input-bg);
|
|
color: var(--text);
|
|
border: 1px solid var(--input-border);
|
|
padding: 8px 10px;
|
|
border-radius: 10px;
|
|
}
|
|
.checkbox-row {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 8px;
|
|
color: var(--muted);
|
|
font-size: 0.95rem;
|
|
}
|
|
.checkbox-row.inline {
|
|
display: inline-flex;
|
|
gap: 10px;
|
|
align-items: center;
|
|
}
|
|
.checkbox-row.inline.tight {
|
|
margin-top: 6px;
|
|
}
|
|
.checkbox-row.inline.nowrap span {
|
|
white-space: nowrap;
|
|
}
|
|
.control-row.split {
|
|
display: flex;
|
|
gap: 12px;
|
|
align-items: center;
|
|
flex-wrap: wrap;
|
|
}
|
|
.control-row.split > * {
|
|
margin: 0;
|
|
}
|
|
.dual-row {
|
|
display: grid;
|
|
grid-template-columns: 1fr 1fr;
|
|
gap: 10px;
|
|
align-items: center;
|
|
}
|
|
.dual-row .dual-col:last-child {
|
|
text-align: right;
|
|
}
|
|
.dual-row .checkbox-row.inline {
|
|
justify-content: flex-start;
|
|
width: fit-content;
|
|
}
|
|
.form-grid {
|
|
display: grid;
|
|
gap: 6px;
|
|
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
|
|
}
|
|
.field {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 4px;
|
|
color: var(--muted);
|
|
font-size: 0.95rem;
|
|
}
|
|
.field input,
|
|
.field select {
|
|
width: 100%;
|
|
}
|
|
.checkbox-field .checkbox-row {
|
|
color: var(--text);
|
|
}
|
|
.status-msg.error {
|
|
color: #f87171;
|
|
}
|
|
.note-warn {
|
|
color: #f87171;
|
|
font-weight: 600;
|
|
}
|
|
.is-disabled {
|
|
opacity: 0.45;
|
|
}
|
|
.is-disabled input,
|
|
.is-disabled select,
|
|
.is-disabled textarea {
|
|
filter: grayscale(0.5);
|
|
background: var(--input-disabled-bg);
|
|
color: var(--input-disabled-text);
|
|
border-color: var(--input-disabled-border);
|
|
box-shadow: none;
|
|
}
|
|
.is-disabled label {
|
|
color: var(--disabled-text);
|
|
}
|
|
.is-disabled .slider {
|
|
filter: grayscale(0.7);
|
|
}
|
|
/* utility hidden class for non-overlay elements */
|
|
.hidden {
|
|
display: none !important;
|
|
}
|
|
button:disabled {
|
|
opacity: 0.55;
|
|
cursor: not-allowed;
|
|
box-shadow: none;
|
|
background: #2f3844;
|
|
border: 1px solid #3b4756;
|
|
color: #c9d2dc;
|
|
pointer-events: none;
|
|
}
|
|
#acc-updates .accordion-body {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 6px;
|
|
padding: 8px 12px 6px !important;
|
|
}
|
|
#updatesSection {
|
|
width: 100%;
|
|
gap: 4px;
|
|
margin-bottom: 0;
|
|
}
|
|
#updatesControls {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 6px;
|
|
margin: 0;
|
|
padding: 0;
|
|
width: 100%;
|
|
}
|
|
#updatesControls.is-disabled {
|
|
opacity: 0.6;
|
|
background: var(--disabled-bg);
|
|
border: 1px dashed var(--disabled-border);
|
|
border-radius: 8px;
|
|
padding: 6px;
|
|
}
|
|
#updatesControls.is-disabled * {
|
|
pointer-events: none;
|
|
}
|
|
#updatesControls input:disabled,
|
|
#updatesControls select:disabled,
|
|
#updatesControls textarea:disabled {
|
|
background: var(--input-disabled-bg);
|
|
color: var(--input-disabled-text);
|
|
border-color: var(--input-disabled-border);
|
|
}
|
|
#updatesControls .checkbox-row input:disabled + span,
|
|
#updatesControls label,
|
|
#updatesControls .field > span,
|
|
#updatesControls .hint {
|
|
color: var(--disabled-text);
|
|
}
|
|
#updatesControls .control-actions,
|
|
#updatesControls .field {
|
|
opacity: 0.9;
|
|
}
|
|
#updatesControls .toggle .slider {
|
|
filter: grayscale(0.9);
|
|
}
|
|
/* Disabled styling scoped to updates section */
|
|
#updatesControls.is-disabled input,
|
|
#updatesControls.is-disabled select,
|
|
#updatesControls.is-disabled textarea {
|
|
background: var(--input-disabled-bg);
|
|
color: var(--input-disabled-text);
|
|
border-color: var(--input-disabled-border);
|
|
box-shadow: none;
|
|
}
|
|
#updatesControls.is-disabled .checkbox-row span,
|
|
#updatesControls.is-disabled label,
|
|
#updatesControls.is-disabled .field > span,
|
|
#updatesControls.is-disabled .hint {
|
|
color: var(--disabled-text);
|
|
}
|
|
#updatesControls.is-disabled .control-actions,
|
|
#updatesControls.is-disabled .field {
|
|
opacity: 0.9;
|
|
}
|
|
#updatesControls.is-disabled .toggle .slider {
|
|
filter: grayscale(0.8);
|
|
}
|
|
/* Light theme contrast for disabled controls */
|
|
:root[data-theme="light"] #updatesSection {
|
|
background: #f7f9fd;
|
|
border: 1px solid #d9dfeb;
|
|
border-radius: 10px;
|
|
padding: 8px 10px;
|
|
}
|
|
:root[data-theme="light"] #updatesControls {
|
|
gap: 8px;
|
|
}
|
|
:root[data-theme="light"] #updatesControls.is-disabled {
|
|
opacity: 1;
|
|
background: var(--disabled-bg);
|
|
border: 1px dashed var(--disabled-border);
|
|
border-radius: 8px;
|
|
padding: 6px;
|
|
}
|
|
:root[data-theme="light"] #updatesControls.is-disabled * {
|
|
pointer-events: none;
|
|
}
|
|
:root[data-theme="light"] #updatesControls.is-disabled input,
|
|
:root[data-theme="light"] #updatesControls.is-disabled select,
|
|
:root[data-theme="light"] #updatesControls.is-disabled textarea {
|
|
background: var(--input-disabled-bg) !important;
|
|
color: var(--input-disabled-text) !important;
|
|
border: 1px dashed var(--disabled-border) !important;
|
|
box-shadow: none !important;
|
|
}
|
|
:root[data-theme="light"] #updatesControls.is-disabled .checkbox-row input:disabled + span,
|
|
:root[data-theme="light"] #updatesControls.is-disabled label,
|
|
:root[data-theme="light"] #updatesControls.is-disabled .field > span,
|
|
:root[data-theme="light"] #updatesControls.is-disabled .hint {
|
|
color: var(--disabled-text) !important;
|
|
}
|
|
:root[data-theme="light"] #updatesControls.is-disabled .control-actions,
|
|
:root[data-theme="light"] #updatesControls.is-disabled .field {
|
|
opacity: 1;
|
|
}
|
|
:root[data-theme="light"] #updatesControls.is-disabled .toggle .slider {
|
|
filter: grayscale(0.2);
|
|
}
|
|
#updatesControls .form-grid {
|
|
margin: 0;
|
|
}
|
|
#updatesControls .control-actions.split-row {
|
|
margin: 0;
|
|
}
|
|
#acc-updates .accordion-body {
|
|
padding-bottom: 2px !important;
|
|
}
|
|
|
|
/* Motion (opt-out via data-anim="off") */
|
|
html[data-anim="on"] .card,
|
|
html[data-anim="on"] .stat,
|
|
html[data-anim="on"] button,
|
|
html[data-anim="on"] .accordion,
|
|
html[data-anim="on"] .modal-card {
|
|
transition:
|
|
transform 0.18s ease,
|
|
box-shadow 0.18s ease,
|
|
border-color 0.18s ease,
|
|
background-color 0.18s ease;
|
|
}
|
|
|
|
html[data-anim="on"] .card:hover {
|
|
transform: translateY(-2px);
|
|
box-shadow: 0 14px 26px rgba(0, 0, 0, 0.12);
|
|
}
|
|
|
|
html[data-anim="on"][data-theme="light"] .card:hover {
|
|
box-shadow: 0 14px 26px rgba(12, 18, 32, 0.12);
|
|
}
|
|
|
|
html[data-anim="on"] button:hover {
|
|
transform: translateY(-1px);
|
|
box-shadow: var(--shadow);
|
|
}
|
|
|
|
html[data-anim="on"] button:active {
|
|
transform: translateY(1px);
|
|
}
|
|
|
|
html[data-anim="off"] .card,
|
|
html[data-anim="off"] .stat,
|
|
html[data-anim="off"] button,
|
|
html[data-anim="off"] .accordion,
|
|
html[data-anim="off"] .modal-card {
|
|
transition: none;
|
|
}
|
|
|
|
/* Hard-stop any remaining motion (spinners, keyframes, incidental transitions) */
|
|
html[data-anim="off"] *,
|
|
html[data-anim="off"] *::before,
|
|
html[data-anim="off"] *::after {
|
|
animation: none !important;
|
|
transition: none !important;
|
|
}
|
|
|
|
/* Focus states */
|
|
button:focus-visible,
|
|
input:focus-visible,
|
|
select:focus-visible,
|
|
.card:focus-visible,
|
|
.status-chip:focus-visible,
|
|
.accordion-toggle:focus-visible {
|
|
outline: 2px solid var(--accent);
|
|
outline-offset: 2px;
|
|
}
|
|
|
|
/* Responsive tweaks */
|
|
@media (max-width: 960px) {
|
|
.hero {
|
|
grid-template-columns: 1fr;
|
|
}
|
|
.layout {
|
|
padding: 24px 14px 60px;
|
|
}
|
|
.panel {
|
|
padding: 16px;
|
|
}
|
|
.grid {
|
|
gap: 10px;
|
|
}
|
|
.card {
|
|
padding: 12px;
|
|
}
|
|
.hero-stats {
|
|
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
|
|
}
|
|
}
|
|
.codeblock {
|
|
background: var(--input-bg);
|
|
padding: 10px;
|
|
border-radius: 10px;
|
|
max-width: 440px;
|
|
min-width: 260px;
|
|
border: 1px solid var(--border);
|
|
white-space: pre-wrap;
|
|
word-break: break-all;
|
|
}
|
|
|
|
.modal {
|
|
position: fixed;
|
|
inset: 0;
|
|
background: rgba(0, 0, 0, 0.55);
|
|
display: grid;
|
|
place-items: center;
|
|
opacity: 0;
|
|
pointer-events: none;
|
|
transition: opacity 0.18s ease;
|
|
z-index: 20;
|
|
}
|
|
.modal.hidden {
|
|
display: none;
|
|
}
|
|
.modal:not(.hidden) {
|
|
opacity: 1;
|
|
pointer-events: auto;
|
|
}
|
|
.modal-card {
|
|
background: var(--panel);
|
|
border: 1px solid var(--border);
|
|
padding: 18px;
|
|
border-radius: 14px;
|
|
min-width: 300px;
|
|
max-width: 420px;
|
|
}
|
|
.modal-card.wide {
|
|
max-width: 820px;
|
|
width: 90vw;
|
|
max-height: 90vh;
|
|
overflow-y: auto;
|
|
position: relative;
|
|
padding: 0;
|
|
}
|
|
.modal-card {
|
|
transform: translateY(6px) scale(0.99);
|
|
transition:
|
|
transform 0.18s ease,
|
|
box-shadow 0.18s ease;
|
|
}
|
|
.modal-card.wide .panel-header {
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 3;
|
|
margin: 0 0 12px;
|
|
padding: 18px 18px 12px;
|
|
background: var(--panel);
|
|
border-bottom: 1px solid var(--border);
|
|
}
|
|
|
|
.modal-card.wide .help-body {
|
|
padding: 0 18px 18px;
|
|
}
|
|
|
|
/* Extra breathing room for custom add-service modal */
|
|
#addServiceModal .modal-card {
|
|
padding: 18px 18px 16px;
|
|
}
|
|
#addServiceModal .controls {
|
|
padding: 0 2px 4px;
|
|
}
|
|
.modal:not(.hidden) .modal-card {
|
|
transform: translateY(0) scale(1);
|
|
}
|
|
.modal-card .close-btn {
|
|
min-width: 0;
|
|
width: 36px;
|
|
height: 36px;
|
|
font-size: 1rem;
|
|
line-height: 1;
|
|
padding: 0;
|
|
}
|
|
.config-list {
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 12px;
|
|
}
|
|
.config-row {
|
|
border: 1px solid var(--border);
|
|
border-radius: 12px;
|
|
padding: 12px;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
gap: 12px;
|
|
flex-wrap: wrap;
|
|
align-items: center;
|
|
}
|
|
.config-row.danger {
|
|
border-color: #ef4444;
|
|
}
|
|
|
|
.modal-actions {
|
|
display: flex;
|
|
gap: 10px;
|
|
align-items: center;
|
|
margin-top: 16px;
|
|
}
|
|
.modal-actions .push {
|
|
flex: 1;
|
|
}
|
|
.modal-actions .primary {
|
|
background: linear-gradient(135deg, #16d0d8, #59e693);
|
|
color: #0c0f17;
|
|
border: none;
|
|
padding: 10px 14px;
|
|
border-radius: 10px;
|
|
font-weight: 600;
|
|
}
|
|
.modal-card .status-msg {
|
|
margin-top: 6px;
|
|
}
|
|
.config-label h4 {
|
|
margin: 0 0 4px;
|
|
}
|
|
.config-controls {
|
|
display: flex;
|
|
gap: 10px;
|
|
align-items: center;
|
|
flex-wrap: wrap;
|
|
}
|
|
.config-controls textarea {
|
|
width: 100%;
|
|
resize: vertical;
|
|
min-height: 96px;
|
|
}
|
|
.config-controls input[type="text"],
|
|
.config-controls input[type="number"],
|
|
.config-controls select {
|
|
width: 100%;
|
|
max-width: 100%;
|
|
}
|
|
.status-msg {
|
|
margin-top: 4px;
|
|
}
|
|
|
|
.overlay {
|
|
position: fixed;
|
|
inset: 0;
|
|
background: rgba(0, 0, 0, 0.6);
|
|
display: grid;
|
|
place-items: center;
|
|
z-index: 50;
|
|
}
|
|
.overlay.hidden {
|
|
display: none;
|
|
}
|
|
.overlay-box {
|
|
background: var(--panel);
|
|
border: 1px solid var(--border);
|
|
padding: 20px;
|
|
border-radius: 14px;
|
|
max-width: 420px;
|
|
text-align: center;
|
|
box-shadow: var(--shadow);
|
|
}
|
|
.spinner {
|
|
margin: 12px auto 4px;
|
|
width: 32px;
|
|
height: 32px;
|
|
border: 4px solid rgba(255, 255, 255, 0.2);
|
|
border-top-color: var(--accent);
|
|
border-radius: 50%;
|
|
animation: spin 0.8s linear infinite;
|
|
}
|
|
@keyframes spin {
|
|
to {
|
|
transform: rotate(360deg);
|
|
}
|
|
}
|
|
.modal-actions {
|
|
margin-top: 14px;
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
gap: 10px;
|
|
}
|
|
.modal-actions button {
|
|
min-width: 100px;
|
|
}
|
|
.help-body h4 {
|
|
margin: 10px 0 6px;
|
|
}
|
|
.help-body ul {
|
|
margin: 0 0 12px 18px;
|
|
padding: 0;
|
|
color: var(--text);
|
|
}
|
|
.help-body ul a {
|
|
color: var(--accent);
|
|
text-decoration: underline;
|
|
}
|
|
.help-body li {
|
|
margin: 4px 0;
|
|
}
|
|
.danger {
|
|
border-color: #ef4444;
|
|
}
|
|
.modal-card label {
|
|
display: block;
|
|
margin-top: 10px;
|
|
color: var(--muted);
|
|
font-size: 0.95rem;
|
|
}
|
|
.modal-card input {
|
|
width: 100%;
|
|
margin-top: 4px;
|
|
}
|
|
.modal-actions {
|
|
margin-top: 14px;
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
gap: 10px;
|
|
}
|
|
|
|
/* Header and status chips responsive layout */
|
|
@media (max-width: 760px) {
|
|
.topbar {
|
|
flex-direction: column;
|
|
align-items: stretch;
|
|
gap: 10px;
|
|
padding: 12px 16px;
|
|
}
|
|
.brand {
|
|
justify-content: flex-start;
|
|
}
|
|
.top-actions {
|
|
width: 100%;
|
|
justify-content: flex-start;
|
|
gap: 8px;
|
|
}
|
|
.top-actions .ghost {
|
|
padding: 8px 10px;
|
|
}
|
|
.top-indicators {
|
|
width: 100%;
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
|
|
gap: 8px;
|
|
align-items: center;
|
|
}
|
|
.top-indicators .chip-label {
|
|
grid-column: 1 / -1;
|
|
margin-right: 0;
|
|
font-size: 0.8rem;
|
|
}
|
|
.top-indicators .status-chip,
|
|
.top-indicators .hint {
|
|
width: auto;
|
|
justify-self: flex-start;
|
|
}
|
|
}
|
|
|
|
@media (max-width: 820px) {
|
|
.hero {
|
|
grid-template-columns: 1fr;
|
|
}
|
|
.hero-stats {
|
|
grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
|
|
}
|
|
}
|