@import "https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Noto+Sans+JP:wght@400;500;600;700;900&family=Inter:wght@400;500;600;700&display=swap";
:root{--bg-base:#0a0d14;--bg-surface:#111827;--bg-card:#1a2232;--bg-elevated:#212d40;--bg-input:#0f1623;--accent-primary:#4f8ef7;--accent-secondary:#7c3aed;--accent-cyan:#22d3ee;--accent-green:#10b981;--accent-red:#ef4444;--accent-amber:#f59e0b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--text-link:#60a5fa;--border-subtle:#ffffff0f;--border-default:#ffffff1f;--border-accent:#4f8ef766;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow:0 0 20px #4f8ef733;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--score-font:"Bebas Neue", sans-serif;--ui-font:"Noto Sans JP", "Inter", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--ui-font);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.5}button{font-family:var(--ui-font);cursor:pointer;transition:var(--transition-fast);border:none;outline:none}input,textarea,select{font-family:var(--ui-font);background:var(--bg-input);border:1px solid var(--border-default);color:var(--text-primary);transition:border-color var(--transition-fast);border-radius:6px;outline:none;width:100%;padding:8px 12px}input:focus,textarea:focus,select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px #4f8ef726}.admin-root{flex-direction:column;height:100vh;display:flex;overflow:hidden}.admin-header{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 20px;display:flex}.admin-header-logo{font-family:var(--score-font);letter-spacing:2px;color:var(--accent-primary);font-size:22px}.admin-header-room{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.admin-header-room strong{color:var(--text-primary);font-weight:600}.admin-body{flex-direction:column;flex:1;display:flex;overflow:hidden}.preview-panel{border-bottom:2px solid var(--border-default);background:#000;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.preview-panel-label{color:var(--text-secondary);z-index:5;background:#000000b3;border-radius:4px;align-items:center;gap:6px;padding:3px 8px;font-size:11px;display:flex;position:absolute;top:8px;left:12px}.preview-panel-label .live-dot{background:var(--accent-red);border-radius:50%;width:8px;height:8px;animation:1.5s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.preview-iframe-wrapper{aspect-ratio:16/9;width:100%;position:relative}.preview-iframe-wrapper iframe{border:none;width:100%;height:100%;display:block}.controller-panel{background:var(--bg-base);flex-direction:column;flex:1;display:flex;overflow:hidden}.tabs-bar{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);scrollbar-width:none;flex-shrink:0;display:flex;overflow-x:auto}.tabs-bar::-webkit-scrollbar{display:none}.tab-btn{color:var(--text-secondary);white-space:nowrap;transition:var(--transition-fast);background:0 0;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:10px 18px;font-size:13px;font-weight:500;display:flex}.tab-btn:hover{color:var(--text-primary);background:#ffffff08}.tab-btn.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.tab-content{scrollbar-width:thin;scrollbar-color:var(--border-default) transparent;flex:1;padding:16px 20px;overflow-y:auto}.btn{transition:var(--transition-fast);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #6366f1);color:#fff}.btn-primary:hover{opacity:.85;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default)}.btn-secondary:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.btn-danger{color:var(--accent-red);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover{background:var(--accent-red);color:#fff}.btn-success{color:var(--accent-green);background:#10b98126;border:1px solid #10b9814d}.btn-success:hover{background:var(--accent-green);color:#fff}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:12px 24px;font-size:15px}.btn-full{width:100%}.score-btn{min-width:64px;font-size:16px;font-weight:700;font-family:var(--score-font);letter-spacing:1px;transition:var(--transition-fast);cursor:pointer;border:none;border-radius:10px;padding:10px 14px}.score-btn.plus{color:#fff;background:linear-gradient(135deg,#10b981,#059669)}.score-btn.plus:hover{transform:scale(1.05);box-shadow:0 0 16px #10b98166}.score-btn.minus{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626)}.score-btn.minus:hover{transform:scale(1.05);box-shadow:0 0 16px #ef444466}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:16px}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;align-items:center;gap:8px;margin-bottom:12px;font-size:13px;font-weight:600;display:flex}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section-title{color:var(--text-primary);font-size:14px;font-weight:700}.team-swatch{border-radius:3px;flex-shrink:0;width:12px;height:12px;display:inline-block}.grid-2{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.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}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mt-3{margin-top:12px}.text-sm{font-size:12px}.text-muted{color:var(--text-secondary)}.text-accent{color:var(--accent-primary)}.badge{border-radius:99px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-blue{color:var(--accent-primary);background:#4f8ef726}.badge-green{color:var(--accent-green);background:#10b98126}.badge-amber{color:var(--accent-amber);background:#f59e0b26}.badge-red{color:var(--accent-red);background:#ef444426}.room-select-page{background:radial-gradient(ellipse at top, #4f8ef714 0%, var(--bg-base) 60%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.room-select-logo{font-family:var(--score-font);letter-spacing:6px;color:var(--accent-primary);margin-bottom:8px;font-size:48px}.room-select-subtitle{color:var(--text-secondary);margin-bottom:48px;font-size:13px}.room-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;width:100%;max-width:900px;display:grid}.room-card{background:var(--bg-card);border:1px solid var(--border-subtle);cursor:pointer;transition:var(--transition-base);border-radius:16px;flex-direction:column;gap:8px;padding:20px;display:flex}.room-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.room-card-name{font-size:18px;font-weight:700}.room-card-meta{color:var(--text-secondary);gap:12px;font-size:12px;display:flex}.room-new-btn{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;transition:var(--transition-base);font-size:16px;font-weight:700;font-family:var(--ui-font);border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;padding:20px;display:flex}.room-new-btn:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.score-control-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.team-score-card{background:var(--bg-card);border:2px solid var(--border-subtle);transition:var(--transition-base);border-radius:16px;padding:20px}.team-score-card.active-team{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.team-score-card-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.team-score-card-name{font-size:15px;font-weight:700}.team-score-display{font-family:var(--score-font);text-align:center;color:var(--text-primary);margin:8px 0 16px;font-size:64px;line-height:1}.score-rule-buttons{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.score-rule-btn{cursor:pointer;transition:var(--transition-fast);font-size:14px;font-weight:700;font-family:var(--score-font);letter-spacing:1px;border:none;border-radius:8px;padding:8px 14px}.score-rule-btn.positive{color:#10b981;background:#10b98133;border:1px solid #10b9814d}.score-rule-btn.positive:hover{color:#fff;background:#10b981}.score-rule-btn.negative{color:#ef4444;background:#ef444433;border:1px solid #ef44444d}.score-rule-btn.negative:hover{color:#fff;background:#ef4444}.taisho-grid{flex-direction:column;gap:8px;display:flex}.taisho-match-row{background:var(--bg-card);border:1px solid var(--border-subtle);transition:var(--transition-base);border-radius:10px;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:12px 16px;display:grid}.taisho-match-row.current{border-color:var(--accent-amber);background:#f59e0b0d;box-shadow:0 0 12px #f59e0b1a}.taisho-match-row.a-win .taisho-member-a,.taisho-match-row.b-win .taisho-member-b{color:var(--accent-green);font-weight:700}.taisho-position{text-align:center;color:var(--text-secondary);font-size:12px}.taisho-position strong{color:var(--text-primary);font-size:16px;font-weight:700;display:block}.taisho-member-a,.taisho-member-b{align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.taisho-member-a{justify-content:flex-end}.taisho-member-b{justify-content:flex-start}.taisho-result-badge{border-radius:4px;padding:2px 6px;font-size:11px;font-weight:700}.timer-display{font-family:var(--score-font);text-align:center;letter-spacing:4px;color:var(--text-primary);font-size:80px;line-height:1}.timer-controls{justify-content:center;gap:12px;margin-top:16px;display:flex}.display-mode-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;display:grid}.display-mode-btn{background:var(--bg-card);border:2px solid var(--border-subtle);cursor:pointer;transition:var(--transition-base);text-align:center;color:var(--text-secondary);font-size:12px;font-weight:600;font-family:var(--ui-font);border-radius:12px;padding:14px 10px}.display-mode-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.display-mode-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#4f8ef71a}.display-mode-icon{margin-bottom:6px;font-size:22px;display:block}.obs-root{width:1920px;height:1080px;font-family:var(--ui-font);position:relative;overflow:hidden}.obs-score-only{justify-content:center;align-items:center;gap:0;width:100%;height:100%;display:flex}.obs-team-block{flex-direction:column;flex:1;justify-content:center;align-items:center;height:100%;display:flex;position:relative;overflow:hidden}.obs-team-name{letter-spacing:2px;text-shadow:0 2px 20px #0009;text-align:center;padding:0 24px;font-size:64px;font-weight:900}.obs-team-score{font-family:var(--score-font);text-shadow:0 4px 40px #0009;font-size:280px;line-height:.9;transition:all .3s}.obs-divider{background:#ffffff26;flex-shrink:0;width:4px;height:70%}.obs-mini-score{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;border:1px solid #ffffff26;border-radius:12px;align-items:center;gap:16px;padding:12px 20px;display:flex;position:absolute}.obs-mini-score.top-left{top:24px;left:24px}.obs-mini-score.top-right{top:24px;right:24px}.obs-mini-score.bottom-left{bottom:24px;left:24px}.obs-mini-score.bottom-right{bottom:24px;right:24px}.obs-mini-team{align-items:center;gap:8px;display:flex}.obs-mini-abbr{font-size:16px;font-weight:700}.obs-mini-pts{font-family:var(--score-font);font-size:36px;line-height:1}.obs-mini-separator{font-family:var(--score-font);color:#fff6;font-size:28px}.obs-team-detail{grid-template-rows:auto 1fr;width:100%;height:100%;display:grid}.obs-team-detail-header{justify-content:center;align-items:center;gap:80px;padding:40px;display:flex}.obs-team-detail-name{font-size:72px;font-weight:900}.obs-team-detail-score{font-family:var(--score-font);font-size:120px;line-height:1}.obs-team-detail-members{justify-content:space-around;gap:60px;padding:20px 60px;display:flex}.obs-team-detail-roster{flex:1}.obs-roster-title{color:#ffffff80;text-transform:uppercase;letter-spacing:3px;margin-bottom:20px;font-size:20px;font-weight:700}.obs-roster-member{border-bottom:1px solid #ffffff14;align-items:center;gap:20px;padding:14px 0;display:flex}.obs-roster-number{font-family:var(--score-font);color:#ffffff4d;text-align:right;width:60px;font-size:40px}.obs-roster-name{font-size:36px;font-weight:700}.obs-roster-pos{color:#fff6;margin-left:auto;font-size:18px}.obs-game-scores{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:60px;display:flex}.obs-game-table{border-collapse:collapse;width:100%}.obs-game-table th{color:#ffffff80;border-bottom:2px solid #ffffff1a;padding:16px 24px;font-size:28px;font-weight:700}.obs-game-table td{font-family:var(--score-font);text-align:center;border-bottom:1px solid #ffffff0d;padding:20px 24px;font-size:48px}.obs-game-table td.game-name{font-family:var(--ui-font);text-align:left;color:#ffffffb3;font-size:28px;font-weight:700}.obs-game-table tr.is-active td{background:#4f8ef714}.obs-fighting{justify-content:space-between;align-items:center;gap:40px;width:100%;height:100%;padding:80px;display:flex}.obs-fighter-block{flex-direction:column;flex:1;align-items:center;gap:20px;display:flex}.obs-fighter-name{text-align:center;text-shadow:0 4px 20px #00000080;font-size:80px;font-weight:900}.obs-fighter-stars{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.obs-star{filter:drop-shadow(0 2px 8px #0006);font-size:48px}.obs-vs-block{flex-direction:column;align-items:center;gap:8px;display:flex}.obs-vs-text{font-family:var(--score-font);color:#ffffff4d;font-size:100px}.obs-game-count{color:#ffffff80;font-size:24px}.obs-taisho{flex-direction:column;gap:24px;width:100%;height:100%;padding:60px;display:flex}.obs-taisho-header{justify-content:space-between;align-items:center;display:flex}.obs-taisho-team-name{font-size:52px;font-weight:900}.obs-taisho-score-sum{font-family:var(--score-font);font-size:80px;line-height:1}.obs-taisho-matches{flex-direction:column;flex:1;justify-content:center;gap:12px;display:flex}.obs-taisho-match-row{background:#ffffff0a;border-radius:12px;grid-template-columns:1fr 200px 1fr;align-items:center;gap:20px;padding:16px 24px;transition:all .3s;display:grid}.obs-taisho-match-row.obs-current{background:#f59e0b1a;border:1px solid #f59e0b66}.obs-taisho-fighter-a{text-align:right;font-size:36px;font-weight:700}.obs-taisho-fighter-b{text-align:left;font-size:36px;font-weight:700}.obs-taisho-pos-center{text-align:center}.obs-taisho-pos-label{color:#fff6;font-size:20px}.obs-taisho-result{font-family:var(--score-font);font-size:40px}.obs-timer{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.obs-timer-display{font-family:var(--score-font);letter-spacing:8px;font-size:300px;line-height:1}.obs-member-call{flex-direction:column;justify-content:center;align-items:center;gap:32px;width:100%;height:100%;padding:80px;display:flex}.obs-member-call-team{color:#fff9;text-transform:uppercase;letter-spacing:4px;font-size:32px;font-weight:700}.obs-member-call-members{flex-wrap:wrap;justify-content:center;gap:60px;display:flex}.obs-member-call-item{text-align:center}.obs-member-call-number{font-family:var(--score-font);color:#ffffff4d;font-size:60px}.obs-member-call-name{font-size:56px;font-weight:900}.obs-member-call-pos{color:#fff6;margin-top:4px;font-size:24px}@keyframes scoreFlash{0%{opacity:1;transform:scale(1)}20%{opacity:1;color:#fff;filter:brightness(1.5);transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.score-flash{animation:.6s ease-out scoreFlash}@media (max-width:1200px){.preview-panel{max-height:35vh}}@media (max-width:768px){.grid-2{grid-template-columns:1fr}.grid-4{grid-template-columns:repeat(2,1fr)}.preview-panel{max-height:28vh}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:var(--bg-surface);border:1px solid var(--border-default);width:90%;max-width:480px;box-shadow:var(--shadow-lg);border-radius:16px;padding:28px}.modal-title{margin-bottom:20px;font-size:18px;font-weight:700}.form-group{margin-bottom:14px}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.toggle{flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-slider{background:var(--bg-elevated);cursor:pointer;transition:var(--transition-base);border:1px solid var(--border-default);border-radius:24px;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-secondary);width:18px;height:18px;transition:var(--transition-base);border-radius:50%;position:absolute;top:2px;left:3px}.toggle input:checked+.toggle-slider{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle input:checked+.toggle-slider:before{background:#fff;transform:translate(20px)}
