:root{--ink-black: #000000;--ink-white: #FFFFFF;--ink-blue: #1E4E8C;--ink-green: #2E7D44;--ink-yellow: #E3A81C;--ink-red: #C23B2E;--bg: #FAFAFA;--surface: #FFFFFF;--border: #E0E0E0;--text: #1A1A1A;--text-muted: #666666}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--ink-blue);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:inherit}.app-layout{display:flex;height:100%}.sidebar{width:220px;background:var(--ink-black);color:var(--ink-white);display:flex;flex-direction:column;padding:0;flex-shrink:0}.sidebar-header{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h1{font-size:18px;font-weight:800;letter-spacing:-.02em}.sidebar-header span{font-size:11px;opacity:.5}.sidebar-nav{flex:1;padding:12px 0}.sidebar-nav a{display:flex;align-items:center;gap:10px;color:#ffffffb3;padding:10px 16px;font-size:14px;font-weight:500;transition:all .15s;text-decoration:none;border-left:3px solid transparent}.sidebar-nav a:hover{color:var(--ink-white);background:#ffffff0d;text-decoration:none}.sidebar-nav a.active{color:var(--ink-white);background:#ffffff1a;border-left-color:var(--ink-blue)}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;opacity:.5}.sidebar-footer button{background:none;border:none;color:#ffffff80;font-size:12px;padding:0}.sidebar-footer button:hover{color:var(--ink-white)}.main-content{flex:1;overflow-y:auto;padding:32px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h2{font-size:24px;font-weight:700;letter-spacing:-.02em}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:16px}.card-header{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px 20px}.stat-card .label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.stat-card .value{font-size:28px;font-weight:800;margin-top:4px}.stat-card .value.blue{color:var(--ink-blue)}.stat-card .value.green{color:var(--ink-green)}.stat-card .value.yellow{color:var(--ink-yellow)}.stat-card .value.red{color:var(--ink-red)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-weight:600;font-size:14px;border:none;transition:all .15s}.btn-primary{background:var(--ink-black);color:var(--ink-white)}.btn-primary:hover{background:#333}.btn-success{background:var(--ink-green);color:var(--ink-white)}.btn-success:hover{background:#236b34}.btn-danger{background:var(--ink-red);color:var(--ink-white)}.btn-danger:hover{background:#a02a22}.btn-outline{background:transparent;color:var(--ink-black);border:1px solid var(--border)}.btn-outline:hover{background:var(--bg)}.btn-sm{padding:4px 10px;font-size:12px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 12px;border-bottom:2px solid var(--border)}td{padding:10px 12px;border-bottom:1px solid var(--border)}tr:hover td{background:var(--bg)}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-active{background:#e8f5e9;color:var(--ink-green)}.badge-offline{background:#f5f5f5;color:var(--text-muted)}.badge-updating{background:#fff8e1;color:var(--ink-yellow)}.badge-error{background:#ffebee;color:var(--ink-red)}.badge-decommissioned{background:#eceff1;color:#90a4ae}.badge-pending{background:#e3f2fd;color:var(--ink-blue)}.badge-in-progress{background:#fff8e1;color:var(--ink-yellow)}.badge-completed{background:#e8f5e9;color:var(--ink-green)}.badge-failed{background:#ffebee;color:var(--ink-red)}.badge-cancelled{background:#f5f5f5;color:var(--text-muted)}.badge-rolled-back{background:#f3e5f5;color:#7b1fa2}.badge-draft{background:#f5f5f5;color:var(--text-muted)}.badge-ready{background:#e8f5e9;color:var(--ink-green)}.badge-deploying{background:#fff8e1;color:var(--ink-yellow)}.badge-archived{background:#eceff1;color:#90a4ae}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:14px;background:var(--surface)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--ink-blue);box-shadow:0 0 0 3px #1e4e8c1a}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:12px;padding:24px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto}.modal h3{font-size:18px;font-weight:700;margin-bottom:16px}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}.auth-page{min-height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;width:100%;max-width:400px}.auth-card h1{font-size:24px;font-weight:800;margin-bottom:8px}.auth-card p{color:var(--text-muted);margin-bottom:24px;font-size:14px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state h3{font-size:16px;color:var(--text);margin-bottom:8px}.empty-state p{margin-bottom:16px}.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-muted)}.alert{padding:12px 16px;border-radius:6px;margin-bottom:16px;font-size:14px}.alert-error{background:#ffebee;color:var(--ink-red);border:1px solid #FFCDD2}.alert-success{background:#e8f5e9;color:var(--ink-green);border:1px solid #C8E6C9}.alert-info{background:#e3f2fd;color:var(--ink-blue);border:1px solid #BBDEFB}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;z-index:200;animation:slideUp .3s ease}.toast-success{background:var(--ink-green);color:#fff}.toast-error{background:var(--ink-red);color:#fff}.toast-info{background:var(--ink-blue);color:#fff}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.sidebar{display:none}.app-layout{flex-direction:column}.main-content{padding:12px 12px 80px!important}.page-header{flex-direction:column;align-items:flex-start;gap:8px}.page-header h2{font-size:20px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:12px 14px}.stat-card .value{font-size:22px}table,thead,tbody,th,td,tr{display:block}thead tr{display:none}tr{margin-bottom:12px;border:1px solid var(--border);border-radius:8px;padding:12px;background:var(--surface)}td{padding:4px 0;border:none;font-size:14px}td:before{content:attr(data-label);font-weight:700;font-size:11px;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:2px}.card{padding:14px;margin-bottom:12px}.modal{max-width:95vw;padding:20px}.btn{padding:10px 16px;min-height:44px;font-size:14px}.btn-sm{padding:8px 14px;min-height:36px;font-size:13px}.auth-card{max-width:100%;padding:24px 20px}input,textarea,select{font-size:16px!important}}.mobile-nav{display:none}@media (max-width: 768px){.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--ink-black);color:var(--ink-white);justify-content:space-around;align-items:center;height:60px;padding:0 8px;box-shadow:0 -2px 12px #00000026}.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:#ffffff8c;text-decoration:none;font-size:10px;font-weight:500;padding:4px 8px;border-radius:8px;transition:all .15s}.mobile-nav a.active{color:#fff}.mobile-nav a svg{width:20px;height:20px}}.sticky-bar{display:none}@media (max-width: 768px){.sticky-bar{display:flex;position:fixed;bottom:60px;left:0;right:0;z-index:99;background:var(--surface);border-top:1px solid var(--border);padding:10px 12px;gap:10px;justify-content:center;box-shadow:0 -2px 8px #0000000f}.sticky-bar button{flex:1;min-height:48px;font-size:15px;font-weight:700}}.mobile-home-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 16px;cursor:pointer;text-decoration:none;color:inherit;transition:box-shadow .15s;min-height:44px}.mobile-home-card:hover{box-shadow:0 2px 12px #0000000f}.mobile-home-card .icon{font-size:28px;flex-shrink:0}.mobile-home-card .label{font-weight:700;font-size:16px}.mobile-home-card .sub{font-size:12px;color:var(--text-muted);margin-top:2px}.mobile-block{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px;cursor:pointer}.mobile-block .block-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.mobile-block .block-text{font-size:15px;line-height:1.5}.mobile-wizard-step{text-align:center;padding:20px 0}.mobile-wizard-step h3{font-size:20px;margin-bottom:8px}.mobile-wizard-step p{color:var(--text-muted);margin-bottom:20px;font-size:14px}@media (max-width: 768px){.desktop-only{display:none!important}}@media (min-width: 769px){.mobile-only{display:none!important}}
