:root{--primary:#1a365d;--primary-light:#2b4c7e;--success:#16a34a;--success-bg:#dcfce7;--error:#dc2626;--error-bg:#fee2e2;--warning:#d97706;--warning-bg:#fef3c7;--bg:#f3f4f6;--surface:#fff;--text:#1f2937;--text-secondary:#6b7280;--border:#d1d5db;--radius:8px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.nav{background:var(--primary);color:#fff;z-index:50;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex;position:sticky;top:0}.nav h1{font-size:1.1rem;font-weight:700}.nav-links{align-items:center;gap:.5rem;display:flex}.nav-links a,.nav-links button{color:#fff;border-radius:var(--radius);cursor:pointer;background:0 0;border:none;padding:.4rem .75rem;font-size:.85rem;text-decoration:none}.nav-links a:hover,.nav-links button:hover{background:var(--primary-light)}.page{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1rem}.page h2{color:var(--primary);margin-bottom:1rem;font-size:1.4rem}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:.75rem;padding:1rem}.card h3{margin-bottom:.5rem;font-size:1rem}.card-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:.75rem;display:grid}.form-group{margin-bottom:.75rem}.form-group label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.85rem;font-weight:600;display:block}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;padding:.6rem;font-size:.95rem}input:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #1a365d26}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.4rem;padding:.6rem 1.2rem;font-size:.9rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-light)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--error);color:#fff}.btn-outline{border:2px solid var(--border);color:var(--text);background:0 0}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-lg{padding:.8rem 1.5rem;font-size:1.1rem}.btn-block{justify-content:center;width:100%}.btn-hit{background:var(--success);color:#fff;cursor:pointer;touch-action:manipulation;border:none;border-radius:12px;min-width:80px;min-height:60px;font-size:1.3rem;font-weight:700}.btn-miss{background:var(--error);color:#fff;cursor:pointer;touch-action:manipulation;border:none;border-radius:12px;min-width:80px;min-height:60px;font-size:1.3rem;font-weight:700}.btn-hit.selected{transform:scale(1.05);box-shadow:0 0 0 4px #16a34a66}.btn-miss.selected{transform:scale(1.05);box-shadow:0 0 0 4px #dc262666}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.5rem .75rem}th{text-transform:uppercase;color:var(--text-secondary);background:var(--bg);font-size:.8rem;font-weight:600}.status{border-radius:99px;padding:.15rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.status-draft{color:#374151;background:#e5e7eb}.status-active{color:#1d4ed8;background:#dbeafe}.status-verify{background:var(--warning-bg);color:var(--warning)}.status-published{background:var(--success-bg);color:var(--success)}.alert{border-radius:var(--radius);margin-bottom:.75rem;padding:.75rem 1rem;font-size:.9rem}.alert-error{background:var(--error-bg);color:var(--error);border:1px solid #fca5a5}.alert-success{background:var(--success-bg);color:var(--success);border:1px solid #86efac}.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #fcd34d}.flex{display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.text-sm{font-size:.85rem}.text-secondary{color:var(--text-secondary)}.text-center{text-align:center}.font-bold{font-weight:700}.font-mono{font-family:SF Mono,Menlo,monospace}.shot-dot{text-align:center;color:#fff;border-radius:50%;width:20px;height:20px;margin:0 2px;font-size:.7rem;font-weight:700;line-height:20px;display:inline-block}.shot-hit{background:var(--success)}.shot-miss{background:var(--error)}.offline-bar{background:var(--warning);color:#fff;text-align:center;padding:.3rem;font-size:.8rem;font-weight:600}.online-bar{background:var(--success);color:#fff;text-align:center;padding:.3rem;font-size:.8rem;font-weight:600}.tabs{border-bottom:2px solid var(--border);scrollbar-width:none;-ms-overflow-style:none;gap:0;margin-bottom:1rem;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{cursor:pointer;color:var(--text-secondary);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.5rem 1rem;font-size:.9rem;font-weight:600}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.login-container{max-width:400px;margin:3rem auto;padding:0 1rem}.login-container .card{padding:2rem}.login-container h1{text-align:center;color:var(--primary);margin-bottom:.5rem;font-size:1.8rem}.login-container .subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem}.fullscreen{z-index:100;background:var(--bg);padding:1rem;position:fixed;inset:0;overflow:auto}.fullscreen table{font-size:1.1rem}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=640px){.page{padding:.5rem}.card-grid{grid-template-columns:1fr}.hide-mobile{display:none}th,td{padding:.35rem .5rem;font-size:.85rem}}
