:root{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-card:#1e293b;--bg-input:#334155;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border:#334155;--accent:#3b82f6;--accent-hover:#2563eb;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#3b82f6;--radius:12px;--radius-sm:8px;--shadow:0 4px 6px -1px #0000004d}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Noto Sans JP,sans-serif;line-height:1.6}#root{flex-direction:column;min-height:100dvh;display:flex}.app-container{width:100%;max-width:480px;margin:0 auto;padding:0 16px 80px}@media (width>=768px){.app-container{max-width:900px;padding:0 24px 80px}}.header{border-bottom:1px solid var(--border);background:var(--bg-primary);z-index:100;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 0;display:flex;position:sticky;top:0}.header h1{align-items:center;gap:8px;font-size:1.25rem;font-weight:700;display:flex}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:16px;padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:500}.hero-number{letter-spacing:-.02em;font-size:2rem;font-weight:800;line-height:1.2}.hero-number.success{color:var(--success)}.hero-number.warning{color:var(--warning)}.hero-number.danger{color:var(--danger)}.hero-sub{color:var(--text-secondary);margin-top:4px;font-size:.9rem}.badge{border-radius:9999px;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge.success{color:var(--success);background:#10b98126}.badge.warning{color:var(--warning);background:#f59e0b26}.badge.danger{color:var(--danger);background:#ef444426}.badge.info{color:var(--info);background:#3b82f626}.stat-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.stat-item{text-align:center;background:var(--bg-primary);border-radius:var(--radius-sm);padding:12px 8px}.stat-value{font-size:1.15rem;font-weight:700}.stat-label{color:var(--text-muted);margin-top:2px;font-size:.7rem}.alert-banner{border-radius:var(--radius-sm);align-items:flex-start;gap:12px;margin-bottom:12px;padding:14px 16px;font-size:.85rem;line-height:1.5;display:flex}.alert-banner.critical{border-left:3px solid var(--danger);color:#fca5a5;background:#ef44441f}.alert-banner.warning{border-left:3px solid var(--warning);color:#fcd34d;background:#f59e0b1f}.alert-banner.info{border-left:3px solid var(--info);color:#93c5fd;background:#3b82f61f}.bottom-nav{background:var(--bg-secondary);border-top:1px solid var(--border);padding:8px 0;padding-bottom:max(8px, env(safe-area-inset-bottom));z-index:200;justify-content:space-around;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:4px 12px;font-size:.65rem;text-decoration:none;transition:color .2s;display:flex}.nav-item.active,.nav-item:hover{color:var(--accent)}.nav-item svg{width:22px;height:22px}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:500;display:block}.form-input,.form-select{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:10px 14px;font-size:1rem;transition:border-color .2s}.form-input:focus,.form-select:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-danger{color:var(--danger);background:#ef444426}.btn-danger:hover{background:#ef444440}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-input)}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-full{width:100%}.modal-overlay{z-index:300;background:#0009;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;max-height:85dvh;padding:24px 20px;animation:.3s slideUp;overflow-y:auto}@media (width>=768px){.modal-overlay{align-items:center}.modal-content{border-radius:var(--radius);max-width:560px}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:1.1rem;font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px}.empty-state-icon{margin-bottom:12px;font-size:2.5rem}.pipeline-bar{border-radius:6px;height:12px;margin:12px 0;display:flex;overflow:hidden}.pipeline-segment{transition:width .3s}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.85rem}.table th{text-align:left;color:var(--text-muted);text-transform:uppercase;border-bottom:1px solid var(--border);padding:10px 12px;font-size:.75rem;font-weight:500}.table td{border-bottom:1px solid #33415580;padding:10px 12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.text-right{text-align:right}.text-sm{font-size:.85rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.font-bold{font-weight:700}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}
