:root{--bg: #ffffff;--bg-elevated: #ffffff;--bg-muted: #f9fafb;--bg-hover: #f5f5f5;--bg-input: #ffffff;--border: #e5e7eb;--border-hover: #d1d5db;--border-focus: #9ca3af;--text: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--accent: #111827;--accent-light: #f3f4f6;--success: #16a34a;--success-bg: #f0fdf4;--warning: #d97706;--warning-bg: #fffbeb;--info: #2563eb;--info-bg: #eff6ff;--danger: #dc2626;--danger-bg: #fef2f2;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-pill: 999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 16px 48px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;background:var(--bg-muted);color:var(--text);-webkit-font-smoothing:antialiased}.app-root{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1}.topnav{height:52px;position:sticky;top:0;z-index:100;background:var(--bg);border-bottom:1px solid var(--border)}.topnav-inner{max-width:1200px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center}.topnav-brand{display:flex;align-items:center;gap:7px;margin-right:24px;flex-shrink:0;text-decoration:none}.topnav-logo{font-size:17px}.topnav-title{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.3px}.topnav-links{display:flex;align-items:stretch;height:100%;flex:1}.topnav-link{display:flex;align-items:center;padding:0 12px;font-size:13.5px;font-weight:500;color:var(--text-secondary);text-decoration:none;background:none;border:none;border-bottom:2px solid transparent;transition:color .1s,border-color .1s;white-space:nowrap;cursor:pointer;font-family:inherit}.topnav-link:hover{color:var(--text)}.topnav-link.active{color:var(--text);font-weight:600;border-bottom-color:var(--text)}.topnav-right{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0}.topnav-logout{padding:5px 12px;font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;transition:border-color .1s,color .1s;font-family:inherit}.topnav-logout:hover{border-color:var(--danger);color:var(--danger)}.page{max-width:1200px;margin:0 auto;padding:36px 24px 64px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px}.page-header-left h1{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.4px;line-height:1.2}.page-header-left p{font-size:13px;color:var(--text-secondary);margin-top:3px}.page-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-top:2px}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-tertiary);margin-bottom:18px}.breadcrumb a,.breadcrumb button{color:var(--text-secondary);text-decoration:none;background:none;border:none;cursor:pointer;padding:0;font-size:13px;font-family:inherit;transition:color .1s}.breadcrumb a:hover,.breadcrumb button:hover{color:var(--text)}.drawer-hero{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);padding-bottom:var(--space-4);border-bottom:1px solid var(--border);margin-bottom:var(--space-4);color:var(--text-secondary);font-size:12.5px}.drawer-hero-sep{color:var(--text-tertiary);margin:0 2px}.chip-row{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-3)}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px 10px;border-radius:var(--r-pill);font-size:11.5px;font-weight:500;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-secondary)}.chip-success{background:var(--success-bg,#f0fdf4);color:var(--success,#16a34a);border-color:var(--success,#16a34a)}.chip-danger{background:var(--danger-bg,#fef2f2);color:var(--danger,#dc2626);border-color:var(--danger,#dc2626)}.chip-accent{background:var(--accent-light,#eff6ff);color:var(--accent,#2563eb);border-color:var(--accent,#2563eb)}.data-grid{display:grid;gap:var(--space-3)}.data-grid-auto{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.data-grid-2{grid-template-columns:repeat(2,1fr)}.data-grid-3{grid-template-columns:repeat(3,1fr)}.data-row{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4);background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--r-sm);min-width:0}.data-row-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary)}.data-row-value{display:flex;align-items:center;gap:var(--space-2);min-width:0}.data-row-text{flex:1;font-size:13.5px;font-weight:500;color:var(--text);min-width:0;word-break:break-all}.data-row-text.mono{font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px}.code-block{position:relative;background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--r-sm);padding:var(--space-3) var(--space-4);font-family:JetBrains Mono,ui-monospace,monospace;font-size:12px;word-break:break-all;line-height:1.6;color:var(--text-secondary)}.code-block-copy{position:absolute;top:6px;right:6px}.empty-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-7) 0;color:var(--text-secondary);text-align:center;gap:var(--space-2)}.empty-tab-icon{font-size:2rem;opacity:.4}.empty-tab-title{font-size:.875rem;font-weight:500;color:var(--text)}.empty-tab-desc{font-size:.8rem}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.section-head-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary)}.drawer-footer-bar{display:flex;gap:var(--space-2);width:100%}.drawer-footer-bar>.btn{flex:1}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;border-radius:var(--r-sm);border:none;cursor:pointer;transition:opacity .1s,background .1s,border-color .1s,color .1s;white-space:nowrap;text-decoration:none;font-family:inherit;line-height:1.4}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--text);color:#fff;font-weight:600}.btn-primary:not(:disabled):hover{background:#1f2937}.btn-secondary{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:not(:disabled):hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text)}.btn-danger{background:var(--bg);color:var(--danger);border:1px solid var(--border)}.btn-danger:not(:disabled):hover{background:var(--danger-bg);border-color:var(--danger)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:6px 8px}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.stat-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:36px}.stat-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:20px}.stat-num{font-size:28px;font-weight:700;color:var(--text);letter-spacing:-1px;line-height:1}.stat-label{font-size:12px;color:var(--text-secondary);margin-top:5px}.section{margin-bottom:36px}.section-title{font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px}.grid{display:grid;gap:12px}.grid-2{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.grid-4{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:18px 20px;cursor:pointer;transition:border-color .12s,box-shadow .12s}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.card-plain{cursor:default}.card-plain:hover{border-color:var(--border);box-shadow:none}.rows{display:flex;flex-direction:column;gap:6px}.row-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color .1s}.row-item:hover{border-color:var(--border-hover)}.row-item-plain{cursor:default}.row-item-plain:hover{border-color:var(--border)}.badge{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:var(--r-pill);font-size:11.5px;font-weight:500;white-space:nowrap}.badge-active{background:var(--success-bg);color:var(--success)}.badge-creating{background:var(--info-bg);color:var(--info)}.badge-updating{background:var(--warning-bg);color:var(--warning)}.badge-planning{background:#eff6ff;color:#2563eb}.badge-deleting,.badge-error{background:var(--danger-bg);color:var(--danger)}.badge-neutral{background:var(--bg-muted);color:var(--text-secondary)}.chip-server{background:#eff6ff;color:#2563eb}.chip-db{background:#f5f3ff;color:#7c3aed}.chip-storage{background:#f0fdfa;color:#0f766e}.chip-site{background:#fff7ed;color:#c2410c}.dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.75)}}.dot-pulse{animation:dot-pulse 1.2s ease-in-out infinite}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center}.empty-icon{font-size:34px;opacity:.3;margin-bottom:14px}.empty h3{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}.empty p{font-size:13px;color:var(--text-secondary);margin-bottom:20px;max-width:300px}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton{border-radius:var(--r-sm);background:linear-gradient(90deg,#f3f4f6 25%,#e9eaec,#f3f4f6 75%);background-size:1200px 100%;animation:shimmer 1.5s ease-in-out infinite}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:200;display:flex;justify-content:flex-end;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in{0%{transform:translate(24px);opacity:0}to{transform:none;opacity:1}}.drawer{background:var(--bg);border-left:1px solid var(--border);width:480px;max-width:100vw;height:100vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slide-in .18s ease}.drawer-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.drawer-title{font-size:15px;font-weight:700;color:var(--text)}.drawer-close{background:none;border:none;cursor:pointer;color:var(--text-tertiary);font-size:20px;line-height:1;padding:4px 6px;border-radius:4px;transition:color .1s,background .1s}.drawer-close:hover{color:var(--text);background:var(--bg-hover)}.drawer-body{flex:1;overflow-y:auto;padding:24px}.drawer-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0;background:var(--bg-muted)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border);cursor:pointer;gap:16px}.toggle-row:last-child{border-bottom:none}.toggle-row-title{font-size:.875rem;font-weight:500;color:var(--text);margin-bottom:2px}.toggle-row-desc{font-size:.75rem;color:var(--text-secondary)}.toggle{flex-shrink:0;width:36px;height:20px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--border);border-radius:10px;cursor:pointer;position:relative;transition:background .2s}.toggle:checked{background:var(--accent)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px #0003}.toggle:checked:after{transform:translate(16px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;animation:fade-in .15s ease}.modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:85vh;display:flex;flex-direction:column;animation:slide-in .15s ease}.modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:15px;font-weight:700;color:var(--text)}.modal-body{padding:20px 24px;overflow-y:auto;flex:1}.modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}.field{margin-bottom:16px}.label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}.label-hint{text-transform:none;letter-spacing:0;font-weight:400;color:var(--text-tertiary);margin-left:4px}.input,.select,.textarea{width:100%;padding:8px 11px;font-size:13.5px;font-family:inherit;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-input);color:var(--text);outline:none;transition:border-color .1s}.input:focus,.select:focus,.textarea:focus{border-color:var(--border-focus)}.input::placeholder,.textarea::placeholder{color:var(--text-tertiary)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%239ca3af' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}.textarea{resize:vertical;min-height:80px}.tabs-bar{display:flex;border-bottom:1px solid var(--border);margin-bottom:24px}.tab{padding:10px 16px;font-size:13.5px;font-weight:500;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .1s,border-color .1s;margin-bottom:-1px;font-family:inherit;white-space:nowrap}.tab:hover{color:var(--text)}.tab.active{color:var(--text);font-weight:600;border-bottom-color:var(--text)}.toggle-wrap{position:relative;width:36px;height:20px;flex-shrink:0}.toggle-wrap input{position:absolute;opacity:0;width:0;height:0}.toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-pill);background:var(--border-hover);cursor:pointer;transition:background .15s}.toggle-wrap input:checked+.toggle-track{background:var(--text)}.toggle-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .15s;pointer-events:none;box-shadow:0 1px 3px #0003}.toggle-wrap input:checked~.toggle-thumb{transform:translate(16px)}.comp-block{border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:8px;overflow:hidden}.comp-block.on{border-color:var(--text)}.comp-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--bg);cursor:pointer;-webkit-user-select:none;user-select:none}.comp-head-label{font-size:14px;font-weight:600;color:var(--text)}.comp-head-desc{font-size:12px;color:var(--text-tertiary);margin-top:1px}.comp-body{border-top:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:14px;background:var(--bg-muted)}.info-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px;margin-bottom:20px}.info-block{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px}.info-block-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:3px}.info-block-value{font-size:13px;color:var(--text);word-break:break-all}.mono{font-family:JetBrains Mono,Fira Mono,monospace;font-size:12px}.divider{height:1px;background:var(--border);margin:20px 0}.logo-mark{border-radius:var(--r-sm);background:#f5a623;display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-mark--sm{border-radius:4px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;flex-shrink:0}.spinner--sm{width:12px;height:12px}.dot--success{background:var(--success)}.dot--danger{background:var(--danger)}.dot--warning{background:var(--warning)}.dot--muted{background:var(--text-tertiary)}.pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:var(--r-pill);font-size:11.5px;font-weight:500;border:1px solid var(--border);background:var(--bg-muted);color:var(--text-secondary)}.pill--running{background:var(--success-bg);color:var(--success);border-color:transparent}.pill--starting{background:var(--warning-bg);color:var(--warning);border-color:transparent}.pill--stopped{background:var(--bg-muted);color:var(--text-secondary);border-color:transparent}.pill--exited{background:var(--danger-bg);color:var(--danger);border-color:transparent}.pill--restarting{background:var(--warning-bg);color:var(--warning);border-color:transparent}.copy-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;font-size:12px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;color:var(--text-secondary);transition:color .1s,background .1s;font-family:inherit;white-space:nowrap}.copy-btn:hover{background:var(--border-hover);color:var(--text)}.popover{position:absolute;z-index:500;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);min-width:160px;overflow:hidden}.toasts{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}@keyframes slide-in-up{0%{transform:translateY(10px);opacity:0}to{transform:none;opacity:1}}.toast{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--r-md);font-size:13px;font-weight:500;box-shadow:var(--shadow-md);animation:slide-in-up .18s ease;pointer-events:all;white-space:nowrap}.toast--info{background:var(--text);color:#fff}.toast--success{background:var(--success);color:#fff}.toast--error{background:var(--danger);color:#fff}.particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}@keyframes particle-twinkle{0%,to{opacity:0}50%{opacity:.7}}.particle{position:absolute;width:4px;height:4px;border-radius:50%;background:#f5a623;animation:particle-twinkle ease-in-out infinite}.login{display:flex;height:100vh;overflow:hidden}.login__left{display:flex;flex-direction:column;justify-content:center;width:440px;min-width:360px;flex-shrink:0;padding:48px 56px;background:var(--bg);overflow-y:auto}.login__right{flex:1;position:relative;background:#0d1117;overflow:hidden}.login__brand{display:flex;align-items:center;gap:10px;margin-bottom:44px}.login__brand-name{font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.2px}.login__title{font-size:26px;font-weight:700;color:var(--text);letter-spacing:-.5px;line-height:1.2;margin-bottom:8px}.login__subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:32px}.login__field{margin-bottom:16px}.login__field label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}.login__input{width:100%;padding:10px 13px;font-size:14px;font-family:inherit;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-input);color:var(--text);outline:none;transition:border-color .1s}.login__input:focus{border-color:var(--border-focus)}.login__footer{font-size:12px;color:var(--text-tertiary);margin-top:32px}.login__overlay{position:absolute;bottom:24px;left:24px;color:#ffffff73;font-size:11.5px;line-height:1.7}.login__viz{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:.85}.btn--primary{background:var(--text);color:#fff;font-weight:600}.btn--primary:not(:disabled):hover{background:#1f2937}.btn--lg{padding:11px 20px;font-size:14px}.btn--block{width:100%;justify-content:center}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:3px}.tab-btn{padding:6px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;cursor:pointer;border-radius:6px;transition:background .15s,color .15s}.tab-btn:hover{background:var(--bg-hover);color:var(--text)}.tab-btn-active{background:var(--bg-hover)!important;color:var(--accent)!important;font-weight:600}.region-select{background:var(--bg-muted);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:.8rem;cursor:pointer}.page-title{font-size:1.5rem;font-weight:600;margin:0}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.card-clickable{cursor:pointer;transition:border-color .15s}.card-clickable:hover{border-color:var(--accent)!important}.card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.card-title{font-weight:600;font-size:1rem}.card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:.8rem;opacity:.7}.card-url{font-size:.75rem;font-family:monospace;opacity:.8;margin-top:4px;word-break:break-all}.card-actions{margin-top:8px;display:flex;gap:8px}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100;display:flex;justify-content:flex-end}.detail-panel{width:min(640px,100vw);height:100%;background:var(--bg-elevated);display:flex;flex-direction:column}.detail-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.detail-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.detail-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0;background:var(--bg-muted)}.detail-title{font-size:1.1rem;font-weight:700;margin-right:8px}.detail-info-row{display:flex;flex-wrap:wrap;gap:16px}.detail-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-full{width:100%}.btn-sm{padding:4px 10px;font-size:.75rem}.form-section{margin-bottom:20px}.section-label{font-weight:600;font-size:.875rem;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em;opacity:.6}.sub-section-label{font-size:.8rem;font-weight:500;margin:10px 0 6px;opacity:.7}.input-sm{padding:6px 8px;font-size:.8rem}.hint-text{font-size:.75rem;opacity:.6;margin-top:2px}.env-row,.port-row{display:flex;gap:6px;margin-bottom:6px;align-items:center}.power-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin-bottom:16px}.power-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:16px 12px;border:1.5px solid var(--border);border-radius:var(--r-md);background:var(--bg);cursor:pointer;transition:border-color .15s,background .15s;text-align:center;min-width:0}.power-card:hover{border-color:var(--border-hover);background:var(--bg-hover)}.power-card-active{border-color:var(--accent);background:var(--accent-light, #eff6ff)}.power-icon{font-size:2rem;line-height:1;margin-bottom:4px}.power-size{font-size:13px;font-weight:700;color:var(--text)}.power-name{font-size:11px;color:var(--text-secondary)}.power-specs{font-size:11px;color:var(--text-tertiary)}.power-price{font-size:12px;font-weight:600;color:var(--text);margin-top:2px}.radio-row{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--border);border-radius:6px;margin-bottom:6px;cursor:pointer}.radio-row-active{border-color:var(--accent);background:var(--accent-light)}.price-tag{margin-left:auto;font-size:.8rem;color:var(--accent);font-weight:500}.summary-section{background:var(--bg-muted);border:1px solid var(--border);border-radius:8px;padding:12px;font-size:.875rem}.log-box{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:12px;font-family:monospace;font-size:.8rem;max-height:320px;overflow-y:auto}.log-line{display:flex;gap:8px;margin-bottom:2px}.log-ts{opacity:.4;white-space:nowrap}.containers-list,.history-list{display:flex;flex-direction:column;gap:8px}.container-item{background:var(--bg-muted);border:1px solid var(--border);border-radius:8px;padding:12px}.container-item-name{font-weight:600}.container-item-image{font-family:monospace;font-size:.8rem;opacity:.8}.history-item{background:var(--bg-muted);border:1px solid var(--border);border-radius:8px;padding:10px}.history-item-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.tab-bar{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:8px}.container-entry{background:var(--bg-muted);border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:12px}.container-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:500}.link{color:var(--accent);text-decoration:none}.link:hover{text-decoration:underline}
