*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background-color:#18191c;color:#e4e6eb;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}img,video{max-width:100%;height:auto}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}*{scrollbar-width:thin;scrollbar-color:#3a3d44 transparent}*::-webkit-scrollbar{width:10px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background-color:#3a3d44;border-radius:8px}*::-webkit-scrollbar-thumb:hover{background-color:#4a4e57}.auth-page{min-height:calc(100vh - 64px);display:grid;grid-template-columns:1fr 1.2fr;background:#18191c;color:#fff}.auth-form-wrapper{display:flex;align-items:center;justify-content:center}.auth-form{width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}.auth-title{font-size:32px;margin:0}.auth-form input{background:#232428;border:1px solid rgba(255,255,255,.08);border-radius:10px;height:44px;padding:0 14px;line-height:44px;margin:0;color:#fff;font-size:15px}.auth-form input::placeholder{color:#fff6}.auth-form input:focus{outline:none;border-color:#ffffff40}.password-field{position:relative;width:100%}.password-field input{width:100%;padding-right:44px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(calc(-50% + 1px))!important;background:none;border:none;padding:0;cursor:pointer}.password-toggle svg{display:block;width:20px;height:20px;stroke:#ffffff8c;fill:none;stroke-width:1.8;transform:none!important}.password-toggle:hover svg{stroke:#ffffffd9}.auth-button{min-height:44px;border-radius:10px;border:none;background:#3198cb;color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin:0;transition:background-color .2s ease}.auth-button:hover{background:#0c4862}.auth-error{color:#ff6b6b;font-size:14px;margin:0}.login-actions{display:flex;gap:12px;margin:0}.login-secondary-btn{flex:1;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:#3198cb;color:#fff;font-size:14px;font-weight:500;text-decoration:none;transition:background-color .2s ease}.login-secondary-btn:hover{background:#0c4862}.role-switch{display:flex;gap:12px;margin:0}.role-switch button{flex:1;min-height:44px;border-radius:10px;border:none;background:#3198cb;color:#fff;font-size:14px;cursor:pointer;transition:background-color .2s ease}.role-switch button.active,.role-switch button:hover{background:#0c4862}.auth-visual{display:flex;align-items:center;justify-content:center;padding:32px}.auth-visual-inner{width:100%;height:100%;background:#232428;border-radius:20px;position:relative;box-shadow:0 0 0 1px #ffffff0f,0 30px 80px #0009}.auth-grid{position:absolute;inset:16px;border-radius:16px;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:32px 32px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:500;color:#ffffffb3;text-align:center;padding:16px}@media(max-width:768px){.auth-page{display:flex;flex-direction:column;min-height:calc(100vh - 64px)}.auth-visual{order:-1;padding:12px 16px 0}.auth-visual-inner{aspect-ratio:16 / 9;height:auto}.auth-grid{font-size:14px}.auth-form-wrapper{order:0;align-items:flex-start;justify-content:flex-start;padding:16px 16px 24px}.auth-title{font-size:26px}}.dashboard-page{height:calc(100vh - 64px);padding:24px;background:#18191c;color:#fff;position:relative}.rooms-btn{position:absolute;top:24px;left:24px;width:220px;height:72px;border-radius:16px;border:1px solid rgba(255,255,255,.08);background:#1f2024;color:#fff;font-size:18px;font-weight:600;letter-spacing:.2px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,transform .1s ease,box-shadow .15s ease,border-color .15s ease}@media(hover:hover)and (pointer:fine){.rooms-btn:hover{background:#2a2d33;border-color:#ffffff29;box-shadow:0 0 0 1px #ffffff0a,0 8px 24px #00000059}}.rooms-btn:active{transform:translateY(1px)}.dashboard-right{position:absolute;right:24px;top:24px;width:320px;display:flex;flex-direction:column;gap:16px}.card{background:#18191c;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px}.card h3{margin:0 0 12px;font-size:16px;font-weight:600}.profile-card{display:grid;grid-template-columns:1fr;gap:12px}.profile-inner{background:#1f2024;border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:12px;width:100%;box-sizing:border-box}.profile-card h3{opacity:.85}.profile-grid{display:grid;grid-template-columns:auto 1fr;row-gap:8px;column-gap:16px;font-size:14px}.profile-grid .label{color:#fff9;text-align:left}.profile-grid .value{color:#fff}.contacts-card{height:420px;display:flex;flex-direction:column}.add-contact{display:flex;gap:8px;margin-bottom:12px}.add-contact input{flex:1;background:#18191c;border:1px solid #333;border-radius:8px;padding:8px;color:#fff}.add-contact button{width:44px;height:44px;border-radius:12px;padding:0;display:flex;align-items:center;justify-content:center;font-size:26px;line-height:1}.add-contact button span{transform:translateY(-2px);display:block}.contacts-inner{flex:1;background:#1f2024;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:12px}.contacts-list{height:100%;overflow-y:scroll;padding-right:10px;display:flex;flex-direction:column;gap:12px;scrollbar-gutter:stable}.contacts-list::-webkit-scrollbar{width:8px}.contacts-list::-webkit-scrollbar-track{background:transparent}.contacts-list::-webkit-scrollbar-thumb{background-color:#3a3d44;border-radius:6px}.contacts-list::-webkit-scrollbar-thumb:hover{background-color:#4a4e57}.contact-item{display:flex;justify-content:space-between;align-items:center;background:#18191c;padding:10px 12px;border-radius:10px}.contact-item button{background:none;border:none;color:#ff5c5c;cursor:pointer;display:flex;align-items:center;justify-content:center}.toast{position:fixed;top:24px;left:50%;transform:translate(-50%);padding:12px 20px;border-radius:12px;font-weight:500;opacity:.9;z-index:1000}.toast.success{background:#2ecc71d9}.toast.error{background:#e74c3cd9}@media(max-width:768px){.dashboard-page{display:flex;flex-direction:column;gap:16px}.dashboard-right{position:static;width:100%;display:contents}.profile-card{order:1}.rooms-btn{order:2}.contacts-card{order:3}.rooms-btn{position:static;width:100%;height:72px;border-radius:18px;font-size:18px;font-weight:600;margin:0}.contacts-card{height:auto}.contacts-list{overflow-y:auto;padding-right:0;scrollbar-gutter:auto}.profile-inner{padding:12px}.contact-item{margin-right:0}.contact-item button span{transform:translateY(2px);display:block}.profile-inner{width:100%;box-sizing:border-box}}@media(max-width:768px){.profile-grid{font-size:12px}}@media(max-width:768px){.add-contact button span{transform:translateY(1px)}}.rooms-page{min-height:calc(100vh - 64px);background:#18191c;color:#fff;padding:24px}.rooms-shell{width:100%;max-width:980px;margin:0 auto}.rooms-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:9999;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);box-shadow:0 16px 40px #00000059;max-width:min(520px,calc(100vw - 24px));text-align:center}.rooms-toast.success{background:#32b4782e}.rooms-toast.error{background:#dc50502e}.rooms-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.rooms-title-block{display:flex;flex-direction:column;gap:4px}.rooms-title{font-size:26px;font-weight:700;letter-spacing:.2px}.rooms-subtitle{font-size:14px;color:#ffffffad}.rooms-back{min-height:64px;padding:0 18px;display:flex;align-items:center;border-radius:12px;cursor:pointer;color:#fff;background:#ffffff0f;border:1px solid rgba(255,255,255,.1)}.rooms-back:hover{background:#ffffff17}.rooms-back:active{transform:translateY(1px)}.rooms-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;box-shadow:0 18px 40px #00000047;margin-bottom:14px}.rooms-card-head{margin-bottom:12px}.rooms-card-head-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.rooms-card-title{font-size:16px;font-weight:700;margin-bottom:4px}.rooms-card-hint{font-size:13px;color:#ffffff9e}.rooms-create-row{display:flex;gap:10px}.rooms-input{flex:1;height:42px;border-radius:12px;padding:0 14px;background:#232428;border:1px solid rgba(255,255,255,.1);color:#fff;outline:none;font-size:15px;box-sizing:border-box}.rooms-input::placeholder{color:#ffffff73}.rooms-input:focus{border-color:#78b4ff73;box-shadow:0 0 0 3px #78b4ff1f}.rooms-primary,.rooms-ghost{height:42px;padding:0 14px;border-radius:12px;cursor:pointer;font-size:14px;color:#fff;border:1px solid rgba(255,255,255,.12)}.rooms-primary{background:#78b4ff38}.rooms-primary:hover{background:#78b4ff47}.rooms-primary:active{transform:translateY(1px)}.rooms-primary:disabled{opacity:.45;cursor:not-allowed}.rooms-ghost{background:#ffffff0f}.rooms-ghost:hover{background:#ffffff17}.rooms-ghost:active{transform:translateY(1px)}.rooms-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.room-card{border-radius:16px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);display:grid;grid-template-rows:auto auto 1fr;row-gap:12px;min-width:0}.room-card-top{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;min-width:0}.room-card-title{min-width:0;font-size:16px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-status{font-size:12px;padding:5px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);white-space:nowrap}.room-status.open{background:#32b47829}.room-status.closed{background:#dc505029}.room-card-meta{display:grid;row-gap:6px}.room-meta-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;min-width:0;font-size:13px;color:#ffffffa6}.room-meta-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.8}.room-meta-row b{white-space:nowrap;color:#fff;font-weight:700}.room-card-actions{display:flex;align-items:flex-end}.rooms-empty{padding:14px 10px;border-radius:14px;color:#ffffffad;background:#ffffff08;border:1px dashed rgba(255,255,255,.12)}.rooms-skeleton-line{height:14px;border-radius:999px;margin-bottom:10px;background:#ffffff12}.rooms-skeleton-line:last-child{margin-bottom:0}@media(max-width:980px){.rooms-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.rooms-page{padding:16px}.rooms-title{font-size:22px}.rooms-create-row{flex-direction:column}.rooms-grid{grid-template-columns:1fr}.room-card-actions{justify-content:flex-end}}@media(max-width:420px){.rooms-back{min-height:62px;padding:0 12px}.rooms-primary,.rooms-ghost{height:40px}.rooms-input{min-height:40px;padding:5px 15px;font-size:16px;line-height:1.2}}.wb-root{height:100%;min-height:0;display:flex}.wb-card{width:100%;height:100%;min-height:0;display:flex;flex-direction:column;background:#121318;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden}.wb-topbar{height:34px;display:flex;align-items:center;gap:10px;padding:4px 10px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.08)}.wb-topbarSpacer{flex:1}.wb-topbarMeta{height:24px;padding:0 10px;display:flex;align-items:center;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#1a1b22}.wb-topbarMetaText{font-size:12px;color:#ffffffd9}.wb-boardPicker{position:relative;display:flex;align-items:center;gap:8px}.wb-boardBtn{height:24px;display:flex;align-items:center;gap:8px;max-width:320px;padding:0 10px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#1a1b22;color:#fff;cursor:pointer}.wb-boardBtnTitle{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.wb-boardBtnIcon{display:flex;align-items:center;justify-content:center;width:14px;height:14px;opacity:.9}.wb-boardBtnIcon svg{width:14px;height:14px}.wb-boardMenu{position:absolute;top:30px;left:0;width:280px;background:#14151b;border:1px solid rgba(255,255,255,.1);border-radius:14px;box-shadow:0 10px 30px #00000073;padding:8px;z-index:20}.wb-boardMenuList{max-height:280px;overflow:auto;padding-right:2px}.wb-boardRow{display:flex;align-items:center;gap:6px;border-radius:12px;padding:4px}.wb-boardRow.active{background:#ffffff0f}.wb-boardRowMain{flex:1;height:30px;display:flex;align-items:center;border:none;background:transparent;color:#fff;cursor:pointer;padding:0 8px;border-radius:10px;font-size:12px}.wb-boardRowMain:hover{background:#ffffff0f}.wb-boardRowTitle{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wb-boardRowActions{display:flex;gap:6px;padding-right:2px}.wb-miniIcon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#1a1b22;color:#ffffffe6;cursor:pointer}.wb-miniIcon svg{width:16px;height:16px}.wb-miniIcon:disabled{opacity:.35;cursor:not-allowed}.wb-miniIcon.danger{color:#ff6b6b;border-color:#ff6b6b59}.wb-boardCreate{margin-top:8px;height:32px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#1a1b22;color:#fff;cursor:pointer;font-size:12px}.wb-boardCreateIcon{width:16px;height:16px;display:flex}.wb-boardCreateIcon svg{width:16px;height:16px}.wb-body{flex:1;min-height:0;display:flex;gap:10px;padding:10px}.wb-canvasCard{flex:1;min-width:0;min-height:0;border-radius:14px;overflow:hidden;background:#fff;border:1px solid rgba(0,0,0,.08)}.wb-canvasWrap{width:100%;height:100%;min-height:0;position:relative;background:#fff;-webkit-user-select:none;user-select:none}.wb-canvasWrap canvas{width:100%;height:100%;display:block}.wb-followHint{position:absolute;top:10px;left:10px;padding:6px 8px;border-radius:10px;background:#0000008c;color:#fff;font-size:12px}.wb-toolbar{width:92px;min-width:92px;min-height:0;display:flex;flex-direction:column;gap:10px;background:#121318;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px 8px;position:relative}.wb-spacer{flex:1}.wb-iconBtn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#1a1b22;color:#ffffffeb;cursor:pointer;position:relative}.wb-iconBtn svg{width:20px;height:20px}.wb-iconBtn:hover{background:#20222b}.wb-iconBtn.active{background:#6366f12e;border-color:#6366f166}.wb-iconBtn:disabled{opacity:.4;cursor:not-allowed}.wb-iconBtn.disabled{opacity:.45;cursor:not-allowed}.wb-badge{position:absolute;right:4px;bottom:4px;font-size:10px;line-height:1;padding:2px 4px;border-radius:7px;background:#00000059;border:1px solid rgba(255,255,255,.12);color:#ffffffe6}.wb-settings{display:flex;flex-direction:column;gap:10px}.wb-colorGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.wb-colorBtn{width:36px;height:36px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#1a1b22;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center}.wb-colorBtn.active{outline:2px solid rgba(99,102,241,.7);outline-offset:1px}.wb-colorCustom{position:relative}.wb-colorCustom input[type=color]{position:absolute;inset:0;opacity:0;cursor:pointer}.wb-colorCustomInner{position:absolute;inset:6px;border-radius:10px;border:1px solid rgba(0,0,0,.18)}.wb-settingsGrid{margin-top:2px}@keyframes wbFlyIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.wb-flyoutTitle{font-size:12px;color:#fff;margin-bottom:8px;font-weight:700}.wb-flyoutRow{display:flex;align-items:center;gap:10px}.wb-flyoutRow input[type=range]{width:100%}.wb-flyoutValue{width:54px;text-align:right;font-size:12px;color:#ffffffd9}.wb-usersList{max-height:240px;overflow:auto;display:flex;flex-direction:column;gap:6px;padding-right:2px}.wb-userRow{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;color:#ffffffe6;font-size:12px}.wb-userRow:hover{background:#ffffff0f}.wb-userRow input{accent-color:#6366f1}.wb-userName{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wb-flyoutNote{margin-top:10px;font-size:11px;color:#ffffffa6}.wb-iconBtn{width:40px;height:40px;border-radius:10px}.wb-card{background:transparent;border:none;border-radius:0;overflow:visible}.wb-body{padding:0}.wb-canvasCard{border:none}.wb-topbar{height:32px;padding:0;background:transparent;border:none;border-radius:0}.wb-canvasWrap{position:relative}.wb-canvas.grid{z-index:0;pointer-events:none}.wb-canvas.main{z-index:1}.wb-canvasWrap{position:relative;width:100%;height:100%}.wb-canvas{position:absolute;inset:0}.wb-canvas.grid{z-index:1}.wb-canvas.eraser{z-index:2;pointer-events:none}.wb-canvas.main{z-index:3}.wb-toolbar{width:88px;min-width:88px;padding:8px 6px;gap:10px;background:transparent;border:none}.wb-toolGrid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.wb-iconBtn{width:32px;height:32px;border-radius:10px}.wb-divider{height:1px;margin:6px 0}.wb-toolbar{width:108px;min-width:108px;padding:8px;gap:10px;background:transparent;border:none;border-radius:0}.wb-toolGrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.wb-iconBtn{width:32px;height:32px;border-radius:9px}.wb-colorBtn{width:32px;height:32px;border-radius:9px;padding:0;margin:0;box-shadow:inset 0 0 0 1px #ffffff1f}.wb-colorBtn.active{outline:2px solid #6c7cff;outline-offset:1px}.wb-colorBtn>span,.wb-colorBtn>div{border-radius:inherit}.wb-iconBtn[data-tool=width],.wb-iconBtn[data-tool=text]{background:var(--wb-btn-bg);border:var(--wb-btn-border);box-shadow:var(--wb-btn-shadow)}.wb-flyout{position:absolute;left:calc(100% + 12px);top:0;background:#1f2126;border-radius:12px;padding:12px;box-shadow:0 8px 24px #00000059,inset 0 0 0 1px #ffffff0f;z-index:50}.wb-flyout input[type=range]{width:160px;accent-color:#6c7cff}.wb-toolGroup{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;justify-items:center}.wb-iconBtn{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center}.wb-flyout--compact{padding:10px 12px;width:auto;min-width:220px}.wb-flyoutRow--compact{display:flex;align-items:center;gap:10px}.wb-flyoutLabel{font-size:13px;color:#cfd3ff;white-space:nowrap}.wb-flyoutRow--compact input[type=range]{flex:1}.wb-flyoutValue{min-width:42px;text-align:right;font-size:12px;opacity:.85}.wb-flyout.wb-flyout--compact{height:auto!important;min-height:unset!important;padding:8px 10px!important;display:flex!important;align-items:center!important;border-radius:10px}.wb-flyoutRow--compact{display:flex;align-items:center;height:28px;gap:10px;width:100%}.wb-flyoutValue{min-width:44px;text-align:right;font-size:12px;line-height:1;opacity:.85}.wb-flyout--compact input[type=range]{height:16px;margin:0}.wb-flyout{position:absolute;z-index:60;background:#1f2126;border-radius:12px;border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 30px #00000073;padding:10px 12px}.wb-flyout.wb-flyout--compact{left:calc(100% + 12px);top:50%;transform:translateY(-50%);width:auto;min-width:260px;max-width:320px;height:auto;min-height:0;padding:8px 10px}.wb-flyoutRow--compact{display:flex;align-items:center;gap:10px;height:28px;width:100%}.wb-flyoutLabel{white-space:nowrap;font-size:13px;color:#ffffffe6}.wb-flyoutRow--compact input[type=range]{flex:1;height:16px;margin:0;accent-color:#6c7cff}.wb-flyoutValue{min-width:44px;text-align:right;font-size:12px;line-height:1;color:#ffffffd9}.wb-flyout.users{left:calc(100% + 12px);top:80px;transform:none;width:240px;padding:10px}.wb-flyout.wb-flyout--compact{width:330px;min-width:330px;max-width:330px;padding:8px 10px}.wb-flyoutRow--compact{height:28px;gap:8px}.wb-flyoutLabel{width:64px;flex:0 0 64px}.wb-flyoutRow--compact input[type=range]{flex:0 0 200px;width:200px}.wb-flyoutValue{flex:0 0 48px;width:48px;text-align:left;margin-left:2px}.wb-flyout.wb-flyout--compact{padding-right:14px}.room-page{height:calc(100vh - 64px);min-height:calc(100vh - 64px);background:#18191c;color:#fff;padding:12px;overflow:hidden;display:flex;flex-direction:column;gap:10px}@supports (height: 100dvh){.room-page{height:calc(100dvh - 64px);min-height:calc(100dvh - 64px)}}.room-state{padding:24px;color:#fff;background:#18191c;min-height:calc(100vh - 64px)}.room-header{background:#1f2024;border:1px solid rgba(255,255,255,.08);border-radius:14px}.room-header-compact{padding:8px 10px}.room-header-row{display:flex;align-items:center;gap:10px;min-height:42px}.room-header-left,.room-header-center,.room-header-right{display:flex;align-items:center;gap:10px}.room-header-left{flex:1;min-width:240px}.room-header-center{justify-content:center}.room-header-right{justify-content:flex-end;gap:8px;flex-wrap:wrap}.room-title-wrap-compact{display:flex;align-items:center;gap:10px;min-width:0}.room-title-compact{font-size:14px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:420px}.room-status-badge{font-size:11px;padding:5px 9px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;font-weight:800;white-space:nowrap}.room-status-badge.open{color:#a9f5c6}.room-status-badge.closed{color:#ffb0b0}.room-btn{background:#232428;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:10px 12px;cursor:pointer;font-weight:800;font-size:13px;line-height:1;transition:transform .05s ease,background .15s ease,border-color .15s ease,opacity .15s ease;white-space:nowrap}.room-btn:hover{background:#2a2b30;border-color:#ffffff2e}.room-btn:active{transform:translateY(1px)}.room-btn:disabled{opacity:.5;cursor:not-allowed}.room-btn-sm{padding:8px 10px;font-size:12px;border-radius:9px}.room-btn-ghost{background:transparent;border-color:#ffffff1a}.room-btn-success{background:#26af6038;border-color:#26af6059}.room-btn-danger{background:#d23c3c38;border-color:#d23c3c59}.room-btn-danger-outline{background:transparent;border-color:#d23c3c8c;color:#ffb0b0}.room-input,.room-select{background:#232428;border:1px solid rgba(255,255,255,.1);color:#fff;border-radius:10px;padding:10px 12px;font-size:13px}.room-input{width:100%}.room-input::placeholder{color:#ffffff73}.room-controls{display:flex;align-items:center;gap:8px}.room-ctl{width:40px;height:40px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;cursor:pointer;display:grid;place-items:center;padding:0;transition:transform .06s ease,background .15s ease,border-color .15s ease,opacity .15s ease}.room-ctl svg{width:20px;height:20px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.room-ctl.is-on{background:#26af6033;border-color:#26af6059}.room-ctl.is-off{background:#ffffff0d;border-color:#ffffff1f}.room-ctl.is-warn.is-on{background:#d23c3c33;border-color:#d23c3c59}.room-ctl:hover{background:#ffffff14;border-color:#ffffff2e}.room-ctl.is-on:hover{background:#26af6042;border-color:#26af6073}.room-ctl.is-warn.is-on:hover{background:#d23c3c42;border-color:#d23c3c73}.room-ctl:active{transform:translateY(1px)}.room-ctl:disabled{opacity:.45;cursor:not-allowed}.room-main{flex:1;min-height:0;display:grid;grid-template-columns:1fr 360px;gap:10px}.room-panel{background:#1f2024;border:1px solid rgba(255,255,255,.08);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;min-height:0}.room-panel-tight .room-panel-body{padding:10px}.room-panel-head{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;gap:10px}.room-panel-title{margin:0;font-size:13px;font-weight:900;letter-spacing:.2px}.room-panel-body{padding:12px;min-height:0}.room-scroll{overflow:auto}.room-stage{min-height:0}.room-stage-head{padding:8px 10px}.room-tabs{display:inline-flex;background:#00000038;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden}.room-tab{background:transparent;border:0;color:#ffffffbf;font-weight:900;font-size:12px;padding:8px 12px;cursor:pointer}.room-tab.active{color:#fff;background:#ffffff1a}.room-stage-hint{opacity:.5;font-size:12px;font-weight:800;white-space:nowrap}.room-stage-body{padding:0;flex:1;min-height:0}.room-side{min-height:0;display:grid;grid-template-rows:.9fr 1.1fr;gap:10px}.room-participants{list-style:none;margin:0;padding:0;display:grid;gap:8px}.room-participant{display:flex;align-items:baseline;gap:6px;padding:8px 10px;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.room-participant-name{font-weight:900}.room-participant-role{opacity:.7}.room-add-student{margin-top:12px;display:grid;gap:10px}.room-add-row{display:flex;gap:10px;align-items:center}.room-add-row .room-select{flex:1}.room-chat-panel .room-panel-body{padding:12px}.room-chat-body{display:flex;flex-direction:column;gap:10px;height:100%;min-height:0}.room-chat-readonly{color:#ffb0b0;font-weight:900;font-size:13px}.room-chat-messages{flex:1;min-height:0;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#0000002e;padding:10px}.room-chat-system{opacity:.65;font-style:italic;margin-bottom:6px}.room-chat-message{margin-bottom:6px}.room-chat-author{font-weight:900}.room-chat-form{display:flex;gap:10px;align-items:center}.room-video-shell{height:100%;min-height:0;padding:12px}.room-video-grid{height:100%;min-height:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.room-video-tile{border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;cursor:pointer;height:200px;background:#000;display:flex;align-items:center;justify-content:center}.room-video-tile.active{height:420px}.room-video-el{width:100%;height:100%;object-fit:cover}.room-video-off{color:#ffffff8c;font-weight:800}.room-empty{grid-column:1 / -1;opacity:.6;font-weight:800;padding:10px}.room-audio{display:none}@media(max-width:1050px){.room-title-compact{max-width:260px}.room-main{grid-template-columns:1fr 320px}}@media(max-width:920px){.room-page{padding:10px}.room-header-row{flex-wrap:wrap;gap:8px}.room-header-left{flex:1 1 100%}.room-header-center{flex:1 1 auto;justify-content:flex-start}.room-header-right{flex:1 1 auto;justify-content:flex-end}.room-main{grid-template-columns:1fr}.room-side{grid-template-rows:auto auto}.room-add-row{flex-direction:column;align-items:stretch}}.room-header-compact{padding:6px 10px}.room-header-row{gap:10px;min-height:40px}:root{--topbar-h: 40px}.room-ctl{width:var(--topbar-h);height:var(--topbar-h);border-radius:12px}.room-header .room-btn,.room-header .room-btn-sm{height:var(--topbar-h);padding:0 12px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;line-height:1}.room-header .room-btn-sm{padding:0 10px;font-size:12px}.room-status-badge{height:var(--topbar-h);padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px}.room-title-wrap-compact{align-items:center}.room-title-compact{line-height:1}.room-header-right .room-btn{min-width:64px}.room-header{border-radius:14px}.room-main{grid-template-columns:1fr 300px}@media(max-width:1050px){.room-main{grid-template-columns:1fr 280px}}.room-side .room-panel-title,.room-side,.room-side *{font-size:12px}.room-members-panel .room-panel-body{padding:10px}.room-members-body{display:flex;flex-direction:column;min-height:0;gap:10px}.room-members-count{opacity:.65;font-weight:900;font-size:12px}.room-members-list{min-height:0}.room-participants-compact{gap:6px}.room-participant-compact{padding:6px 8px;border-radius:10px}.room-participant-name-compact{font-weight:900}.room-participant-role-compact{margin-left:auto;opacity:.65;font-weight:800;font-size:11px}.room-online-dot{width:8px;height:8px;border-radius:999px;display:inline-block;margin-right:8px;border:1px solid rgba(255,255,255,.14)}.room-online-dot.on{background:#26af60d9;box-shadow:0 0 0 3px #26af601a}.room-online-dot.off{background:#d23c3cd9;box-shadow:0 0 0 3px #d23c3c1a}.room-add-student-bottom{margin-top:auto;padding-top:8px}.room-add-row-compact{gap:8px}.room-select-compact{height:36px;padding:0 10px;font-size:12px}.room-btn-compact{height:36px;width:36px;padding:0;border-radius:12px;display:grid;place-items:center;font-weight:900}.room-chat-messages,.room-chat-message,.room-chat-system,.room-chat-author,.room-chat-text{font-size:12px}.room-chat-panel .room-panel-body{position:relative}.room-chat-jump{position:absolute;right:18px;bottom:64px;width:36px;height:36px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#00000059;display:grid;place-items:center;cursor:pointer}.room-chat-jump svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.room-chat-form{margin-top:auto}.room-chat-form .room-input,.room-chat-form .room-btn{height:40px;padding:0 12px;display:inline-flex;align-items:center}.room-chat-form .room-btn{min-width:78px;justify-content:center}.room-main{grid-template-columns:1fr 220px;gap:10px}@media(max-width:1050px){.room-main{grid-template-columns:1fr 200px}}.room-side,.room-side *,.room-side .room-panel-title,.room-members-count{font-size:11px}.room-participants-compact{gap:5px}.room-participant-compact{padding:5px 7px;border-radius:9px;line-height:1.15}.room-online-dot{width:7px;height:7px;margin-right:7px}.room-participant-role-compact{font-size:10px}.room-stage-head{padding:6px 8px;align-items:flex-end}.room-tabs{display:flex;gap:2px;background:transparent;border:0;border-radius:0;overflow:visible}.room-tab{height:32px;padding:0 12px;border:1px solid rgba(255,255,255,.1);border-bottom:0;border-radius:10px 10px 0 0;background:#ffffff0a;color:#ffffffbf;font-weight:900;font-size:12px;cursor:pointer;display:inline-flex;align-items:center}.room-tab.active{background:#1f2024;color:#fff;border-color:#ffffff24;position:relative;top:1px}.room-stage-head:after{content:"";display:block;height:1px;background:#ffffff14;margin-top:6px;width:100%}.room-stage{background:transparent;border:none;border-radius:0}.room-stage .room-panel-head{border:none;padding:0 0 6px}.room-stage .room-panel-body{padding:0;background:transparent;border:none}.room-stage-hint{display:none}.room-tabs{display:flex;gap:14px}.room-tab{height:22px;padding:0;border:0;background:transparent;color:#ffffffb3;font-weight:900;font-size:12px}.room-tab.active{color:#fff;text-decoration:underline;text-underline-offset:6px}.room-board-shell{height:100%;min-height:0}.room-video-tile{position:relative}.room-video-avatar{width:64px;height:64px;border-radius:999px;display:grid;place-items:center;background:#ffffff14;border:1px solid rgba(255,255,255,.16);font-weight:900;font-size:22px;color:#ffffffe6}.room-video-shell{height:100%;min-height:0;padding:12px;position:relative}.room-video-grid{height:100%;min-height:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;align-content:start}.room-video-tile{position:relative;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;cursor:pointer;background:#000;aspect-ratio:16 / 9;height:auto;display:grid;place-items:center}.room-video-el{width:100%;height:100%;object-fit:contain;background:#000}.room-video-name{position:absolute;right:8px;bottom:8px;padding:4px 8px;border-radius:10px;background:#0000008c;border:1px solid rgba(255,255,255,.14);font-size:12px;font-weight:900;color:#fff;max-width:calc(100% - 16px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.room-video-actions{position:absolute;top:8px;right:8px;display:flex;gap:6px;z-index:3}.room-video-action{width:32px;height:32px;border-radius:10px;background:#00000073;border:1px solid rgba(255,255,255,.14);color:#ffffffeb;display:grid;place-items:center;cursor:pointer}.room-video-action:hover{background:#0000009e}.room-video-fallback{width:100%;height:100%;display:grid;place-items:center;background:#000}.room-video-avatar{width:64px;height:64px;border-radius:999px;display:grid;place-items:center;background:#ffffff14;border:1px solid rgba(255,255,255,.16);font-weight:900;font-size:22px;color:#ffffffeb}.room-video-focus{position:absolute;inset:0;background:#0f1012;padding:12px;z-index:10;display:flex}.room-video-focus-inner{width:100%;height:100%;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#000;position:relative}.reset-page{min-height:calc(100vh - 64px);display:flex;align-items:center;justify-content:center;background:#18191c;color:#fff}.reset-board{width:100%;max-width:520px;background:#232428;border-radius:20px;position:relative;box-shadow:0 0 0 1px #ffffff0f,0 30px 80px #0009}.reset-grid{position:relative;border-radius:16px;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:32px 32px;display:flex;flex-direction:column;gap:12px;padding:24px}.reset-title{font-size:28px;margin:0}.reset-grid input{height:44px;padding:0 14px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#232428;color:#fff;font-size:15px;margin:0}.reset-grid input::placeholder{color:#fff6}.reset-grid input:focus{outline:none;border-color:#ffffff40}.reset-grid>button{height:44px;border-radius:10px;border:none;background:#3198cb;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.reset-grid>button:hover{background:#0c4862}.reset-page .password-field{position:relative;width:100%}.reset-page .password-field input{width:100%;height:44px;padding-right:44px}.reset-page .password-toggle{position:absolute;right:12px;top:50%;transform:translateY(calc(-50% + 1px))!important;background:none!important;border:none;padding:0;height:auto;width:auto;cursor:pointer}.reset-page .password-toggle svg{display:block;width:20px;height:20px;stroke:#fff9;fill:none;stroke-width:1.8}.reset-error{color:#ff6b6b;font-size:14px;margin:0}.reset-success{color:#ffffffd9;font-size:16px;margin:0}@media(max-width:768px){.reset-page{align-items:flex-start;justify-content:flex-start}.reset-board{width:calc(100% - 32px);margin:16px auto 0}.reset-grid{padding:20px}.reset-title{font-size:22px}}.app-header{height:56px;width:100%;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(16px,4vw,24px);background:#232428;border-bottom:1px solid #1c1d20;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:12px}.burger-btn{width:40px;height:40px;display:flex;flex-direction:column;justify-content:center;gap:5px;background:transparent;border:none;cursor:pointer}.burger-btn span{display:block;height:2px;width:20px;background:#eaeaea;border-radius:2px}.header-logo{height:40px;width:auto;display:block;object-fit:contain;opacity:.95;-webkit-user-select:none;user-select:none;pointer-events:none}@media(max-width:480px){.header-logo{height:34px}}.header-right{display:flex;align-items:center;gap:12px}.username{font-size:14px;color:#c7c9ce;white-space:nowrap}.btn{height:32px;padding:0 12px;border-radius:6px;font-size:14px;cursor:pointer}.btn.primary,.btn.secondary{background:#3198cb;color:#fff;border:none}.btn.primary:hover,.btn.secondary:hover{background:#0c4862}html,body{overflow-x:hidden}.hero{position:relative;min-height:calc(100vh - 56px);padding-top:30px;overflow:hidden}.hero-top{position:relative;z-index:2;display:grid;grid-template-columns:220px 1fr;gap:64px;align-items:center;padding-left:clamp(16px,3vw,48px)}.hero-main-text h1{font-size:clamp(18px,3vw,28px);line-height:1.1;font-weight:600;letter-spacing:-.02em}.hero-bottom{position:relative;z-index:2;margin-top:48px;padding-left:clamp(16px,3vw,48px);max-width:420px}.hero-bottom .hero-sub{font-size:14px;color:#aeb3bb;line-height:1.6}.hero-bg{position:absolute;inset:0;z-index:1;pointer-events:none;contain:layout paint}.bg-circle.small{position:absolute;border-radius:50%;background:radial-gradient(circle,#3198cb73,#3198cb40 45%,#3198cb1a 62%,#3198cb00 78%);opacity:0;transform:translate(-50%,-50%) scale(.6);animation:circle-fade 6s ease-in-out forwards}@keyframes circle-fade{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}20%{opacity:1}80%{opacity:.9;transform:translate(-50%,-50%) scale(1.2)}to{opacity:0;transform:translate(-50%,-50%) scale(1.4)}}.bg-circle.big{position:absolute;border-radius:50%;opacity:0;transform:translate(-50%,-50%) scale(.25);animation:big-circle 10s ease-in-out forwards}.bg-circle.big:before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(circle,#3198cb61,#3198cb47 45%,#3198cb1f 62%,#3198cb00 78%)}.bg-circle-core{position:absolute;inset:16%;border-radius:50%;background:radial-gradient(circle,#ffffffb3,#ffffff73 24%,#ffffff40 45%,#ffffff1a 62%,#fff0 78%);display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:0;transform:scale(.7);animation:core-fade 10s ease-in-out forwards}@keyframes big-circle{0%{opacity:0;transform:translate(-50%,-50%) scale(.25)}15%{opacity:1}60%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.08)}}@keyframes core-fade{0%,28%{opacity:0;transform:scale(.65)}42%{opacity:1;transform:scale(1)}to{opacity:.9;transform:scale(1.02)}}.bg-circle-core .grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.08) 1px,transparent 1px);background-size:18px 18px;opacity:.9}.bg-circle-core .formula{position:relative;z-index:2;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:16px;font-weight:600;color:#111;opacity:.9;background:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:0;border-radius:0;-webkit-user-select:none;user-select:none;text-align:center;max-width:80%;text-shadow:0 1px 1px rgba(255,255,255,.4),0 0 6px rgba(255,255,255,.25)}.demo-board{position:relative;width:220px;height:160px;border-radius:12px;background:#fff;border:1px solid rgba(0,0,0,.12);overflow:hidden}.board-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.06) 1px,transparent 1px);background-size:20px 20px}.board-svg{position:absolute;inset:0;width:100%;height:100%;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:400;stroke-dashoffset:400;opacity:0;visibility:hidden;animation-name:draw-sequence;animation-duration:9s;animation-timing-function:linear;animation-iteration-count:infinite}.draw{stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:400;stroke-dashoffset:400;opacity:0;animation:draw-sequence 12s linear infinite}.square{animation-delay:0s;stroke:#ef4444}.circle{animation-delay:3s;stroke:#22c55e}.triangle{animation-delay:6s;stroke:#3b82f6}@keyframes draw-sequence{0%{stroke-dashoffset:400;opacity:1;visibility:visible}11%{stroke-dashoffset:0;opacity:1}17%{stroke-dashoffset:0;opacity:1}22%{stroke-dashoffset:400;opacity:0}to{stroke-dashoffset:400;opacity:0;visibility:hidden}}@media(max-width:768px){.hero{padding-top:12px}.hero-top{grid-template-columns:160px 1fr;gap:20px;padding-left:16px;padding-right:16px}.demo-board{width:160px;height:116px}.hero-main-text h1{font-size:clamp(14px,4vw,17px);line-height:1.15}.hero-bottom{margin-top:24px;padding-left:16px;padding-right:16px;max-width:none}}.burger-menu{position:fixed;top:72px;left:16px;width:260px;background-color:#232428;border-radius:12px;border:1px solid rgba(255,255,255,.08);padding:8px;z-index:1000;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 24px #00000073}.burger-menu button{background:transparent;border:none;color:#fff;font-size:15px;font-weight:500;text-align:left;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background-color .2s ease,color .2s ease}.burger-menu button:hover{background-color:#ffffff0f}.burger-menu button:only-child{color:#ff6b6b;font-weight:600}.burger-menu button:only-child:hover{background-color:#ff6b6b1f}.icons-preview{min-height:100vh;padding:24px;background:#18191c;color:#fff}.icons-preview h1{font-size:24px;margin-bottom:8px}.icons-preview .hint{opacity:.6;margin-bottom:24px}.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#232428;border-radius:8px;border:none;color:#fff;cursor:pointer;transition:background .15s ease,transform .1s ease}.icon-btn:hover{background:#2c2d31}.icon-btn:active{transform:scale(.96)}.icons-row{display:flex;gap:12px}
