:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f7;--bg-tertiary: #e8e8ed;--text-primary: #1d1d1f;--text-secondary: #86868b;--text-tertiary: #6e6e73;--accent-blue: #0066cc;--accent-blue-hover: #004499;--border-light: #d2d2d7;--border-subtle: #e5e5e5;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 12px 24px rgba(0, 0, 0, .12);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 18px;--radius-full: 9999px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:linear-gradient(135deg,#fef5e7,#ffe4f1,#e8f4fd,#fff9e6,#f0e7fd,#e6f9f5,#fff0e6 90%,#f5e6ff);background-attachment:fixed;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;min-height:100vh;min-height:100dvh}.home-page{position:relative;background-image:url(/homepage-background.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;min-height:100vh;background-color:transparent}.home-page:before{content:"";position:fixed;inset:0;background-image:url(/homepage-background.png);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;z-index:-1;pointer-events:none}.home-page>*{position:relative;z-index:1}.text-h1{font-size:2rem;font-weight:600;letter-spacing:-.003em;line-height:1.2}.text-h2{font-size:1.75rem;font-weight:600;letter-spacing:-.003em;line-height:1.2}.text-h3{font-size:1.5rem;font-weight:600;letter-spacing:-.003em;line-height:1.2}@media (min-width: 960px){.text-h1{font-size:3rem}.text-h2{font-size:2.5rem}.text-h3{font-size:2rem}}.text-headline{font-size:1.25rem;font-weight:600;letter-spacing:.009em}.text-body{font-size:1rem;font-weight:400;letter-spacing:-.022em}.text-caption{font-size:.875rem;font-weight:400;letter-spacing:-.016em}.text-small{font-size:.75rem;font-weight:500;letter-spacing:-.01em}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.p-2{padding:.5rem}.p-4{padding:1rem}.w-full{width:100%}.h-full{height:100%}.h-screen{height:100vh;height:100dvh}.min-h-screen{min-height:100vh}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:var(--radius-full);font-weight:500;cursor:pointer;transition:all .2s ease;border:none;gap:.5rem}.btn-primary{background-color:#000;color:#fff}.btn-primary:hover{background-color:#333}.btn-secondary{background-color:var(--bg-secondary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--bg-tertiary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background-color:#ffffff80}.btn-icon{padding:.5rem;border-radius:var(--radius-md);color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:color .2s,background-color .2s}.btn-icon:hover{color:var(--text-primary);background-color:var(--bg-secondary)}.navbar{position:sticky;top:0;z-index:50;background-color:#fffffff2;backdrop-filter:blur(10px);border-bottom:1px solid var(--border-subtle);height:56px;display:flex;align-items:center;padding:0 1rem}@media (min-width: 960px){.navbar{height:64px;padding:0 1.5rem}}.navbar-content{max-width:1200px;margin:0 auto;width:100%;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.logo-container{display:flex;align-items:center;gap:.5rem}.logo-icon{height:24px;width:auto;display:flex;align-items:center}@media (min-width: 610px){.logo-icon{height:32px}}.hero{padding:2rem 1rem 1.5rem;text-align:center;max-width:1200px;margin:0 auto}@media (min-width: 960px){.hero{padding:3rem 1.5rem 2rem}}.hero h1{margin-bottom:.75rem;color:var(--text-primary)}.hero p{color:var(--text-secondary);max-width:600px;margin:0 auto 1.5rem}.main-container{max-width:900px;margin:0 auto;padding:0 1rem 2rem}@media (min-width: 640px){.main-container{padding:0 1.5rem 3rem}}.card{background-color:#fffffff2;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000014;border:1px solid rgba(255,255,255,.6);overflow:hidden;backdrop-filter:blur(10px)}.toolbar{padding:1rem;border-bottom:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px){.toolbar{flex-direction:row;justify-content:space-between;align-items:center}}.search-input-wrapper{position:relative}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.search-input{padding:.5rem 1rem .5rem 2.25rem;background-color:var(--bg-secondary);border:none;border-radius:var(--radius-md);font-size:14px;width:100%;transition:box-shadow .2s}.search-input:focus{outline:none;box-shadow:0 0 0 2px var(--accent-blue)}.room-list-container{padding:1.5rem;min-height:400px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:256px;text-align:center;color:var(--text-secondary)}.empty-icon{width:64px;height:64px;background-color:var(--bg-secondary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;opacity:.5}.whiteboard-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;background-color:var(--bg-secondary);overflow:hidden;position:relative}.top-bar{height:60px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;box-shadow:var(--shadow-sm);z-index:9000;position:relative}@media (min-width: 640px){.top-bar{padding:0 1.5rem}}.floating-sidebar{position:absolute;left:50%;bottom:1.5rem;top:auto;transform:translate(-50%);background-color:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:row;padding:.5rem;gap:.5rem;z-index:40;width:auto;max-width:calc(100% - 3rem);overflow-x:auto;scrollbar-width:none}.floating-sidebar::-webkit-scrollbar{display:none}@media (min-width: 960px){.floating-sidebar{left:1.5rem;top:50%;bottom:auto;transform:translateY(-50%);flex-direction:column;width:56px;max-width:none;overflow-x:visible}}.tool-btn--danger{color:#dc2626}.tool-btn--danger:hover{background-color:#fee2e2;color:#b91c1c}.color-picker-trigger{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-subtle);cursor:pointer;margin:.5rem auto 0;transition:transform .2s}.color-picker-trigger:hover{transform:scale(1.1)}.canvas-container{flex:1;flex-shrink:0;position:relative;background-color:var(--bg-tertiary);overflow:hidden;display:flex;align-items:stretch;justify-content:stretch;width:100%;height:100%}.canvas-wrapper{position:relative;flex-shrink:0;background-color:#fff;cursor:crosshair;width:100%;height:100%}.whiteboard-canvas{display:block;width:100%;height:100%}.user-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;border:2px solid white;box-shadow:var(--shadow-sm)}.user-avatar-group{display:flex;align-items:center;margin-right:1rem}.user-avatar-group .user-avatar{margin-left:-8px}.user-avatar-group .user-avatar:first-child{margin-left:0}.hidden-sm{display:none}@media (min-width: 640px){.hidden-sm{display:block}}.text-center{text-align:center}.mx-auto{margin-left:auto;margin-right:auto}.w-16{width:4rem}.h-16{height:4rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:var(--shadow-sm)}.text-3xl{font-size:1.875rem}.flex-1{flex:1}.gap-6{gap:1.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.modal-overlay{position:fixed;inset:0;background-color:#0006;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease-out}.create-room-modal,.join-room-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;height:100%;max-width:none;max-height:none;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.16,1,.3,1);overflow:hidden}@media (min-width: 640px){.create-room-modal,.join-room-modal{width:90%;height:auto;max-width:600px;max-height:90vh;border-radius:var(--radius-lg)}.join-room-modal{max-width:480px}}.modal-header{padding:1.5rem;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.modal-header h2{font-size:1.25rem;font-weight:600;margin:0}.close-btn{background:transparent;border:none;font-size:1.25rem;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:50%;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.modal-form{display:flex;flex-direction:column;flex:1;overflow:hidden}.form-content{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.form-section h3{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-subtle);background-color:var(--bg-secondary);display:flex;justify-content:flex-end;gap:1rem}.form-field{display:flex;flex-direction:column;gap:.5rem}.field-label{font-size:.875rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.field-input input,.field-input textarea,.field-input select{width:100%;padding:.75rem;border:1px solid var(--border-light);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:all .2s;background-color:var(--bg-primary)}.field-input input:focus,.field-input textarea:focus,.field-input select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #0066cc1a}.field-error{font-size:.875rem;color:#ef4444;display:flex;align-items:center;gap:.25rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.btn--default{background-color:var(--bg-secondary);color:var(--text-primary)}.btn--default:hover{background-color:var(--border-light)}.btn--active{background-color:#000;color:#fff}.btn--active:hover{background-color:#333}.btn--danger{background-color:#fee2e2;color:#dc2626}.btn--danger:hover{background-color:#fecaca}.rooms-container.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.rooms-container.list{display:flex;flex-direction:column;gap:1rem}.room-card{background-color:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s ease;display:flex;flex-direction:column;height:100%}.room-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-light)}.room-thumbnail{height:140px;background-color:var(--bg-secondary);position:relative;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden}.room-thumbnail:before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--border-subtle) 1px,transparent 1px);background-size:20px 20px;opacity:.5}.room-privacy,.room-password{background-color:#ffffffe6;backdrop-filter:blur(4px);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;box-shadow:var(--shadow-sm)}.room-info{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.75rem}.room-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.room-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.room-description{font-size:.875rem;color:var(--text-secondary);margin:0;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.6em}.room-tags{display:flex;flex-wrap:wrap;gap:.5rem}.room-tag{background-color:var(--bg-secondary);color:var(--text-secondary);font-size:.75rem;padding:.125rem .5rem;border-radius:var(--radius-full)}.room-stats{display:flex;align-items:center;gap:1rem;font-size:.75rem;color:var(--text-tertiary);margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border-subtle)}.stat{display:flex;align-items:center;gap:.25rem}.occupancy-bar{width:40px;height:4px;background-color:var(--bg-secondary);border-radius:var(--radius-full);overflow:hidden;margin-left:.25rem}.occupancy-fill{height:100%;background-color:var(--accent-blue);border-radius:var(--radius-full)}.room-footer{padding:1rem;background-color:var(--bg-secondary);border-top:1px solid var(--border-subtle)}.user-setup-overlay{position:fixed;inset:0;background-color:#0006;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s ease-out}.user-setup-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:400px;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.user-setup-modal h2{font-size:1.5rem;font-weight:600;text-align:center;margin:0}.name-input-group input{flex:1;padding:.75rem;border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:1rem}.name-input-group input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #0066cc1a}.color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-top:.5rem}.form-actions{margin-top:1rem}.form-actions button{width:100%}.form-group{display:flex;flex-direction:column;gap:.5rem}.color-option{width:100%;aspect-ratio:1;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--text-primary);transform:scale(1.15)}.advanced-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;color:var(--text-secondary);font-weight:500;cursor:pointer;padding:.5rem 0;width:100%;transition:color .2s}.advanced-toggle:hover{color:var(--text-primary)}.advanced-toggle .arrow{display:inline-block;transition:transform .2s ease;font-size:.75rem}.advanced-toggle .arrow.up{transform:rotate(180deg)}.advanced-settings{animation:slideDown .3s ease-out;padding-top:1rem;border-top:1px solid var(--border-subtle);margin-top:.5rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}@media (min-width: 640px){.settings-grid{grid-template-columns:repeat(2,1fr)}}.setting-group{background-color:var(--bg-secondary);padding:1rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:1rem}.setting-group h4{font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.custom-size-inputs{display:flex;gap:1rem}.custom-size-inputs>*{flex:1}.color-picker-grid{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background-color:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-light);width:fit-content}.color-picker-grid .color-option{width:24px;height:24px;flex-shrink:0}.room-join-btn{width:100%;justify-content:center}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-label{font-size:.75rem;color:var(--text-secondary);font-weight:500}.info-value{font-size:.875rem;font-weight:500}.settings-grid{display:grid;grid-template-columns:1fr;gap:.75rem;margin-top:.5rem}@media (min-width: 480px){.settings-grid{grid-template-columns:1fr 1fr}}.setting-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.setting-status.enabled{color:#10b981}.setting-status.disabled{color:#ef4444}.home-page{min-height:100vh;color:var(--text-primary);font-family:var(--font-sans)}.navbar{display:flex;align-items:center;justify-content:center;padding:1rem;background-color:var(--bg-primary);border-bottom:1px solid var(--border-subtle)}.navbar-content{width:100%;max-width:1200px;display:flex;align-items:center;justify-content:space-between}.logo-container{display:flex;align-items:center;text-decoration:none;color:inherit;padding:.5rem;margin-left:-.5rem;flex-shrink:0;position:relative;z-index:10}.home-page .logo-container .logo-full{display:block!important;max-height:20px}@media (min-width: 610px){.home-page .logo-container .logo-full{max-height:32px}}.nav-actions,.recent-rooms-header{display:flex;align-items:center;gap:1rem}.rooms-count-badge{background-color:var(--bg-secondary);padding:.25rem .5rem;border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--text-secondary)}.toolbar-actions{display:flex;align-items:center;gap:.75rem}.search-icon-wrapper{display:flex;align-items:center}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#ef4444}.loading-spinner-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.spinner-icon{animation:spin 1s linear infinite;margin-bottom:1rem;opacity:.5}.empty-state-search{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.empty-icon-wrapper{color:var(--text-tertiary);margin-bottom:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.gap-4{gap:1rem}.gap-3{gap:.75rem}.icon-sm{width:1rem;height:1rem}.h-4{height:1rem}.icon-lg{width:2rem;height:2rem}.h-8{height:2rem}.user-setup-overlay{position:fixed;inset:0;background-color:#0006;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.user-setup-modal{background-color:var(--bg-primary);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:2rem;box-shadow:var(--shadow-lg)}.setup-header{text-align:center;margin-bottom:.5rem}.welcome-emoji{width:4rem;height:4rem;background-color:var(--bg-secondary);border-radius:1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:1.875rem;box-shadow:var(--shadow-sm)}.setup-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.field-label{font-weight:500;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.name-input-group{display:flex;gap:.5rem}.name-input{flex:1}.color-option{width:100%;aspect-ratio:1;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all .2s ease}.color-option.selected{border-color:var(--accent-blue);transform:scale(1.1);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--accent-blue)}.setup-footer{margin-top:1rem}.btn-full{width:100%;justify-content:center;padding:.75rem}.text-secondary{color:var(--text-secondary)}.text-sm{font-size:.875rem}.mt-2{margin-top:.5rem}.top-bar__left{display:flex;align-items:center;gap:.75rem}@media (min-width: 960px){.top-bar__left{gap:1.5rem}}.logo-container{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit;cursor:pointer;padding:.5rem;margin-left:-.5rem;flex-shrink:0;position:relative;z-index:10}.logo-icon{height:1.75rem;width:auto;display:flex;align-items:center}@media (min-width: 610px){.logo-icon{height:2.5rem}}.logo-icon img{height:100%;width:auto;object-fit:contain}.logo-full{display:none}@media (min-width: 610px){.logo-full{display:block}.logo-mobile{display:none}}.logo-text{display:none;font-size:1.5rem;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}@media (min-width: 1024px){.logo-text{display:block}}.room-info{display:flex;flex-direction:column;padding-left:.5rem;border-left:1px solid var(--border-subtle);height:1.5rem;justify-content:center}@media (min-width: 960px){.room-info{padding-left:1.5rem;height:60px}}.room-info__content{display:flex;flex-direction:column}.room-info__title{font-size:.75rem;font-weight:600;color:var(--text-primary);margin:0}.room-info__status{display:flex;align-items:center;gap:.375rem}.status-indicator{width:.375rem;height:.375rem;border-radius:50%}.status-indicator--connected{background-color:#22c55e}.status-indicator--offline{background-color:#ef4444}.status-text{font-size:.625rem;color:var(--text-tertiary)}.top-bar__center{display:flex;align-items:center;gap:.5rem;background-color:var(--bg-secondary);padding:.25rem;border-radius:var(--radius-full)}.action-btn{width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all .2s}.action-btn:hover{background-color:#fff;box-shadow:var(--shadow-sm);color:var(--text-primary)}.action-btn svg{width:1rem;height:1rem}.action-btn--danger{color:#ef4444}.action-btn--danger:hover{color:#dc2626}.action-divider{width:1px;height:1rem;background-color:var(--border-light);margin:0 .25rem}.top-bar__right{display:flex;align-items:center;gap:.5rem}@media (min-width: 960px){.top-bar__right{gap:1rem}}.hidden-mobile{display:none}@media (min-width: 640px){.hidden-mobile{display:inline}}.top-bar__actions{display:flex;align-items:center;gap:.5rem}.user-avatar--current{box-shadow:0 0 0 2px var(--bg-primary)}.tool-btn svg{width:1.25rem;height:1.25rem;pointer-events:none}.menu-toggle-btn{display:none;width:48px;height:48px;align-items:center;justify-content:center;background-color:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow-md);transition:all .2s;z-index:50;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.menu-toggle-btn:hover{background-color:var(--bg-secondary)}.sidebar-content{display:flex;flex-direction:inherit;align-items:center;gap:.5rem;position:relative;z-index:10}.tool-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all .2s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.tool-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.tool-btn.active{background-color:#eef2ff;color:var(--accent-blue)}.tool-divider{width:1px;height:24px;background-color:var(--border-subtle);margin:0 .25rem}.stroke-width-popover{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:10px;background-color:var(--bg-primary);padding:12px;border-radius:8px;box-shadow:0 8px 16px #00000026;z-index:2000;border:1px solid var(--border-subtle);min-width:200px;pointer-events:auto}.color-picker-container{position:relative}.color-picker-btn{display:flex;align-items:center;justify-content:center}.color-picker-trigger{width:24px;height:24px;border-radius:50%;border:2px solid var(--border-subtle);pointer-events:none}.color-picker-popover{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:10px;background-color:var(--bg-primary);padding:12px;border-radius:8px;box-shadow:0 8px 16px #00000026;z-index:2000;border:1px solid var(--border-subtle);min-width:180px;pointer-events:auto}.color-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:12px}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid rgba(0,0,0,.15);cursor:pointer;transition:transform .15s,box-shadow .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.color-swatch:hover,.color-swatch:active{transform:scale(1.15);box-shadow:0 2px 8px #0003}.color-swatch.active{box-shadow:0 0 0 3px var(--accent-blue)}.color-custom{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid var(--border-subtle);cursor:pointer}.color-custom span{font-size:12px;color:var(--text-secondary);white-space:nowrap}.color-custom-preview{position:relative;width:40px;height:28px;border-radius:4px;border:2px solid var(--border-subtle);cursor:pointer;overflow:hidden}.color-custom-input{position:absolute;inset:0;width:200%;height:200%;cursor:pointer;border:none;padding:0;opacity:0;-webkit-appearance:none;appearance:none}.color-custom-input-visible{width:48px;height:36px;padding:0;border:2px solid var(--border-subtle);border-radius:4px;cursor:pointer;-webkit-appearance:none;appearance:none}.color-custom-input-visible::-webkit-color-swatch-wrapper{padding:0}.color-custom-input-visible::-webkit-color-swatch{border:none;border-radius:2px}.disabled-warning{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background-color:#fee2e2;color:#dc2626;border-radius:var(--radius-md)}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 960px){.tool-divider{height:1px;width:100%;margin:.25rem 0}}@media (max-width: 610px),(max-height: 620px),(orientation: landscape) and (max-height: 620px){.floating-sidebar{position:fixed!important;left:1rem!important;right:auto!important;top:auto!important;bottom:1rem!important;transform:none!important;background:transparent!important;border:none!important;box-shadow:none!important;padding:0!important;z-index:10000!important;width:auto!important;height:auto!important;max-height:calc(100dvh - 2rem)!important;display:flex!important;flex-direction:column-reverse!important;overflow:visible!important;pointer-events:auto!important}}@media (max-width: 610px),(max-height: 620px){@media (min-width: 960px){.floating-sidebar{left:1.5rem!important}}}@media (max-width: 610px),(max-height: 620px){.menu-toggle-btn{display:flex;pointer-events:auto!important;box-shadow:var(--shadow-lg)}.sidebar-content{display:none;flex-direction:column;background-color:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:.5rem;margin-bottom:.5rem;box-shadow:var(--shadow-lg);z-index:10001;animation:fadeIn .2s ease-out;overflow-y:visible;width:56px;min-width:56px;align-items:center;touch-action:pan-y!important;-webkit-overflow-scrolling:touch}.floating-sidebar.menu-expanded .sidebar-content{display:flex;max-height:calc(100dvh - 140px)!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;scrollbar-width:thin;padding-right:.25rem;overscroll-behavior-y:contain}.sidebar-content *{flex-shrink:0!important;touch-action:pan-y!important}.sidebar-content::-webkit-scrollbar{width:4px;display:block}.sidebar-content::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}@media (max-height: 480px){.floating-sidebar.menu-expanded .sidebar-content{max-height:calc(100dvh - 100px)!important}}.stroke-width-popover,.color-picker-popover{position:fixed!important;bottom:1rem!important;left:calc(1rem + 68px)!important;top:auto!important;right:auto!important;transform:none!important;margin:0!important;z-index:10002!important;pointer-events:auto!important;animation:fadeIn .2s ease-out}.stroke-width-popover input,.color-picker-popover input{pointer-events:auto!important}.tool-divider{width:24px;height:1px;margin:.25rem 0}}.stroke-width-slider{display:flex;flex-direction:column;gap:8px;min-width:180px}.stroke-width-header{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary)}.stroke-width-value{font-weight:600;color:var(--text-primary)}.custom-slider-track{position:relative;width:100%;height:44px;display:flex;align-items:center;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.custom-slider-track:before{content:"";position:absolute;left:0;right:0;height:6px;background:var(--border-subtle);border-radius:3px}.custom-slider-fill{position:absolute;left:0;height:6px;background:var(--accent-blue);border-radius:3px;pointer-events:none}.custom-slider-thumb{position:absolute;width:24px;height:24px;background:var(--accent-blue);border-radius:50%;transform:translate(-50%);box-shadow:0 2px 6px #0000004d;pointer-events:none}.zoom-controls-overlay{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.25rem;background-color:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:.5rem;box-shadow:var(--shadow-md);z-index:1000;pointer-events:auto}.zoom-level{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:40px;text-align:center}@media (max-width: 610px){.zoom-controls-overlay{top:1rem;right:1rem;padding:.25rem}}.whiteboard-content{display:flex;flex:1;overflow:hidden;position:relative}.loading-room-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:var(--bg-primary);color:var(--text-primary);gap:1rem}.loading-room-spinner{width:40px;height:40px;border:4px solid var(--primary-color);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite}.loading-room-title{font-size:1rem;font-weight:500}.loading-room-subtitle{font-size:.875rem;color:var(--text-secondary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.home-page{min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.home-header{background:#fffffff2;backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);padding:2rem 0}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.brand{flex:1}.app-title{font-size:2.5rem;font-weight:800;color:#1f2937;margin:0 0 .5rem;display:flex;align-items:center;gap:.75rem}.logo{font-size:3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.app-subtitle{font-size:1.125rem;color:#6b7280;margin:0;font-weight:400}.header-actions{display:flex;gap:1rem}.create-room-btn,.join-room-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.create-room-btn.primary{background:#3b82f6;color:#fff;box-shadow:0 4px 12px #3b82f666}.create-room-btn.primary:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680}.join-room-btn.secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.join-room-btn.secondary:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-2px)}.home-main{padding:3rem 0}.main-content{max-width:1400px;margin:0 auto;padding:0 1rem;display:flex;flex-direction:column;gap:2rem}@media (min-width: 1024px){.main-content{padding:0 2rem;display:grid;grid-template-columns:320px 1fr}}.sidebar{display:flex;flex-direction:column;gap:2rem}.stats-panel{background:#fffffff2;backdrop-filter:blur(10px);border-radius:1rem;padding:1.5rem;box-shadow:0 8px 32px #0000001a}.stats-panel h3{margin:0 0 1rem;color:#1f2937;font-size:1.125rem;font-weight:700}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.stat-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8fafc;border-radius:.5rem;border:1px solid #e2e8f0}.stat-icon{font-size:1.5rem}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.25rem;font-weight:700;color:#1f2937;line-height:1}.stat-label{font-size:.75rem;color:#6b7280;font-weight:500}.popular-tags h4{margin:0 0 .75rem;color:#374151;font-size:.875rem;font-weight:600}.tags-list{display:flex;flex-direction:column;gap:.5rem}.popular-tag{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#f1f5f9;border-radius:.375rem;border:1px solid #cbd5e1}.tag-name{font-size:.8125rem;color:#334155;font-weight:500}.tag-count{font-size:.75rem;color:#64748b;background:#e2e8f0;padding:.125rem .375rem;border-radius:.25rem;font-weight:600}.filters-section{background:#fffffff2;backdrop-filter:blur(10px);border-radius:1rem;padding:1.5rem;box-shadow:0 8px 32px #0000001a}.filters-section h3{margin:0 0 1rem;color:#1f2937;font-size:1.125rem;font-weight:700}.search-bar{margin-bottom:1.5rem}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;color:#6b7280;font-size:1rem;pointer-events:none}.search-input{width:100%;padding:.75rem .75rem .75rem 2.5rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;background:#fff;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.clear-search{position:absolute;right:.75rem;background:none;border:none;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:.25rem;transition:color .2s ease}.clear-search:hover{color:#374151;background:#f3f4f6}.filter-options{display:flex;flex-direction:column;gap:.75rem}.filter-option{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151;cursor:pointer}.filter-option input[type=checkbox]{width:1rem;height:1rem;accent-color:#3b82f6}.rooms-section{background:#fffffff2;backdrop-filter:blur(10px);border-radius:1rem;padding:2rem;box-shadow:0 8px 32px #0000001a}.rooms-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.rooms-title h2{margin:0;color:#1f2937;font-size:1.5rem;font-weight:700}.rooms-count{font-size:.875rem;color:#6b7280;margin-left:.5rem}.view-controls{display:flex;justify-content:flex-end;margin-bottom:1rem}.view-mode-toggle{display:flex;background:#f3f4f6;border-radius:.5rem;padding:.25rem}.view-mode-btn{padding:.5rem;background:none;border:none;cursor:pointer;border-radius:.375rem;font-size:1rem;color:#6b7280;transition:all .2s ease}.view-mode-btn.active,.view-mode-btn:hover{background:#fff;color:#374151;box-shadow:0 1px 2px #0000000d}.room-browser-empty{display:flex;justify-content:center;align-items:center;min-height:400px}.rooms-container{display:grid;gap:1.5rem}.rooms-container.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.rooms-container.list{grid-template-columns:1fr}.room-card{background:#fff;border-radius:.75rem;box-shadow:0 4px 12px #0000000d;overflow:hidden;transition:all .2s ease;border:1px solid #e5e7eb}.room-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.room-card.private{border-left:4px solid #f59e0b}.room-card.list{display:flex}.room-card.list .room-thumbnail{width:120px;height:80px;flex-shrink:0}.room-card.list .room-info{flex:1;padding:1rem}.room-card.list .room-footer{width:120px;flex-shrink:0;padding:1rem;display:flex;align-items:center;justify-content:center}.room-thumbnail{position:relative;background:#f8fafc;cursor:pointer;overflow:hidden}.thumbnail-placeholder{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(135deg,#e2e8f0,#cbd5e1)}.thumbnail-icon{font-size:2rem;opacity:.6}.room-overlay{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.5rem}.room-privacy,.room-password{background:#000000b3;color:#fff;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;backdrop-filter:blur(4px)}.room-info{padding:1.25rem}.room-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.room-name{margin:0;font-size:1.125rem;font-weight:600;color:#1f2937;line-height:1.25;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.room-actions{display:flex;gap:.25rem;margin-left:.5rem}.action-btn{padding:.375rem;background:none;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;font-size:.875rem;color:#6b7280;transition:all .2s ease}.action-btn:hover{background:#f9fafb;border-color:#d1d5db}.action-btn.delete:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.room-description{margin:0 0 1rem;font-size:.875rem;color:#6b7280;line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.room-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem}.room-tag{background:#f1f5f9;color:#475569;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500;border:1px solid #cbd5e1}.room-tag.more{background:#e2e8f0;color:#64748b}.room-stats{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f3f4f6}.stat{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#6b7280}.stat-icon{font-size:1rem}.occupancy-bar{flex:1;height:4px;background:#e5e7eb;border-radius:2px;margin-left:.5rem;overflow:hidden}.occupancy-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .3s ease}.room-creator{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#6b7280}.creator-avatar{width:1.5rem;height:1.5rem;border-radius:50%;overflow:hidden;background:#e5e7eb}.creator-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#9ca3af;color:#fff;font-size:.75rem;font-weight:600}.room-footer{padding:1.25rem;padding-top:0}.join-btn{width:100%;padding:.75rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.join-btn:hover:not(:disabled){background:#2563eb;transform:translateY(-1px)}.join-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#6b7280}.loading-spinner{width:2rem;height:2rem;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-spinner.small{width:1rem;height:1rem;border-width:1px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#dc2626;text-align:center}.retry-btn{margin-top:1rem;padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;transition:background .2s ease}.retry-btn:hover{background:#b91c1c}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#6b7280}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.empty-state h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#374151}.empty-state p{margin:0 0 2rem;max-width:400px;line-height:1.5}.create-first-room-btn{padding:.75rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.create-first-room-btn:hover{background:#2563eb;transform:translateY(-1px)}.home-footer{background:#ffffff1a;backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2);padding:2rem 0;margin-top:2rem}.footer-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.quick-actions h3{margin:0 0 1rem;color:#fff;font-size:1.125rem;font-weight:700}.quick-action-buttons{display:flex;gap:1rem}.quick-action-btn{padding:.625rem 1.25rem;background:#ffffffe6;color:#374151;border:none;border-radius:.5rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.quick-action-btn:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.footer-info{color:#fffc;font-size:.875rem}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1024px){.main-content{grid-template-columns:280px 1fr;gap:1.5rem}.app-title{font-size:2rem}.header-content{padding:0 1rem}.rooms-section{padding:1.5rem}}@media (max-width: 768px){.header-content{flex-direction:column;gap:1.5rem;text-align:center}.main-content{grid-template-columns:1fr;gap:1rem}.sidebar{order:2}.rooms-section{order:1;padding:1rem}.rooms-container.grid{grid-template-columns:1fr}.rooms-header{flex-direction:column;gap:1rem;align-items:stretch}.stats-grid{grid-template-columns:1fr}.footer-content{flex-direction:column;gap:1.5rem;text-align:center}.quick-action-buttons{justify-content:center}}@media (max-width: 480px){.home-header{padding:1rem 0}.header-content{padding:0 .5rem}.app-title{font-size:1.5rem}.main-content{padding:0 .5rem}.rooms-section{padding:.75rem}.room-card.list{flex-direction:column}.room-card.list .room-thumbnail{width:100%;height:150px}.room-card.list .room-footer{width:100%;padding:1rem 1.25rem}.header-actions{flex-direction:column;width:100%;gap:.75rem}.create-room-btn,.join-room-btn{justify-content:center;width:100%}}.room-loading{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:2rem}.loading-content{background:#fffffff2;backdrop-filter:blur(10px);border-radius:1rem;padding:3rem;text-align:center;max-width:500px;width:100%;box-shadow:0 20px 40px #0000001a}.loading-spinner.large{width:3rem;height:3rem;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.loading-content h2{margin:0 0 .5rem;color:#1f2937;font-size:1.5rem;font-weight:700}.loading-content p{margin:0 0 2rem;color:#6b7280;line-height:1.5}.loading-steps{display:flex;flex-direction:column;gap:.75rem;text-align:left}.step{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f9fafb;border-radius:.5rem;font-size:.875rem;color:#6b7280;border:1px solid #e5e7eb}.step.active{background:#ecfdf5;color:#065f46;border-color:#10b981}.room-not-found,.not-found-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:2rem}.not-found-content{background:#fffffff2;backdrop-filter:blur(10px);border-radius:1rem;padding:3rem;text-align:center;max-width:600px;width:100%;box-shadow:0 20px 40px #0000001a}.not-found-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.8}.not-found-content h1{margin:0 0 1rem;color:#1f2937;font-size:2rem;font-weight:700}.not-found-content p{margin:0 0 2rem;color:#6b7280;line-height:1.6;font-size:1.125rem}.suggestions{text-align:left;background:#f8fafc;border-radius:.75rem;padding:1.5rem;margin-bottom:2rem;border:1px solid #e2e8f0}.suggestions h3{margin:0 0 1rem;color:#374151;font-size:1rem;font-weight:600}.suggestions ul{margin:0;padding-left:1.5rem;color:#6b7280;line-height:1.6}.suggestions li{margin-bottom:.5rem}.not-found-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.home-btn,.back-btn,.retry-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-decoration:none}.home-btn.primary,.retry-btn.primary{background:#3b82f6;color:#fff}.home-btn.primary:hover,.retry-btn.primary:hover{background:#2563eb;transform:translateY(-2px)}.back-btn.secondary,.retry-btn.secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.back-btn.secondary:hover,.retry-btn.secondary:hover{background:#f9fafb;border-color:#d1d5db;transform:translateY(-2px)}@media (max-width: 640px){.loading-content,.not-found-content{padding:2rem 1.5rem;margin:1rem}.not-found-content h1{font-size:1.5rem}.not-found-actions{flex-direction:column;align-items:stretch}.home-btn,.back-btn,.retry-btn{justify-content:center}.loading-steps{text-align:center}.step{justify-content:center}}.modal-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out;padding:1rem;overflow-y:auto}.create-room-modal,.join-room-modal{background:#fff;border-radius:1rem;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px #0000004d;animation:slideUp .3s ease-out;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:1;border-radius:1rem 1rem 0 0}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1f2937}.close-btn{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s ease;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.375rem}.close-btn:hover{color:#374151;background:#f3f4f6}.modal-form{display:flex;flex-direction:column;height:100%}.form-content{flex:1;padding:2rem;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;border-top:1px solid #e5e7eb;position:sticky;bottom:0;background:#fff;border-radius:0 0 1rem 1rem}.form-error{padding:1rem;margin:0 2rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.modal-overlay{padding:0}.create-room-modal,.join-room-modal{max-width:100%;max-height:100vh;border-radius:0}.modal-header,.form-content,.modal-footer{padding-left:1rem;padding-right:1rem}.modal-header,.modal-footer{border-radius:0}}.user-setup-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(8px);padding:1.5rem;z-index:11000}.user-setup-modal{width:min(420px,100%);background:#fff;border-radius:1.25rem;box-shadow:0 25px 50px #00000040;padding:2rem;animation:slideUp .3s ease-out,fadeIn .2s ease-out;display:flex;flex-direction:column;gap:1.5rem}@media (max-width: 640px){.user-setup-overlay{padding:1rem}.user-setup-modal{width:100%;padding:1.5rem;border-radius:1rem}}
