:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}a{font-weight:500;color:#2563eb;text-decoration:none}a:hover{text-decoration:underline}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}button:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000014;text-align:center}.login-card h1{font-size:1.8rem;color:#1a1a1a;margin:0 0 4px}.login-subtitle{color:#666;font-size:.9rem;margin:0 0 24px}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;background:#fff;font-size:15px;font-weight:500;color:#333;cursor:pointer;transition:background .2s,box-shadow .2s}.google-btn:hover{background:#f8f8f8;box-shadow:0 2px 8px #00000014}.login-divider{display:flex;align-items:center;margin:20px 0;color:#999;font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.login-divider span{padding:0 12px}.login-card form{display:flex;flex-direction:column;gap:12px}.login-card input[type=text],.login-card input[type=email],.login-card input[type=password]{padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:15px;outline:none;transition:border-color .2s;background:#fff;color:#333}.login-card input:focus{border-color:#2563eb}.submit-btn{padding:12px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s}.submit-btn:hover:not(:disabled){background:#3b82f6}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-success{color:#22c55e;font-size:14px;margin:12px 0 0;padding:10px 12px;background:#22c55e14;border-radius:6px}.login-error{color:#e63946;font-size:14px;margin:12px 0 0;padding:8px 12px;background:#e6394614;border-radius:6px}.forgot-password{margin:10px 0 0;font-size:13px}.login-toggle{margin:16px 0 0;font-size:14px;color:#666}.link-btn{background:none;border:none;color:#2563eb;font-weight:500;cursor:pointer;font-size:14px;padding:0 4px}.link-btn:hover{text-decoration:underline}.dashboard{min-height:100vh;background:#fff;font-family:system-ui,-apple-system,sans-serif}.dashboard-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.1rem;color:#666}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:#fff;border-bottom:1px solid #e5e7eb}.header-left h1{margin:0;font-size:1.4rem;font-weight:700;color:#1a1a1a}.header-right{display:flex;align-items:center;gap:12px}.user-name{font-size:.9rem;color:#555;font-weight:500}.admin-link{padding:6px 14px;border:1px solid #2563eb;border-radius:6px;background:transparent;color:#2563eb;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s,color .2s}.admin-link:hover{background:#2563eb;color:#fff}.sign-out-btn{padding:6px 14px;border:1px solid #d1d5db;border-radius:6px;background:transparent;color:#555;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}.sign-out-btn:hover{background:#f3f4f6;color:#333}.dashboard-content{max-width:960px;margin:0 auto;padding:32px 24px}.dashboard-section{margin-bottom:48px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dashboard-section h2{margin:0 0 4px;font-size:1.25rem;font-weight:700;color:#1a1a1a}.section-description{margin:0 0 20px;font-size:.9rem;color:#666}.new-session-btn{padding:10px 20px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.new-session-btn:hover{background:#3b82f6}.empty-state{padding:32px 20px;text-align:center;color:#999;font-size:.95rem;background:#f9fafb;border-radius:12px;border:1px dashed #e5e7eb}.sessions-list{display:flex;flex-direction:column;gap:10px}.session-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#1a1a1a;border-radius:12px;cursor:pointer;transition:transform .15s,box-shadow .15s}.session-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0003}.session-info h3{margin:0 0 4px;font-size:1rem;font-weight:600;color:#fff}.session-date{margin:0;font-size:.8rem;color:#999}.session-badges{display:flex;align-items:center;gap:8px;flex-shrink:0}.session-delete-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid transparent;border-radius:50%;color:#666;font-size:1.1rem;cursor:pointer;opacity:0;transition:opacity .15s,color .15s,border-color .15s}.session-card:hover .session-delete-btn{opacity:1}.type-badge{padding:4px 10px;font-size:.75rem;font-weight:600;color:#ccc;border:1px solid #444;border-radius:20px;white-space:nowrap}.state-badge{padding:4px 10px;font-size:.75rem;font-weight:600;color:#fff;border-radius:20px;white-space:nowrap}.library-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.library-card{padding:24px 20px;background:#1a1a1a;border-radius:12px;cursor:pointer;transition:transform .15s,box-shadow .15s}.library-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0003}.library-card h3{margin:0 0 8px;font-size:1rem;font-weight:600;color:#fff}.interpreter-name{margin:0;font-size:.85rem;color:#999}@media(max-width:768px){.library-grid{grid-template-columns:repeat(2,1fr)}.dashboard-header{padding:14px 20px}.dashboard-content{padding:24px 16px}}@media(max-width:600px){.dashboard-header{flex-direction:column;gap:12px;align-items:flex-start;padding:14px 16px}.header-right{width:100%;justify-content:flex-end}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.new-session-btn{width:100%;text-align:center}.library-grid{grid-template-columns:1fr}.session-card{flex-direction:column;align-items:flex-start;gap:12px}.session-badges{align-self:flex-end}}.comparison-container{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.comparison-video-title{font-size:1.4rem;color:#333;margin:0;text-align:center;max-width:800px;font-weight:600}.comparison-youtube-wrapper{width:100%;max-width:800px;aspect-ratio:16 / 9;background-color:#000;border-radius:8px;overflow:hidden}.comparison-youtube-wrapper iframe,.comparison-youtube-wrapper>div:not(.resize-grip){width:100%!important;height:100%!important;max-width:100%}.comparison-timeline{display:flex;align-items:center;gap:15px;width:100%;max-width:800px;padding:10px 0}.comparison-timeline-slider{flex:1;height:8px;-webkit-appearance:none;appearance:none;background:#d1d5db;border-radius:4px;cursor:pointer;outline:none}.comparison-timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:#2563eb;border-radius:50%;cursor:pointer;transition:transform .1s ease}.comparison-timeline-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.comparison-timeline-slider::-moz-range-thumb{width:18px;height:18px;background:#2563eb;border-radius:50%;cursor:pointer;border:none;transition:transform .1s ease}.comparison-timeline-slider::-moz-range-thumb:hover{transform:scale(1.2)}.comparison-timeline-slider:disabled{opacity:.5;cursor:not-allowed}.comparison-time-display{font-size:14px;color:#555;font-family:monospace;min-width:45px}.comparison-videos-row{display:flex;gap:20px;width:100%;max-width:960px;justify-content:center;align-items:center}.comparison-video-panel{flex:1;min-width:0;display:flex;flex-direction:column}.comparison-panel-header{min-height:60px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:2px;margin-bottom:8px}.comparison-panel-label{font-size:1.1rem;color:#333;margin:0;font-weight:600}.comparison-panel-note{font-size:.8rem;color:#888;margin:0;font-style:italic}.comparison-mark-btn{padding:4px 12px;font-size:13px;font-weight:600;border:none;border-radius:6px;background-color:#2563eb;color:#fff;cursor:pointer;transition:all .2s ease}.comparison-mark-btn:hover:not(:disabled){background-color:#3b82f6;transform:translateY(-1px)}.comparison-mark-btn:disabled{opacity:.4;cursor:not-allowed}.comparison-mark-row{display:flex;align-items:center;gap:8px}.comparison-mark-status{font-size:.85rem;font-weight:500;color:#22c55e;animation:mark-fade-in .2s ease}@keyframes mark-fade-in{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.comparison-video-wrapper{position:relative;width:100%;aspect-ratio:16 / 9;background-color:#1a1a1a;border-radius:8px;overflow:hidden}.comparison-local-video{width:100%;height:100%;object-fit:contain;background:#000}.comparison-no-video{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#1a1a1a;color:#666;font-style:italic}.comparison-processing p:first-child{font-size:1.2rem;color:#f59e0b;font-style:normal;font-weight:600;margin:0 0 6px}.comparison-processing-hint{font-size:.85rem;color:#888;margin:0}.comparison-swap-btn{display:flex;align-items:center;justify-content:center;width:50px;height:50px;font-size:24px;border:none;border-radius:50%;background-color:#2563eb;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.comparison-swap-btn:hover:not(:disabled){background-color:#3b82f6;transform:scale(1.1)}.comparison-swap-btn:disabled{background-color:#d1d5db;color:#999;cursor:not-allowed}.comparison-controls{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;padding:10px 0}.comparison-control-btn{padding:12px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;background-color:#e5e7eb;color:#333}.comparison-control-btn:hover:not(:disabled){transform:translateY(-2px)}.comparison-control-btn:active:not(:disabled){transform:translateY(0)}.comparison-control-btn:disabled{opacity:.5;cursor:not-allowed}.comparison-toggle-btn{background-color:#2563eb;color:#fff;min-width:120px}.comparison-toggle-btn:hover:not(:disabled){background-color:#3b82f6}.comparison-speed-btn{background-color:#e5e7eb;color:#333;min-width:60px}.comparison-speed-btn.active{background-color:#f59e0b;color:#000}.comparison-speed-btn.active:hover:not(:disabled){background-color:#fbbf24}.comparison-headstart-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.comparison-headstart-label{font-size:14px;color:#ccc;font-weight:500}.comparison-toggle-switch{width:40px;height:22px;background-color:#555;border-radius:11px;position:relative;transition:background-color .2s;cursor:pointer}.comparison-toggle-switch.active{background-color:#2563eb}.comparison-toggle-knob{width:18px;height:18px;background-color:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .2s}.comparison-toggle-switch.active .comparison-toggle-knob{transform:translate(18px)}.comparison-loading-text{color:#888;font-style:italic}.comparison-video-wrapper.blurred-unplayable video{filter:blur(15px);pointer-events:none}.comparison-blur-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;color:#fff;font-size:1.15rem;font-weight:600;text-align:center;pointer-events:none;text-shadow:0 2px 8px rgba(0,0,0,.7)}.comparison-video-loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:#000000b3;z-index:5;border-radius:8px}.comparison-video-loading-overlay{flex-direction:column;gap:10px}.comparison-video-loading-overlay p{color:#ccc;font-size:1rem;font-style:italic;margin:0}.comparison-progress-bar{width:60%;max-width:200px;height:4px;background:#ffffff26;border-radius:2px;overflow:hidden}.comparison-progress-fill{height:100%;background:#2563eb;border-radius:2px;transition:width .2s ease}.loading-dots-text:after{content:"";animation:loading-dots 1.5s infinite}.comparison-container.focus-mode{background-color:#000;border-radius:12px;padding:20px;transition:background-color .8s ease}.focus-faded{opacity:.2;pointer-events:none;transition:opacity .8s ease}.comparison-container.focus-mode .comparison-video-panel{transition:opacity .8s ease}.comparison-container.focus-mode .comparison-video-panel.focus-active{cursor:default}.comparison-container.focus-mode .comparison-video-panel:not(.focus-faded){cursor:default}.comparison-video-panel{cursor:pointer;transition:opacity .8s ease}.comparison-swap-btn,.comparison-controls,.comparison-video-title{transition:opacity .8s ease}.comparison-container{transition:background-color .8s ease}@media(max-width:600px){.comparison-control-btn{padding:10px 18px;font-size:14px}.comparison-panel-label{font-size:1rem}.comparison-videos-row{flex-direction:column;gap:20px;max-width:100%}.comparison-swap-btn{transform:rotate(90deg)}.comparison-swap-btn:hover:not(:disabled){transform:rotate(90deg) scale(1.1)}.comparison-youtube-wrapper,.comparison-video-wrapper{width:100%;min-width:0;max-width:100%}.comparison-timeline{max-width:100%;box-sizing:border-box;padding:10px 4px}.comparison-video-panel{width:100%;max-width:100%}}.audio-comparison{display:flex;flex-direction:column;gap:20px;padding:20px}.audio-comparison .youtube-wrapper{background:#000;border-radius:12px;overflow:hidden;aspect-ratio:16 / 9;max-width:640px;margin:0 auto;width:100%}.audio-comparison .cards{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:600px){.audio-comparison .cards{grid-template-columns:1fr}}.audio-comparison .audio-card{background:#1a1a1a;border-radius:12px;padding:20px;color:#fff;display:flex;flex-direction:column;gap:12px;border:2px solid transparent;transition:border-color .2s}.audio-comparison .audio-card.active{border-color:#2563eb}.audio-comparison .audio-card .label{font-weight:600;font-size:14px;color:#9ca3af}.audio-comparison .audio-card .play-btn{padding:12px 24px;font-size:16px;font-weight:600;background:#2563eb;color:#fff;border:none;border-radius:8px;cursor:pointer}.audio-comparison .audio-card .play-btn.playing{background:#e63946}.audio-comparison .audio-card .scrubber{width:100%}.audio-comparison .audio-card .time{font-variant-numeric:tabular-nums;font-size:14px;color:#9ca3af}.audio-comparison .controls{display:flex;gap:12px;justify-content:center}.audio-comparison .speed-btn{padding:8px 16px;background:#1f2937;color:#fff;border:2px solid transparent;border-radius:8px;cursor:pointer}.audio-comparison .speed-btn.active{border-color:#f59e0b}.audio-comparison .audio-card .mark-btn{padding:10px 16px;background:#10b981;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;font-size:15px}.audio-comparison .audio-card .mark-btn:disabled{background:#6b7280;cursor:not-allowed;opacity:.6}.reflection-form-container{max-width:100%;margin:32px 0;padding:0;font-family:system-ui,-apple-system,sans-serif}.reflection-loading,.reflection-empty{text-align:center;padding:32px 20px;color:#999;font-size:.95rem;background:#f9fafb;border-radius:12px;border:1px dashed #e5e7eb;max-width:100%;margin:32px 0}.reflection-title{margin:0 0 24px;font-size:1.25rem;font-weight:700;color:#1a1a1a}.reflection-form{display:flex;flex-direction:column;gap:0}.reflection-question{padding:20px 0;border-bottom:1px solid #e5e7eb}.reflection-question:first-child{padding-top:0}.reflection-question:last-of-type{border-bottom:none}.question-text{margin:0 0 14px;font-size:.95rem;font-weight:500;color:#1a1a1a;line-height:1.5}.question-number{font-weight:700;color:#2563eb;margin-right:4px}.radio-group{display:flex;flex-direction:column;gap:10px;padding-left:4px}.radio-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.9rem;color:#333;padding:8px 12px;border-radius:8px;transition:background .15s}.radio-label:hover{background:#f3f4f6}.radio-label input[type=radio]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid #d1d5db;border-radius:50%;flex-shrink:0;cursor:pointer;position:relative;transition:border-color .15s}.radio-label input[type=radio]:checked{border-color:#2563eb}.radio-label input[type=radio]:checked:after{content:"";position:absolute;top:3px;left:3px;width:8px;height:8px;background:#2563eb;border-radius:50%}.radio-text{-webkit-user-select:none;user-select:none}.essay-input{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-family:system-ui,-apple-system,sans-serif;font-size:.9rem;color:#1a1a1a;background:#fff;resize:vertical;min-height:120px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}.essay-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.essay-input::placeholder{color:#9ca3af}.reflection-submit{margin-top:24px;padding:12px 28px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s;align-self:flex-start}.reflection-submit:hover:not(:disabled){background:#3b82f6}.reflection-submit:disabled{opacity:.6;cursor:not-allowed}.reflection-success{padding:20px 24px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;color:#166534;font-size:.95rem;font-weight:500}.reflection-success p{margin:0}.reflection-error{margin:12px 0 0;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.9rem;font-weight:500}.reflection-responses-display{margin-top:24px}.saved-responses{display:flex;flex-direction:column;gap:8px;margin-top:8px}.saved-response{padding:10px 14px;background:#f9fafb;border-radius:8px;font-size:.9rem;color:#333;border:1px solid #e5e7eb}.saved-response.own-response{background:#eff6ff;border-color:#bfdbfe}.saved-response.partner-response{margin-top:10px}.response-author{font-weight:600;color:#1a1a1a;margin-right:6px}.response-text{color:#374151}@media(max-width:600px){.reflection-form-container{margin:24px auto;padding:0 12px}.reflection-title{font-size:1.1rem}.reflection-question{padding:16px 0}.reflection-submit{width:100%;text-align:center}}.webcam-recorder{display:flex;flex-direction:column;align-items:center;gap:15px;padding:20px;background-color:#1a1a1a;border-radius:12px;width:100%}.webcam-title{font-size:1.2rem;color:#fff;margin:0;font-weight:500}.webcam-error{color:#e63946;font-size:.9rem;margin:0;text-align:center}.webcam-preview{position:relative;width:100%;aspect-ratio:4 / 3;background-color:#000;border-radius:8px;overflow:hidden}.webcam-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.webcam-video.preview-video{transform:scaleX(1)}.recording-indicator{position:absolute;top:10px;left:10px;display:flex;align-items:center;gap:8px;background-color:#000000b3;padding:6px 12px;border-radius:20px}.recording-dot{width:12px;height:12px;background-color:#e63946;border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.recording-time{color:#fff;font-size:14px;font-family:monospace}.webcam-controls{display:flex;flex-direction:column;align-items:center;gap:10px}.webcam-btn{padding:12px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.webcam-btn:disabled{opacity:.5;cursor:not-allowed}.record-btn{background-color:#e63946;color:#fff}.record-btn:hover:not(:disabled){background-color:#f25c69}.stop-btn{background-color:#3b3b3b;color:#fff}.stop-btn:hover:not(:disabled){background-color:#4a4a4a}.recording-actions{display:flex;flex-direction:column;align-items:center;gap:10px}.recording-buttons{display:flex;gap:10px}.recording-ready{color:#4ade80;font-size:14px;margin:0}.recording-actions .webcam-btn{min-width:140px}.discard-btn{background-color:#6b7280;color:#fff}.discard-btn:hover:not(:disabled){background-color:#7c8591}.rerecord-btn{background-color:#2563eb;color:#fff}.rerecord-btn:hover:not(:disabled){background-color:#3b82f6}@media(max-width:600px){.webcam-recorder{max-width:100%}.webcam-btn{padding:10px 18px;font-size:14px}}.audio-recorder{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px;background:#1a1a1a;border-radius:12px;color:#fff}.audio-recorder .mic-status{font-size:14px;color:#9ca3af;display:flex;align-items:center;gap:6px}.audio-recorder .mic-status.ready{color:#10b981}.audio-recorder .mic-status.error{color:#ef4444}.audio-recorder .recording-indicator{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600;color:#e63946}.audio-recorder .recording-dot{width:12px;height:12px;border-radius:50%;background:#e63946;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.audio-recorder .recording-time{font-variant-numeric:tabular-nums}.audio-recorder .audio-btn{padding:12px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;color:#fff;min-width:200px}.audio-recorder .record-btn{background:#e63946}.audio-recorder .record-btn:disabled{background:#6b7280;cursor:not-allowed}.audio-recorder .stop-btn{background:#1f2937;border:2px solid #e63946}.audio-recorder .discard-btn{background:#6b7280}.audio-recorder .rerecord-btn{background:#2563eb}.audio-recorder .recording-actions{display:flex;flex-direction:column;align-items:center;gap:12px}.audio-recorder .recording-buttons{display:flex;gap:12px}.audio-recorder audio{width:100%;max-width:400px}.audio-recorder .audio-error{color:#ef4444;font-size:14px}.stripe-payment-container{max-width:720px;margin:32px auto;padding:0 16px;font-family:system-ui,-apple-system,sans-serif}.stripe-payment-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.stripe-title{margin:0 0 8px;font-size:1.15rem;font-weight:700;color:#1a1a1a}.stripe-description{margin:0 0 20px;font-size:.95rem;color:#555;line-height:1.5}.stripe-pay-btn{padding:12px 28px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.stripe-pay-btn:hover:not(:disabled){background:#3b82f6}.stripe-pay-btn:disabled{opacity:.6;cursor:not-allowed}.stripe-pay-btn-locked,.stripe-pay-btn-locked:hover{background:#9ca3af}.stripe-locked-hint{margin:10px 0 0;font-size:.85rem;color:#6b7280;line-height:1.4}.stripe-checkout-form{display:flex;flex-direction:column;gap:16px}.stripe-submit-btn{padding:12px 28px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s;align-self:flex-start}.stripe-submit-btn:hover:not(:disabled){background:#3b82f6}.stripe-submit-btn:disabled{opacity:.6;cursor:not-allowed}.stripe-error{margin:8px 0 0;padding:10px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.9rem;font-weight:500}.stripe-success{display:flex;align-items:center;gap:14px;padding:20px 24px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;color:#166534;font-size:.95rem;font-weight:500}.stripe-success p{margin:4px 0 0;font-weight:400;font-size:.9rem}.stripe-success-icon{font-size:1.5rem;font-weight:700;flex-shrink:0}@media(max-width:600px){.stripe-payment-container{margin:24px auto;padding:0 12px}.stripe-payment-card{padding:20px 16px}.stripe-pay-btn,.stripe-submit-btn{width:100%;text-align:center}}.snippet-card{background:#1a1a1a;border-radius:8px;padding:16px;margin-bottom:12px}.snippet-card.own-card{border-left:3px solid #2563eb}.snippet-card.partner-card{border-left:3px solid #555}.snippet-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.snippet-card-header-info{display:flex;align-items:center;gap:8px;color:#ccc;font-size:.85rem}.snippet-card-header-info .snippet-user{font-weight:600;color:#fff}.snippet-remove-btn{background:none;border:none;color:#888;font-size:1rem;cursor:pointer;padding:2px 6px;border-radius:4px}.snippet-remove-btn:hover{color:#e63946;background:#e639461a}.snippet-confirm-remove{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#ccc}.snippet-confirm-remove span{color:#e63946;font-weight:600}.snippet-confirm-yes,.snippet-confirm-no{background:none;border:1px solid #555;color:#ccc;font-size:.75rem;padding:2px 8px;border-radius:4px;cursor:pointer}.snippet-confirm-yes:hover{background:#e63946;color:#fff;border-color:#e63946}.snippet-confirm-no:hover{background:#333}.snippet-mini-player{position:relative;max-width:400px;aspect-ratio:16 / 9;background:#000;border-radius:6px;overflow:hidden;margin-bottom:8px}.snippet-mini-player video{width:100%;height:100%;object-fit:contain;display:block}.snippet-video-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b3;z-index:5;border-radius:6px}.snippet-video-loading p{color:#ccc;font-size:.9rem;font-style:italic;margin:0}.snippet-video-loading p:after{content:"";animation:loading-dots 1.5s infinite}@keyframes loading-dots{0%{content:""}16%{content:"."}33%{content:".."}50%{content:"..."}66%{content:".."}83%{content:"."}to{content:""}}.snippet-play-btn{position:absolute;bottom:8px;left:8px;width:32px;height:32px;border-radius:50%;background:#0009;border:none;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}.snippet-play-btn:hover{background:#000c}.snippet-trim-bar{position:relative;height:32px;background:#333;border-radius:4px;margin-bottom:10px;-webkit-user-select:none;user-select:none;touch-action:none;cursor:default;overflow:hidden}.snippet-trim-region{position:absolute;top:0;height:100%;background:#f59e0b66;pointer-events:none}.snippet-trim-handle{position:absolute;top:0;width:12px;height:100%;background:#f59e0b;border-radius:3px;z-index:3;cursor:ew-resize}.snippet-trim-handle.disabled{cursor:default;opacity:.6}.snippet-trim-handle-left,.snippet-trim-handle-right{transform:translate(-100%)}.snippet-trim-playhead{position:absolute;top:0;width:2px;height:100%;background:#fff;z-index:3;cursor:ew-resize}.snippet-trim-playhead:before{content:"";position:absolute;top:0;left:-6px;width:14px;height:100%}.snippet-trim-times{display:flex;justify-content:space-between;font-size:.75rem;color:#888;margin-bottom:10px}.snippet-reflection{margin-bottom:10px}.snippet-reflection-label{font-size:.8rem;color:#888;margin-bottom:4px}.snippet-reflection textarea{width:100%;min-height:60px;background:#2a2a2a;border:1px solid #444;border-radius:6px;color:#eee;padding:8px;font-size:.9rem;resize:vertical;font-family:inherit;box-sizing:border-box}.snippet-reflection textarea:focus{border-color:#2563eb;outline:none}.snippet-reflection-readonly{background:#2a2a2a;border:1px solid #333;border-radius:6px;color:#ccc;padding:8px;font-size:.9rem;white-space:pre-wrap;min-height:40px}.snippet-save-btn{background:#2563eb;color:#fff;border:none;padding:4px 14px;border-radius:4px;font-size:.8rem;cursor:pointer;margin-top:4px}.snippet-save-btn:hover{background:#1d4ed8}.snippet-save-btn:disabled{opacity:.5;cursor:not-allowed}.snippet-save-row{display:flex;align-items:center;gap:10px;margin-top:8px}.snippet-save-status{font-size:.85rem;font-weight:500;animation:snippet-fade-in .2s ease}.snippet-save-ok{color:#22c55e}.snippet-save-err{color:#e63946}@keyframes snippet-fade-in{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.snippet-comments{border-top:1px solid #333;padding-top:10px;margin-top:10px}.snippet-comments-title{font-size:.8rem;color:#888;margin-bottom:6px}.snippet-comment{margin-bottom:8px;font-size:.85rem;color:#ccc}.snippet-comment-user{font-weight:700;color:#fff;margin-right:6px}.snippet-comment-date{font-size:.7rem;color:#666;margin-left:6px}.snippet-comment-text{margin-top:2px}.snippet-comment-input-row{display:flex;gap:6px;margin-top:6px;align-items:flex-end}.snippet-comment-textarea{flex:1;background:#2a2a2a;border:1px solid #444;border-radius:6px;color:#eee;padding:6px 8px;font-size:.85rem;font-family:inherit;resize:vertical;min-height:40px}.snippet-comment-textarea:focus{border-color:#2563eb;outline:none}.snippet-reply-btn{background:#333;color:#ccc;border:none;padding:6px 12px;border-radius:4px;font-size:.8rem;cursor:pointer;white-space:nowrap}.snippet-reply-btn:hover{background:#444;color:#fff}.snippet-reply-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:600px){.snippet-mini-player{max-width:100%}.snippet-trim-handle{width:16px}.snippet-card{padding:12px}}.video-snippets-section{width:100%;max-width:960px;margin:0 auto}.video-snippets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.video-snippets-title{font-size:1.3rem;font-weight:600;color:#333;margin:0}.video-snippets-count{font-size:.9rem;color:#888}.video-snippets-list{display:flex;flex-direction:column;gap:16px}.video-snippets-divider{display:flex;align-items:center;gap:12px;margin:8px 0;color:#666;font-size:.85rem}.video-snippets-divider:before,.video-snippets-divider:after{content:"";flex:1;height:1px;background:#333}.video-snippets-empty{text-align:center;color:#888;font-style:italic;padding:20px}.session-view{min-height:100vh;background:#fff;font-family:system-ui,-apple-system,sans-serif}.session-loading,.session-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:#666;font-size:1.05rem}.session-error p{color:#e63946}.session-header{display:flex;align-items:center;gap:16px;padding:16px 32px;border-bottom:1px solid #e5e7eb;background:#fff}.session-back-btn{padding:6px 14px;border:1px solid #d1d5db;border-radius:6px;background:transparent;color:#555;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s;flex-shrink:0}.session-back-btn:hover{background:#f3f4f6;color:#333}.session-header-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.session-title-text{margin:0;font-size:1.3rem;font-weight:700;color:#1a1a1a}.session-state-badge{padding:4px 12px;font-size:.75rem;font-weight:600;color:#fff;border-radius:20px;white-space:nowrap}.session-admin-badge{padding:4px 12px;font-size:.75rem;font-weight:600;color:#6b7280;background:#f3f4f6;border:1px solid #d1d5db;border-radius:20px;white-space:nowrap}.admin-session-details p{margin:6px 0;font-size:.95rem;color:#333}.admin-session-details a{color:#2563eb}.session-delete-btn{margin-left:auto;padding:6px 14px;background:none;border:1px solid #666;border-radius:6px;color:#666;font-size:.8rem;cursor:pointer;transition:color .15s,border-color .15s}.session-delete-btn:hover{color:#e63946;border-color:#e63946}.session-create-form{max-width:960px;margin:0 auto;padding:32px 24px;display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.9rem;font-weight:600;color:#333}.form-hint{font-size:.85rem;color:#999;margin:0;font-style:italic}.form-input{padding:10px 14px;font-size:.95rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#333;outline:none;transition:border-color .2s}.form-input:focus{border-color:#2563eb}.form-input::placeholder{color:#999}.form-select{padding:10px 14px;font-size:.95rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#333;outline:none;cursor:pointer}.form-select:focus{border-color:#2563eb}.session-type-selector{display:flex;gap:8px}.type-option{flex:1;padding:10px 16px;border:2px solid #d1d5db;border-radius:8px;background:#fff;color:#555;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.type-option:hover{border-color:#2563eb;color:#2563eb}.type-option.selected{border-color:#2563eb;background:#2563eb;color:#fff}.youtube-url-row{display:flex;gap:10px}.youtube-url-row .form-input{flex:1}.youtube-preview{width:100%;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden}.youtube-preview iframe{width:100%!important;height:100%!important}.resize-grip{position:absolute;right:0;bottom:0;width:16px;height:16px;cursor:nwse-resize;z-index:10;border-radius:3px 0 8px;background:#0006;background-image:linear-gradient(135deg,transparent 30%,rgba(255,255,255,.5) 30%,rgba(255,255,255,.5) 36%,transparent 36%,transparent 52%,rgba(255,255,255,.5) 52%,rgba(255,255,255,.5) 58%,transparent 58%,transparent 74%,rgba(255,255,255,.5) 74%,rgba(255,255,255,.5) 80%,transparent 80%);transition:background-color .15s}.resize-grip:hover{background-color:#2563eb99}.webcam-resize-wrapper{width:480px;max-width:100%;border-radius:12px;overflow-x:hidden;overflow-y:visible;background:#1a1a1a}.yt-video-info{display:flex;align-items:center;gap:10px;margin-bottom:8px;max-width:720px}.yt-video-title{font-size:.95rem;font-weight:600;color:#1a1a1a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.yt-video-duration{font-size:.85rem;font-weight:600;color:#555;background:#f0f0f0;padding:2px 10px;border-radius:12px;white-space:nowrap}.session-recorder-section{display:flex;flex-direction:column;align-items:center;gap:16px}.recorder-heading{margin:0;font-size:1.1rem;font-weight:600;color:#333}.session-btn-primary{padding:10px 22px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.session-btn-primary:hover:not(:disabled){background:#3b82f6}.session-btn-primary:disabled{opacity:.5;cursor:not-allowed}.session-btn-secondary{padding:10px 22px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#555;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.session-btn-secondary:hover{background:#f3f4f6;color:#333}.session-submit-btn{align-self:center;padding:14px 40px;font-size:1rem}.session-message{text-align:center;padding:10px 16px;border-radius:8px;font-size:.9rem;margin:0}.session-message.success{background:#22c55e1a;color:#16a34a}.session-message.error{background:#e639461a;color:#e63946}.session-waiting{display:flex;justify-content:center;padding:48px 24px}.waiting-card{max-width:600px;width:100%;background:#1a1a1a;border-radius:16px;padding:32px;text-align:center}.waiting-card h2{margin:0 0 12px;color:#fff;font-size:1.3rem}.waiting-card p{margin:0 0 24px;color:#999;font-size:.95rem;line-height:1.5}.invite-section{display:flex;flex-direction:column;gap:16px}.invite-link-row{display:flex;gap:10px}.invite-link-input{flex:1;background:#2a2a2a!important;border-color:#444!important;color:#fff!important;font-size:.85rem!important}.invite-email-row{display:flex;gap:10px}.invite-email-row .form-input{flex:1;background:#2a2a2a;border-color:#444;color:#fff}.invite-email-row .form-input::placeholder{color:#777}.session-recording-b{display:flex;justify-content:center;padding:32px 24px}.recording-b-card{max-width:960px;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px}.recording-b-card h2{margin:0;font-size:1.3rem;font-weight:700;color:#1a1a1a}.recording-b-card>p{margin:0;color:#666;font-size:.95rem;line-height:1.5;text-align:center;max-width:560px}.recording-b-panels{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:100%}.recording-b-panel{display:flex;flex-direction:column;gap:12px}.recording-b-panel-label{margin:0;font-size:.95rem;font-weight:600;color:#555;text-align:center}.blurred-video-placeholder{position:relative;width:100%;aspect-ratio:4 / 3;border-radius:12px;overflow:hidden;background:#1a1a1a}.blurred-video-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2a2a3e,#1a1a2e,#2d1f3d 60%,#1a2a3a);filter:blur(8px);transform:scale(1.1);color:#ffffff26}.blurred-video-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#ffffffb3;z-index:1}.blurred-video-overlay svg{opacity:.6}.blurred-video-overlay span{font-size:.95rem;font-weight:600;letter-spacing:.02em}.blurred-video-name{font-size:1.1rem!important;font-weight:700!important;color:#ffffffe6!important}.blurred-video-hint{font-size:.78rem!important;font-weight:400!important;color:#fff6!important}.session-comparison{max-width:1100px;margin:0 auto;padding:32px 24px;display:flex;flex-direction:column;gap:32px}.session-reflection-placeholder{background:#f9fafb;border:1px dashed #e5e7eb;border-radius:12px;padding:32px 24px;text-align:center}.session-reflection-placeholder h3{margin:0 0 8px;font-size:1.1rem;color:#555;font-weight:600}.session-reflection-placeholder p{margin:0;color:#999;font-size:.9rem}@media(max-width:600px){.session-header{padding:14px 16px;gap:12px}.session-title-text{font-size:1.1rem}.session-create-form{padding:24px 16px}.youtube-url-row,.session-type-selector,.invite-link-row,.invite-email-row{flex-direction:column}.recording-b-panels{grid-template-columns:1fr}.session-comparison{padding:20px 12px;overflow-x:hidden}.waiting-card{padding:24px 16px}}.admin-extras{margin-top:24px}.admin-extras-loading{text-align:center;color:#888;padding:16px}.admin-extras-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:20px;margin-bottom:16px}.admin-extras-heading{margin:0 0 12px;font-size:1.05rem;font-weight:700;color:#333}.admin-extras-empty{color:#888;font-size:.9rem;margin:0}.admin-reflection-item{padding:10px 0;border-bottom:1px solid #e5e7eb}.admin-reflection-item:last-child{border-bottom:none}.admin-reflection-question{margin:0 0 6px;font-weight:600;font-size:.95rem;color:#1a1a1a}.admin-reflection-num{color:#2563eb;margin-right:4px}.admin-reflection-type{font-weight:400;color:#888;font-size:.8rem;margin-left:6px}.admin-reflection-answer{padding:4px 0 4px 20px;font-size:.9rem}.admin-reflection-author{font-weight:600;color:#555;margin-right:6px}.admin-reflection-text{color:#333}.admin-reflection-no-answer{color:#aaa;font-size:.85rem;padding-left:20px;margin:4px 0}.admin-payment-item{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid #e5e7eb;font-size:.9rem}.admin-payment-item:last-child{border-bottom:none}.admin-payment-user{font-weight:600;color:#333}.admin-payment-badge{padding:2px 10px;border-radius:12px;font-size:.78rem;font-weight:600}.admin-payment-badge.paid{background:#dcfce7;color:#16a34a}.admin-payment-badge.unpaid{background:#fef2f2;color:#e63946}.admin-payment-amount{color:#555}.admin-payment-date{color:#888;margin-left:auto}.locked-partner-card{padding:24px;background:#1a1a1a;border:2px dashed #4b5563;border-radius:12px;color:#9ca3af;text-align:center;font-size:16px;margin:12px 0}.snippet-replace-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.snippet-replace-modal{background:#1a1a1a;border-radius:12px;padding:24px;max-width:400px;width:90%}.snippet-replace-modal h3{color:#e5e7eb;margin:0 0 8px}.snippet-replace-modal p{color:#999;font-size:.9rem;margin:0 0 16px}.snippet-replace-option{display:block;width:100%;padding:10px 14px;margin-bottom:8px;background:#2a2a2a;border:1px solid #444;border-radius:8px;color:#e5e7eb;font-size:.9rem;cursor:pointer;text-align:left;transition:all .2s}.snippet-replace-option:hover{background:#333;border-color:#2563eb}.snippet-replace-cancel{display:block;width:100%;padding:10px;margin-top:8px;background:none;border:1px solid #555;border-radius:8px;color:#888;font-size:.9rem;cursor:pointer}.snippet-replace-cancel:hover{color:#ccc;border-color:#888}.admin-panel{min-height:100vh;background:#fff;font-family:system-ui,-apple-system,sans-serif}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:#fff;border-bottom:1px solid #e5e7eb}.admin-header h1{margin:0;font-size:1.4rem;font-weight:700;color:#1a1a1a}.back-link{padding:6px 14px;border:1px solid #d1d5db;border-radius:6px;background:transparent;color:#555;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s,color .2s}.back-link:hover{background:#f3f4f6;color:#333}.admin-tabs{display:flex;gap:0;padding:0 32px;background:#fff;border-bottom:2px solid #e5e7eb}.tab-btn{padding:12px 20px;border:none;border-bottom:2px solid transparent;background:transparent;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;transition:color .2s,border-color .2s;margin-bottom:-2px}.tab-btn:hover{color:#333}.tab-btn.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.admin-content{max-width:1100px;margin:0 auto;padding:24px 32px}.admin-loading{padding:48px 24px;text-align:center;color:#888;font-size:.95rem}.admin-error{padding:20px 24px;margin:16px 0;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.9rem}.admin-empty{padding:32px 20px;text-align:center;color:#999;font-size:.95rem;background:#f9fafb;border-radius:12px;border:1px dashed #e5e7eb}.tab-panel{animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tab-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.tab-panel-header h2,.tab-panel h2{margin:0 0 4px;font-size:1.2rem;font-weight:700;color:#1a1a1a}.btn-primary{padding:8px 18px;border:none;border-radius:8px;background:#2563eb;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover{background:#3b82f6}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{padding:8px 18px;border:none;border-radius:8px;background:#dc2626;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-danger:hover{background:#b91c1c}.header-actions{display:flex;gap:10px}.payments-total{font-size:.95rem;color:#555;padding:6px 14px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px}.payments-total strong{color:#166534}.btn-secondary{padding:8px 18px;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#555;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#f3f4f6}.btn-small{padding:4px 10px;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;border:none;transition:background .2s}.btn-edit{background:#eff6ff;color:#2563eb}.btn-edit:hover{background:#dbeafe}.btn-delete{background:#fef2f2;color:#e63946}.btn-delete:hover{background:#fecaca}.btn-activate{background:#dcfce7;color:#16a34a}.btn-activate:hover{background:#bbf7d0}.action-btns{display:flex;gap:6px}.action-btns .btn-small{flex:1;text-align:center;white-space:nowrap}.sessions-search{position:relative;margin-bottom:16px;max-width:360px}.search-input{width:100%;padding:8px 32px 8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.88rem;font-family:inherit;color:#333;background:#fff;transition:border-color .2s;box-sizing:border-box}.search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.search-input::placeholder{color:#aaa}.search-clear{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.15rem;color:#999;cursor:pointer;padding:2px 6px;line-height:1}.search-clear:hover{color:#555}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.th-sortable:hover{color:#2563eb}.sort-arrows{display:inline-flex;flex-direction:column;vertical-align:middle;margin-left:4px;line-height:1;gap:0}.sort-arrow-up,.sort-arrow-down{font-size:.55rem;color:#ccc;line-height:.7}.sort-arrow-up.active,.sort-arrow-down.active{color:#2563eb}.table-wrapper{overflow-x:auto;border-radius:10px;border:1px solid #e5e7eb}.admin-table{width:100%;border-collapse:collapse;font-size:.88rem}.admin-table th{padding:10px 14px;text-align:left;font-weight:600;font-size:.8rem;color:#555;text-transform:uppercase;letter-spacing:.03em;background:#f9fafb;border-bottom:1px solid #e5e7eb;white-space:nowrap}.admin-table td{padding:10px 14px;color:#333;border-bottom:1px solid #f0f0f0;vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.row-alt{background:#fafbfc}.td-title{font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-question{max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-url{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.td-url a{color:#2563eb;text-decoration:none}.td-url a:hover{text-decoration:underline}.type-pill{display:inline-block;padding:3px 10px;font-size:.75rem;font-weight:600;border-radius:20px;background:#f0f0f0;color:#555}.state-pill{display:inline-block;padding:3px 10px;font-size:.75rem;font-weight:600;border-radius:20px;color:#fff;white-space:nowrap}.state-created{background:#888}.state-a_submitted{background:#f59e0b}.state-invited{background:#2563eb}.state-b_submitted{background:#f97316}.state-unlocked_compare,.state-solo_comparison{background:#22c55e}.payment-pill{display:inline-block;padding:3px 10px;font-size:.75rem;font-weight:600;border-radius:20px;white-space:nowrap}.payment-paid{background:#dcfce7;color:#16a34a}.payment-pending{background:#fef3c7;color:#b45309}.payment-none{background:#f3f4f6;color:#999}.active-badge{display:inline-block;padding:3px 10px;font-size:.75rem;font-weight:600;border-radius:20px}.active-badge.active{background:#dcfce7;color:#16a34a}.active-badge.inactive{background:#f3f4f6;color:#999}.inline-form{padding:20px 24px;margin-bottom:20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px}.inline-form h3{margin:0 0 16px;font-size:1rem;font-weight:600;color:#1a1a1a}.form-group{margin-bottom:14px}.form-group label{display:block;margin-bottom:5px;font-size:.82rem;font-weight:600;color:#555}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.88rem;font-family:inherit;color:#333;background:#fff;transition:border-color .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb26}.form-group textarea{resize:vertical;min-height:72px}.form-group input[type=file]{padding:8px 0;font-size:.85rem;border:none}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.form-actions{display:flex;gap:10px;margin-top:6px}.settings-card{padding:24px;margin-top:20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:24px}.setting-info h3{margin:0 0 6px;font-size:1rem;font-weight:600;color:#1a1a1a}.setting-info p{margin:0;font-size:.88rem;color:#666;max-width:480px;line-height:1.45}.setting-control{display:flex;align-items:center;gap:10px;flex-shrink:0}.toggle-btn{position:relative;width:48px;height:26px;border-radius:13px;border:none;cursor:pointer;transition:background .25s;padding:0}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-on{background:#2563eb}.toggle-off{background:#d1d5db}.toggle-knob{position:absolute;top:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000026;transition:left .25s}.toggle-on .toggle-knob{left:25px}.toggle-off .toggle-knob{left:3px}.toggle-label{font-size:.85rem;font-weight:600}.toggle-label.on{color:#2563eb}.toggle-label.off{color:#999}@media(max-width:768px){.admin-header{padding:14px 20px}.admin-tabs{padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-btn{white-space:nowrap;padding:10px 14px;font-size:.82rem}.admin-content{padding:20px 16px}.form-row{flex-direction:column;gap:0}.setting-row{flex-direction:column;align-items:flex-start;gap:16px}}@media(max-width:600px){.admin-header{flex-direction:column;gap:10px;align-items:flex-start;padding:14px 16px}.tab-panel-header{flex-direction:column;align-items:flex-start;gap:12px}.admin-table{font-size:.8rem}.admin-table th,.admin-table td{padding:8px 10px}}.btn-view{background:none;border:1px solid #d1d5db;border-radius:6px;padding:4px 8px;cursor:pointer;font-size:1rem;line-height:1;transition:background .15s}.btn-view:hover{background:#f3f4f6}.detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.detail-dialog{background:#fff;border-radius:12px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003;margin:16px}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 12px;border-bottom:1px solid #e5e7eb}.detail-header h3{margin:0;font-size:1.15rem;font-weight:700;color:#1a1a1a}.detail-close{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0 4px;line-height:1}.detail-close:hover{color:#333}.detail-body{padding:16px 24px 24px}.detail-row{display:flex;padding:10px 0;border-bottom:1px solid #f3f4f6;gap:12px}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.85rem;font-weight:600;color:#555;min-width:100px;flex-shrink:0}.detail-value{font-size:.9rem;color:#1a1a1a;word-break:break-all}.detail-mono{font-family:monospace;font-size:.82rem}.row-clickable{cursor:pointer}.row-clickable:hover{background:#eef2ff}.row-deactivated td{opacity:.5}.detail-dialog-wide{max-width:700px}.detail-section-title{margin:20px 0 8px;font-size:1rem;font-weight:700;color:#333;border-top:1px solid #e5e7eb;padding-top:16px}.admin-table-compact{font-size:.85rem}.admin-table-compact th,.admin-table-compact td{padding:6px 10px}.app{width:100%;min-height:100vh}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;color:#666;font-size:18px}
