*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg1: #0f1117;--bg2: #1a1d27;--bg3: #232736;--bg4: #2d3145;--border: #2e3347;--text1: #e8eaf0;--text2: #8b90a7;--text3: #555a70;--accent: #4f8ef7;--accent2: #3a7ae8;--green: #2ecc71;--red: #e74c3c;--yellow: #f39c12;--gray: #636878;--purple: #9b59b6;--font: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", sans-serif;--mono: "SF Mono", "Fira Code", "Consolas", monospace;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--sidebar-w: 220px;--topbar-h: 56px;--bottomnav-h: 60px}html{font-size:16px}body{font-family:var(--font);background:var(--bg1);color:var(--text1);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}#root{display:flex;flex-direction:column;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}h1{font-size:1.5rem;font-weight:700}h2{font-size:1.25rem;font-weight:600}h3{font-size:1rem;font-weight:600}p{color:var(--text2)}a{color:var(--accent);text-decoration:none}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-md);font-size:14px;font-weight:500;font-family:var(--font);border:none;cursor:pointer;transition:all .15s ease;white-space:nowrap;min-height:36px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent2)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-success{background:var(--green);color:#fff}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg3);color:var(--text1)}.btn-sm{padding:5px 10px;font-size:12px;min-height:28px}.btn-icon{padding:6px;min-height:32px;width:32px;justify-content:center}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text2)}input,select,textarea{background:var(--bg3);border:1px solid var(--border);color:var(--text1);border-radius:var(--r-md);padding:9px 12px;font-size:16px;font-family:var(--font);width:100%;transition:border-color .15s ease;-webkit-appearance:none}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}input::placeholder,textarea::placeholder{color:var(--text3)}select option{background:var(--bg3)}textarea{resize:vertical;min-height:80px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-active{background:#2ecc7126;color:var(--green)}.badge-blocked{background:#e74c3c26;color:var(--red)}.badge-expired{background:#63687826;color:var(--gray)}.badge-paid{background:#2ecc7126;color:var(--green)}.badge-unpaid{background:#e74c3c26;color:var(--red)}.badge-pending{background:#f39c1226;color:var(--yellow)}.progress{background:var(--bg4);border-radius:4px;height:6px;overflow:hidden}.progress-bar{height:100%;border-radius:4px;transition:width .3s ease}.progress-bar.ok{background:var(--green)}.progress-bar.warning{background:var(--yellow)}.progress-bar.danger{background:var(--red)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}th{text-align:left;padding:10px 12px;color:var(--text2);font-weight:500;font-size:12px;text-transform:uppercase;border-bottom:1px solid var(--border)}td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .15s ease}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUp .15s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:14px}.modal-footer{padding:0 24px 20px;display:flex;gap:8px;justify-content:flex-end}.toast-container{position:fixed;bottom:80px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}@media (min-width: 768px){.toast-container{bottom:24px}}.toast{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 16px;font-size:14px;min-width:240px;max-width:360px;display:flex;align-items:center;gap:10px;animation:slideUp .2s ease;pointer-events:all}.toast.success{border-color:var(--green)}.toast.error{border-color:var(--red)}.toast.warning{border-color:var(--yellow)}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-logo{padding:20px 16px;border-bottom:1px solid var(--border);font-size:16px;font-weight:700;color:var(--text1);display:flex;align-items:center;gap:10px}.sidebar-logo span{color:var(--accent)}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.sidebar-nav a,.nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r-md);font-size:14px;font-weight:500;color:var(--text2);cursor:pointer;transition:all .15s ease;text-decoration:none;border:none;background:transparent;width:100%;text-align:left}.sidebar-nav a:hover,.nav-link:hover{background:var(--bg3);color:var(--text1)}.sidebar-nav a.active,.nav-link.active{background:#4f8ef71f;color:var(--accent)}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border)}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column}.topbar{height:var(--topbar-h);background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50}.topbar-title{font-size:16px;font-weight:600}.topbar-actions{display:flex;align-items:center;gap:8px}.page{padding:20px;flex:1}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottomnav-h);background:var(--bg2);border-top:1px solid var(--border);z-index:100;display:none;align-items:center;justify-content:space-around}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;padding:8px 4px;font-size:10px;font-weight:500;color:var(--text2);cursor:pointer;border:none;background:none;text-decoration:none;transition:color .15s}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item svg{width:22px;height:22px}@media (max-width: 767px){.sidebar{display:none}.main-content{margin-left:0;padding-bottom:var(--bottomnav-h)}.bottom-nav{display:flex}.topbar{padding:0 14px}.page{padding:14px}.modal{max-width:100%;margin:0;border-radius:var(--r-lg) var(--r-lg) 0 0}.modal-overlay{align-items:flex-end;padding:0}table{display:none}.card-list{display:flex;flex-direction:column;gap:10px}}@media (min-width: 768px){.card-list-mobile{display:none}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}.stat-card-label{font-size:12px;color:var(--text2);text-transform:uppercase;font-weight:500;margin-bottom:6px}.stat-card-value{font-size:24px;font-weight:700}.stat-card-sub{font-size:12px;color:var(--text2);margin-top:4px}.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.service-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px}.service-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.service-card-name{font-weight:600;display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.status-dot.active{background:var(--green);box-shadow:0 0 6px var(--green)}.status-dot.inactive{background:var(--gray)}.status-dot.failed{background:var(--red);box-shadow:0 0 6px var(--red)}.service-card-actions{display:flex;gap:6px;flex-wrap:wrap}.filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:16px}.filters input,.filters select{width:auto;font-size:14px;padding:7px 10px}.filters input{min-width:180px}.log-box{background:var(--bg1);border:1px solid var(--border);border-radius:var(--r-md);padding:12px;font-family:var(--mono);font-size:12px;color:var(--text2);height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}.divider{height:1px;background:var(--border);margin:16px 0}.empty{text-align:center;padding:48px 16px;color:var(--text2)}.empty h3{color:var(--text1);margin-bottom:8px}@media (max-width: 480px){.logout-label{display:none}}
