:root{--bg-dark: #0a0a0f;--bg-card: #12121a;--bg-card-hover: #1a1a25;--neon-cyan: #00ffff;--neon-magenta: #ff00ff;--neon-blue: #0088ff;--neon-green: #00ff88;--text-primary: #ffffff;--text-muted: #888899;--border-color: #2a2a3a;--glow-cyan: 0 0 20px rgba(0, 255, 255, .3);--glow-magenta: 0 0 20px rgba(255, 0, 255, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;line-height:1.5}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.animated-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0}.login-container{position:relative;z-index:10;padding:2rem}.login-card{position:relative;background:#12121ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(0,255,255,.2);border-radius:24px;padding:3rem 2.5rem;width:100%;max-width:400px;overflow:hidden}.login-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(0,255,255,.08) 0%,rgba(255,0,255,.05) 30%,transparent 60%);animation:rotateGlow 20s linear infinite;pointer-events:none}@keyframes rotateGlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-header{text-align:center;margin-bottom:2.5rem}.login-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,#00ffff26,#ff00ff1a);border:1px solid rgba(0,255,255,.3);border-radius:20px;margin-bottom:1.5rem}.login-icon{color:var(--neon-cyan);filter:drop-shadow(0 0 15px rgba(0,255,255,.6))}.login-title{font-size:2.5rem;font-weight:800;letter-spacing:.3em;background:linear-gradient(135deg,var(--neon-cyan) 0%,var(--neon-magenta) 50%,var(--neon-cyan) 100%);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 5s ease infinite;text-shadow:0 0 40px rgba(0,255,255,.4)}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.login-subtitle{color:var(--text-muted);font-size:.95rem;margin-top:.5rem;letter-spacing:.1em}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{position:relative}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted);z-index:2;transition:color .3s ease}.input-group input{width:100%;padding:1rem 1rem 1rem 3rem;background:#ffffff08;border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:1rem;transition:all .3s ease;position:relative;z-index:1}.input-group input::placeholder{color:var(--text-muted)}.input-group input:focus{outline:none;border-color:var(--neon-cyan);background:#00ffff08;box-shadow:0 0 20px #00ffff26,inset 0 0 20px #00ffff08}.input-group:focus-within .input-icon{color:var(--neon-cyan)}.input-glow{position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:13px;background:linear-gradient(135deg,var(--neon-cyan),var(--neon-magenta));opacity:0;z-index:0;transition:opacity .3s ease}.input-group:focus-within .input-glow{opacity:.3;animation:pulseGlow 2s ease-in-out infinite}@keyframes pulseGlow{0%,to{opacity:.3}50%{opacity:.5}}.login-error{background:#ff44441a;border:1px solid rgba(255,68,68,.3);color:#f66;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;text-align:center}.login-btn{position:relative;width:100%;padding:1rem 2rem;margin-top:.5rem;background:linear-gradient(135deg,#0ff3,#ff00ff26);border:1px solid var(--neon-cyan);border-radius:12px;color:var(--neon-cyan);font-size:1rem;font-weight:600;letter-spacing:.1em;cursor:pointer;transition:all .3s ease;overflow:hidden}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#00ffff4d,#ff00ff40);box-shadow:0 0 30px #00ffff4d,0 0 60px #ff00ff26;transform:translateY(-2px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.btn-glow{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:btnShine 3s ease-in-out infinite}@keyframes btnShine{0%{left:-100%}50%,to{left:100%}}.btn-spinner{display:inline-block;width:20px;height:20px;border:2px solid transparent;border-top-color:var(--neon-cyan);border-radius:50%;animation:spin .8s linear infinite}.login-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem;color:var(--text-muted);font-size:.85rem}.pulse-dot{width:8px;height:8px;background:var(--neon-green);border-radius:50%;box-shadow:0 0 10px var(--neon-green);animation:pulse 2s ease-in-out infinite}.app{min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}.background-grid{position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(0,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,255,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none;z-index:0}header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(180deg,#12121af2,#0a0a0fcc);border-bottom:1px solid var(--border-color);position:relative;z-index:10}.header-left{display:flex;align-items:center;gap:1rem}.header-icon{color:var(--neon-cyan);filter:drop-shadow(0 0 10px rgba(0,255,255,.5))}header h1{font-size:1.75rem;font-weight:700;letter-spacing:.2em;background:linear-gradient(135deg,var(--neon-cyan) 0%,var(--neon-magenta) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(0,255,255,.3)}.header-subtitle{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-muted)}.header-right{display:flex;align-items:center;gap:1rem}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:#00ffff1a;border:1px solid rgba(0,255,255,.2);border-radius:20px;color:var(--neon-cyan);font-size:.8rem;font-weight:500}.refresh-btn,.logout-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-muted);padding:.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.refresh-btn:hover{border-color:var(--neon-cyan);color:var(--neon-cyan);box-shadow:var(--glow-cyan)}.logout-btn:hover{border-color:var(--neon-magenta);color:var(--neon-magenta);box-shadow:var(--glow-magenta)}.last-update{font-size:.8rem;color:var(--text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.online{background:var(--neon-green);box-shadow:0 0 10px var(--neon-green);animation:pulse 2s infinite}.status-dot.offline{background:#f44;box-shadow:0 0 10px #f44}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%;position:relative;z-index:5}.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-card{background:linear-gradient(135deg,var(--bg-card) 0%,rgba(18,18,26,.8) 100%);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.metric-card:hover{transform:translateY(-2px);border-color:#00ffff4d;box-shadow:0 10px 40px #0000004d,var(--glow-cyan)}.metric-icon{padding:.75rem;background:#ffffff0d;border-radius:12px}.metric-content{flex:1}.metric-title{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.25rem}.metric-value{font-size:2rem;font-weight:700;line-height:1.2}.metric-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.containers-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;color:var(--neon-cyan)}.section-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.container-count{margin-left:auto;font-size:.85rem;color:var(--text-muted);background:#ffffff0d;padding:.25rem .75rem;border-radius:20px}.table-wrapper{overflow-x:auto}.containers-table{width:100%;border-collapse:collapse}.containers-table th{text-align:left;padding:.75rem 1rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border-color)}.containers-table td{padding:.875rem 1rem;border-bottom:1px solid rgba(42,42,58,.5);font-size:.9rem}.containers-table tr:last-child td{border-bottom:none}.containers-table tr:hover{background:#ffffff05}.containers-table .image-col{color:var(--text-muted);font-family:SF Mono,Monaco,monospace;font-size:.8rem}.containers-table .status-col{width:120px}.containers-table .status-text{color:var(--text-muted);font-size:.8rem}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:20px;font-size:.75rem;font-weight:500}.status-badge.running{background:#00ff8826;color:var(--neon-green)}.status-badge.stopped{background:#ff444426;color:#f66}.architecture-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;margin-bottom:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.architecture-diagram{position:relative;padding:1.5rem 0}.arch-flow{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.arch-node{display:flex;flex-direction:column;align-items:center;padding:1rem 1.25rem;background:#ffffff08;border:1px solid var(--border-color);border-radius:12px;min-width:100px;transition:all .3s ease}.arch-node:hover{transform:translateY(-2px);border-color:var(--neon-cyan);box-shadow:0 5px 20px #0000004d,var(--glow-cyan)}.arch-node-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#ffffff0d;border-radius:12px;margin-bottom:.75rem}.arch-node.internet .arch-node-icon{color:var(--neon-blue)}.arch-node.traefik .arch-node-icon{color:var(--neon-green)}.arch-node.frontend .arch-node-icon{color:var(--neon-cyan)}.arch-node.api .arch-node-icon{color:var(--neon-magenta)}.arch-node.postgres .arch-node-icon{color:#336791}.arch-node-label{font-size:.9rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.arch-node-sub{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.arch-node-detail{font-size:.65rem;color:var(--neon-green);margin-top:.5rem;padding:.2rem .5rem;background:#00ff881a;border-radius:4px}.arch-arrow{display:flex;flex-direction:column;align-items:center;gap:.25rem;color:var(--text-muted);padding:0 .5rem}.arch-arrow span{font-size:.65rem;font-family:SF Mono,Monaco,monospace;color:var(--neon-cyan);opacity:.7}.arch-stack{display:flex;flex-direction:column;gap:.5rem}.arch-stack .arch-node{min-width:110px;padding:.75rem 1rem}.arch-stack .arch-node-icon{width:40px;height:40px;margin-bottom:.5rem}.arch-network-label{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.5rem;padding-top:1rem;border-top:1px dashed var(--border-color);color:var(--text-muted);font-size:.75rem}.arch-network-label svg{color:var(--neon-cyan)}@media(max-width:768px){.arch-flow{flex-direction:column;gap:.75rem}.arch-arrow{transform:rotate(90deg);padding:.25rem 0}.arch-stack{flex-direction:row}.arch-node{min-width:90px;padding:.75rem}.arch-node-icon{width:36px;height:36px}}.info-section{margin-bottom:2rem}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-card{display:flex;align-items:center;gap:1rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem;color:var(--neon-cyan)}.info-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:.9rem;color:var(--text-primary)}.quick-ref{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.quick-ref-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;cursor:pointer;color:var(--neon-cyan);transition:background .2s ease}.quick-ref-header:hover{background:#ffffff05}.quick-ref-header span{flex:1;color:var(--text-primary);font-weight:500}.quick-ref-content{padding:0 1.25rem 1.25rem;display:grid;gap:.5rem}.command-row{display:flex;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid rgba(42,42,58,.3)}.command-row:last-child{border-bottom:none}.command-row code{font-family:SF Mono,Monaco,monospace;font-size:.85rem;color:var(--neon-magenta);background:#ff00ff1a;padding:.25rem .5rem;border-radius:4px;min-width:200px}.command-row span{font-size:.85rem;color:var(--text-muted)}footer{padding:1.5rem 2rem;text-align:center;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border-color);background:#12121acc;display:flex;justify-content:center;align-items:center;gap:.75rem;position:relative;z-index:10}.footer-dot{color:var(--neon-cyan)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;background:var(--bg-dark)}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--neon-cyan);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:1rem}.error-screen{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background:var(--bg-dark)}.error-icon{color:#f44}.error-text{font-size:1.5rem;font-weight:600}.error-detail{color:var(--text-muted)}.retry-btn{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1.5rem;background:transparent;border:1px solid var(--neon-cyan);color:var(--neon-cyan);border-radius:8px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.retry-btn:hover{background:#00ffff1a;box-shadow:var(--glow-cyan)}@media(max-width:768px){header{padding:1rem 1.25rem}header h1{font-size:1.25rem}.header-subtitle{font-size:.75rem}.user-badge{display:none}main{padding:1rem}.metrics{grid-template-columns:repeat(2,1fr);gap:1rem}.metric-card{padding:1rem}.metric-value{font-size:1.5rem}.containers-table .image-col,.containers-table .status-text{display:none}.info-cards{grid-template-columns:1fr}.command-row{flex-direction:column;align-items:flex-start;gap:.25rem}.command-row code{min-width:auto}.login-card{padding:2rem 1.5rem}.login-title{font-size:2rem}}@media(max-width:480px){.metrics{grid-template-columns:1fr}.last-update{display:none}}
