:root{--brand: #005249;--brand-strong: #003f39;--brand-soft: #e7f2f0;--ink: #12221f;--muted: #5d6b68;--line: #dce6e3;--surface: #ffffff;--background: #f5f8f7;--danger: #b42318;--orange: #b65a00;--purple: #6b3fa0;--green: #0f6b42;--blue: #1f5f9f;--shadow: 0 16px 44px rgba(18, 34, 31, .1);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--ink);background:var(--background)}*{box-sizing:border-box}html{min-width:320px;background:var(--background)}body{margin:0;min-height:100vh;background:var(--background)}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.65}.auth-page{min-height:100vh;display:grid;grid-template-columns:minmax(320px,.9fr) minmax(360px,1.1fr);background:var(--background)}.auth-hero{background:var(--brand);color:#fff;padding:clamp(32px,7vw,76px);display:flex;flex-direction:column;justify-content:center;gap:22px}.auth-wordmark,.brand-wordmark{font-weight:800;letter-spacing:0}.auth-wordmark{font-size:32px}.auth-hero h1{font-size:clamp(38px,5.5vw,76px);line-height:1.02;max-width:780px}.auth-hero p{color:#ffffffd1;font-size:18px;line-height:1.7;max-width:560px}.auth-panel{margin:auto;width:min(640px,calc(100% - 40px));max-height:calc(100vh - 42px);overflow:auto;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);padding:clamp(22px,4vw,36px)}.segmented,.auth-tabs,.tabs,.filter-row{display:flex;gap:8px;flex-wrap:wrap}.segmented{background:var(--brand-soft);border:1px solid var(--line);border-radius:8px;padding:6px}.segmented button,.auth-tabs button,.tabs button,.filter-chip{border:1px solid transparent;background:transparent;color:var(--brand);border-radius:8px;min-height:40px;padding:0 14px;display:inline-flex;align-items:center;gap:8px;font-weight:700}.segmented button{flex:1;justify-content:center}.segmented .active,.auth-tabs .active,.tabs .active,.filter-chip.active{background:var(--brand);color:#fff}.auth-tabs{margin:18px 0 22px}.form-stack,.page-stack,.task-list,.submission-card-list,.announcement-list{display:flex;flex-direction:column;gap:16px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-section-title{color:var(--brand);font-weight:800;margin-top:8px}.field{display:flex;flex-direction:column;gap:7px;color:var(--muted);font-size:13px;font-weight:700}.field input,.field select,.field textarea,.add-class-form input,.submission-heading select{width:100%;min-height:44px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:10px 12px;outline:none}.field textarea{min-height:110px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus,.add-class-form input:focus,.submission-heading select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0052491f}.button,.ghost-action,.profile-button{min-height:44px;border-radius:8px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:0 16px;font-weight:800}.button.primary,.button.secondary:hover,.profile-button,.ghost-action:hover{background:var(--brand);color:#fff}.button.secondary{background:#fff;color:var(--brand);border-color:var(--brand)}.button.danger{background:#fff7f6;color:var(--danger);border-color:#f1b7b1}.button-blue{background:var(--blue);color:#fff}.button.full{width:100%}.app-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr)}.sidebar{position:sticky;top:0;height:100vh;background:var(--brand);color:#fff;padding:24px;display:flex;flex-direction:column;gap:26px}.brand-lockup{display:flex;flex-direction:column;gap:7px}.brand-lockup span:last-child{color:#ffffffc2;font-size:13px;line-height:1.45}.brand-wordmark{font-size:28px}.side-nav{display:grid;gap:8px}.side-nav a,.ghost-action{color:#ffffffd1;border-radius:8px;min-height:44px;padding:0 12px;display:flex;align-items:center;gap:10px;font-weight:750;background:transparent;border:0}.side-nav a.active,.side-nav a:hover{background:#ffffff1f;color:#fff}.sidebar-footer{margin-top:auto;display:grid;gap:12px}.mode-pill{width:fit-content;border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:6px 10px;color:#ffffffc7;font-size:12px;font-weight:800}.main-shell{padding:24px;min-width:0}.topbar{min-height:94px;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.topbar-label,.eyebrow,.announcement-meta,.detail-item dt,.task-details span{color:var(--brand);font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}.topbar h1{font-size:clamp(24px,3vw,38px);line-height:1.1}.topbar-card{min-height:48px;display:inline-flex;align-items:center;gap:10px;color:var(--brand);background:#fff;border:1px solid var(--line);border-radius:8px;padding:0 14px;font-weight:800;max-width:320px}.portal-panel,.profile-prompt,.class-action-card,.pending-panel,.task-card,.submission-card,.table-row,.metric-strip>div{background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 30px #12221f0f}.portal-panel{padding:clamp(18px,3vw,26px)}.student-home-grid{display:grid;grid-template-columns:minmax(0,1fr) 270px;gap:18px}.announcement-panel{min-height:48vh}.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.section-header h2{font-size:clamp(22px,3vw,32px)}.section-actions{display:flex;align-items:center;gap:10px}.announcement-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;padding:16px 0;border-top:1px solid var(--line)}.announcement-item h3,.class-card h3,.task-card h3,.submission-card h3,.table-row h3{font-size:18px;line-height:1.25}.announcement-item p,.empty-state p,.task-card p,.submission-card p,.table-row p,.muted-text{color:var(--muted);line-height:1.6}.heart-button{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);color:var(--brand);background:#fff;display:grid;place-items:center}.heart-button.active{background:var(--brand);color:#fff}.profile-prompt{padding:18px;display:grid;align-content:space-between;gap:20px}.profile-button{width:100%}.profile-prompt h2{color:var(--brand);overflow-wrap:anywhere}.section-divider{height:1px;background:var(--line);margin:8px 0}.add-class-form{display:grid;grid-template-columns:minmax(180px,1fr) auto;gap:10px;margin-bottom:14px}.class-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.class-card{border:1px solid var(--line);border-radius:8px;padding:18px;display:grid;gap:16px;background:#fff}.class-card dl,.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:0}.details-grid.compact{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.class-card dt,.detail-item dt{color:var(--muted);font-size:12px;font-weight:800}.class-card dd,.detail-item dd{margin:3px 0 0;color:var(--ink);font-weight:750;overflow-wrap:anywhere}.empty-state{border:1px dashed var(--line);border-radius:8px;padding:24px;background:#fbfdfc}.status-message{border-radius:8px;padding:12px 14px;font-weight:750;line-height:1.45}.status-message.info{background:var(--brand-soft);color:var(--brand)}.status-message.success{background:#e8f4ee;color:var(--green)}.status-message.danger{background:#fff1f0;color:var(--danger)}.status-badge{width:fit-content;display:inline-flex;align-items:center;min-height:28px;border-radius:999px;padding:0 10px;font-size:12px;font-weight:850}.status-badge.brand{color:var(--brand);background:var(--brand-soft)}.status-badge.orange{color:var(--orange);background:#fff3e6}.status-badge.red{color:var(--danger);background:#fff1f0}.status-badge.green{color:var(--green);background:#e8f4ee}.class-overview{background:var(--brand);color:#fff}.class-overview .eyebrow,.class-overview .status-badge{color:#fff}.class-overview .status-badge{background:#ffffff24}.class-meta-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;color:#ffffffdb;font-weight:750}.action-card-grid{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:14px}.class-action-card{min-height:150px;padding:18px;color:#fff;display:flex;flex-direction:column;justify-content:space-between;font-size:18px;font-weight:850}.class-action-card.orange{background:var(--orange)}.class-action-card.purple{background:var(--purple)}.class-action-card.green{background:var(--green)}.class-action-card.red{background:var(--danger)}.class-action-card.blue{background:var(--blue)}.task-card,.submission-card{padding:18px;display:grid;gap:14px}.task-details{border-top:1px solid var(--line);padding-top:14px}.check-row{display:flex;align-items:center;gap:9px;min-height:44px;color:var(--brand);font-weight:800}.submission-heading,.table-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.tabs{background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px;width:fit-content}.metric-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.metric-strip>div{padding:18px;color:var(--muted);font-weight:800}.metric-strip span{display:block;color:var(--brand);font-size:32px}.table-list{display:grid;gap:12px}.table-row{padding:14px}.center-state,.pending-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.pending-panel{max-width:560px;padding:28px}.pending-panel h1{margin-bottom:10px}@media (max-width: 1120px){.action-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 860px){.auth-page,.app-shell,.student-home-grid{grid-template-columns:1fr}.auth-hero{min-height:300px}.auth-panel{max-height:none;margin:-40px auto 28px}.sidebar{position:static;height:auto;padding:18px}.main-shell{padding:18px}.topbar{align-items:stretch;flex-direction:column}.topbar-card{max-width:100%;width:100%}.metric-strip{grid-template-columns:1fr}}@media (max-width: 640px){.form-grid,.form-grid.two,.class-card dl,.details-grid,.details-grid.compact,.add-class-form,.action-card-grid{grid-template-columns:1fr}.section-header,.submission-heading,.table-row{align-items:stretch;flex-direction:column}.section-actions,.tabs{width:100%}.tabs button,.filter-chip{flex:1;justify-content:center}.auth-panel{width:calc(100% - 24px);padding:18px}.class-action-card{min-height:116px}}
