:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:6px;font-weight:500;transition:all .2s ease;cursor:pointer;text-decoration:none;gap:8px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-small{padding:8px 16px;font-size:14px;height:36px}.btn-medium{padding:12px 24px;font-size:16px;height:44px}.btn-large{padding:16px 32px;font-size:18px;height:52px}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:active:not(:disabled){background-color:#1d4ed8}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#4b5563}.btn-secondary:active:not(:disabled){background-color:#374151}.btn-outline{background-color:transparent;color:#3b82f6;border:2px solid #3b82f6}.btn-outline:hover:not(:disabled){background-color:#3b82f6;color:#fff}.btn-outline:active:not(:disabled){background-color:#2563eb;border-color:#2563eb}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-danger:active:not(:disabled){background-color:#b91c1c}.btn-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.btn-text-loading{opacity:.7}.btn:focus{outline:none;box-shadow:0 0 0 3px #3b82f64d}.btn-secondary:focus{box-shadow:0 0 0 3px #6b72804d}.btn-danger:focus{box-shadow:0 0 0 3px #ef44444d}.room-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.room-card:hover{border-color:#3b82f6;box-shadow:0 8px 25px #3b82f61a;transform:translateY(-2px)}.room-card:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f64d}.room-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;position:relative}.room-card-title-section{flex:1;min-width:0}.kebab-menu-container{position:relative;z-index:20}.kebab-button{width:32px;height:32px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;opacity:0;transform:scale(.9)}.kebab-button:hover{background:#f3f4f6;border-color:#d1d5db}.kebab-icon{font-size:16px;font-weight:700;color:#6b7280;line-height:1}.room-card:hover .kebab-button{opacity:1;transform:scale(1)}.kebab-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;min-width:140px;overflow:hidden;z-index:50;animation:menuSlideIn .15s ease-out}@keyframes menuSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.menu-item{width:100%;padding:12px 16px;background:none;border:none;text-align:left;cursor:pointer;transition:background-color .15s ease;display:flex;align-items:center;gap:8px;font-size:14px;color:#374151}.menu-item:hover{background:#f9fafb}.menu-item:disabled{opacity:.6;cursor:not-allowed}.menu-item.delete-item{color:#dc2626}.menu-item.delete-item:hover{background:#fef2f2}.menu-icon{font-size:14px;width:16px;text-align:center}.menu-divider{height:1px;background:#e5e7eb;margin:4px 0}@media (max-width: 768px){.kebab-button{opacity:.8;transform:scale(1)}.room-card:hover .kebab-button{opacity:1}}.user-avatar{border-radius:50%;object-fit:cover;border:1px solid #e5e7eb}.user-avatar.placeholder{background:#f3f4f6;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:50%}.user-avatar.initials{font-family:system-ui,-apple-system,sans-serif;text-align:center}.room-card-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#1f2937;line-height:1.4}.room-card-badges{display:flex;gap:8px;flex-wrap:wrap}.status-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.status-active{background-color:#dcfce7;color:#166534}.status-completed{background-color:#dbeafe;color:#1e40af}.status-archived{background-color:#f3f4f6;color:#374151}.visibility-badge{display:inline-block;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.visibility-badge.public{background-color:#fef3c7;color:#92400e}.visibility-badge.private{background-color:#e0e7ff;color:#3730a3}.room-card-content{margin-bottom:16px}.room-card-topic{margin:0 0 16px;color:#4b5563;line-height:1.5;font-size:14px}.room-card-axes{display:grid;grid-template-columns:1fr 1fr;gap:12px}.axis-info{display:flex;align-items:center}.axis-label{font-size:13px;font-weight:500;display:flex;align-items:center;gap:4px}.room-card-footer{display:flex;justify-content:space-between;align-items:end;font-size:12px;color:#6b7280;border-top:1px solid #f3f4f6;padding-top:12px}.room-card-meta{display:flex;flex-direction:column;gap:4px}.participants-count,.created-date{display:flex;align-items:center;gap:4px}.room-card-owner{display:flex;align-items:center;gap:8px;font-size:11px;color:#9ca3af}.owner-name{font-weight:500}@media (max-width: 768px){.room-card{padding:16px}.room-card-title{font-size:16px}.room-card-axes{grid-template-columns:1fr;gap:8px}.room-card-footer{flex-direction:column;align-items:flex-start;gap:8px}.room-card-meta{flex-direction:row;gap:16px}}@media (prefers-reduced-motion: no-preference){.room-card{animation:slideUp .3s ease-out}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0000001a;max-height:90vh;overflow-y:auto;animation:slideIn .3s ease-out}.modal-small{width:90%;max-width:400px}.modal-medium{width:90%;max-width:600px}.modal-large{width:90%;max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:20px}.modal-title{margin:0;font-size:1.5rem;font-weight:600;color:#1f2937}.modal-close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close-button:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:0 24px 24px}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.modal-content{margin:20px}.modal-small,.modal-medium,.modal-large{width:calc(100% - 40px);max-width:none}}.create-room-form{display:flex;flex-direction:column;gap:24px;max-height:70vh;overflow-y:auto}@media (max-width: 640px){.form-actions{flex-direction:column-reverse}.create-room-form{gap:16px}.form-section{padding:16px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.friend-add-modal{background:#fff;border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:20px}.modal-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-content{padding:0 24px 24px}.add-method-section{text-align:center;margin-bottom:24px}.method-icon{font-size:3rem;margin-bottom:12px}.add-method-section h3{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:#111827}.add-method-section p{margin:0;color:#6b7280;font-size:.9rem;line-height:1.5}.friend-add-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:500;color:#374151;font-size:.9rem}.email-input{padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.email-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.email-input:disabled{background:#f9fafb;color:#6b7280}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:.9rem;border:1px solid #fecaca}.success-message{background:#f0fdf4;color:#16a34a;padding:12px 16px;border-radius:8px;font-size:.9rem;border:1px solid #bbf7d0}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.method-divider{display:flex;align-items:center;margin:32px 0;color:#6b7280;font-size:.9rem}.method-divider:before,.method-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.method-divider span{padding:0 16px}.alternative-methods{display:flex;flex-direction:column;gap:12px}.method-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.method-item .method-icon{font-size:1.5rem;margin:0}.method-content h4{margin:0 0 4px;font-size:1rem;font-weight:600;color:#111827}.method-content p{margin:0;font-size:.9rem;color:#6b7280;line-height:1.4}@media (max-width: 640px){.modal-overlay{padding:16px}.friend-add-modal{max-width:100%}.modal-header{padding:20px 20px 0}.modal-content{padding:0 20px 20px}.form-actions{flex-direction:column-reverse}}.edit-room-form{display:flex;flex-direction:column;gap:24px;max-height:70vh;overflow-y:auto}.form-section{border:1px solid #e2e8f0;border-radius:8px;padding:20px;background-color:#f8fafc}.section-title{margin:0 0 16px;font-size:18px;font-weight:600;color:#1f2937;display:flex;align-items:center;gap:8px}.section-title:before{content:"";width:4px;height:18px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:2px}.section-description{margin:0 0 20px;color:#64748b;font-size:14px;line-height:1.5}.form-group{margin-bottom:16px}.form-label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.required{color:#ef4444}.form-input,.form-textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:border-color .2s,box-shadow .2s;background-color:#fff}.form-input:disabled,.form-textarea:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.form-color-input{width:48px;height:48px;padding:4px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;background-color:#fff}.form-color-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.color-text-input{flex:1;font-family:monospace;font-size:12px}.checkbox-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:16px;border:2px solid #e2e8f0;border-radius:8px;background-color:#fff;transition:border-color .2s,background-color .2s}.checkbox-label:hover{border-color:#cbd5e1;background-color:#f8fafc}.form-checkbox{width:18px;height:18px;margin:0;cursor:pointer;accent-color:#3b82f6}.checkbox-text{flex:1;display:flex;flex-direction:column;gap:4px}.checkbox-help{color:#64748b;font-size:12px;font-weight:400}.friend-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border:2px solid #e2e8f0;border-radius:8px;background-color:#fff;cursor:pointer;transition:all .2s}.friend-item:hover{border-color:#cbd5e1;background-color:#f8fafc}.friend-item.selected{border-color:#3b82f6;background-color:#3b82f60d}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px;border-top:1px solid #e2e8f0;margin-top:auto}@media (max-width: 640px){.form-actions{flex-direction:column-reverse}.edit-room-form{gap:16px}.form-section{padding:16px}}.share-room-modal{display:flex;flex-direction:column;gap:24px;max-height:80vh;overflow-y:auto}.share-header{text-align:center;padding:20px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;border:1px solid #e2e8f0}.room-title{margin:0 0 8px;font-size:20px;font-weight:600;color:#1f2937}.room-topic{margin:0 0 12px;color:#64748b;font-style:italic}.room-status .status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.public{background:#22c55e1a;color:#059669}.status-badge.private{background:#ef44441a;color:#dc2626}.share-modes{display:flex;flex-direction:column;gap:20px}.mode-tabs{display:flex;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#f8fafc}.mode-tab{flex:1;padding:12px 16px;border:none;background:transparent;color:#64748b;font-weight:500;cursor:pointer;transition:all .2s}.mode-tab:hover{background:#ffffff80;color:#374151}.mode-tab.active{background:#fff;color:#3b82f6;font-weight:600;box-shadow:0 2px 4px #0000000d}.permission-selector{margin-bottom:20px}.permission-selector h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#374151}.permission-options.horizontal{flex-direction:row;gap:16px}.permission-option{display:flex;align-items:center;gap:12px;padding:12px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.permission-option:hover{border-color:#cbd5e1;background:#f8fafc}.permission-option:has(input:checked){border-color:#3b82f6;background:#3b82f60d}.permission-option input[type=radio]{margin:0;accent-color:#3b82f6}.option-content{display:flex;flex-direction:column;gap:2px}.option-title{font-weight:500;color:#1f2937}.option-description{font-size:12px;color:#64748b}.permission-options.horizontal .permission-option{flex:1;justify-content:center}.permission-options.horizontal .option-content{align-items:center}.share-links-section{display:flex;flex-direction:column;gap:20px}.link-share{display:flex;flex-direction:column;gap:12px}.link-input-group{display:flex;gap:8px;align-items:center}.share-link-input{flex:1;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#374151;font-family:monospace;font-size:12px}.share-link-input:focus{outline:none;border-color:#3b82f6;background:#fff}.link-description{margin:0;color:#64748b;font-size:14px;line-height:1.5}.friends-share-section{display:flex;flex-direction:column;gap:20px}.loading-friends{display:flex;flex-direction:column;align-items:center;padding:40px;color:#64748b}.loading-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.no-friends{text-align:center;padding:40px;color:#64748b}.friends-selection{display:flex;flex-direction:column;gap:16px}.selected-count{display:flex;justify-content:flex-end}.count-badge{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.friends-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.friend-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border:2px solid #e2e8f0;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s}.friend-item:hover{border-color:#cbd5e1;background:#f8fafc}.friend-item.selected{border-color:#3b82f6;background:#3b82f60d}.friend-info{display:flex;align-items:center;gap:12px;flex:1}.friend-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.friend-details{display:flex;flex-direction:column;gap:2px}.friend-name{font-weight:500;color:#1f2937}.friend-email{font-size:12px;color:#64748b}.friend-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.share-friends-action{border-top:1px solid #e2e8f0;padding-top:16px}.qr-share-section{display:flex;flex-direction:column;gap:20px}.qr-code-container{display:flex;gap:24px;align-items:flex-start}.qr-code-wrapper{display:flex;justify-content:center;padding:20px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d}.qr-instructions{flex:1;display:flex;flex-direction:column;gap:12px}.qr-instructions h4{margin:0;font-size:16px;font-weight:600;color:#374151}.qr-instructions ol{margin:0;padding-left:20px}.qr-instructions li{margin-bottom:4px;color:#64748b;font-size:14px}.share-actions{display:flex;justify-content:flex-end;padding-top:20px;border-top:1px solid #e2e8f0}@media (max-width: 640px){.share-room-modal{gap:16px}.share-header{padding:16px}.mode-tabs{flex-direction:column}.mode-tab{text-align:center}.permission-options.horizontal,.link-input-group{flex-direction:column}.qr-code-container{flex-direction:column;gap:16px}.qr-code-wrapper{align-self:center}}.home-page{min-height:100vh;background-color:#f5f7fa;display:flex;width:100%}.home-main{flex:1;display:flex;flex-direction:column;padding:24px;gap:24px;min-width:0;overflow-x:hidden;margin-left:0;transition:margin-left .3s ease}.main-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:20px 24px;border-radius:12px;box-shadow:0 4px 20px #0000001a}.tab-navigation{display:flex;gap:2px;background:#f3f4f6;padding:4px;border-radius:8px}.tab-button{padding:8px 16px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-weight:500;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;gap:8px}.tab-button:disabled{cursor:not-allowed;opacity:.5}.tab-button.active{background:#fff;color:#3b82f6;box-shadow:0 2px 4px #0000001a}.tab-count{background:#3b82f6;color:#fff;font-size:12px;padding:2px 6px;border-radius:12px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center}.tab-button.active .tab-count{background:#1e40af}.header-actions{display:flex;gap:12px;align-items:center}.add-friend-button,.qr-button{font-size:14px;padding:8px 16px}.create-room-button{font-weight:600}.qr-code-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px;border-radius:12px;margin-bottom:24px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.qr-code-container{display:flex;flex-direction:column;align-items:center;text-align:center}.qr-code-container h3{margin:0 0 16px;font-size:20px;font-weight:600}.qr-description{margin:16px 0 0;opacity:.9;line-height:1.5;max-width:400px}.link-button{background:none;border:none;color:#bfdbfe;text-decoration:underline;cursor:pointer;font:inherit;padding:0;margin:0 4px}.link-button:hover{color:#fff}.rooms-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:24px;min-height:400px;flex:1}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;width:100%}.friends-content{min-height:400px}.friends-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.friend-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.friend-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a;transform:translateY(-1px)}.friend-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.friend-info h4{margin:0 0 4px;font-size:16px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-info p{margin:0 0 8px;font-size:14px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-info .status-badge{font-size:12px;padding:2px 8px;border-radius:12px;font-weight:500}.friend-info .status-badge.accepted{background:#dcfce7;color:#166534}.friend-info .status-badge.pending{background:#fef3c7;color:#92400e}.friend-actions{display:flex;gap:8px}.btn-chat,.btn-invite{width:36px;height:36px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:16px}.btn-chat:hover{border-color:#3b82f6;background:#eff6ff}.btn-invite:hover{border-color:#10b981;background:#ecfdf5}.auth-prompt{display:flex;align-items:center;justify-content:center;min-height:400px}.auth-prompt-content{text-align:center;max-width:400px}.auth-prompt-content h3{margin:0 0 16px;font-size:24px;color:#1f2937}.auth-prompt-content p{margin:0 0 24px;color:#6b7280;line-height:1.6}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state h3{margin:0 0 12px;font-size:20px;color:#1f2937}.empty-state p{margin:0 0 24px;color:#6b7280;max-width:400px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-state p{color:#6b7280;margin:0}.sidebar-overlay{display:none}@media (max-width: 1024px){.home-main{padding:20px}.rooms-grid,.friends-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}}@media (max-width: 768px){.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:150}.home-main{padding:16px;width:100%;margin-left:0!important}.main-header{flex-direction:column;gap:16px;align-items:stretch}.tab-navigation{justify-content:center}.header-actions{justify-content:center;flex-wrap:wrap}.create-room-button,.add-friend-button,.qr-button{flex:1;min-width:120px}.rooms-grid,.friends-grid{grid-template-columns:1fr}.friend-card{padding:16px}.qr-code-section{padding:20px}}@media (max-width: 480px){.home-main{padding:12px}.rooms-content,.main-header{padding:16px}.header-actions{flex-direction:column;gap:8px}.friend-card{flex-direction:column;text-align:center;gap:12px}.friend-info h4,.friend-info p{white-space:normal;text-align:center}}.app-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#f5f7fa;overflow:hidden;user-select:none;-webkit-user-select:none;display:flex;flex-direction:row;transition:all .3s ease}.main-content{flex:1;width:calc(100vw - 60px);height:100vh;transition:all .3s ease;position:relative}.main-content.sidebar-expanded{width:calc(100vw - 280px)}.main-content.with-dictionary-sidebar{margin-right:320px}.graph-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.graph-page .graph-header{flex-shrink:0;z-index:1000;position:relative}.graph-page .main-graph-container{flex:1;height:100vh;overflow:hidden;position:relative}@media (max-width: 768px){.app-container{flex-direction:column}.main-content{width:100vw;height:100vh}.main-content.sidebar-expanded{width:100vw}}.coordinate-point{width:8px;height:8px;background:#dc3545;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;z-index:501}.app-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;z-index:100}.app-header h1{margin:0;font-size:24px;font-weight:700;color:#1f2937}.graph-header{display:none!important}.header-title-section{display:flex;justify-content:space-between;align-items:center;gap:16px}.header-title-section h1{margin:0;font-size:16px;font-weight:600;color:#1f2937;flex:1}.settings-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:10px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:4px;white-space:nowrap}.settings-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.settings-button:active{transform:translateY(0)}.back-button{background:#f3f4f6;color:#374151;border:none;border-radius:3px;padding:4px 8px;font-size:10px;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#e5e7eb;transform:translateY(-1px)}.room-topic{font-size:10px;color:#6b7280;font-style:italic}.room-id{font-size:8px;color:#9ca3af;font-family:monospace}.auth-status{font-size:8px;padding:2px 4px;border-radius:3px;font-weight:500}.header-controls{display:flex;align-items:center;gap:12px}.word-bank-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.word-bank-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.rotate-btn{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.rotate-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b4d}.stats{display:flex;gap:12px;font-size:12px;color:#6b7280}.stats span{background:#0000000d;padding:4px 8px;border-radius:6px;font-weight:500}.app-sidebar{background:#f1f3f5;color:#495057;width:60px;height:100vh;display:flex;flex-direction:column;box-shadow:2px 0 8px #00000014;z-index:150;position:relative;border-right:1px solid #e9ecef;transition:width .3s ease;flex-shrink:0}.app-sidebar.expanded{width:280px}@media (max-width: 768px){.app-sidebar{position:fixed;top:0;left:0;width:280px!important;transform:translate(-100%);z-index:150;background:#f1f3f5f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-sidebar.expanded{transform:translate(0)}.app-sidebar .sidebar-title,.app-sidebar .nav-label,.app-sidebar .stats{opacity:1!important}.main-content{margin-left:0!important;width:100%!important}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:149;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}}.sidebar-header{padding:12px 16px;border-bottom:1px solid #e9ecef;display:flex;align-items:center;justify-content:flex-start;min-height:48px}.hamburger-btn{background:transparent;border:none;font-size:18px;cursor:pointer;padding:6px;border-radius:4px;transition:all .15s ease;color:#495057;display:flex;align-items:center;justify-content:center;width:30px;height:30px}.hamburger-btn:hover{background:#0000001a;color:#212529}.sidebar-title{margin-left:12px;font-size:16px;font-weight:600;color:#212529;opacity:0;transition:opacity .3s ease;white-space:nowrap;overflow:hidden}.app-sidebar.expanded .sidebar-title{opacity:1}.sidebar-nav{flex:1;padding:8px 0;display:flex;flex-direction:column;gap:4px}.nav-item{padding:12px 16px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:16px;font-size:14px;font-weight:500;color:#495057;border-radius:6px;margin:0 8px;position:relative}.nav-item:hover{background:#0000000d;color:#212529}.nav-item.active{background:#0d6efd1a;color:#0d6efd;border-left:none}.nav-item.active:before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#0d6efd;border-radius:2px}.nav-icon{font-size:18px;width:20px;text-align:center;flex-shrink:0}.nav-label{opacity:0;transition:opacity .3s ease;white-space:nowrap;overflow:hidden}.app-sidebar.expanded .nav-label{opacity:1}.sidebar-footer{padding:16px;border-top:1px solid #e9ecef}.stats{display:flex;flex-direction:column;gap:8px;font-size:12px;opacity:0;transition:opacity .3s ease}.app-sidebar.expanded .stats{opacity:1}.stats .stat-item{background:#0000000d;padding:6px 10px;border-radius:6px;display:flex;justify-content:space-between;align-items:center}.stat-value{font-weight:600;color:#0d6efd}.quadrant-graph{position:relative;width:100%;height:100%;background:#fff;border:2px solid #d0d7de;border-radius:12px;overflow:hidden;transition:all .2s ease;cursor:pointer;z-index:1;box-shadow:0 1px 3px #00000014,inset 0 0 0 1px #ffffff1a;touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.main-graph-container .quadrant-graph{height:100%;min-height:400px}@media (max-width: 768px){.main-graph-container .quadrant-graph{border-radius:8px;min-height:350px}.quadrant-graph{border-width:1px}}.quadrant-graph.placement-mode{background:linear-gradient(135deg,#e8f5e8,#d4f4dd,#e8f5e8,#d4f4dd,#e8f5e8);border-color:#28a745;box-shadow:0 0 0 4px #28a74533;cursor:crosshair}.grid-line{position:absolute;background:#d1d5dbcc;z-index:2;opacity:.7}.grid-line.vertical{width:1px;height:100%;top:0}.grid-line.horizontal{width:100%;height:1px;left:0}.quadrant-label{position:absolute;font-size:11px;color:#6b7280;font-weight:500;padding:6px 8px;background:#fffffff2;border-radius:6px;z-index:5;pointer-events:none;text-align:center;line-height:1.2;box-shadow:0 1px 3px #00000014;border:1px solid rgba(209,213,219,.2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.quadrant-label.top-right{top:15px;right:15px}.quadrant-label.top-left{top:15px;left:15px}.quadrant-label.bottom-left{bottom:15px;left:15px}.quadrant-label.bottom-right{bottom:15px;right:15px}.quadrant-label.enhanced{background:#fffffff2!important;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 12px #00000026!important;border:1px solid rgba(255,255,255,.2);padding:8px 10px;border-radius:8px;font-size:11px;z-index:50}.graph-container{position:absolute;top:0;left:0;width:100%;height:100%;padding:40px;box-sizing:border-box}.interaction-hints{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;pointer-events:none;z-index:5}.hint{background:#6c757de6;color:#fff;padding:8px 16px;border-radius:16px;font-size:12px;text-align:center;animation:hintFade 4s infinite}.hint:nth-child(2){animation-delay:2s}@keyframes hintFade{0%,85%{opacity:0}90%,95%{opacity:1}to{opacity:0}}.placement-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#28a745e6;color:#fff;padding:12px 24px;border-radius:24px;font-weight:700;pointer-events:none;z-index:50;animation:placementPulse 2s infinite}@keyframes placementPulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.05)}}.placement-instruction{position:fixed;top:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:12px 20px;border-radius:24px;box-shadow:0 4px 16px #28a7454d;z-index:1400;display:flex;align-items:center;gap:12px;animation:slideInTop .3s ease-out}@keyframes slideInTop{0%{transform:translate(-50%,-20px);opacity:0}to{transform:translate(-50%);opacity:1}}.cancel-placement{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:4px 12px;border-radius:12px;cursor:pointer;font-size:12px;transition:all .2s ease}.cancel-placement:hover{background:#ffffff4d}.axis-labels{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;pointer-events:none}.axis-line{position:absolute;pointer-events:none;z-index:5}.axis-line.x-axis{bottom:50%;left:15px;right:15px;height:2px;opacity:.6}.axis-line.y-axis{left:50%;top:15px;bottom:15px;width:2px;background:linear-gradient(0deg,#10b981,#10b981);opacity:.6}.axis-arrow{position:absolute;font-size:16px;font-weight:700;color:inherit;text-shadow:0 0 3px rgba(255,255,255,.8)}.axis-line.x-axis:before{content:"▶";position:absolute;right:-8px;top:50%;transform:translateY(-50%);color:#f59e0b;font-size:12px;text-shadow:0 0 3px rgba(255,255,255,.8)}.axis-line.x-axis:after{content:"◀";position:absolute;left:-8px;top:50%;transform:translateY(-50%);color:#f59e0b;font-size:12px;opacity:.4;text-shadow:0 0 3px rgba(255,255,255,.8)}.axis-line.y-axis:before{content:"▲";position:absolute;top:-8px;left:50%;transform:translate(-50%);color:#10b981;font-size:12px;text-shadow:0 0 3px rgba(255,255,255,.8)}.axis-line.y-axis:after{content:"▼";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);color:#10b981;font-size:12px;opacity:.4;text-shadow:0 0 3px rgba(255,255,255,.8)}.y-axis-label-container{position:absolute;left:15px;top:50%;transform:translateY(-50%);pointer-events:auto;display:flex;align-items:center;gap:8px;z-index:20}.x-axis-label-container{position:absolute;bottom:15px;left:50%;transform:translate(-50%);pointer-events:auto;display:flex;align-items:center;gap:8px;z-index:20}.y-axis-label,.x-axis-label{font-weight:600;color:#374151;font-size:14px;background:#fffffff2;padding:8px 12px;border-radius:8px;box-shadow:0 2px 8px #0000001a,0 0 0 1px #0000000d;pointer-events:auto;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;border:1px solid rgba(209,213,219,.3);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.axis-icon{font-size:16px;opacity:.8;transition:all .2s ease}.editable-axis-label:hover{background:#f9fafb;box-shadow:0 4px 12px #00000026,0 0 0 1px #3b82f633;transform:scale(1.02);border-color:#3b82f64d}.editable-axis-label:hover .axis-icon{opacity:1;transform:scale(1.1)}.edit-hint{opacity:0;font-size:10px;transition:opacity .15s ease;filter:grayscale(.8) opacity(.7)}.editable-axis-label:hover .edit-hint{opacity:.8;filter:grayscale(0)}.axis-label-input{font-weight:600;color:#1f2937;font-size:14px;background:#fff;border:2px solid #3b82f6;border-radius:8px;padding:8px 12px;outline:none;box-shadow:0 0 0 3px #3b82f61a;text-align:left;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;min-width:120px}.y-axis-input{border-left:4px solid #10b981}.x-axis-input{border-bottom:4px solid #f59e0b}.input-dropdown{z-index:1000;display:flex;align-items:center;gap:8px;animation:dropdownFadeIn .2s ease-out;opacity:1;pointer-events:auto}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.position-marker{width:12px;height:12px;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #ee5a5266;flex-shrink:0;position:relative;transform:translate(-6px);animation:markerPulse .3s ease-out}@keyframes markerPulse{0%{transform:translate(-6px) scale(0)}50%{transform:translate(-6px) scale(1.2)}to{transform:translate(-6px) scale(1)}}.input-dropdown.reverse .position-marker{transform:translate(6px);animation:markerPulseReverse .3s ease-out}@keyframes markerPulseReverse{0%{transform:translate(6px) scale(0)}50%{transform:translate(6px) scale(1.2)}to{transform:translate(6px) scale(1)}}.input-controls{display:flex;align-items:center;gap:6px;background:#fff;border-radius:20px;padding:6px;box-shadow:0 4px 16px #00000026;border:2px solid #e1e8ed;animation:controlsSlideIn .25s ease-out .1s both}.word-bank-sidebar{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:overlayFadeIn .3s ease-out;display:flex;align-items:center;justify-content:center;z-index:1500}.word-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:2px solid #dee2e6;border-radius:16px;padding:8px 12px;font-size:14px;font-weight:500;-webkit-user-select:none;user-select:none;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;position:relative;z-index:502}.word-chip.positioned:hover{transform:translateY(-2px) scale(1.05);z-index:600}.word-chip.positioned:active,.word-chip.positioned.dragging{cursor:grabbing;transform:scale(1.1) rotate(2deg);z-index:2000!important;transition:none!important}.word-chip.positioned[style*="position: fixed"]{z-index:2000!important}@keyframes overlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.word-bank-container{background:#fff;border-radius:24px;box-shadow:0 20px 40px #0000004d;animation:bankSlideIn .3s ease-out;display:flex;flex-direction:column;width:90vw;max-width:600px;height:70vh;max-height:500px}@keyframes bankSlideIn{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.word-bank-container .sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #e1e8ed;background:#f1f3f5}.word-bank-container .sidebar-header h3{margin:0;color:#333;font-size:18px}.close-btn{background:none;border:none;font-size:24px;color:#6c757d;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-btn:hover{background-color:#0000001a;color:#495057}.bank-instruction{text-align:center;color:#6b7280;font-weight:500;font-size:14px;margin:0 0 16px;padding:8px;background:#d1d5db33;border-radius:8px;border:1px dashed #9ca3af}.add-to-bank{margin-bottom:16px}.bank-input{width:100%;padding:10px 12px;border:2px solid #d0d7de;border-radius:12px;font-size:14px;margin-bottom:16px;outline:none;transition:border-color .2s ease;background:#fff;box-sizing:border-box}.bank-input:focus{border-color:#0d6efd;background:#fff}.sidebar-content{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.word-bank-sidebar .sidebar-content{background:#fff;border:2px dashed #d0d7de;border-top:none;border-radius:0 0 16px 16px;margin:0 16px 16px}.empty-message{text-align:center;color:#6c757d;font-style:italic;margin-top:20px}.sidebar-word{width:100%;justify-content:space-between;background-color:#f8f9fa;border:2px solid #d0d7de;border-radius:12px;padding:12px 16px;transition:all .2s ease;cursor:pointer;z-index:1600}.sidebar-word:hover{background-color:#e9ecef;transform:translate(-4px);box-shadow:4px 4px 12px #6c757d33}.sidebar-word.selected{background:linear-gradient(135deg,#d4edda,#c3e6cb);border-color:#28a745;box-shadow:0 0 0 3px #28a74533}.drag-arrow-preview{pointer-events:none;z-index:2000}.drag-line{animation:dragLinePulse 2s infinite}@keyframes dragLinePulse{0%,to{opacity:.8}50%{opacity:1}}.drag-end-marker{width:12px;height:12px;background:linear-gradient(135deg,#667eea,#764ba2);border:3px solid white;border-radius:50%;box-shadow:0 4px 12px #667eea66;animation:dragMarkerPulse 1s infinite}.drag-arrow-icon{animation:arrowIconBounce 1.5s infinite}@keyframes arrowIconBounce{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}@keyframes dragMarkerPulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.2)}}.coordinate-display{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.coordinate-values{position:absolute;top:16px;right:16px;background:#000c;color:#fff;padding:8px 12px;border-radius:8px;font-family:Courier New,monospace;font-size:12px;display:flex;flex-direction:column;gap:4px;align-items:flex-start;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0003;min-width:100px}.coord-label{color:#aaa;font-weight:700}.coord-value{color:#4fc3f7;font-weight:700;min-width:40px;text-align:right}.coordinate-indicator{position:absolute;width:6px;height:6px;background:#4fc3f7;border:2px solid white;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 2px #4fc3f74d,0 2px 4px #0003;animation:coordinateIndicatorPulse 2s infinite}@keyframes coordinateIndicatorPulse{0%,to{transform:translate(-50%,-50%) scale(1);box-shadow:0 0 0 2px #4fc3f74d,0 2px 4px #0003}50%{transform:translate(-50%,-50%) scale(1.3);box-shadow:0 0 0 6px #4fc3f733,0 2px 4px #0003}}@keyframes coordinatePulse{0%,to{transform:scale(1);box-shadow:0 2px 8px #ee5a5266}50%{transform:scale(1.15);box-shadow:0 4px 12px #ee5a5299}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (prefers-color-scheme: dark){.app-container{background-color:#0d1117}.app-header{background:#161b22;border-bottom-color:#30363d;color:#e6edf3}.app-header h1{color:#f0f6fc}.app-sidebar{background:#161b22;border-right-color:#30363d}.hamburger-btn{color:#e6edf3}.hamburger-btn:hover{background:#ffffff14;color:#f0f6fc}.sidebar-title{color:#f0f6fc}.sidebar-header{border-bottom-color:#30363d}.sidebar-footer{border-top-color:#30363d}.nav-item{color:#e6edf3}.nav-item:hover{background:#ffffff14;color:#f0f6fc}.nav-item.active{background:#388bfd26;color:#58a6ff}.nav-item.active:before{background:#58a6ff}.stats .stat-item{background:#ffffff14}.stat-value{color:#58a6ff}.quadrant-graph{background:#0d1117;border-color:#30363d;box-shadow:0 1px 3px #0000001f,inset 0 0 0 1px #f0f6fc1a}.quadrant-graph.placement-mode{background:#0d1117;border-color:#238636}.grid-line{background:#4b556399}.quadrant-label{background:#0d1117f2;color:#e6edf3;border:1px solid #30363d}.editable-axis-label{background:#0d1117f2!important;color:#e6edf3!important;border:1px solid #30363d}.editable-axis-label:hover{background:#161b22f2!important;box-shadow:0 3px 8px #00000040,0 0 0 1px #0969da4d!important}.axis-label-input{background:#21262d!important;color:#e6edf3!important;border-color:#0969da!important;box-shadow:0 0 0 3px #0969da33!important}.input-controls{background:#21262d;border-color:#30363d}.dropdown-input{background:#0d1117;color:#e6edf3}.dropdown-input:focus{background:#21262d}.word-bank-sidebar{background:#0d1117e6}.word-bank-container{background:#0d1117;border:1px solid #30363d}.word-bank-container .sidebar-header{background:linear-gradient(135deg,#21262d,#161b22);color:#e6edf3;border-bottom-color:#30363d}.sidebar-word{background-color:#21262d;border-color:#30363d;color:#e6edf3}.sidebar-word:hover{background-color:#30363d}.bank-input{background:#21262d;border-color:#30363d;color:#e6edf3}.bank-input:focus{border-color:#0969da;background:#21262d}.close-btn{color:#8b949e}.close-btn:hover{background-color:#ffffff1a;color:#e6edf3}.coordinate-values{background:#0d1117e6;color:#e6edf3;border:1px solid #30363d}.coord-label{color:#8b949e}.coord-value{color:#58a6ff}.bank-instruction{background:#30363d4d;border-color:#30363d;color:#8b949e}.empty-message{color:#8b949e}}.word-wrapper{position:absolute;z-index:500}.coordinate-point{position:absolute;top:50%;left:50%;width:8px;height:8px;background:#dc3545;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;transform:translate(-50%,-50%);z-index:501}.word-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:2px solid #dee2e6;border-radius:16px;padding:8px 12px;font-size:14px;font-weight:500;-webkit-user-select:none;user-select:none;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;z-index:502}.input-dropdown{z-index:1000;display:flex;align-items:center}@keyframes dropdownSlideIn{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.position-marker{width:12px;height:12px;background:linear-gradient(135deg,#ff6b6b,#ee5a52);border:3px solid white;border-radius:50%;box-shadow:0 2px 8px #ee5a5266;animation:markerPulse 2s infinite;flex-shrink:0}@keyframes markerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.input-controls{display:flex;align-items:center;gap:6px;background:#fff;border-radius:20px;padding:6px;box-shadow:0 4px 16px #00000026;border:2px solid #e1e8ed;animation:controlsSlideIn .3s ease-out .1s both}@keyframes controlsSlideIn{0%{transform:translate(-10px);opacity:0}to{transform:translate(0);opacity:1}}.dropdown-input{border:none;outline:none;padding:8px 12px;font-size:14px;min-width:140px;border-radius:14px;background:#f8f9fa;transition:all .2s ease}.dropdown-input:focus{background:#fff;box-shadow:0 0 0 2px #667eea33}.dictionary-btn{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:all .2s ease;flex-shrink:0}.dictionary-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 2px 8px #28a7454d}.dictionary-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.add-word-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:14px;padding:8px 12px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.add-word-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.add-word-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.word-chip.positioned{cursor:grab;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.word-chip.positioned:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #2196f34d;z-index:600}.word-chip.positioned:active,.word-chip.positioned.dragging{cursor:grabbing;transform:scale(1.1) rotate(2deg);z-index:2000!important;box-shadow:0 8px 20px #2196f399!important;transition:none!important}.word-chip.positioned[style*="position: fixed"]{z-index:2000!important;box-shadow:0 8px 20px #2196f366!important}.remove-btn{background:none;border:none;color:#dc3545;cursor:pointer;font-size:16px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:503}.remove-btn:hover{background-color:#dc3545;color:#fff;transform:scale(1.2)}.word-and-marker,.word-wrapper{position:absolute;z-index:500}.coordinate-point{width:8px;height:8px;background:#dc3545;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;pointer-events:none}.word-chip.positioned{white-space:nowrap;display:inline-flex;align-items:center}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}to{transform:translate(-50%,-50%) scale(1)}}.user-cursor{transition:all .1s ease-out}.user-cursor .cursor-icon{animation:pulse 2s infinite}.user-cursor .cursor-label{opacity:0;transition:opacity .2s ease}.user-cursor:hover .cursor-label{opacity:1}.user-drag-indicator{pointer-events:none}.user-drag-line{animation:dragPulse 1s infinite}.user-drag-arrow{animation:arrowBounce .8s infinite}.user-drag-avatar{animation:avatarFloat 2s infinite}@keyframes dragPulse{0%{opacity:.9}50%{opacity:.6}to{opacity:.9}}@keyframes arrowBounce{0%{transform:translate(-50%,-50%) rotate(var(--angle)) scale(1)}50%{transform:translate(-50%,-50%) rotate(var(--angle)) scale(1.1)}to{transform:translate(-50%,-50%) rotate(var(--angle)) scale(1)}}@keyframes avatarFloat{0%{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-2px)}to{transform:translate(-50%,-50%) translateY(0)}}.connection-status{position:fixed;top:16px;right:16px;z-index:10000;display:flex;align-items:center;gap:8px;background:#fffffff2;padding:8px 12px;border-radius:20px;box-shadow:0 2px 8px #0000001a;font-size:12px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.connection-indicator{width:8px;height:8px;border-radius:50%;transition:all .3s ease}.connection-indicator.connected{background:#22c55e;animation:connectedPulse 2s infinite}.connection-indicator.disconnected{background:#ef4444;animation:disconnectedBlink 1s infinite}.connection-indicator.connecting{background:#f59e0b;animation:connectingPulse .8s infinite}@keyframes connectedPulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}to{transform:scale(1);opacity:1}}@keyframes disconnectedBlink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}@keyframes connectingPulse{0%{transform:scale(.8);opacity:.6}50%{transform:scale(1.2);opacity:1}to{transform:scale(.8);opacity:.6}}.connected-users-count{background:#3b82f61a;color:#3b82f6;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600}.connected-users-avatars{display:flex;align-items:center;margin-left:4px}.user-avatar{position:relative;width:32px;height:32px;border-radius:50%;overflow:hidden;border:2px solid white;box-shadow:0 2px 4px #0000001a;transition:all .2s ease;cursor:pointer}.user-avatar:hover{transform:scale(1.1);z-index:20!important}.user-avatar.current-user{border-color:#22c55e;box-shadow:0 0 0 2px #22c55e4d}.user-avatar.connected-user{border-color:#3b82f6}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(45deg,#667eea,#764ba2);color:#fff;font-size:12px;font-weight:600}.current-user-indicator{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;background:#22c55e;border:2px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:8px;line-height:1}.more-users-indicator{background:#000000b3;color:#fff;padding:4px 6px;border-radius:12px;font-size:10px;font-weight:600;margin-left:4px;min-width:24px;text-align:center}.connection-error{position:fixed;top:60px;right:16px;z-index:10000;background:#ef4444f2;color:#fff;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:500;max-width:250px;animation:slideInFromRight .3s ease}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.realtime-update-indicator{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,#3b82f6 50%,transparent 100%);animation:realtimeProgress .5s ease;z-index:1000}@keyframes realtimeProgress{0%{transform:translate(-100%)}to{transform:translate(100%)}}.drag-arrow-preview{pointer-events:none;z-index:3000}.drag-line{position:fixed;height:4px;background:linear-gradient(90deg,var(--arrow-color) 0%,var(--arrow-color-alpha) 100%);transform-origin:0 50%;pointer-events:none;border-radius:2px;box-shadow:0 2px 4px #0003;animation:dragLinePulse .5s ease}.drag-end-marker{position:fixed;width:12px;height:12px;background:var(--arrow-color, #3b82f6);border-radius:50%;border:2px solid white;box-shadow:0 2px 6px #0003;pointer-events:none;animation:markerPulse .6s infinite}.drag-arrow-icon{position:fixed;font-size:20px;color:var(--arrow-color, #3b82f6);text-shadow:0 2px 4px rgba(0,0,0,.2);pointer-events:none;animation:arrowBounce .4s ease}@keyframes dragLinePulse{0%{opacity:0;transform:var(--line-transform) scaleX(0)}to{opacity:1;transform:var(--line-transform) scaleX(1)}}@keyframes markerPulse{0%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.2)}to{transform:translate(-50%,-50%) scale(1)}}@keyframes arrowBounce{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@media (max-width: 768px){.connection-status{top:8px;right:8px;padding:6px 8px;font-size:0;min-width:auto;border-radius:20px}.connection-status>span{display:none}.connected-users-count{display:none}.connection-indicator{width:12px;height:12px}.user-avatar{width:24px;height:24px;border-width:1px}.current-user-indicator{width:8px;height:8px;bottom:-1px;right:-1px;border-width:1px;font-size:6px}.more-users-indicator{font-size:8px;padding:2px 4px;margin-left:2px}.user-cursor .cursor-label,.user-drag-avatar>div:last-child{display:none}.user-cursor .cursor-icon{width:16px;height:16px}.user-drag-avatar>div:first-child{width:20px;height:20px}}@media (prefers-contrast: high){.user-cursor .cursor-icon{border-width:3px}.user-drag-line{height:4px}.connection-status{border:2px solid #000}}.save-fab{position:fixed!important;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#ff6b6b,#ee5a24);border:none;color:#fff;font-size:20px;cursor:pointer;z-index:1000;box-shadow:0 4px 12px #ff6b6b66,0 2px 4px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;margin:0!important;transform:none}@media (min-width: 769px){.save-fab{right:20px!important;position:fixed!important}.sidebar-expanded .save-fab{right:20px!important}}.save-fab:hover:not(:disabled){transform:translateY(-2px) scale(1.05)!important;box-shadow:0 6px 16px #ff6b6b80,0 4px 8px #0003;background:linear-gradient(135deg,#ff5252,#d84315)}.save-fab:active:not(:disabled){transform:translateY(0) scale(.95)!important;box-shadow:0 2px 8px #ff6b6b66}.save-fab.saved,.save-fab:disabled{background:linear-gradient(135deg,#28a745,#20c997);cursor:default;box-shadow:0 2px 8px #28a7454d}.save-fab.saved:hover,.save-fab:disabled:hover{transform:none;background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 2px 8px #28a7454d}.save-fab.saving{background:#ccc;cursor:not-allowed;animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.save-fab .pending-badge{position:absolute;top:-5px;right:-5px;background:#fff;color:#ff6b6b;border-radius:50%;min-width:20px;height:20px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #ff6b6b;animation:bounce .5s ease-out;box-shadow:0 2px 4px #0000001a}@keyframes bounce{0%{transform:scale(.8)}50%{transform:scale(1.2)}to{transform:scale(1)}}.save-fab:before{content:attr(data-tooltip);position:absolute;bottom:70px;right:0;background:#000c;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .3s ease;transform:translate(50%)}.save-fab:hover:before{opacity:1}@media (max-width: 768px){.save-fab{bottom:80px;right:16px;width:48px;height:48px;font-size:18px}.save-fab .pending-badge{min-width:18px;height:18px;font-size:11px;top:-3px;right:-3px}.save-fab:before{bottom:60px;font-size:11px}}.save-fab.pulse-save{animation:savePulse .6s ease-out}@keyframes savePulse{0%{transform:scale(1)}50%{transform:scale(1.1);box-shadow:0 0 20px #28a74599}to{transform:scale(1)}}.mobile-room-header{position:fixed;top:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-bottom:1px solid #e9ecef;z-index:90;text-align:center}.mobile-room-title{font-size:16px;font-weight:600;color:#212529;margin-bottom:2px}.mobile-room-topic{font-size:12px;color:#6c757d;font-weight:500}.mobile-quick-actions{position:fixed;bottom:20px;left:20px;display:flex;flex-direction:column;gap:12px;z-index:90}.quick-action-btn{width:48px;height:48px;border-radius:50%;border:none;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#495057;font-size:20px;cursor:pointer;box-shadow:0 2px 8px #0000001a;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.quick-action-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #0003;background:#fff}.quick-action-btn:active{transform:translateY(0) scale(.95)}@media (min-width: 769px){.mobile-room-header,.mobile-quick-actions{display:none!important}}@media (max-width: 768px){.mobile-room-header,.mobile-quick-actions{display:block}.mobile-quick-actions{display:flex}}.graph-settings-modal .modal-content{max-width:600px;max-height:80vh;overflow-y:auto}.graph-settings-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-weight:500;font-size:14px;color:#374151;margin-bottom:4px}.form-label .required{color:#ef4444;margin-left:4px}.form-input,.form-textarea{padding:12px;border:1px solid #D1D5DB;border-radius:8px;font-size:14px;transition:border-color .2s,box-shadow .2s;background:#fff}.form-input:focus,.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input.error,.form-textarea.error{border-color:#ef4444}.form-input.error:focus,.form-textarea.error:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-input:disabled,.form-textarea:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.form-textarea{resize:vertical;min-height:80px}.error-message{font-size:12px;color:#ef4444;margin-top:4px}.character-count{font-size:12px;color:#6b7280;text-align:right}.section-title{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:16px;border-bottom:1px solid #E5E7EB;padding-bottom:8px}.axis-settings-section{display:flex;flex-direction:column;gap:20px}.axis-group{padding:16px;border:1px solid #E5E7EB;border-radius:8px;background:#f9fafb;display:flex;flex-direction:column;gap:16px}.axis-title{font-size:14px;font-weight:600;color:#374151;margin:0}.color-input-group{display:flex;gap:8px;align-items:center}.color-picker{width:40px;height:40px;border:1px solid #D1D5DB;border-radius:8px;cursor:pointer;background:none}.color-picker:disabled{cursor:not-allowed;opacity:.5}.color-text-input{flex:1;padding:8px 12px;border:1px solid #D1D5DB;border-radius:8px;font-size:14px;font-family:monospace;text-transform:uppercase}.preset-colors{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.preset-color-btn{width:32px;height:32px;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s;position:relative}.preset-color-btn:hover{transform:scale(1.1);border-color:#d1d5db}.preset-color-btn.selected{border-color:#1f2937;box-shadow:0 0 0 2px #1f293733}.preset-color-btn:disabled{cursor:not-allowed;opacity:.5}.preset-color-btn:disabled:hover{transform:none}.preview-section{padding:16px;background:#f3f4f6;border-radius:8px;border:1px solid #E5E7EB}.axis-preview{display:flex;flex-direction:column;gap:16px;align-items:center}.preview-axis{display:flex;align-items:center;gap:12px}.preview-label{font-weight:500;font-size:14px;min-width:60px}.preview-line{width:80px;height:3px;border-radius:2px}.preview-x-axis .preview-line{width:80px;height:3px}.preview-y-axis{flex-direction:column;gap:8px}.preview-y-axis .preview-line{width:3px;height:60px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #E5E7EB}@media (max-width: 640px){.graph-settings-modal .modal-content{max-width:95vw;margin:10px;max-height:90vh}.graph-header{padding:12px 16px}.header-title-section{flex-direction:column;align-items:stretch;gap:12px}.header-title-section h1{font-size:20px;text-align:center}.settings-button{width:100%;justify-content:center;padding:12px 16px;font-size:16px}.back-button{padding:10px 14px}.axis-group{padding:12px}.color-input-group{flex-direction:column;align-items:stretch}.preset-colors{justify-content:center}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}@media (prefers-color-scheme: dark){.form-label{color:#e5e7eb}.form-input,.form-textarea{background:#1f2937;border-color:#4b5563;color:#e5e7eb}.form-input:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.form-input:disabled,.form-textarea:disabled{background-color:#374151;color:#9ca3af}.axis-group{background:#1f2937;border-color:#4b5563}.axis-title{color:#e5e7eb}.section-title{color:#e5e7eb;border-color:#4b5563}.character-count{color:#9ca3af}.preview-section{background:#1f2937;border-color:#4b5563}.color-picker,.color-text-input{border-color:#4b5563}.color-text-input{background:#1f2937;color:#e5e7eb}}.graph-invite-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 0;border-bottom:1px solid #e5e7eb;margin-bottom:24px}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.modal-close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close-button:hover{background:#f3f4f6;color:#374151}.modal-content{padding:0 24px}.invite-tabs{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:10px;margin-bottom:24px}.invite-tabs .tab-button{flex:1;padding:12px 16px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-weight:500;color:#6b7280;transition:all .2s ease;font-size:14px}.invite-tabs .tab-button.active{background:#fff;color:#3b82f6;box-shadow:0 2px 4px #0000001a}.permission-selector{margin-bottom:24px}.permission-selector h4{margin:0 0 12px;font-size:1rem;font-weight:600;color:#374151}.permission-options{display:flex;flex-direction:column;gap:8px}.permission-option{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s ease}.permission-option:hover{border-color:#3b82f6;background:#f8faff}.permission-option input[type=radio]{margin:2px 0 0}.permission-info{flex:1;display:flex;flex-direction:column;gap:4px}.permission-title{font-weight:600;color:#374151}.permission-desc{font-size:14px;color:#6b7280}.link-share-section{min-height:200px}.invite-method h4{margin:0 0 8px;font-size:1rem;font-weight:600;color:#374151}.invite-method p{margin:0 0 16px;font-size:14px;color:#6b7280;line-height:1.5}.link-actions{margin-bottom:20px}.invite-link-result{border:1px solid #e5e7eb;border-radius:10px;padding:20px;background:#f9fafb}.link-display{display:flex;gap:12px;margin-bottom:16px}.invite-link-input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;color:#374151;font-family:monospace}.invite-link-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.qr-section{display:flex;flex-direction:column;align-items:center;gap:16px}.qr-code-container{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;background:#fff;border-radius:12px;border:1px solid #e5e7eb}.friends-share-section{min-height:300px}.loading-friends{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.no-friends{text-align:center;padding:60px 20px;color:#6b7280}.no-friends p{margin:0 0 8px}.friends-list h4{margin:0 0 16px;font-size:1rem;font-weight:600;color:#374151}.friends-grid{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:8px;padding:8px}.friend-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.friend-item:hover{background:#f9fafb}.friend-item.selected{background:#eff6ff;border-color:#3b82f6}.friend-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.friend-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.friend-info{flex:1;min-width:0}.friend-name{display:block;font-weight:600;color:#374151;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-email{display:block;font-size:13px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selection-indicator{width:24px;height:24px;border:2px solid #d1d5db;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#3b82f6;transition:all .2s ease}.friend-item.selected .selection-indicator{background:#3b82f6;border-color:#3b82f6;color:#fff}.invite-actions{margin-top:20px;padding:16px;background:#f0f9ff;border-radius:8px;text-align:center}.invite-actions p{margin:0 0 12px;font-weight:500;color:#374151}.modal-footer{padding:20px 24px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}@media (max-width: 640px){.graph-invite-modal{max-width:100%;margin:0;border-radius:16px 16px 0 0;max-height:95vh}.modal-header,.modal-content,.modal-footer{padding-left:20px;padding-right:20px}.permission-options{gap:12px}.link-display{flex-direction:column;gap:8px}.friends-grid{max-height:250px}.invite-tabs .tab-button{font-size:13px;padding:10px 12px}}.invite-handler{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;padding:20px}.invite-container{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:500px;width:100%;overflow:hidden}.invite-content{padding:40px}.invite-header{text-align:center;margin-bottom:30px}.invite-header h2{margin:0 0 8px;color:#1f2937;font-size:24px;font-weight:600}.invite-header p{margin:0;color:#64748b;font-size:16px}.invite-details{margin-bottom:30px}.from-user{display:flex;align-items:center;gap:16px;padding:20px;background:#f8fafc;border-radius:12px;margin-bottom:16px}.user-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:24px}.user-info h3,.user-info h5{margin:0 0 4px;color:#1f2937;font-size:18px;font-weight:600}.user-info p{margin:0;color:#64748b;font-size:14px}.invite-message{padding:16px;background:#f0f9ff;border-left:4px solid #3b82f6;border-radius:8px;margin-bottom:16px}.invite-message p{margin:0;color:#1e40af;font-style:italic}.current-user-info{margin-bottom:30px}.current-user-info h4{margin:0 0 12px;color:#374151;font-size:16px;font-weight:500}.user-card{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e2e8f0;border-radius:8px}.user-card .user-avatar{width:40px;height:40px}.user-card .avatar-placeholder{font-size:16px}.actions{display:flex;gap:12px;margin-bottom:30px}.actions button{flex:1}.invite-info{background:#f8fafc;padding:20px;border-radius:8px;border-left:4px solid #10b981}.invite-info p{margin:0 0 12px;color:#374151;font-weight:500}.invite-info ul{margin:0;padding-left:20px}.invite-info li{margin-bottom:6px;color:#64748b;font-size:14px}.loading-state,.error-state,.success-state,.auth-required{padding:40px;text-align:center}.loading-state{color:#64748b}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.error-state,.success-state{color:#1f2937}.error-icon,.success-icon,.auth-icon{font-size:48px;margin-bottom:16px}.error-state h2,.success-state h2,.auth-required h2{margin:0 0 16px;font-size:24px;font-weight:600}.error-message,.success-message{margin:0 0 24px;color:#64748b;line-height:1.5}.redirect-info{margin:16px 0;padding:12px;background:#f0f9ff;border-radius:6px}.redirect-info p{margin:0;color:#1e40af;font-size:14px}.auth-required{color:#1f2937}.invite-preview{margin:24px 0;padding:20px;background:#f8fafc;border-radius:8px}.invite-preview .from-user{background:#fff;margin-bottom:12px}.invite-preview>p{margin:0;color:#64748b;text-align:center}@media (max-width: 640px){.invite-handler{padding:12px}.invite-content{padding:24px}.from-user{flex-direction:column;text-align:center;gap:12px}.actions{flex-direction:column}.invite-header h2{font-size:20px}}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background-color:#f5f7fa}*{box-sizing:border-box}#root,.App{width:100%;min-height:100vh}.auth-callback{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-callback-content{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 25px #0000001a;text-align:center;max-width:400px;width:90%}.auth-callback-content h2{margin:0 0 16px;color:#1f2937}.auth-callback-content p{margin:8px 0;color:#6b7280}.auth-callback-content.error{border-left:4px solid #ef4444}.auth-callback-content.error h2{color:#dc2626}.loading-spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{to{transform:rotate(360deg)}}
