:root{color:#dbe4f0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#08111f;--bg-elev:#0e1728;--bg-soft:#121d31;--line:#ffffff14;--text:#edf2f8;--muted:#8fa2bd;--primary:#6d5dfc;--primary-2:#3997ff;--success:#16a34a;--danger:#ef4444;--shadow:0 18px 50px #0000004d;background:#08111f;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}html,body,#root{min-height:100%}html{scroll-behavior:smooth}body{color:var(--text);background:radial-gradient(circle at top left, #3997ff26, transparent 28%), radial-gradient(circle at top right, #6d5dfc2e, transparent 28%), var(--bg);margin:0;overflow-x:hidden}img,svg,video,canvas{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{-webkit-tap-highlight-color:transparent}input,textarea,select{min-width:0}#root{isolation:isolate}.public-layout{flex-direction:column;min-height:100vh;display:flex}.public-layout__main{flex-direction:column;flex:1;display:flex}.public-layout--loading{place-items:center;display:grid}.app-layout{grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid;position:relative}.app-layout__overlay{display:none}.app-layout__main{min-width:0}.app-layout__content{padding:28px}.page-section{gap:24px;display:grid}.page-header{justify-content:space-between;align-items:flex-start;gap:20px;min-width:0;max-width:100%;display:flex}.page-header__content{flex:auto;gap:8px;min-width:0;max-width:100%;display:grid}.page-header h1{word-break:break-word;overflow-wrap:anywhere;margin:0;font-size:clamp(2rem,4vw,2.8rem);line-height:1.05}.page-header p{color:var(--muted);white-space:pre-line;word-break:break-word;overflow-wrap:anywhere;width:100%;max-width:72ch;margin:0;line-height:1.55}.page-header__action{flex-shrink:0;justify-content:flex-end;align-items:center;max-width:100%;display:flex}.detail-grid,.files-layout,.profile-grid{grid-template-columns:minmax(0,2fr) minmax(320px,1fr);align-items:start;gap:18px;display:grid}.detail-grid>*,.files-layout>*,.profile-grid>*{align-self:start}.detail-side{gap:18px;display:grid}.overlay-modal{z-index:80;position:fixed;inset:0}.overlay-modal__backdrop{background:#030812b8;border:0;position:absolute;inset:0}.overlay-modal__panel{z-index:1;background:#0e1728;width:min(900px,100vw - 32px);max-height:calc(100vh - 48px);margin:24px auto;position:relative;overflow:auto}.empty-state{text-align:center;max-width:620px;margin:40px auto;padding:34px}.empty-state__icon{background:linear-gradient(135deg,#6d5dfc3d,#3997ff33);border-radius:22px;place-items:center;width:64px;height:64px;margin:0 auto 16px;font-size:1.8rem;display:grid}.empty-state__action{margin-top:18px}.empty-inline{color:var(--muted);padding:18px 0}.sidebar{border-right:1px solid var(--line);z-index:40;background:#0a1221f2;height:100vh;padding:28px 18px;position:sticky;top:0}.sidebar__brand{align-items:center;gap:14px;margin-bottom:28px;padding:10px 8px;display:flex}.sidebar__brand strong{font-size:1rem;display:block}.sidebar__brand span{color:var(--muted);font-size:.85rem;display:block}.sidebar__logo{flex:0 0 54px;justify-content:center;align-items:center;width:54px;height:54px;display:flex}.sidebar__logo-image{object-fit:contain;border:1px solid #fff;border-radius:10px;width:100%;height:100%;display:block}.sidebar__nav{gap:8px;display:grid}.sidebar__link{color:#c3d0e3;border-radius:16px;align-items:center;gap:12px;padding:12px 14px;transition:all .2s;display:flex}.sidebar__link:hover{color:#fff;background:#ffffff0a}.sidebar__link--active{color:#fff;background:#6d5dfc2e;border:1px solid #6d5dfc52}.sidebar__icon{text-align:center;width:22px}.topbar{z-index:20;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);background:#08111fb3;justify-content:space-between;align-items:center;gap:16px;min-height:82px;padding:16px 28px;display:flex;position:sticky;top:0}.topbar__left,.topbar__right{align-items:center;gap:14px;min-width:0;display:flex}.topbar__left{flex:1}.topbar__menu-btn{border:1px solid var(--line);width:46px;height:46px;color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:16px;flex:none;display:none}.topbar__search{flex:1;min-width:0;position:relative}.topbar__search input{border:1px solid var(--line);background:var(--bg-soft);width:100%;height:46px;color:var(--text);border-radius:16px;outline:none;padding:0 14px}.topbar__search input::placeholder{color:#6f86a6}.topbar__search-results{z-index:70;border:1px solid var(--line);background:#0e1728fa;border-radius:18px;position:absolute;top:calc(100% + 10px);left:0;right:0;overflow:hidden;box-shadow:0 24px 70px #00000061}.topbar__search-state{color:var(--muted);padding:16px;font-size:.92rem}.topbar__search-list{max-height:min(420px,100vh - 190px);display:grid;overflow-y:auto}.topbar__search-result{border:0;border-bottom:1px solid var(--line);color:var(--text);text-align:left;cursor:pointer;background:0 0;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:12px;padding:13px 14px;display:grid}.topbar__search-result:last-child{border-bottom:0}.topbar__search-result:hover,.topbar__search-result--active{background:#6d5dfc29}.topbar__search-result-badge{color:#cfc6ff;white-space:nowrap;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;width:fit-content;padding:5px 8px;font-size:.7rem;font-weight:800;display:inline-flex}.topbar__search-result-content{gap:4px;min-width:0;display:grid}.topbar__search-result-content strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.topbar__search-result-content small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.topbar__cta{white-space:nowrap}.user-menu{align-items:center;gap:12px;min-width:0;display:flex}.user-avatar{border:1px solid var(--line);background:linear-gradient(135deg,#26364f,#162237);border-radius:14px;flex:none;place-items:center;width:42px;height:42px;font-weight:700;display:grid}.user-menu__infos{flex-direction:column;min-width:0;display:flex}.user-menu__name{font-size:.92rem}.user-menu__role{color:var(--muted);text-transform:uppercase;font-size:.8rem}.eyebrow{color:#c8beff;text-transform:uppercase;letter-spacing:.05em;background:#6d5dfc29;border-radius:999px;margin-bottom:10px;padding:8px 12px;font-size:.78rem;font-weight:700;display:inline-flex}.btn{cursor:pointer;text-align:center;border:0;border-radius:16px;place-items:center;min-height:46px;padding:0 16px;font-weight:700;transition:all .2s;display:inline-grid}.btn:disabled{opacity:.7;cursor:not-allowed}.btn-primary{color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-2));box-shadow:0 14px 34px #3997ff33}.btn-primary:hover:not(:disabled){transform:translateY(-1px)}.btn-secondary{color:var(--text);border:1px solid var(--line);background:#ffffff0a}.btn-danger{color:#fff;background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 12px 24px #ef444438}.btn-block{width:100%}.btn-compact{border-radius:11px;min-height:34px;padding:0 11px;font-size:.82rem}.loader-wrap,.loader-inline{text-align:center;place-items:center;gap:14px;min-height:40vh;display:grid}.loader-label{color:var(--muted);margin:0}.loader-spinner{border:3px solid #ffffff1f;border-top-color:var(--primary);border-radius:999px;width:38px;height:38px;animation:.9s linear infinite spin}.stat-card,.panel-card,.file-card,.upload-box,.auth-card,.status-card,.empty-state{border:1px solid var(--line);box-shadow:var(--shadow);background:#0e1728e0;border-radius:24px}.panel-card{gap:18px;padding:22px;display:grid}.panel-card--compact{padding:18px}.section-block{gap:16px;display:grid}.section-block__head{justify-content:space-between;align-items:center;gap:12px;display:flex}.section-block__head--stack{align-items:flex-start}.section-block__head h2,.panel-card h2,.panel-card h3{margin:0}.link-action{color:#b9c8db}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.field{gap:10px;min-width:0;display:grid}.field__label{font-weight:600}.field__input,.field__textarea{border:1px solid var(--line);background:var(--bg-soft);width:100%;color:var(--text);border-radius:16px;outline:none;padding:14px 16px}.field__textarea{resize:vertical;min-height:140px}.field--full{grid-column:1/-1}.form-actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;display:flex}.alert{border-radius:16px;padding:14px 16px;line-height:1.5}.alert-success{color:#c8f5d4;background:#16a34a1f;border:1px solid #16a34a4d}.alert-error{color:#ffd2d2;background:#ef44441f;border:1px solid #ef44444d}.info-list{gap:14px;margin:0;padding:0;list-style:none;display:grid}.info-list li{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:12px;display:flex}.info-list li strong{text-align:right;word-break:break-word}.permission-badge{color:#cfc6ff;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;justify-content:center;align-items:center;min-height:28px;padding:4px 10px;font-size:.78rem;font-weight:700;display:inline-flex}.stack-form{gap:.9rem;display:grid}.field__error{color:#ff8f8f;font-size:.85rem}.classroom-card p,.file-card p,.empty-state p,.info-list span,.resource-row__meta,.page-header p,.auth-card p{color:var(--muted)}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.stat-card{padding:22px}.stat-card__label,.stat-card__hint{display:block}.stat-card__label{color:var(--muted);margin-bottom:10px}.stat-card__value{margin-bottom:8px;font-size:2rem;display:block}.stat-card__hint{color:#7f95b0;font-size:.9rem}.classroom-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;min-width:0;max-width:100%;display:grid}.classroom-card{border:1px solid var(--line);background:linear-gradient(180deg, #ffffff08, #ffffff03), var(--bg-elev);border-radius:24px;gap:16px;min-width:0;max-width:100%;min-height:250px;padding:20px;display:grid;overflow:hidden}.classroom-card--violet{box-shadow:inset 0 0 0 1px #6d5dfc14}.classroom-card--blue{box-shadow:inset 0 0 0 1px #3997ff14}.classroom-card--emerald{box-shadow:inset 0 0 0 1px #10b98114}.classroom-card__top,.classroom-card__stats,.classroom-card__footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;min-width:0;max-width:100%;display:flex}.classroom-card__top-tags{flex-wrap:wrap;align-items:center;gap:8px;min-width:0;display:inline-flex}.classroom-card__body{gap:10px;min-width:0;max-width:100%;display:grid}.classroom-card__body h3,.classroom-card h3{overflow-wrap:anywhere;word-break:break-word;min-width:0;max-width:100%;margin:0;font-size:1.2rem;line-height:1.25}.classroom-card__body p{color:var(--muted);white-space:pre-line;overflow-wrap:anywhere;word-break:break-word;-webkit-line-clamp:5;-webkit-box-orient:vertical;min-width:0;max-width:100%;margin:0;line-height:1.5;display:-webkit-box;overflow:hidden}.classroom-card__level{color:#bbf7d0;letter-spacing:.01em;overflow-wrap:anywhere;word-break:break-word;background:#22c55e29;border:1px solid #22c55e61;border-radius:999px;align-items:center;width:fit-content;max-width:100%;padding:7px 12px;font-size:.78rem;font-weight:900;display:inline-flex;box-shadow:0 10px 24px #22c55e1a}.classroom-card__actions{flex-wrap:wrap;gap:10px;min-width:0;display:flex}.classroom-card__badge,.classroom-card__visibility,.classroom-card__members-badge,.permission-badge{overflow-wrap:anywhere;word-break:break-word;max-width:100%}.classroom-card__badge,.classroom-card__visibility{color:#cfd8e6;background:#ffffff0f;border-radius:999px;padding:7px 10px;font-size:.78rem}.classroom-card__updated{color:#93a7c0;overflow-wrap:anywhere;word-break:break-word;font-size:.9rem}.classroom-card__members-badge{color:#cfc6ff;cursor:pointer;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;padding:7px 10px;font-size:.78rem}.classroom-card__members-badge:hover{background:#6d5dfc33}.classroom-card__storage{background:#ffffff09;border:1px solid #94a3b82e;border-radius:16px;flex:100%;gap:7px;min-width:0;padding:10px 12px;display:grid}.classroom-card__storage-head{min-width:0;color:var(--muted);justify-content:space-between;align-items:center;gap:10px;font-size:.78rem;display:flex}.classroom-card__storage-head strong{color:var(--text);text-align:right;overflow-wrap:anywhere;word-break:break-word}.classroom-card__storage-track{background:#94a3b82e;border-radius:999px;height:6px;overflow:hidden}.classroom-card__storage-track span{border-radius:inherit;background:linear-gradient(90deg,#22c55e,#60a5fa);height:100%;transition:width .2s;display:block}.classroom-form,.classroom-edit-form{gap:18px}.classroom-detail-page{gap:20px;min-width:0;max-width:100%}.classroom-detail__header-actions{flex-wrap:wrap;gap:12px;min-width:0;max-width:100%;display:flex}.classroom-hero{min-width:0;max-width:100%;padding:18px 22px;overflow:hidden}.classroom-hero__grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;min-width:0;max-width:100%;display:grid}.classroom-hero__item{border:1px solid var(--line);background:#ffffff08;border-radius:18px;gap:6px;min-width:0;max-width:100%;padding:16px;display:grid}.classroom-hero__item span{color:var(--muted);font-size:.9rem}.classroom-hero__item strong{font-size:1.05rem}.classroom-hero__item span,.classroom-hero__item strong{overflow-wrap:anywhere;word-break:break-word;min-width:0}.classroom-hero__item--button{text-align:left;cursor:pointer;width:100%;color:inherit}.classroom-hero__item--button:hover{background:#ffffff0f}.classroom-section-text{color:var(--muted);white-space:pre-line;overflow-wrap:anywhere;word-break:break-word;max-width:100%;margin:4px 0 0}.classroom-edit-form__text{color:var(--muted);overflow-wrap:anywhere;word-break:break-word;max-width:100%;margin:6px 0 0}.classroom-edit-form__actions{justify-content:flex-end;gap:12px}.classroom-info-success{margin-top:4px;margin-bottom:4px}.classroom-resources-card{align-content:start;min-width:0;max-width:100%}.classroom-resources-card .section-block__head{margin-bottom:6px}.classroom-resources-meta{color:var(--muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;min-width:0;max-width:100%;margin-bottom:6px;font-size:.9rem;display:flex}.classroom-resources-meta__count{color:var(--text);font-weight:600}.classroom-info-actions{gap:12px;display:grid}.student-picker{gap:10px;min-width:0;max-height:320px;padding-right:4px;display:grid;overflow-y:auto}.student-picker__item{border:1px solid var(--line);background:#ffffff05;border-radius:16px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-width:0;padding:12px 14px;display:grid}.student-picker__content{min-width:0}.student-picker__content strong{overflow-wrap:anywhere;word-break:break-word;margin-bottom:4px;display:block}.students-list{gap:10px;min-width:0;display:grid}.student-row{border:1px solid var(--line);background:#ffffff05;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;min-width:0;padding:12px 14px;display:flex}.student-row__content{overflow-wrap:anywhere;word-break:break-word;min-width:0}.student-row__status{color:var(--muted);white-space:nowrap}.classroom-tabs{flex-wrap:wrap;gap:10px;min-width:0;max-width:100%;display:flex}.classroom-tabs__item{border:1px solid var(--line);color:var(--muted);cursor:pointer;background:#ffffff08;border-radius:999px;padding:10px 14px;font-weight:700;transition:all .2s}.classroom-tabs__item:hover{color:var(--text);background:#ffffff0f}.classroom-tabs__item--active{color:#fff;background:#6d5dfc2e;border-color:#6d5dfc73}.invitation-links{gap:12px;min-width:0;margin-top:8px;display:grid}.invitation-links h4{margin:0}.invitation-link-row{border:1px solid var(--line);background:#ffffff08;border-radius:16px;justify-content:space-between;align-items:center;gap:12px;min-width:0;padding:12px 14px;display:flex}.invitation-link-row__content{gap:4px;min-width:0;display:grid}.invitation-link-row__content strong{word-break:break-word;overflow-wrap:anywhere}.invitation-link-row__content span{color:var(--muted);overflow-wrap:anywhere;word-break:break-word;font-size:.9rem}.invitation-link-row__content small{color:#93a7c0;word-break:break-all;font-size:.78rem}.classroom-card--pinned{border-color:#facc1552;box-shadow:inset 0 0 0 1px #facc151f,0 18px 50px #facc1514}.classroom-card__pin{border:1px solid var(--line);color:#93a7c0;cursor:pointer;background:#ffffff0a;border-radius:999px;place-items:center;width:34px;height:34px;transition:background .18s,color .18s,border-color .18s,transform .18s;display:inline-grid}.classroom-card__pin:hover{color:#fff;background:#ffffff14;transform:translateY(-1px)}.classroom-card__pin--active{color:#facc15;background:#facc1524;border-color:#facc156b}.classroom-card__pin:disabled{opacity:.55;cursor:wait;transform:none}.classroom-card__pin svg{width:17px;height:17px}.resource-list{gap:12px;display:grid}.resource-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:14px;padding:14px 0;display:flex}.resource-row__content{flex:1;min-width:0}.resource-row__title{word-break:break-word;display:block}.resource-row__meta{flex-wrap:wrap;gap:10px;margin-top:6px;font-size:.9rem;display:flex}.resource-row__actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;display:flex}.upload-box{gap:16px;padding:22px;display:grid}.upload-box__content{gap:6px;display:grid}.upload-box__drop{color:#c9d7e9;cursor:pointer;text-align:center;background:#ffffff05;border:1px dashed #ffffff29;border-radius:20px;place-items:center;min-height:140px;padding:18px;display:grid}.upload-box__drop-text{word-break:break-word}.files-list{gap:14px;display:grid}.file-card{grid-template-columns:72px minmax(0,1fr) auto;align-items:center;gap:16px;padding:18px;display:grid}.file-card__icon{text-align:center;background:linear-gradient(135deg,#6d5dfc3d,#3997ff33);border-radius:20px;place-items:center;width:72px;height:72px;font-weight:800;display:grid}.file-card__body{min-width:0}.file-card__body h3{word-break:break-word;margin:0 0 8px;font-size:1rem}.file-card__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.profile-form{gap:18px}.field__date-trigger{text-align:left;cursor:pointer;justify-content:space-between;align-items:center;display:flex}.field__date-trigger--open{border-color:#6d5dfc80;box-shadow:0 0 0 3px #6d5dfc1f}.field__date-placeholder{color:var(--muted)}.field__date-icon{opacity:.9;flex:none}.date-picker-popover{border:1px solid var(--line);background:#0e1728;border-radius:20px;gap:14px;padding:16px;display:grid;position:relative;box-shadow:0 18px 44px #00000059}.date-picker-popover__header{justify-content:space-between;align-items:center;gap:12px;display:flex}.date-picker-popover__title{text-transform:capitalize;font-size:1rem}.date-picker-popover__nav{border:1px solid var(--line);width:40px;height:40px;color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:14px}.date-picker-popover__nav:hover{background:#ffffff12}.date-picker-popover__weekdays,.date-picker-popover__grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.date-picker-popover__weekdays span{text-align:center;color:var(--muted);font-size:.8rem;font-weight:700}.date-picker-popover__day{min-height:42px;color:var(--text);cursor:pointer;background:#ffffff08;border:1px solid #0000;border-radius:14px;font-weight:600}.date-picker-popover__day:hover:not(:disabled){background:#ffffff14}.date-picker-popover__day--today{border-color:#3997ff73}.date-picker-popover__day--selected{background:linear-gradient(135deg, var(--primary), var(--primary-2));color:#fff}.date-picker-popover__day--empty{visibility:hidden}.date-picker-popover__day:disabled{opacity:.35;cursor:not-allowed}.date-picker-popover__footer{justify-content:space-between;gap:10px;display:flex}.date-picker-popover__manual{gap:10px;display:grid}.date-picker-popover__manual-row{grid-template-columns:1fr auto;gap:10px;display:grid}.date-picker-popover__selectors{grid-template-columns:1fr 1fr;gap:12px;display:grid}.upload-box__drop--loading{cursor:wait;background:radial-gradient(circle at 0 0,#60a5fa1f,#0000 34%),#ffffff06;border-color:#60a5fa57}.upload-box__progress{gap:10px;width:min(420px,100%);display:grid}.upload-box__progress-head{color:#c9d7e9;justify-content:space-between;align-items:center;gap:12px;font-size:.88rem;display:flex}.upload-box__progress-head span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.upload-box__progress-head strong{color:#93c5fd;flex:none;font-size:.82rem}.upload-box__progress-track{background:#94a3b82e;border-radius:999px;width:100%;height:5px;overflow:hidden}.upload-box__progress-fill{border-radius:inherit;background:linear-gradient(90deg,#60a5fa,#818cf8);height:100%;transition:width .18s;display:block}.profile-storage{border:1px solid var(--line);background:#ffffff09;border-radius:18px;gap:10px;margin-top:18px;padding:14px;display:grid}.profile-storage__head{color:var(--muted);justify-content:space-between;align-items:flex-start;gap:12px;font-size:.9rem;display:flex}.profile-storage__head strong{color:var(--text);text-align:right}.profile-storage__track{background:#94a3b82e;border-radius:999px;height:7px;overflow:hidden}.profile-storage__track span{border-radius:inherit;background:linear-gradient(90deg,#60a5fa,#818cf8);height:100%;transition:width .2s;display:block}.profile-storage small{color:var(--muted);line-height:1.4}.auth-screen{grid-template-columns:1.15fr .85fr;min-height:100vh;display:grid}.auth-screen__visual,.auth-screen__form{place-items:center;padding:42px;display:grid}.auth-screen__visual{background:radial-gradient(circle at 0 0,#3997ff38,#0000 26%),radial-gradient(circle at 100% 100%,#6d5dfc3d,#0000 28%),#071120}.auth-hero{max-width:640px}.auth-hero h1{margin:0 0 16px;font-size:clamp(2.4rem,5vw,4.5rem);line-height:1.02}.auth-hero p{color:var(--muted);margin:0;font-size:1.05rem}.auth-hero__features{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.auth-hero__features span{color:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0f;border:1px solid #ffffff24;border-radius:999px;align-items:center;padding:.55rem .85rem;font-size:.85rem;display:inline-flex}.auth-helper-text{color:var(--text-muted,#7b8494);text-align:center;margin-top:.85rem;font-size:.875rem}.auth-card,.status-card{width:min(100%,520px);padding:30px}.auth-card h2,.status-card h1,.empty-state h3{margin:0 0 12px}.auth-form{gap:16px;margin-top:20px;display:grid}.verify-screen{place-items:center;min-height:100vh;padding:28px;display:grid}.status-card__actions{justify-content:center;margin-top:16px;display:flex}.auth-hero__logo-wrap{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:22px;justify-content:center;align-items:center;width:84px;height:84px;margin-bottom:18px;display:flex}.auth-hero__logo{object-fit:contain;width:60px;height:60px;display:block}.auth-legal-text,.legal-hint{color:var(--muted);margin:12px 0 0;font-size:.88rem;line-height:1.5}.auth-legal-text a,.legal-hint a{color:#b9c8ff;text-decoration:underline}.legal-page{background:radial-gradient(circle at 0 0,#3997ff29,#0000 26%),radial-gradient(circle at 100% 100%,#6d5dfc2e,#0000 28%),#071120;gap:24px;min-height:100vh;padding:48px 24px;display:grid}.legal-page__hero,.legal-card{width:min(100%,980px);margin:0 auto}.legal-page__back{color:#b9c8db;margin-bottom:18px;display:inline-flex}.legal-page__back:hover{color:#fff;text-underline-offset:4px;text-decoration:underline}.legal-page__hero h1{margin:0 0 12px;font-size:clamp(2.2rem,4vw,4rem);line-height:1.05}.legal-page__hero p{color:var(--muted);margin:0}.legal-card{border:1px solid var(--line);box-shadow:var(--shadow);background:#0e1728eb;border-radius:28px;gap:18px;padding:clamp(24px,4vw,44px);line-height:1.7;display:grid}.legal-card h2{margin:24px 0 0;font-size:1.35rem}.legal-card h2:first-child{margin-top:0}.legal-card p{color:#d9e4f3;margin:0}.legal-card a{color:#b9c8ff;text-underline-offset:4px;font-weight:700;-webkit-text-decoration:underline #b9c8ff73;text-decoration:underline #b9c8ff73;transition:all .2s}.legal-card a:hover{color:#fff;text-decoration-color:#ffffffbf}.legal-card a:focus-visible{outline-offset:3px;border-radius:6px;outline:3px solid #6d5dfc59}.legal-card ul{color:#d9e4f3;margin:0;padding-left:1.2rem}.legal-card li{margin:6px 0}.legal-footer{border-top:1px solid var(--line);color:var(--muted);background:#08111feb;flex-wrap:wrap;justify-content:space-between;gap:16px;padding:18px 28px;display:flex}.legal-footer nav{flex-wrap:wrap;gap:14px;display:flex}.legal-footer a{color:#b9c8ff;font-weight:600;text-decoration:none;transition:all .2s}.legal-footer a:hover{color:#fff;text-underline-offset:4px;text-decoration:underline}.legal-footer a:focus-visible,.auth-legal-text a:focus-visible,.legal-hint a:focus-visible,.cookie-consent__content a:focus-visible{outline-offset:3px;border-radius:6px;outline:3px solid #6d5dfc59}.cookie-consent{z-index:120;pointer-events:none;justify-content:center;display:flex;position:fixed;inset:auto 18px 18px}.cookie-consent__panel{border:1px solid var(--line);pointer-events:auto;background:#0e1728fa;border-radius:28px;grid-template-columns:minmax(0,1fr) auto;gap:18px;width:min(100%,980px);padding:22px;display:grid;box-shadow:0 30px 90px #00000073}.cookie-consent__content{gap:10px;display:grid}.cookie-consent__content h2{margin:0}.cookie-consent__content p{color:var(--muted);margin:0;line-height:1.5}.cookie-consent__content a{color:#b9c8ff;text-decoration:underline}.cookie-consent__actions{flex-wrap:wrap;justify-content:flex-end;align-items:end;gap:10px;display:flex}.cookie-consent__settings{gap:10px;margin-top:8px;display:grid}.cookie-consent__setting{border:1px solid var(--line);background:#ffffff08;border-radius:18px;justify-content:space-between;align-items:center;gap:14px;padding:12px;display:flex}.cookie-consent__setting span{color:var(--muted);margin-top:3px;font-size:.86rem;display:block}.cookie-consent__setting input{width:20px;height:20px}.collaborative-settings{margin-bottom:18px}.collaborative-doc{gap:16px;display:grid}.collaborative-doc__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;display:flex}.collaborative-doc__toolbar-group{align-items:center;gap:10px;display:flex}.collaborative-doc__toolbar-group--editor{flex-wrap:wrap}.editor-toolbar__button{border:1px solid var(--line);color:var(--text);cursor:pointer;background:#ffffff0a;border-radius:12px;padding:9px 12px;font-size:.9rem;font-weight:700}.editor-toolbar__button:hover{background:#ffffff14}.editor-toolbar__button--active{color:#d6ceff;background:#6d5dfc2e;border-color:#6d5dfc73}.collaborative-doc__presence{color:var(--muted);font-size:.92rem}.collaborative-doc__rich{border:1px solid var(--line);background:#ffffff08;border-radius:20px;overflow:hidden}.collaborative-doc__rich-content .ProseMirror{min-height:70vh;color:var(--text);outline:none;padding:22px;line-height:1.7}.collaborative-doc__rich-content .ProseMirror p{margin:0 0 1em}.collaborative-doc__rich-content .ProseMirror h1,.collaborative-doc__rich-content .ProseMirror h2,.collaborative-doc__rich-content .ProseMirror h3{margin:1.1em 0 .55em;line-height:1.2}.collaborative-doc__rich-content .ProseMirror h1{font-size:2rem}.collaborative-doc__rich-content .ProseMirror h2{font-size:1.55rem}.collaborative-doc__rich-content .ProseMirror h3{font-size:1.2rem}.collaborative-doc__rich-content .ProseMirror ul,.collaborative-doc__rich-content .ProseMirror ol{padding-left:1.3rem}.collaborative-doc__rich-content .ProseMirror blockquote{color:#c8d8ff;border-left:4px solid #6d5dfc66;margin:1rem 0;padding-left:1rem}.collaborative-doc__rich-content .ProseMirror pre{color:#dbe6ff;background:#0b1223;border:1px solid #ffffff14;border-radius:16px;padding:14px;overflow:auto}.collaborative-doc__rich-content .ProseMirror a{color:#8dd8ff;text-decoration:underline}.collaborative-doc__rich-content .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--muted);float:left;pointer-events:none;height:0}.collaborative-doc__code{border:1px solid var(--line);border-radius:20px;overflow:hidden}.project-list{gap:14px;display:grid}.project-card{border:1px solid var(--line);background:#ffffff06;border-radius:20px;justify-content:space-between;align-items:center;gap:16px;padding:18px;display:flex}.project-card__content{min-width:0}.project-card__content h3{margin:8px 0 6px}.project-card__content p{color:var(--muted);margin:0}.project-card__badge{color:#cfc6ff;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;width:fit-content;margin:10px 0;padding:6px 10px;font-size:.75rem;font-weight:800;display:inline-flex}.project-card__actions{flex-wrap:wrap;gap:10px;display:flex}.project-workbench{grid-template-columns:280px minmax(0,1fr);align-items:start;gap:20px;display:grid}.project-workbench--text{grid-template-columns:280px minmax(0,1fr)}.project-files-panel,.project-editor-panel{min-width:0}.project-files-list{gap:10px;display:grid}.project-file-button-wrap{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:8px;display:grid}.project-file-button{border:1px solid var(--line);width:100%;color:var(--text);text-align:left;cursor:pointer;background:#ffffff08;border-radius:16px;gap:4px;padding:12px;display:grid}.project-file-button span{color:var(--muted);font-size:.82rem}.project-file-button:hover{background:#ffffff0f}.project-file-button-wrap--active .project-file-button{background:#6d5dfc2e;border-color:#6d5dfc73}.project-file-delete{color:#ffd2d2;cursor:pointer;background:#ef44441f;border:1px solid #ef444459;border-radius:14px;width:38px;font-size:1.2rem;font-weight:800}.project-file-delete:hover:not(:disabled){background:#ef444433}.project-file-delete:disabled{opacity:.65;cursor:not-allowed}.project-editor-panel__head{justify-content:space-between;align-items:center;gap:14px;display:flex}.project-editor-panel__head h3{margin:0}.project-editor-panel__actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.project-monaco-wrap,.project-preview-frame{border:1px solid var(--line);border-radius:18px;overflow:hidden}.project-preview-frame{background:#fff;width:100%;height:68vh}.project-preview-actions{flex-wrap:wrap;gap:10px;display:flex}.project-preview-detached{z-index:100;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.project-preview-detached__backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:radial-gradient(circle at 0 0,#3997ff29,#0000 28%),radial-gradient(circle at 100% 100%,#6d5dfc2e,#0000 28%),#030812d6;border:0;position:absolute;inset:0}.project-preview-detached__panel{z-index:1;background:linear-gradient(#0f172afa,#080d18fa),#0e1728fa;border:1px solid #94a3b82e;border-radius:30px;grid-template-rows:auto auto minmax(0,1fr);width:min(1380px,100vw - 36px);height:min(920px,100vh - 36px);min-height:620px;display:grid;position:relative;overflow:hidden;box-shadow:0 40px 120px #00000094,inset 0 1px #ffffff0f}.project-preview-detached__head{background:linear-gradient(#ffffff0b,#ffffff04),#0f172aeb;border-bottom:1px solid #94a3b829;justify-content:space-between;align-items:flex-start;gap:18px;padding:20px 22px;display:flex}.project-preview-detached__title{align-items:flex-start;gap:14px;min-width:0;display:flex}.project-preview-detached__title strong{font-size:1.05rem;display:block}.project-preview-detached__icon{color:#fff;background:linear-gradient(135deg,#6d5dfc57,#3997ff38);border:1px solid #93c5fd38;border-radius:16px;flex:none;place-items:center;width:44px;height:44px;font-weight:900;display:grid;box-shadow:0 14px 30px #3997ff1f}.project-preview-detached__actions{flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;display:flex}.project-preview-detached__toolbar{background:#080d18c7;border-bottom:1px solid #94a3b821;justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;display:flex}.project-preview-detached__presets{flex-wrap:wrap;gap:10px;min-width:0;display:flex}.project-preview-preset{min-width:108px;color:var(--text);cursor:pointer;text-align:left;background:#ffffff0b;border:1px solid #94a3b82e;border-radius:16px;gap:3px;padding:10px 12px;transition:transform .18s,background .18s,border-color .18s;display:grid}.project-preview-preset:hover{background:#6d5dfc29;border-color:#6d5dfc75;transform:translateY(-1px)}.project-preview-preset span{color:var(--muted);font-size:.78rem;font-weight:600}.project-preview-preset--fullscreen{font-weight:900}.project-preview-detached__size{color:#ded8ff;white-space:nowrap;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;flex-shrink:0;align-items:center;gap:8px;height:42px;padding:0 14px;font-size:.9rem;font-weight:800;display:inline-flex}.project-preview-device__resize{cursor:nwse-resize;z-index:25;touch-action:none;background:linear-gradient(135deg,#fffffff2,#e2e8f0eb);border:1px solid #0f172a2e;border-radius:14px;place-items:center;width:38px;height:38px;transition:transform .18s,box-shadow .18s;display:grid;position:absolute;bottom:12px;right:12px;box-shadow:0 12px 30px #0f172a38,inset 0 1px #fffc}.project-preview-device__resize:hover{transform:scale(1.05);box-shadow:0 16px 36px #0f172a47,0 0 0 4px #6d5dfc24}.project-preview-device__resize span{background:linear-gradient(135deg,#0000 0 46%,#0f172a57 46% 56%,#0000 56%),linear-gradient(135deg,#0000 0 64%,#0f172a80 64% 74%,#0000 74%),linear-gradient(135deg,#0000 0 80%,#0f172ab8 80% 90%,#0000 90%);width:18px;height:18px;display:block}.project-type-grid{gap:10px;display:grid}.project-type-card{border:1px solid var(--line);color:var(--text);text-align:left;cursor:pointer;background:#ffffff08;border-radius:18px;gap:8px;padding:14px;transition:all .2s;display:grid}.project-type-card:hover:not(:disabled){background:#ffffff0f}.project-type-card--active{background:#6d5dfc2e;border-color:#6d5dfc8c}.project-type-card--disabled{opacity:.5;cursor:not-allowed}.project-type-card__badge{color:#cfc6ff;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;width:fit-content;padding:5px 9px;font-size:.72rem;font-weight:800}.project-type-card small{color:var(--muted);line-height:1.45}.project-card__name{margin:8px 0 6px;line-height:1.2}.project-card__name-button{max-width:100%;color:var(--text);font:inherit;font-weight:inherit;line-height:inherit;text-align:left;cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;padding:0;display:inline-flex}.project-card__name-button span:first-child{text-overflow:ellipsis;min-width:0;overflow:hidden}.project-card__name-button:hover{color:#ded8ff}.project-card__name-edit-icon{color:#cfc6ff;opacity:.78;background:#6d5dfc24;border:1px solid #6d5dfc47;border-radius:999px;flex:none;place-items:center;width:22px;height:22px;font-size:.78rem;line-height:1;display:inline-grid}.project-card__name-button:hover .project-card__name-edit-icon{opacity:1;background:#6d5dfc38;border-color:#6d5dfc73}.project-card__name-static{color:var(--text);display:block}.project-card__name-input{width:100%;min-width:220px;color:var(--text);font:inherit;font-weight:inherit;line-height:inherit;background:#ffffff0b;border:1px solid #6d5dfc6b;border-radius:12px;outline:none;padding:7px 10px;display:block}.project-card__name-input:focus{background:#6d5dfc1f;border-color:#6d5dfcbf;box-shadow:0 0 0 3px #6d5dfc24}.project-editor-action-button{position:relative;overflow:visible}.project-editor-action-bubble{z-index:20;white-space:nowrap;pointer-events:none;color:#fff;background:#0f172af5;border:1px solid #94a3b847;border-radius:999px;padding:6px 10px;font-size:.72rem;font-weight:800;animation:1.5s both project-editor-action-bubble;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 12px 30px #00000052}@keyframes project-editor-action-bubble{0%{opacity:0;transform:translate(-50%)translateY(6px)scale(.96)}15%{opacity:1;transform:translate(-50%)translateY(0)scale(1)}78%{opacity:1;transform:translate(-50%)translateY(0)scale(1)}to{opacity:0;transform:translate(-50%)translateY(-4px)scale(.98)}}.project-preview-detached__panel--studio{border-radius:22px;grid-template-rows:auto auto minmax(0,1fr);width:calc(100vw - 24px);height:calc(100vh - 24px);min-height:0}.project-preview-detached__head--compact{align-items:center;gap:12px;padding:9px 12px}.project-preview-detached__head--compact .project-preview-detached__icon{border-radius:12px;width:34px;height:34px}.project-preview-detached__head--compact .project-preview-detached__title{align-items:center}.project-preview-detached__head--compact .project-preview-detached__title strong{font-size:.95rem}.project-preview-detached__head--compact .classroom-section-text{margin-top:1px;font-size:.76rem}.project-preview-detached__toolbar--compact{min-height:40px;padding:6px 10px}.project-preview-detached__toolbar--compact .project-preview-preset{border-radius:12px;min-width:82px;padding:6px 9px;font-size:.78rem}.project-preview-detached__toolbar--compact .project-preview-preset span{font-size:.64rem}.project-preview-detached__toolbar--compact .project-preview-detached__size{height:30px;font-size:.74rem}.project-preview-detached__body--studio{padding:0;display:block;position:relative;overflow:hidden}.project-visual-studio{background:linear-gradient(#0f172af5,#080d18f5),#0e1728f5;border-radius:24px;grid-template-rows:minmax(0,1fr);min-width:0;display:grid;overflow:hidden}.project-visual-studio--fullscreen{background:0 0;border-radius:0;width:100%;height:100%}.project-visual-studio__body{grid-template-columns:minmax(0,1fr);min-width:0;min-height:0;display:grid}.project-visual-studio__body--fullscreen{height:100%;min-height:0;position:relative}.project-visual-studio--inspector-open .project-visual-studio__body--fullscreen{grid-template-columns:minmax(0,1fr) 300px}.project-visual-studio--inspector-closed .project-visual-studio__body--fullscreen{grid-template-columns:minmax(0,1fr)}.project-visual-stage{background:linear-gradient(#94a3b80b 1px,#0000 1px) 0 0/28px 28px,linear-gradient(90deg,#94a3b80b 1px,#0000 1px) 0 0/28px 28px,radial-gradient(circle at top,#3997ff14,#0000 38%),#070d19;place-items:center;min-width:0;min-height:0;padding:18px;display:grid}.project-visual-stage--fullscreen{place-items:center;min-width:0;min-height:0;padding:10px;overflow:auto}.project-visual-frame-shell{background:#0f172a;border:1px solid #e2e8f029;border-radius:22px;grid-template-rows:42px minmax(0,1fr);width:100%;height:68vh;min-height:520px;display:grid;position:relative;overflow:hidden;box-shadow:0 26px 80px #00000057,0 0 0 8px #ffffff06}.project-visual-frame-shell--fullscreen{border-radius:16px;max-width:none;height:min(100%,100vh - 128px);min-height:0;max-height:none}.project-visual-frame-shell__topbar{background:linear-gradient(#ffffff17,#ffffff09),#111827;border-bottom:1px solid #e2e8f01f;align-items:center;gap:8px;height:42px;padding:0 14px;display:flex}.project-visual-frame-shell__topbar span{border-radius:999px;width:10px;height:10px}.project-visual-frame-shell__topbar span:first-child{background:#fb7185}.project-visual-frame-shell__topbar span:nth-child(2){background:#fbbf24}.project-visual-frame-shell__topbar span:nth-child(3){background:#34d399}.project-visual-frame-shell__topbar strong{color:#cbd5e1;text-overflow:ellipsis;white-space:nowrap;min-width:0;margin-left:8px;font-size:.82rem;overflow:hidden}.project-visual-frame-shell__topbar--compact{height:30px;padding:0 10px}.project-visual-frame-shell__topbar--compact span{width:8px;height:8px}.project-visual-frame-shell__topbar--compact strong{font-size:.74rem}.project-visual-frame{background:#fff;border:0;width:100%;height:100%;display:block}.project-dom-inspector{background:linear-gradient(#0f172afa,#080d18fa);border-left:1px solid #94a3b829;width:300px;min-width:300px;max-width:300px;min-height:0;padding:10px;overflow:auto}.project-dom-inspector__head{gap:8px;margin-bottom:10px;display:grid}.project-dom-inspector__head strong{font-size:.92rem}.project-dom-inspector__head .classroom-section-text{font-size:.75rem}.project-dom-inspector__content{gap:10px;display:grid}.project-dom-selected-card{background:#6d5dfc29;border:1px solid #6d5dfc47;border-radius:12px;gap:4px;padding:9px;display:grid}.project-dom-selected-card span{color:var(--muted);font-size:.76rem}.project-dom-selected-card strong{font-size:.9rem}.project-dom-selected-card small{color:#cbd5e1;word-break:break-all;font-size:.72rem}.project-dom-group{background:#ffffff06;border:1px solid #94a3b829;border-radius:14px;gap:8px;padding:9px;display:grid}.project-dom-group h4{margin:0;font-size:.86rem}.project-dom-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.project-dom-inspector .field{gap:6px}.project-dom-inspector .field__label{font-size:.78rem}.project-dom-inspector .field__input{border-radius:12px;min-height:38px;padding:9px 10px;font-size:.84rem}.project-dom-inspector textarea.field__input{resize:vertical;min-height:68px}.project-dom-help,.project-dom-empty p{color:var(--muted);margin:0;font-size:.76rem;line-height:1.5}.project-dom-empty{text-align:center;min-height:220px;color:var(--muted);align-content:center;gap:10px;padding:10px;display:grid}.project-dom-empty strong{color:var(--text)}.project-dom-inspector-toggle{z-index:30;color:#fff;cursor:pointer;background:#0f172af5;border:1px solid #94a3b838;border-right:0;border-radius:14px 0 0 14px;width:28px;height:58px;font-size:1.35rem;font-weight:900;position:absolute;top:50%;right:0;transform:translateY(-50%);box-shadow:0 14px 36px #00000057}.project-dom-inspector-toggle:hover{background:#6d5dfce6}.project-dom-inspector-toggle--open{right:300px}.project-dom-actions{flex-wrap:wrap;gap:8px;display:flex}.project-dom-actions--grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.project-dom-actions--grid .btn{width:100%}.project-color-row{flex-wrap:wrap;gap:7px;display:flex}.project-color-swatch{cursor:pointer;border:1px solid #e2e8f052;border-radius:9px;width:26px;height:26px;box-shadow:inset 0 1px #ffffff38,0 8px 18px #0000002e}.project-color-swatch:hover{border-color:#ffffff8c;transform:translateY(-1px)}.project-color-swatch--active{outline-offset:2px;border-color:#fff;outline:3px solid #6d5dfc99}.project-color-input{cursor:pointer;min-height:38px;padding:4px 8px}.project-dom-drag-hint{outline-offset:6px!important;outline:3px dashed #22c55e!important}.project-dom-dragging{opacity:.55!important}.project-block-toolbar{border-right:1px solid #94a3b82e;flex-wrap:wrap;align-items:center;gap:8px;margin-right:4px;padding-right:8px;display:flex}.project-block-toolbar .btn{white-space:nowrap}.project-preview-detached__actions{row-gap:8px}.project-dom-inspector__title-row{justify-content:space-between;align-items:flex-start;gap:10px;display:flex;position:relative}.project-info-button{color:#ded8ff;cursor:pointer;background:#6d5dfc2e;border:1px solid #94a3b847;border-radius:999px;flex:none;width:28px;height:28px;font-weight:900}.project-info-button:hover{color:#fff;background:#6d5dfc47}.project-info-popover{background:#0f172af5;border:1px solid #6d5dfc47;border-radius:14px;gap:8px;margin-top:8px;padding:10px;display:grid;box-shadow:0 18px 44px #00000047}.project-info-popover strong{font-size:.82rem}.project-info-popover p{color:var(--muted);margin:0;font-size:.74rem;line-height:1.5}.project-info-popover code{color:#c4b5fd;word-break:break-word;background:#020617b8;border-radius:10px;padding:8px;font-size:.72rem;line-height:1.6;display:block}.classroom-video-room{gap:18px}.classroom-video-room__status{border:1px solid var(--line);width:fit-content;max-width:100%;color:var(--muted);background:#ffffff0a;border-radius:999px;align-items:center;padding:8px 12px;font-size:.86rem;font-weight:700;display:inline-flex}.classroom-video-room__layout{grid-template-columns:minmax(0,1fr) 340px;align-items:stretch;gap:16px;display:grid}.classroom-video-room__main{gap:14px;min-width:0;display:grid}.classroom-video-room__stage{border:1px solid var(--line);background:radial-gradient(circle at 0 0,#22d3ee1f,#0000 36%),#020617b8;border-radius:24px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start;gap:14px;min-height:420px;padding:14px;display:grid;overflow:hidden}.classroom-video-room__empty{min-height:260px;color:var(--muted);text-align:center;border:1px dashed #94a3b847;border-radius:20px;place-items:center;padding:20px;display:grid}.classroom-video-room__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.classroom-video-action-btn{border:1px solid var(--line);width:46px;height:46px;color:var(--muted);cursor:pointer;background:#ffffff0e;border-radius:14px;flex:none;place-items:center;transition:transform .15s,background .15s,border-color .15s,color .15s,box-shadow .15s;display:inline-grid;position:relative}.classroom-video-action-btn:hover{color:var(--text);background:#ffffff14;transform:translateY(-1px)}.classroom-video-action-btn--active{color:#dcfce7;background:#22c55e2e;border-color:#22c55e6b;box-shadow:0 10px 24px #22c55e1f,inset 0 0 0 1px #22c55e14}.classroom-video-action-btn--danger{color:#fee2e2;background:#ef444429;border-color:#ef444459}.classroom-video-action-btn--danger:hover{background:#ef44443d;border-color:#ef444475}.classroom-video-action-btn--compact{border-radius:12px;width:42px;height:42px}.classroom-video-action-btn__icon{width:21px;height:21px}.classroom-video-action-btn__badge{color:#fff;background:#ef4444;border-radius:999px;place-items:center;min-width:18px;height:18px;padding:0 5px;font-size:.65rem;font-weight:900;line-height:1;display:inline-grid;position:absolute;top:-6px;right:-6px}.classroom-video-action-btn__icon--phone{width:35px;height:35px}.classroom-video-tile{aspect-ratio:16/9;background:#0f172adb;border:1px solid #94a3b82e;border-radius:20px;width:100%;min-height:0;position:relative;overflow:hidden}.classroom-video-tile__media{object-fit:contain;background:#020617;width:100%;height:100%;min-height:0;display:block}.classroom-video-tile__label{color:#fff;white-space:nowrap;text-overflow:ellipsis;background:#020617c2;border-radius:999px;max-width:calc(100% - 24px);padding:7px 10px;font-size:.78rem;font-weight:800;position:absolute;bottom:12px;left:12px;overflow:hidden}.classroom-video-tile--compact{border-radius:16px;flex:none;width:150px;height:112px;min-height:0}.classroom-video-tile--compact .classroom-video-tile__media{object-fit:contain;width:100%;height:100%;min-height:0}.classroom-video-tile--compact .classroom-video-tile__label{padding:5px 8px;font-size:.68rem;bottom:8px;left:8px}.classroom-video-chat{border:1px solid var(--line);background:#ffffff09;border-radius:22px;grid-template-rows:auto minmax(0,1fr) auto;min-width:0;min-height:420px;display:grid;overflow:hidden}.classroom-video-chat__head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;display:flex}.classroom-video-chat__head strong{color:var(--text)}.classroom-video-chat__head span{min-width:28px;height:28px;color:var(--muted);background:#ffffff14;border-radius:999px;place-items:center;font-size:.78rem;font-weight:800;display:inline-grid}.classroom-video-chat__messages{align-content:start;gap:10px;min-height:0;padding:14px;display:grid;overflow-y:auto}.classroom-video-chat__empty{text-align:center;min-height:180px;color:var(--muted);border:1px dashed #94a3b847;border-radius:18px;place-items:center;padding:16px;display:grid}.classroom-video-chat__message{background:#0f172aad;border:1px solid #94a3b82e;border-radius:16px;max-width:92%;padding:10px 12px}.classroom-video-chat__message--local{background:#3b82f62e;border-color:#60a5fa47;justify-self:end}.classroom-video-chat__meta{justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px;font-size:.74rem;display:flex}.classroom-video-chat__meta strong{color:var(--text)}.classroom-video-chat__meta span{color:var(--muted);white-space:nowrap}.classroom-video-chat__message p{color:var(--text);overflow-wrap:anywhere;word-break:break-word;margin:0;line-height:1.45}.classroom-video-chat__form{border-top:1px solid var(--line);gap:8px;padding:12px;display:flex}.classroom-video-chat__form input{border:1px solid var(--line);min-width:0;height:40px;color:var(--text);background:#ffffff0e;border-radius:13px;outline:none;flex:auto;padding:0 12px}.classroom-video-chat__form input:focus{border-color:#60a5fa8c}.classroom-video-chat__form input:disabled{opacity:.62;cursor:not-allowed}.classroom-video-floating{z-index:80;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:radial-gradient(circle at 0 0,#3b82f62e,#0000 34%),#0f172af5;border:1px solid #94a3b847;border-radius:24px;gap:0;width:min(520px,100vw - 28px);max-height:calc(100vh - 32px);display:grid;position:fixed;bottom:18px;right:18px;overflow:hidden;box-shadow:0 24px 80px #0000006b}.classroom-video-floating--collapsed{width:min(360px,100vw - 28px)}.classroom-video-floating__head{border-bottom:1px solid #94a3b82e;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.classroom-video-floating__head strong{color:#fff;font-size:.92rem;display:block}.classroom-video-floating__head span{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;max-width:270px;margin-top:2px;font-size:.76rem;display:block;overflow:hidden}.classroom-video-floating__head-actions{align-items:center;gap:6px;display:inline-flex}.classroom-video-floating__icon{color:#fff;cursor:pointer;background:#ffffff0f;border:1px solid #94a3b840;border-radius:999px;place-items:center;width:34px;height:34px;display:inline-grid}.classroom-video-floating__icon:hover{background:#ffffff1c}.classroom-video-floating__tiles{overscroll-behavior-x:contain;align-items:stretch;gap:10px;padding:12px;display:flex;overflow-x:auto}.classroom-video-floating__empty{color:#94a3b8;text-align:center;border:1px dashed #94a3b847;border-radius:16px;place-items:center;min-height:96px;padding:12px;display:grid}.classroom-video-floating__actions{flex-wrap:wrap;align-items:center;gap:8px;padding:0 12px 12px;display:flex}.classroom-video-floating__chat{border-top:1px solid #94a3b82e;max-height:min(430px,52vh);display:grid}.classroom-video-floating__chat .classroom-video-chat{background:0 0;border:0;border-radius:0;min-height:330px}.classroom-tabs__item--video-live{color:#bbf7d0;letter-spacing:.01em;background:#22c55e29;border-color:#22c55e61;align-items:center;width:fit-content;display:inline-flex;box-shadow:0 10px 24px #22c55e1a,inset 0 0 0 1px #22c55e1f}.classroom-tabs__item--video-live:hover{background:#22c55e38;border-color:#22c55e85}.classroom-tabs__item--video-live.classroom-tabs__item--active{color:#dcfce7;background:#22c55e38;border-color:#22c55e94;box-shadow:0 14px 34px #22c55e29,inset 0 0 0 1px #22c55e29}.classroom-tabs__item--video-live:before{content:"";background:#22c55e;border-radius:999px;width:8px;height:8px;margin-right:8px;animation:1.6s ease-in-out infinite classroom-video-live-pulse;box-shadow:0 0 0 5px #22c55e24}.classroom-tabs__live-dot{color:#bbf7d0;background:#22c55e33;border:1px solid #22c55e73;border-radius:999px;margin-left:8px;padding:4px 8px;font-size:.68rem;font-weight:900;line-height:1;box-shadow:0 8px 18px #22c55e1f}.classroom-card__video-live,.classroom-detail-video-live{color:#bbf7d0;letter-spacing:.01em;background:#22c55e29;border:1px solid #22c55e61;border-radius:999px;align-items:center;gap:7px;width:fit-content;max-width:100%;padding:7px 10px;font-size:.78rem;font-weight:900;display:inline-flex;box-shadow:0 10px 24px #22c55e1a}.classroom-card__video-live:before,.classroom-detail-video-live:before,.classroom-video-room__join--live:before{content:"";background:#22c55e;border-radius:999px;flex:none;width:8px;height:8px;animation:1.6s ease-in-out infinite classroom-video-live-pulse;box-shadow:0 0 0 5px #22c55e24}.classroom-card__video-live small,.classroom-video-room__join--live small{color:#dcfce7;background:#22c55e3d;border:1px solid #22c55e6b;border-radius:999px;place-items:center;min-width:18px;height:18px;padding:0 6px;font-size:.68rem;font-weight:900;line-height:1;display:inline-grid}.classroom-video-room__join--live{color:#dcfce7;background:#22c55e38;border-color:#22c55e94;align-items:center;gap:8px;display:inline-flex;box-shadow:0 14px 34px #22c55e29,inset 0 0 0 1px #22c55e29}.classroom-video-room__join--live:hover{background:#22c55e47;border-color:#22c55ead}@keyframes classroom-video-live-pulse{0%,to{transform:scale(1);box-shadow:0 0 0 5px #22c55e24}50%{transform:scale(1.15);box-shadow:0 0 0 8px #22c55e0a}}.classroom-video-audio-sink{opacity:0;pointer-events:none;width:1px;height:1px;position:fixed;top:auto;left:-99999px;overflow:hidden}.classroom-video-floating{touch-action:none}.classroom-video-floating__head{cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.classroom-video-floating--dragging .classroom-video-floating__head{cursor:grabbing}.classroom-video-floating__head-actions,.classroom-video-floating__head-actions button{cursor:auto}.classroom-video-floating__icon svg{display:block}.classroom-video-room__layout,.classroom-video-room__main{min-height:0}.classroom-video-room__layout>.classroom-video-chat{align-self:stretch;height:clamp(360px,62vh,620px);min-height:0;max-height:620px}.classroom-video-room__layout>.classroom-video-chat .classroom-video-chat__messages{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;min-height:0;overflow-y:auto}@media (width<=980px){.classroom-video-room__layout{grid-template-columns:1fr}.classroom-video-chat{min-height:360px}.classroom-video-room__layout>.classroom-video-chat{height:min(430px,52vh);min-height:0;max-height:430px}}@media (width<=680px){.classroom-video-room__stage{border-radius:18px;grid-template-columns:1fr;min-height:300px;padding:10px}.classroom-video-room__stage .classroom-video-tile:not(.classroom-video-tile--compact){min-height:220px}.classroom-video-room__stage .classroom-video-tile:not(.classroom-video-tile--compact) .classroom-video-tile__media{min-height:0}.classroom-video-room__actions{justify-content:flex-start}.classroom-video-room__actions .classroom-video-action-btn{width:44px;height:44px}.classroom-video-room__layout>.classroom-video-chat .classroom-video-chat__form{flex-direction:column}.classroom-video-room__layout>.classroom-video-chat .classroom-video-chat__form .btn{width:100%}.classroom-video-floating{border-radius:20px;width:min(420px,100vw - 20px);max-width:calc(100vw - 20px);bottom:10px;left:auto;right:10px}.classroom-video-floating--collapsed{width:min(360px,100vw - 20px)}.classroom-video-floating__tiles{align-items:stretch}.classroom-video-tile--compact{height:100px;min-height:0}.classroom-video-tile--compact .classroom-video-tile__media{min-height:0}.classroom-video-floating__actions{justify-content:flex-start}.classroom-video-floating__actions .classroom-video-action-btn{width:40px;height:40px}.classroom-tabs__live-dot{display:none}.classroom-video-floating{flex-direction:column;max-height:calc(100dvh - 20px);display:flex;overflow:hidden}.classroom-video-floating__head,.classroom-video-floating__tiles,.classroom-video-floating__actions{flex:none}.classroom-video-floating__chat{flex:auto;min-height:0;max-height:none;overflow:hidden}.classroom-video-floating__chat .classroom-video-chat{grid-template-rows:auto minmax(0,1fr) auto;height:100%;min-height:0;display:grid}.classroom-video-floating__chat .classroom-video-chat__messages{min-height:0;overflow-y:auto}.classroom-video-floating__chat .classroom-video-chat__form{flex-direction:row;grid-template-columns:minmax(0,1fr) auto;gap:6px;display:grid}.classroom-video-floating__chat .classroom-video-chat__form input{width:100%;min-width:0}.classroom-video-floating__chat .classroom-video-chat__form .btn{flex:none;width:auto;min-width:max-content;padding-inline:10px}.classroom-video-room__layout>.classroom-video-chat{height:min(380px,46vh);min-height:260px;max-height:380px}.classroom-video-room__layout>.classroom-video-chat .classroom-video-chat__messages{overflow-y:auto}}@media (width<=1280px){.project-workbench,.project-workbench--text{grid-template-columns:240px minmax(0,1fr)}.project-visual-studio--inspector-open .project-visual-studio__body--fullscreen{grid-template-columns:minmax(0,1fr) 280px}.project-dom-inspector{width:280px;min-width:280px;max-width:280px}.project-dom-inspector-toggle--open{right:280px}}@media (width<=1180px){.classroom-grid,.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-grid,.files-layout,.profile-grid{grid-template-columns:minmax(0,1fr)}.detail-grid>*,.files-layout>*,.profile-grid>*,.detail-side,.panel-card{min-width:0;max-width:100%}}@media (width<=940px){html{font-size:13.5px}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}.app-layout{grid-template-columns:minmax(0,1fr)}.app-layout,.app-layout__main,.app-layout__content,.page-section,.classroom-detail-page,.detail-grid,.detail-side,.files-layout,.profile-grid,.panel-card{min-width:0;max-width:100%}.app-layout__content{padding:14px}.sidebar{width:min(86vw,300px);height:100vh;padding:20px 14px;transition:transform .24s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 20px 60px #00000059}.sidebar--mobile-open{transform:translate(0)}.app-layout__overlay{z-index:30;background:#03081294;border:0;display:block;position:fixed;inset:0}.topbar{flex-direction:column;align-items:stretch;gap:12px;min-height:0;padding:12px 14px}.topbar__left,.topbar__right,.topbar__search{width:100%;min-width:0}.topbar__menu-btn{border-radius:13px;place-items:center;width:40px;height:40px;display:inline-grid}.topbar__right{flex-wrap:wrap;justify-content:space-between}.topbar__cta{flex:180px}.topbar__search input{border-radius:13px;height:40px}.page-section{gap:14px}.page-header{flex-direction:column;align-items:stretch;gap:10px;min-width:0;max-width:100%}.page-header__content,.page-header__action,.page-header__action>*{width:100%;min-width:0;max-width:100%}.page-header h1{margin:0;font-size:clamp(1.45rem,7vw,2rem);line-height:1.08}.page-header p{white-space:pre-line;word-break:break-word;overflow-wrap:anywhere;max-width:100%;line-height:1.5}.classroom-section-text,.panel-card h2,.panel-card h3,.resource-row__title,.student-row__content,.invitation-link-row__content strong,.invitation-link-row__content small{overflow-wrap:anywhere;word-break:break-word}.panel-card,.stat-card,.upload-box,.auth-card,.status-card,.empty-state{border-radius:18px}.panel-card{gap:14px;padding:16px}.panel-card--compact{padding:12px}.btn{border-radius:12px;min-height:40px;padding:0 13px;font-size:.9rem}.btn-compact{border-radius:9px;min-height:30px;padding:0 9px;font-size:.78rem}.field{gap:7px}.field__input,.field__textarea{border-radius:12px;padding:10px 12px}.classroom-detail__header-actions{width:100%;min-width:0}.classroom-hero{width:100%;min-width:0;padding:14px;overflow:hidden}.classroom-hero__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;min-width:0}.classroom-hero__item{border-radius:14px;min-width:0;padding:12px}.classroom-hero__item span,.classroom-hero__item strong{overflow-wrap:anywhere;word-break:break-word;min-width:0}.classroom-tabs{scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:8px;width:100%;max-width:100%;padding:10px;overflow:auto hidden}.classroom-tabs::-webkit-scrollbar{display:none}.classroom-tabs__item{white-space:nowrap;flex:none;padding:8px 12px;font-size:.86rem}.classroom-resources-meta{align-items:flex-start}.auth-screen{grid-template-columns:1fr}.auth-screen__visual{min-height:260px}.project-visual-studio--inspector-open .project-visual-studio__body--fullscreen,.project-visual-studio--inspector-closed .project-visual-studio__body--fullscreen{grid-template-columns:1fr}.project-dom-inspector{border-top:1px solid #94a3b829;border-left:0;width:100%;min-width:0;max-width:none;max-height:260px}.project-dom-inspector-toggle,.project-dom-inspector-toggle--open{border-bottom:0;border-right:1px solid #94a3b838;border-radius:14px 14px 0 0;width:58px;height:28px;top:auto;bottom:0;right:14px;transform:none}.project-visual-frame-shell--fullscreen{height:60vh}}@media (width<=820px){.project-workbench,.project-workbench--text{grid-template-columns:minmax(0,1fr)}.project-card{flex-direction:column;align-items:stretch}.project-card__actions,.project-editor-panel__actions,.project-card__actions .btn{width:100%}.project-editor-panel__head{flex-direction:column;align-items:stretch;gap:12px}.project-file-button-wrap{grid-template-columns:minmax(0,1fr) 40px}.project-preview-detached{padding:8px}.project-preview-detached__panel{border-radius:18px;width:calc(100vw - 16px);height:calc(100vh - 16px);min-height:0}.project-preview-detached__head{flex-direction:column;padding:14px}.project-preview-detached__actions{justify-content:stretch;width:100%}.project-preview-detached__actions .btn{width:100%}.project-preview-detached__toolbar{flex-direction:column;align-items:stretch}.project-preview-detached__presets{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.project-preview-preset{min-width:0}.project-preview-detached__size{justify-content:center;width:100%}.project-preview-detached__body--studio{place-items:initial;padding:0;display:block}.cookie-consent__panel{grid-template-columns:1fr}.cookie-consent__actions{justify-content:stretch}.cookie-consent__actions .btn{width:100%}.legal-footer{flex-direction:column}.project-dom-grid{grid-template-columns:1fr}.project-block-toolbar{border-bottom:1px solid #94a3b82e;border-right:0;width:100%;margin-right:0;padding-bottom:8px;padding-right:0}.project-block-toolbar .btn{flex:90px}}@media (width<=820px),(height<=700px){.project-preview-detached{padding:0}.project-preview-detached__panel--studio{border-radius:0;width:100%;max-width:100%;height:100dvh;max-height:100dvh}.project-preview-detached__head--compact{flex-shrink:0;grid-template-columns:minmax(0,1fr);gap:8px;padding:8px 10px;display:grid}.project-preview-detached__title{align-items:center;gap:8px;min-width:0;display:flex}.project-preview-detached__icon{width:28px;min-width:28px;height:28px;font-size:14px}.project-preview-detached__title strong{font-size:13px;line-height:1.1}.project-preview-detached__title .classroom-section-text{display:none}.project-preview-detached__actions,.project-dom-actions{scrollbar-width:none;-webkit-overflow-scrolling:touch;align-items:center;gap:6px;display:flex;overflow:auto hidden}.project-preview-detached__actions{flex-flow:row;justify-content:flex-start;width:100%;padding-bottom:2px}.project-preview-detached__actions::-webkit-scrollbar{display:none}.project-dom-actions::-webkit-scrollbar{display:none}.project-block-toolbar{border-bottom:0;border-right:0;flex-flow:row;flex:none;align-items:center;gap:6px;width:auto;margin-right:0;padding-bottom:0;padding-right:0;display:flex}.project-preview-detached__actions .btn,.project-preview-detached__actions .btn-compact,.project-block-toolbar .btn,.project-block-toolbar .btn-compact,.project-dom-actions .btn,.project-dom-actions .btn-compact{white-space:nowrap;border-radius:999px;flex:none;width:auto;min-width:max-content;min-height:30px;padding:6px 9px;font-size:11px;line-height:1}.project-preview-detached__toolbar--compact{flex-shrink:0;gap:6px;padding:6px 10px}.project-preview-detached__presets{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:6px;overflow-x:auto}.project-preview-detached__presets::-webkit-scrollbar{display:none}.project-preview-preset{border-radius:12px;flex:none;padding:6px 9px;font-size:11px}.project-preview-preset span,.project-preview-detached__size{display:none}.project-preview-detached__body--studio{height:100%;min-height:0;padding:6px;overflow:hidden}.project-visual-studio,.project-visual-studio__body--fullscreen,.project-visual-stage--fullscreen{height:100%;min-height:0}.project-visual-stage--fullscreen{padding:6px;overflow:hidden}.project-visual-frame-shell--fullscreen{max-width:100%;max-height:100%;width:100%!important;height:100%!important}.project-preview-device__resize{display:none}.project-preview-preset--fullscreen{min-width:auto}.project-preview-preset--fullscreen span{display:none}}@media (width<=680px){html{font-size:13px}.app-layout__content{padding:12px}.page-section{gap:12px}.panel-card{border-radius:16px;gap:12px;padding:14px}.panel-card--compact{padding:10px}.classroom-grid,.form-grid{grid-template-columns:minmax(0,1fr)}.stats-grid{scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;grid-template-columns:repeat(3,minmax(112px,1fr));gap:10px;padding-bottom:6px;display:grid;overflow-x:auto}.stats-grid .stat-card{scroll-snap-align:start;min-width:112px;padding:14px 12px}.stats-grid .stat-card__label{margin-bottom:6px;font-size:.78rem;line-height:1.2}.stats-grid .stat-card__value{margin-bottom:5px;font-size:1.55rem}.stats-grid .stat-card__hint{font-size:.72rem;line-height:1.25}.classroom-detail-page{gap:12px}.classroom-detail__header-actions,.page-header__action,.topbar__right{width:100%}.classroom-detail__header-actions{grid-template-columns:minmax(0,1fr);gap:10px;display:grid}.classroom-detail__header-actions .btn,.classroom-detail__header-actions .permission-badge{width:100%}.classroom-hero{border-radius:16px;padding:12px;overflow:hidden}.classroom-hero__grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:7px;display:grid}.classroom-hero__item{border-radius:13px;gap:4px;min-width:0;padding:9px 7px}.classroom-hero__item span{white-space:nowrap;text-overflow:ellipsis;font-size:.68rem;line-height:1.1;overflow:hidden}.classroom-hero__item strong{white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;line-height:1.15;overflow:hidden}.classroom-tabs{margin-inline:-2px;padding:8px}.classroom-tabs__item{padding:8px 11px;font-size:.82rem}.detail-grid,.detail-side{gap:12px}.file-card{grid-template-columns:minmax(0,1fr);justify-items:stretch}.file-card__icon{border-radius:16px;width:56px;height:56px}.file-card__actions,.resource-row__actions,.classroom-card__actions,.file-card__actions .btn,.resource-row__actions .btn,.classroom-card__actions .btn,.student-picker__item .btn,.form-actions--mobile-stack .btn{width:100%}.resource-row,.student-row,.student-picker__item{flex-direction:column;grid-template-columns:minmax(0,1fr);align-items:stretch}.resource-row{gap:10px;padding:12px 0}.resource-row__actions{grid-template-columns:minmax(0,1fr);gap:8px;display:grid}.resource-row__meta{gap:7px;font-size:.8rem}.info-list li{flex-direction:column;gap:8px}.info-list li strong{text-align:left}.classroom-card__footer,.classroom-card__stats,.classroom-card__top,.classroom-resources-meta,.section-block__head{align-items:flex-start}.topbar__right{gap:10px;display:grid}.topbar__cta{width:100%}.topbar__search-results{max-height:calc(100vh - 150px);position:fixed;top:132px;left:12px;right:12px;overflow:hidden}.user-menu{justify-content:space-between;width:100%}.user-menu__infos{display:none}.collaborative-doc__toolbar{flex-direction:column;align-items:flex-start}.collaborative-doc__presence{word-break:break-word;width:100%}.date-picker-popover__footer{flex-direction:column}.date-picker-popover__footer .btn{width:100%}.date-picker-popover__manual-row,.date-picker-popover__selectors{grid-template-columns:minmax(0,1fr)}.invitation-link-row{flex-direction:column;align-items:stretch}.invitation-link-row .btn{width:100%}}@media (width>=941px){html{font-size:14px}.app-layout{grid-template-columns:248px minmax(0,1fr)}.app-layout__content{padding:20px}.sidebar{padding:22px 14px}.sidebar__brand{gap:10px;margin-bottom:20px}.sidebar__logo{flex:0 0 46px;width:46px;height:46px}.sidebar__link{border-radius:13px;padding:10px 12px}.topbar{min-height:64px;padding:10px 20px}.topbar__search input{border-radius:12px;height:38px}.user-avatar{border-radius:12px;width:36px;height:36px}.page-section{gap:18px}.page-header{gap:14px}.page-header h1{margin-bottom:6px;font-size:clamp(1.55rem,3vw,2.15rem)}.panel-card,.stat-card,.upload-box,.auth-card,.status-card,.empty-state{border-radius:18px}.panel-card{gap:14px;padding:18px}.panel-card--compact{padding:14px}.btn{border-radius:12px;min-height:38px;padding:0 13px;font-size:.9rem}.btn-compact{border-radius:9px;min-height:30px;padding:0 9px;font-size:.78rem}.field{gap:7px}.field__input,.field__textarea{border-radius:12px;padding:10px 12px}.detail-grid,.files-layout,.profile-grid,.classroom-grid,.stats-grid{gap:14px}.classroom-card{border-radius:18px;gap:12px;min-height:210px;padding:16px}.classroom-hero{padding:14px 16px}.classroom-hero__item{border-radius:14px;padding:12px}.project-workbench,.project-workbench--text{grid-template-columns:248px minmax(0,1fr);gap:16px}.project-file-button{border-radius:12px;padding:10px}.project-file-delete{border-radius:12px;width:34px}.project-monaco-wrap,.project-preview-frame{border-radius:14px}}
