:root{--primary: #2563eb;--primary-hover: #1d4ed8;--primary-light: #dbeafe;--primary-dark: #1e3a8a;--bg: #ebf2ff;--bg-alt: #e2ebfa;--surface: #ffffff;--surface-hover: #f3f7ff;--border: #d8e4f7;--border-dark: #c5d4ed;--text: #0f172a;--text-muted: #64748b;--text-light: #94a3b8;--success: #059669;--warning: #d97706;--error: #dc2626;--danger: #dc2626;--info: #0284c7;--ease-out: cubic-bezier(.33, 1, .68, 1);--ease-standard: cubic-bezier(.4, 0, .2, 1);--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 12px rgba(15, 23, 42, .07), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 28px -10px rgba(15, 23, 42, .1), 0 4px 10px rgba(15, 23, 42, .05);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--max-width: 1280px;--app-gutter: clamp(5px, 1vw, 10px);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--text-display: clamp(1.75rem, 4vw, 2.25rem);--text-title: 1.25rem;--text-body: 1rem;--text-small: .875rem;--text-caption: .8125rem;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-interactive: 0 10px 28px -8px rgba(37, 99, 235, .12), 0 4px 12px rgba(15, 23, 42, .06);--elevation-1: var(--shadow);--elevation-2: var(--shadow-md);--elevation-3: var(--shadow-lg);--sidebar-width-max: 300px;--sidebar-width: 260px;--sidebar-width-collapsed: 72px;--topbar-height: 56px;--sidebar-bg: var(--surface);--sidebar-border: var(--border);--surface-elevated: #ffffff;--focus-ring: 0 0 0 3px rgba(37, 99, 235, .28)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;left:-9999px;z-index:9999;padding:var(--space-3) var(--space-4);background:var(--primary);color:#fff!important;border-radius:var(--radius)}.skip-link:focus{left:var(--space-4);top:var(--space-4);outline:none;box-shadow:var(--focus-ring)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.app-shell a:focus-visible,.app-shell button:focus-visible,.app-topbar a:focus-visible,.app-topbar button:focus-visible,.landing a:focus-visible,.landing button:focus-visible,.login-page a:focus-visible,.btn-primary:focus-visible,.btn-secondary:focus-visible,.btn-outline:focus-visible,.btn-danger:focus-visible,.ui-btn-ghost:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.app-shell input:focus-visible,.app-shell select:focus-visible,.app-shell textarea:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ui-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.profile-learning-carousel,.udemy-learning-carousel{width:100%;min-width:0;max-width:100%;box-sizing:border-box;gap:var(--app-gutter);scrollbar-width:thin;scrollbar-color:var(--border) transparent}.udemy-learning-carousel:has(>.udemy-carousel__item:only-child),.profile-learning-carousel:has(>.udemy-carousel__item:only-child){overflow-x:visible}.udemy-learning-carousel:has(>.udemy-carousel__item:only-child)>.udemy-carousel__item:not(.udemy-carousel__item--compact),.profile-learning-carousel:has(>.udemy-carousel__item:only-child)>.udemy-carousel__item:not(.udemy-carousel__item--compact){flex:0 0 min(260px,100%)!important;width:auto!important;max-width:min(300px,100%)!important}.udemy-learning-carousel:has(>.udemy-carousel__item--compact:only-child)>.udemy-carousel__item--compact,.profile-learning-carousel:has(>.udemy-carousel__item--compact:only-child)>.udemy-carousel__item--compact{flex:0 0 min(220px,100%)!important;width:auto!important;max-width:min(260px,100%)!important}.profile-learning-carousel::-webkit-scrollbar,.udemy-learning-carousel::-webkit-scrollbar{height:6px}.profile-learning-carousel::-webkit-scrollbar-track,.udemy-learning-carousel::-webkit-scrollbar-track{background:transparent}.profile-learning-carousel::-webkit-scrollbar-thumb,.udemy-learning-carousel::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}.udemy-learning-card__cover-link:hover .udemy-learning-card__cover{filter:brightness(1.06)}*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}[dir=rtl]{text-align:right}[dir=rtl] .container,[dir=rtl] nav{direction:rtl}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;min-height:100vh;overflow-x:clip}#root{min-width:0;max-width:100%;min-height:100vh}a{color:var(--primary);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover)}button{font-family:inherit;cursor:pointer;border:none;border-radius:9999px;padding:.65rem 1.5rem;font-size:.95rem;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap}.btn-primary,.btn-secondary,.btn-outline{display:inline-flex;align-items:center;justify-content:center;text-align:center;padding:.65rem 1.5rem;white-space:nowrap;transition:background .2s var(--ease-standard),color .2s var(--ease-standard),border-color .2s var(--ease-standard),box-shadow .28s var(--ease-out),transform .22s var(--ease-out)}.btn-primary{background:var(--surface-elevated);color:var(--primary)!important;font-weight:600;border:2px solid var(--primary);border-radius:9999px}.btn-primary:hover{background:var(--primary);color:#fff!important;border-color:var(--primary);transform:translateY(-1px);box-shadow:0 8px 22px #2563eb47}.btn-secondary{background:var(--surface-elevated);color:var(--text)!important;border:2px solid var(--border-dark);font-weight:500;border-radius:9999px}.btn-secondary:hover{background:var(--primary);border-color:var(--primary);color:#fff!important;box-shadow:0 6px 18px #2563eb38}.btn-outline{background:var(--surface-elevated);color:var(--primary)!important;border:2px solid var(--primary);border-radius:9999px}.btn-outline:hover{background:var(--primary);color:#fff!important;border-color:var(--primary);box-shadow:0 8px 22px #2563eb42}.btn-primary:active,.btn-secondary:active,.btn-outline:active{transform:translateY(0);box-shadow:0 2px 8px #2563eb26}button,a.btn-primary,a.btn-secondary,a.btn-outline,input[type=submit],input[type=button]{border-radius:9999px}.status-badge{display:inline-flex;align-items:center;align-self:flex-start;width:fit-content;padding:.2rem .5rem;font-size:.85rem;font-weight:500;border-radius:9999px;border:2px solid var(--border-dark);background:var(--surface-hover);color:var(--text)}.status-badge.status-draft{border-color:var(--text-muted);color:var(--text-muted)}.status-badge.status-published{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}input:not([type=checkbox]):not([type=radio]):not([type=file]),select,textarea{font-family:inherit;font-size:1rem;padding:.65rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-elevated);color:var(--text);width:100%;transition:border-color .2s}input[type=checkbox],input[type=radio]{width:auto;max-width:none;flex-shrink:0;padding:0;vertical-align:middle}input:not([type=checkbox]):not([type=radio]):not([type=file]):focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}label{display:block;font-weight:500;margin-bottom:.35rem;color:var(--text)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem;box-shadow:var(--shadow);transition:box-shadow .28s var(--ease-out),transform .28s var(--ease-out),border-color .22s var(--ease-standard)}@media(prefers-reduced-motion:no-preference){.card:hover{transform:translateY(-1px);box-shadow:var(--shadow-interactive);border-color:#2563eb33}}@media(prefers-reduced-motion:reduce){.card:hover{box-shadow:var(--shadow-md)}}.card--elevated{box-shadow:var(--elevation-2);border-color:var(--border-dark)}.app-main-inner .card{border-top:none;padding:.75rem .85rem;margin-bottom:var(--app-gutter)}.ui-card-header{margin:0 0 var(--app-gutter);padding-bottom:var(--space-2);border-bottom:1px solid var(--border);font-size:var(--text-title);font-weight:700}.ui-card-body{min-width:0}.ui-modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--space-4)}@media(prefers-reduced-motion:no-preference){.ui-modal-overlay{animation:ui-modal-fade-in .15s ease}}@keyframes ui-modal-fade-in{0%{opacity:0}to{opacity:1}}.ui-modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--elevation-3);max-width:min(440px,100%);width:100%;padding:var(--space-6);max-height:min(90vh,800px);overflow-y:auto}.ui-modal-panel--wide{max-width:min(560px,100%)}.ui-btn-ghost{background:transparent!important;border:2px solid transparent!important;color:var(--text-muted)!important;font-weight:500}.ui-btn-ghost:hover{background:var(--surface-hover)!important;color:var(--primary)!important;border-color:var(--border)!important}.btn-danger{background:var(--surface-elevated)!important;color:var(--danger)!important;border:2px solid var(--danger)!important;font-weight:600}.btn-danger:hover{background:var(--danger)!important;color:#fff!important}.ui-badge-info{border-color:var(--info);color:var(--info);background:#0284c714}.ui-badge-inline{margin-inline-start:.35rem;vertical-align:middle}.page-header{margin-bottom:var(--app-gutter);min-width:0;width:100%}.page-header h1{margin:0;font-size:var(--text-display);font-weight:700;letter-spacing:-.02em;line-height:1.2}.page-header .page-header__subtitle{margin:var(--space-2) 0 0;color:var(--text-muted);font-size:var(--text-small);max-width:42rem}.course-ai-page{width:100%;max-width:none;min-width:0}.course-ai-card{width:100%;max-width:none;box-sizing:border-box}.course-ai-textarea{min-height:5.5rem;resize:vertical;font-family:inherit;line-height:1.5}.project-form-page{width:100%;max-width:none;min-width:0}.project-form-card{width:100%;max-width:none;box-sizing:border-box}.project-form-textarea{min-height:5rem;resize:vertical;font-family:inherit;line-height:1.5}.ui-grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,240px),1fr));gap:var(--app-gutter);width:100%;min-width:0}.ui-grid-cards .card{margin-bottom:0;display:flex;flex-direction:column;height:100%;transition:transform .15s ease,box-shadow .15s ease}.ui-grid-cards--natural-height{align-items:start}.ui-grid-cards--natural-height .card{height:auto;width:100%;max-width:100%;box-sizing:border-box}.ui-grid-cards--course-list{align-items:stretch}.ui-grid-cards--course-list .card{height:100%;min-height:280px}@media(prefers-reduced-motion:no-preference){.ui-grid-cards .card:hover{transform:translateY(-2px)}}.course-card{min-width:0;overflow:hidden;box-sizing:border-box}.course-card__head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:var(--space-2);min-width:0}.course-card__title{flex:1 1 12rem;min-width:0;margin:0;font-size:1.1rem;font-weight:700;line-height:1.35;overflow-wrap:anywhere;word-break:break-word}.course-card__title a{color:var(--primary);text-decoration:none}.course-card__title a:hover{color:var(--primary-hover);text-decoration:underline}.course-card__actions{display:flex;flex:0 1 auto;flex-wrap:wrap;gap:.25rem;align-items:center;justify-content:flex-end;max-width:100%}.course-card__desc{margin:.5rem 0 0;color:var(--text-muted);font-size:.9rem;min-width:0;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:5;line-clamp:5}.course-card__meta{margin-top:auto;padding-top:.75rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;flex-shrink:0}.profile-page-wrap{width:100%;min-width:0;max-width:100%;margin-inline:0;box-sizing:border-box}.profile-top-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--app-gutter);align-items:stretch;width:100%;min-width:0}.profile-field-box>*+*{border-top:1px solid var(--border)}@container app-main (max-width: 720px){.profile-top-grid{grid-template-columns:1fr}}@media(max-width:640px){.profile-top-grid{grid-template-columns:1fr}}.course-player{width:100%;min-width:0;max-width:100%;box-sizing:border-box}.course-player__toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--app-gutter)}.dash-section{margin-bottom:var(--app-gutter)}.ideation-page{width:100%;min-width:0;box-sizing:border-box}.ideation-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,1fr);gap:var(--space-3);align-items:start;margin-top:var(--space-2)}.ideation-panel-title{margin:0 0 var(--space-3);font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:.02em}.ideation-composer-card{padding:var(--space-4)!important}.ideation-form{display:flex;flex-direction:column;gap:var(--space-2);margin:0}.ideation-label{font-size:var(--text-small);font-weight:600;color:var(--text-muted)}.ideation-textarea{width:100%;min-width:0;min-height:min(360px,52vh);padding:var(--space-3);border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-alt);color:var(--text);font:inherit;font-size:1rem;line-height:1.55;resize:vertical;box-sizing:border-box}.ideation-textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--focus-ring)}.ideation-form-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-1)}.ideation-form-actions .btn-primary{padding:.55rem 1.25rem;font-weight:700}.ideation-aside{display:flex;flex-direction:column;gap:var(--space-3);min-width:0}.ideation-how-card,.ideation-history-card{padding:var(--space-4)!important}.ideation-steps{margin:0;padding-inline-start:1.25rem;color:var(--text-muted);font-size:var(--text-small);line-height:1.6;display:flex;flex-direction:column;gap:var(--space-2)}.ideation-steps li{padding-inline-start:.15rem}.ideation-empty{margin:0;color:var(--text-muted);font-size:var(--text-small);line-height:1.5}.ideation-history-list{list-style:none;margin:0;padding:0;max-height:min(55vh,480px);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-2);scrollbar-width:thin}.ideation-history-item{padding:var(--space-3);border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-alt)}.ideation-history-meta{font-size:.75rem;color:var(--text-muted);margin-bottom:var(--space-1)}.ideation-history-kicker{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);margin-bottom:.2rem}.ideation-history-rough{margin:0 0 var(--space-2);font-size:.9rem;line-height:1.45;color:var(--text)}.ideation-details summary{cursor:pointer;font-size:var(--text-small);font-weight:600;color:var(--primary);list-style:none}.ideation-details summary::-webkit-details-marker{display:none}.ideation-result-full{margin-top:var(--space-3);padding:var(--space-4)!important;width:100%;box-sizing:border-box}.ideation-result-label{margin:0 0 var(--space-2);font-size:var(--text-small);font-weight:600;color:var(--text-muted)}.ideation-proposal{margin:0;white-space:pre-wrap;word-break:break-word;font-family:var(--font);font-size:.95rem;line-height:1.6;padding:var(--space-3);border-radius:var(--radius);background:var(--bg-alt);border:1px solid var(--border);color:var(--text);max-height:min(70vh,720px);overflow:auto}.ideation-proposal--nested{margin-top:var(--space-2);max-height:min(40vh,320px);font-size:.88rem}@container app-main (max-width: 960px){.ideation-layout{grid-template-columns:1fr}}@media(max-width:960px){.ideation-layout{grid-template-columns:1fr}.ideation-textarea{min-height:min(280px,45vh)}}.course-player-grid{display:grid;width:100%;min-width:0;gap:var(--app-gutter);align-items:start}.course-player-grid--split{grid-template-columns:minmax(200px,min(280px,34vw)) minmax(0,1fr)}.course-player-grid--full{grid-template-columns:minmax(0,1fr)}.course-player__aside{position:sticky;top:var(--space-4);padding:var(--space-4);max-height:calc(100vh - 8rem);overflow-y:auto}.course-player__main{width:100%;min-width:0;overflow:visible}@container app-main (max-width: 768px){.course-player-grid--split{grid-template-columns:1fr}}@media(max-width:768px){.course-player-grid--split{grid-template-columns:1fr}}.ui-pill-tabs{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--app-gutter)}.ui-stack{display:flex;flex-direction:column;gap:var(--app-gutter)}.dashboard-welcome{margin-bottom:var(--app-gutter);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--border);border-top:none;background:linear-gradient(135deg,var(--bg-alt) 0%,var(--surface) 55%,var(--bg-alt) 100%);box-shadow:var(--shadow-md);width:100%;min-width:0;box-sizing:border-box}.dashboard-welcome h1{margin:0 0 var(--space-2);font-size:clamp(1.45rem,3.5vw,1.85rem);font-weight:800;letter-spacing:-.02em}.dashboard-welcome p{margin:0 0 var(--space-3);color:var(--text-muted);font-size:var(--text-body);max-width:35rem;line-height:1.55}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}main.layout-main-wide{max-width:none!important;width:100%!important;min-width:0;box-sizing:border-box}.practice-lab-card{min-width:0;overflow:hidden}.practice-lab-card__desc{margin:.5rem 0 0;color:var(--text-muted);font-size:.9rem;min-width:0;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:6;line-clamp:6}.practice-lab-card__head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:var(--space-2);min-width:0}.practice-lab-card__title{flex:1 1 auto;min-width:0;margin:0;font-size:1.1rem;font-weight:700;line-height:1.35;overflow-wrap:anywhere;word-break:break-word}.practice-lab-card__title a{color:var(--primary);text-decoration:none}.practice-lab-card__title a:hover{color:var(--primary-hover);text-decoration:underline}.practice-lab-card__actions{display:flex;flex:0 0 auto;flex-shrink:0;flex-wrap:wrap;gap:.25rem;align-items:center;justify-content:flex-end;max-width:100%}.exam-attempts-section{margin-top:var(--space-4);width:100%;min-width:0}.exam-attempts-section h2{margin:0 0 var(--space-2);font-size:1.15rem;font-weight:700}.exam-attempts-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface)}.exam-attempts-table{width:100%;min-width:36rem;table-layout:fixed;border-collapse:collapse;font-size:var(--text-small)}.exam-attempts-table col.exam-attempts-table__col--student{width:36%}.exam-attempts-table col.exam-attempts-table__col--score{width:14%}.exam-attempts-table col.exam-attempts-table__col--status{width:22%}.exam-attempts-table col.exam-attempts-table__col--actions{width:28%}.exam-attempts-table thead th{text-align:start;font-weight:600;color:var(--text-muted);padding:.65rem .85rem;border-bottom:1px solid var(--border);background:var(--bg-alt);vertical-align:bottom}.exam-attempts-table tbody td{text-align:start;padding:.65rem .85rem;border-bottom:1px solid var(--border);vertical-align:middle;word-break:break-word}.exam-attempts-table tbody tr:last-child td{border-bottom:none}.exam-attempts-table tbody td:nth-child(2){white-space:nowrap}.exam-attempts-table tbody td:last-child{text-align:end}.exam-attempts-table thead th:last-child{text-align:end}.exam-create-coding-panel{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.exam-create-coding-panel textarea{max-width:100%;box-sizing:border-box}.mcq-options{display:flex;flex-direction:column;gap:1rem;margin:.5rem 0 0;padding:.25rem 0 0;width:100%;max-width:100%;box-sizing:border-box}.mcq-option-row{display:flex;align-items:center;gap:.85rem;margin:0;cursor:pointer;font-size:1rem;line-height:1.5;min-width:0}.mcq-option-row:not(.mcq-option-row--editor){color:var(--text-muted)}.mcq-option-row--editor{align-items:center}.mcq-option-radio,input[type=checkbox].ui-checkbox-square{appearance:none;-webkit-appearance:none;width:1.125rem;height:1.125rem;min-width:1.125rem;min-height:1.125rem;margin:0;flex-shrink:0;border:1.5px solid var(--border, #c5d0dc);border-radius:.3rem;background:var(--surface, #fff);cursor:pointer;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}.mcq-option-radio:hover:not(:disabled),input[type=checkbox].ui-checkbox-square:hover:not(:disabled){border-color:var(--text-muted)}.mcq-option-radio:focus-visible,input[type=checkbox].ui-checkbox-square:focus-visible{outline:2px solid var(--primary, #3b82f6);outline-offset:2px}.mcq-option-radio:checked,input[type=checkbox].ui-checkbox-square:checked{background-color:var(--primary, #2563eb);border-color:var(--primary, #2563eb);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3E%3Cpath d='M13.78 4.22a.75.75 0 010 1.06l-7.25 7.25a.75.75 0 01-1.06 0L2.22 9.28a.75.75 0 111.06-1.06l2.97 2.97 6.72-6.72a.75.75 0 011.06 0z'/%3E%3C/svg%3E");background-size:.72rem;background-position:center;background-repeat:no-repeat}.mcq-option-radio:disabled{opacity:.45;cursor:not-allowed}.mcq-option-label{flex:1;min-width:0;color:var(--text-muted);line-height:1.5}.mcq-option-text-input{flex:1;min-width:0;margin:0}.admin-share-inst-dropdown{border-radius:.35rem}.admin-share-option-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .75rem;margin:0;cursor:pointer;min-height:2.5rem;box-sizing:border-box;border-radius:.35rem;transition:background .15s ease,box-shadow .15s ease}.admin-share-option-row:hover{background:var(--bg-alt, rgba(0, 0, 0, .04))}.admin-share-option-row:has(input.ui-checkbox-square:checked){box-shadow:inset 0 0 0 1.5px var(--primary, #2563eb);background:#2563eb14}.admin-share-option-row span{flex:1;min-width:0;text-align:left;font-size:.95rem;line-height:1.45;color:var(--text)}.admin-share-option-row--header{font-weight:600;border-bottom:1px solid var(--border);border-radius:0}.coding-ai-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;min-width:0;width:100%;max-width:100%;box-sizing:border-box}.coding-ai-row input:not([type=checkbox]):not([type=radio]),.coding-ai-row select{width:auto;min-width:0;max-width:min(420px,100%);flex:1 1 180px}.coding-ai-row input[type=number]{flex:0 1 auto;min-width:min(12rem,100%);max-width:min(16rem,100%)}.coding-ai-row input[type=number].exam-mcq-ai-count{min-width:min(14rem,100%)}.coding-ai-row .btn-secondary,.coding-ai-row button{flex-shrink:0}.coding-difficulty-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;min-width:0}.coding-difficulty-row select{width:auto;max-width:280px}.section{padding:4rem 0}.section-alt{background:var(--bg-alt)}.error-msg{color:var(--error);font-size:.9rem;margin-top:.25rem}.nav-link{color:var(--text-muted)!important;font-weight:500;padding:.5rem 1rem;border-radius:var(--radius);transition:color .2s var(--ease-standard),background .2s var(--ease-standard),box-shadow .25s var(--ease-out),transform .15s var(--ease-out);text-decoration:none;position:relative}.nav-link:hover{color:var(--primary)!important;background:var(--surface-hover)}.nav-link:active{transform:scale(.98)}.nav-link.active{color:var(--primary)!important;background:var(--primary-light);font-weight:600;box-shadow:var(--shadow-sm)}.landing-nav{position:sticky;top:0;z-index:100;background:#ebf2fff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);padding:.75rem 0}.landing-hero{background:linear-gradient(165deg,#ebf2ff,#e2ebfa 42%,#d8e4fc);padding:5rem 0}.landing-hero .hero-title{color:var(--text);text-shadow:none}.landing-hero .hero-subtitle{color:var(--text-muted)}.hero-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.2;color:var(--text);margin-bottom:1rem}.hero-subtitle{font-size:1.25rem;color:var(--text-muted);max-width:600px;margin:0 auto 2rem}.cta-group{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature-card{padding:1.5rem;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);transition:box-shadow .28s var(--ease-out),transform .28s var(--ease-out),border-color .22s var(--ease-standard)}@media(prefers-reduced-motion:no-preference){.feature-card:hover{border-color:#2563eb47;box-shadow:var(--shadow-interactive);transform:translateY(-2px)}}@media(prefers-reduced-motion:reduce){.feature-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}}.benefits-list{list-style:none;padding:0;margin:0}.benefits-list li{padding:.5rem 0 .5rem 1.5rem;position:relative}.benefits-list li:before{content:"✓";position:absolute;left:0;color:var(--primary);font-weight:700}.faq-item{border-bottom:1px solid var(--border);padding:1rem 0}.faq-item:last-child{border-bottom:none}.faq-question{font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.faq-question:hover{color:var(--primary)}.faq-answer{color:var(--text-muted);padding-top:.5rem;line-height:1.7}.footer{background:var(--text);color:#94a3b8;padding:3rem 0 2rem;margin-top:4rem}.footer a{color:#cbd5e1}.footer a:hover{color:#fff}.btn-settings{color:var(--text)!important}.app-shell{display:flex;min-height:100vh;width:100%;max-width:100%;min-width:0;background:var(--bg);overflow-x:clip}.app-sidebar{width:max-content;max-width:min(var(--sidebar-width-max),100vw);flex-shrink:0;background:var(--sidebar-bg);border-inline-end:1px solid var(--sidebar-border);display:flex;flex-direction:column;position:sticky;top:0;align-self:flex-start;height:100vh;overflow-y:auto;overflow-x:hidden;z-index:150;transition:transform .2s ease,box-shadow .2s ease,width .22s ease}.app-sidebar__brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-4);border-bottom:1px solid var(--sidebar-border);min-height:var(--topbar-height)}.app-sidebar__brand-link{display:flex;align-items:center;justify-content:flex-start;gap:var(--space-2);min-width:0;font-weight:700;font-size:var(--text-title);color:var(--text)!important;text-decoration:none}.app-sidebar__brand-mark{display:none;width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary);align-items:center;justify-content:center;font-weight:800;font-size:.85rem;flex-shrink:0}.app-sidebar__brand-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-sidebar:not(.app-sidebar--collapsed) .app-sidebar__brand-text{min-width:min-content;overflow:visible;text-overflow:clip}.app-sidebar__nav{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);flex:1}.app-sidebar__nav .nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-lg);width:100%;box-sizing:border-box}.app-sidebar__nav .nav-link__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.app-sidebar__nav .nav-link.active .nav-link__icon,.app-sidebar__nav .nav-link:hover .nav-link__icon{color:var(--primary)}.app-sidebar__nav .nav-link__label{min-width:0}@media(min-width:900px){.app-sidebar:not(.app-sidebar--collapsed) .app-sidebar__nav .nav-link__label{white-space:nowrap}}@media(min-width:900px){.app-sidebar.app-sidebar--collapsed{width:var(--sidebar-width-collapsed);max-width:var(--sidebar-width-collapsed)}.app-sidebar--collapsed .app-sidebar__brand{justify-content:center;padding-inline:var(--space-2)}.app-sidebar--collapsed .app-sidebar__brand-link{justify-content:center}.app-sidebar--collapsed .app-sidebar__brand-mark{display:flex}.app-sidebar--collapsed .app-sidebar__brand-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-sidebar--collapsed .app-sidebar__nav .nav-link--with-icon{justify-content:center;padding-inline:var(--space-2)}.app-sidebar--collapsed .app-sidebar__nav .nav-link__label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-sidebar--collapsed .app-sidebar-profile__meta,.app-sidebar--collapsed .app-sidebar-profile__chevron{display:none}.app-sidebar--collapsed .app-sidebar-profile__trigger{justify-content:center;padding-inline:var(--space-2)}.app-sidebar--collapsed .app-sidebar-profile__panel--open.app-sidebar-profile__panel--from-rail{position:fixed;z-index:400;inset-inline-start:var(--sidebar-width-collapsed);bottom:var(--space-4);width:min(288px,calc(100vw - var(--sidebar-width-collapsed) - var(--space-6)));max-height:min(70vh,420px)!important;overflow-y:auto;margin:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:1;visibility:visible}[dir=rtl] .app-sidebar--collapsed .app-sidebar-profile__panel--open.app-sidebar-profile__panel--from-rail{inset-inline-start:auto;inset-inline-end:var(--sidebar-width-collapsed)}}.app-sidebar__dock{display:none;flex-shrink:0;padding:0 var(--space-2) var(--space-2)}@media(min-width:900px){.app-sidebar__dock{display:block}}.app-sidebar__dock-btn{width:100%;display:flex;align-items:center;justify-content:center;padding:var(--space-2);border-radius:var(--radius-lg);border:1px solid var(--sidebar-border);background:var(--surface-hover);color:var(--text-muted);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.app-sidebar__dock-btn:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.app-sidebar__dock-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}[dir=rtl] .app-sidebar__dock-btn svg{transform:scaleX(-1)}.app-sidebar__footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--sidebar-border);font-size:var(--text-small);color:var(--text-muted)}.app-sidebar-profile{margin-top:auto;border-top:1px solid var(--sidebar-border);padding:var(--space-2);flex-shrink:0}.app-sidebar-profile__trigger{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);border:none;border-radius:var(--radius-lg);background:transparent;cursor:pointer;color:inherit;text-align:start;font:inherit;transition:background .15s ease}.app-sidebar-profile__trigger:hover{background:var(--surface-hover)}.app-sidebar-profile__trigger:focus-visible{outline:2px solid var(--primary);outline-offset:2px}[dir=rtl] .app-sidebar-profile__meta{align-items:flex-end}[dir=rtl] .app-sidebar-profile__trigger{text-align:end}.app-sidebar-profile__avatar{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;letter-spacing:.02em}.app-sidebar-profile__meta{flex:1;min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.app-sidebar-profile__name{font-weight:600;color:var(--text);font-size:var(--text-small);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.app-sidebar-profile__role{font-size:.75rem;color:var(--text-muted);line-height:1.2}.app-sidebar-profile__chevron{flex-shrink:0;color:var(--text-muted);transition:transform .2s ease}.app-sidebar-profile__chevron--open{transform:rotate(180deg)}.app-sidebar-profile__panel{max-height:0;overflow:hidden;opacity:0;visibility:hidden;transition:max-height .28s ease,opacity .2s ease,visibility .2s}.app-sidebar-profile__panel--open{max-height:320px;opacity:1;visibility:visible}.app-sidebar-profile__panel-inner{padding:var(--space-2) var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.app-sidebar-profile__email{margin:0;font-size:.75rem;color:var(--text-muted);word-break:break-all;line-height:1.35}.app-sidebar-profile__link{display:block;padding:var(--space-2) var(--space-3);border-radius:var(--radius);font-size:var(--text-small);font-weight:500;color:var(--text)!important;text-decoration:none;background:var(--surface-hover);transition:background .15s ease,color .15s ease}.app-sidebar-profile__link:hover{background:var(--primary-light);color:var(--primary)!important}.app-sidebar-profile__link.active{background:var(--primary-light);color:var(--primary)!important;font-weight:600}.app-sidebar-profile__action{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-size:var(--text-small);font-weight:500;cursor:pointer;text-align:start;transition:background .15s ease,border-color .15s ease}.app-sidebar-profile__action:hover{background:var(--surface-hover);border-color:var(--border-dark)}.app-sidebar-profile__action--danger{color:var(--danger);border-color:#e74c3c59}.app-sidebar-profile__action--danger:hover{background:#e74c3c14;border-color:var(--danger)}@media(prefers-reduced-motion:reduce){.app-sidebar-profile__panel,.app-sidebar-profile__chevron{transition:none}.app-sidebar{transition:transform .2s ease,box-shadow .2s ease}}.app-shell__column{flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}.app-topbar{position:sticky;top:0;z-index:100;height:var(--topbar-height);min-height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:0 var(--app-gutter);background:#ebf2fff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);color:var(--text)}.app-topbar__left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.app-topbar__title{font-weight:600;font-size:var(--text-small);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(200px,40vw)}.app-topbar__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.app-menu-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border-radius:var(--radius);background:var(--surface-hover);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:background .15s ease,border-color .15s ease}.app-menu-btn:hover{background:var(--primary-light);border-color:var(--border-dark)}.app-menu-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.app-sidebar__backdrop{display:none;position:fixed;inset:0;background:#0f172a73;z-index:140;opacity:0;pointer-events:none;transition:opacity .2s ease}.app-sidebar__backdrop--visible{opacity:1;pointer-events:auto}.app-main-inner{flex:1;width:100%;min-width:0;max-width:100%;margin:0;padding:var(--app-gutter);box-sizing:border-box;overflow-x:auto;container-type:inline-size;container-name:app-main}.app-main-inner.layout-main-wide{max-width:none!important;width:100%!important}@media(max-width:899px){.app-menu-btn{display:inline-flex}.app-sidebar{position:fixed;inset-block:0;inset-inline-start:0;height:100%;box-shadow:var(--shadow-lg);transform:translate(-100%);max-width:min(var(--sidebar-width-max),calc(100vw - var(--space-4)))}[dir=rtl] .app-sidebar{transform:translate(100%);inset-inline-start:auto;inset-inline-end:0}.app-sidebar--open,[dir=rtl] .app-sidebar--open{transform:translate(0)}.app-sidebar__backdrop{display:block}.app-topbar__title{max-width:min(160px,35vw)}}@media(min-width:900px){.app-sidebar__backdrop{display:none!important}}[data-theme=dark]{--primary: #60a5fa;--primary-hover: #93c5fd;--primary-light: #1e3a8a;--primary-dark: #dbeafe;--bg: #0f172a;--bg-alt: #1e293b;--surface: #1e293b;--surface-hover: #334155;--border: #334155;--border-dark: #475569;--text: #f1f5f9;--text-muted: #94a3b8;--text-light: #64748b;--success: #34d399;--warning: #fbbf24;--error: #f87171;--danger: #f87171;--info: #38bdf8;--shadow: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.4);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.4);--btn-bg: #1e293b;--btn-border: #60a5fa;--btn-text: #60a5fa;--sidebar-bg: #1e293b;--surface-elevated: #334155}[data-theme=dark] .app-topbar{background:#0f172af0;border-bottom:none;box-shadow:none;color:var(--text)}[data-theme=dark] .app-topbar a{color:var(--text-muted)!important}[data-theme=dark] .app-topbar a:hover{color:var(--primary)!important}[data-theme=dark] .app-topbar__title{color:var(--text-muted)!important}[data-theme=dark] .app-menu-btn{background:var(--surface-hover);border-color:var(--border);color:var(--text)}[data-theme=dark] .landing-nav{background:#0f172af2}[data-theme=dark] .landing-nav .nav-link{color:var(--text-muted)!important}[data-theme=dark] .landing-nav .nav-link:hover{background:var(--surface-hover)!important;color:var(--primary)!important}[data-theme=dark] .landing-nav .nav-link.active{background:#60a5fa26!important;color:var(--primary)!important}[data-theme=dark] .nav-link:hover{background:var(--surface-hover);color:var(--primary)!important}[data-theme=dark] .nav-link.active{background:#60a5fa26;color:var(--primary)!important}[data-theme=dark] .landing-hero{background:linear-gradient(135deg,var(--bg-alt) 0%,var(--primary-light) 100%)}[data-theme=dark] .footer{background:#020617;color:#94a3b8}[data-theme=dark] .btn-settings{background:#ffffff1a!important;border-color:#ffffff4d!important;color:#fff!important}[data-theme=dark] .btn-settings:hover{background:#fff3!important;border-color:#ffffff80!important}[data-theme=dark] .btn-settings svg{stroke:#fff}[data-theme=dark] .btn-primary{background:var(--btn-bg)!important;color:var(--btn-text)!important;border:2px solid var(--btn-border)!important}[data-theme=dark] .btn-primary:hover{background:var(--primary)!important;color:#0f172a!important;border-color:var(--primary)!important}[data-theme=dark] .btn-secondary{background:var(--btn-bg)!important;color:var(--text-muted)!important;border:2px solid var(--border)!important}[data-theme=dark] .btn-secondary:hover{background:var(--primary)!important;color:#0f172a!important;border-color:var(--primary)!important}[data-theme=dark] .btn-outline{background:var(--btn-bg)!important;color:var(--btn-text)!important;border:2px solid var(--btn-border)!important}[data-theme=dark] .btn-outline:hover{background:var(--primary)!important;color:#0f172a!important;border-color:var(--primary)!important}[data-theme=dark] .status-badge{background:var(--surface-hover);border-color:var(--border);color:var(--text-muted)}[data-theme=dark] .status-badge.status-published{border-color:var(--primary);color:var(--primary);background:#60a5fa26}[data-theme=eye-comfort]{--primary: #ea580c;--primary-hover: #c2410c;--primary-light: #ffedd5;--primary-dark: #9a3412;--bg: #f5f0e6;--bg-alt: #ebe4d8;--surface: #fffef9;--surface-hover: #f5f0e6;--border: #e8e0d0;--border-dark: #ddd4c2;--text: #3d3629;--text-muted: #6b6356;--text-light: #8a8174;--success: #059669;--warning: #d97706;--error: #dc2626;--danger: #dc2626;--info: #0f766e;--shadow: 0 1px 3px rgba(61, 54, 41, .1);--shadow-md: 0 4px 12px rgba(251, 146, 60, .12), 0 2px 4px rgba(61, 54, 41, .06);--shadow-lg: 0 10px 22px -6px rgba(249, 115, 22, .14), 0 4px 8px rgba(61, 54, 41, .07)}[data-theme=eye-comfort] .landing-nav{background:#f5f0e6f2}[data-theme=eye-comfort] .nav-link:hover{background:var(--surface-hover);color:var(--primary)!important}[data-theme=eye-comfort] .nav-link.active{background:var(--primary-light);color:var(--primary-dark)!important}[data-theme=eye-comfort] .landing-hero{background:linear-gradient(135deg,var(--bg-alt) 0%,#e8e0d0 100%)}[data-theme=eye-comfort] .app-topbar{background:#fffef9f0}.rich-text-area:empty:before,.rich-text-area[data-placeholder]:empty:before,.rich-text-area[data-empty=true]:before{content:attr(data-placeholder);color:var(--text-light, #94a3b8)}.rich-text-area ul,.rich-text-area ol{margin:.5rem 0;padding-left:1.5rem}.rich-text-area li{margin:.25rem 0}.rich-text-area h1{font-size:1.5rem;font-weight:700;margin:.75rem 0 .5rem}.rich-text-area h2{font-size:1.25rem;font-weight:700;margin:.6rem 0 .4rem}.rich-text-area h3{font-size:1.1rem;font-weight:600;margin:.5rem 0 .35rem}.rich-text-area h4{font-size:1rem;font-weight:600;margin:.4rem 0 .3rem}.rich-text-area p{margin:.35rem 0}.module-content ul,.module-content ol{margin:.5rem 0;padding-left:1.5rem}.module-content li{margin:.25rem 0}.module-content h1{font-size:1.5rem;font-weight:700;margin:.75rem 0 .5rem}.module-content h2{font-size:1.25rem;font-weight:700;margin:.6rem 0 .4rem}.module-content h3{font-size:1.1rem;font-weight:600;margin:.5rem 0 .35rem}.module-content h4{font-size:1rem;font-weight:600;margin:.4rem 0 .3rem}.module-content p{margin:.35rem 0}.module-content strong{font-weight:700}.module-content em{font-style:italic}.module-content code{background:var(--bg-alt);padding:.1rem .3rem;border-radius:4px;font-size:.9em;font-family:Fira Code,Consolas,monospace}.module-content pre{background:var(--bg-alt);padding:.75rem;border-radius:var(--radius);overflow:auto;margin:.5rem 0}.module-content pre code{background:none;padding:0}.module-content img{max-width:100%;height:auto;vertical-align:middle}.module-content table{width:100%;max-width:100%;border-collapse:collapse;margin:.75rem 0;font-size:.95rem}.module-content th,.module-content td{border:1px solid var(--border);padding:.45rem .65rem;text-align:start;vertical-align:top}.module-content blockquote{margin:.75rem 0;padding:.5rem 0 .5rem 1rem;border-inline-start:4px solid var(--border-dark);color:var(--text-muted)}.pdf-viewer-container{max-width:900px;margin-left:auto;margin-right:auto}.pdf-viewer-book{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-md),0 0 0 1px #0f172a0a}.pdf-viewer-page{background:var(--surface-elevated);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 3px #0f172a0a,0 4px 14px #0f172a0f;min-height:600px}.pdf-viewer-iframe{width:100%;height:75vh;min-height:600px;border:none;display:block}.pdf-viewer-open-link{display:inline-block;margin-top:.5rem;font-size:.9rem;color:var(--primary)!important}.pdf-viewer-open-link:hover{color:var(--primary-hover)!important}.pdf-viewer-fullscreen{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;flex-direction:column;align-items:stretch}.pdf-viewer-fullscreen-close{position:absolute;top:1rem;right:1rem;z-index:10001;width:44px;height:44px;border-radius:50%;border:2px solid var(--border);background:var(--surface);color:var(--text);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.pdf-viewer-fullscreen-close:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.pdf-viewer-fullscreen-iframe{flex:1;width:100%;border:none;display:block}[data-theme=dark] .pdf-viewer-book{background:var(--surface);border-color:var(--border);box-shadow:var(--shadow-md)}[data-theme=dark] .pdf-viewer-page{background:#1e293b;box-shadow:inset 0 1px 2px #0000004d,0 4px 12px #0006}[data-theme=eye-comfort] .pdf-viewer-book{background:var(--surface);border-color:var(--border)}[data-theme=eye-comfort] .pdf-viewer-page{background:#fffef9;box-shadow:inset 0 1px 2px #3d36290f,0 4px 12px #3d36291a}.exam-coding-shell-root{min-height:100vh;background:#0b111e;color:#e2e8f0}.exam-coding-shell-main{display:flex;flex-direction:column;min-height:100vh;max-width:none;width:100%;margin:0;padding:0;box-sizing:border-box}.exam-coding-header{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;border-bottom:1px solid rgba(148,163,184,.22);background:#0f172aeb;flex-wrap:wrap;gap:.75rem}.exam-coding-header h1{margin:0;font-size:1.15rem;font-weight:600;color:#f8fafc;letter-spacing:.01em}.exam-coding-timer{font-variant-numeric:tabular-nums;font-size:1.35rem;font-weight:600;color:#f8fafc}.exam-coding-timer--warn{color:#fbbf24}.exam-coding-tabs{flex-shrink:0;display:flex;flex-wrap:wrap;gap:.25rem;padding:.35rem 1rem 0;border-bottom:1px solid rgba(148,163,184,.18);background:#111827f2}.exam-coding-tab{padding:.45rem .9rem;font-size:.85rem;font-weight:600;color:#94a3b8;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;border-radius:.25rem .25rem 0 0}.exam-coding-tab:hover{color:#cbd5e1}.exam-coding-tab.active{color:#60a5fa;border-bottom-color:#3b82f6}.exam-coding-split{flex:1;display:grid;grid-template-columns:1fr 1.25fr;min-height:0;min-height:min(65vh,calc(100vh - 10rem));overflow:hidden}@media(max-width:900px){.exam-coding-split{grid-template-columns:1fr;min-height:min(75vh,calc(100vh - 9rem))}}.exam-coding-problem-pane{display:flex;flex-direction:column;min-width:0;min-height:0;background:#111827;border-right:1px solid rgba(148,163,184,.18);overflow:hidden}.exam-coding-problem-tabs{flex-shrink:0;display:flex;gap:0;border-bottom:1px solid rgba(148,163,184,.18);background:#0f172ad9;padding:0 .35rem}.exam-coding-problem-tab{padding:.65rem 1rem;font-weight:600;font-size:.9rem;color:#94a3b8;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer}.exam-coding-problem-tab:hover{color:#cbd5e1}.exam-coding-problem-tab.active{color:#60a5fa;border-bottom-color:#3b82f6}.exam-coding-problem-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:1.25rem 1.5rem}.exam-coding-q-label{margin:0 0 .75rem;font-weight:700;font-size:1.05rem;color:#f8fafc}.exam-coding-problem-scroll .problem-statement{color:#cbd5e1;line-height:1.65}.exam-coding-problem-scroll .problem-statement h1,.exam-coding-problem-scroll .problem-statement h2,.exam-coding-problem-scroll .problem-statement h3,.exam-coding-problem-scroll .problem-statement strong{color:#f1f5f9}.exam-coding-problem-scroll .problem-statement code{background:#00000059;color:#e2e8f0;border:1px solid rgba(148,163,184,.2)}.exam-coding-problem-scroll .problem-statement pre{background:#0f172a;border-color:#94a3b840;color:#e2e8f0}.exam-coding-plain{margin:0;white-space:pre-wrap;color:#cbd5e1;line-height:1.65;font-size:.95rem}.exam-coding-ide-pane{display:flex;flex-direction:column;min-width:0;min-height:0;background:#0f172a;overflow:hidden}.exam-coding-ide-head{flex-shrink:0;padding:.5rem 1rem;border-bottom:1px solid rgba(148,163,184,.18);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#94a3b8}.exam-coding-ide-pane .practice-lab-ide-scroll.exam-coding-ide-scroll{flex:1;min-height:0;display:flex;flex-direction:column;overflow-y:auto}.exam-coding-ide-toolbar{border-bottom-color:#94a3b833!important;background:#0f172a80}.exam-coding-lang-select{padding:.4rem .65rem;font-size:.85rem;border-radius:6px;min-width:180px;background:#1e293b;color:#e2e8f0;border:1px solid rgba(148,163,184,.35)}.exam-coding-code-wrap{flex:1;min-height:0;display:flex;flex-direction:column;padding:1rem}.exam-coding-code-wrap .practice-lab-code-textarea{flex:1;min-height:220px;max-height:none;height:auto}.exam-coding-ide-pane .practice-lab-ide-editor{flex:0 0 auto}.exam-coding-ide-pane .practice-lab-code-textarea.exam-coding-code-editor{flex:0 0 auto;height:280px;min-height:240px;max-height:min(92vh,2000px);resize:vertical;box-sizing:border-box}.exam-coding-run-actions{background:#111827f2!important;border-top-color:#94a3b833!important}.exam-coding-custom-label{display:block;width:100%;font-size:.88rem;color:#94a3b8;margin-bottom:.35rem}.exam-coding-custom-input{width:100%;box-sizing:border-box;min-width:0;font-family:ui-monospace,Consolas,monospace;font-size:.85rem;padding:.5rem .65rem;margin-bottom:.65rem;border-radius:6px;border:1px solid rgba(148,163,184,.25);background:#1e293b;color:#e2e8f0}.exam-coding-run-output{margin:0 1rem 1rem!important;background:#1e293b!important;border-color:#94a3b840!important;color:#e2e8f0}.exam-coding-output-title{margin:0 0 .5rem;font-size:.95rem;color:#f1f5f9}.exam-coding-test-row{margin-bottom:.5rem;padding:.5rem .65rem;border-radius:6px;font-size:.88rem}.exam-coding-test-row--pass{background:#0596691f}.exam-coding-test-row--fail{background:#dc26261a}.exam-coding-test-pre{margin:.35rem 0 0;font-size:.8rem;white-space:pre-wrap;word-break:break-word}.exam-coding-stderr{color:#fca5a5}.exam-coding-run-summary{margin:.5rem 0 0;font-weight:600;color:#cbd5e1}.exam-coding-submit{flex-shrink:0;display:flex;justify-content:flex-end;align-items:center;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid rgba(148,163,184,.18);background:#111827fa}.practice-lab-page{display:flex;flex-direction:column;height:calc(100vh - 56px);min-height:400px;min-width:0;overflow:hidden}.practice-lab-page.practice-lab-page-with-form{height:auto;min-height:calc(100vh - 56px);overflow-y:auto;overflow-x:hidden}.practice-lab-page.practice-lab-page-with-form .practice-lab-main{flex:none;min-height:70vh}.practice-lab-main{display:grid;grid-template-columns:1fr 1.5fr;flex:1;min-height:0;overflow:hidden}.practice-lab-main.practice-lab-main--problem-only{grid-template-columns:1fr}.practice-lab-main.practice-lab-main--problem-only .practice-lab-ide-pane{display:none!important}.practice-lab-main.practice-lab-main--problem-only .practice-lab-problem-pane{border-right:none;max-width:100%}.practice-lab-problem-pane{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg-alt);border-right:1px solid var(--border);overflow:hidden}.practice-lab-problem-tabs{flex-shrink:0;display:flex;gap:0;border-bottom:1px solid var(--border);background:var(--surface);padding:0 .5rem 0 0}.practice-lab-problem-tab{padding:.75rem 1rem;font-weight:600;font-size:.9rem;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer}.practice-lab-problem-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.practice-lab-problem-list{flex-shrink:0;padding:.5rem;border-bottom:1px solid var(--border);max-height:min(40vh,260px);overflow-y:auto;display:flex;flex-direction:column;gap:.45rem}.practice-lab-problem-item{padding:.5rem .65rem;cursor:pointer;border-radius:var(--radius);font-size:.85rem;border:1px solid var(--border);background:var(--surface);box-sizing:border-box;transition:border-color .15s,background .15s}.practice-lab-problem-item:hover,.practice-lab-problem-item:focus-visible{border-color:var(--primary);outline:none}.practice-lab-problem-item--selected{border-color:var(--primary);background:var(--primary-light)}.practice-lab-problem-item-num{flex-shrink:0;font-weight:700;color:var(--text-muted)}.practice-lab-problem-item--selected .practice-lab-problem-item-num{color:var(--text)}.practice-lab-problem-item-title{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.practice-lab-problem-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:1rem 1.25rem}.practice-lab-ide-pane{display:flex;flex-direction:column;min-width:0;min-height:0;background:var(--bg);overflow:hidden}.practice-lab-ide-header{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.5rem}.practice-lab-ide-scroll{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.practice-lab-ide-editor{flex-shrink:0;min-height:260px;display:flex;flex-direction:column;padding:1rem}.practice-lab-ide-actions{flex-shrink:0;display:flex;flex-direction:column;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--border);background:var(--bg-alt)}.practice-lab-ide-actions .btn-primary{align-self:flex-start}.practice-lab-code-textarea{width:100%;height:260px;min-height:200px;max-height:min(92vh,2000px);font-family:Fira Code,Consolas,Monaco,monospace;font-size:.9rem;line-height:1.5;resize:vertical;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;background:#1e293b;color:#e2e8f0;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.practice-lab-code-textarea:focus{outline:none;border-color:var(--primary)}.practice-lab-output{flex-shrink:0;margin:0 1rem 1rem;padding:1rem;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);max-height:280px;overflow-y:auto}.problem-statement{font-size:.95rem;line-height:1.6;color:var(--text)}.problem-statement h1{font-size:1.35rem;font-weight:700;margin:0 0 .75rem;color:var(--text)}.problem-statement h2{font-size:1.15rem;font-weight:700;margin:1.25rem 0 .5rem;color:var(--text)}.problem-statement h3{font-size:1.05rem;font-weight:600;margin:1rem 0 .4rem;color:var(--text)}.problem-statement p{margin:.5rem 0}.problem-statement strong{font-weight:700;color:var(--text)}.problem-statement ul,.problem-statement ol{margin:.5rem 0;padding-left:1.5rem}.problem-statement li{margin:.35rem 0}.problem-statement code{background:#0000000f;padding:.15rem .4rem;border-radius:4px;font-family:Fira Code,Consolas,monospace;font-size:.88em}.problem-statement pre{background:#f1f5f9;border:1px solid var(--border);border-radius:6px;padding:.75rem 1rem;overflow-x:auto;margin:.5rem 0;font-size:.85rem}.problem-statement br{display:block;content:"";margin-top:.25rem}
