/* =================================================================== 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 1fr; } .row-bottom { grid-template-columns: 1.2fr 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); }