:root{color-scheme:light;--bg: #eef6ef;--bg-accent: #d4ead7;--panel: rgba(252, 255, 252, .93);--panel-strong: #ffffff;--line: rgba(24, 84, 45, .12);--line-strong: rgba(24, 84, 45, .24);--text: #17331f;--muted: #4d6f58;--accent: #217346;--accent-strong: #185c37;--accent-soft: #e8f5ec;--warn: #4b8f34;--good: #185c37;--error: #a12929;--shadow: 0 24px 64px rgba(16, 72, 36, .12);font-family:Aptos,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background:radial-gradient(circle at top left,rgba(33,115,70,.2),transparent 30%),radial-gradient(circle at top right,rgba(110,186,123,.2),transparent 28%),linear-gradient(180deg,#f8fdf8 0%,var(--bg) 100%);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{min-height:100vh}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;align-items:stretch}.user-brand-kicker,.user-kicker{display:block;margin-bottom:.2rem;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}.user-app-shell .main-panel{max-width:1120px}.sidebar{position:sticky;top:0;display:flex;flex-direction:column;gap:2rem;height:100vh;min-height:100vh;padding:2rem 1.5rem;background:linear-gradient(180deg,rgba(24,92,55,.96),rgba(33,115,70,.94)),radial-gradient(circle at top,rgba(255,255,255,.1),transparent 40%);color:#f3fff7}.brand{display:flex;align-items:center;gap:1rem}.brand-copy{display:grid;gap:.15rem}.brand strong{display:block;font-size:1.45rem;line-height:1;letter-spacing:-.03em}.brand p{margin:.15rem 0 0;color:#f3fff7c7}.brand-logo{width:4.75rem;height:4.75rem;object-fit:cover;object-position:center;border-radius:24px;padding:.25rem;border:1px solid rgba(243,255,247,.32);background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.3),transparent 45%),rgba(255,255,255,.12);box-shadow:0 18px 36px #00000038,inset 0 1px #ffffff2e}.nav{display:grid;gap:.6rem}.nav a{padding:.9rem 1rem;border:1px solid transparent;border-radius:14px;color:#fff7ead9;transition:background-color .12s ease,border-color .12s ease,transform .12s ease}.nav a:hover,.nav a.active{background:rgba(243,255,247,.12);border-color:#f3fff72e;color:#fffdf7;transform:translate(2px)}.main-panel{padding:2rem;min-height:100vh}.page-stack{display:grid;gap:1.5rem}.hero-card{display:grid;gap:1.25rem;padding:1.5rem;border:1px solid rgba(24,84,45,.14);border-radius:28px;background:radial-gradient(circle at top right,rgba(110,186,123,.22),transparent 28%),linear-gradient(135deg,rgba(255,255,255,.96),rgba(232,245,236,.9));box-shadow:var(--shadow)}.user-hero,.user-surface{border:1px solid rgba(24,84,45,.14);border-radius:28px;background:radial-gradient(circle at top right,rgba(110,186,123,.16),transparent 30%),linear-gradient(180deg,rgba(255,255,255,.95),rgba(241,249,242,.96));box-shadow:var(--shadow)}.user-hero-simple{grid-template-columns:1fr}.user-hero{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(280px,.9fr);gap:1.5rem;padding:1.75rem}.user-status-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.user-status-strip article,.user-summary-row div{padding:1rem 1.1rem;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.78)}.user-status-strip span,.user-summary-row span{display:block;margin-bottom:.35rem;color:var(--muted);font-size:.9rem}.user-status-strip strong,.user-summary-row strong{display:block;margin-bottom:.25rem;font-size:1.1rem}.user-status-strip p{margin:0;color:var(--muted)}.user-hero-copy h1{margin:0;font-size:clamp(2.1rem,4vw,4rem);line-height:.95;letter-spacing:-.04em}.user-hero-copy p{max-width:60ch;color:var(--muted)}.user-hero-panel{display:grid;gap:1rem;padding:1.2rem;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.72)}.user-bullet-list{margin:0;padding-left:1.2rem;color:var(--muted)}.user-inline-stat{display:grid;gap:.25rem;padding-top:.8rem;border-top:1px solid var(--line)}.user-inline-stat span{color:var(--muted)}.user-inline-stat strong{font-size:1.4rem}.user-flow-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.user-flow-line{display:grid;gap:.9rem}.user-flow-step{padding:.15rem 0 .9rem;border-bottom:1px solid var(--line)}.user-flow-step strong{display:block;margin-bottom:.25rem}.user-flow-step p{margin:0;color:var(--muted)}.user-flow-card{display:grid;gap:.45rem;padding:1.15rem;border:1px solid var(--line);border-radius:22px;background:rgba(255,255,255,.88);box-shadow:0 14px 34px #10482414}.user-flow-card span{color:var(--accent);font-weight:700}.user-flow-card strong{font-size:1.15rem}.user-flow-card p{margin:0;color:var(--muted)}.user-surface{display:grid;gap:1.4rem;padding:1.5rem}.user-form-surface{gap:1.1rem}.user-form{display:grid;gap:1.25rem}.user-form-section{display:grid;gap:1rem}.user-form-section h2{margin:0;font-size:1rem;color:var(--muted)}.user-choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.user-toggle-row{display:flex;gap:.85rem;flex-wrap:wrap}.user-inline-toggle{display:inline-flex;align-items:center;gap:.55rem;padding:.8rem 1rem;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.78);color:var(--text)}.user-inline-toggle input{width:auto;margin:0}.user-choice-card{display:flex;gap:.85rem;align-items:flex-start;padding:1rem 1.1rem;border:1px solid var(--line);border-radius:20px;background:rgba(232,245,236,.9)}.user-choice-card input{width:auto;margin-top:.2rem}.user-choice-card strong{display:block}.user-choice-card p{margin:.25rem 0 0;color:var(--muted)}.user-admin-callout{background:rgba(248,252,249,.96);box-shadow:none}.user-list-panel,.user-rekey-panel{box-shadow:0 12px 28px #1048240f}.assignment-list-card{align-items:center}.assignment-status-badge{display:inline-flex;align-items:center;justify-content:center;min-width:9rem;padding:.6rem .9rem;border-radius:999px;font-weight:700;background:rgba(33,115,70,.1);color:var(--accent-strong)}.status-being-created{background:rgba(163,230,53,.18);color:#3f6212}.status-in-progress{background:rgba(59,130,246,.14);color:#1d4ed8}.status-completed{background:rgba(34,197,94,.16);color:#166534}.user-summary-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.user-summary-row-workflow{grid-template-columns:repeat(4,minmax(0,1fr))}.user-summary-row-wide{grid-template-columns:repeat(5,minmax(0,1fr))}.template-editor{display:grid;gap:1.25rem}.template-editor-compact{gap:1rem}.template-token-row{display:grid;gap:.6rem}.template-token-row span{color:var(--muted);font-weight:600}.template-token-list{display:flex;flex-wrap:wrap;gap:.5rem}.template-token-list code{padding:.35rem .55rem;border-radius:999px;background:rgba(24,92,55,.08);color:var(--accent-strong)}.template-section{display:grid;gap:.8rem}.template-section h3{margin:0;font-size:1rem}.hero-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.hero-point{padding:1rem 1.1rem;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.72)}.hero-point strong{display:block;margin-bottom:.35rem}.hero-point p{margin:0;color:var(--muted)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.page-header h1{margin:0;font-size:clamp(2rem,3vw,3rem);line-height:1}.page-header p{margin:.6rem 0 0;max-width:60ch;color:var(--muted)}.page-actions,.button-row{display:flex;gap:.75rem;flex-wrap:wrap}.stats-grid,.content-grid{display:grid;gap:1rem}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.content-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card,.panel,.list-card{border:1px solid var(--line);background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow)}.stat-card{display:grid;gap:.45rem;padding:1.2rem 1.3rem;border-radius:22px}.stat-card span{color:var(--muted);font-size:.95rem}.stat-card strong{font-size:1.8rem;line-height:1}.stat-good{border-color:#16653440}.stat-warn{border-color:#b4530947}.panel{padding:1.25rem;border-radius:24px}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.panel-header h2{margin:0;font-size:1.05rem}.panel-header a{color:var(--accent-strong)}.panel-header a.button{color:#fff}.panel-header a.button.ghost{color:var(--accent-strong)}.list-stack{display:grid;gap:.8rem}.list-card{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding:1rem 1.05rem;border-radius:18px}.list-card>div:first-child{flex:1 1 320px}.list-card p{margin:.25rem 0 0;color:var(--muted)}.button{display:inline-flex;align-items:center;justify-content:center;min-height:2.8rem;padding:.7rem 1.1rem;border:1px solid var(--accent);border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;font-weight:600;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.button:hover{transform:translateY(-1px);box-shadow:0 10px 24px #2173463d}.button:disabled{cursor:not-allowed;opacity:.65}.button.ghost{background:transparent;color:var(--accent-strong)}.alert{padding:.9rem 1rem;border-radius:16px;border:1px solid transparent}.alert.error{border-color:#b91c1c33;background:rgba(254,242,242,.95);color:var(--error)}.alert.success{border-color:#16653433;background:rgba(240,253,244,.96);color:var(--good)}.empty-state{margin:0;color:var(--muted)}.form-panel{gap:1rem}.feature-grid,.toggle-grid{display:grid;gap:1rem}.feature-grid,.compact-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.feature-card,.toggle-card,.inset-panel{border:1px solid var(--line);border-radius:20px;background:var(--accent-soft)}.feature-card{padding:1rem 1.1rem}.feature-card strong{display:block;margin-bottom:.35rem}.feature-card p{margin:0;color:var(--muted)}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.form-grid label,.checkbox-row{display:grid;gap:.45rem;color:var(--muted)}.span-2{grid-column:span 2}input,textarea,select{width:100%;padding:.85rem .95rem;border:1px solid var(--line-strong);border-radius:16px;background:var(--panel-strong);color:var(--text)}textarea{resize:vertical}input:focus,textarea:focus{outline:2px solid rgba(15,118,110,.18);border-color:var(--accent)}.checkbox-row{grid-auto-flow:column;justify-content:start;align-items:center}.toggle-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.toggle-card{display:flex;gap:.85rem;align-items:flex-start;padding:1rem 1.1rem}.toggle-card input{width:auto;margin-top:.2rem}.toggle-card strong{display:block;color:var(--text)}.toggle-card p{margin:.25rem 0 0;color:var(--muted)}.inset-panel{padding:1rem 1.1rem}.collapsible-panel{border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.84)}.collapsible-summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;cursor:pointer;list-style:none;font-weight:600}.collapsible-summary::-webkit-details-marker{display:none}.collapsible-summary span{color:var(--text)}.collapsible-summary strong{color:var(--muted);font-size:.95rem}.collapsible-body{padding:0 1rem 1rem}.upload-callout{margin-top:1rem}.checkbox-row input{width:auto;margin:0}.detail-grid{display:grid;grid-template-columns:140px 1fr;gap:.65rem 1rem;margin:0}.detail-grid dt{color:var(--muted)}.detail-grid dd{margin:0;overflow-wrap:anywhere}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.75rem .8rem;border-bottom:1px solid var(--line);text-align:left}th{color:var(--muted);font-weight:600}.code-block{margin:0;padding:1rem;border-radius:18px;background:#241b12;color:#fdf5e9;overflow:auto;font-family:Consolas,Cascadia Code,monospace;font-size:.9rem}.button.compact{padding:.55rem .9rem;font-size:.9rem}.user-account,.sidebar-account{display:flex;align-items:center;gap:.9rem}.user-account strong,.sidebar-account strong{display:block}.user-account span,.sidebar-account span{display:block;color:var(--muted);font-size:.9rem}.sidebar-account{margin-top:auto;padding-top:1rem;flex-direction:column;align-items:flex-start;border-top:1px solid rgba(255,255,255,.12)}.sidebar-account strong{color:#f3fff7}.sidebar-account span{color:#f3fff7c7}.sidebar-account .button.ghost{border-color:#f3fff738;color:#f3fff7}.sidebar-account .button.ghost:hover{background:rgba(243,255,247,.12)}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:2rem;background:radial-gradient(circle at top,rgba(80,200,120,.18),transparent 36%),linear-gradient(180deg,#f7fcf8 0%,#edf7ef 100%)}.auth-card{width:min(560px,100%);padding:1.8rem;border-radius:28px;background:rgba(255,255,255,.92);border:1px solid rgba(43,111,62,.1);box-shadow:0 30px 60px #2854311f}.auth-logo{width:92px;height:92px;display:block;margin-bottom:1rem}.auth-copy h1{margin:.25rem 0 .4rem;font-size:clamp(2rem,4vw,2.6rem)}.auth-copy p{margin:0 0 1.25rem;color:var(--muted)}.admin-toolbar{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}.admin-toolbar-field-search{grid-column:span 2}.admin-toolbar-field{display:flex;flex-direction:column;gap:.45rem;color:var(--muted);font-size:.92rem}.admin-toolbar-field input,.admin-toolbar-field select{width:100%}.admin-user-meta{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.45rem}.admin-inline-detail{width:100%;padding:1rem 1.05rem;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.72)}.admin-inline-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem}.admin-inline-detail-grid span{display:block;margin-bottom:.25rem;color:var(--muted);font-size:.9rem}.admin-inline-detail-grid strong{display:block;overflow-wrap:anywhere}.admin-inline-note{margin:.85rem 0 0;color:var(--muted)}.dropzone{padding:1rem;border:2px dashed var(--line-strong);border-radius:20px;background:rgba(255,255,255,.76);cursor:pointer}.dropzone strong{display:block;color:var(--text)}.dropzone input[type=file]{margin-top:.5rem}.hidden-file-input{display:none}.dropzone-active{border-color:var(--accent);background:rgba(232,245,236,.95)}.sheet-selector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.sheet-selector-card{display:flex;align-items:center;gap:.7rem;padding:.9rem 1rem;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.84);color:var(--text)}.sheet-selector-card input{width:auto;margin:0}.course-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:1.25rem}.course-nav{display:grid;gap:.6rem;align-content:start}.course-nav a{padding:.85rem 1rem;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.82);color:var(--muted)}.course-nav a.active{border-color:#21734638;background:rgba(33,115,70,.1);color:var(--accent-strong)}.course-content{min-width:0}.user-badge{display:inline-flex;align-items:center;padding:.22rem .65rem;border-radius:999px;font-size:.8rem;font-weight:600;line-height:1.2}.user-badge-admin{background:rgba(36,125,70,.12);color:#17603a}.user-badge-instructor{background:rgba(60,88,70,.09);color:#365143}.user-badge-active{background:rgba(76,183,116,.12);color:#267146}.user-badge-inactive{background:rgba(173,58,58,.12);color:#8a2d2d}.user-badge-self{background:rgba(34,76,125,.1);color:#2d557f}.assignment-hero-result{display:grid;gap:1rem}.assignment-histogram{width:100%;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.9);object-fit:contain}.assignment-secondary-list{display:grid;gap:.8rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--line)}.assignment-secondary-list strong{display:block}.assignment-action-panel{display:flex;justify-content:flex-start}@media (max-width: 1080px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.stats-grid,.content-grid,.form-grid,.feature-grid,.toggle-grid,.hero-points,.user-flow-grid,.user-choice-grid,.user-hero,.user-status-strip,.user-summary-row,.admin-toolbar,.admin-inline-detail-grid,.course-layout{grid-template-columns:1fr}.span-2,.admin-toolbar-field-search{grid-column:auto}}@media (max-width: 720px){.main-panel{padding:1rem}.user-toggle-row{flex-direction:column}.page-header,.list-card,.panel-header{flex-direction:column;align-items:flex-start}.detail-grid{grid-template-columns:1fr}}
