@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Noto+Sans:wght@400;500;600;700&display=swap";:root{--pink-50: #fdf2f8;--pink-100: #fce7f3;--pink-200: #fbcfe8;--pink-300: #f9a8d4;--pink-400: #f472b6;--pink-500: #ec4899;--pink-600: #db2777;--pink-700: #be185d;--pink-800: #9d174d;--pink-900: #831843;--color-pink-50: var(--pink-50);--color-pink-100: var(--pink-100);--color-pink-200: var(--pink-200);--color-pink-300: var(--pink-300);--color-pink-400: var(--pink-400);--color-pink-500: var(--pink-500);--color-pink-600: var(--pink-600);--color-pink-700: var(--pink-700);--color-pink-800: var(--pink-800);--color-pink-900: var(--pink-900);--purple-400: #c084fc;--purple-500: #a855f7;--purple-600: #9333ea;--coral-400: #fb923c;--coral-500: #f97316;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e5e5e5;--gray-300: #d4d4d4;--gray-400: #a3a3a3;--gray-500: #737373;--gray-600: #525252;--gray-700: #404040;--gray-800: #262626;--gray-900: #171717;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--gradient-primary: linear-gradient(135deg, #ec4899 0%, #a855f7 100%);--gradient-warm: linear-gradient(135deg, #f472b6 0%, #fb923c 100%);--gradient-cool: linear-gradient(135deg, #a855f7 0%, #3b82f6 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.1) 0%, rgba(255,255,255,.05) 100%);--bg-primary: #ffffff;--bg-secondary: #fdf2f8;--bg-tertiary: #fce7f3;--bg-glass: rgba(255, 255, 255, .85);--bg-glass-border: rgba(236, 72, 153, .15);--bg-overlay: rgba(255, 255, 255, .6);--text-primary: #171717;--text-secondary:#525252;--text-muted: #a3a3a3;--text-inverse: #ffffff;--border-color: #f3d5e5;--border-subtle: #fce7f3;--font-sans: "Inter", "Noto Sans", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(236, 72, 153, .06);--shadow-md: 0 4px 12px rgba(236, 72, 153, .1);--shadow-lg: 0 12px 32px rgba(236, 72, 153, .12);--shadow-glow: 0 0 24px rgba(236, 72, 153, .25);--shadow-glow-strong: 0 0 40px rgba(236, 72, 153, .4);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width: 64px;--chat-width: clamp(280px, 24vw, 360px);--toolbar-height: 72px;--header-height: 56px;--toolbar-safe-bottom: max(16px, env(safe-area-inset-bottom, 16px));--thumb-strip-height: clamp(100px, 15vh, 180px);--mobile-header-height: 56px;--mobile-toolbar-height: 60px;--mobile-thumbstrip-height: 80px;--mobile-bottom-sheet-handle: 32px}[data-theme=dark]{--bg-primary: #0f0f0f;--bg-secondary: #13111c;--bg-tertiary: #1a1625;--bg-glass: rgba(15, 15, 15, .85);--bg-glass-border: rgba(236, 72, 153, .22);--bg-overlay: rgba(0, 0, 0, .6);--text-primary: #f5f5f5;--text-secondary:#a3a3a3;--text-muted: #737373;--text-inverse: #0f0f0f;--border-color: #2a2535;--border-subtle: #1e1a2a;--color-pink-300: #f9a8d4;--color-pink-400: #f472b6;--color-pink-500: #ec4899;--gradient-primary: linear-gradient(135deg, #f472b6 0%, #c084fc 100%);--gradient-warm: linear-gradient(135deg, #f472b6 0%, #fb923c 100%);--gradient-cool: linear-gradient(135deg, #c084fc 0%, #60a5fa 100%);--gradient-glass: linear-gradient(135deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.02) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .6);--shadow-glow: 0 0 30px rgba(236, 72, 153, .18);--shadow-glow-strong: 0 0 48px rgba(236, 72, 153, .35)}[data-theme=dark] body{background:var(--bg-primary);color:var(--text-primary)}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] input::placeholder,[data-theme=dark] textarea::placeholder{color:var(--text-muted)}[data-theme=dark] kbd{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-primary);line-height:1.6;-webkit-font-smoothing:antialiased;transition:background var(--transition-normal),color var(--transition-normal)}img,video{max-width:100%;display:block}button{cursor:pointer;font:inherit}a{color:inherit;text-decoration:none}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 8px #ec48994d}50%{box-shadow:0 0 24px #ec489999}}@keyframes floatEmoji{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-120px) scale(1.4)}}@keyframes pinkPulse{0%{background-position:-200px 0}to{background-position:calc(100% + 200px) 0}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--pink-100) 25%,var(--pink-200) 50%,var(--pink-100) 75%);background-size:400px 100%;animation:pinkPulse 1.5s ease-in-out infinite;border-radius:var(--radius-md)}[data-theme=dark] .skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,#2a2040 50%,var(--bg-tertiary) 75%);background-size:400px 100%}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:min(360px,calc(100vw - 2rem));pointer-events:none}.toast{pointer-events:auto;display:flex;align-items:flex-start;gap:.6rem;padding:.75rem .9rem;border-radius:var(--radius-md, 12px);border-left:3px solid var(--pink-400, #ec4899);font-size:.92rem;line-height:1.35;color:var(--text-primary, #1a1a1a);background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);cursor:pointer;animation:slideInRight .22s ease-out;box-shadow:var(--shadow-lg, 0 12px 32px rgba(0, 0, 0, .18))}.toast-success{border-left-color:#10b981}.toast-warning{border-left-color:#f59e0b}.toast-error{border-left-color:#ef4444}.toast-info{border-left-color:var(--pink-400, #ec4899)}.toast-icon{flex-shrink:0;width:1.25rem;height:1.25rem;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.toast-success .toast-icon{color:#10b981}.toast-warning .toast-icon{color:#f59e0b}.toast-error .toast-icon{color:#ef4444}.toast-info .toast-icon{color:var(--pink-500, #db2777)}.toast-message{flex:1;word-break:break-word}.toast-close{flex-shrink:0;background:transparent;border:0;color:var(--text-secondary, #777);font-size:1.1rem;line-height:1;cursor:pointer;padding:0 .25rem}.toast-close:hover{color:var(--text-primary, #111)}.glass{background:var(--bg-glass);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--bg-glass-border);box-shadow:var(--shadow-md)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--pink-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--pink-400)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--pink-700)}::selection{background:var(--pink-200);color:var(--pink-900)}[data-theme=dark] ::selection{background:var(--pink-800);color:var(--pink-100)}:focus-visible{outline:2px solid var(--pink-400);outline-offset:2px;border-radius:var(--radius-sm)}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn .18s ease-out}.modal-box,.modal-content{position:relative;width:100%;max-width:480px;max-height:calc(100vh - 32px);display:flex;flex-direction:column;border-radius:var(--radius-xl, 16px);background:var(--bg-primary);color:var(--text-primary);box-shadow:0 16px 48px #00000073;overflow:hidden;animation:slideUp .22s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border-subtle, rgba(255, 255, 255, .08));flex-shrink:0}.modal-header h2,.modal-header h3{margin:0;font-size:1.05rem;font-weight:700}.modal-close{background:transparent;border:none;color:inherit;cursor:pointer;font-size:1.2rem;line-height:1;padding:6px 10px;border-radius:var(--radius-sm, 6px);opacity:.7;transition:opacity .15s,background .15s}.modal-close:hover{opacity:1;background:#ffffff0f}.modal-body{padding:18px;overflow-y:auto;flex:1;min-height:0}.modal-footer,.modal-actions{display:flex;gap:8px;justify-content:flex-end;padding:12px 18px;border-top:1px solid var(--border-subtle, rgba(255, 255, 255, .08));flex-shrink:0}@media(max-width:640px){.modal-overlay{padding:0;align-items:flex-end}.modal-box,.modal-content{max-width:100%!important;width:100%;max-height:92vh;border-radius:16px 16px 0 0;animation:slideUpSheet .25s ease-out}.modal-header{padding:12px 16px}.modal-body{padding:14px 16px}.modal-footer,.modal-actions{padding:10px 16px calc(14px + env(safe-area-inset-bottom,0px))}.modal-footer .btn,.modal-actions .btn{flex:1;min-width:0}.modal-body input:not([type=checkbox]):not([type=radio]),.modal-body select,.modal-body textarea,.modal-content input:not([type=checkbox]):not([type=radio]),.modal-content select,.modal-content textarea{min-height:44px;font-size:16px}.modal-body .btn,.modal-content .btn,.modal-footer .btn,.modal-actions .btn{min-height:44px}.modal-body input[type=checkbox],.modal-body input[type=radio],.modal-content input[type=checkbox],.modal-content input[type=radio]{width:20px;height:20px}}@media(max-width:640px){.modal-box:before,.modal-content:before{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:36px;height:4px;border-radius:2px;background:#ffffff40;pointer-events:none;z-index:2}.modal-header{padding-top:18px}}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);transition:background var(--transition-normal)}.header{height:var(--header-height);padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;border-bottom:1px solid var(--border-subtle)}.header-left{display:flex;align-items:center;gap:var(--space-md)}.header-right{display:flex;align-items:center;gap:var(--space-sm)}.user-menu{display:flex;align-items:center;gap:var(--space-sm);padding:4px 12px 4px 4px;background:var(--bg-tertiary);border-radius:var(--radius-full)}.user-avatar-sm{width:28px;height:28px;border-radius:var(--radius-full);object-fit:cover}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo{font-size:1.5rem;font-weight:800;letter-spacing:-.03em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.9rem;transition:all var(--transition-fast);position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff0;transition:background var(--transition-fast)}.btn:hover:after{background:#ffffff1a}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-sm{padding:6px 14px;font-size:.82rem}.btn-icon{width:40px;height:40px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;transition:all var(--transition-fast)}.btn-icon:hover{background:var(--bg-tertiary);border-color:var(--pink-300)}.input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-primary);color:var(--text-primary);font-size:.95rem;transition:all var(--transition-fast);outline:none}.input:focus{border-color:var(--pink-400);box-shadow:0 0 0 3px #ec489926}.input::placeholder{color:var(--text-muted)}.lang-switcher{display:flex;gap:2px;padding:3px;background:var(--bg-secondary);border-radius:var(--radius-md)}.lang-btn{padding:4px 10px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:500;transition:all var(--transition-fast)}.lang-btn.active{background:var(--gradient-primary);color:#fff}.lang-btn:hover:not(.active){background:var(--bg-tertiary)}.main-content{flex:1;max-width:960px;margin:0 auto;padding:var(--space-2xl) var(--space-lg);width:100%}.hero{text-align:center;padding:var(--space-3xl) 0 var(--space-2xl);animation:slideUp .6s ease-out}.hero-title{font-size:2.2rem;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.3}.hero-subtitle{margin-top:var(--space-md);font-size:1.1rem;color:var(--text-secondary)}.create-room-section{margin-bottom:var(--space-2xl)}.create-room-card{padding:var(--space-xl);border-radius:var(--radius-xl);animation:slideUp .6s ease-out .1s both}.create-room-card h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-md)}.create-room-form{display:flex;gap:var(--space-md)}.create-room-form .input{flex:1}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-lg)}.room-card{padding:var(--space-lg);border-radius:var(--radius-xl);display:flex;flex-direction:column;gap:var(--space-md);transition:all var(--transition-normal);animation:scaleIn .4s ease-out}.room-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.room-card-header{display:flex;justify-content:space-between;align-items:flex-start}.room-card-header h4{font-size:1rem;font-weight:700;color:var(--text-primary)}.room-code{font-family:var(--font-mono);font-size:.75rem;padding:2px 8px;background:var(--pink-100);color:var(--pink-700);border-radius:var(--radius-sm);font-weight:600}[data-theme=dark] .room-code{background:var(--pink-900);color:var(--pink-300)}.participants-count{font-size:.85rem;color:var(--text-secondary)}.empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted);font-size:1rem;animation:fadeIn .5s ease}.mobile-menu-toggle{display:none;background:transparent;border:1px solid var(--border-color, rgba(255, 255, 255, .15));border-radius:var(--radius-md, 8px);padding:6px 12px;font-size:1.25rem;line-height:1;color:var(--text-primary, inherit);cursor:pointer;transition:background var(--transition-fast)}.mobile-menu-toggle:hover{background:var(--bg-tertiary, rgba(255, 255, 255, .06))}.mobile-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;animation:fadeIn .15s ease}.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(85vw,320px);background:var(--bg-primary, #1a1a2e);border-left:1px solid var(--border-color, rgba(255, 255, 255, .1));padding:16px;overflow-y:auto;animation:slideInRight .2s ease;display:flex;flex-direction:column;gap:8px;box-shadow:-8px 0 32px #0000004d}.mobile-drawer-close{align-self:flex-end;background:transparent;border:none;color:var(--text-primary, inherit);font-size:1.4rem;cursor:pointer;padding:4px 10px;border-radius:var(--radius-sm, 6px)}.mobile-drawer-close:hover{background:var(--bg-tertiary, rgba(255, 255, 255, .06))}.mobile-drawer-section{display:flex;flex-direction:column;gap:4px}.mobile-drawer-divider{border-top:1px solid var(--border-color, rgba(255, 255, 255, .1));margin-top:12px;padding-top:12px}.mobile-menu-item{display:flex;align-items:center;gap:10px;background:transparent;border:none;color:var(--text-primary, inherit);font-size:.95rem;text-align:left;padding:12px 14px;border-radius:10px;cursor:pointer;width:100%;transition:background var(--transition-fast)}.mobile-menu-item:hover,.mobile-menu-item:active{background:var(--bg-tertiary, rgba(255, 255, 255, .06))}.mobile-menu-primary{background:var(--gradient-primary);color:#fff;font-weight:600;margin-top:8px}.mobile-menu-danger{color:#f87171}.mobile-drawer-langs{display:flex;gap:4px;margin-bottom:8px}.mobile-lang-btn{flex:1;padding:10px;border-radius:8px;border:1px solid var(--border-color, rgba(255, 255, 255, .15));background:transparent;color:var(--text-primary, inherit);font-weight:600;cursor:pointer;font-size:.85rem;transition:all var(--transition-fast)}.mobile-lang-btn.active{background:var(--gradient-primary);color:#fff;border-color:transparent}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@media(max-width:768px){.header{padding:8px 12px}.logo{font-size:1.15rem}.header-right>.btn,.header-right>.lang-switcher{display:none}.user-menu{padding:2px 4px;background:transparent}.user-menu .user-name,.user-menu .btn{display:none}.mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center}.hero{padding:var(--space-xl) 0 var(--space-lg)}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.9rem;margin-top:var(--space-sm)}.create-room-form{flex-direction:column;gap:var(--space-sm)}.create-room-form .input,.create-room-form .btn{width:100%}.create-room-card,.join-card{padding:var(--space-lg)}.main-content{padding:var(--space-lg) var(--space-md)}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-md)}}@media(max-width:480px){.hero{padding:var(--space-lg) 0 var(--space-md)}.hero-title{font-size:1.35rem}.hero-subtitle{font-size:.85rem}.rooms-grid{grid-template-columns:1fr;gap:12px}.main-content{padding:var(--space-md) var(--space-sm)}.create-room-card,.join-card{padding:var(--space-md)}.create-room-card h3,.join-card h3{font-size:1rem}}.recordings-error{color:#dc143c}.recordings-page-shell{padding:24px;max-width:1100px;margin:0 auto;min-height:100vh}.recordings-page-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.recordings-page-title{margin:0;font-size:1.5rem;font-weight:700}.recordings-room-picker h3{margin:0 0 12px;font-size:1.05rem;font-weight:600}.recordings-room-list{list-style:none;padding:0;margin:0}.recordings-room-row{padding:10px 0;border-bottom:1px solid var(--bg-glass-border, rgba(255, 255, 255, .08))}.recordings-room-btn{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;text-align:left;padding:4px 0}.recordings-room-btn:hover{opacity:.9}.recordings-empty{padding:40px;text-align:center;border-radius:16px;margin-top:24px}.recordings-empty-icon{font-size:4rem;display:block;margin-bottom:16px}.recordings-empty-title{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0}.recordings-empty-sub{font-size:.9rem;color:var(--text-secondary);margin-top:8px}.recordings-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.recording-card-inner{padding:14px;border-radius:var(--radius-lg, 12px)}.recording-card-icon{font-size:2.4rem;text-align:center}.recording-card-id{font-weight:600;margin-top:8px;word-break:break-all;font-size:.95rem}.recording-card-meta{font-size:.85em;opacity:.88;margin-top:8px;line-height:1.45}.recording-card-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.recordings-player-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e0;z-index:5000;display:flex;align-items:center;justify-content:center}.recordings-player-box{position:relative;width:90%;max-width:1200px;height:85vh;background:#000;border-radius:12px;overflow:hidden}.recordings-player-close{position:absolute;top:10px;right:10px;z-index:2;background:#000000a6;color:#fff;border:none;width:36px;height:36px;border-radius:18px;cursor:pointer;font-size:1.1rem}.recordings-player-video{width:100%;height:100%;object-fit:contain;display:block}.recordings-player-video-wrap{position:relative;flex:1 1 auto;min-height:0;background:#000}.recordings-player-video-wrap .recordings-player-video{width:100%;height:100%}.wb-canvas-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:2}.wb-canvas-hidden{display:none}.wb-controls{display:flex;align-items:center;gap:8px;padding:6px 10px;font-size:.85rem;color:#ffffffb3;background:#00000073;flex-shrink:0}.wb-timeline{position:relative;height:16px;background:#ffffff1a;border-radius:8px;margin:0 10px 8px;overflow:visible;flex-shrink:0}.wb-timeline-marker{position:absolute;width:4px;height:16px;background:#f59e0b;border-radius:2px;cursor:pointer;transform:translate(-50%);top:0;transition:transform .1s,background .1s}.wb-timeline-marker:hover{background:#fbbf24;transform:translate(-50%) scaleY(1.3)}.recordings-player-box{display:flex;flex-direction:column}@media(max-width:640px){.recordings-page-shell{padding:16px 10px}.recordings-page-title{font-size:1.2rem}.recordings-grid{grid-template-columns:1fr;gap:10px}.recording-card-inner{padding:12px}.recording-card-icon{font-size:2rem}.recording-card-actions{flex-wrap:wrap;gap:6px}.recording-card-actions .btn,.recording-card-actions .btn.btn-sm,.recording-card-actions a.btn{flex:1 1 calc(50% - 3px);min-width:0;font-size:.78rem;padding:6px 8px;text-align:center}.recordings-player-box{width:100%!important;max-width:100%!important;height:100vh!important;border-radius:0!important}.recordings-player-close{width:40px;height:40px;border-radius:20px;top:8px;right:8px}.wb-controls{flex-wrap:wrap;font-size:.78rem}}.usage-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.usage-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.usage-header h1{margin:0;font-size:1.1rem}.usage-main{flex:1;padding:var(--space-lg);max-width:520px;margin:0 auto;width:100%}.usage-hint{color:var(--text-secondary);font-size:.9rem}.usage-card{padding:var(--space-lg);border-radius:var(--radius-xl)}.usage-error{border:1px solid var(--color-error);color:var(--color-error)}.usage-dl{margin:0;display:grid;grid-template-columns:1fr auto;gap:var(--space-sm) var(--space-lg);font-size:.88rem}.usage-dl dt{color:var(--text-secondary);font-weight:600}.usage-dl dd{margin:0;text-align:right;font-weight:600}.usage-section-title{margin:0 0 var(--space-md);font-size:1rem}.usage-profile-card{margin-top:var(--space-md)}.usage-field{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--space-md);font-size:.85rem;color:var(--text-secondary)}.usage-actions-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-md)}.usage-upgrade-cta{display:flex;align-items:flex-start;gap:20px;padding:24px;border-radius:16px;margin-top:24px;border:1px solid rgba(244,114,182,.3);background:linear-gradient(135deg,#f472b60d,#c084fc0d)}.usage-upgrade-icon{font-size:2.5rem;flex-shrink:0}.usage-upgrade-content{flex:1}.usage-upgrade-content h3{margin:0 0 6px;color:#f472b6}.usage-upgrade-content p{margin:0 0 10px;opacity:.8;font-size:.9rem}.usage-upgrade-features{list-style:none;padding:0;margin:0;font-size:.85rem}.usage-upgrade-features li{padding:2px 0}@media(max-width:640px){.usage-header{padding:var(--space-sm) var(--space-md)}.usage-header h1{font-size:1rem}.usage-main{padding:var(--space-md);max-width:100%}.usage-card{padding:var(--space-md)}.usage-section-title{font-size:.95rem}.usage-dl{gap:6px var(--space-md);font-size:.82rem}.usage-upgrade-cta{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.usage-upgrade-icon{font-size:2rem;text-align:center}.usage-upgrade-content h3{text-align:center;font-size:1rem}.usage-upgrade-content p{font-size:.85rem}.usage-upgrade-cta .btn{width:100%}.usage-actions-row .btn{flex:1 1 100%}}@media(max-width:380px){.usage-dl{grid-template-columns:1fr;gap:2px}.usage-dl dd{text-align:left;margin-bottom:6px;opacity:.95}}.admin-stats{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.admin-stat{padding:12px 20px;border-radius:8px;text-align:center;min-width:120px;flex:1 1 120px}.admin-stat-value{font-size:1.5rem;font-weight:700}.admin-stat-label{font-size:.8rem;opacity:.7}.admin-cards{display:none;flex-direction:column;gap:8px}.admin-card{padding:12px 14px;border-radius:10px}.admin-card-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}.admin-card-time{font-size:.72rem;opacity:.65;white-space:nowrap}.admin-card-body{font-size:.85rem}.admin-card-body>div:first-child{font-weight:600}.admin-card-secondary{opacity:.75;font-size:.8rem;margin-top:2px}.admin-card-status{margin-top:6px;font-size:.72rem;opacity:.7}.admin-rooms-cards{display:none;flex-direction:column;gap:8px}.admin-room-card{padding:12px 14px;border-radius:10px}.admin-room-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}.admin-room-meta{font-size:.85rem;display:flex;flex-direction:column;gap:4px}.admin-room-desc{opacity:.7;font-size:.8rem}.admin-room-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.admin-room-actions .btn{flex:1 1 auto;min-width:0}.admin-room-edit{display:flex;flex-direction:column;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-subtle, rgba(255,255,255,.08))}.admin-room-edit .input{width:100%}.admin-room-edit-actions{display:flex;gap:8px}.admin-room-edit-actions .btn{flex:1}.admin-desktop-only{display:block}.admin-mobile-only{display:none}@media(max-width:640px){.admin-desktop-only{display:none!important}.admin-mobile-only{display:flex!important;flex-direction:column;gap:8px}.admin-cards,.admin-rooms-cards{display:flex}.admin-stats{gap:8px}.admin-stat{padding:8px 6px;min-width:0;flex:1 1 calc(33% - 8px)}.admin-stat-value{font-size:1.1rem}.admin-stat-label{font-size:.7rem}}@media(max-width:380px){.admin-stat{flex:1 1 100%}}.admin-edges{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.admin-edge-card{padding:14px;border-radius:12px;border-left:3px solid #3b82f6}.admin-edge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.admin-edge-meta{display:flex;flex-direction:column;gap:4px;font-size:.82rem;margin-bottom:8px}.admin-edge-meta span{opacity:.6;margin-right:4px}.admin-edge-meta code{font-size:.75rem;background:#ffffff0d;padding:1px 5px;border-radius:3px}.admin-edge-bar{height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.admin-edge-bar-fill{height:100%;background:linear-gradient(90deg,#22c55e,#f59e0b 70%,#ef4444);transition:width .3s}.status-active{background:#22c55e33;color:#86efac}.status-stale{background:#f59e0b33;color:#fbbf24}.attendance-page{max-width:1200px;margin:0 auto;padding:24px 16px}.attendance-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.attendance-header h1{margin:0;font-size:1.5rem}.attendance-room-picker h3{margin:0 0 12px;opacity:.8}.attendance-room-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.attendance-room-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:var(--bg-glass);border:1px solid var(--bg-glass-border);border-radius:12px;color:inherit;cursor:pointer;text-align:left;transition:transform .15s,border-color .15s}.attendance-room-btn:hover{transform:translateY(-2px);border-color:var(--pink-400)}.attendance-room-icon{font-size:1.5rem}.attendance-room-name{font-weight:600}.attendance-room-id{font-size:.75rem;opacity:.5}.attendance-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.stat-card{padding:16px;border-radius:12px;text-align:center}.stat-icon{font-size:1.6rem;margin-bottom:4px}.stat-value{font-size:1.8rem;font-weight:700;color:var(--pink-500, #f472b6)}.stat-label{font-size:.85rem;opacity:.7}.attendance-toolbar{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.attendance-table-wrap{border-radius:12px;overflow-x:auto;padding:0}.attendance-table{width:100%;border-collapse:collapse;font-size:.875rem}.attendance-table th,.attendance-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--bg-glass-border);white-space:nowrap}.attendance-table th{background:#ffffff0a;font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;opacity:.7}.attendance-table tr.row-active{background:#22c55e0d}.attendance-table tr:hover{background:#ffffff08}.status-badge{display:inline-block;padding:3px 9px;border-radius:999px;color:#fff;font-size:.72rem;font-weight:600;letter-spacing:.02em}.attendance-empty{padding:40px;border-radius:12px;text-align:center;opacity:.7}.attendance-empty p{margin:8px 0}.attendance-footer{margin-top:12px;font-size:.8rem;opacity:.5;text-align:right}@media(max-width:768px){.attendance-stats{grid-template-columns:repeat(2,1fr)}.attendance-table{font-size:.78rem}.attendance-table th,.attendance-table td{padding:8px}}.attendance-cards{display:none;flex-direction:column;gap:8px}.attendance-card{padding:12px 14px;border-radius:10px;border-left:3px solid transparent}.attendance-card.card-active{border-left-color:#22c55e}.attendance-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.attendance-card-meta{display:flex;flex-direction:column;gap:4px;font-size:.85rem}.attendance-card-meta>div{display:flex;justify-content:space-between;gap:8px}.attendance-card-meta span{opacity:.6}.attendance-mobile-only{display:none}@media(max-width:640px){.attendance-page{padding:16px 10px}.attendance-desktop-only{display:none!important}.attendance-mobile-only{display:flex!important;flex-direction:column;gap:8px}.attendance-stats{grid-template-columns:repeat(2,1fr);gap:8px}.stat-card{padding:10px}.stat-value{font-size:1.3rem}.stat-label{font-size:.75rem}.stat-icon{font-size:1.2rem}.attendance-toolbar{flex-direction:column;align-items:stretch}.attendance-toolbar .input,.attendance-toolbar select{max-width:none!important;width:100%!important}.attendance-toolbar .btn{flex:1}.attendance-room-list{grid-template-columns:1fr}}@media(max-width:380px){.attendance-stats{grid-template-columns:1fr}}.auth-modal{position:relative;width:100%;max-width:400px;padding:var(--space-xl);border-radius:var(--radius-xl);box-shadow:0 20px 40px #00000026;overflow-y:auto;-webkit-overflow-scrolling:touch}.auth-checkbox{width:18px;height:18px;accent-color:var(--pink-500)}@media(max-width:640px){.auth-modal{max-width:100%!important;padding:calc(var(--space-lg) + 8px) var(--space-md) calc(var(--space-md) + env(safe-area-inset-bottom,0px));border-radius:16px 16px 0 0;max-height:92vh}.auth-header h2{font-size:1.25rem}.auth-submit-btn{width:100%;height:48px}.auth-modal .input{font-size:16px;min-height:44px}.auth-checkbox{width:22px;height:22px}}.btn-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:1.2rem;color:var(--text-secondary);cursor:pointer;transition:transform var(--transition-fast)}.btn-close:hover{transform:scale(1.1);color:var(--text-primary)}.auth-header{text-align:center;margin-bottom:var(--space-lg)}.auth-header h2{font-size:1.5rem;font-weight:800;margin-bottom:var(--space-xs);background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-header p{color:var(--text-secondary);font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-left:4px}.auth-submit-btn{margin-top:var(--space-md);height:48px;font-size:1rem}.auth-footer{margin-top:var(--space-lg);text-align:center;font-size:.9rem;color:var(--text-secondary)}.btn-link{background:transparent;border:none;color:var(--pink-500);font-weight:600;cursor:pointer}.btn-link:hover{text-decoration:underline}.alert{padding:12px;border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:.9rem;text-align:center}.alert-error{background:#ef44441a;color:var(--color-error);border:1px solid rgba(239,68,68,.2)}.field-error{font-size:.78rem;color:var(--color-error, #ef4444);margin-top:2px;margin-left:4px}.input.input-error{border-color:var(--color-error, #ef4444);outline-color:var(--color-error, #ef4444)}@keyframes spin{to{transform:rotate(360deg)}}
