kitestacks-homelab/apps/kitestacks-portal-test/public/style.css.backup-before-discord-2026-06-08-2231
2026-06-08 22:47:39 -05:00

678 lines
19 KiB
Text

/* ===================================================================
KiteStacks.ao — cyberpunk portal stylesheet
=================================================================== */
:root {
--bg: #05030f;
--panel-bg: rgba(10, 6, 28, 0.72);
--panel-bg-solid: #0a061c;
--cyan: #54e8ff;
--cyan-bright: #7df3ff;
--magenta: #ff45c8;
--magenta-bright: #ff7adb;
--purple: #bd6cff;
--purple-bright: #d99dff;
--pink: #ff5fb1;
--green: #39ff7a;
--yellow: #ffd84a;
--orange: #ff8b3a;
--text: #e6f3ff;
--text-dim: #8aa3c0;
--font-display: 'Orbitron', sans-serif;
--font-ui: 'Rajdhani', sans-serif;
--font-mono: 'Share Tech Mono', monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
body {
font-family: var(--font-ui);
color: var(--text);
background: var(--bg) url('/images/cyberpunk-bg.png') center top / cover no-repeat fixed;
background-attachment: fixed;
min-height: 100vh;
overflow-x: hidden;
}
/* darkening overlay so neon pops */
.bg-overlay {
position: fixed; inset: 0;
background:
radial-gradient(ellipse at top, rgba(120, 60, 200, 0.18), transparent 60%),
linear-gradient(180deg, rgba(5, 3, 15, 0.55), rgba(5, 3, 15, 0.85));
pointer-events: none;
z-index: 0;
}
.portal {
position: relative;
z-index: 1;
max-width: 1700px;
margin: 0 auto;
padding: 18px 26px 32px;
display: flex;
flex-direction: column;
gap: 18px;
}
/* =================================================================
TOP HUD
================================================================= */
.hud {
display: grid;
grid-template-columns: repeat(5, minmax(160px, 1fr)) 2fr;
gap: 14px;
align-items: stretch;
}
.hud-cell {
display: flex;
align-items: center;
gap: 12px;
padding: 10px 16px;
border-radius: 10px;
background: linear-gradient(180deg, rgba(15, 10, 40, 0.7), rgba(8, 5, 22, 0.85));
border: 1px solid rgba(84, 232, 255, 0.35);
box-shadow:
0 0 12px rgba(84, 232, 255, 0.15),
inset 0 0 18px rgba(84, 232, 255, 0.05);
color: var(--cyan);
min-height: 64px;
}
.hud-icon {
width: 30px; height: 30px;
flex: 0 0 auto;
filter: drop-shadow(0 0 6px currentColor);
}
.hud-text { display: flex; flex-direction: column; line-height: 1.1; min-width: 0; }
.hud-label {
font-family: var(--font-display);
font-size: 11px;
letter-spacing: 0.16em;
color: var(--text-dim);
text-transform: uppercase;
}
.hud-value {
font-family: var(--font-display);
font-weight: 700;
font-size: 17px;
color: var(--cyan-bright);
text-shadow: 0 0 8px rgba(84, 232, 255, 0.6);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* per-cell accents */
.hud-cpu { border-color: rgba(84, 232, 255, 0.45); color: var(--cyan); }
.hud-ram { border-color: rgba(189, 108, 255, 0.45); color: var(--purple); }
.hud-storage { border-color: rgba(255, 69, 200, 0.45); color: var(--magenta); }
.hud-uptime { border-color: rgba(57, 255, 122, 0.45); color: var(--green); }
.hud-weather { border-color: rgba(255, 216, 74, 0.45); color: var(--yellow); }
.hud-cpu .hud-value { color: #9af0ff; text-shadow: 0 0 8px var(--cyan); }
.hud-ram .hud-value { color: #d9b5ff; text-shadow: 0 0 8px var(--purple); }
.hud-storage .hud-value { color: #ff9ddc; text-shadow: 0 0 8px var(--magenta); }
.hud-uptime .hud-value { color: #9affc1; text-shadow: 0 0 8px var(--green); }
.hud-weather .hud-value { color: #ffec9a; text-shadow: 0 0 8px var(--yellow); }
.hud-temp { font-size: 19px; }
.hud-search {
display: flex; align-items: center;
background: linear-gradient(180deg, rgba(15, 10, 40, 0.7), rgba(8, 5, 22, 0.85));
border: 1px solid rgba(84, 232, 255, 0.4);
border-radius: 10px;
padding: 0 14px;
box-shadow:
0 0 12px rgba(84, 232, 255, 0.18),
inset 0 0 18px rgba(84, 232, 255, 0.05);
}
.hud-search input {
flex: 1;
background: transparent;
border: 0;
outline: none;
color: var(--text);
font-family: var(--font-ui);
font-size: 17px;
padding: 14px 0;
}
.hud-search input::placeholder { color: var(--text-dim); }
.hud-search button {
background: transparent;
border: 0;
color: var(--cyan);
cursor: pointer;
padding: 6px;
display: flex;
filter: drop-shadow(0 0 6px var(--cyan));
}
.hud-search button svg { width: 22px; height: 22px; }
/* =================================================================
HERO
================================================================= */
.hero {
display: flex;
align-items: center;
justify-content: center;
gap: 32px;
padding: 8px 12px 4px;
min-height: 220px;
}
.hero-center {
display: flex;
align-items: center;
gap: 24px;
}
.hero-kite {
width: 140px; height: 140px;
object-fit: contain;
filter:
drop-shadow(0 0 18px var(--cyan))
drop-shadow(0 0 32px rgba(84, 232, 255, 0.6));
animation: kite-pulse 4s ease-in-out infinite;
}
@keyframes kite-pulse {
0%, 100% { filter: drop-shadow(0 0 14px var(--cyan)) drop-shadow(0 0 28px rgba(84, 232, 255, 0.5)); }
50% { filter: drop-shadow(0 0 22px var(--cyan)) drop-shadow(0 0 44px rgba(84, 232, 255, 0.8)); }
}
.hero-titles { display: flex; flex-direction: column; }
.hero-title {
font-family: var(--font-display);
font-weight: 900;
font-size: clamp(48px, 6vw, 92px);
margin: 0;
line-height: 1;
color: #ffffff;
text-shadow:
0 0 12px rgba(255, 255, 255, 0.6),
0 0 24px var(--cyan),
0 0 48px rgba(84, 232, 255, 0.6);
letter-spacing: 0.01em;
}
.dot-ao {
color: var(--cyan-bright);
text-shadow:
0 0 12px var(--cyan),
0 0 30px rgba(84, 232, 255, 0.8);
}
.hero-tagline {
font-family: var(--font-display);
font-weight: 500;
font-size: clamp(13px, 1.2vw, 17px);
letter-spacing: 0.42em;
color: var(--text-dim);
margin: 8px 0 0;
text-shadow: 0 0 6px rgba(84, 232, 255, 0.4);
}
/* hex badge */
.hex-badge { position: relative; width: 180px; height: 200px; }
.hex-svg { width: 100%; height: 100%; filter: drop-shadow(0 0 14px var(--magenta)); }
.hex-outer { fill: none; stroke: var(--magenta); stroke-width: 3; }
.hex-inner { fill: rgba(20, 8, 32, 0.7); stroke: rgba(255, 69, 200, 0.6); stroke-width: 1.5; }
.hex-content {
position: absolute; inset: 0;
display: flex; flex-direction: column; align-items: center; justify-content: center;
gap: 2px;
font-family: var(--font-display);
text-shadow: 0 0 8px var(--magenta);
}
.hex-l1 { font-size: 13px; letter-spacing: 0.3em; color: var(--magenta-bright); }
.hex-l2 { font-size: 22px; font-weight: 700; letter-spacing: 0.15em; color: #ff9ddc; }
.hex-l3 {
font-size: 38px; font-weight: 900;
color: var(--cyan-bright);
text-shadow: 0 0 12px var(--cyan);
line-height: 1;
}
.hex-l3 span { font-size: 22px; color: var(--magenta-bright); text-shadow: 0 0 8px var(--magenta); }
.hex-pulse {
width: 80px; height: 14px; margin-top: 4px;
}
.hex-pulse polyline {
fill: none; stroke: var(--green); stroke-width: 1.5;
filter: drop-shadow(0 0 4px var(--green));
}
/* =================================================================
PANELS
================================================================= */
.row { display: grid; gap: 18px; }
.row-2 { grid-template-columns: 1fr 1fr; }
.row-3 { grid-template-columns: 1fr 1fr; }
.row-bottom { grid-template-columns: 1.6fr 1fr; align-items: start; }
.panel {
position: relative;
background: var(--panel-bg);
border: 1.5px solid var(--panel-border, var(--cyan));
border-radius: 10px;
padding: 14px 18px 14px;
box-shadow:
0 0 22px var(--panel-glow, rgba(84, 232, 255, 0.22)),
inset 0 0 30px rgba(0, 0, 0, 0.4);
backdrop-filter: blur(6px);
}
.panel-cyan { --panel-border: var(--cyan); --panel-glow: rgba(84, 232, 255, 0.28); --panel-head-color: var(--cyan); }
.panel-magenta { --panel-border: var(--magenta); --panel-glow: rgba(255, 69, 200, 0.28); --panel-head-color: var(--magenta); }
.panel-purple { --panel-border: var(--purple); --panel-glow: rgba(189, 108, 255, 0.28); --panel-head-color: var(--purple); }
.panel-pink { --panel-border: var(--pink); --panel-glow: rgba(255, 95, 177, 0.28); --panel-head-color: var(--pink); }
.panel-head {
font-family: var(--font-display);
font-weight: 700;
font-size: 14px;
letter-spacing: 0.22em;
color: var(--panel-head-color);
text-shadow: 0 0 8px var(--panel-head-color);
margin-bottom: 12px;
display: flex;
align-items: center;
gap: 8px;
}
.chevrons { color: var(--panel-head-color); font-weight: 700; opacity: 0.85; }
/* =================================================================
CARDS
================================================================= */
.cards { display: grid; gap: 14px; }
.cards-2 { grid-template-columns: 1fr 1fr; }
.cards-3 { grid-template-columns: repeat(3, 1fr); }
.cards-4 { grid-template-columns: repeat(4, 1fr); }
.card {
display: flex;
align-items: center;
gap: 14px;
padding: 14px 16px;
border-radius: 8px;
border: 1px solid rgba(84, 232, 255, 0.22);
background: linear-gradient(180deg, rgba(20, 10, 40, 0.55), rgba(8, 4, 22, 0.75));
text-decoration: none;
color: var(--text);
transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
min-height: 76px;
}
.card:hover {
transform: translateY(-2px);
border-color: var(--panel-border, var(--cyan));
box-shadow: 0 0 18px var(--panel-glow, rgba(84, 232, 255, 0.4));
background: linear-gradient(180deg, rgba(30, 15, 55, 0.65), rgba(12, 6, 28, 0.8));
}
.card img {
width: 44px; height: 44px;
object-fit: contain;
flex: 0 0 auto;
filter: drop-shadow(0 0 6px rgba(84, 232, 255, 0.4));
}
.card-title {
font-family: var(--font-display);
font-weight: 700;
font-size: 17px;
color: #ffffff;
line-height: 1.1;
text-shadow: 0 0 4px rgba(255, 255, 255, 0.25);
}
.card-sub {
font-family: var(--font-ui);
font-size: 13px;
color: var(--text-dim);
margin-top: 3px;
letter-spacing: 0.04em;
}
.sc-icon {
width: 44px; height: 44px;
display: inline-flex; align-items: center; justify-content: center;
font-family: var(--font-mono);
font-size: 22px;
color: var(--purple-bright);
text-shadow: 0 0 8px var(--purple);
background: rgba(189, 108, 255, 0.08);
border: 1px solid rgba(189, 108, 255, 0.35);
border-radius: 6px;
flex: 0 0 auto;
}
/* =================================================================
OVERVIEW
================================================================= */
.overview {
list-style: none;
margin: 0; padding: 4px 0;
font-family: var(--font-mono);
font-size: 15px;
display: flex;
flex-direction: column;
gap: 10px;
}
.overview li {
display: grid;
grid-template-columns: 110px 14px 1fr;
align-items: center;
gap: 4px;
}
.ov-key {
color: var(--text-dim);
letter-spacing: 0.08em;
text-transform: uppercase;
font-family: var(--font-display);
font-size: 12px;
font-weight: 600;
}
.ov-sep { color: var(--cyan); text-align: center; }
.ov-val { color: var(--cyan-bright); text-shadow: 0 0 6px rgba(84, 232, 255, 0.5); }
/* =================================================================
GAUGES
================================================================= */
.gauges {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 14px;
padding: 4px 0 0;
}
.gauge {
position: relative;
display: flex;
flex-direction: column;
align-items: center;
gap: 4px;
padding: 4px 2px 8px;
}
.gauge svg:first-child { width: 110px; height: 110px; transform: rotate(-90deg); }
.g-track { fill: none; stroke: rgba(255, 255, 255, 0.08); stroke-width: 9; }
.g-fill {
fill: none;
stroke-width: 9;
stroke-linecap: round;
stroke-dasharray: 301.6; /* 2π·48 */
stroke-dashoffset: 301.6;
transition: stroke-dashoffset 0.8s cubic-bezier(.2,.8,.2,1);
}
.gauge[data-color="cyan"] .g-fill { stroke: var(--cyan); filter: drop-shadow(0 0 6px var(--cyan)); }
.gauge[data-color="green"] .g-fill { stroke: var(--green); filter: drop-shadow(0 0 6px var(--green)); }
.gauge[data-color="yellow"] .g-fill { stroke: var(--yellow); filter: drop-shadow(0 0 6px var(--yellow)); }
.gauge[data-color="pink"] .g-fill { stroke: var(--pink); filter: drop-shadow(0 0 6px var(--pink)); }
.gauge .g-label {
position: absolute;
top: 38px;
font-family: var(--font-display);
font-size: 11px;
letter-spacing: 0.18em;
color: var(--text-dim);
}
.gauge .g-value {
position: absolute;
top: 54px;
font-family: var(--font-display);
font-weight: 700;
font-size: 22px;
color: var(--cyan-bright);
text-shadow: 0 0 8px currentColor;
}
.gauge[data-color="green"] .g-value { color: var(--green); }
.gauge[data-color="yellow"] .g-value { color: var(--yellow); }
.gauge .g-sub {
font-family: var(--font-mono);
font-size: 11px;
color: var(--text-dim);
margin-top: 6px;
}
.g-wave {
width: 100%; height: 16px; margin-top: 4px;
}
.g-wave polyline {
fill: none;
stroke: var(--cyan);
stroke-width: 1.2;
filter: drop-shadow(0 0 3px var(--cyan));
}
.gauge-net {
justify-content: flex-start;
padding-top: 38px;
}
.gauge-net .g-label { position: static; margin-bottom: 6px; }
.g-net { display: flex; flex-direction: column; gap: 4px; align-items: center; }
.net-line {
font-family: var(--font-display);
font-weight: 700;
font-size: 14px;
}
.net-line.up { color: var(--green); text-shadow: 0 0 6px var(--green); }
.net-line.dn { color: var(--magenta); text-shadow: 0 0 6px var(--magenta); }
/* =================================================================
RECENT ACTIVITY
================================================================= */
.activity {
list-style: none;
margin: 0; padding: 4px 0;
display: flex;
flex-direction: column;
gap: 12px;
}
.activity li {
display: grid;
grid-template-columns: 18px 1fr auto;
align-items: center;
gap: 12px;
padding: 8px 6px;
border-radius: 6px;
background: rgba(20, 10, 40, 0.35);
border: 1px solid rgba(84, 232, 255, 0.12);
}
.act-ico { font-size: 14px; filter: drop-shadow(0 0 4px currentColor); }
.act-txt { font-family: var(--font-ui); font-size: 15px; color: var(--text); }
.act-time { font-family: var(--font-mono); font-size: 13px; color: var(--text-dim); }
/* =================================================================
FOOTER
================================================================= */
.portal-footer {
display: flex;
align-items: center;
justify-content: center;
gap: 18px;
padding: 18px 0 6px;
font-family: var(--font-display);
font-size: 13px;
letter-spacing: 0.16em;
color: var(--text-dim);
}
.foot-text { text-shadow: 0 0 4px rgba(189, 108, 255, 0.4); }
.foot-bracket {
flex: 1;
height: 8px;
position: relative;
}
.foot-bracket::before {
content: "";
position: absolute;
top: 50%;
left: 0; right: 0;
height: 1px;
background: linear-gradient(90deg, transparent, var(--purple) 30%, var(--cyan) 70%, transparent);
opacity: 0.7;
}
.foot-bracket.left::after, .foot-bracket.right::after {
content: "";
position: absolute; top: 50%;
width: 26px; height: 8px;
transform: translateY(-50%);
background:
repeating-linear-gradient(90deg, var(--cyan) 0 3px, transparent 3px 6px);
opacity: 0.7;
}
.foot-bracket.left::after { right: 8px; }
.foot-bracket.right::after { left: 8px; }
/* =================================================================
RESPONSIVE
================================================================= */
@media (max-width: 1400px) {
.hud { grid-template-columns: repeat(3, 1fr); }
.hud-search { grid-column: 1 / -1; }
.hero { grid-template-columns: 1fr; }
.hero-right { justify-content: center; }
.row-3, .row-bottom { grid-template-columns: 1fr; }
.row-2 { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
.hud { grid-template-columns: 1fr 1fr; }
.cards-4, .cards-3 { grid-template-columns: 1fr 1fr; }
.hero-title { font-size: 44px; }
.hero-kite { width: 96px; height: 96px; }
.gauges { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
.hud { grid-template-columns: 1fr; }
.cards-2, .cards-3, .cards-4 { grid-template-columns: 1fr; }
.gauges { grid-template-columns: 1fr; }
}
/* =================================================================
TOAST (coming soon)
================================================================= */
#ks-toast {
position: fixed;
left: 50%;
bottom: 40px;
transform: translate(-50%, 30px);
background: linear-gradient(180deg, rgba(20, 10, 40, 0.95), rgba(8, 4, 22, 0.95));
border: 1px solid var(--magenta);
border-radius: 8px;
padding: 12px 22px;
font-family: var(--font-display);
font-weight: 600;
font-size: 14px;
letter-spacing: 0.14em;
color: var(--magenta-bright);
text-shadow: 0 0 6px var(--magenta);
box-shadow: 0 0 24px rgba(255, 69, 200, 0.5);
opacity: 0;
pointer-events: none;
transition: opacity 0.25s ease, transform 0.25s ease;
z-index: 1000;
}
#ks-toast.show {
opacity: 1;
transform: translate(-50%, 0);
}
/* ─── Activity panel polish ─── */
.activity li.act-empty {
opacity: 0.7;
font-style: italic;
}
.activity li .act-txt {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
/* ─── Per-core CPU bars ─── */
.cores {
margin-top: 14px;
padding: 12px 4px 2px;
border-top: 1px dashed rgba(255, 69, 200, 0.25);
}
.cores-head {
display: flex;
align-items: baseline;
justify-content: space-between;
margin-bottom: 10px;
padding: 0 6px;
}
.cores-title {
font-family: var(--font-display);
font-size: 12px;
letter-spacing: 0.22em;
color: var(--magenta);
text-shadow: 0 0 6px var(--magenta);
}
.cores-meta {
font-family: var(--font-mono);
font-size: 12px;
color: var(--text-dim);
}
.cores-grid {
display: grid;
grid-template-columns: repeat(8, 1fr);
gap: 10px;
padding: 0 4px;
justify-content: center;
}
@media (max-width: 1100px) {
.cores-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 560px) {
.cores-grid { grid-template-columns: repeat(2, 1fr); }
}
.core {
display: flex;
flex-direction: column;
gap: 4px;
padding: 6px 8px;
border-radius: 6px;
background: rgba(20, 10, 40, 0.45);
border: 1px solid rgba(84, 232, 255, 0.15);
}
.core-head {
display: flex;
align-items: baseline;
justify-content: space-between;
font-family: var(--font-display);
font-size: 11px;
letter-spacing: 0.1em;
}
.core-label { color: var(--text-dim); }
.core-pct {
color: var(--cyan-bright);
text-shadow: 0 0 4px var(--cyan);
font-weight: 700;
}
.core-track {
position: relative;
height: 6px;
background: rgba(255, 255, 255, 0.06);
border-radius: 3px;
overflow: hidden;
}
.core-bar {
position: absolute;
top: 0; left: 0; bottom: 0;
width: 0%;
background: linear-gradient(90deg, var(--cyan), var(--purple));
box-shadow: 0 0 6px var(--cyan);
transition: width 0.6s cubic-bezier(.2,.8,.2,1);
border-radius: 3px;
}
/* color shifts as load increases */
.core[data-load="med"] .core-bar { background: linear-gradient(90deg, var(--green), var(--yellow)); box-shadow: 0 0 6px var(--yellow); }
.core[data-load="med"] .core-pct { color: var(--yellow); text-shadow: 0 0 4px var(--yellow); }
.core[data-load="high"] .core-bar { background: linear-gradient(90deg, var(--yellow), var(--magenta)); box-shadow: 0 0 6px var(--magenta); }
.core[data-load="high"] .core-pct { color: var(--magenta-bright); text-shadow: 0 0 4px var(--magenta); }