:root{color:#111827;background:#f7f7f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--brand: #f17224;--brand-soft: #fff3ea;--ink: #121826;--muted: #667085;--line: #e7e8ea;--surface: #ffffff}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;font-weight:400}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer;font-weight:500}input,select,textarea{font-weight:400}h1,h2,h3,h4,strong,b{font-weight:600}.app-shell{width:min(1220px,calc(100% - 32px));margin:0 auto;padding:24px 0 56px}.topbar{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;min-height:72px;margin-bottom:24px;padding:0 18px;border:1px solid var(--line);border-radius:8px;background:#fffffff0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand{display:inline-flex;gap:10px;align-items:center;font-size:22px;font-weight:600;color:var(--ink)}.brand svg{width:30px;height:30px;color:var(--brand)}.brand.large{margin-bottom:22px}nav{display:flex;gap:8px;align-items:center}nav a{padding:10px 14px;color:var(--ink);text-decoration:none;border-radius:8px}nav a:hover{background:var(--brand-soft);color:var(--brand)}.topbar nav>button{padding:10px 14px;color:var(--ink);border-radius:8px;background:transparent;font-weight:400}.topbar nav>button:hover{color:var(--brand);background:var(--brand-soft)}.icon-button{display:inline-grid;width:42px;height:42px;place-items:center;color:var(--brand);border-radius:8px;background:#fff}.icon-button:hover{background:var(--brand-soft)}.icon-button svg{width:20px;height:20px}.hero{display:grid;align-items:center;min-height:250px;margin-bottom:30px;padding:36px;color:#fff;border-radius:8px;background:linear-gradient(90deg,#121826d6,#1218265c),linear-gradient(135deg,#f17224,#1e4f78 58%,#1f2937)}.portal-hero{position:relative;display:flex;min-height:250px;align-items:center;margin-bottom:30px;overflow:hidden;color:#fff;border-radius:8px;background:#1f2937}.portal-hero-image,.portal-hero-shade{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.portal-hero-image{object-fit:cover}.portal-hero-shade{background:#12182694}.portal-hero-content{position:relative;z-index:1;width:min(720px,100%);padding:38px 74px}.portal-hero h1{margin:0;overflow-wrap:anywhere;font-size:34px;line-height:1.16}.portal-hero p{max-width:680px;margin:12px 0 0;font-size:17px;line-height:1.45}.portal-hero-action{display:inline-flex;min-height:44px;align-items:center;gap:8px;margin-top:24px;padding:0 20px;color:var(--brand);border-radius:8px;background:#fff;font-weight:600}.portal-hero-action:hover{background:var(--brand-soft)}.portal-hero-arrow{position:absolute;z-index:2;top:50%;display:grid;width:40px;height:40px;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.55);border-radius:8px;background:#12182685;transform:translateY(-50%)}.portal-hero-arrow:hover{background:#121826cc}.portal-hero-arrow.previous{left:14px}.portal-hero-arrow.next{right:14px}.portal-hero-dots{position:absolute;z-index:2;bottom:14px;left:50%;display:flex;gap:7px;transform:translate(-50%)}.portal-hero-dots button{width:8px;height:8px;padding:0;border-radius:4px;background:#ffffff8c}.portal-hero-dots button.active{width:30px;background:var(--brand)}.portal-hero-fallback .portal-hero-content{width:100%}.eyebrow{display:inline-block;margin-bottom:14px;font-weight:500;color:#ffd7bf}.eyebrow.dark{margin-bottom:8px;color:var(--brand)}.topbar-actions{display:flex;gap:6px;align-items:center}.notification-center,.notification-center .icon-button{position:relative}.notification-badge{position:absolute;top:2px;right:1px;display:grid;min-width:18px;height:18px;padding:0 4px;place-items:center;color:#fff;border:2px solid #fff;border-radius:9px;background:#d92d20;font-size:10px;font-weight:600}.notification-panel{position:absolute;z-index:30;top:calc(100% + 10px);right:0;width:min(380px,calc(100vw - 32px));overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 18px 44px #1118272e}.notification-panel>header{display:flex;min-height:50px;align-items:center;justify-content:space-between;gap:12px;padding:0 14px;border-bottom:1px solid var(--line)}.notification-panel>header button{padding:6px;color:var(--brand);background:transparent;font-size:12px;font-weight:500}.notification-list{max-height:430px;overflow-y:auto}.notification-item{display:grid;width:100%;grid-template-columns:8px minmax(0,1fr);gap:10px;padding:13px 14px;color:var(--ink);text-align:left;border-bottom:1px solid var(--line);background:#fff}.notification-item:hover{background:#f9fafb}.notification-item.unread{background:#fff7f2}.notification-dot{width:7px;height:7px;margin-top:6px;border-radius:50%;background:transparent}.notification-item.unread .notification-dot{background:var(--brand)}.notification-item strong,.notification-item small,.notification-item time{display:block}.notification-item small{margin-top:4px;color:var(--muted);line-height:1.4}.notification-item time{margin-top:7px;color:#98a2b3;font-size:11px}.notification-empty{padding:28px 16px;color:var(--muted);text-align:center}h1,h2,h3,p{margin:0}h1{max-width:720px;font-size:42px;line-height:1.08;letter-spacing:0}.hero p{margin-top:14px;max-width:760px;font-size:17px;line-height:1.55}.section-header{display:flex;gap:12px;align-items:center;margin:30px 0 14px}.section-header h2{font-size:22px}.section-header span{min-width:28px;padding:4px 9px;color:var(--brand);text-align:center;border-radius:999px;background:var(--brand-soft)}.catalog-toolbar{display:grid;grid-template-columns:1fr minmax(260px,360px);gap:16px;align-items:end}.search-box{display:flex;gap:10px;align-items:center;height:44px;padding:0 14px;border:1px solid var(--line);border-radius:8px;background:#fff}.search-box svg{width:18px;height:18px;color:var(--muted)}.search-box input{width:100%;border:0;outline:0}.course-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.course-card{display:grid;grid-template-rows:150px 1fr auto;min-height:380px;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.course-cover{display:grid;place-items:center;color:var(--brand);background:#f4f5f7}.course-cover svg{width:44px;height:44px}.course-cover img{width:100%;height:100%;object-fit:cover}.course-body{padding:18px}.course-badge{display:inline-flex;max-width:100%;margin-bottom:12px;padding:5px 9px;overflow:hidden;color:var(--brand);text-overflow:ellipsis;white-space:nowrap;border-radius:8px;background:var(--brand-soft)}.course-card h3{display:-webkit-box;min-height:54px;overflow:hidden;font-size:20px;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:2}.course-card p{display:-webkit-box;margin-top:10px;overflow:hidden;color:var(--muted);line-height:1.5;-webkit-box-orient:vertical;-webkit-line-clamp:3}.course-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-top:1px solid var(--line)}.course-footer span{color:var(--muted)}.course-footer button,.login-panel button{min-width:132px;padding:12px 18px;color:#fff;font-weight:500;border-radius:8px;background:var(--brand)}.course-footer button:hover,.login-panel button:hover{background:#dd651e}.login-panel button:disabled{cursor:wait;opacity:.7}.empty-state{grid-column:1 / -1;padding:32px;color:var(--muted);text-align:center;border:1px dashed var(--line);border-radius:8px;background:#fff}.alert{margin-bottom:18px;padding:12px 14px;color:#9b2c12;border:1px solid #fed7aa;border-radius:8px;background:#fff7ed}.admin-section-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:0;margin-bottom:26px;border-bottom:1px solid var(--line)}.admin-section-nav button{display:inline-flex;min-height:48px;align-items:center;justify-content:center;gap:8px;padding:0 14px;color:var(--muted);border-bottom:2px solid transparent;background:transparent;font-weight:400}.admin-section-nav button:hover{color:var(--ink);background:#fff}.admin-section-nav button.active{color:var(--brand);border-bottom-color:var(--brand);background:#fff;font-weight:500}.admin-section-content{min-height:420px}.admin-overview{display:grid;grid-template-columns:minmax(180px,1fr) 2fr auto;gap:18px;align-items:center;margin-bottom:30px;padding:22px;border:1px solid var(--line);border-radius:8px;background:#fff}.admin-overview h2{font-size:22px}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric{min-height:74px;padding:12px;border-radius:8px;background:#f7f7f8}.metric span{display:block;margin-bottom:8px;color:var(--muted);font-size:14px}.metric strong{color:var(--ink);font-size:24px}.download-link{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 18px;color:#fff;font-weight:500;text-decoration:none;border-radius:8px;background:var(--brand)}.admin-reports{display:grid;gap:16px;margin-bottom:30px}.report-heading,.report-table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.report-heading h2{font-size:22px}.report-heading .download-link{gap:8px}.report-metrics{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}.report-metrics .metric{border:1px solid var(--line);background:#fff}.report-filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;padding:16px;border:1px solid var(--line);border-radius:8px;background:#fff}.report-filters label{display:grid;gap:6px;color:var(--ink);font-size:13px;font-weight:500}.report-filters input,.report-filters select,.report-table-toolbar input{width:100%;min-width:0;min-height:42px;padding:9px 11px;color:var(--ink);border:1px solid var(--line);border-radius:8px;outline:0;background:#fff}.report-filters input:focus,.report-filters select:focus,.report-table-toolbar input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.report-filter-actions{display:flex;grid-column:1 / -1;justify-content:flex-end;gap:10px}.report-filter-actions button{display:inline-flex;min-height:42px;align-items:center;justify-content:center;gap:7px;padding:0 18px;color:#fff;border-radius:8px;background:var(--brand);font-weight:500}.report-filter-actions button.secondary-action{color:var(--brand);border:1px solid var(--brand);background:#fff}.report-filter-actions button:disabled{cursor:wait;opacity:.55}.report-table-toolbar label{position:relative;width:min(100%,360px)}.report-table-toolbar label svg{position:absolute;top:12px;left:12px;color:var(--muted)}.report-table-toolbar input{padding-left:40px}.report-table-toolbar>span{margin-left:auto;color:var(--muted);font-size:14px}.report-table-toolbar button,.report-pagination button{min-height:42px;padding:0 16px;color:#fff;border-radius:8px;background:var(--brand);font-weight:500}.report-table-toolbar button:disabled,.report-pagination button:disabled{cursor:default;opacity:.4}.report-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px;background:#fff}.report-table{width:100%;min-width:1120px;border-collapse:collapse;font-size:14px}.report-table th{padding:12px 14px;color:#475467;text-align:left;border-bottom:1px solid var(--line);background:#f7f7f8;font-size:12px;text-transform:uppercase}.report-table td{padding:13px 14px;vertical-align:top;border-bottom:1px solid var(--line)}.report-table tr:last-child td{border-bottom:0}.report-table td strong,.report-table td>span:not(.report-status){display:block}.report-table td>span:not(.report-status){margin-top:3px;color:var(--muted);font-size:12px}.report-status{display:inline-flex;min-height:26px;align-items:center;padding:0 9px;color:#344054;border-radius:6px;background:#f2f4f7;font-size:12px;font-weight:500;white-space:nowrap}.report-status.status-completed{color:#067647;background:#ecfdf3}.report-status.status-in_progress{color:#175cd3;background:#eff8ff}.report-status.status-overdue,.report-status.status-failed{color:#b42318;background:#fef3f2}.report-empty{padding:34px!important;color:var(--muted);text-align:center}.report-detail-button{display:inline-flex;min-height:34px;align-items:center;gap:6px;padding:0 10px;color:var(--brand);border:1px solid #fdba8c;border-radius:6px;background:#fff;font-size:12px;font-weight:500;white-space:nowrap}.report-detail-button:hover{background:var(--brand-soft)}.report-detail-button:disabled{cursor:wait;opacity:.5}.report-pagination{display:flex;align-items:center;justify-content:flex-end;gap:12px}.report-pagination span{min-width:90px;color:var(--muted);text-align:center;font-size:14px}.test-details-backdrop{position:fixed;z-index:50;top:0;right:0;bottom:0;left:0;display:grid;padding:24px;place-items:center;background:#11182794}.test-details-dialog{display:grid;grid-template-rows:auto minmax(0,1fr);width:min(100%,980px);max-height:min(88vh,900px);overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 24px 60px #1118273d}.test-details-dialog>header{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:76px;padding:16px 20px;border-bottom:1px solid var(--line)}.test-details-dialog>header h2{font-size:20px}.test-details-dialog>header .eyebrow{margin-bottom:5px}.test-details-dialog>header button{display:grid;width:40px;height:40px;flex:0 0 40px;place-items:center;color:var(--muted);border-radius:8px;background:#f2f4f7}.test-details-content{overflow-y:auto;padding:0 20px 20px}.attempt-detail{padding:20px 0;border-bottom:1px solid var(--line)}.attempt-detail:last-child{border-bottom:0}.attempt-detail-heading,.attempt-result,.attempt-answer-heading{display:flex;align-items:center;gap:12px}.attempt-detail-heading{justify-content:space-between;margin-bottom:14px}.attempt-detail-heading h3{margin-bottom:4px;font-size:17px}.attempt-detail-heading>div>span{color:var(--muted);font-size:13px}.attempt-result strong{font-size:24px}.attempt-answers{display:grid;gap:8px}.attempt-answer{padding:14px;border-left:3px solid #d0d5dd;background:#f9fafb}.attempt-answer.correct{border-left-color:#12b76a}.attempt-answer.incorrect{border-left-color:#f04438}.attempt-answer.pending{border-left-color:#2e90fa}.attempt-answer-heading>span{display:grid;width:26px;height:26px;flex:0 0 26px;place-items:center;color:#fff;border-radius:6px;background:#667085;font-size:12px;font-weight:600}.attempt-answer-heading>strong{flex:1}.attempt-answer-heading>b{white-space:nowrap}.answer-comparison{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px;padding-left:38px}.answer-comparison span{color:var(--muted);font-size:12px;font-weight:500;text-transform:uppercase}.answer-comparison p{margin:4px 0 0;line-height:1.45}.test-details-empty{padding:28px 0;color:var(--muted);text-align:center}.admin-assignments{margin-bottom:30px}.open-review,.user-access{display:grid;gap:14px;margin-bottom:30px}.user-access-heading{display:flex;align-items:center;justify-content:space-between;gap:16px}.user-access-heading h2{font-size:22px}.user-access-heading form{position:relative;display:flex;width:min(100%,440px);gap:8px}.user-access-heading form svg{position:absolute;top:12px;left:12px;color:var(--muted)}.user-access-heading input{width:100%;min-width:0;min-height:42px;padding:9px 11px 9px 40px;border:1px solid var(--line);border-radius:8px;outline:0}.user-access-heading input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.user-access-heading button,.user-access-table button,.temporary-access button{display:inline-flex;min-height:42px;align-items:center;justify-content:center;gap:7px;padding:0 15px;color:#fff;border-radius:8px;background:var(--brand);font-weight:500;white-space:nowrap}.temporary-access{display:grid;grid-template-columns:minmax(0,1fr) auto 40px;gap:14px;align-items:center;padding:16px;color:#fff;border-radius:8px;background:#1f2937}.temporary-access span,.temporary-access strong,.temporary-access small{display:block}.temporary-access strong{margin:5px 0;color:#ffd7bf;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:24px;letter-spacing:0}.temporary-access small{color:#d0d5dd}.temporary-access button.temporary-close{width:40px;padding:0;color:#fff;background:#ffffff1f}.user-access-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:8px;background:#fff}.user-access-table{width:100%;min-width:920px;border-collapse:collapse;font-size:14px}.user-access-table th,.user-access-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line)}.user-access-table th{color:#475467;background:#f7f7f8;font-size:12px;text-transform:uppercase}.user-access-table tr:last-child td{border-bottom:0}.user-access-table td:first-child strong,.user-access-table td:first-child span{display:block}.user-access-table td:first-child span{margin-top:3px;color:var(--muted);font-size:12px}.user-access-table td:last-child{text-align:right}.user-access-table button{min-height:36px;font-size:12px}.user-access-table button:disabled,.user-access-heading button:disabled{cursor:default;opacity:.45}.access-status{display:inline-flex;min-height:26px;align-items:center;padding:0 9px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap}.access-status.active{color:#067647;background:#ecfdf3}.access-status.temporary{color:#b54708;background:#fffaeb}.open-review-heading,.open-review-meta,.open-review-fields{display:flex;align-items:center;justify-content:space-between;gap:16px}.open-review-heading h2{font-size:22px}.review-count{padding:8px 11px;color:#b54708;border-radius:6px;background:#fffaeb;font-size:13px;font-weight:600}.open-review-empty{display:flex;min-height:82px;align-items:center;justify-content:center;gap:9px;padding:18px;color:var(--muted);border:1px solid var(--line);border-radius:8px;background:#fff}.open-review-list{display:grid;gap:12px}.open-review-item{display:grid;gap:14px;padding:18px;border:1px solid var(--line);border-radius:8px;background:#fff}.open-review-meta{align-items:flex-start;padding-bottom:12px;border-bottom:1px solid var(--line)}.open-review-meta>div:last-child{text-align:right}.open-review-meta strong,.open-review-meta span,.open-review-question>span,.open-review-question>strong,.open-review-answer>span{display:block}.open-review-meta span,.open-review-question>span,.open-review-answer>span{margin-top:3px;color:var(--muted);font-size:12px}.open-review-question>span,.open-review-answer>span{margin:0 0 5px;font-weight:500;text-transform:uppercase}.open-review-answer{padding:13px 14px;border-left:3px solid var(--brand);background:#fff7f2}.open-review-answer p{margin:0;line-height:1.5}.open-review-fields{display:grid;grid-template-columns:180px minmax(0,1fr) auto;align-items:end}.open-review-fields label{display:grid;gap:6px;font-size:13px;font-weight:500}.open-review-fields input{width:100%;min-height:42px;padding:9px 11px;border:1px solid var(--line);border-radius:8px;outline:0}.open-review-fields input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.open-review-fields button{display:inline-flex;min-height:42px;align-items:center;gap:7px;padding:0 18px;color:#fff;border-radius:8px;background:var(--brand);font-weight:500}.open-review-fields button:disabled{cursor:wait;opacity:.55}.assignment-form{display:grid;gap:20px;padding:20px;border:1px solid var(--line);border-radius:8px;background:#fff}.assignment-main-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.assignment-form label{display:grid;gap:7px;color:var(--ink);font-weight:500}.assignment-form input,.assignment-form select{width:100%;min-width:0;min-height:44px;padding:10px 12px;color:var(--ink);border:1px solid var(--line);border-radius:8px;outline:0;background:#fff}.assignment-form input:focus,.assignment-form select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.assignment-targets{display:grid;gap:10px;padding-top:18px;border-top:1px solid var(--line)}.assignment-subheading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:2px}.assignment-subheading h3{margin-bottom:3px;font-size:17px}.assignment-subheading p{margin:0;color:var(--muted);font-size:13px}.assignment-target-row{display:grid;grid-template-columns:30px 220px minmax(0,1fr) 40px;gap:10px;align-items:center}.assignment-target-row>span{display:grid;width:28px;height:28px;place-items:center;color:#fff;border-radius:6px;background:var(--brand);font-weight:600}.assignment-form button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;gap:8px;padding:0 18px;color:#fff;border-radius:8px;background:var(--brand);font-weight:500}.assignment-form button:hover{background:#dd651e}.assignment-form button.secondary-action{color:var(--brand);border:1px solid var(--brand);background:#fff}.assignment-form button.secondary-action:hover{color:#fff;background:var(--brand)}.assignment-form button.target-remove{width:40px;padding:0;color:#b42318;border:1px solid #fda29b;background:#fff}.assignment-form button.target-remove:hover{background:#fef3f2}.assignment-form button:disabled{cursor:default;opacity:.45}.assignment-preview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#f7f7f8}.assignment-preview>div{min-height:88px;padding:16px;border-right:1px solid var(--line)}.assignment-preview>div.accent{color:#fff;border-right:0;background:var(--brand)}.assignment-preview strong,.assignment-preview span{display:block}.assignment-preview strong{margin-bottom:6px;font-size:26px}.assignment-preview span{color:var(--muted);font-size:13px}.assignment-preview .accent span{color:#fff}.assignment-preview .assignment-repeat{grid-column:1 / -1;padding:14px 16px;border-top:1px solid var(--line);background:#fff}.assignment-actions{display:flex;justify-content:flex-end;gap:10px}.course-detail{display:grid;gap:18px}.course-completion{display:grid;gap:20px}.completion-summary{position:relative;display:grid;min-height:300px;align-content:center;justify-items:center;padding:36px 200px;overflow:hidden;color:#fff;text-align:center;border-radius:8px;background:linear-gradient(120deg,#b54708,var(--brand) 55%,#1f2937)}.completion-summary h1{margin-bottom:18px;font-size:34px}.completion-summary>p{margin:14px 0 0;color:#fff7ed}.completion-score{display:grid;width:126px;height:126px;place-items:center;align-content:center;border:9px solid #6ce9a6;border-radius:50%;background:#1f293752}.completion-score strong,.completion-score span{display:block}.completion-score strong{font-size:40px;line-height:1}.completion-score span{margin-top:4px;font-size:13px}.course-rating-form{display:grid;width:min(100%,760px);gap:24px;justify-self:center;padding:16px 0 24px}.course-rating-form fieldset{min-width:0;padding:0;border:0}.course-rating-form legend,.course-rating-form>label{display:grid;gap:8px;color:var(--ink);font-weight:500}.course-rating-form legend{margin-bottom:12px}.star-rating{display:flex;gap:8px}.star-rating button{display:grid;width:46px;height:46px;place-items:center;color:#fdb022;border-radius:8px;background:#fffaeb}.star-rating button:hover,.star-rating button.selected{background:#fef0c7}.recommend-scale{display:grid;grid-template-columns:repeat(11,minmax(38px,1fr));gap:6px}.recommend-scale button{min-height:40px;color:var(--ink);border:1px solid var(--line);border-radius:6px;background:#fff;font-weight:500}.recommend-scale button:hover,.recommend-scale button.selected{color:#fff;border-color:var(--brand);background:var(--brand)}.recommend-labels{display:flex;justify-content:space-between;margin-top:8px;color:var(--muted);font-size:12px}.course-rating-form textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:8px;outline:0;resize:vertical}.course-rating-form textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.completion-actions{display:flex;justify-content:flex-end;gap:10px}.completion-actions button,.completion-thanks button{min-height:44px;padding:0 20px;color:#fff;border-radius:8px;background:var(--brand);font-weight:500}.completion-actions button.secondary-action{color:var(--brand);border:1px solid var(--brand);background:#fff}.completion-thanks{display:grid;min-height:240px;place-items:center;align-content:center;gap:12px;color:#067647;text-align:center}.back-button{display:inline-flex;gap:8px;align-items:center;justify-self:start;min-height:42px;padding:0 14px;color:var(--brand);font-weight:500;border-radius:8px;background:var(--brand-soft)}.back-button svg,.lesson-actions svg{width:18px;height:18px}.course-detail-hero{position:relative;display:grid;align-content:end;min-height:260px;padding:32px;overflow:hidden;color:#fff;border-radius:8px;background:#1f2937}.course-detail-cover,.course-detail-shade{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.course-detail-cover{object-fit:cover}.course-detail-shade{background:#121826a8}.course-detail-hero>:not(.course-detail-cover):not(.course-detail-shade){position:relative;z-index:1}.course-detail-hero h1{margin-top:8px}.course-detail-hero p{max-width:760px;margin-top:14px;line-height:1.55}.course-detail-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.course-detail-meta span{padding:7px 10px;color:#fff;border-radius:8px;background:#ffffff29}.course-content-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:18px;align-items:start}.course-content-main,.course-content-side{border:1px solid var(--line);border-radius:8px;background:#fff}.course-content-main{padding:4px 18px 18px}.course-content-side{display:grid;gap:12px;padding:18px}.course-content-side h2{font-size:20px}.course-content-side p{color:var(--muted);line-height:1.5}.metric.compact{min-height:68px}.lesson-list{display:grid;gap:10px}.lesson-row{display:grid;grid-template-columns:42px 1fr auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:8px;background:#fff}.lesson-index{display:grid;width:36px;height:36px;place-items:center;color:var(--brand);font-weight:600;border-radius:8px;background:var(--brand-soft)}.lesson-info h3{font-size:17px}.lesson-info p{margin-top:5px;color:var(--muted)}.lesson-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.lesson-actions button{display:inline-flex;gap:8px;align-items:center;min-height:40px;padding:0 12px;color:#fff;font-weight:500;border-radius:8px;background:var(--brand)}.lesson-actions .secondary-action{color:var(--brand);background:var(--brand-soft)}.course-materials{margin-top:22px;padding-top:4px;border-top:1px solid var(--line)}.course-material-list{display:grid;gap:8px}.course-material-row{display:grid;grid-template-columns:30px minmax(0,1fr) auto;gap:12px;align-items:center;min-height:58px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#f9fafb}.course-material-row>svg{color:#d92d20}.course-material-row strong,.course-material-row span{display:block}.course-material-row span{margin-top:3px;color:var(--muted);font-size:12px}.course-material-row button{display:inline-flex;min-height:38px;align-items:center;gap:7px;padding:0 12px;color:var(--brand);border:1px solid #fdba8c;border-radius:8px;background:#fff;font-weight:500}.course-material-row button:hover{background:var(--brand-soft)}.test-player{display:grid;gap:16px;margin-top:18px;padding:18px;border:1px solid var(--line);border-radius:8px;background:#fbfbfc}.test-player-header{display:flex;gap:12px;align-items:center;justify-content:space-between}.test-player-header h2{margin-top:8px;font-size:22px}.close-test{min-height:40px;padding:0 14px;color:var(--brand);font-weight:500;border-radius:8px;background:var(--brand-soft)}.test-form{display:grid;gap:14px}.question-block{display:grid;gap:12px;margin:0;padding:16px;border:1px solid var(--line);border-radius:8px;background:#fff}.question-block legend{padding:0 4px;font-weight:600;line-height:1.45}.question-block textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:8px;outline:0;resize:vertical}.answer-list{display:grid;gap:10px}.answer-option{display:flex;gap:10px;align-items:flex-start;line-height:1.45}.answer-option input{width:18px;height:18px;margin-top:2px;accent-color:var(--brand)}.submit-test{justify-self:start;min-height:44px;padding:0 18px;color:#fff;font-weight:500;border-radius:8px;background:var(--brand)}.submit-test:disabled{cursor:wait;opacity:.72}.test-result{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.inline-alert{margin-top:14px;margin-bottom:0}.admin-forms{margin-bottom:30px}.admin-forms-heading{margin-bottom:14px}.admin-forms-heading h2{font-size:22px}.admin-message{margin-bottom:14px;padding:12px 14px;color:#14532d;border:1px solid #bbf7d0;border-radius:8px;background:#f0fdf4}.content-section-nav{display:flex;gap:4px;margin-bottom:18px;overflow-x:auto;border-bottom:1px solid var(--line)}.content-section-nav button{display:inline-flex;min-height:44px;flex:0 0 auto;align-items:center;gap:7px;padding:0 14px;color:var(--muted);border-bottom:2px solid transparent;background:transparent;font-weight:400}.content-section-nav button:hover,.content-section-nav button.active{color:var(--brand);border-bottom-color:var(--brand);background:#fff}.admin-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}.admin-form{display:grid;align-content:start;gap:14px;padding:18px;border:1px solid var(--line);border-radius:8px;background:#fff}.admin-form[hidden]{display:none}.admin-form.wide{grid-column:1 / -1}.admin-form h3{font-size:18px}.admin-form label{display:grid;gap:7px;color:var(--ink);font-weight:500}.admin-form input,.admin-form select,.admin-form textarea{width:100%;min-height:44px;padding:10px 12px;color:var(--ink);border:1px solid var(--line);border-radius:8px;outline:0;background:#fff}.admin-form textarea{resize:vertical}.admin-form input:focus,.admin-form select:focus,.admin-form textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.admin-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.admin-fields.compact-fields{gap:10px}.admin-fields .span-2{grid-column:span 2}.course-builder{display:grid;gap:14px;padding-top:4px}.course-builder-heading,.course-element-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px}.course-builder-heading h4{margin:0 0 3px;font-size:17px}.course-builder-heading p{margin:0;color:var(--muted);font-size:13px;font-weight:400}.weight-total{flex:0 0 auto;padding:7px 10px;color:#b42318;border-radius:6px;background:#fef3f2}.weight-total.valid{color:#067647;background:#ecfdf3}.course-element-list{display:grid;gap:12px}.course-element-editor{overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fafafa}.course-element-toolbar{min-height:48px;padding:8px 10px;border-bottom:1px solid var(--line);background:#fff}.course-element-toolbar>strong{min-width:0;margin-right:auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-element-number{display:grid;width:28px;height:28px;flex:0 0 28px;place-items:center;color:#fff;border-radius:6px;background:var(--brand);font-weight:600}.course-element-actions{display:flex;gap:6px}.admin-form .course-element-actions button{display:grid;width:34px;min-height:34px;padding:0;place-items:center;color:var(--ink);border:1px solid var(--line);background:#fff}.admin-form .course-element-actions button:hover{color:var(--brand);border-color:var(--brand);background:#fff7f2}.admin-form .course-element-actions button.danger:hover{color:#b42318;border-color:#fda29b;background:#fef3f2}.admin-form .course-element-actions button:disabled{cursor:default;opacity:.35}.course-element-fields{display:grid;grid-template-columns:minmax(0,1fr) 140px;gap:12px;padding:14px}.admin-form button.add-course-element{display:inline-flex;width:fit-content;align-items:center;gap:8px;color:var(--brand);border:1px solid var(--brand);background:#fff}.admin-form button.add-course-element:hover{color:#fff;background:var(--brand)}.checkbox-label{display:flex!important;flex-direction:row;gap:10px!important;align-items:center}.checkbox-label input{width:18px;min-height:18px;padding:0;accent-color:var(--brand)}.admin-form button{min-height:44px;padding:0 18px;color:#fff;font-weight:500;border-radius:8px;background:var(--brand)}.admin-form button:hover{background:#dd651e}.admin-form button:disabled{cursor:wait;opacity:.7}.banner-admin-form>button[type=submit]{width:fit-content}.banner-admin-list{display:grid;gap:10px;padding-top:4px}.banner-admin-item{display:grid;grid-template-columns:150px minmax(0,1fr) 42px;gap:14px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px;background:#f9fafb}.banner-admin-item img{width:150px;aspect-ratio:3 / 1;object-fit:cover;border-radius:6px}.banner-admin-item>div{min-width:0}.banner-admin-item strong,.banner-admin-item span,.banner-admin-item small{display:block}.banner-admin-item span{margin-top:4px;color:var(--muted);overflow-wrap:anywhere}.banner-admin-item small{margin-top:6px;color:#475467}.admin-form .banner-admin-item .banner-delete{display:grid;width:42px;min-height:42px;padding:0;place-items:center;color:#b42318;border:1px solid #fda29b;background:#fff}.admin-form .banner-admin-item .banner-delete:hover{color:#fff;background:#b42318}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(135deg,#f172241f,#1e4f781f),#f7f7f8}.login-panel{width:min(100%,440px);padding:32px;border:1px solid var(--line);border-radius:8px;background:#fff}.login-panel h1{margin-bottom:24px;color:var(--ink);font-size:28px}.login-panel label{display:grid;gap:8px;margin-bottom:16px;color:var(--ink);font-weight:500}.login-panel input{height:46px;padding:0 12px;border:1px solid var(--line);border-radius:8px;outline:0}.login-panel input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #f1722424}.login-panel button{width:100%;margin-top:8px}.password-change-panel>p{margin:-12px 0 20px;color:var(--muted);line-height:1.5}.login-panel button.logout-link{color:var(--muted);border:1px solid var(--line);background:#fff}.login-panel button.logout-link:hover{color:var(--ink);background:#f7f7f8}input[type=file]{padding:7px}input[type=file]::file-selector-button{min-height:30px;margin-right:10px;padding:0 11px;color:var(--ink);border:1px solid var(--line);border-radius:6px;background:#fff;font-weight:400;cursor:pointer}input[type=file]::file-selector-button:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-soft)}:is(.course-footer button,.login-panel button,.download-link,.report-filter-actions button,.report-table-toolbar button,.report-pagination button,.user-access-heading button,.user-access-table button,.open-review-fields button,.assignment-form button:not(.target-remove),.completion-actions button,.completion-thanks button,.lesson-actions button,.submit-test,.admin-form>button,.admin-form button.add-course-element){color:var(--brand);border:1px solid var(--brand);background:#fff;font-weight:500}.admin-form>button{width:fit-content;min-width:180px;justify-self:start}:is(.course-footer button,.login-panel button,.download-link,.report-filter-actions button,.report-table-toolbar button,.report-pagination button,.user-access-heading button,.user-access-table button,.open-review-fields button,.assignment-form button:not(.target-remove),.completion-actions button,.completion-thanks button,.lesson-actions button,.submit-test,.admin-form>button,.admin-form button.add-course-element):hover{color:#c95d1b;border-color:#e56a20;background:var(--brand-soft)}.assignment-preview>div.accent{color:var(--brand);border-left:2px solid var(--brand);background:#fff7f2}.assignment-preview .accent span{color:var(--muted)}@media(max-width:900px){.topbar{grid-template-columns:1fr auto}.admin-section-nav{display:flex;overflow-x:auto}.admin-section-nav button{min-width:150px}nav{grid-column:1 / -1;overflow-x:auto}.catalog-toolbar,.admin-overview,.admin-form-grid,.course-content-layout,.course-grid,.admin-fields,.assignment-main-fields{grid-template-columns:1fr}.report-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.report-filters{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-fields .span-2,.course-builder.span-2,.course-element-fields .span-2{grid-column:auto}.course-element-fields{grid-template-columns:1fr}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.test-result{grid-template-columns:1fr}}@media(max-width:640px){.app-shell{width:min(100% - 24px,1220px);padding-top:12px}.notification-panel{position:fixed;top:78px;right:12px;left:12px;width:auto}.hero{min-height:240px;padding:24px}.portal-hero{min-height:260px}.portal-hero-content{padding:34px 56px}.portal-hero h1{font-size:28px}.portal-hero p{font-size:15px}.banner-admin-item{grid-template-columns:88px minmax(0,1fr) 42px}.banner-admin-item img{width:88px}h1{font-size:32px}.course-card{min-height:350px}.course-detail-hero{min-height:240px;padding:24px}.completion-summary{min-height:280px;padding:28px 18px}.completion-summary h1{font-size:28px}.recommend-scale{display:flex;padding-bottom:6px;overflow-x:auto}.recommend-scale button{min-width:40px}.completion-actions{align-items:stretch;flex-direction:column}.lesson-row{grid-template-columns:36px 1fr}.lesson-actions{grid-column:1 / -1;justify-content:flex-start}.course-material-row{grid-template-columns:30px minmax(0,1fr)}.course-material-row button{grid-column:1 / -1;justify-content:center}.test-player-header,.assignment-subheading,.open-review-heading,.open-review-meta{align-items:flex-start;flex-direction:column}.open-review-meta>div:last-child{text-align:left}.open-review-fields{grid-template-columns:1fr}.user-access-heading{align-items:stretch;flex-direction:column}.user-access-heading form{width:100%}.temporary-access{grid-template-columns:minmax(0,1fr) 40px}.temporary-access>div{grid-column:1 / -1}.report-heading,.report-table-toolbar{align-items:stretch;flex-direction:column}.report-heading .download-link,.report-table-toolbar label{width:100%}.report-table-toolbar>span{margin-left:0}.report-metrics,.report-filters{grid-template-columns:1fr}.report-filter-actions{align-items:stretch;flex-direction:column}.report-pagination{justify-content:space-between}.test-details-backdrop{padding:0;place-items:stretch}.test-details-dialog{width:100%;max-height:100vh;border-radius:0}.test-details-dialog>header,.test-details-content{padding-right:14px;padding-left:14px}.attempt-detail-heading{align-items:flex-start;flex-direction:column}.answer-comparison{grid-template-columns:1fr;padding-left:0}.attempt-answer-heading{align-items:flex-start}.assignment-target-row{grid-template-columns:30px minmax(0,1fr) 40px;align-items:start}.assignment-target-row>span{grid-column:1;grid-row:1;margin-top:8px}.assignment-target-row>select:first-of-type{grid-column:2;grid-row:1}.assignment-target-row>select:last-of-type{grid-column:2;grid-row:2}.assignment-target-row>button{grid-column:3;grid-row:1}.assignment-preview{grid-template-columns:1fr}.assignment-preview>div{min-height:auto;border-right:0;border-bottom:1px solid var(--line)}.assignment-actions{align-items:stretch;flex-direction:column}.course-builder-heading{align-items:flex-start;flex-direction:column}.weight-total{align-self:stretch}.course-element-toolbar{gap:8px}}
