*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4f46e5;--primary-hover: #4338ca;--success: #16a34a;--danger: #dc2626;--warning: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -4px rgba(0,0,0,.1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.5;min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}input,textarea,select{font:inherit;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);width:100%;transition:border-color .15s}input:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e533}textarea{resize:vertical}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius);border:1px solid transparent;font:inherit;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--gray-200);color:var(--gray-800)}.btn-secondary:hover:not(:disabled){background:var(--gray-300)}.btn-outline{background:#fff;border-color:var(--gray-300);color:var(--gray-700)}.btn-outline:hover:not(:disabled){background:var(--gray-100);border-color:var(--gray-400)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger-text{background:none;border:none;color:var(--danger);cursor:pointer;font:inherit}.btn-danger-text:hover{text-decoration:underline}.btn-sm{padding:.25rem .75rem;font-size:.875rem}.btn-full{width:100%;justify-content:center}.alert{padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1rem}.alert-error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.navbar{display:flex;align-items:center;gap:1.5rem;padding:0 1.5rem;height:56px;background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.navbar-brand{font-size:1.25rem;font-weight:700;color:var(--primary)}.navbar-brand:hover{text-decoration:none}.navbar-links{display:flex;gap:1rem;flex:1}.navbar-links a{color:var(--gray-600);font-size:.875rem;font-weight:500}.navbar-links a:hover{color:var(--primary);text-decoration:none}.navbar-user{display:flex;align-items:center;gap:.75rem}.navbar-username{font-size:.875rem;color:var(--gray-600)}.app{min-height:100vh}.main-content{padding:1.5rem;max-width:1200px;margin:0 auto}.main-content.full{padding:0;max-width:none}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.125rem;color:var(--gray-500)}.loading,.empty-state{text-align:center;padding:3rem;color:var(--gray-500)}.empty-state p{margin-bottom:1rem}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.auth-card{background:#fff;border-radius:12px;padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;color:var(--primary);margin-bottom:.25rem}.auth-header p{color:var(--gray-500)}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--gray-500);font-size:.875rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:var(--gray-700)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-group label{display:flex;align-items:center;gap:.5rem;font-weight:400;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto}.code-input{font-size:1.25rem;text-align:center;letter-spacing:.25rem;text-transform:uppercase}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.dashboard-header h2{font-size:1.5rem}.dashboard-header p{color:var(--gray-500);margin-top:.25rem}.dashboard-actions{display:flex;gap:.75rem}.filter-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.meeting-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.meeting-card{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);border:1px solid var(--gray-200);transition:box-shadow .15s}.meeting-card:hover{box-shadow:var(--shadow-lg)}.meeting-card.ended{opacity:.6}.meeting-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem}.meeting-card-header h3{font-size:1.125rem}.meeting-card-desc{color:var(--gray-500);font-size:.875rem;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.meeting-card-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8125rem;color:var(--gray-500);margin-bottom:.75rem}.meeting-card-join{margin-top:.5rem}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-active{background:#dcfce7;color:#166534}.status-scheduled{background:#fef3c7;color:#92400e}.status-ended{background:var(--gray-200);color:var(--gray-500)}.status-cancelled{background:#fef2f2;color:#991b1b}.meeting-room{display:flex;flex-direction:column;height:calc(100vh - 56px)}.meeting-topbar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#fff;border-bottom:1px solid var(--gray-200)}.meeting-info{display:flex;align-items:center;gap:1rem}.meeting-info h3{font-size:1.125rem}.room-code{font-family:monospace;background:var(--gray-100);padding:.25rem .5rem;border-radius:4px;font-size:.875rem}.meeting-controls{display:flex;gap:.5rem}.meeting-body{display:flex;flex:1;overflow:hidden}.meeting-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.meeting-sidebar{width:250px;background:#fff;border-left:1px solid var(--gray-200);padding:1rem;overflow-y:auto;flex-shrink:0}.meeting-sidebar h4{margin-bottom:.75rem;font-size:.875rem;color:var(--gray-600)}.participant-list{list-style:none}.participant-list li{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--gray-100);font-size:.875rem}.participant-list li.is-you{color:var(--primary);font-weight:500}.participant-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700}.you-tag{font-size:.75rem;color:var(--gray-400)}.video-container{background:var(--gray-900)}.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem;padding:.75rem;min-height:200px;max-height:400px;overflow-y:auto}.video-tile{position:relative;background:var(--gray-800);border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3}.video-element{width:100%;height:100%;object-fit:cover}.video-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;color:var(--gray-400);gap:.5rem}.video-placeholder.connecting{background:var(--gray-750)}.connecting-text{font-size:.75rem;color:var(--gray-400)}.avatar-placeholder{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--gray-600);color:#fff;font-size:1.5rem;font-weight:700}.video-label{position:absolute;bottom:0;left:0;right:0;padding:.25rem .5rem;background:#0009;color:#fff;font-size:.75rem}.video-controls-overlay{position:absolute;top:.25rem;right:.25rem;display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.video-tile:hover .video-controls-overlay{opacity:1}.ctrl-btn{width:32px;height:32px;border-radius:50%;border:none;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#00000080;transition:background .15s}.ctrl-btn.on{background:#00000080}.ctrl-btn.off{background:#dc2626cc}.ctrl-btn.disabled{opacity:.4;cursor:not-allowed;background:#64646480}.ctrl-btn:hover{background:#000000bf}.panel-tabs{display:flex;border-bottom:1px solid var(--gray-200)}.tab-btn{flex:1;padding:.5rem;border:none;background:none;font:inherit;font-size:.875rem;font-weight:500;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-btn:hover{color:var(--gray-700)}.panel-content{flex:1;overflow:hidden;display:flex;flex-direction:column}.chat-panel{display:flex;flex-direction:column;height:100%}.chat-messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.chat-msg{max-width:80%;padding:.5rem .75rem;border-radius:var(--radius);background:var(--gray-100)}.chat-msg.own{align-self:flex-end;background:var(--primary);color:#fff}.chat-msg.system{align-self:center;background:transparent;color:var(--gray-400);font-size:.8125rem;text-align:center;max-width:100%}.chat-author{display:block;font-size:.75rem;font-weight:600;margin-bottom:.125rem}.chat-msg.own .chat-author{color:#fffc}.chat-text{font-size:.875rem;word-break:break-word}.chat-time{display:block;font-size:.6875rem;color:var(--gray-400);margin-top:.125rem}.chat-msg.own .chat-time{color:#fff9}.chat-input{display:flex;gap:.5rem;padding:.5rem .75rem;border-top:1px solid var(--gray-200);background:#fff}.chat-input input{flex:1}.file-panel{padding:.75rem;overflow-y:auto}.file-upload-row{margin-bottom:.75rem}.upload-btn{cursor:pointer}.file-list{list-style:none}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--gray-100);gap:.5rem}.file-info{flex:1;min-width:0}.file-name{display:block;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{font-size:.75rem;color:var(--gray-500)}.file-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.create-meeting{max-width:640px;margin:0 auto}.create-meeting h2{margin-bottom:1.5rem}.meeting-form{background:#fff;padding:1.5rem;border-radius:var(--radius);box-shadow:var(--shadow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:#fff;border-radius:12px;padding:1.5rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.modal h3{margin-bottom:1rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}@media (max-width: 768px){.meeting-body{flex-direction:column}.meeting-sidebar{width:100%;max-height:200px;border-left:none;border-top:1px solid var(--gray-200)}.dashboard-header{flex-direction:column}.form-row{grid-template-columns:1fr}.video-grid{max-height:240px}.navbar-right{gap:.5rem}.lang-switcher{font-size:.75rem;padding:.2rem}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:380px}.toast{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:var(--radius);box-shadow:var(--shadow-lg);cursor:pointer;animation:toast-in .3s ease-out;font-size:.875rem;font-weight:500}.toast-info{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.toast-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.toast-warn{background:#fefce8;color:#92400e;border:1px solid #fef08a}.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast-icon{font-size:1rem;flex-shrink:0}.toast-msg{flex:1}@keyframes toast-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.navbar-right{display:flex;align-items:center;gap:.75rem}.lang-switcher{padding:.25rem .5rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.8125rem;background:#fff;color:var(--gray-700);cursor:pointer;outline:none}.lang-switcher:focus{border-color:var(--primary)}.perm-warn{font-size:2rem;margin-bottom:.25rem}.perm-text{font-size:.75rem;color:var(--gray-400);text-align:center;padding:0 1rem}.screen-share-tile{border:2px solid #f59e0b}.file-hint{font-size:.75rem;color:var(--gray-400);margin-left:.5rem}
