:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh}button{font-family:inherit}:root{--bg: #050816;--bg-elevated: #0c1220;--bg-softer: #101729;--border-subtle: rgba(255, 255, 255, .06);--border-strong: rgba(255, 255, 255, .14);--text-main: #f9fafb;--text-muted: #9ca3af;--primary: #4f46e5;--primary-soft: rgba(79, 70, 229, .12);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .18);--radius-lg: 18px;--radius-xl: 24px;--shadow-soft: 0 20px 45px rgba(0, 0, 0, .45);--shadow-subtle: 0 10px 25px rgba(0, 0, 0, .35)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;scroll-behavior:smooth}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;background:radial-gradient(circle at top,#1d2539 0,#050816 55%);color:var(--text-main);overflow:hidden}.app-shell{height:100%;min-height:100vh;display:flex;flex-direction:column;padding:16px;overflow:hidden}.lobby{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;overflow:hidden}.role-select{flex:1;display:flex;align-items:center;justify-content:center}.role-card,.login-card{width:100%;max-width:760px;padding:28px;border-radius:var(--radius-xl);background:linear-gradient(135deg,#0f172afa,#090c18fa);border:1px solid rgba(148,163,184,.18);box-shadow:var(--shadow-soft)}.role-select__options{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:20px}.role-select__option{border-radius:16px;border:1px solid var(--border-subtle);background:#0f172ab3;color:var(--text-main);padding:14px;text-align:left;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,transform .08s ease}.role-select__option--active{border-color:#818cf8cc;box-shadow:0 0 0 1px #818cf880;transform:translateY(-1px)}.role-select__title{font-weight:600;margin-bottom:6px}.login{flex:1;display:flex;align-items:center;justify-content:center}.login-card{max-width:720px}.modal-backdrop{position:fixed;inset:0;background:#0009;display:grid;place-items:center;z-index:20}.modal{background:#0f172afa;border-radius:16px;padding:20px;border:1px solid var(--border-strong);box-shadow:var(--shadow-soft);max-width:360px;width:100%}.modal__title{font-size:16px;font-weight:600;margin-bottom:8px}.modal__body{font-size:14px;color:var(--text-muted);margin-bottom:12px}.lobby-card{display:grid;gap:24px;width:100%;max-width:720px;max-height:calc(100vh - 40px);padding:24px;background:linear-gradient(135deg,#0f172afa,#111827f5);border-radius:var(--radius-xl);border:1px solid rgba(148,163,184,.18);box-shadow:var(--shadow-soft);overflow:auto}.app-title{font-size:26px;font-weight:650;letter-spacing:.02em;margin-bottom:8px}.app-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:24px;max-width:420px}.section-title{font-size:16px;margin-bottom:8px}.form{display:flex;flex-direction:column;gap:14px}.form__group{display:flex;flex-direction:column;gap:6px}.form label{font-size:13px;color:var(--text-muted)}input,select{border-radius:10px;border:1px solid var(--border-subtle);background:#0f172af5;color:var(--text-main);padding:9px 10px;font-size:14px;outline:none;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}input::placeholder{color:#94a3b8cc}input:focus,select:focus{border-color:#4f46e5b3;box-shadow:0 0 0 1px #4f46e566;background:#0f172a}.btn{border-radius:999px;border:1px solid transparent;font-size:14px;padding:9px 18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:background .16s ease,transform .1s ease,box-shadow .16s ease,border-color .16s ease}.btn-small{padding:6px 12px;font-size:12px}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 10px 25px #4f46e566}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 16px 30px #4f46e580}.btn-secondary{background:var(--primary-soft);color:#e5e7eb;border-color:#818cf859}.btn-secondary:hover{background:#4f46e53d}.btn-ghost{background:transparent;color:#e5e7eb;border-color:#94a3b873}.btn-ghost:hover{background:#94a3b81a}.btn-danger{background:var(--danger-soft);color:#fecaca;border-color:#ef4444a6}.btn-danger:hover{background:#ef444452}.lobby-card__left{padding:8px}.lobby-card__right{padding:8px;border-radius:var(--radius-lg);background:radial-gradient(circle at top left,#111827 0,#020617 75%);border:1px solid rgba(148,163,184,.25)}.role-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:12px;background:#0f172acc;border:1px solid var(--border-subtle);margin-bottom:14px}.role-banner__value{font-weight:600}.templates{display:flex;flex-direction:column;gap:16px}.templates__list{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;max-height:360px;overflow-y:auto;padding-right:6px}.template-card{background:#0f172a99;border-radius:16px;border:1px solid var(--border-subtle);padding:8px;cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease}.template-card__preview{border-radius:10px;background-size:cover;background-position:center;height:72px}.template-card__body{display:flex;flex-direction:column;gap:2px}.template-card__title{font-size:13px;font-weight:500}.template-card--active{border-color:#818cf8e6;background:radial-gradient(circle at top,#111827 0,#020617 65%);box-shadow:0 0 0 1px #818cf866;transform:translateY(-1px)}.create-card{margin-top:4px;padding:10px;border-radius:16px;background:#0f172acc;border:1px dashed rgba(148,163,184,.5);display:flex;flex-direction:column;gap:8px;font-size:13px}.status{font-size:13px;margin-top:10px;color:#e5e7eb}.status--inline{margin-top:8px}.status--room{position:fixed;left:16px;bottom:16px;padding:8px 12px;border-radius:999px;background:#0f172aeb;border:1px solid rgba(148,163,184,.4)}.room{display:flex;flex-direction:column;gap:10px;height:calc(100vh - 32px);min-height:0}.room__header{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-radius:18px;background:#0f172af0;border:1px solid rgba(148,163,184,.26);box-shadow:var(--shadow-subtle);gap:12px}.room__title-block{min-width:0}.room__title-text{font-size:16px;font-weight:500;display:flex;align-items:baseline;gap:6px}.room__code{font-size:12px;color:var(--text-muted)}.room__me{text-align:right;min-width:0}.room__me-name{font-size:14px}.room__actions{display:flex;align-items:center;gap:8px}.room__body{flex:1;display:grid;grid-template-columns:minmax(0,1fr);gap:12px;min-height:0}.room__main{border-radius:18px;background:radial-gradient(circle at top,#060918 0,#0a1021 65%);border:1px solid rgba(15,23,42,.92);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-soft);min-height:0;position:relative}.room__canvas{position:relative;flex:1;overflow:hidden;background-size:cover;background-position:center;touch-action:none}.room__canvas-inner{position:relative}.tile{position:absolute;width:140px;height:140px;border-radius:18px;overflow:hidden;background:#0f172af5;border:1px solid rgba(148,163,184,.5);box-shadow:0 10px 18px #00000047;display:flex;flex-direction:column;cursor:grab;-webkit-user-select:none;user-select:none;transition:box-shadow .12s ease,transform .06s ease,border-color .12s ease;touch-action:none}.tile:active{transform:scale(.99);box-shadow:0 12px 22px #0009}.tile__video{flex:1;background:#020617}.tile__video video{width:100%;height:100%;object-fit:cover}.tile__placeholder{width:100%;height:100%;display:grid;place-items:center;font-size:12px;color:var(--text-muted)}.tile__name{padding:4px 8px;font-size:11px;display:flex;align-items:center;justify-content:space-between;background:#0f172afa}.tile__badge{margin-left:6px;font-size:10px;padding:2px 6px;border-radius:999px;background:#22c55e33;color:#bbf7d0}.seat{position:absolute;min-width:56px;padding:4px 8px;border-radius:999px;border:1px dashed rgba(148,163,184,.7);background:#0f172ae0;font-size:11px;display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);cursor:pointer}.seat--occupied{background:#4f46e533;border-style:solid}.seat--self{border-color:#818cf8f2;box-shadow:0 0 0 1px #818cf8b3}.seat__label{font-weight:500}.seat__occupant{font-size:10px;color:#e5e7eb}.mini-map{position:absolute;right:16px;bottom:16px;width:190px;padding:8px;border-radius:14px;background:#0f172af0;border:1px solid rgba(148,163,184,.4);font-size:10px}.room__toolbar{position:sticky;bottom:0;padding:12px 14px;border-top:1px solid rgba(148,163,184,.16);display:flex;align-items:center;justify-content:center;gap:12px;background:linear-gradient(180deg,#060916e6,#060916eb);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 -6px 24px #0000004d;flex-wrap:wrap}.toolbar-btn{font-size:13px;border-radius:14px;border:1px solid rgba(148,163,184,.45);padding:10px 14px;background:linear-gradient(145deg,#111827eb,#0f172ad1);color:#e5e7eb;cursor:pointer;box-shadow:0 10px 22px #00000052;min-width:120px}.toolbar-btn:hover{background:#1f2937f0}.toolbar-btn--muted{border-color:#f87171e6;background:#7f1d1dcc;color:#fecaca}.muted{color:var(--text-muted);font-size:12px}.fullscreen-exit{position:absolute;top:12px;right:12px;z-index:2;padding:6px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.6);background:#0f172ae6;color:#e5e7eb;cursor:pointer}.room--fullscreen{height:100vh;padding:0}.room--fullscreen .room__header,.room--fullscreen .sidebar,.room--fullscreen .mini-map{display:none}.room--fullscreen .room__body{grid-template-columns:1fr;height:100%}.room--fullscreen .room__main,.room--fullscreen .room__canvas{border-radius:0}.room--fullscreen .room__toolbar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#04060cb3;border:1px solid var(--border-strong);border-radius:14px;box-shadow:var(--shadow-subtle)}.room--fullscreen .room__toolbar .toolbar-btn{background:#0f172adb}@media(max-width:900px){.lobby-card{grid-template-columns:minmax(0,1fr);padding:18px}.room__body{grid-template-columns:minmax(0,1fr)}.sidebar{order:2;max-height:180px}.room__main{order:1}.room{height:calc(100vh - 24px)}.room__header{flex-wrap:wrap;gap:10px}.room__actions{width:100%;justify-content:flex-end;flex-wrap:wrap}.mini-map{display:none}}@media(max-width:600px){.app-shell{padding:8px}.lobby-card{box-shadow:none;border-radius:16px}.room__header{padding:10px 12px}.room__main{border-radius:14px}.tile{width:120px;height:120px}}
