.login-container{display:flex;justify-content:center;align-items:center;min-height:clamp(360px,68vh,640px);padding:clamp(1.8rem,5vw,3rem) 1.25rem}.login-card{width:min(640px,100%);background:var(--cs-white);border-radius:18px;box-shadow:0 18px 36px #0c297c1f;padding:clamp(1.45rem,3vw,2.3rem);display:grid;gap:1.4rem;border:1px solid rgba(12,41,124,.06)}.login-card__header{display:flex;gap:1.35rem;align-items:center;background:#0c297c0d;border-radius:14px;padding:1.1rem 1.3rem;border:1px solid rgba(12,41,124,.1)}.login-card__logo{width:clamp(72px,9vw,92px);flex-shrink:0}.login-card__header h1{margin:0;font-size:clamp(1.5rem,3.2vw,2rem);color:var(--cs-blue)}.login-role{display:grid;gap:.6rem}.login-role__toggle{display:inline-flex;padding:.25rem;gap:.25rem;border-radius:999px;background:#0c297c0f;border:1px solid rgba(12,41,124,.12)}.login-role__toggle button{border:none;background:transparent;padding:.5rem 1.2rem;font-weight:600;color:#0c297cb3;border-radius:999px;transition:background .2s ease,color .2s ease,box-shadow .2s ease}.login-role__toggle button.active{background:var(--cs-blue);color:var(--cs-white);box-shadow:0 12px 22px #0c297c38}.login-form{display:grid;gap:1.1rem}.login-form label{display:grid;gap:.35rem}.login-form input{border:1px solid rgba(12,41,124,.16);border-radius:.75rem;padding:.7rem .85rem;font-size:1rem;background:var(--cs-white)}.login-submit{border:none;border-radius:999px;padding:.75rem 1.7rem;font-weight:600;background:linear-gradient(135deg,var(--cs-gold),#d2a35a);color:var(--cs-black);transition:transform .17s ease,box-shadow .17s ease}.login-submit:hover{transform:translateY(-1px);box-shadow:0 14px 30px #b2854140}.login-submit:disabled{opacity:.6;cursor:progress}.status{font-size:.9rem;margin:0}.status--loading{color:var(--cs-blue)}.login-footnote{border-top:1px solid rgba(12,41,124,.12);padding-top:1rem}@media (max-width: 640px){.login-card__header{flex-direction:column;text-align:center}.login-role__toggle{width:100%}.login-role__toggle button{flex:1;text-align:center}}.stat-card{background:var(--color-white);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:clamp(1.25rem,2vw,1.75rem);display:grid;gap:var(--space-3);position:relative;color:var(--color-text)}.stat-card--brand{background:var(--cs-gradient-card);border-color:#0c297c2e;box-shadow:var(--shadow-md);color:var(--color-text)}.stat-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.stat-card__title{display:flex;flex-direction:column;gap:var(--space-2)}.stat-card__badge{display:inline-flex;align-items:center;justify-content:center;padding:calc(var(--space-1) + 1px) var(--space-3);border-radius:var(--radius-pill);background:#0c297c1f;color:var(--cs-blue);font-weight:600;font-size:var(--text-sm);letter-spacing:.08em;text-transform:uppercase}.stat-card__badge.is-celebrating{animation:stat-card-celebrate .6s ease-out}.stat-card__label{font-size:var(--text-sm);font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted)}.stat-card__actions{display:inline-flex;gap:var(--space-2);align-items:center}.stat-card__action,.stat-card__actions>button{display:inline-flex;align-items:center;justify-content:center;padding:calc(var(--space-1) + 1px) var(--space-3);border-radius:var(--radius-pill);border:1px solid rgba(12,41,124,.28);background:#0c297c14;color:var(--cs-blue);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast);cursor:pointer}.stat-card__action:hover,.stat-card__action:focus-visible,.stat-card__actions>button:hover,.stat-card__actions>button:focus-visible{background:#0c297c29;border-color:#0c297c61;transform:translateY(-1px)}.stat-card__content{display:flex;gap:var(--space-3);align-items:flex-start}.stat-card__icon{font-size:1.75rem;line-height:1;filter:drop-shadow(0 6px 16px rgba(12,41,124,.18))}.stat-card__metrics{display:grid;gap:var(--space-2)}.stat-card__value{font-size:clamp(1.85rem,3vw,2.5rem);font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.stat-card--brand .stat-card__value{background:linear-gradient(135deg,var(--cs-blue),var(--cs-blue-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card__description{margin:0;font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6}.stat-card__meta{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.stat-card__meta-text{display:inline-flex;align-items:center;gap:var(--space-1)}.stat-card__progress{position:relative;height:12px;border-radius:var(--radius-full);background:#0c297c1f;overflow:hidden;box-shadow:inset 0 2px 4px #0c297c14}.stat-card__progress-bar{width:var(--stat-card-progress, 0%);height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--cs-blue-light),var(--cs-blue-lighter),var(--color-xp-gold));box-shadow:0 0 12px #3275ff66;transition:width var(--transition-base)}.stat-card__progress-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:stat-card-shimmer 2s infinite}.stat-card__progress-label{font-size:var(--text-sm);font-weight:600;color:var(--cs-blue);display:inline-flex;align-items:center;gap:var(--space-2)}.stat-card--compact{padding:var(--space-4);gap:var(--space-2)}.stat-card--compact .stat-card__description,.stat-card--compact .stat-card__progress,.stat-card--compact .stat-card__progress-label{display:none}@keyframes stat-card-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes stat-card-celebrate{0%,to{transform:scale(1);box-shadow:0 0 #fbbf2400}50%{transform:scale(1.08);box-shadow:0 0 30px #fbbf2499}}@media (max-width: 768px){.stat-card{padding:var(--space-4)}.stat-card__content{flex-direction:column;align-items:flex-start}}.status-banner{--status-banner-bg: var(--status-info-bg);--status-banner-border: var(--status-info-border);--status-banner-text: var(--status-info-text);display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--status-banner-border);background:var(--status-banner-bg);color:var(--status-banner-text);box-shadow:var(--shadow-xs)}.status-banner__icon{font-size:1.2rem;line-height:0;display:inline-flex;align-items:center;justify-content:center}.status-banner__content{display:grid;gap:var(--space-1);flex:1 1 auto}.status-banner__content strong{font-size:var(--text-sm);color:var(--color-text)}.status-banner__body{font-size:var(--text-sm);color:var(--status-banner-text)}.status-banner__actions{display:inline-flex;gap:var(--space-2);align-items:center}.status-banner__dismiss{border:none;background:transparent;color:inherit;font-size:1.1rem;line-height:1;cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.status-banner__dismiss:hover,.status-banner__dismiss:focus-visible{background:color-mix(in srgb,currentColor 14%,transparent)}.status-banner--info{--status-banner-bg: var(--status-info-bg);--status-banner-border: var(--status-info-border);--status-banner-text: var(--status-info-text)}.status-banner--success{--status-banner-bg: var(--status-success-bg);--status-banner-border: var(--status-success-border);--status-banner-text: var(--status-success-text)}.status-banner--warning{--status-banner-bg: var(--status-warning-bg);--status-banner-border: var(--status-warning-border);--status-banner-text: var(--status-warning-text)}.status-banner--danger{--status-banner-bg: var(--status-error-bg);--status-banner-border: var(--status-error-border);--status-banner-text: var(--status-error-text)}.status-banner--neutral{--status-banner-bg: color-mix(in srgb, var(--color-primary-100) 32%, var(--color-white));--status-banner-border: color-mix(in srgb, var(--color-primary-800) 16%, transparent);--status-banner-text: var(--color-text)}.teacher-dashboard{display:grid;gap:var(--space-6);min-height:0}.teacher-dashboard__hero{display:grid;gap:var(--space-6);grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);padding:clamp(2rem,4vw,3rem);border-radius:var(--radius-xl);border:1px solid var(--color-border-subtle);background:radial-gradient(140% 120% at 100% 0%,#0c297c2e,#0c297c00 70%),var(--color-white);box-shadow:var(--shadow-md)}.teacher-dashboard__hero-left{display:grid;gap:var(--space-4);align-content:start}.teacher-dashboard__eyebrow{font-size:var(--text-xs);letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:#0c297ca6}.teacher-dashboard__hero-left h1{font-size:clamp(1.9rem,3.6vw,2.6rem);letter-spacing:-.02em;color:var(--color-primary-800);margin:0}.teacher-dashboard__hero-left p{max-width:56ch}.teacher-dashboard__hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.teacher-dashboard__summary-grid{width:100%}.teacher-dashboard__summary-grid .stat-card{height:100%}.teacher-dashboard__summary-grid .stat-card__value{font-size:clamp(1.6rem,2.4vw,2.1rem)}.teacher-dashboard__workspace{display:grid;grid-template-columns:minmax(240px,320px) minmax(0,1fr);gap:var(--space-6);min-height:0}.teacher-dashboard__class-panel,.teacher-dashboard__class-detail,.teacher-dashboard__card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm)}.teacher-dashboard__class-panel{display:flex;flex-direction:column;gap:var(--space-4);padding:clamp(1.4rem,3vw,2rem);min-height:0}.teacher-dashboard__class-panel header h2{color:var(--color-primary-800);margin:0}.teacher-dashboard__class-list{display:grid;gap:var(--space-3);overflow-y:auto;padding-right:var(--space-1);min-height:0}.teacher-dashboard__class-button{display:flex;justify-content:space-between;gap:var(--space-3);align-items:flex-start;border-radius:var(--radius-md);border:1px solid transparent;background:#0c297c0a;padding:var(--space-3) var(--space-4);text-align:left;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.teacher-dashboard__class-button strong{display:block;color:var(--color-primary-800);margin-bottom:2px}.teacher-dashboard__class-button span{display:block;color:var(--color-text-muted);font-size:var(--text-sm)}.teacher-dashboard__class-button:hover,.teacher-dashboard__class-button:focus-visible{background:#0c297c1f;border-color:#0c297c4d;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.teacher-dashboard__class-button.is-active{background:linear-gradient(135deg,#0c297c24,#b285412e);border-color:#0c297c59;box-shadow:var(--shadow-md)}.teacher-dashboard__class-meta-chip{display:grid;gap:var(--space-1);text-align:right;font-weight:600;color:var(--color-text-muted)}.teacher-dashboard__class-detail{display:grid;gap:var(--space-5);padding:clamp(1.6rem,3vw,2.4rem);min-height:0}.teacher-dashboard__class-header{display:flex;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.teacher-dashboard__class-header h2{margin:0;color:var(--color-primary-800)}.teacher-dashboard__class-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.teacher-dashboard__class-summary{width:100%}.teacher-dashboard__class-summary .stat-card{height:100%}.teacher-dashboard__class-summary .stat-card__value{font-size:clamp(1.6rem,2.4vw,2rem)}.teacher-dashboard__class-summary .stat-card__progress-label{font-size:var(--text-xs);color:var(--color-text-muted)}.teacher-dashboard__pacing-actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.teacher-dashboard__pacing-status{font-weight:600;font-size:var(--text-sm);margin-top:var(--space-3)}.teacher-dashboard__pacing-status--success{color:var(--status-success-text)}.teacher-dashboard__pacing-status--error{color:var(--status-error-text)}.teacher-dashboard__table-wrapper{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden}.teacher-dashboard__table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.teacher-dashboard__table th,.teacher-dashboard__table td{padding:var(--space-3) var(--space-3);border-bottom:1px solid rgba(12,41,124,.08);text-align:left}.teacher-dashboard__table th{text-transform:uppercase;letter-spacing:.08em;font-size:var(--text-xs);color:#0c297c9e}.teacher-dashboard__student-row{cursor:pointer;transition:background var(--transition-fast)}.teacher-dashboard__student-row:hover{background:#0c297c0f}.teacher-dashboard__table-actions{text-align:right}.teacher-student-name{display:block;font-weight:600;color:var(--color-primary-800)}.teacher-student-sub{display:block;font-size:var(--text-xs);color:var(--color-text-muted)}.teacher-password{background:#0c297c14;border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font:inherit;font-weight:600;color:var(--color-primary-800);border:1px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast)}.teacher-password:hover,.teacher-password:focus-visible{background:#0c297c29;border-color:#0c297c47}.teacher-dashboard__insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-5)}.teacher-dashboard__card{padding:clamp(1.6rem,3vw,2.4rem);display:grid;gap:var(--space-4)}.teacher-dashboard__metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}.teacher-dashboard__metrics div{border-radius:var(--radius-md);padding:var(--space-3);background:#b285411f;color:var(--color-accent-700);display:grid;gap:var(--space-1);text-align:center}.teacher-dashboard__metrics span{font-weight:700;font-size:var(--text-lg)}.teacher-dashboard__metrics small{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase}.teacher-dashboard__list{display:grid;gap:var(--space-3);list-style:none;padding:0;margin:0}.teacher-dashboard__list li{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid rgba(12,41,124,.08)}.teacher-dashboard__list li:last-child{border-bottom:none;padding-bottom:0}.teacher-dashboard__list--compact li{gap:var(--space-2)}.teacher-dashboard__list-meta{display:grid;gap:var(--space-1);text-align:right}.teacher-dashboard__tag{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:#0c297c1f;color:var(--color-primary-800)}.teacher-dashboard__tag--locked{background:#050d311f;color:var(--color-black)}.teacher-dashboard__tag--available{background:#0c297c2e;color:var(--color-primary-800)}.teacher-dashboard__tag--formative-complete,.teacher-dashboard__tag--summative-complete{background:#b285412e;color:var(--color-accent-700)}.teacher-dashboard__empty-detail{padding:var(--space-6);border:1px dashed rgba(12,41,124,.35);border-radius:var(--radius-lg);text-align:center;color:var(--color-text-muted);font-weight:600}.status{font-weight:600;font-size:var(--text-sm)}.status--error{color:var(--status-error-text)}.status--success{color:var(--status-success-text)}.teacher-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#050d3159;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;padding:var(--space-5);z-index:80}.teacher-modal__dialog{background:var(--color-white);border-radius:var(--radius-lg);width:min(520px,100%);box-shadow:0 40px 80px #050d3133;display:grid;grid-template-rows:auto 1fr;overflow:hidden}.teacher-modal__dialog header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-subtle)}.teacher-modal__dialog header h2{font-size:var(--text-xl);color:var(--color-primary-800);margin:0}.teacher-modal__dialog header button{border:none;background:transparent;font-size:1.6rem;line-height:1;color:var(--color-text-muted);cursor:pointer}.teacher-modal__content{padding:var(--space-5);display:grid;gap:var(--space-4)}.teacher-modal__content label{display:grid;gap:var(--space-2);font-weight:600;color:var(--color-primary-800);font-size:var(--text-sm)}.teacher-modal__content input,.teacher-modal__content select{font:inherit;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid rgba(12,41,124,.2);background:var(--color-white)}.teacher-modal__ghost{justify-self:flex-start;border:1px solid rgba(12,41,124,.2);border-radius:var(--radius-pill);padding:var(--space-2) var(--space-4);background:#0c297c14;color:var(--color-primary-800);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.teacher-modal__ghost:hover,.teacher-modal__ghost:focus-visible{background:#0c297c29;border-color:#0c297c4d}.teacher-modal__preview{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:#0c297c14;color:var(--color-primary-800);font-weight:600}.teacher-modal__content footer{display:flex;justify-content:flex-end;gap:var(--space-3)}.teacher-modal__content footer button{border-radius:var(--radius-pill);border:1px solid rgba(12,41,124,.2);padding:var(--space-2) var(--space-4);background:#0c297c0f;color:var(--color-primary-800);cursor:pointer}.teacher-modal__content footer .pill{border:none}@media (max-width: 1024px){.teacher-dashboard__hero,.teacher-dashboard__workspace{grid-template-columns:1fr}}@media (max-width: 768px){.teacher-dashboard__class-header,.teacher-dashboard__hero-actions,.teacher-dashboard__class-actions{flex-direction:column;align-items:flex-start}.teacher-dashboard__class-meta-chip{text-align:left}.teacher-dashboard__table{display:block;overflow-x:auto}.teacher-modal__dialog{width:100%}}.keyword-card{background:linear-gradient(135deg,#fffffffa,#f6f8fff2);border-radius:var(--radius-lg);padding:1.2rem 1.4rem;border:2px solid rgba(18,46,132,.12);box-shadow:var(--shadow-sm);transition:all var(--transition-base);position:relative;overflow:hidden}.keyword-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--cs-blue),var(--cs-blue-light));opacity:0;transition:opacity var(--transition-base)}.keyword-card:hover{transform:translate(6px);box-shadow:var(--shadow-md);border-color:#122e8440}.keyword-card:hover:before{opacity:1}.keyword-card__header{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem}.keyword-card__icon{font-size:1.2em;color:var(--cs-blue-light);font-weight:700}.keyword-card__term{margin:0;font-size:1.1rem;font-weight:700;color:var(--cs-blue);flex:1}.keyword-card__definition{margin:0;color:#122e84d9;line-height:1.6}.callout{border-radius:var(--radius-xl);padding:1.2rem 1.5rem;border:2px solid;display:grid;gap:.8rem;box-shadow:var(--shadow-sm);animation:fadeIn var(--transition-base) ease-out}.callout__header{display:flex;align-items:center;gap:.75rem}.callout__icon{font-size:1.5em;line-height:1}.callout__title{font-size:1.05rem;font-weight:700}.callout__body{line-height:1.6}.callout--info{background:linear-gradient(135deg,var(--color-info-light),rgba(255,255,255,.95));border-color:var(--color-info);color:#1e40af}.callout--tip{background:linear-gradient(135deg,#fbbf2426,#fffffff2);border-color:var(--color-xp-gold);color:#92400e}.callout--warning{background:linear-gradient(135deg,var(--color-warning-light),rgba(255,255,255,.95));border-color:var(--color-warning);color:#92400e}.callout--success{background:linear-gradient(135deg,var(--color-success-light),rgba(255,255,255,.95));border-color:var(--color-success);color:var(--color-success-dark)}.callout--error{background:linear-gradient(135deg,var(--color-error-light),rgba(255,255,255,.95));border-color:var(--color-error);color:#991b1b}.enhanced-table-wrapper{border-radius:var(--radius-xl);border:2px solid rgba(18,46,132,.15);background:#fffffffa;box-shadow:var(--shadow-md);overflow:hidden;animation:fadeIn var(--transition-base) ease-out}.enhanced-table__caption{padding:1rem 1.5rem;background:linear-gradient(135deg,#0c297c14,#3fb5ff14);font-weight:700;color:var(--cs-blue);border-bottom:2px solid rgba(18,46,132,.15)}.enhanced-table__scroll{overflow-x:auto}.enhanced-table{width:100%;border-collapse:collapse;min-width:480px}.enhanced-table th{padding:1rem 1.5rem;background:linear-gradient(135deg,#0c297c14,#3fb5ff14);font-weight:700;text-transform:uppercase;font-size:.85rem;letter-spacing:.05em;color:var(--cs-blue);text-align:left;position:sticky;top:0;z-index:10}.enhanced-table td{padding:1rem 1.5rem;border-bottom:1px solid rgba(18,46,132,.08);text-align:left;transition:background var(--transition-fast)}.enhanced-table tbody tr{transition:all var(--transition-fast)}.enhanced-table tbody tr:nth-child(2n){background:#122e8408}.enhanced-table tbody tr:hover{background:#3fb5ff1f;transform:scale(1.002)}.enhanced-table tbody tr:last-child td{border-bottom:none}.enhanced-table code{background:#0a1030eb;color:#ffffffeb;padding:.2rem .5rem;border-radius:var(--radius-sm);font-family:Fira Code,Courier New,monospace;font-size:.9em}.progress-indicator{display:grid;gap:.75rem;padding:1rem 1.2rem;background:linear-gradient(135deg,#fffffffa,#f6f8fff2);border-radius:var(--radius-lg);border:2px solid rgba(18,46,132,.12);box-shadow:var(--shadow-sm)}.progress-indicator__label{font-size:.9rem;font-weight:600;color:#122e84bf}.progress-indicator__track{position:relative;height:14px;background:#122e841f;border-radius:var(--radius-full);overflow:hidden;box-shadow:inset 0 2px 4px #122e841a}.progress-indicator__fill{position:relative;height:100%;width:var(--progress-indicator, 0%);background:linear-gradient(90deg,var(--cs-blue),var(--cs-blue-light),var(--color-xp-gold));border-radius:inherit;transition:width .8s cubic-bezier(.4,0,.2,1);box-shadow:0 0 15px #3275ff99}.progress-indicator__shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:shimmer 2s infinite}.progress-indicator__stats{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;font-weight:600;color:#122e84b3}.progress-indicator__percentage{font-size:1rem;font-weight:700;color:var(--cs-blue)}.achievement-badge{display:flex;align-items:center;gap:1rem;padding:1rem 1.3rem;border-radius:var(--radius-xl);border:2px solid;background:linear-gradient(135deg,#fffffffa,#fbbf2414);box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative}.achievement-badge.is-unlocked{border-color:var(--color-xp-gold)}.achievement-badge.is-unlocked:hover{transform:translateY(-2px) rotate(1deg);box-shadow:var(--shadow-lg),0 0 30px #fbbf244d}.achievement-badge.is-locked{border-color:#122e8433;opacity:.6;filter:grayscale(.8)}.achievement-badge__icon{font-size:2.5em;line-height:1;animation:pulse 2s ease-in-out infinite}.achievement-badge.is-locked .achievement-badge__icon{animation:none}.achievement-badge__content{flex:1;display:grid;gap:.3rem}.achievement-badge__title{font-size:1.05rem;font-weight:700;color:var(--cs-blue)}.achievement-badge__description{margin:0;font-size:.9rem;color:#122e84b3}.achievement-badge__lock{font-size:1.5em;opacity:.5}.xp-notification{position:fixed;top:2rem;right:2rem;display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--color-xp-gold),var(--color-xp-gold-dark));border-radius:var(--radius-xl);box-shadow:var(--shadow-xl),0 0 40px #fbbf2480;color:var(--cs-black);z-index:1000;animation:slideInRight var(--transition-base) ease-out}.xp-notification__content{display:flex;align-items:center;gap:.75rem}.xp-notification__icon{font-size:1.8em;animation:pulse 1s ease-in-out infinite}.xp-notification__text{display:grid;gap:.2rem}.xp-notification__xp{font-size:1.2rem;font-weight:800;line-height:1}.xp-notification__message{margin:0;font-size:.9rem;opacity:.9}.xp-notification__close{background:none;border:none;color:inherit;font-size:1.8em;line-height:1;cursor:pointer;opacity:.7;transition:opacity var(--transition-fast)}.xp-notification__close:hover{opacity:1}.streak-indicator{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.2rem;background:linear-gradient(135deg,#f9731626,#fffffff2);border:2px solid var(--color-streak-fire);border-radius:var(--radius-xl);box-shadow:var(--shadow-md),0 0 20px #f9731633}.streak-indicator__flame{font-size:2em;line-height:1;animation:wiggle 1s ease-in-out infinite}.streak-indicator__content{display:grid;gap:.2rem}.streak-indicator__count{font-size:1.8rem;font-weight:800;line-height:1;background:linear-gradient(135deg,var(--color-streak-fire),#ea580c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.streak-indicator__label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#122e84b3}.skeleton-container{display:grid;gap:.75rem}.skeleton{background:linear-gradient(90deg,#0c297c0f 25%,#0c297c1f,#0c297c0f 75%);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius-md)}.skeleton--text{height:1rem;width:100%}.skeleton--heading{height:2rem;width:70%}.skeleton--card{height:8rem;width:100%}.skeleton--circle{height:3rem;width:3rem;border-radius:var(--radius-full)}@media (max-width: 768px){.xp-notification{top:1rem;right:1rem;left:1rem;max-width:none}.achievement-badge{flex-direction:column;text-align:center}}.progress-bar{--progress-percent: 0%;--progress-track-bg: rgba(12, 41, 124, .12);--progress-fill-bg: linear-gradient(135deg, rgba(12, 41, 124, .86), rgba(47, 93, 199, .92));--progress-height: 12px;display:grid;gap:var(--space-2)}.progress-bar__track{position:relative;height:var(--progress-height);border-radius:var(--radius-full);background:var(--progress-track-bg);overflow:hidden;box-shadow:inset 0 2px 4px #0c297c14}.progress-bar__fill{width:var(--progress-percent);height:100%;border-radius:inherit;background:var(--progress-fill-bg);display:grid;place-items:center;transition:width var(--transition-base);box-shadow:0 0 12px #3275ff73;position:relative;overflow:hidden}.progress-bar__fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:progress-bar-shimmer 2.2s infinite}.progress-bar__value{font-size:var(--text-xs);font-weight:600;color:var(--color-white);padding:0 var(--space-2);position:relative;z-index:1}.progress-bar__footer{font-size:var(--text-sm);color:var(--color-text-muted);display:flex;align-items:center;gap:var(--space-2)}.progress-bar--brand{--progress-fill-bg: linear-gradient(135deg, var(--cs-blue), var(--cs-blue-light))}.progress-bar--success{--progress-fill-bg: linear-gradient(135deg, #22c55e, #0ea5e9);--progress-track-bg: rgba(34, 197, 94, .16)}.progress-bar--warning{--progress-fill-bg: linear-gradient(135deg, #f59e0b, #f97316);--progress-track-bg: rgba(245, 158, 11, .18)}.progress-bar--muted{--progress-fill-bg: rgba(148, 163, 184, .75);--progress-track-bg: rgba(148, 163, 184, .25)}.progress-bar--xs{--progress-height: 6px}.progress-bar--sm{--progress-height: 8px}.progress-bar--lg{--progress-height: 18px}@keyframes progress-bar-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.status-pill{--status-pill-bg: var(--status-info-bg);--status-pill-border: var(--status-info-border);--status-pill-text: var(--status-info-text);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);padding:calc(var(--space-1) + 1px) var(--space-3);border-radius:var(--radius-pill);border:1px solid var(--status-pill-border);background:var(--status-pill-bg);color:var(--status-pill-text);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;line-height:1;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.status-pill__icon{font-size:1em;line-height:0;display:inline-flex;align-items:center;justify-content:center}.status-pill__label{display:inline-flex;align-items:center;gap:var(--space-1)}.status-pill--size-md{padding:calc(var(--space-1) + 2px) var(--space-4);font-size:var(--text-sm)}.status-pill--size-lg{padding:var(--space-2) var(--space-5);font-size:var(--text-sm);letter-spacing:.06em}.status-pill--info{--status-pill-bg: var(--status-info-bg);--status-pill-border: var(--status-info-border);--status-pill-text: var(--status-info-text)}.status-pill--success{--status-pill-bg: var(--color-success-light);--status-pill-border: color-mix(in srgb, var(--color-success-dark) 40%, transparent);--status-pill-text: var(--color-success-dark)}.status-pill--warning{--status-pill-bg: var(--color-warning-light);--status-pill-border: color-mix(in srgb, var(--color-warning-dark) 32%, transparent);--status-pill-text: var(--color-warning-dark)}.status-pill--danger{--status-pill-bg: var(--color-error-light);--status-pill-border: color-mix(in srgb, var(--color-error-dark) 36%, transparent);--status-pill-text: var(--color-error-dark)}.status-pill--neutral,.status-pill--muted{--status-pill-bg: color-mix(in srgb, var(--color-primary-100) 32%, var(--color-white));--status-pill-border: color-mix(in srgb, var(--color-primary-800) 24%, transparent);--status-pill-text: color-mix(in srgb, var(--color-primary-800) 64%, var(--color-white))}.status-pill--variant-solid{border-color:transparent;color:var(--color-white);background:linear-gradient(135deg,color-mix(in srgb,var(--status-pill-text) 86%,var(--color-black) 14%),var(--status-pill-text))}.status-pill--variant-outline{background:transparent;border-color:color-mix(in srgb,var(--status-pill-border) 70%,var(--status-pill-text) 30%);color:var(--status-pill-text)}.status-pill--with-icon.status-pill--variant-outline{padding-inline:var(--space-4)}.status-pill--variant-outline .status-pill__icon,.status-pill--variant-solid .status-pill__icon,.status-pill--variant-solid .status-pill__label{color:inherit}.student-dashboard{display:grid;grid-template-rows:auto minmax(0,1fr);gap:var(--space-6);min-height:100%;--sd-surface: var(--color-white);--sd-surface-soft: color-mix(in srgb, var(--color-primary-100) 22%, var(--color-white));--sd-surface-strong: color-mix(in srgb, var(--color-primary-100) 36%, var(--color-white));--sd-surface-gold: color-mix(in srgb, var(--color-accent-200) 40%, var(--color-white));--sd-border: var(--color-border-subtle);--sd-border-strong: color-mix(in srgb, var(--color-primary-800) 32%, transparent);--sd-border-gold: color-mix(in srgb, var(--color-accent-600) 36%, transparent);--sd-shadow-xs: var(--shadow-xs);--sd-shadow-sm: var(--shadow-sm);--sd-shadow-md: var(--shadow-md);--sd-hero-gradient: radial-gradient(140% 120% at 100% 0%, color-mix(in srgb, var(--color-primary-100) 40%, transparent) 0%, transparent 70%);--sd-hero-orb: radial-gradient(circle, color-mix(in srgb, var(--color-primary-100) 48%, transparent) 0%, transparent 68%);--sd-chip-bg: var(--status-info-bg);--sd-chip-text: var(--status-info-text);--sd-success-bg: var(--color-success-light);--sd-success-text: var(--color-success-dark);--sd-warning-bg: var(--color-warning-light);--sd-warning-text: var(--color-warning-dark);--sd-muted-text: var(--color-text-muted)}.student-dashboard__hero{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(260px,1fr);gap:var(--space-6);padding:clamp(2rem,4vw,3rem);border-radius:var(--radius-xl);border:1px solid var(--sd-border);background:var(--sd-hero-gradient),var(--sd-surface);box-shadow:var(--sd-shadow-md);position:relative;overflow:hidden}.student-dashboard__hero:after{content:"";position:absolute;inset:auto -20% -40% auto;width:min(320px,36vw);height:min(320px,36vw);border-radius:var(--radius-full);background:var(--sd-hero-orb);pointer-events:none}.student-dashboard__hero-left{display:grid;gap:var(--space-4);align-content:start;position:relative;z-index:1}.student-dashboard__hero-left h1{font-size:clamp(1.9rem,3.6vw,2.6rem);letter-spacing:-.02em;margin:0;color:var(--color-primary-800)}.student-dashboard__eyebrow{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.16em;font-weight:700;color:color-mix(in srgb,var(--color-primary-800) 55%,var(--color-white))}.student-dashboard__hero-left p{max-width:52ch}.student-dashboard__hero-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.student-dashboard__summary{display:grid;gap:var(--space-4);justify-items:center;align-content:start;position:relative;z-index:1}.student-dashboard__meta-grid{width:100%;display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.student-dashboard__meta-card{background:color-mix(in srgb,var(--color-primary-50, var(--color-white)) 94%,var(--color-white));border-radius:var(--radius-lg);border:1px solid var(--sd-border);padding:var(--space-4);display:grid;gap:var(--space-2);box-shadow:var(--sd-shadow-xs);transition:transform var(--transition-base),box-shadow var(--transition-base)}.student-dashboard__meta-card:hover{transform:translateY(-2px);box-shadow:var(--sd-shadow-sm)}.student-dashboard__meta-card span{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:color-mix(in srgb,var(--color-primary-800) 55%,var(--color-white));font-weight:700}.student-dashboard__meta-card strong{font-size:clamp(1.3rem,2.4vw,1.8rem);font-weight:700;color:var(--color-primary-800);letter-spacing:-.01em}.circular-progress{position:relative;display:grid;place-items:center;width:var(--progress-size, 160px);height:var(--progress-size, 160px);filter:drop-shadow(0 8px 24px color-mix(in srgb,var(--color-primary-800) 18%,transparent))}.circular-progress__svg{width:100%;height:100%;transform:rotate(-90deg)}.circular-progress__track{stroke:color-mix(in srgb,var(--color-primary-100) 40%,transparent);stroke-width:var(--progress-stroke, 12)}.circular-progress__indicator{stroke:var(--color-primary-800);stroke-width:var(--progress-stroke, 12);stroke-linecap:round;transition:stroke-dashoffset .7s cubic-bezier(.4,0,.2,1)}.circular-progress__label{position:absolute;display:grid;gap:var(--space-1);align-items:center;text-align:center}.circular-progress__label strong{font-size:clamp(1.6rem,2.8vw,2rem);color:var(--color-primary-800)}.circular-progress__label span{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:color-mix(in srgb,var(--color-primary-800) 55%,var(--color-white))}.circular-progress__label small{font-size:var(--text-xs);color:var(--sd-muted-text)}.student-dashboard__stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3);width:100%}.student-dashboard__stat-card{position:relative;overflow:hidden;border-radius:var(--radius-md);border:1px solid var(--sd-border);background:var(--sd-surface);padding:var(--space-4);display:grid;gap:var(--space-2);text-align:center;box-shadow:var(--sd-shadow-xs)}.student-dashboard__stat-card span{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:color-mix(in srgb,var(--color-primary-800) 50%,var(--color-white))}.student-dashboard__stat-card strong{font-size:var(--text-lg);color:var(--color-primary-800)}.student-dashboard__stat-card small{font-size:var(--text-xs);color:var(--sd-muted-text)}.student-dashboard__stat-card--level{background:color-mix(in srgb,var(--color-primary-100) 60%,var(--color-white))}.student-dashboard__stat-card--xp,.student-dashboard__stat-card--streak,.student-dashboard__stat-card--accuracy{background:color-mix(in srgb,var(--color-accent-200) 52%,var(--color-white));color:var(--color-accent-700)}.student-dashboard__stat-card--xp strong,.student-dashboard__stat-card--streak strong,.student-dashboard__stat-card--accuracy strong{color:var(--color-accent-700)}.student-dashboard__summary .pill--live{margin-top:var(--space-2)}.student-dashboard__view{display:grid;grid-template-columns:minmax(240px,340px) minmax(0,1fr);gap:var(--space-6);min-height:0}.student-dashboard__unit-column,.student-dashboard__detail-panel,.student-dashboard__insight-panel,.student-dashboard__timeline{background:var(--sd-surface);border-radius:var(--radius-lg);border:1px solid var(--sd-border);box-shadow:var(--sd-shadow-sm)}.student-dashboard__unit-column{display:flex;flex-direction:column;gap:var(--space-4);padding:clamp(1.4rem,3vw,2rem);min-height:0}.student-dashboard__unit-column header h2{margin:0;color:var(--color-primary-800)}.student-dashboard__unit-list{display:grid;gap:var(--space-3);min-height:0;overflow-y:auto;padding-right:var(--space-1)}.student-dashboard__unit-button{display:flex;justify-content:space-between;gap:var(--space-3);align-items:flex-start;border-radius:var(--radius-md);border:1px solid transparent;background:var(--sd-surface-soft);padding:var(--space-3);text-align:left;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.student-dashboard__unit-button strong{display:block;color:var(--color-primary-800);margin-bottom:4px}.student-dashboard__unit-button span{display:block;color:var(--sd-muted-text);font-size:var(--text-sm)}.student-dashboard__unit-button:hover,.student-dashboard__unit-button:focus-visible{background:var(--sd-surface-strong);border-color:var(--sd-border-strong);transform:translateY(-1px);box-shadow:var(--sd-shadow-xs)}.student-dashboard__unit-button.is-active{background:linear-gradient(135deg,var(--sd-surface-strong),var(--sd-surface-gold));border-color:var(--sd-border-strong);box-shadow:var(--sd-shadow-md)}.student-dashboard__mini-summary{display:grid;gap:var(--space-1);text-align:right;font-weight:600;color:var(--sd-muted-text);min-width:96px}.student-dashboard__mini-summary span{color:var(--color-primary-800)}.student-dashboard__mini-summary small{font-size:var(--text-xs);color:var(--sd-muted-text)}.student-dashboard__mini-bar.progress-bar{--progress-height: 6px;--progress-track-bg: color-mix(in srgb, var(--color-primary-100) 38%, transparent);--progress-fill-bg: linear-gradient(135deg, var(--color-primary-800), var(--color-primary-600))}.student-dashboard__mini-bar .progress-bar__footer{display:none}.student-dashboard__detail-panel{display:grid;gap:var(--space-5);padding:clamp(1.6rem,3vw,2.4rem);min-height:0}.student-dashboard__unit-header{display:flex;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.student-dashboard__unit-header h2{margin:0;color:var(--color-primary-800)}.student-dashboard__unit-score{display:grid;gap:var(--space-1);text-align:right;color:var(--sd-muted-text)}.student-dashboard__unit-score strong{font-size:clamp(2rem,3.2vw,2.4rem);color:var(--color-primary-800)}.student-dashboard__stack-bar{display:flex;width:100%;height:12px;border-radius:var(--radius-pill);overflow:hidden;background:color-mix(in srgb,var(--color-primary-100) 42%,transparent)}.student-dashboard__stack-bar-segment{flex:0 0 var(--segment-percent, 0%);height:100%}.student-dashboard__stack-bar-segment--complete{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-600))}.student-dashboard__stack-bar-segment--progress{background:linear-gradient(135deg,var(--color-accent-600),var(--color-accent-400))}.student-dashboard__stack-bar-segment--locked{background:color-mix(in srgb,var(--color-primary-800) 18%,transparent)}.student-dashboard__unit-counters{display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-6);font-weight:600;color:var(--sd-muted-text)}.student-dashboard__unit-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.student-dashboard__hint{font-weight:600;color:var(--sd-muted-text)}.student-dashboard__lesson-items{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-3)}.student-dashboard__lesson-items li{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--sd-border);background:var(--sd-surface-soft);padding:var(--space-3) var(--space-4);box-shadow:var(--sd-shadow-xs)}.student-dashboard__lesson-info{display:grid;gap:var(--space-1)}.student-dashboard__lesson-info strong{color:var(--color-primary-800)}.student-dashboard__lesson-actions{display:flex;align-items:center;gap:var(--space-2);min-width:max-content}.student-dashboard__insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-4)}.student-dashboard__insight-panel,.student-dashboard__timeline{display:grid;gap:var(--space-4);padding:clamp(1.4rem,3vw,2rem);min-height:0}.student-dashboard__insight-header{display:flex;justify-content:space-between;gap:var(--space-3);align-items:center}.student-dashboard__tabs{display:inline-flex;gap:var(--space-2);border-radius:var(--radius-pill);padding:var(--space-1);border:1px solid var(--sd-border);background:color-mix(in srgb,var(--color-primary-50, var(--color-white)) 94%,var(--color-white))}.student-dashboard__tab{border:none;background:transparent;padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);font-weight:600;font-size:var(--text-sm);color:color-mix(in srgb,var(--color-primary-800) 52%,var(--color-white));cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.student-dashboard__tab.is-active{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-600));color:var(--color-white);box-shadow:0 8px 18px color-mix(in srgb,var(--color-primary-800) 18%,transparent)}.student-dashboard__focus ul{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-2);font-weight:600;color:var(--sd-muted-text)}.student-dashboard__insight-scroll{border-radius:var(--radius-md);border:1px solid var(--sd-border);overflow-x:auto}.student-dashboard__insight-scroll table{width:100%;border-collapse:collapse}.student-dashboard__insight-scroll th,.student-dashboard__insight-scroll td{padding:var(--space-3);border-bottom:1px solid var(--sd-border);text-align:left;font-size:var(--text-sm)}.student-dashboard__timeline ul{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-3)}.student-dashboard__timeline li{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--sd-border)}.student-dashboard__timeline li:last-child{border-bottom:none;padding-bottom:0}.student-dashboard__empty-panel,.student-dashboard__empty{display:grid;place-items:center;gap:var(--space-2);text-align:center;color:var(--sd-muted-text)}.student-tag{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-pill);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;background:var(--sd-chip-bg);color:var(--sd-chip-text)}.student-tag--summative-complete,.student-tag--formative-complete{background:var(--sd-success-bg);color:var(--sd-success-text)}.student-tag--available{background:var(--sd-warning-bg);color:var(--sd-warning-text)}.student-tag--locked{background:color-mix(in srgb,var(--color-primary-100) 32%,transparent);color:color-mix(in srgb,var(--color-primary-800) 52%,var(--color-white))}.pill--ghost{background:color-mix(in srgb,var(--color-primary-50, var(--color-white)) 92%,var(--color-white));border-color:var(--sd-border);color:var(--color-primary-800)}.pill--ghost:hover,.pill--ghost:focus-visible{background:var(--sd-surface-strong)}.pill--live{background:linear-gradient(135deg,var(--color-accent-600),var(--color-accent-400));color:var(--color-white);border-color:transparent;box-shadow:0 10px 26px color-mix(in srgb,var(--color-accent-600) 24%,transparent)}.pill--live:hover,.pill--live:focus-visible{background:linear-gradient(135deg,var(--color-accent-600),var(--color-accent-500))}.student-dashboard__lesson-items li .pill{font-size:var(--text-xs)}.student-dashboard__class-card{display:grid;gap:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--sd-border);background:var(--sd-surface-soft);padding:var(--space-4);box-shadow:var(--sd-shadow-xs)}.student-dashboard__class-eyebrow{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.12em;color:color-mix(in srgb,var(--color-primary-800) 55%,var(--color-white));font-weight:700}.student-dashboard__class-card strong{color:var(--color-primary-800);font-size:var(--text-lg)}.student-dashboard__class-meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);font-weight:600;color:var(--sd-muted-text)}.student-dashboard__pointer{display:grid;gap:var(--space-1);padding:var(--space-3);border-radius:var(--radius-md);background:var(--sd-surface-gold);border:1px solid var(--sd-border-gold)}.student-dashboard__pointer span{font-size:var(--text-xs);letter-spacing:.12em;text-transform:uppercase;color:color-mix(in srgb,var(--color-accent-700) 70%,var(--color-white))}.student-dashboard__pointer strong{color:var(--color-accent-700)}.student-dashboard__pointer small{color:var(--sd-muted-text);font-weight:600}@media (max-width: 1080px){.student-dashboard__hero{grid-template-columns:1fr}.student-dashboard__summary{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.student-dashboard__view{grid-template-columns:1fr}}@media (max-width: 720px){.student-dashboard__lesson-items li,.student-dashboard__timeline li{flex-direction:column;align-items:flex-start}.student-dashboard__lesson-actions{width:100%;justify-content:flex-start}.student-dashboard__stat-grid{grid-template-columns:1fr}}.curriculum-page .page-hero{position:relative}.curriculum-page .page-hero:before{content:"";position:absolute;inset:auto -20% -40% auto;width:min(260px,35vw);height:min(260px,35vw);background:radial-gradient(circle,color-mix(in srgb,var(--cs-gold) 45%,transparent) 0%,transparent 70%);opacity:.6}.curriculum-panel{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);padding:clamp(1.45rem,3.2vw,2.1rem);display:grid;gap:var(--space-4)}.curriculum-panel--highlight{background:var(--cs-gradient-card);border-color:var(--color-border);box-shadow:var(--shadow-md)}.curriculum-panel__header{display:flex;flex-direction:column;gap:var(--space-2)}.curriculum-panel__header>div h2{margin:0;font-size:1.4rem;color:var(--color-primary-800)}.curriculum-panel__body{display:grid;gap:var(--space-3)}.curriculum-buttons{display:flex;flex-wrap:wrap;gap:var(--space-3)}.curriculum-buttons .pill{border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);background:var(--status-info-bg);color:var(--status-info-text);font-weight:600;display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);text-decoration:none}.curriculum-buttons .pill small{font-weight:500;font-size:var(--text-xs);color:var(--color-text-muted)}.curriculum-buttons .pill--locked{cursor:not-allowed;border-color:var(--color-border-subtle);background:var(--color-surface-muted);color:var(--color-text-muted)}.curriculum-buttons .pill--live{background:var(--color-primary-100);border-color:var(--color-primary-200);color:var(--color-primary-800);text-decoration:none}.curriculum-buttons .pill--live small{color:var(--color-text-muted)}.curriculum-buttons .pill--live:hover,.curriculum-buttons .pill--live:focus-visible{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.curriculum-buttons .pill--action{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);border:none;text-decoration:none}.curriculum-panel--highlight .pill--action{box-shadow:var(--shadow-md)}.ib-layout{display:grid;gap:clamp(1.5rem,4vw,2.5rem);grid-template-columns:minmax(0,1fr);--ib-surface-muted: color-mix(in srgb, var(--color-primary-100) 35%, var(--color-white));--ib-surface-tint: color-mix(in srgb, var(--color-primary-100) 55%, var(--color-white));--ib-surface-strong: color-mix(in srgb, var(--color-primary-100) 70%, var(--color-white));--ib-border-soft: color-mix(in srgb, var(--color-primary-800) 12%, transparent);--ib-border-strong: color-mix(in srgb, var(--color-primary-800) 24%, transparent);--ib-border-highlight: color-mix(in srgb, var(--color-primary-800) 30%, transparent)}.ib-sidebar{background:var(--color-white);border-radius:20px;border:1px solid var(--ib-border-soft);box-shadow:var(--shadow-lg);padding:clamp(1.6rem,3vw,2.4rem);display:grid;gap:1.8rem;position:sticky;top:clamp(1rem,4vw,2rem);align-self:start}.ib-sidebar__intro h1{margin-bottom:.45rem;font-size:clamp(1.75rem,4vw,2.4rem);color:var(--color-primary-800)}.ib-sidebar__intro p{margin:0;line-height:1.6}.ib-sidebar__back{display:inline-flex;align-items:center;gap:.35rem;margin-top:1.25rem;color:var(--color-primary-800);font-weight:600;text-decoration:none}.ib-sidebar__nav{display:grid;gap:.5rem}.ib-sidebar__unit{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.65rem;align-items:center;border:1px solid transparent;border-radius:var(--radius-md);background:var(--ib-surface-muted);padding:.65rem .85rem;text-align:left;font:inherit;color:var(--color-primary-800);cursor:pointer;transition:background var(--transition-base),border var(--transition-base),transform var(--transition-base)}.ib-sidebar__unit:hover,.ib-sidebar__unit:focus-visible{background:var(--ib-surface-tint)}.ib-sidebar__unit.is-active{border-color:var(--ib-border-strong);background:var(--ib-surface-strong);transform:translate(4px)}.ib-sidebar__unit-code{font-weight:700;letter-spacing:.02em}.ib-sidebar__unit-title{font-weight:600}.ib-content{background:var(--color-white);border-radius:22px;border:1px solid var(--ib-border-soft);box-shadow:var(--shadow-lg);padding:clamp(1.6rem,4vw,2.8rem);display:grid;gap:clamp(1.6rem,3vw,2.3rem)}.ib-content__header{display:flex;flex-direction:column;gap:1rem}.ib-content__theme{text-transform:uppercase;letter-spacing:.08em;font-size:var(--text-xs);color:var(--color-text-muted)}.ib-content__header h2{margin:0;font-size:clamp(1.6rem,4vw,2.2rem)}.ib-content__guiding{margin:0;max-width:60ch;line-height:1.6}.ib-content__meta{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.ib-unit-launch{display:flex;gap:var(--space-4);align-items:center;justify-content:space-between;flex-wrap:wrap;background:var(--ib-surface-muted);border:1px solid var(--ib-border-soft);border-radius:var(--radius-xl);padding:1.2rem 1.5rem}.ib-chapters{display:grid;gap:var(--space-6)}.ib-chapter{border:1px solid var(--ib-border-soft);border-radius:var(--radius-xl);padding:clamp(1.5rem,3vw,2rem);background:var(--color-white);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-4)}.ib-chapter__header{display:flex;flex-direction:column;gap:var(--space-3)}.ib-chapter__header h3{margin:0;font-size:clamp(1.2rem,3vw,1.6rem)}.ib-chapter__tag{display:inline-flex;padding:.35rem .75rem;border-radius:var(--radius-pill);background:var(--status-info-bg);color:var(--status-info-text);font-size:var(--text-xs);font-weight:600;margin-top:.35rem}.ib-chapter__actions{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}.ib-chapter__link{border-radius:var(--radius-pill);border:1px solid var(--color-border-subtle);padding:.45rem .9rem;font-weight:600;color:var(--color-primary-800);transition:background var(--transition-fast),color var(--transition-fast),border var(--transition-fast),box-shadow var(--transition-fast);text-decoration:none}.ib-chapter__link:hover,.ib-chapter__link:focus-visible{background:var(--color-primary-800);color:var(--color-white);border-color:transparent;box-shadow:var(--shadow-sm)}.ib-chapter__link.is-disabled{pointer-events:none;opacity:.55}.ib-lessons{list-style:none;margin:0;padding:0;display:grid;gap:.65rem}.ib-lesson{display:grid;grid-template-columns:minmax(100px,140px) minmax(0,1fr) auto;gap:.75rem;align-items:center;background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);padding:.75rem 1rem}.ib-lesson__code{font-weight:700;color:var(--color-primary-800)}.ib-lesson__title{font-weight:500;color:var(--color-text)}justify-self: end; display: flex; gap: var(--space-2); } .ib-placeholder{min-height:200px;display:grid;place-items:center;color:var(--color-text-muted)}.ib-loading{padding:2.5rem;border-radius:20px;background:var(--color-white);border:1px solid var(--ib-border-soft);text-align:center;box-shadow:var(--shadow-lg)}.ib-unit-assessment{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center;background:var(--ib-surface-muted);border:1px dashed var(--ib-border-soft);border-radius:var(--radius-lg);padding:clamp(1rem,2.5vw,1.6rem)}.ib-unit-assessment h3{margin:0;font-size:1.2rem}.ib-b1-preview,.ib-b2-preview{display:grid;gap:1.5rem;background:var(--ib-surface-muted);border:1px solid var(--ib-border-soft);border-radius:20px;padding:clamp(1.6rem,3vw,2.2rem)}.ib-b1-preview__intro h3,.ib-b2-preview__intro h3{margin:0 0 .4rem;font-size:1.3rem;color:var(--color-primary-800)}.ib-b1-preview__stages,.ib-b2-preview__stages{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.ib-b1-preview__stages article,.ib-b2-preview__stages article{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);padding:1rem 1.2rem;display:grid;gap:.4rem;box-shadow:var(--shadow-xs)}.ib-b1-preview__stages h4,.ib-b2-preview__stages h4{margin:0;font-size:1.05rem;color:var(--color-primary-800)}.ib-b1-preview__stages span,.ib-b2-preview__stages span{font-size:.85rem;color:var(--color-text-muted);font-weight:600}.ib-b1-preview__actions,.ib-b2-preview__actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;justify-content:space-between}@media (min-width: 1024px){.ib-layout{grid-template-columns:minmax(280px,340px) minmax(0,1fr)}}@media (max-width: 900px){.ib-sidebar{position:static}.ib-lesson{grid-template-columns:minmax(80px,110px) minmax(0,1fr);grid-template-rows:auto auto;row-gap:.35rem}.ib-lesson__status{grid-column:1 / -1}}@media (max-width: 640px){.ib-content__meta{flex-direction:column;align-items:flex-start}.ib-lesson{grid-template-columns:minmax(0,1fr)}.ib-lesson__code{font-size:.9rem}.ib-lesson__title{font-size:.95rem}}.igcse-map{display:grid;gap:clamp(1.6rem,3vw,2.8rem)}.igcse-hero{display:flex;flex-direction:column;gap:1.4rem;padding:clamp(1.8rem,4vw,2.6rem);border-radius:28px;background:linear-gradient(135deg,#1d4ed81f,#0ea5e914);box-shadow:0 22px 48px #1e40af2e}.igcse-hero__text{display:grid;gap:.75rem}.igcse-hero__eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:700;color:#1d4ed8bf}.igcse-hero__status{display:grid;gap:.4rem;align-self:flex-start}.igcse-grid{display:grid;gap:clamp(1.2rem,2.4vw,2rem);grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.igcse-unit{border-top:6px solid var(--cs-blue);border-radius:22px;padding:clamp(1.4rem,3vw,2rem);display:grid;gap:1.2rem}.igcse-unit__header{display:flex;gap:1rem;align-items:flex-start}.igcse-unit__icon{font-size:2rem;line-height:1}.igcse-unit__meta{display:grid;gap:.4rem}.igcse-unit__list{list-style:none;margin:0;padding:0;display:grid;gap:.8rem}.igcse-lesson{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:start;padding:.85rem .95rem;border-radius:16px;background:#ffffffe0;border:1px solid rgba(2,132,199,.14);box-shadow:0 16px 38px #0f172a14}.igcse-lesson__order{font-size:.9rem;font-weight:700;color:#1d4ed8d1;letter-spacing:.08em}.igcse-lesson__meta{display:grid;gap:.25rem}.igcse-lesson__meta strong{font-size:1.02rem}.topic-page{display:flex;flex-direction:column;min-height:calc(100vh - 80px);background:linear-gradient(135deg,#f5f7fa,#e9ecef)}.topic-breadcrumb{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:#fff;border-bottom:1px solid #e0e0e0;font-size:.875rem;color:#666}.topic-breadcrumb a{color:#4a90e2;text-decoration:none;transition:color .2s}.topic-breadcrumb a:hover{color:#357abd;text-decoration:underline}.topic-breadcrumb span:not(:last-child){color:#999}.topic-content{max-width:1200px;margin:0 auto;padding:2rem;width:100%}.topic-header{margin-bottom:2rem;text-align:center}.topic-header h1{margin:0 0 .5rem;font-size:2rem;color:#2c3e50;font-weight:700}.topic-header .muted{font-size:1rem}.topic-alert{margin-top:1rem;display:inline-block;padding:.65rem 1rem;border-radius:12px;background:#e67e221f;color:#d35400;font-weight:600}.topic-lessons{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #00000014}.topic-lessons h2{margin:0 0 1.5rem;font-size:1.5rem;color:#2c3e50}.topic-lessons__intro{margin-top:-1rem;margin-bottom:1.5rem;font-size:.95rem;color:#555}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:2rem}.lesson-card{position:relative;display:flex;flex-direction:column;gap:.75rem;padding:1.5rem;border:2px solid #e0e0e0;border-radius:12px;background:#fff;text-decoration:none;color:inherit;transition:all .3s;cursor:pointer}.lesson-card:hover{border-color:#4a90e2;box-shadow:0 4px 12px #4a90e226;transform:translateY(-2px)}.lesson-card.unlocked{border-color:#48bb78;background:linear-gradient(135deg,#f0fff4,#fff)}.lesson-card.locked{opacity:.6;cursor:not-allowed;background:#f7fafc}.lesson-card.locked:hover{transform:none;box-shadow:none;border-color:#e0e0e0}.lesson-card__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.lesson-card__number{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;border-radius:50%;font-weight:700;font-size:.875rem}.lesson-card.locked .lesson-card__number{background:#cbd5e0}.lesson-card.unlocked .lesson-card__number{background:linear-gradient(135deg,#48bb78,#38a169)}.lesson-card__title{margin:0;font-size:1rem;font-weight:600;color:#2c3e50;line-height:1.4}.lesson-card__lock{position:absolute;top:1rem;right:1rem;color:#a0aec0}.badge{display:inline-block;padding:.25rem .5rem;border-radius:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge--hl{background:#fff5e6;color:#e67e22;border:1px solid #f39c12}.badge--unlocked{background:#e8f5e9;color:#2e7d32}.badge--teacher{background:#0c297c1f;color:var(--cs-blue)}.topic-footer{margin-top:2rem;padding-top:2rem;border-top:2px solid #e0e0e0}.topic-test{text-align:center;padding:2rem;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:2px dashed #cbd5e0}.topic-test h3{margin:0 0 .5rem;font-size:1.25rem;color:#2c3e50}.topic-test .muted{margin-bottom:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 2rem;border:none;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff;box-shadow:0 2px 4px #4a90e24d}.btn--primary:hover:not(:disabled){background:linear-gradient(135deg,#357abd,#2868a8);box-shadow:0 4px 8px #4a90e266;transform:translateY(-1px)}@media (max-width: 768px){.topic-content{padding:1rem}.topic-header h1{font-size:1.5rem}.topic-lessons{padding:1.5rem}.lesson-grid{grid-template-columns:1fr}.topic-test{padding:1.5rem 1rem}}.lesson-page{display:grid;gap:var(--space-5);min-height:100%}.lesson-breadcrumb{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-xs);font-size:var(--text-sm);color:var(--color-text-muted)}.lesson-breadcrumb a{color:var(--color-primary-800);text-decoration:none;font-weight:600}.lesson-breadcrumb a:hover,.lesson-breadcrumb a:focus-visible{text-decoration:underline}.lesson-container{display:grid;grid-template-columns:minmax(280px,24%) minmax(0,1fr);gap:var(--space-5);width:100%}@media (max-width: 960px){.lesson-container{grid-template-columns:1fr}}.lesson-sidebar{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);padding:clamp(1.2rem,2.4vw,1.8rem);display:flex;flex-direction:column;gap:var(--space-4);position:sticky;top:var(--space-5);max-height:calc(100vh - 2 * var(--space-5))}.lesson-sidebar__header{border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-3);display:grid;gap:var(--space-2)}.lesson-sidebar__header h3{margin:0;font-size:1.35rem;color:var(--color-primary-800)}.lesson-sidebar__alert{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);background:#b2854129;color:var(--color-accent-700);font-weight:700;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em}.lesson-nav{flex:1;overflow-y:auto;display:grid;gap:var(--space-2);padding-right:var(--space-1)}.lesson-nav__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:#0c297c0a;color:var(--color-text);text-decoration:none;font-size:var(--text-sm);transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.lesson-nav__item:hover,.lesson-nav__item:focus-visible{transform:translate(4px);border-color:#0c297c52;background:#0c297c1f}.lesson-nav__item.active{background:linear-gradient(135deg,#0c297ce6,#2f5dc7f2);border-color:#0c297c66;color:var(--color-white);box-shadow:var(--shadow-sm)}.lesson-nav__item.locked{opacity:.55;cursor:not-allowed}.lesson-nav__number{flex-shrink:0;width:32px;height:32px;display:grid;place-items:center;border-radius:var(--radius-pill);background:#0c297c26;color:var(--color-primary-800);font-weight:700}.lesson-nav__item.active .lesson-nav__number{background:var(--color-white);color:var(--color-primary-800)}.lesson-sidebar__footer{margin-top:auto;border-top:1px solid var(--color-border-subtle);padding-top:var(--space-3)}.lesson-content{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);padding:clamp(1.8rem,3vw,2.4rem);display:grid;gap:var(--space-5)}.lesson-header{display:grid;gap:var(--space-3);border-bottom:1px solid var(--color-border-subtle);padding-bottom:var(--space-4)}.lesson-header h1{margin:0;font-size:clamp(1.8rem,3vw,2.4rem);color:var(--color-primary-900);letter-spacing:-.01em}.lesson-header__meta{display:flex;gap:var(--space-2);flex-wrap:wrap}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.badge--primary{background:#0c297c24;color:var(--color-primary-800)}.badge--muted{background:#0c297c14;color:var(--color-text-muted)}.badge--hl,.badge--teacher{background:#b2854129;color:var(--color-accent-700)}.lesson-sections{display:grid;gap:var(--space-3)}.lesson-section{border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);overflow:hidden;background:#0c297c08;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.lesson-section:hover{border-color:#0c297c38;box-shadow:var(--shadow-xs)}.lesson-section__title{margin:0;padding:var(--space-3) var(--space-4);background:#0c297c0f;font-size:1.1rem;font-weight:600;color:var(--color-primary-800)}.lesson-section__content{padding:var(--space-4);line-height:1.7;color:var(--color-text)}.lesson-section__content ul{padding-left:var(--space-5);margin:0;display:grid;gap:var(--space-2)}.lesson-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:space-between;border-top:1px solid var(--color-border-subtle);padding-top:var(--space-4)}.btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);text-decoration:none;display:inline-flex;align-items:center;gap:var(--space-2)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);border:none;box-shadow:var(--shadow-xs)}.btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn--secondary{background:#0c297c0d;color:var(--color-primary-800);border:1px solid rgba(12,41,124,.24)}.btn--secondary:hover:not(:disabled){background:#0c297c1f}.lesson-progress{background:var(--color-white);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);display:grid;gap:var(--space-3);box-shadow:var(--shadow-xs)}.lesson-progress__track{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center}.lesson-progress__dot{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-pill);border:2px solid rgba(12,41,124,.16);background:#0c297c0a;color:var(--color-text-muted);font-weight:600;transition:transform var(--transition-fast),border-color var(--transition-fast),background var(--transition-fast)}.lesson-progress__dot:hover{transform:scale(1.05);border-color:#0c297c47}.lesson-progress__dot.active{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);border-color:#0c297c66;box-shadow:var(--shadow-xs)}.lesson-progress__dot.completed{background:#b2854138;border-color:#b2854166;color:var(--color-accent-700)}.lesson-progress__dot.locked{opacity:.45}.lesson-progress__label{text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}@media (max-width: 768px){.lesson-breadcrumb{padding:var(--space-2) var(--space-3)}.lesson-container{gap:var(--space-4)}.lesson-sidebar{position:static;max-height:none}.lesson-actions{flex-direction:column;align-items:stretch}.btn{justify-content:center;width:100%}}.admin-grid{display:grid;gap:2rem}.card{background:var(--cs-white);border-radius:18px;padding:clamp(1.6rem,3.5vw,2.4rem);box-shadow:0 22px 48px #0c297c24;border:1px solid rgba(12,41,124,.12);display:grid;gap:1.4rem}.status{margin:0}.status--error{color:#c0392b}.status--success{color:#0f7a39}.status--info{color:var(--cs-blue)}.muted{color:var(--cs-muted)}.admin-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.admin-summary div{border-radius:1rem;border:1px solid rgba(12,41,124,.12);background:#0c297c0a;padding:1rem 1.1rem;display:grid;gap:.35rem}.admin-form{display:grid;gap:.9rem}.admin-form label{display:grid;gap:.35rem}.admin-form input{border:1px solid rgba(12,41,124,.18);border-radius:.75rem;padding:.65rem .85rem;background:#0c297c0a}.teacher-table{display:grid;gap:.85rem}.teacher-table__head,.teacher-row{display:grid;grid-template-columns:1.5fr 1fr .8fr .8fr 1fr auto;gap:.75rem;align-items:center}.teacher-table__head{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cs-muted)}.teacher-row{border:1px solid rgba(12,41,124,.12);border-radius:1rem;padding:.85rem 1rem;background:#0c297c0d}.badge{display:inline-block;border-radius:999px;padding:.25rem .7rem;background:#0c297c1f;color:var(--cs-blue);font-size:.75rem;font-weight:600;text-align:center}@media (max-width: 860px){.teacher-table__head{display:none}.teacher-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.teacher-row span:last-child{grid-column:1 / -1}}.account-grid{display:grid;gap:2rem}.card{background:var(--cs-white);border-radius:18px;padding:clamp(1.6rem,3.5vw,2.4rem);box-shadow:0 18px 44px #0c297c1f;border:1px solid rgba(12,41,124,.12);display:grid;gap:1.4rem}.card-header{display:flex;flex-direction:column;gap:1rem}.account-detail{display:grid;gap:.85rem}.account-detail div{border-radius:1rem;border:1px solid rgba(12,41,124,.12);background:#0c297c0d;padding:.9rem 1.1rem;display:grid;gap:.3rem}.account-detail dt{color:var(--cs-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}.account-detail dd{margin:0;font-size:1rem;font-weight:600}@media (min-width: 900px){.card-header{flex-direction:row;justify-content:space-between;align-items:flex-start}}.layout-root{min-height:100vh;background:var(--color-surface);color:var(--color-text);display:flex}.layout-root--collapsed .layout-sidebar{width:92px}.layout-root--collapsed .layout-brand__text,.layout-root--collapsed .layout-sidebar__nav-text,.layout-root--collapsed .layout-sidebar__section-title,.layout-root--collapsed .layout-sidebar__footer{opacity:0;visibility:hidden;pointer-events:none}.layout-root--collapsed .layout-sidebar__nav-item{justify-content:center}.layout-root--collapsed .layout-sidebar__nav-bullet{margin:0}.layout-root--collapsed .layout-sidebar__collapse span{transform:rotate(180deg)}.layout-sidebar{width:280px;background:var(--color-white);border-right:1px solid var(--color-border);box-shadow:0 20px 40px #050d3114;display:flex;flex-direction:column;gap:var(--space-6);padding:var(--space-6) var(--space-4);position:sticky;top:0;height:100vh;transition:width var(--transition-base) ease;z-index:32}.layout-sidebar__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.layout-brand{display:inline-flex;align-items:center;gap:var(--space-3);color:inherit;text-decoration:none;white-space:nowrap}.layout-brand--inline{gap:var(--space-3)}.layout-brand__mark{width:52px;height:auto;filter:drop-shadow(0 6px 18px rgba(12,41,124,.12));transition:transform var(--transition-fast)}.layout-brand:hover .layout-brand__mark{transform:scale(1.02)}.layout-brand__text{display:flex;flex-direction:column;gap:2px}.layout-brand__title{font-weight:700;letter-spacing:-.01em}.layout-brand__subtitle{font-size:var(--text-xs);color:#0c297ca6}.layout-sidebar__collapse{width:36px;height:36px;border-radius:var(--radius-md);border:1px solid rgba(12,41,124,.18);background:#0c297c0d;display:grid;place-items:center;transition:background var(--transition-fast),border-color var(--transition-fast)}.layout-sidebar__collapse:hover{background:#0c297c1f;border-color:#0c297c47}.layout-sidebar__collapse span{width:12px;height:12px;border-right:2px solid var(--color-primary-800);border-bottom:2px solid var(--color-primary-800);transform:rotate(45deg);transition:transform var(--transition-base)}.layout-sidebar__sections{flex:1;overflow-y:auto;display:grid;gap:var(--space-5);padding-right:var(--space-2)}.layout-sidebar__section{display:grid;gap:var(--space-2)}.layout-sidebar__section-title{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#0c297c8c}.layout-sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-soft);font-weight:600;position:relative;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.layout-sidebar__nav-item:hover{background:#0c297c14;color:var(--color-primary-800)}.layout-sidebar__nav-item.is-active{background:#0c297c29;color:var(--color-primary-800);box-shadow:inset 0 0 0 1px #0c297c2e}.layout-sidebar__nav-item.is-active:before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:4px;height:20px;border-radius:var(--radius-pill);background:var(--color-primary-700)}.layout-sidebar__nav-bullet{width:32px;height:32px;border-radius:var(--radius-md);background:#0c297c1f;color:var(--color-primary-800);display:grid;place-items:center;font-weight:700;font-size:var(--text-sm)}.layout-sidebar__nav-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layout-sidebar__footer{display:grid;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border-subtle)}.layout-sidebar__user{display:flex;align-items:center;gap:var(--space-3)}.layout-sidebar__avatar{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--color-primary-800) 0%,var(--color-primary-700) 100%);color:var(--color-white);font-weight:700;letter-spacing:.06em}.layout-sidebar__user-meta{display:grid;gap:2px}.layout-sidebar__user-meta strong{font-size:var(--text-sm)}.layout-sidebar__signout{justify-self:flex-start;padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);border:1px solid rgba(5,13,49,.16);color:var(--color-text);transition:background var(--transition-fast),color var(--transition-fast)}.layout-sidebar__signout:hover{background:#050d3114}.layout-sidebar__scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#050d3166;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity var(--transition-base);z-index:24}.layout-root--nav-open .layout-sidebar__scrim{opacity:1;pointer-events:auto}.layout-scaffold{flex:1;display:flex;flex-direction:column;min-height:100vh}.layout-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-5);background:#ffffffe6;border-bottom:1px solid var(--color-border-subtle);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.layout-topbar__left{display:flex;align-items:center;gap:var(--space-3)}.layout-topbar__nav-toggle{width:44px;height:44px;border-radius:var(--radius-md);border:1px solid rgba(12,41,124,.2);background:#0c297c0d;display:grid;place-items:center;padding:0 var(--space-2);gap:4px;transition:background var(--transition-fast),border-color var(--transition-fast)}.layout-topbar__nav-toggle:hover{background:#0c297c1f}.layout-topbar__nav-toggle span{display:block;width:100%;height:2px;border-radius:999px;background:var(--color-primary-800)}.layout-topbar__title{font-weight:600;letter-spacing:-.01em}.layout-topbar__actions{display:flex;align-items:center;gap:var(--space-3)}.layout-login-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-pill);border:1px solid rgba(12,41,124,.18);background:#0c297c0f;color:var(--color-primary-800);font-weight:600;transition:background var(--transition-fast),border-color var(--transition-fast)}.layout-login-link:hover{background:#0c297c24;border-color:#0c297c47}.layout-account{position:relative}.layout-account__button{display:inline-flex;align-items:center;gap:var(--space-3);border-radius:var(--radius-pill);padding:var(--space-2) var(--space-4);border:1px solid rgba(12,41,124,.2);background:#0c297c0f;color:var(--color-primary-800);font-weight:600;transition:background var(--transition-fast),border-color var(--transition-fast)}.layout-account__button:hover{background:#0c297c24;border-color:#0c297c4d}.layout-account__avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--color-primary-800) 0%,var(--color-primary-700) 100%);color:var(--color-white);font-weight:700;letter-spacing:.06em;font-size:var(--text-sm)}.layout-account__chevron{width:12px;height:8px}.layout-account__menu{position:absolute;right:0;top:calc(100% + .5rem);min-width:210px;border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);background:#fffffffa;box-shadow:0 16px 36px #050d3124;padding:var(--space-1) 0;display:grid;gap:0}.layout-account__menu a,.layout-account__menu button{font:inherit;text-align:left;padding:var(--space-3) var(--space-4);background:transparent;border:none;color:var(--color-primary-800);font-weight:600;transition:background var(--transition-fast),padding-left var(--transition-fast)}.layout-account__menu a:hover,.layout-account__menu button:hover,.layout-account__menu a:focus-visible,.layout-account__menu button:focus-visible{background:#0c297c14;padding-left:calc(var(--space-4) + 4px)}.layout-account__greeting{white-space:nowrap}.layout-main{flex:1;padding:clamp(1.5rem,3vw,3rem)}.layout-main>.layout-contained{max-width:var(--max-content-width);margin:0 auto}.layout-footer{background:#050d31eb;color:#ffffffe0;text-align:center;padding:var(--space-4);font-size:var(--text-sm);letter-spacing:.04em}@media (max-width: 1199px){.layout-root--collapsed .layout-sidebar{width:280px}.layout-root--collapsed .layout-brand__text,.layout-root--collapsed .layout-sidebar__nav-text,.layout-root--collapsed .layout-sidebar__section-title,.layout-root--collapsed .layout-sidebar__footer{opacity:1;visibility:visible;pointer-events:auto}}@media (max-width: 1023px){.layout-root{position:relative}.layout-sidebar{position:fixed;left:0;top:0;height:100vh;transform:translate(-100%);transition:transform var(--transition-base)}.layout-root--nav-open .layout-sidebar{transform:translate(0)}.layout-topbar{padding-inline:var(--space-4)}.layout-brand__subtitle{display:none}.layout-topbar__title{font-size:var(--text-lg)}}@media (max-width: 640px){.layout-topbar__actions{gap:var(--space-2)}.layout-account__greeting{display:none}.layout-main{padding:var(--space-5) var(--space-4)}.layout-footer{padding:var(--space-4) var(--space-3)}}.gamified-card{background:var(--color-white);border-radius:var(--radius-xl);padding:clamp(var(--space-6),3vw,var(--space-7));border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-md);display:grid;gap:var(--space-5)}.gamified-card header h3{margin:0;font-size:clamp(var(--text-xl),2.6vw,var(--text-2xl));color:var(--color-text)}.gamified-card header .muted{margin-top:var(--space-2)}.gamified-card__body{display:grid;gap:var(--space-4);line-height:1.7;color:var(--color-text-soft)}.gamified-card__body--list{gap:var(--space-4)}.gamified-list-item{background:linear-gradient(135deg,#fffffff5,#f8faffe6);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);position:relative;z-index:0;overflow:hidden}.gamified-list-item:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0c297c14,#3fb5ff14);opacity:0;transition:opacity var(--transition-base);pointer-events:none;z-index:-1}.gamified-list-item:hover{transform:translate(var(--space-1));box-shadow:var(--shadow-md);border-color:var(--color-border)}.gamified-list-item:hover:before{opacity:1}.gamified-list-item h4{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:700;color:var(--color-primary-800);display:flex;align-items:center;gap:var(--space-2)}.gamified-list-item h4:before{content:"";width:6px;height:6px;border-radius:999px;background:var(--color-primary-500)}.gamified-list-item p{margin:0;color:var(--color-text-soft);line-height:1.6}.gamified-table-wrapper{overflow-x:auto;border-radius:var(--radius-xl);border:1px solid var(--color-border-subtle);background:var(--color-white);box-shadow:var(--shadow-sm)}.gamified-table-wrapper table{width:100%;border-collapse:collapse;min-width:480px}.gamified-table-wrapper th{padding:var(--space-3) var(--space-5);background:var(--cs-gradient-card);font-weight:700;text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.08em;color:var(--color-primary-800);border-bottom:2px solid var(--color-border-subtle);text-align:left;position:sticky;top:0;z-index:1}.gamified-table-wrapper td{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--color-border-subtle);text-align:left;transition:background var(--transition-fast)}.gamified-table-wrapper tbody tr{transition:background var(--transition-fast),transform var(--transition-fast)}.gamified-table-wrapper tbody tr:nth-child(2n){background:#0c297c08}.gamified-table-wrapper tbody tr:hover{background:#3fb5ff14;transform:translateY(-1px)}.gamified-table-wrapper tbody tr:last-child td{border-bottom:none}.gamified-table-wrapper code{background:#0a1030eb;color:#ffffffeb;padding:.15rem .4rem;border-radius:var(--radius-sm);font-family:Fira Code,Courier New,monospace;font-size:.9em}.gamified-accordion details{border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);background:#0c297c0d;padding:var(--space-4) var(--space-5)}.gamified-accordion summary{cursor:pointer;font-weight:600;color:var(--color-primary-800)}.gamified-segment-nav{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.gamified-segment-actions{display:flex;gap:var(--space-3);align-items:center}.btn{border:1px solid transparent;border-radius:var(--radius-pill);font-weight:600;cursor:pointer;padding:calc(var(--space-2) + 2px) var(--space-5);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);font-size:var(--text-sm);letter-spacing:.01em;background:transparent;color:inherit}.btn:disabled{opacity:.5;pointer-events:none}.btn--primary{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--ghost{background:#0c297c0a;border-color:#0c297c3d;color:var(--color-primary-800)}.btn--ghost:hover:not(:disabled){background:#0c297c1a}.btn--outline{background:var(--color-white);border-color:#0c297c3d;color:var(--color-primary-800);box-shadow:var(--shadow-xs)}.btn--outline:hover:not(:disabled){box-shadow:var(--shadow-sm)}.pill{display:inline-flex;align-items:center;gap:var(--space-2);border-radius:var(--radius-pill);padding:calc(var(--space-1) + 1px) var(--space-4);border:1px solid rgba(12,41,124,.18);background:#0c297c0f;color:var(--color-primary-800);text-decoration:none;font-size:var(--text-sm);cursor:pointer}.pill--outline{border-color:#0c297c47;background:transparent;color:var(--color-primary-800)}.pill--action{border:none;background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);box-shadow:var(--shadow-sm)}.gamified-attempt-badge{font-size:var(--text-sm);font-weight:600;background:#0c297c1f;color:var(--color-primary-800);border-radius:var(--radius-pill);padding:.35rem .9rem}.gamified-feedback{margin:0;font-weight:600;color:var(--color-primary-800)}.gamified-feedback.is-error{color:var(--color-error)}.gamified-feedback.is-success{color:var(--color-success-dark)}.gamified-micro-quiz{display:grid;gap:1.2rem}.gamified-micro-question{border-radius:var(--radius-xl);border:2px solid rgba(18,46,132,.14);padding:1.2rem 1.4rem;background:#fffffff2;display:grid;gap:1rem;transition:all var(--transition-base);position:relative;overflow:hidden}.gamified-micro-question:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--cs-blue),var(--cs-blue-light));opacity:0;transition:opacity var(--transition-base)}.gamified-micro-question legend{font-weight:600;color:#122e84e0}.gamified-micro-options{display:grid;gap:.6rem}.gamified-micro-option{display:flex;align-items:center;gap:.75rem;border-radius:var(--radius-md);border:2px solid rgba(18,46,132,.15);background:#fffffff2;padding:.75rem 1rem;transition:all var(--transition-fast);cursor:pointer;position:relative}.gamified-micro-option:hover{border-color:#122e844d;background:#f6f8fff2;transform:translate(2px)}.gamified-micro-option input{transform:scale(1.1);cursor:pointer}.gamified-micro-option span{flex:1;line-height:1.5}.gamified-micro-option--correct{border-color:var(--color-success);background:var(--color-success-light);animation:pulse .5s ease-out}.gamified-micro-option--correct:after{content:"✓";position:absolute;right:1rem;color:var(--color-success-dark);font-weight:700;font-size:1.2em}.gamified-micro-option--incorrect{border-color:var(--color-error);background:var(--color-error-light);animation:wiggle .4s ease-out}.gamified-micro-option--incorrect:after{content:"✗";position:absolute;right:1rem;color:var(--color-error);font-weight:700;font-size:1.2em}.gamified-micro-option--missed{border-color:var(--color-warning);background:var(--color-warning-light)}.gamified-micro-option--missed:after{content:"→";position:absolute;right:1rem;color:var(--color-warning);font-weight:700;font-size:1.2em}.gamified-micro-question.is-correct{border-color:var(--color-success);background:#fffffffa;animation:scaleIn var(--transition-base) ease-out}.gamified-micro-question.is-correct:before{opacity:1;background:linear-gradient(90deg,var(--color-success),var(--color-success-dark))}.gamified-micro-question.is-incorrect{border-color:var(--color-error);background:#fffffffa}.gamified-micro-question.is-incorrect:before{opacity:1;background:linear-gradient(90deg,var(--color-error),#dc2626)}.gamified-feedback.is-success{color:var(--color-success-dark);font-weight:700;display:flex;align-items:center;gap:.5rem}.gamified-feedback.is-success:before{content:"🎉";font-size:1.2em}@media (max-width: 768px){.gamified-card{padding:var(--space-5) var(--space-4);gap:var(--space-4)}.gamified-card header{display:grid;gap:var(--space-2)}.gamified-segment-nav{flex-direction:column;align-items:stretch;gap:var(--space-3)}.gamified-segment-actions{width:100%;flex-wrap:wrap;justify-content:stretch}.gamified-segment-actions .btn,.gamified-segment-nav>.btn,.gamified-segment-actions>button{width:100%}}.activity-matching{display:grid;gap:.8rem}.activity-matching__row{display:grid;gap:.4rem;background:#122e840a;border-radius:16px;border:1px solid rgba(18,46,132,.1);padding:.75rem 1rem}.activity-matching__term{font-weight:600;color:#122e84d9}.activity-matching__row select{border-radius:12px;border:1px solid rgba(18,46,132,.25);padding:.6rem .8rem;font:inherit}.activity-ordering{display:grid;gap:1rem}.activity-ordering__hint{margin:0;font-size:.95rem;color:#122e84bf}.activity-ordering__list{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}.activity-ordering__card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:1rem;padding:1rem 1.2rem;border-radius:var(--radius-xl);border:2px solid rgba(18,46,132,.12);background:linear-gradient(135deg,#fffffffa,#f6f8fff2);box-shadow:var(--shadow-md);cursor:grab;transition:all var(--transition-base);position:relative}.activity-ordering__card:before{content:"⋮⋮";position:absolute;left:.5rem;color:#122e844d;font-weight:700;line-height:.8}.activity-ordering__card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:#122e8440}.activity-ordering__card:active{cursor:grabbing;transform:scale(1.02) rotate(2deg)}.activity-ordering__card.is-correct{border-color:var(--color-success);background:linear-gradient(135deg,var(--color-success-light),rgba(255,255,255,.95));box-shadow:0 18px 30px #10b98140;animation:bounce .6s ease-out}.activity-ordering__card.is-correct:after{content:"✓";position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--color-success-dark);font-size:1.5em;font-weight:700}.activity-ordering__card.is-incorrect{border-color:var(--color-error);background:linear-gradient(135deg,var(--color-error-light),rgba(255,255,255,.95));box-shadow:0 18px 30px #ef444440;animation:wiggle .4s ease-out}.activity-ordering__card.is-drop-target{border-style:dashed;border-color:var(--cs-blue-light);background:#3275ff1f;transform:scale(1.05)}.activity-ordering__index{width:44px;height:44px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--cs-blue-light),var(--cs-blue-lighter));color:#fff;font-weight:700;display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.activity-ordering__card:hover .activity-ordering__index{transform:scale(1.1);box-shadow:var(--shadow-md)}.activity-ordering__text{font-size:1rem;line-height:1.5}.activity-ordering__actions{display:flex;gap:.35rem}.activity-ordering__action{width:32px;height:32px;border-radius:10px;border:1px solid rgba(18,46,132,.18);background:#ffffffe6;font-weight:700;cursor:pointer;transition:background .15s ease,transform .15s ease}.activity-ordering__action:hover:not(:disabled){background:#3275ff1f;transform:translateY(-1px)}.activity-ordering__action:disabled{opacity:.4;cursor:not-allowed}.activity-ordering__dropzone{border:2px dashed rgba(50,117,255,.4);border-radius:16px;padding:.75rem;text-align:center;color:#122e84a6;background:#3275ff0d}.activity-ordering__dropzone.is-drop-target{background:#3275ff1f;border-color:#3275ffa6}.activity-dragdrop{display:grid;gap:1.2rem}.activity-dragdrop__bank,.activity-dragdrop__targets{display:flex;flex-wrap:wrap;gap:.75rem}.activity-dragdrop__token{padding:.55rem .85rem;border-radius:12px;background:#fffffff2;border:1px solid rgba(18,46,132,.18);cursor:pointer;transition:transform .1s ease,box-shadow .1s ease}.activity-dragdrop__token.is-picked{opacity:.45}.activity-dragdrop__target{min-width:160px;min-height:60px;border-radius:14px;border:2px dashed rgba(18,46,132,.3);display:flex;align-items:center;justify-content:center;padding:.6rem;background:#122e840a;text-align:center}.activity-dragdrop__target.is-filled{border-style:solid;border-color:#18a46d99;background:#18a46d1f}.activity-dragdrop__target.is-incorrect{border-color:#c32d3f99;background:#c32d3f1f}.activity-gapfill{display:grid;gap:1rem}.activity-gapfill--tokens{gap:1.4rem}.activity-gapfill__text{font-size:1rem;line-height:1.6}.activity-gapfill__bank{display:flex;flex-wrap:wrap;gap:.6rem}.activity-gapfill__token{padding:.5rem .85rem;border-radius:12px;border:1px solid rgba(18,46,132,.18);background:#fffffff2;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease,background .1s ease}.activity-gapfill__token.is-assigned{opacity:.45;cursor:not-allowed}.activity-gapfill__token.is-selected{border-color:#3275ff99;background:#3275ff1f;box-shadow:0 10px 18px #3275ff2e}.activity-gapfill__blank{display:inline-flex;align-items:center;gap:.4rem;background:#122e840d;border-radius:12px;border:1px dashed rgba(18,46,132,.3);padding:.2rem .5rem;margin:0 .25rem}.activity-gapfill__blank select{border:none;background:transparent;font:inherit}.activity-gapfill__blank--drop{padding:0;border-style:dashed}.activity-gapfill__drop{min-width:120px;padding:.3rem .6rem;border-radius:10px;border:none;background:transparent;font:inherit;cursor:pointer;color:#122e84d9}.activity-gapfill__drop:hover:not(:disabled){background:#3275ff1f}.activity-gapfill__drop:disabled{cursor:not-allowed}.activity-gapfill__blank.is-correct{background:#18a46d2e;border-color:#18a46d99}.activity-gapfill__blank.is-incorrect{background:#c32d3f2e;border-color:#c32d3f99}.activity-planner{display:grid;gap:1.2rem}.activity-planner__panel{display:grid;gap:.5rem}.activity-planner__panel textarea{border-radius:14px;border:1px solid rgba(18,46,132,.22);padding:.75rem 1rem;font:inherit;resize:vertical;min-height:120px}.activity-hotspot{position:relative;border-radius:20px;overflow:hidden;border:1px solid rgba(18,46,132,.12)}.activity-hotspot img{display:block;width:100%;height:auto}.activity-hotspot__point{position:absolute;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;background:#3275ffe6;color:#fff;font-weight:700;cursor:pointer;transition:transform .1s ease}.activity-hotspot__point.is-selected{background:#18a46deb}.activity-hotspot__point.is-incorrect{background:#c32d3feb}.activity-classification{display:grid;gap:1.4rem}.activity-classification__bank{display:flex;flex-wrap:wrap;gap:.65rem}.activity-classification__token{padding:.65rem 1rem;border-radius:var(--radius-md);border:2px solid rgba(18,46,132,.18);background:linear-gradient(135deg,#fffffffa,#f6f8fff2);cursor:pointer;transition:all var(--transition-fast);font-weight:600;position:relative;overflow:hidden}.activity-classification__token:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--cs-blue-light),var(--cs-blue-lighter));opacity:0;transition:opacity var(--transition-fast)}.activity-classification__token:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#122e844d}.activity-classification__token.is-selected{border-color:var(--cs-blue-light);background:linear-gradient(135deg,var(--cs-blue-light),var(--cs-blue-lighter));color:#fff;box-shadow:0 12px 24px #3275ff40;transform:scale(1.05)}.activity-classification__bank-empty{font-size:.9rem;color:#122e8499;font-style:italic}.activity-classification__categories{display:grid;gap:1rem}.activity-classification__category{border-radius:18px;border:1px solid rgba(18,46,132,.14);background:#fffffff2;padding:.9rem 1.1rem;box-shadow:0 16px 28px #122e8414}.activity-classification__category header h4{margin:0 0 .3rem}.activity-classification__slots{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.75rem;min-height:48px}.activity-classification__chip{border-radius:12px;border:1px solid rgba(18,46,132,.18);background:#3275ff14;padding:.45rem .8rem;font:inherit;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease,background .1s ease}.activity-classification__chip.is-correct{border-color:#18a46d99;background:#18a46d26}.activity-classification__chip.is-incorrect{border-color:#c32d3f99;background:#c32d3f26}.activity-classification__placeholder{font-size:.9rem;color:#122e848c;background:#122e840f;border:1px dashed rgba(18,46,132,.2);border-radius:12px;padding:.45rem .75rem}.activity-code{display:grid;gap:1.2rem}.activity-code__prompt{margin:0;font-size:.95rem;color:#122e84c7}.activity-code__block{margin:0;padding:1rem;border-radius:18px;background:#0a1030eb;color:#ffffffeb;overflow-x:auto;font-size:.95rem;line-height:1.6}.activity-code__block code{font-family:Fira Code,Courier New,monospace}.activity-code__blank{display:inline-flex;align-items:center;margin:0 .25rem;padding:.15rem .35rem;border-radius:8px;background:#ffffff2e}.activity-code__blank input{background:transparent;border:none;border-bottom:2px solid rgba(255,255,255,.55);color:inherit;font:inherit;padding:0 .25rem;min-width:80px}.activity-code__blank.is-correct{background:#18a46d3d}.activity-code__blank.is-incorrect{background:#c32d3f3d}.activity-code__hints{margin:0;padding-left:1rem;display:grid;gap:.3rem;color:#122e84c7;font-size:.9rem}.activity-spot{display:grid;gap:.8rem}.activity-spot__item{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:start;padding:.85rem 1rem;border-radius:18px;border:1px solid rgba(18,46,132,.16);background:#fffffff2;text-align:left;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.activity-spot__item:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 18px 28px #122e841f}.activity-spot__item.is-selected{border-color:#3275ff99;background:#3275ff1f}.activity-spot__item.is-correct{border-color:#18a46d99;background:#18a46d2e}.activity-spot__item.is-incorrect{border-color:#c32d3f99;background:#c32d3f2e}.activity-spot__badge{width:36px;height:36px;border-radius:50%;background:#122e8414;display:grid;place-items:center;font-weight:700;color:#122e84d9}.activity-spot__text{font-size:.98rem;line-height:1.5}.activity-spot__explanation{grid-column:1 / -1;margin-top:.45rem;font-size:.9rem;color:#122e84bf}.activity-diagram{display:grid;gap:1.4rem}.activity-diagram__bank{display:flex;flex-wrap:wrap;gap:.6rem}.activity-diagram__token{padding:.55rem .9rem;border-radius:12px;border:1px solid rgba(18,46,132,.18);background:#fffffff2;cursor:pointer;transition:background .1s ease,box-shadow .1s ease,transform .1s ease}.activity-diagram__token.is-selected{border-color:#3275ff99;background:#3275ff1f;box-shadow:0 14px 26px #3275ff2e}.activity-diagram__placeholder{font-size:.9rem;color:#122e84a6;font-style:italic}.activity-diagram__canvas{position:relative;border-radius:20px;overflow:hidden;border:1px solid rgba(18,46,132,.12);box-shadow:0 20px 36px #122e841a}.activity-diagram__canvas img{display:block;width:100%;height:auto}.activity-diagram__target{position:absolute;transform:translate(-50%,-50%);min-width:120px;border-radius:14px;border:2px dashed rgba(18,46,132,.25);background:#ffffffeb;padding:.55rem .8rem;font-size:.9rem;color:#122e84d9;cursor:pointer;transition:border-color .15s ease,background .15s ease}.activity-diagram__target.is-correct{border-color:#18a46da6;background:#18a46d26}.activity-diagram__target.is-incorrect{border-color:#c32d3fa6;background:#c32d3f2e}.gamified-card--python{background:#121826;color:#f5f8ff;border:1px solid rgba(99,181,255,.25);box-shadow:0 26px 48px #0c60cc40}.gamified-card--python header h3{color:#fff}.gamified-card--python .gamified-feedback{color:#fff}.python-playground{display:grid;gap:1.2rem}@media (min-width: 960px){.python-playground{grid-template-columns:minmax(0,1fr) minmax(0,.9fr);align-items:start}}.python-playground__editor{display:grid;gap:.8rem}.python-playground__label{font-weight:600;color:#ffffffb3}.python-playground__textarea{font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.95rem;background:#0d1323;color:#f5f8ff;border-radius:16px;border:1px solid rgba(99,181,255,.3);padding:1rem;min-height:260px;line-height:1.6;resize:vertical;box-shadow:inset 0 0 0 1px #ffffff05}.python-playground__textarea:focus{outline:2px solid rgba(99,181,255,.6);outline-offset:2px}.python-playground__actions{display:flex;gap:.8rem}.python-playground__examples{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;font-size:.85rem}.python-playground__console{background:#0a0f1c;border-radius:18px;border:1px solid rgba(99,181,255,.3);min-height:220px;display:grid;grid-template-rows:auto 1fr;overflow:hidden}.python-playground__console header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;font-weight:600;color:#ffffffbf}.python-playground__console pre{margin:0;padding:1rem;font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.92rem;line-height:1.6;white-space:pre-wrap;overflow:auto}.console-status{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;padding:.2rem .6rem;border-radius:999px}.console-status.is-success{background:#18a46d33;color:#a6ffdaf2}.console-status.is-error{background:#c32d3f40;color:#ffa1b1f2}.python-playground__fill{background:#0a0f1cbf;border-radius:18px;border:1px solid rgba(99,181,255,.25);padding:1.4rem;display:grid;gap:1rem}.python-playground__fill h4{margin:0;color:#ffffffd9}.python-playground__snippet{display:block;font-family:JetBrains Mono,Fira Code,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:#0c1224f2;border-radius:14px;border:1px solid rgba(99,181,255,.18);padding:.85rem 1rem;line-height:1.6;color:#f5f8ff;margin-bottom:.8rem}.python-playground__blank{display:inline-flex;align-items:center;background:#63b5ff1f;border-radius:12px;border:1px dashed rgba(99,181,255,.3);margin:0 .3rem;padding:.15rem .4rem}.python-playground__blank select{background:transparent;border:none;color:inherit;font:inherit;padding:0 .2rem}.python-playground__blank.is-correct{border-color:#18a46d99;background:#18a46d2e}.python-playground__blank.is-incorrect{border-color:#c32d3f99;background:#c32d3f2e}.results-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:50}.results-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0d12288c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.results-modal__card{position:relative;z-index:1;width:min(420px,calc(100vw - 2.5rem));border-radius:24px;padding:2rem;display:grid;gap:1.5rem;text-align:center;color:#fff;animation:pop-in .3s ease forwards}.results-modal.is-success .results-modal__card{background:linear-gradient(135deg,#1ea37a,#54d68d);box-shadow:0 35px 60px #1ea37a59}.results-modal.is-error .results-modal__card{background:linear-gradient(135deg,#d64565,#f6767f);box-shadow:0 35px 60px #d6456559}.results-modal__card header h3{margin:0;font-size:1.8rem}.results-modal__card header p{margin:.4rem 0 0;font-size:1rem}.results-modal__stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.results-modal__stats span{display:block;font-size:.85rem;opacity:.85}.results-modal__stats strong{display:block;font-size:1.6rem;font-weight:700}.results-modal__actions{display:flex;justify-content:center;gap:1rem}@keyframes pop-in{0%{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.live-assessment-dashboard{background-color:var(--cs-grey-light);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-md);color:var(--cs-dark)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--cs-grey-mid)}.dashboard-header h3{margin:0;font-size:1.5rem;color:var(--cs-blue)}.summary{display:flex;align-items:center;gap:var(--space-sm)}.summary progress{width:150px;height:10px;accent-color:var(--cs-green)}.dashboard-controls{display:flex;gap:var(--space-md);margin-bottom:var(--space-lg)}.control-button{padding:var(--space-sm) var(--space-md);border:1px solid var(--cs-blue);background-color:transparent;color:var(--cs-blue);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.control-button:hover{background-color:var(--cs-blue-light);color:var(--cs-light)}.control-button.primary{background-color:var(--cs-blue);color:var(--cs-light)}.control-button.primary:hover{background-color:var(--cs-purple)}.control-button[disabled]{opacity:.6;cursor:not-allowed;background-color:var(--cs-grey-mid-light);border-color:var(--cs-grey-mid);color:var(--cs-grey-dark)}.student-grid-container{overflow-x:auto}.student-progress-table{width:100%;border-collapse:collapse}.student-progress-table th,.student-progress-table td{padding:var(--space-md);text-align:left;border-bottom:1px solid var(--cs-grey-mid)}.student-progress-table th{background-color:var(--cs-grey-mid-light);font-weight:700}.student-progress-table tbody tr:last-child td{border-bottom:none}.status-indicator{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:var(--space-sm)}.status-not-started .status-indicator{background-color:var(--cs-grey-dark)}.status-in-progress .status-indicator{background-color:var(--cs-orange);animation:pulse 1.5s infinite}.status-completed .status-indicator{background-color:var(--cs-green)}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.dashboard-subtitle{margin:0;color:var(--cs-grey-dark);font-size:.95rem}.dashboard-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.meta-pill{display:inline-flex;align-items:center;gap:var(--space-xs);padding:calc(var(--space-xs) + 2px) var(--space-sm);border-radius:999px;font-size:.9rem;background:var(--cs-grey-mid-light);color:var(--cs-dark)}.meta-pill--complete{background:#38b00026;color:var(--cs-green)}.meta-pill--progress{background:#ff8c0026;color:var(--cs-orange, #ff8c00)}.meta-pill--idle{background:#78787826;color:var(--cs-grey-dark)}.dashboard-alerts{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.alert-note{color:var(--cs-blue);font-weight:500}.alert-error{color:var(--cs-red, #d32f2f);font-weight:500}.table-empty{text-align:center;padding:var(--space-lg);color:var(--cs-grey-dark);font-style:italic}.gamified-page{display:grid;grid-template-rows:auto 1fr;grid-template-columns:320px 1fr;min-height:100vh;background:var(--cs-background);transition:grid-template-columns .4s cubic-bezier(.25,.46,.45,.94)}.gamified-page.sidebar-collapsed{grid-template-columns:56px 1fr}.gamified-header{grid-column:1 / -1;background:var(--cs-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:1.5rem 2rem;transition:all .4s cubic-bezier(.25,.46,.45,.94);overflow:hidden}.gamified-header.is-collapsed{padding-top:1rem;padding-bottom:1rem;max-height:80px}.gamified-header__main{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,5vw,3.5rem);justify-content:space-between;align-items:flex-start;gap:1rem;transition:all .4s ease}.header-collapsed .gamified-header__main{align-items:center}.gamified-header__main>div:first-child h1{font-size:2.25rem;margin-top:.25rem;margin-bottom:.5rem;transition:all .4s ease}.header-collapsed .gamified-header__main h1{font-size:1.5rem;margin-bottom:0}.gamified-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;color:#122e84bf}.gamified-header h1{margin:.35rem 0 .5rem;font-size:clamp(2.1rem,4vw,2.8rem);font-weight:700}.gamified-meta{display:flex;gap:.75rem;flex-wrap:wrap;font-weight:600;color:#122e84bf}.gamified-header__stats{display:grid;gap:var(--space-4);min-width:min(320px,100%);align-content:start}.header-collapsed .gamified-header__stats .stat-card{padding:var(--space-4)}.header-collapsed .gamified-header__stats .stat-card__value{font-size:clamp(1.5rem,2.5vw,1.85rem)}.gamified-main{grid-column:1 / -1;display:grid;grid-template-columns:minmax(240px,280px) minmax(0,1fr);gap:clamp(1.5rem,3vw,2.5rem);align-items:start;transition:grid-template-columns var(--transition-base)}.gamified-page.sidebar-collapsed .gamified-main{grid-template-columns:0 minmax(0,1fr);gap:0}.gamified-stages{grid-column:1 / 2;background:var(--cs-gradient-sidebar);padding:1.5rem;overflow-y:auto;transition:all .4s ease;overflow-x:hidden}.sidebar-collapsed .gamified-stages{padding-left:0;padding-right:0}.sidebar-collapsed .gamified-stages ul{opacity:0;transform:translate(-20px);pointer-events:none}.gamified-sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);cursor:pointer;margin:0 auto 1.5rem;transition:background .2s}.sidebar-collapsed .gamified-sidebar-toggle{margin-left:12px}.gamified-sidebar-toggle:hover{background:#fff3}.gamified-stages ul{list-style:none;padding:0;margin:0;transition:opacity .3s ease,transform .3s ease}.gamified-stage-link{width:100%;text-align:left;border-radius:var(--radius-xl);border:2px solid rgba(18,46,132,.13);background:linear-gradient(135deg,#fffffffa,#f6f8fff2);padding:1.1rem 1.4rem;display:grid;gap:.5rem;box-shadow:var(--shadow-md);transition:all var(--transition-base);position:relative;overflow:hidden}.gamified-stage-link:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--cs-blue),var(--cs-blue-light));transform:scaleY(0);transition:transform var(--transition-base)}.gamified-stage-link:hover:not(:disabled){transform:translate(4px);box-shadow:var(--shadow-lg);border-color:#122e8440}.gamified-stage-link:hover:not(:disabled):before{transform:scaleY(1)}.gamified-stage-link.is-active{border-color:var(--cs-blue);background:linear-gradient(135deg,#0c297c14,#3fb5ff1f);box-shadow:var(--shadow-xl),0 0 20px #0c297c26;transform:translate(4px)}.gamified-stage-link.is-active:before{transform:scaleY(1)}.gamified-stage-link.is-complete{border-color:var(--color-success);background:linear-gradient(135deg,rgba(255,255,255,.98),var(--color-success-light))}.gamified-stage-link.is-complete:after{content:"✓ Completed";justify-self:flex-start;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-success-dark);padding:.2rem .6rem;background:var(--color-success-light);border-radius:var(--radius-full)}.gamified-stage-link.is-pointer{border-color:#0c297c99;box-shadow:var(--shadow-lg),0 0 0 2px #0c297c2e}.gamified-stage-link.is-locked{opacity:.5;pointer-events:none;filter:grayscale(.5)}.gamified-stage-link.is-locked:after{content:"🔒";position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:1.2em;opacity:.5}.gamified-stage-title{font-weight:600}.gamified-stage-duration{font-size:.85rem;color:#122e84a6}.gamified-stage-viewer{display:grid;gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(.5rem,2vw,2rem);transition:max-width var(--transition-base)}.gamified-page.sidebar-collapsed .gamified-stage-viewer{max-width:1400px}.gamified-stage{display:grid;gap:1.3rem}.gamified-stage-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.gamified-stage-header__actions{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;justify-content:flex-end}.gamified-stage-eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;color:#122e84b3}.gamified-stage-progress{background:#122e841f;border-radius:999px;padding:.35rem .9rem;font-weight:600;color:#122e84bf}.gamified-stage__panel{background:#fffffffa;border-radius:24px;border:1px solid rgba(18,46,132,.12);box-shadow:0 24px 60px #122e8424;padding:clamp(1.75rem,4vw,2.4rem);animation-duration:.45s;animation-fill-mode:both;animation-timing-function:cubic-bezier(.33,1,.68,1)}.gamified-stage__panel--forward{animation-name:gamified-stage-slide-in-right}.gamified-stage__panel--back{animation-name:gamified-stage-slide-in-left}.gamified-stage-complete{border-radius:24px;padding:clamp(1.75rem,4vw,2.4rem);background:#fffffff0;border:1px solid rgba(18,46,132,.16);box-shadow:0 20px 40px #122e841f}@keyframes gamified-stage-slide-in-right{0%{opacity:0;transform:translate(36px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes gamified-stage-slide-in-left{0%{opacity:0;transform:translate(-36px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}.gamified-assessment{margin-top:clamp(1.5rem,4vw,3rem)}.gamified-assessment__card{gap:1.5rem}.gamified-assessment__header{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.gamified-assessment__lock{margin:0;font-weight:600;color:#122e84cc}.gamified-assessment__body{display:grid;gap:1.5rem}.gamified-assessment__questions{list-style:decimal;padding-left:1.5rem;display:grid;gap:1.2rem;margin:0}.gamified-assessment__prompt{display:flex;justify-content:space-between;gap:1rem;font-weight:600}.gamified-assessment__prompt span{white-space:nowrap;color:#122e84bf}.gamified-assessment__body textarea{border-radius:14px;border:1px solid rgba(18,46,132,.2);padding:.85rem 1rem;font:inherit;resize:vertical;min-height:120px}.gamified-assessment__actions{display:flex;justify-content:flex-end}.gamified-assessment__teacher{border-radius:18px;border:1px solid rgba(18,46,132,.12);background:#122e840d;padding:1.1rem 1.3rem;display:grid;gap:1rem}.gamified-assessment__teacher--panel{background:#122e8408}.gamified-assessment__teacher-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}.gamified-assessment__teacher-grid{display:grid;gap:1.1rem}.gamified-assessment__teacher-item{border-radius:16px;border:1px solid rgba(18,46,132,.12);background:#ffffffe6;padding:.9rem 1.1rem;display:grid;gap:.6rem}.gamified-assessment__teacher-meta{display:flex;justify-content:space-between;gap:1rem;font-weight:600}.gamified-assessment__teacher-item input,.gamified-assessment__teacher-item textarea{border-radius:12px;border:1px solid rgba(18,46,132,.2);padding:.65rem .85rem;font:inherit}.gamified-assessment__teacher--hint{background:#122e8414}.level-up-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn var(--transition-base) ease-out}.level-up-modal{background:linear-gradient(135deg,#fffffffa,#fbbf241a);border-radius:var(--radius-2xl);padding:3rem 2.5rem;max-width:500px;width:90%;box-shadow:var(--shadow-2xl),0 0 60px #fbbf2466;position:relative;overflow:hidden;animation:scaleIn var(--transition-slow) cubic-bezier(.34,1.56,.64,1);border:3px solid rgba(251,191,36,.5)}.level-up-modal__confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;background:var(--color-xp-gold);top:-10px;left:50%;animation:confettiFall 3s ease-out forwards;animation-delay:var(--delay);opacity:0}.confetti-piece:nth-child(odd){background:var(--cs-blue-light)}.confetti-piece:nth-child(3n){background:var(--color-success)}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0) translate(0)}to{opacity:0;transform:translateY(600px) rotate(720deg) translate(var(--offset, 0px))}}.level-up-modal__content{position:relative;z-index:1;text-align:center;display:grid;gap:1.5rem}.level-up-modal__icon{font-size:5rem;animation:bounce 1s ease-out infinite;filter:drop-shadow(0 4px 8px rgba(251,191,36,.4))}.level-up-modal__title{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--cs-blue),var(--color-xp-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;animation:fadeInUp .6s ease-out}.level-up-modal__levels{display:flex;align-items:center;justify-content:center;gap:1.5rem;font-size:2rem;font-weight:700;animation:fadeInUp .8s ease-out}.level-up-modal__old-level{color:#122e8499;text-decoration:line-through}.level-up-modal__arrow{color:var(--color-xp-gold);font-size:2.5rem;animation:pulse 1s ease-out infinite}.level-up-modal__new-level{background:linear-gradient(135deg,var(--color-xp-gold),var(--cs-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:2.5rem;animation:scaleIn .6s cubic-bezier(.34,1.56,.64,1)}.level-up-modal__message{font-size:1.2rem;color:#122e84cc;margin:0;animation:fadeInUp 1s ease-out}.level-up-modal__xp{display:grid;gap:.5rem;padding:1.5rem;background:#fff9;border-radius:var(--radius-xl);border:2px solid rgba(251,191,36,.3);animation:fadeInUp 1.2s ease-out}.level-up-modal__xp strong{font-size:2rem;background:linear-gradient(135deg,var(--cs-blue),var(--color-xp-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:800}.level-up-modal__xp span{font-size:.9rem;color:#122e84b3;text-transform:uppercase;letter-spacing:.1em}.level-up-modal__button{background:linear-gradient(135deg,var(--cs-blue),var(--cs-blue-light));color:#fff;border:none;border-radius:var(--radius-xl);padding:1rem 2rem;font-size:1.1rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-lg);transition:all var(--transition-base);animation:fadeInUp 1.4s ease-out}.level-up-modal__button:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl);background:linear-gradient(135deg,var(--cs-blue-light),var(--cs-blue-lighter))}.level-up-modal__button:active{transform:translateY(0)}@media (max-width: 1024px){.gamified-main{grid-template-columns:1fr}.gamified-stages{position:static}.gamified-page.sidebar-collapsed .gamified-main{grid-template-columns:1fr}.gamified-sidebar-toggle{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:1000;border-radius:0 var(--radius-md) var(--radius-md) 0}.gamified-page.sidebar-collapsed .gamified-sidebar-toggle{left:0}}.gamified-page.presentation-mode .gamified-header,.gamified-page.presentation-mode .gamified-stages{display:none}.gamified-page.presentation-mode .gamified-main{grid-template-columns:1fr;padding:0;margin:0;max-width:100vw;height:100vh;overflow:auto}.gamified-page.presentation-mode .gamified-stage-viewer{padding:2rem;max-width:100%}.gamified-page.presentation-mode .gamified-stage{font-size:1.2rem}.gamified-page.presentation-mode .gamified-stage-header h2{font-size:3rem}.presentation-exit-button{position:fixed;top:1.5rem;right:1.5rem;z-index:1200;background:#0f172aeb;color:#fff;border:none;border-radius:999px;padding:.6rem 1.2rem;font-weight:600;font-size:.95rem;letter-spacing:.03em;box-shadow:0 14px 32px #0f172a38;cursor:pointer;transition:background var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base)}.presentation-exit-button:hover,.presentation-exit-button:focus-visible{background:#2563ebeb;box-shadow:0 18px 40px #2563eb47;transform:translateY(-1px)}.teacher-controls{align-self:center}.gamified-stage-item{position:relative;display:flex;align-items:center}.set-pace-btn{background:var(--cs-primary-accent);color:#fff;border:none;padding:.25rem .5rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;margin-left:.5rem;opacity:0;transition:opacity .2s}.gamified-stage-item:hover .set-pace-btn{opacity:1}.set-pace-btn:hover{background:var(--cs-primary-accent-dark)}.set-pace-btn--setting{background-color:var(--cs-gray-light);cursor:wait}.set-pace-btn--set{background-color:var(--cs-success)}.set-pace-btn--error{background-color:var(--cs-error)}.b1-page{display:flex;flex-direction:column;gap:2rem;padding:clamp(1.5rem,4vw,3rem);color:var(--cs-black)}.b1-hero{background:linear-gradient(135deg,#0c297c1a,#b2854114);border-radius:24px;padding:clamp(1.75rem,5vw,3rem);display:flex;flex-wrap:wrap;gap:clamp(1.5rem,4vw,3rem);justify-content:space-between;align-items:flex-start}.b1-hero__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;color:#0c297cbf}.b1-hero h1{margin:.4rem 0 .5rem;font-size:clamp(2rem,4vw,2.6rem);font-weight:700}.b1-hero__meta{display:flex;gap:.75rem;flex-wrap:wrap;font-weight:600;color:#0c297cbf}.b1-progress-summary{display:grid;gap:.35rem;background:#ffffffd9;border-radius:20px;padding:1rem 1.4rem;border:1px solid rgba(12,41,124,.12);min-width:220px}.b1-progress-summary__label{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#0c297cb3}.b1-progress-summary strong{font-size:1.8rem}.b1-progress-summary__bar{width:100%;height:8px;border-radius:999px;background:#0c297c1a;overflow:hidden}.b1-progress-summary__bar>div{height:100%;background:linear-gradient(135deg,var(--cs-blue),rgba(12,41,124,.75));border-radius:inherit}.b1-main{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:clamp(1.5rem,3vw,3rem);align-items:start}.b1-stages{position:sticky;top:1.5rem;align-self:start}.b1-stages ul{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}.b1-stage-link{width:100%;text-align:left;border-radius:18px;border:1px solid rgba(12,41,124,.12);background:#ffffffeb;padding:.9rem 1.2rem;display:grid;gap:.35rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.b1-stage-link.is-active{border-color:#0c297c59;box-shadow:0 16px 24px #0c297c26;transform:translateY(-2px)}.b1-stage-link.is-complete:after{content:"Completed";justify-self:flex-start;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#0c297cb3}.b1-stage-link.is-locked{opacity:.5;pointer-events:none}.b1-stage-link__title{font-weight:600}.b1-stage-link__duration{font-size:.85rem;color:#0c297c99}.b1-stage-viewer{display:grid;gap:1.5rem}.b1-stage__header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center}.b1-stage__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:#0c297ca6}.b1-stage__progress{background:#0c297c1a;border-radius:999px;padding:.35rem .85rem;font-weight:600;font-size:.85rem}.b1-card{background:#fffffff7;border-radius:22px;border:1px solid rgba(12,41,124,.1);box-shadow:0 18px 28px #0c297c1f;padding:clamp(1.4rem,3.5vw,2rem);display:grid;gap:1rem}.b1-card header h3{margin:0;font-size:1.35rem}.b1-card.is-success{border-color:#19875459;box-shadow:0 18px 34px #19875433}.b1-card.is-error{border-color:#b22c4673;box-shadow:0 18px 34px #b22c4626}.b1-card__body{display:grid;gap:.75rem}.b1-card__body--list .b1-list-item{background:#0c297c0d;border-radius:16px;padding:1rem 1.2rem}.b1-list-item h4{margin:0 0 .35rem;font-size:1.05rem}.b1-vocab__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:.8rem}.b1-vocab__item{border-radius:16px;border:1px solid rgba(12,41,124,.12);background:#fffffff2;padding:.8rem 1rem;display:grid;gap:.4rem}.b1-vocab__term{font-weight:600;color:var(--cs-blue)}.b1-table-wrapper{overflow-x:auto}.b1-table-wrapper table{width:100%;border-collapse:collapse}.b1-table-wrapper th,.b1-table-wrapper td{border:1px solid rgba(12,41,124,.12);padding:.65rem .75rem;text-align:left;vertical-align:top}.b1-accordion details{border:1px solid rgba(12,41,124,.12);border-radius:16px;padding:.75rem 1rem;background:#0c297c0a}.b1-accordion details+details{margin-top:.75rem}.b1-accordion summary{font-weight:600;cursor:pointer}.b1-segment-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.b1-segment-nav__actions{display:inline-flex;align-items:center;gap:.6rem}.b1-matching label,.b1-fill label{display:grid;gap:.4rem;margin-bottom:.85rem}.b1-matching select,.b1-fill input,.b1-ordering select,.b1-planner textarea,.b1-checkpoint input[type=text],.b1-assessment textarea{border:1px solid rgba(12,41,124,.2);border-radius:12px;padding:.6rem .75rem;font:inherit}.b1-ordering{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}.b1-ordering li{display:grid;gap:.4rem;background:#0c297c0a;padding:.75rem 1rem;border-radius:16px}.b1-feedback{margin:0;font-weight:600;color:#0c297ccc}.b1-attempt-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;background:#0c297c1f;color:var(--cs-blue);border-radius:999px;padding:.25rem .75rem;font-weight:600}.b1-attempt-badge__detail{font-weight:500;color:#0c297cbf}.b1-planner label{display:grid;gap:.4rem}.b1-checkpoint__item{display:grid;gap:.6rem;border:1px solid rgba(12,41,124,.12);border-radius:16px;padding:.75rem 1rem;background:#0c297c08}.b1-checkpoint__item.is-correct{border-color:#19875459;background:#1987541f}.b1-checkpoint__item.is-incorrect{border-color:#b22c4666;background:#b22c461f}.b1-checkpoint__options{display:grid;gap:.5rem}.b1-checkpoint__options label{display:inline-flex;gap:.5rem;align-items:center}.b1-rationale{margin:0;font-size:.85rem;color:#0c297cbf}.b1-assessment{background:#0c297c0a;border-radius:24px;padding:clamp(1.5rem,4vw,2.5rem);display:grid;gap:1rem}.b1-assessment header{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}.b1-assessment__lock{margin:0;font-weight:600;color:#0c297cbf}.b1-assessment__questions{list-style:decimal;margin:1rem 0;padding-left:1.2rem;display:grid;gap:1.2rem}.b1-assessment__prompt{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;font-weight:600}.b1-assessment__actions{display:flex;justify-content:flex-end}.b1-assessment__teacher{background:#0c297c14;border-radius:16px;padding:1rem 1.2rem;font-size:.9rem}.b1-assessment__teacher--panel{display:grid;gap:1rem}.b1-assessment__teacher-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}.b1-assessment__teacher-grid{display:grid;gap:1.2rem}.b1-assessment__teacher-item{border:1px solid rgba(12,41,124,.12);border-radius:16px;padding:.9rem 1rem;display:grid;gap:.6rem;background:#fffc}.b1-assessment__teacher-meta{display:flex;justify-content:space-between;gap:1rem;font-weight:600}.b1-assessment__teacher-item input,.b1-assessment__teacher-item textarea{border:1px solid rgba(12,41,124,.2);border-radius:12px;padding:.6rem .75rem;font:inherit}@media (max-width: 960px){.b1-main{grid-template-columns:1fr}.b1-stages{position:static}.b1-stage-link.is-complete:after{justify-self:end}}@media print{.b1-page{padding:1rem}.b1-stages,.b1-assessment header button,.btn{display:none!important}.b1-assessment__body textarea{min-height:120px}}.b2-page{display:flex;flex-direction:column;gap:2rem;padding:clamp(1.5rem,4vw,3rem);color:var(--cs-black)}.b2-hero{background:linear-gradient(135deg,#0c297c1a,#b2854114);border-radius:24px;padding:clamp(1.75rem,5vw,3rem);display:flex;flex-wrap:wrap;gap:clamp(1.5rem,4vw,3rem);justify-content:space-between;align-items:flex-start}.b2-hero__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;color:#0c297cbf}.b2-hero h1{margin:.4rem 0 .5rem;font-size:clamp(2rem,4vw,2.6rem);font-weight:700}.b2-hero__meta{display:flex;gap:.75rem;flex-wrap:wrap;font-weight:600;color:#0c297cbf}.b2-progress-summary{display:grid;gap:.35rem;background:#ffffffd9;border-radius:20px;padding:1rem 1.4rem;border:1px solid rgba(12,41,124,.12);min-width:220px}.b2-progress-summary__label{text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:#0c297cb3}.b2-progress-summary strong{font-size:1.8rem}.b2-progress-summary__bar{width:100%;height:8px;border-radius:999px;background:#0c297c1a;overflow:hidden}.b2-progress-summary__bar>div{height:100%;background:linear-gradient(135deg,var(--cs-blue),rgba(12,41,124,.75));border-radius:inherit}.b2-main{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:clamp(1.5rem,3vw,3rem);align-items:start}.b2-stages{position:sticky;top:1.5rem;align-self:start}.b2-stages ul{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}.b2-stage-link{width:100%;text-align:left;border-radius:18px;border:1px solid rgba(12,41,124,.12);background:#ffffffeb;padding:.9rem 1.2rem;display:grid;gap:.35rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.b2-stage-link.is-active{border-color:#0c297c59;box-shadow:0 16px 24px #0c297c26;transform:translateY(-2px)}.b2-stage-link.is-complete:after{content:"Completed";justify-self:flex-start;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:#0c297cb3}.b2-stage-link.is-locked{opacity:.5;pointer-events:none}.b2-stage-link__title{font-weight:600}.b2-stage-link__duration{font-size:.85rem;color:#0c297c99}.b2-stage-viewer{display:grid;gap:1.5rem}.b2-stage__header{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center}.b2-stage__eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;color:#0c297ca6}.b2-stage__progress{background:#0c297c1a;border-radius:999px;padding:.35rem .85rem;font-weight:600;font-size:.85rem}.b2-card{background:#fffffff7;border-radius:22px;border:1px solid rgba(12,41,124,.1);box-shadow:0 18px 28px #0c297c1f;padding:clamp(1.4rem,3.5vw,2rem);display:grid;gap:1rem}.b2-card header h3{margin:0;font-size:1.35rem}.b2-card.is-success{border-color:#19875459;box-shadow:0 18px 34px #19875433}.b2-card.is-error{border-color:#b22c4673;box-shadow:0 18px 34px #b22c4626}.b2-card__body{display:grid;gap:.75rem}.b2-card__body--list .b2-list-item{background:#0c297c0d;border-radius:16px;padding:1rem 1.2rem}.b2-list-item h4{margin:0 0 .35rem;font-size:1.05rem}.b2-vocab__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:.8rem}.b2-vocab__item{border-radius:16px;border:1px solid rgba(12,41,124,.12);background:#fffffff2;padding:.8rem 1rem;display:grid;gap:.4rem}.b2-vocab__term{font-weight:600;color:var(--cs-blue)}.b2-table-wrapper{overflow-x:auto}.b2-table-wrapper table{width:100%;border-collapse:collapse}.b2-table-wrapper th,.b2-table-wrapper td{border:1px solid rgba(12,41,124,.12);padding:.65rem .75rem;text-align:left;vertical-align:top}.b2-accordion details{border:1px solid rgba(12,41,124,.12);border-radius:16px;padding:.75rem 1rem;background:#0c297c0a}.b2-accordion details+details{margin-top:.75rem}.b2-accordion summary{font-weight:600;cursor:pointer}.b2-segment-nav{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.b2-segment-nav__actions{display:inline-flex;align-items:center;gap:.6rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.25rem;border-radius:999px;border:none;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn--primary{background:linear-gradient(135deg,var(--cs-blue),rgba(12,41,124,.85));color:#fff}.btn--outline{background:transparent;border:1px solid rgba(12,41,124,.35);color:var(--cs-blue)}.btn--ghost{background:#0c297c14;color:var(--cs-blue)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 20px #0c297c2e}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.b2-matching label,.b2-fill label{display:grid;gap:.4rem;margin-bottom:.85rem}.b2-matching select,.b2-fill input,.b2-ordering select,.b2-planner textarea,.b2-checkpoint input[type=text],.b2-assessment textarea{border:1px solid rgba(12,41,124,.2);border-radius:12px;padding:.6rem .75rem;font:inherit}.b2-ordering{list-style:none;padding:0;margin:0;display:grid;gap:.8rem}.b2-ordering li{display:grid;gap:.4rem;background:#0c297c0a;padding:.75rem 1rem;border-radius:16px}.b2-feedback{margin:0;font-weight:600;color:#0c297ccc}.b2-feedback.is-error{color:#c32d3f}.b2-attempt-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;background:#0c297c1f;color:var(--cs-blue);border-radius:999px;padding:.25rem .75rem;font-weight:600}.b2-attempt-badge__detail{font-weight:500;color:#0c297cbf}.b2-planner label{display:grid;gap:.4rem}.b2-checkpoint__item{display:grid;gap:.6rem;border:1px solid rgba(12,41,124,.12);border-radius:16px;padding:.75rem 1rem;background:#0c297c08}.b2-checkpoint__item.is-correct{border-color:#19875459;background:#1987541f}.b2-checkpoint__item.is-incorrect{border-color:#b22c4666;background:#b22c461f}.b2-checkpoint__options{display:grid;gap:.5rem}.b2-checkpoint__options label{display:inline-flex;gap:.5rem;align-items:center}.b2-rationale{margin:0;font-size:.85rem;color:#0c297cbf}.b2-assessment{background:#0c297c0a;border-radius:24px;padding:clamp(1.5rem,4vw,2.5rem);display:grid;gap:1rem}.b2-assessment header{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}.b2-assessment__lock{margin:0;font-weight:600;color:#0c297cbf}.b2-assessment__questions{list-style:decimal;margin:1rem 0;padding-left:1.2rem;display:grid;gap:1.2rem}.b2-assessment__prompt{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;font-weight:600}.b2-assessment__actions{display:flex;justify-content:flex-end}.b2-assessment__teacher{background:#0c297c14;border-radius:16px;padding:1rem 1.2rem;font-size:.9rem}.b2-assessment__teacher--panel{display:grid;gap:1rem}.b2-assessment__teacher-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}.b2-assessment__teacher-grid{display:grid;gap:1.2rem}.b2-assessment__teacher-item{border:1px solid rgba(12,41,124,.12);border-radius:16px;padding:.9rem 1rem;display:grid;gap:.6rem;background:#fffc}.b2-assessment__teacher-meta{display:flex;justify-content:space-between;gap:1rem;font-weight:600}.b2-assessment__teacher-item input,.b2-assessment__teacher-item textarea{border:1px solid rgba(12,41,124,.2);border-radius:12px;padding:.6rem .75rem;font:inherit}.b2-playground{display:grid;gap:1.25rem}@media (min-width: 900px){.b2-playground{grid-template-columns:minmax(0,1fr) minmax(0,.9fr);align-items:stretch}}.b2-playground__editor{display:grid;gap:.75rem}.b2-playground__editor textarea{font-family:JetBrains Mono,SFMono-Regular,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.95rem;border-radius:14px;border:1px solid rgba(12,41,124,.18);background:#0c297c0a;padding:1rem;min-height:260px;resize:vertical;line-height:1.45;color:var(--cs-black)}.b2-playground__editor textarea:focus{outline:3px solid rgba(12,41,124,.28);outline-offset:2px}.b2-playground__snippets{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;font-size:.85rem}.b2-playground__snippets .pill{font-size:.85rem;padding:.45rem .75rem}.b2-playground__console{display:grid;gap:.6rem;background:#0c297c0d;border-radius:14px;border:1px solid rgba(12,41,124,.12);padding:1rem}.b2-playground__console-header{display:flex;justify-content:space-between;align-items:baseline;font-weight:600;color:#0c297ccc}.b2-playground__console pre{font-family:JetBrains Mono,SFMono-Regular,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.92rem;line-height:1.5;margin:0;max-height:260px;overflow:auto;white-space:pre-wrap;background:#ffffffd9;border-radius:10px;padding:.75rem;border:1px dashed rgba(12,41,124,.16);color:var(--cs-black)}.b2-playground__controls{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.b2-status{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;border-radius:999px;padding:.1rem .6rem}.b2-status--success{background:#18a46d26;color:#18a46d}.b2-status--error{background:#da44532e;color:#c32d3f}@media (max-width: 960px){.b2-main{grid-template-columns:1fr}.b2-stages{position:static}.b2-stage-link.is-complete:after{justify-self:end}}@media print{.b2-page{padding:1rem}.b2-stages,.b2-assessment header button,.btn{display:none!important}.b2-assessment__body textarea{min-height:120px}}.y7-map-shell{display:grid;gap:clamp(1.8rem,3vw,2.8rem);padding-bottom:clamp(2rem,6vw,4rem)}.y7-map-hero{background:linear-gradient(140deg,#2563eb2e,#2563eb0d);border-radius:28px;padding:clamp(1.8rem,3.5vw,2.8rem);display:grid;gap:.9rem;box-shadow:0 24px 58px #0f172a1f}.y7-map-eyebrow{font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;color:#2563ebc7}.y7-map-hero h1{margin:0;font-size:clamp(2rem,4vw,2.6rem);color:var(--cs-blue)}.y7-map-hero p{margin:0;max-width:640px;color:#0f172abd;line-height:1.6}.y7-map-alert{border-radius:18px;padding:1rem 1.2rem;background:#ef44441f;color:#b91c1c;font-weight:600}.y7-map-layout{display:grid;gap:clamp(1.6rem,4vw,2.6rem);grid-template-columns:minmax(260px,1fr) minmax(320px,420px)}@media (max-width: 1080px){.y7-map-layout{grid-template-columns:1fr}}.y7-map-units{display:grid;gap:.9rem}.y7-unit-card{display:grid;grid-template-columns:auto 1fr auto;gap:.85rem;align-items:center;padding:.85rem 1rem;border-radius:18px;border:1px solid rgba(37,99,235,.12);background:#fffffff0;box-shadow:0 18px 40px #0f172a14;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .2s}.y7-unit-card:hover{transform:translateY(-1px);box-shadow:0 20px 46px #2563eb24}.y7-unit-card.is-selected{border-color:#2563eb9e;box-shadow:0 24px 58px #2563eb2e}.y7-unit-icon{font-size:1.8rem}.y7-unit-text{display:grid;gap:.35rem;text-align:left}.y7-unit-text strong{font-size:1rem;color:#0f172ae6}.y7-unit-text p{margin:0;color:#0f172aab;font-size:.9rem}.y7-unit-status{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;padding:.3rem .55rem;border-radius:999px;background:#2563eb1f;color:var(--cs-blue)}.y7-unit-status.is-ready{background:#10b98129;color:#047857}.y7-map-detail{display:grid;gap:1.4rem;background:#fffffff2;border-radius:26px;border:1px solid rgba(37,99,235,.12);box-shadow:0 26px 60px #0f172a1f;padding:clamp(1.6rem,3vw,2.2rem);align-content:start}.y7-map-detail__header{display:grid;gap:.85rem}.y7-map-detail__header h2{margin:0;font-size:1.4rem;color:var(--cs-blue)}.y7-map-detail__header p{margin:0;color:#0f172ab8;line-height:1.6}.y7-map-stats{display:flex;flex-wrap:wrap;gap:.9rem}.y7-map-stats div{background:#2563eb12;border-radius:14px;padding:.55rem .75rem;font-size:.85rem;color:#0f172aa6}.y7-map-stats span{display:block;text-transform:uppercase;letter-spacing:.06em;font-size:.7rem}.y7-map-stats strong{color:#0f172ad9}.y7-map-detail__actions{display:grid;gap:1rem}.y7-map-field{display:grid;gap:.35rem;font-size:.9rem}.y7-map-field select{border-radius:12px;border:1px solid rgba(37,99,235,.25);padding:.55rem .7rem;font:inherit}.y7-map-buttons{display:flex;flex-wrap:wrap;gap:.7rem}.y7-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border-radius:12px;border:1px solid rgba(37,99,235,.22);background:#2563eb14;color:var(--cs-blue);padding:.55rem .9rem;font:inherit;cursor:pointer;transition:transform .2s,box-shadow .2s}.y7-btn:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.y7-btn--primary{border-color:transparent;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 16px 30px #2563eb38}.y7-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 28px #2563eb29}.y7-map-coming-soon{border-radius:18px;padding:1rem 1.1rem;background:#2563eb0f;border:1px solid rgba(37,99,235,.16);color:#0f172ab3}.y7-map-live-cards{display:grid;gap:1rem}.y7-live-summary-card{background:#f8fafff2;border-radius:20px;border:1px solid rgba(37,99,235,.12);padding:1rem 1.2rem;display:grid;gap:.6rem}.y7-live-summary-card header{display:flex;justify-content:space-between;align-items:center;gap:.8rem}.y7-live-summary-card p{margin:0;color:#0f172ab3}.y7-live-summary-card .code{font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-weight:600;letter-spacing:.18em;color:#1e3a8a}.y7-live-summary-card .meta{font-size:.8rem;color:#0f172a8c}.chip{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.3rem .6rem;border-radius:999px;background:#2563eb1f;color:var(--cs-blue)}.chip.is-live{background:#10b9812e;color:#047857}.chip.is-paused{background:#f9731633;color:#b45309}.chip.is-idle{background:#2563eb1f;color:var(--cs-blue)}.y7-map-note{border-radius:18px;padding:1.1rem 1.2rem;background:#2563eb0f;border:1px solid rgba(37,99,235,.16);color:#0f172ab8;display:grid;gap:.6rem}.y7-map-note h3{margin:0;font-size:1rem;color:var(--cs-blue)}.y7-map-note ul{margin:0;padding-left:1.2rem;display:grid;gap:.4rem}@media (max-width: 760px){.y7-map-hero{text-align:left}.y7-map-layout{grid-template-columns:1fr}.y7-map-detail{order:-1}}.formative{display:grid;gap:var(--space-4)}.formative__prompt{font-size:var(--text-md);font-weight:600;color:var(--color-text);margin:0}.formative__options{display:grid;gap:var(--space-3)}.formative-option{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);background:var(--color-surface-elevated);color:var(--color-text);box-shadow:var(--shadow-xs);transition:border-color var(--transition-base),box-shadow var(--transition-base),background var(--transition-base);cursor:pointer}.formative-option input{accent-color:var(--color-primary-700);width:var(--space-4);height:var(--space-4);cursor:pointer}.formative-option span{font-size:var(--text-md);color:var(--color-text-soft)}.formative-option:hover{border-color:var(--color-border);background:var(--color-white)}.formative-option.is-selected{border-color:var(--status-info-border);background:var(--status-info-bg);box-shadow:var(--shadow-sm)}.formative-option.is-selected span{color:var(--color-text);font-weight:600}.formative__footer{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.formative__badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:calc(var(--space-1) + 1px) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-sm);font-weight:600;background:var(--status-info-bg);color:var(--color-text);transition:background var(--transition-base),color var(--transition-base)}.formative__badge.is-correct{background:var(--color-success-light);color:var(--color-success-dark)}.formative__badge.is-incorrect{background:var(--color-error-light);color:var(--color-error-dark)}.formative__stack{display:grid;gap:var(--space-3)}.formative-card{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);background:var(--color-white);box-shadow:var(--shadow-xs);transform:var(--sortable-transform, translate3d(0, 0, 0));transition:var(--sortable-transition, transform var(--transition-base)),box-shadow var(--transition-base),background var(--transition-base);opacity:var(--sortable-opacity, 1)}.formative-card[data-dragging=true]{box-shadow:var(--shadow-lg);background:var(--color-surface-elevated)}.formative-card__handle{font-size:var(--text-lg);color:var(--color-text-muted);display:inline-flex;align-items:center}.formative-card--overlay{pointer-events:none;box-shadow:var(--shadow-lg)}.formative__classification{display:grid;gap:var(--space-3)}.formative-classification__row{display:grid;grid-template-columns:1fr minmax(180px,240px) auto;gap:var(--space-3);align-items:center;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);background:var(--color-surface-elevated);box-shadow:var(--shadow-xs);transition:border-color var(--transition-base),box-shadow var(--transition-base),background var(--transition-base)}.formative-classification__label{font-weight:600;color:var(--color-text)}.formative-classification__row select{border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);padding:var(--space-2) var(--space-3);font:inherit;color:var(--color-text);background:var(--color-white);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.formative-classification__row select:focus-visible{border-color:var(--status-info-border);box-shadow:var(--focus-ring)}.formative-classification__row.has-feedback{border-color:var(--status-info-border);background:var(--status-info-bg)}@media (max-width: 720px){.formative-classification__row{grid-template-columns:1fr;align-items:start}.formative-classification__row select{width:100%}}.binary-light-bulbs{display:grid;gap:var(--space-5);justify-items:center;text-align:center}.binary-light-bulbs__grid{display:flex;gap:var(--space-3)}.binary-light-bulbs__bulb{--binary-bulb-size: calc(var(--space-8) + var(--space-4));width:var(--binary-bulb-size);height:var(--binary-bulb-size);border-radius:var(--radius-full);border:none;display:grid;place-items:center;background:var(--status-info-bg);color:var(--color-text);font-size:var(--text-xl);font-weight:600;cursor:pointer;transition:transform var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast),color var(--transition-fast);box-shadow:inset 0 6px 16px #050d3114}.binary-light-bulbs__bulb:hover,.binary-light-bulbs__bulb:focus-visible{background:var(--color-primary-100);box-shadow:var(--shadow-sm)}.binary-light-bulbs__bulb.is-on{background:linear-gradient(135deg,var(--cs-gold),var(--color-warning));color:var(--color-white);box-shadow:0 18px 30px #050d3138}.binary-light-bulbs__value,.binary-light-bulbs__score{margin:0;font-weight:600;color:var(--color-text-soft)}.robot-maze{display:grid;gap:var(--space-4)}.robot-maze__grid{display:grid;gap:var(--space-2)}.robot-maze__row{display:grid;grid-template-columns:repeat(auto-fit,minmax(56px,1fr));gap:var(--space-2)}.robot-maze__cell{aspect-ratio:1 / 1;border-radius:var(--radius-md);display:grid;place-items:center;background:var(--status-info-bg);font-size:var(--text-lg);color:var(--color-text)}.robot-maze__cell--w{background:var(--status-info-border);color:var(--color-white)}.robot-maze__cell--g{background:var(--color-success-light);color:var(--color-success-dark)}.robot-maze__controls,.robot-maze__program,.robot-maze__actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.robot-maze__chip{background:var(--status-info-bg);color:var(--color-primary-800);border-radius:var(--radius-pill);padding:calc(var(--space-1) + 1px) var(--space-3);font-size:var(--text-sm);font-weight:600}.think-pair-share{background:var(--status-info-bg);border:1px solid var(--status-info-border);border-radius:var(--radius-xl);padding:clamp(var(--space-5),4vw,var(--space-6));display:grid;gap:var(--space-4);text-align:center;box-shadow:var(--shadow-xs)}.think-pair-share h3{margin:0;font-size:clamp(var(--text-lg),2vw,var(--text-xl));color:var(--color-text)}.think-pair-share__phases{display:flex;justify-content:center;gap:var(--space-4)}.think-pair-share__phase{opacity:.55;transition:transform var(--transition-fast),opacity var(--transition-fast);display:grid;gap:var(--space-2);justify-items:center;color:var(--color-text-muted)}.think-pair-share__phase.is-active{opacity:1;transform:scale(1.05);color:var(--color-text)}.think-pair-share__icon{font-size:var(--text-xl)}.think-pair-share__timer{margin:0;font-size:clamp(var(--text-xl),3vw,var(--text-2xl));font-weight:700;color:var(--color-text)}@media (max-width: 640px){.binary-light-bulbs__grid{flex-wrap:wrap;justify-content:center}.robot-maze__row{grid-template-columns:repeat(auto-fit,minmax(48px,1fr))}.think-pair-share__phases{gap:var(--space-3)}}.CircularProgressbar{width:100%;vertical-align:middle}.CircularProgressbar .CircularProgressbar-path{stroke:#3e98c7;stroke-linecap:round;-webkit-transition:stroke-dashoffset .5s ease 0s;transition:stroke-dashoffset .5s ease 0s}.CircularProgressbar .CircularProgressbar-trail{stroke:#d6d6d6;stroke-linecap:round}.CircularProgressbar .CircularProgressbar-text{fill:#3e98c7;font-size:20px;dominant-baseline:middle;text-anchor:middle}.CircularProgressbar .CircularProgressbar-background{fill:#d6d6d6}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-background{fill:#3e98c7}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-text{fill:#fff}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-path{stroke:#fff}.CircularProgressbar.CircularProgressbar-inverted .CircularProgressbar-trail{stroke:transparent}.live-dashboard{display:grid;gap:var(--space-5);padding:clamp(var(--space-5),4vw,var(--space-6));border-radius:var(--radius-xl);border:1px solid var(--color-border-subtle);background:var(--color-white);box-shadow:var(--shadow-sm)}.live-dashboard__header{display:grid;gap:var(--space-2)}.live-dashboard__header h2{margin:0;font-size:clamp(var(--text-xl),2.4vw,var(--text-2xl))}.live-dashboard__header p{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.live-dashboard__metrics{display:grid;gap:var(--space-4)}.live-dashboard__card{border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);background:var(--color-surface-elevated);padding:var(--space-4);display:grid;gap:var(--space-3);box-shadow:var(--shadow-xs)}.live-dashboard__card h3{margin:0;font-size:var(--text-md);color:var(--color-text)}.live-dashboard__value{margin:0;font-size:clamp(var(--text-lg),2.2vw,var(--text-xl));font-weight:600;color:var(--color-text)}.live-dashboard__note{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.live-dashboard__gauge{width:clamp(96px,18vw,120px);margin:0 auto}.live-dashboard__assessment-list{margin:0;padding:0;list-style:none;display:grid;gap:var(--space-3)}.live-dashboard__assessment-row{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.live-dashboard__chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:calc(var(--space-1) + 1px) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--status-info-bg);color:var(--status-info-text)}.live-dashboard__chip--success{background:var(--color-success-light);color:var(--color-success-dark)}.live-dashboard__chip--warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.live-dashboard__chip--muted{background:#0c297c14;color:var(--color-text-muted)}.live-dashboard__progress{--progress-height: 6px;--progress-track-bg: rgba(12, 41, 124, .08);--progress-fill-bg: linear-gradient(90deg, var(--color-success), var(--color-info))}.live-dashboard__progress .progress-bar__footer{display:none}.live-dashboard__progress-bar{width:100%}.live-dashboard__grid{display:grid;gap:var(--space-3)}.live-dashboard__grid h3{margin:0;font-size:var(--text-md)}.live-dashboard__grid-body{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.live-dashboard__tile{padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--status-info-border);background:var(--status-info-bg);display:grid;gap:var(--space-2);text-align:center;transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-xs)}.live-dashboard__tile span{font-size:var(--text-sm);color:var(--color-text-muted)}.live-dashboard__tile strong{font-size:var(--text-md);color:var(--color-text)}.live-dashboard__tile--on-time{border-color:var(--color-success-light);background:#10b98129}.live-dashboard__tile--behind{border-color:var(--color-warning-light);background:#f59e0b2e}.live-dashboard__tile--idle{border-color:#0c297c1f;background:#0c297c0f}.live-dashboard__tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.live-dashboard{padding:var(--space-5)}.live-dashboard__grid-body{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}}.y7-live-shell{display:grid;gap:clamp(1.8rem,3vw,2.8rem);padding-bottom:clamp(2rem,6vw,4rem)}.y7-live-header{background:radial-gradient(circle at top left,#2563eb29,#2563eb0a);border-radius:28px;padding:clamp(1.8rem,3.5vw,2.8rem);display:flex;flex-wrap:wrap;gap:clamp(1.4rem,3vw,3rem);align-items:flex-start;box-shadow:0 24px 60px #0f172a1f}.y7-live-eyebrow{font-size:.82rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;color:#2563ebbf}.y7-live-header h1{font-size:clamp(1.9rem,4vw,2.5rem);margin:.45rem 0;color:var(--cs-blue)}.y7-live-header p{max-width:540px;color:#0f172abf;line-height:1.6}.y7-live-meta{display:grid;gap:.7rem;padding:1.1rem 1.4rem;border-radius:22px;background:#ffffffeb;border:1px solid rgba(37,99,235,.12);min-width:240px}.y7-live-meta div{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem;color:#0f172ab3}.y7-live-alert{border-radius:18px;padding:1rem 1.2rem;background:#ef44441f;color:#b91c1c;font-weight:600}.y7-live-layout{display:grid;gap:clamp(1.6rem,4vw,2.6rem);grid-template-columns:minmax(260px,1fr) 360px}@media (max-width: 1080px){.y7-live-layout{grid-template-columns:1fr}}.y7-live-stage{display:grid;gap:clamp(1.3rem,3vw,2.2rem);align-content:start}.y7-live-loading{background:#fffffff2;border-radius:28px;border:1px solid rgba(37,99,235,.1);padding:clamp(2.4rem,6vw,3.4rem);text-align:center;box-shadow:0 26px 60px #0f172a1f;display:grid;gap:1rem;place-items:center}.y7-live-spinner{width:44px;height:44px;border-radius:50%;border:3px solid rgba(37,99,235,.18);border-top-color:#2563ebd9;animation:y7-spin 1s linear infinite}@keyframes y7-spin{to{transform:rotate(360deg)}}.y7-live-stage__card{background:linear-gradient(150deg,#fffffff2,#f1f5ffeb);border-radius:32px;border:1px solid rgba(37,99,235,.1);box-shadow:0 30px 70px #0f172a2e;padding:clamp(1.8rem,4vw,2.6rem);min-height:clamp(320px,40vh,480px);display:flex;align-items:center;justify-content:center}.y7-live-stage__empty{text-align:center;color:#0f172a8c;font-size:1rem}.y7-live-slide{display:grid;gap:1.2rem;width:100%}.y7-live-slide__header{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}.y7-live-slide__badge{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.3rem .6rem;border-radius:999px;background:#2563eb1f;color:var(--cs-blue)}.y7-live-slide__header h2{margin:0;font-size:clamp(1.5rem,3vw,1.9rem);color:#0f172aeb}.y7-live-slide__body{display:grid;gap:1rem;color:#0f172ac7}.y7-live-slide__headline{margin:0;font-size:1.05rem;color:#0f172ad9;font-weight:600}.y7-live-slide__panel{background:#2563eb0f;border-radius:18px;padding:1rem 1.1rem;border:1px solid rgba(37,99,235,.12)}.y7-live-slide__panel h3{margin:0 0 .45rem;font-size:.95rem;color:var(--cs-blue)}.y7-live-slide__panel ul{margin:0;padding-left:1.25rem}.y7-live-reveal{margin:0;padding-left:1.4rem;display:grid;gap:.5rem}.y7-live-bullets{margin:0;padding-left:1.2rem}.y7-live-callouts{display:grid;gap:.75rem}.y7-live-callout{border-radius:16px;padding:.85rem 1rem;border:1px solid rgba(37,99,235,.18);background:#2563eb14;color:#0f172ac7}.y7-live-callout--tip{background:#10b9811f;border-color:#10b98133;color:#047857}.y7-live-callout--warning{background:#eab30824;border-color:#eab30842;color:#92400e}.y7-live-notes p{margin:0;color:#0f172ab3}.y7-live-slide__tag{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:.25rem .55rem;background:#2563eb1f;color:var(--cs-blue)}.y7-live-slide__tag.is-checkpoint{background:#10b98126;color:#047857}.y7-live-slide__tag.is-summative{background:#ef444426;color:#b91c1c}.y7-live-question{display:grid;gap:.65rem;padding:.9rem 1rem;border-radius:18px;background:#fffffff0;border:1px solid rgba(37,99,235,.1)}.y7-live-options{display:grid;gap:.55rem}.y7-live-option{border-radius:14px;border:1px solid rgba(37,99,235,.18);background:#fffffffa;padding:.55rem .75rem;display:flex;align-items:center;gap:.65rem;cursor:pointer;transition:border-color .2s,box-shadow .2s}.y7-live-option.is-selected{border-color:#2563eb7a;box-shadow:0 12px 26px #2563eb29}.y7-live-option input{accent-color:var(--cs-blue)}.y7-live-answer{margin-left:auto;font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:999px}.y7-live-answer--correct{background:#10b9812e;color:#047857}.y7-live-answer--incorrect{background:#ef44442e;color:#b91c1c}.y7-live-question__feedback{margin:0;font-size:.85rem;color:#0f172aa6}.y7-live-slide__footer{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}.y7-live-score{font-weight:600;color:#0f172ac7}.y7-live-matching{display:grid;grid-template-columns:1fr minmax(140px,180px) auto;gap:.55rem;align-items:center}@media (max-width: 700px){.y7-live-matching{grid-template-columns:1fr}}.y7-live-matching__term{font-weight:600;color:#0f172acc}.y7-live-matching__feedback{margin:0;padding-left:1.2rem;color:#0f172ab3}.y7-live-controls{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;justify-content:space-between}.y7-live-controls__middle{display:flex;align-items:center;gap:.75rem;color:#0f172aad}.y7-live-timeline{display:grid;gap:.75rem}.y7-live-timeline__item{display:flex;align-items:center;gap:.75rem;border-radius:16px;border:1px solid rgba(37,99,235,.14);background:#fffffff0;padding:.6rem .75rem;text-align:left;cursor:pointer;transition:border-color .2s,box-shadow .2s}.y7-live-timeline__item:disabled{opacity:.6;cursor:not-allowed}.y7-live-timeline__item--current{border-color:#2563ebd9;box-shadow:0 14px 30px #2563eb2e}.y7-live-timeline__order{width:2.2rem;height:2.2rem;display:grid;place-items:center;border-radius:999px;background:#2563eb1f;color:var(--cs-blue);font-weight:700}.y7-live-timeline__text strong{display:block;color:#0f172ad9}.y7-live-timeline__text span{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:#0f172a8c}.y7-live-sidebar{display:grid;gap:1.4rem}.y7-live-panel{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);padding:clamp(var(--space-5),4vw,var(--space-6));display:grid;gap:var(--space-4)}.y7-live-panel__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);flex-wrap:wrap}.y7-live-panel__header h2{margin:0;font-size:clamp(var(--text-lg),2.2vw,var(--text-xl));color:var(--color-text)}.y7-live-panel__header p{margin:0;color:var(--color-text-muted);font-size:var(--text-sm)}.y7-live-field{display:grid;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-muted)}.y7-live-field select,.y7-live-field input{border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);padding:var(--space-3);font:inherit;background:var(--color-white)}.y7-live-actions{display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.y7-live-panel__footer{font-size:.9rem;color:#0f172ab8}.y7-live-panel__timestamp{margin:.2rem 0 0;font-size:.8rem;color:#0f172a8c}.y7-live-join{display:grid;gap:.65rem}.y7-live-join__status{font-size:.85rem}.y7-live-join__status--success{color:#047857}.y7-live-join__status--error{color:#b91c1c}.slide-container{width:100%;position:relative;display:grid;gap:1.2rem}.slide-layout{display:grid;gap:1rem}.slide-layout--split{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.slide-block--heading{margin:0;font-size:clamp(1.6rem,3vw,2.1rem);color:#0f172aeb}.slide-block--paragraph{margin:0;font-size:1.05rem;line-height:1.6;color:#0f172ac7}.slide-block--list{margin:0;padding-left:1.3rem;display:grid;gap:.45rem}.slide-panel{background:#2563eb14;border:1px solid rgba(37,99,235,.14);border-radius:18px;padding:1rem 1.2rem}.slide-panel--badge{display:flex;gap:1rem;align-items:center}.slide-badge-icon{font-size:2.2rem}.slide-callout{border-radius:16px;padding:.9rem 1.1rem;background:#94a3b81f;border-left:4px solid rgba(148,163,184,.35)}.slide-callout--info{border-left-color:#2563eb8c;background:#2563eb1f}.slide-callout--success{border-left-color:#22c55e99;background:#22c55e26}.slide-callout--warning{border-left-color:#f59e0ba6;background:#f59e0b29}.slide-lock-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0f172a61;border-radius:inherit}.slide-lock-overlay p{color:#fff;font-weight:600}.slide-gallery{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.slide-gallery__card{background:#fffffff0;border-radius:20px;border:1px solid rgba(148,163,184,.25);overflow:hidden;box-shadow:0 18px 38px #0f172a1f}.slide-gallery__card img{width:100%;height:140px;object-fit:cover}.slide-gallery__card>div{padding:1rem 1.2rem 1.4rem}.y7-live-join__status--info{color:var(--cs-blue)}.y7-live-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;text-align:center}.y7-live-summary div{padding:.7rem .6rem;border-radius:12px;background:#2563eb14;color:#0f172ac7}.y7-live-summary span{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}.y7-live-summary strong{font-size:1.15rem}.y7-live-table{border:1px solid rgba(37,99,235,.12);border-radius:16px;overflow:hidden}.y7-live-table table{width:100%;border-collapse:collapse}.y7-live-table th,.y7-live-table td{padding:.65rem .75rem;text-align:left;font-size:.9rem}.y7-live-table thead{background:#2563eb14;font-weight:600;color:#0f172ac7}.status{text-transform:capitalize}.status--completed{color:#047857}.status--in-progress{color:#b45309}.status--not-started{color:#0f172a8f}.y7-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border-radius:var(--radius-pill);border:1px solid rgba(12,41,124,.24);background:#0c297c14;color:var(--color-primary-800);padding:calc(var(--space-2) + 2px) var(--space-4);font:inherit;font-size:var(--text-sm);font-weight:600;letter-spacing:.01em;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.y7-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.y7-btn--primary{border-color:transparent;background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);box-shadow:var(--shadow-sm)}.y7-btn--primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-md)}.y7-btn--ghost{border-color:#0c297c3d;background:#0c297c14;color:var(--color-primary-800);box-shadow:none}.y7-btn--ghost:hover:not(:disabled){background:#0c297c24}.y7-live-alert,.y7-live-summary div{font-family:inherit}:root{color-scheme:light;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;--color-white: #ffffff;--color-black: #050d31;--color-primary-900: #050d31;--color-primary-800: #0c297c;--color-primary-700: #1a3f9f;--color-primary-500: #2f5dc7;--color-primary-200: #c7d5f7;--color-primary-100: #e9f0ff;--color-accent-700: #8f6626;--color-accent-600: #b28541;--color-accent-400: #d8a861;--color-accent-200: #f1dcb4;--color-accent-100: #f7ead2;--color-surface: #f5f7fb;--color-surface-elevated: #fafbfe;--color-surface-muted: #eef1f9;--color-border: rgba(12, 41, 124, .14);--color-border-subtle: rgba(12, 41, 124, .08);--color-text: #111a3b;--color-text-soft: #2a345c;--color-text-muted: #4c597c;--color-link: var(--color-primary-700);--color-link-hover: var(--color-primary-800);--cs-white: var(--color-white);--cs-light: #ffffff;--cs-black: var(--color-black);--cs-dark: #111a3b;--cs-blue: var(--color-primary-800);--cs-blue-light: #3275ff;--cs-blue-lighter: #63b5ff;--cs-gold: var(--color-accent-600);--cs-muted: var(--color-text-muted);--cs-surface: var(--color-surface);--cs-background: linear-gradient(180deg, #f8faff 0%, var(--color-surface) 42%, #ffffff 100%);--cs-success: #10b981;--cs-error: #ef4444;--cs-green: var(--cs-success);--cs-orange: #f97316;--cs-purple: #6366f1;--cs-red: #ef4444;--cs-grey-light: #f1f5f9;--cs-gray-light: var(--cs-grey-light);--cs-grey-mid-light: #e2e8f0;--cs-grey-mid: #cbd5f0;--cs-grey-dark: #475569;--cs-primary-accent: linear-gradient(135deg, var(--cs-blue), var(--cs-blue-light));--cs-primary-accent-dark: linear-gradient(135deg, #0b1f63, var(--cs-blue));--cs-gradient-card: linear-gradient(135deg, rgba(12, 41, 124, .08), rgba(63, 181, 255, .12));--cs-gradient-xp: linear-gradient(135deg, rgba(5, 13, 49, .9), rgba(12, 41, 124, .85));--cs-gradient-sidebar: linear-gradient(180deg, rgba(12, 41, 124, .08), rgba(63, 181, 255, .12));--status-info-bg: rgba(12, 41, 124, .12);--status-info-border: rgba(12, 41, 124, .38);--status-info-text: var(--color-primary-800);--status-success-bg: rgba(178, 133, 65, .16);--status-success-border: rgba(178, 133, 65, .44);--status-success-text: #6e4d1c;--status-warning-bg: rgba(178, 133, 65, .24);--status-warning-border: rgba(178, 133, 65, .54);--status-warning-text: #4a3412;--status-error-bg: rgba(5, 13, 49, .12);--status-error-border: rgba(5, 13, 49, .42);--status-error-text: var(--color-black);--color-info: #3b82f6;--color-info-light: rgba(59, 130, 246, .18);--color-info-dark: #1e3a8a;--color-success: #10b981;--color-success-light: rgba(16, 185, 129, .18);--color-success-dark: #047857;--color-warning: #f59e0b;--color-warning-light: rgba(245, 158, 11, .2);--color-warning-dark: #92400e;--color-error: #ef4444;--color-error-light: rgba(239, 68, 68, .2);--color-error-dark: #b91c1c;--color-xp-gold: #fbbf24;--color-streak-fire: #f97316;--focus-ring: 0 0 0 3px rgba(12, 41, 124, .28);--space-unit: 8px;--space-0: 0;--space-1: calc(var(--space-unit) * .5);--space-2: var(--space-unit);--space-3: calc(var(--space-unit) * 1.5);--space-4: calc(var(--space-unit) * 2);--space-5: calc(var(--space-unit) * 3);--space-6: calc(var(--space-unit) * 4);--space-7: calc(var(--space-unit) * 5);--space-8: calc(var(--space-unit) * 6);--space-9: calc(var(--space-unit) * 8);--space-10: calc(var(--space-unit) * 10);--space-xs: var(--space-1);--space-sm: var(--space-2);--space-md: var(--space-4);--space-lg: var(--space-5);--space-xl: var(--space-6);--space-2xl: var(--space-8);--space-3xl: var(--space-9);--space-4xl: var(--space-10);--font-family-base: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--line-height-base: 1.6;--line-height-tight: 1.3;--line-height-dense: 1.15;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--radius-pill: 999px;--radius-2xl: 32px;--radius-full: 999px;--shadow-xs: 0 1px 2px rgba(5, 13, 49, .08);--shadow-sm: 0 4px 12px rgba(5, 13, 49, .12);--shadow-md: 0 10px 24px rgba(5, 13, 49, .14);--shadow-lg: 0 18px 36px rgba(5, 13, 49, .18);--shadow-xl: 0 24px 48px rgba(5, 13, 49, .22);--shadow-2xl: 0 32px 64px rgba(5, 13, 49, .26);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .22s cubic-bezier(.4, 0, .2, 1);--transition-slow: .36s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--max-content-width: 1240px}@media (prefers-color-scheme: dark){:root{--color-surface: #101527;--color-surface-elevated: #161d33;--color-surface-muted: #1d253f;--color-text: #f1f4ff;--color-text-soft: #c8d2ff;--color-text-muted: #93a1d6;--color-border: rgba(233, 240, 255, .16);--color-border-subtle: rgba(233, 240, 255, .08);--status-error-bg: rgba(233, 240, 255, .1)}}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-family-base);font-size:var(--text-md);line-height:var(--line-height-base);background:linear-gradient(180deg,#f8faff 0%,var(--color-surface) 42%,#ffffff 100%);color:var(--color-text)}a{color:var(--color-link);text-decoration:none;transition:color var(--transition-fast)}a:hover,a:focus-visible{color:var(--color-link-hover)}button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}code,pre{font-family:var(--font-family-mono)}h1,h2,h3,h4,h5,h6{color:var(--color-text);font-weight:600;line-height:var(--line-height-tight);margin:0}h1{font-size:var(--text-4xl);letter-spacing:-.02em}h2{font-size:var(--text-3xl);letter-spacing:-.015em;margin-top:var(--space-8)}h3{font-size:var(--text-2xl);margin-top:var(--space-6)}h4{font-size:var(--text-xl)}p{margin:0 0 var(--space-4);color:var(--color-text-soft)}small{font-size:var(--text-sm)}.text-muted{color:var(--color-text-muted)}.eyebrow{text-transform:uppercase;letter-spacing:.14em;font-size:var(--text-xs);color:#0c297ca6}.link-inline{color:var(--color-link);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:4px}.link-inline:hover,.link-inline:focus-visible{text-decoration-thickness:2px}strong{color:var(--color-text)}.muted{color:var(--color-text-muted)}ul,ol{margin:0 0 var(--space-4);padding-left:var(--space-6)}li+li{margin-top:var(--space-2)}*:focus-visible{outline:none;box-shadow:var(--focus-ring);border-radius:var(--radius-sm)}.btn,.pill,.button-outline{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:calc(var(--space-2) + 2px) calc(var(--space-5));border-radius:var(--radius-pill);border:1px solid transparent;font-weight:600;font-size:var(--text-sm);letter-spacing:.01em;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.btn-primary,.pill.pill--action{background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);box-shadow:var(--shadow-sm)}.btn-primary:hover,.pill.pill--action:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.pill{background:#0c297c14;color:var(--color-primary-800);border-color:#0c297c26}.pill:hover{background:#0c297c29}.button-outline{background:transparent;border-color:#0c297c3d;color:var(--color-primary-800)}.button-outline:hover{background:#0c297c14}.button-outline--danger{border-color:var(--status-error-border);color:var(--status-error-text);background:#050d310a}.button-outline--danger:hover{background:#050d311f}.dashboard-submit{border:none;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--color-primary-800),var(--color-primary-700));color:var(--color-white);padding:calc(var(--space-2) + 2px) var(--space-6);font-weight:600;letter-spacing:.01em;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.dashboard-submit:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:calc(var(--space-1) + 1px) var(--space-3);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.badge--info{background:#0c297c1f;color:var(--color-primary-800)}.badge--accent{background:#b2854129;color:var(--color-accent-700)}.page-shell{display:grid;gap:clamp(1.5rem,3vw,3rem);width:min(var(--max-content-width),100%);margin:0 auto;padding:clamp(1.5rem,3vw,3rem)}.page-shell--fluid{width:100%;padding-inline:clamp(1rem,4vw,3.5rem)}.page-section{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);padding:clamp(1.75rem,3vw,2.5rem);display:grid;gap:var(--space-5)}.page-hero{border-radius:var(--radius-xl);border:1px solid var(--color-border-subtle);background:radial-gradient(145% 120% at 100% 0%,#0c297c1f,#0c297c00 65%),var(--color-white);box-shadow:var(--shadow-md);padding:clamp(2rem,5vw,3.5rem);display:grid;gap:var(--space-4);position:relative;overflow:hidden}.page-hero__content{max-width:720px;display:grid;gap:var(--space-3)}.page-hero__actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.page-panels{display:grid;gap:clamp(1.4rem,3vw,2.4rem);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:stretch}.page-card{border-radius:var(--radius-lg);background:var(--color-white);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm);padding:clamp(1.5rem,3vw,2.2rem);display:grid;gap:var(--space-3);position:relative}.page-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;border:1px solid transparent;transition:border-color var(--transition-fast)}.page-card:hover:after{border-color:#0c297c2e}.layout-grid,.ds-grid{display:grid;gap:var(--space-5)}.ds-grid--auto-fit{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.ds-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.ds-grid--three{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.ds-card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-xs);padding:var(--space-5);display:grid;gap:var(--space-3);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.ds-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.ds-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.ds-card__meta{display:grid;gap:var(--space-1);color:var(--color-text-muted);font-size:var(--text-sm)}.ds-stack{display:grid;gap:var(--space-4)}.ds-surface{background:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle);padding:var(--space-4)}.ds-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(12,41,124,.16),transparent)}.ds-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.ds-table th,.ds-table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid rgba(12,41,124,.08);text-align:left}.ds-table thead th{text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:var(--text-xs);color:var(--color-text-muted)}.ds-table tbody tr:hover{background:#0c297c0a}.skeleton{background:linear-gradient(90deg,#0c297c14 25%,#0c297c29,#0c297c14 75%);background-size:1000px 100%;animation:shimmer 2s infinite;border-radius:var(--radius-md)}@keyframes fade-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.animate-fade-in-up{animation:fade-in-up var(--transition-slow) both}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.hide-mobile{display:none}.show-mobile{display:initial}@media (min-width: 768px){.hide-mobile{display:initial}.show-mobile{display:none}}@media (max-width: 767px){.page-shell{padding:var(--space-5) var(--space-4)}.ds-grid--two,.ds-grid--three{grid-template-columns:1fr}.page-hero{padding:var(--space-6) var(--space-4)}}.content-container{width:min(var(--max-content-width),100%);margin:0 auto;padding:clamp(1.5rem,3vw,3rem);display:grid;gap:clamp(1.5rem,3vw,3rem)}.content-container--compact{max-width:960px}.content-container--wide{max-width:1440px}.content-container--full{width:100%;max-width:none;padding-inline:clamp(1rem,4vw,3.5rem)}.responsive-grid{display:grid;gap:var(--space-5);grid-template-columns:repeat(var(--columns-base, 1),minmax(0,1fr))}.responsive-grid--auto-fit{grid-template-columns:repeat(auto-fit,minmax(var(--min-column-width, 260px),1fr))}.responsive-grid--masonry{display:flex;flex-wrap:wrap;gap:var(--space-5)}.responsive-grid--masonry>*{flex:1 1 calc(33.333% - var(--space-5));min-width:260px}@media (min-width: 640px){.responsive-grid{grid-template-columns:repeat(var(--columns-sm, var(--columns-base, 1)),minmax(0,1fr))}}@media (min-width: 768px){.responsive-grid{grid-template-columns:repeat(var(--columns-md, var(--columns-sm, var(--columns-base, 1))),minmax(0,1fr))}}@media (min-width: 1024px){.responsive-grid{grid-template-columns:repeat(var(--columns-lg, var(--columns-md, var(--columns-sm, var(--columns-base, 1)))),minmax(0,1fr))}}@media (min-width: 1280px){.responsive-grid{grid-template-columns:repeat(var(--columns-xl, var(--columns-lg, var(--columns-md, var(--columns-sm, var(--columns-base, 1))))),minmax(0,1fr))}}
