*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body.no-scroll{overflow:hidden}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.touch-button{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.home-container{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;flex-direction:column;align-items:center;padding:40px 20px}.home-header{text-align:center;margin-bottom:48px}.home-title{font-size:48px;font-weight:700;color:#fff;margin-bottom:8px}.home-subtitle{font-size:18px;color:#9ca3af}.home-menu{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:600px;width:100%}.menu-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;border-radius:20px;text-decoration:none;transition:all .2s ease;min-height:180px}.menu-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.menu-card:active{transform:scale(.98)}.menu-card .menu-icon{font-size:48px;margin-bottom:12px}.menu-card h2{font-size:28px;font-weight:700;color:#fff;margin-bottom:4px}.menu-card p{font-size:14px;color:#ffffffb3}.menu-card.north{background:linear-gradient(135deg,#22c55e,#16a34a)}.menu-card.south{background:linear-gradient(135deg,#3b82f6,#2563eb)}.menu-card.kiosk{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.menu-card.setup{background:linear-gradient(135deg,#6b7280,#4b5563)}.home-footer{margin-top:auto;padding-top:48px;color:#6b7280;font-size:14px}.tablet-container{height:100vh;height:100dvh;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:12px;display:flex;flex-direction:column;overflow:hidden}.tablet-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;flex-shrink:0}.tablet-title{font-size:28px;font-weight:700;color:#fff}.tablet-title.north{color:#22c55e}.tablet-title.south{color:#3b82f6}.connection-status{display:flex;align-items:center;gap:8px;font-size:14px;color:#9ca3af}.status-dot{width:12px;height:12px;border-radius:50%}.status-dot.connected{background:#22c55e;box-shadow:0 0 8px #22c55e}.status-dot.disconnected{background:#ef4444;box-shadow:0 0 8px #ef4444}.club-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:12px;flex:1;width:100%;padding:8px;min-height:0}.club-button{padding:16px 12px;font-size:clamp(18px,3vw,32px);font-weight:700;border:4px solid transparent;border-radius:16px;background:#374151;color:#fff;cursor:pointer;transition:all .1s ease;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.1;min-height:0;height:100%;width:100%}.club-button:active{transform:scale(.95);opacity:.9}.club-button.selected-green{background:#22c55e;border-color:#16a34a;box-shadow:0 0 30px #22c55e99}.club-button.selected-blue{background:#3b82f6;border-color:#2563eb;box-shadow:0 0 30px #3b82f699}.club-button.selected-dim{background:#4a5568;border-color:#2d3748;box-shadow:none}.club-button:disabled{opacity:.5;cursor:not-allowed}@media (orientation: landscape) and (max-height: 600px){.tablet-header{padding:4px 12px}.tablet-title{font-size:20px}.club-grid{gap:8px;padding:4px}.club-button{border-radius:12px;border-width:3px}}@media (orientation: portrait){.club-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(6,1fr)}}.kiosk-container{min-height:100vh;display:flex;align-items:center;justify-content:center}.kiosk-display{text-align:center;transition:opacity .2s ease}.kiosk-display.hidden{opacity:0}.kiosk-waiting{color:#666;font-size:24px}.setup-container{min-height:100vh;background:#f3f4f6;padding:24px;overflow-y:auto}.setup-content{max-width:800px;margin:0 auto;padding-bottom:40px}.tab-nav{display:flex;gap:8px;margin-bottom:24px;background:#fff;padding:8px;border-radius:12px;box-shadow:0 1px 3px #0000001a}.tab-btn{flex:1;padding:12px 16px;border:none;border-radius:8px;background:transparent;color:#6b7280;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.tab-btn:hover{background:#f3f4f6}.tab-btn.active{background:#3b82f6;color:#fff}.section-header{display:flex;justify-content:space-between;align-items:center}.section-header.collapsible{cursor:pointer;padding:8px;margin:-8px -8px 8px;border-radius:8px;transition:background .2s}.section-header.collapsible:hover{background:#0000000d}.collapse-icon{color:#6b7280;font-size:12px}.password-form{max-width:400px}.password-form .form-group{margin-bottom:16px}.password-form .form-input{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px}.password-form .submit-button{margin-top:8px}.success-message{color:#22c55e;font-size:14px;margin-top:8px}.setup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.setup-title{font-size:28px;font-weight:700;color:#1f2937}.logout-button{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px}.logout-button:hover{background:#dc2626}.setup-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.section-title{font-size:20px;font-weight:600;color:#1f2937;margin-bottom:16px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e)}.login-box{background:#fff;padding:40px;border-radius:16px;width:100%;max-width:400px;box-shadow:0 4px 20px #0000004d}.login-title{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:24px;text-align:center}.form-group{margin-bottom:16px}.form-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .2s}.form-input:focus{outline:none;border-color:#3b82f6}.submit-button{width:100%;padding:14px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.submit-button:hover{background:#2563eb}.submit-button:disabled{background:#9ca3af;cursor:not-allowed}.error-message{color:#ef4444;font-size:14px;margin-top:8px;text-align:center}.club-list{display:flex;flex-direction:column;gap:8px}.club-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f9fafb;border-radius:8px}.club-name{font-size:16px;font-weight:500;color:#1f2937}.delete-button{padding:6px 12px;background:#fee2e2;color:#ef4444;border:none;border-radius:6px;cursor:pointer;font-size:14px}.delete-button:hover{background:#fecaca}.add-club-form{display:flex;gap:12px;margin-top:16px}.add-club-form input{flex:1;padding:10px 14px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px}.add-button{padding:10px 20px;background:#22c55e;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.add-button:hover{background:#16a34a}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.config-item{display:flex;flex-direction:column;gap:6px}.config-label{font-size:14px;font-weight:500;color:#374151}.config-input{padding:8px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:14px}.config-input:focus{outline:none;border-color:#3b82f6}.config-slider{width:100%;height:8px;border-radius:4px;background:#e5e7eb;cursor:pointer}.config-checkbox{width:20px;height:20px;cursor:pointer}.color-picker{width:100%;height:40px;border:2px solid #e5e7eb;border-radius:6px;cursor:pointer;padding:2px}.preview-container{margin-top:24px;padding:24px;background:#1a1a2e;border-radius:12px;display:flex;align-items:center;justify-content:center;min-height:200px}.invalid-tablet{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;text-align:center;padding:24px}.invalid-tablet h1{font-size:24px;margin-bottom:16px}.invalid-tablet p{color:#9ca3af;margin-bottom:8px}.invalid-tablet code{background:#374151;padding:4px 8px;border-radius:4px;font-family:monospace}.ndi-status-card{background:#f9fafb;border-radius:12px;padding:16px;margin-bottom:20px}.ndi-status-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.ndi-status-row:not(:last-child){border-bottom:1px solid #e5e7eb}.ndi-status-label{font-size:14px;font-weight:500;color:#374151}.ndi-status-badge{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.ndi-status-badge.connected{background:#dcfce7;color:#16a34a}.ndi-status-badge.disconnected{background:#fee2e2;color:#dc2626}.ndi-status-badge.enabled{background:#dbeafe;color:#2563eb}.ndi-status-badge.disabled{background:#f3f4f6;color:#6b7280}.ndi-status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.ndi-source-name{font-size:14px;font-weight:600;color:#1f2937}.ndi-control-section{margin-bottom:20px}.ndi-toggle-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;font-size:18px;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.ndi-toggle-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.ndi-toggle-btn.active{background:linear-gradient(135deg,#ef4444,#dc2626)}.ndi-toggle-btn.active:hover:not(:disabled){box-shadow:0 4px 12px #ef444466}.ndi-toggle-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.ndi-icon{font-size:24px}.ndi-hint{font-size:13px;color:#6b7280;margin-top:8px}.ndi-source-input-row{display:flex;gap:12px}.ndi-source-input-row input{flex:1}
