*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f0f2f5;color:#333;min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased}
.login-container{display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:16px}
.login-box{background:#fff;padding:40px 28px;border-radius:20px;width:100%;max-width:340px;box-shadow:0 20px 60px rgba(0,0,0,0.3);text-align:center}
.login-icon{font-size:64px;margin-bottom:8px}
.login-box h1{font-size:22px;margin-bottom:20px;color:#1a1a2e}
.login-error{color:#F44336;margin-top:12px;font-size:13px}
.topbar{display:flex;align-items:center;justify-content:space-between;background:#1a1a2e;color:#fff;padding:0 16px;height:48px;position:sticky;top:0;z-index:100}
.brand{font-size:16px;font-weight:700}
.logout-btn{color:rgba(255,255,255,0.7);font-size:13px;padding:4px 10px;border-radius:6px;cursor:pointer}
.logout-btn:hover{color:#fff}
.tabbar{display:flex;background:#fff;position:sticky;top:48px;z-index:99;border-bottom:1px solid #eee;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tabbar .tb{flex:1 0 auto;padding:10px 6px;border:none;background:none;font-size:12px;color:#888;cursor:pointer;border-bottom:2px solid transparent;transition:.2s;white-space:nowrap}
.tabbar .tb.active{color:#1a1a2e;border-bottom-color:#1a1a2e;font-weight:600}
.main-content{padding:12px 12px 24px}
.tab-content{display:none}
.tab-content.active{display:block}
.card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,0.05);margin-bottom:0}
.card-title{font-size:15px;font-weight:600;margin-bottom:8px;color:#1a1a2e}
.card-sub{font-size:12px;color:#999;margin-bottom:8px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.status-text{font-size:14px;padding:4px 0}
.btn{display:inline-block;padding:10px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:.2s}
.btn-block{display:block;width:100%}
.btn-green{background:#4CAF50;color:#fff}
.btn-green:active{background:#43A047}
.btn-red{background:#F44336;color:#fff}
.btn-red:active{background:#E53935}
.btn-sm{padding:4px 10px;font-size:11px;border-radius:6px}
.input{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:10px;font-size:14px;outline:0;transition:.2s;-webkit-appearance:none}
.input:focus{border-color:#1a1a2e;box-shadow:0 0 0 3px rgba(26,26,46,0.08)}
.log-area{background:#1e1e1e;color:#c0c0c0;font-family:'SF Mono',Monaco,monospace;font-size:11px;padding:12px;border-radius:8px;white-space:pre-wrap;overflow-x:auto;line-height:1.5;-webkit-overflow-scrolling:touch}
.file-list{list-style:none}
.file-item{padding:10px 12px;cursor:pointer;border-radius:8px;font-size:13px;display:flex;justify-content:space-between;border-bottom:1px solid #f5f5f5}
.file-item:active{background:#f0f2f5}
.file-item:last-child{border-bottom:none}
.history-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #f5f5f5;font-size:13px;flex-wrap:wrap}
.history-row:last-child{border-bottom:none}
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;color:#fff}
.badge-pre{background:#2196F3}
.badge-prod{background:#F44336}
.badge-success{border:1px solid #4CAF50;color:#4CAF50;background:transparent}
.badge-failed{border:1px solid #F44336;color:#F44336;background:transparent}
.badge-running{background:#FF9800}
.badge-queued{background:#9E9E9E}

@media(max-width:480px){
  .grid-2{grid-template-columns:1fr}
  .card{padding:14px}
  .tabbar .tb{font-size:11px;padding:8px 4px}
}
