:root{font-family:Manrope,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:500;color:#0f172a;background-color:#fff7f2;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 20%,#ffe1d4,#fff7f2 45%),radial-gradient(circle at 80% 0%,#ffd5c2,#fff7f2 40%);color:#0f172a;overflow-x:hidden}a{color:inherit;text-decoration:none}#app{max-width:1200px;margin:0 auto;padding:20px;overflow-x:hidden}.page{display:flex;flex-direction:column;gap:20px;width:100%}.hero{background:linear-gradient(135deg,#ff4800,#ff814f);color:#fff6f0;border-radius:24px;padding:28px;display:grid;grid-template-columns:2fr 1fr;gap:24px;max-width:100%}.hero__text h1{margin:0 0 8px;font-size:34px;letter-spacing:-.5px}.hero__text .lede{margin:0 0 16px;color:#ffe3d2}.hero__aside{display:flex;align-items:center;justify-content:flex-end}.status-card{background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:16px;width:100%}.status-label{margin:0;font-size:13px;text-transform:uppercase;letter-spacing:1px;color:#ffe3d2}.status-value{margin:4px 0;font-size:20px;font-weight:700}.status-note{margin:0;color:#ffe3d2;font-size:14px}.hero__chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.eyebrow{margin:0;text-transform:uppercase;letter-spacing:1px;font-size:12px;color:#64748b}.panel{background:#fff;border-radius:20px;padding:18px;border:1px solid #ffd5c2;box-shadow:0 10px 30px #ff480014;max-width:100%;overflow:hidden}.panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.panel h2{margin:6px 0 0;font-size:24px}.grade-list{display:flex;flex-wrap:wrap;gap:10px}.chip{border-radius:999px;padding:8px 14px;font-weight:600;border:1px solid transparent}.chip.muted{border-color:#ffffff4d;color:#ffe3d2;background:#ffffff1f}.chip.selectable{background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a;cursor:pointer;transition:all .2s ease}.chip.selectable:hover{border-color:#94a3b8;transform:translateY(-1px)}.chip.selectable.active{background:#ff4800;color:#fff;border-color:#ff4800;box-shadow:0 8px 20px #ff480040}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}.card{border:1px solid #e2e8f0;border-radius:16px;padding:14px;background:#fdfefe;display:flex;flex-direction:column;gap:10px;max-width:100%;overflow:hidden}.card__eyebrow{margin:0;font-size:12px;letter-spacing:.5px;color:#64748b;text-transform:uppercase}.card h3{margin:4px 0 6px;font-size:18px}.card__desc{margin:0;color:#334155;word-break:break-word}.thumb-grid{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.thumb img{width:160px;height:120px;border-radius:12px;border:1px solid #e2e8f0;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;display:block}.thumb:hover img{transform:scale(1.01);box-shadow:0 8px 20px #0f172a26}.code-block{background:#0f172a;color:#e2e8f0;border-radius:12px;padding:10px;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;overflow-x:auto}.code-block pre{margin:0;white-space:pre-wrap;word-break:break-word}.code-title{margin:0 0 6px;color:#cbd5e1;font-size:12px;letter-spacing:1px;text-transform:uppercase}.materials{display:flex;flex-direction:column;gap:12px}.material{border:1px solid #e2e8f0;border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:8px;background:linear-gradient(145deg,#fff,#fff5ee);max-width:100%;overflow:hidden}.material__image img{width:160px;height:120px;border-radius:10px;border:1px solid #e2e8f0;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;display:block}.material__image{display:flex;justify-content:center}.material__image a:hover img{transform:scale(1.01);box-shadow:0 8px 20px #0f172a26}.attachments{border-top:1px dashed #e2e8f0;padding-top:8px}.attachment-list{display:flex;gap:8px;flex-wrap:wrap}.submission{border-top:1px dashed #e2e8f0;padding-top:10px;display:flex;flex-direction:column;gap:8px}.input{width:100%;border:1px solid #cbd5e1;border-radius:10px;padding:10px;font-family:inherit;resize:vertical;min-height:80px}.file-label{font-size:14px;color:#475569;display:inline-flex;align-items:center;gap:6px}.file-label input{cursor:pointer}.submit-btn{background:#ff4800;color:#fff;border:none;border-radius:12px;padding:10px 14px;font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.submit-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px #ff480033}.material__links{display:flex;gap:12px;flex-wrap:wrap}.link{color:#0f172a;font-weight:700;background:#ffe7dc;padding:8px 12px;border-radius:999px;border:1px solid transparent;transition:all .2s ease}.link:hover{border-color:#ff4800;transform:translateY(-1px)}.muted-text{color:#94a3b8;margin:8px 0}.tiny-status{background:#ff4800;color:#fff;padding:6px 10px;border-radius:999px;font-size:12px}.error-text{color:#b91c1c;margin:10px 0 0}@media(max-width:920px){.hero{grid-template-columns:1fr}.hero__aside{justify-content:flex-start}#app{padding:14px}}@media(max-width:640px){:root{font-size:15px}.hero__text h1{font-size:24px}.panel h2{font-size:20px}.card-grid{grid-template-columns:1fr}.thumb img,.material__image img{width:140px;height:105px}}
