:root{--blue-700: #007aff;--blue-800: #0066d6;--ink-950: #091223;--ink-800: #1c2740;--ink-500: #5a6a87;--white: #ffffff;--orange: #f2aa3c;--orange-700: #d88f20;--border: rgba(9, 18, 35, .1);--card-shadow: 0 20px 50px rgba(9, 18, 35, .12)}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:Nunito,system-ui,sans-serif;color:var(--ink-950);background:#fff}body:has(.app-shell),body:has(.landing-shell){background:var(--blue-700)}img{max-width:100%;display:block}button,input,textarea{font:inherit}input,textarea{width:100%;border:1px solid rgba(28,39,64,.18);border-radius:12px;padding:.8rem .9rem;background:#fff;color:var(--ink-950);transition:border-color .12s ease,box-shadow .12s ease}textarea{resize:vertical;min-height:110px}input:focus,textarea:focus{outline:none;border-color:var(--blue-700);box-shadow:0 0 0 4px #007aff1f}.landing-shell,.app-shell{min-height:100vh;padding:1rem}.site-header,.app-topbar{max-width:1180px;margin:0 auto;padding:.9rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;border:1px solid rgba(255,255,255,.2);border-radius:18px;box-shadow:0 10px 30px #0912230f}.site-header{background:var(--blue-700)}.landing-shell{padding:0;background:var(--blue-700)}.site-header{max-width:none;margin:0;border-radius:0;border:0;border-bottom:2px solid #ffffff;padding-left:1rem;padding-right:1rem}.app-shell{padding:0;background:var(--blue-700);display:flex;flex-direction:column;height:100vh}.app-topbar{max-width:none;margin:0;border-radius:0;border:0;border-bottom:2px solid #ffffff;padding-left:1rem;padding-right:1rem}.brand{display:flex;align-items:center;gap:.85rem;color:inherit;text-decoration:none;min-width:0}.brand img{width:70px;height:70px}.brand-copy{display:flex;flex-direction:column;line-height:1.05;min-width:0}.brand-name{color:var(--white);font-size:3rem;font-weight:700;display:inline-block;transform:scaleX(1);transform-origin:left center}.brand-tagline{color:var(--orange);font-size:.9rem;font-weight:700;margin-top:.25rem;white-space:nowrap}.site-nav{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;justify-content:flex-end}.site-nav a,.site-nav button{border:1px solid transparent;border-radius:12px;padding:.55rem .8rem;background:transparent;color:#fffffff5;font-weight:800;text-decoration:none;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.site-nav a:hover,.site-nav button:hover,.site-nav button.active,.site-nav a.active{background:transparent;border-color:var(--orange);color:var(--orange)}.nav-divider{width:1px;height:1.2rem;background:#fff6;align-self:center}.landing-main{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;flex-direction:column;gap:3rem}.landing-main.auth-open{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:1rem;align-items:start}.hero-panel{background:linear-gradient(160deg,var(--blue-700),#2190ff 55%,#4ca3ff 100%);color:var(--white);border-radius:24px;padding:2.5rem 2.5rem 2rem;border:1px solid rgba(255,255,255,.25);box-shadow:var(--card-shadow);overflow:hidden;margin-top:2.5rem}.hero-top{display:flex;align-items:center;gap:2.5rem}.hero-text{flex:1;min-width:0}.hero-showcase{flex-shrink:0}.hero-showcase-img{width:220px;border-radius:12px;box-shadow:0 8px 32px #00000040}.eyebrow{margin:0;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;font-weight:800;color:var(--orange)}.hero-panel h1{margin:.75rem 0 0;font-size:clamp(1.6rem,2.8vw,2.4rem);line-height:1.12}.hero-copy{margin:1rem 0 0;color:#ffffffeb;font-size:1rem;line-height:1.6}.hero-actions{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:.75rem}.cta-button-primary{display:inline-block;background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff;border-radius:12px;padding:.85rem 2rem;font-weight:800;font-size:1.05rem;text-decoration:none;cursor:pointer;border:none;transition:background .12s ease,transform 80ms ease;box-shadow:0 4px 14px #00000026}.cta-button-primary:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700));transform:translateY(-1px)}.ghost-button{border:1px solid rgba(255,255,255,.26);background:#ffffff1f;color:#fff;border-radius:12px;padding:.75rem .95rem;font-weight:800;cursor:pointer;transition:background-color .12s ease,border-color .12s ease;text-decoration:none}.ghost-button:hover{background:#ffffff2e;border-color:#ffffff61}.section-heading{color:#fff;font-size:clamp(1.5rem,2.5vw,2rem);text-align:center;margin:0}.section-subheading{color:#ffffffd9;font-size:1.05rem;text-align:center;max-width:56ch;margin:.75rem auto 0;line-height:1.55}.features-section{padding:0}.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-top:2rem}.feature-card{background:#ffffff1f;border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:1.25rem;transition:background .15s ease,transform .15s ease}.feature-card:hover{background:#ffffff2e;transform:translateY(-2px)}.feature-img{width:100%;border-radius:10px;box-shadow:0 4px 16px #0000002e;margin-bottom:1rem}.feature-card h3{color:#fff;font-size:1.1rem;margin:0 0 .4rem}.feature-card p{color:#ffffffd9;font-size:.92rem;line-height:1.5;margin:0}.highlights-section{padding:0}.highlights-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.25rem;margin-top:2rem}.highlight-card{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:1.5rem;text-align:center}.highlight-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:#ffffff1f;color:var(--orange);margin-bottom:1rem}.highlight-card h3{color:#fff;font-size:1.05rem;margin:0 0 .5rem}.highlight-card p{color:#ffffffd9;font-size:.92rem;line-height:1.5;margin:0}.download-section{background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:2.5rem 2rem;text-align:center}.download-copy{color:#ffffffe6;font-size:1.05rem;max-width:52ch;margin:.75rem auto 0;line-height:1.55}.store-badges{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:1.75rem;flex-wrap:wrap}.store-badge{height:auto;transition:opacity .15s ease,transform .15s ease}.store-badge.app-store-badge{width:160px}.store-badge.google-play-badge{width:200px}.store-badge:hover{opacity:.85;transform:translateY(-1px)}.download-note{margin-top:1.5rem;color:#ffffffbf;font-size:.95rem}.download-note a{color:var(--orange);font-weight:700;text-decoration:none}.download-note a:hover{text-decoration:underline}.contact-section{display:flex;justify-content:center}.hero-contact{display:inline-flex;gap:.5rem;flex-wrap:wrap;align-items:center;padding:.65rem .85rem;border-radius:12px;background:#ffffff1f}.hero-contact span{color:#ffffffd9;font-weight:700}.hero-contact a{color:#fff;font-weight:800;text-decoration:none}.hero-contact a:hover{text-decoration:underline}.landing-footer{max-width:1100px;margin:0 auto;padding:2rem 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;color:#ffffff8c;font-size:.82rem}.footer-links{display:flex;gap:1.25rem}.footer-links a{color:#ffffff8c;text-decoration:none;font-size:.82rem}.footer-links a:hover{color:#ffffffd9}.auth-panel{width:100%}.auth-card{background:#f3f4f6;border:1px solid rgba(28,39,64,.08);border-radius:24px;padding:1.2rem;box-shadow:var(--card-shadow)}.card-header h2{margin:.3rem 0 0;font-size:1.4rem;color:var(--ink-950)}.card-header .eyebrow{color:var(--blue-800)}.auth-form{margin-top:1rem;display:grid;gap:.85rem}.auth-form label{display:grid;gap:.35rem;color:var(--ink-800);font-weight:700;font-size:.95rem}.primary-button{border:0;border-radius:12px;padding:.85rem 1rem;background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff;font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;box-shadow:0 10px 20px #f2aa3c47}.primary-button:hover{transform:translateY(-1px);box-shadow:0 14px 24px #f2aa3c52}.primary-button:active{transform:translateY(0)}.form-alert{margin:.9rem 0 0;border-radius:12px;border:1px solid rgba(179,39,39,.22);background:#fff2f2;color:#8d2323;padding:.75rem .85rem;font-weight:700}.app-topbar{background:var(--blue-700)}.app-topbar .brand-name{color:var(--white)}.app-topbar .brand-tagline{color:var(--orange)}.app-topbar-controls{display:flex;align-items:center;gap:.85rem;min-width:0}.app-menu{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.app-menu button,.app-menu a{border:1px solid transparent;border-radius:12px;padding:.55rem .8rem;background:transparent;color:#fffffff5;font-weight:800;text-decoration:none;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.app-menu button:hover,.app-menu a:hover{background:transparent;color:var(--orange);border-color:var(--orange)}.app-menu button.active,.app-menu a.active{background:#ffffff0f;border-color:var(--orange);color:var(--orange)}.app-topbar-divider{width:1px;height:26px;background:#ffffff47}.app-signout{border:1px solid rgba(255,255,255,.28);background:#ffffff1f;color:#fff;border-radius:12px;padding:.65rem .9rem;font-weight:800;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.app-signout:hover{background:#ffffff2e;border-color:#ffffff61}.tab-panel{width:100%;max-width:none;margin:0;min-height:0;flex:1 1 0;overflow-y:auto;overflow-x:hidden;background:transparent;border:0;border-radius:0;box-shadow:none;padding:1.25rem 1rem}.tab-panel h2{margin:0;font-size:1.25rem;color:var(--white)}.tab-panel p{margin:.5rem 0 0;color:#ffffffe0}.students-panel-header{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:1rem}.students-panel-header p{margin:0;font-size:.95rem;color:#ffffffd1}.students-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.students-scroll-area,.portfolio-scroll-area,.subject-scroll-area{flex:1 1 0;min-height:0;overflow-y:auto}.portfolio-page,.subject-page{display:flex;flex-direction:column;height:100%;overflow:hidden}.students-header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}.students-header-divider{width:1px;height:26px;background:#ffffff47}.student-create-button{border:1px solid rgba(255,255,255,.28);background:#ffffff1f;color:#fff;border-radius:12px;padding:.65rem .9rem;font-weight:800;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.student-edit-button{border:1px solid rgba(255,255,255,.28);background:#ffffff14;color:#fff;border-radius:12px;padding:.65rem .9rem;font-weight:800;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.student-edit-button:hover{background:#ffffff24;border-color:#ffffff61}.student-create-button:hover{background:#ffffff2e;border-color:#fff6}.student-modal-backdrop{position:fixed;inset:0;background:#080e1a94;display:grid;place-items:center;padding:1rem;overflow-y:auto;z-index:50}.student-modal{width:min(100%,540px);border-radius:18px;border:1px solid rgba(28,39,64,.08);background:#f3f4f6;box-shadow:var(--card-shadow);padding:1rem}.student-modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.student-modal-header h3{margin:0;color:var(--ink-950);font-size:1.15rem}.student-modal-close{width:34px;height:34px;border-radius:999px;border:1px solid rgba(0,122,255,.2);background:#fff;color:var(--blue-700);cursor:pointer;font-size:1.4rem;line-height:1}.student-create-form{display:grid;gap:1rem}.student-delete-modal{width:min(100%,500px)}.student-modal.student-avatar-editor-modal{width:min(100%,540px);background:#f3f4f6}.student-modal .student-delete-copy{margin:.25rem 0 .9rem;color:var(--ink-950);line-height:1.35}.avatar-editor-shell{display:grid;gap:.9rem}.avatar-editor-stage-wrap{display:grid;justify-content:center}.avatar-editor-stage{position:relative;width:280px;height:280px;display:grid;place-items:center;touch-action:none;-webkit-user-select:none;user-select:none;overflow:hidden;border-radius:12px}.avatar-editor-circle-mask{position:relative;width:280px;height:280px;border-radius:50%;overflow:hidden;border:2px solid #ffffff;background:#dfe5ef;display:grid;place-items:center;z-index:1}.avatar-editor-circle-mask img{position:absolute;top:50%;left:50%;transform-origin:center center;translate:-50% -50%;max-width:none;max-height:none;-webkit-user-select:none;user-select:none;pointer-events:none;cursor:grab}.avatar-editor-circle-mask img.dragging{cursor:grabbing}.avatar-editor-dim-layer{position:absolute;inset:0;border-radius:50%;pointer-events:none;box-shadow:0 0 0 9999px #09122347}.avatar-editor-zoom-control{display:grid;gap:.35rem;color:var(--ink-800);font-weight:700}.avatar-editor-zoom-control input[type=range]{width:100%;padding:0;background:transparent;border:0;box-shadow:none}.student-avatar-editor-modal .avatar-editor-hint{margin:0;color:var(--ink-950);font-size:.95rem}.student-create-avatar-wrap{display:grid;justify-items:center;gap:.65rem;padding:.4rem 0 .2rem}.student-create-avatar-preview{width:118px;height:118px;border-radius:50%;object-fit:cover;border:2px solid #ffffff;background:#ffffff14}.student-create-avatar-placeholder{display:grid;place-items:center;color:#80e7d8}.student-create-avatar-placeholder svg{width:68px;height:68px}.student-create-file-input{display:none}.student-create-avatar-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.55rem}.student-file-button{border:1px solid rgba(0,122,255,.18);background:#007aff1a;color:var(--blue-800);border-radius:10px;padding:.5rem .75rem;font-weight:700;cursor:pointer}.student-file-button-secondary{color:var(--blue-700)}.student-create-field{display:grid;gap:.45rem}.student-create-field span{color:var(--ink-800);font-weight:700;font-size:.95rem}.required-field-label{display:inline-flex;align-items:center;gap:.2rem}.student-create-field .required-indicator{color:#c81e1e;font-weight:800;line-height:1}.student-create-field input{border-radius:12px;border:1px solid rgba(28,39,64,.18);background:#fff;color:var(--ink-950);padding:.75rem .85rem;font-size:1rem}.student-create-field input::placeholder{color:var(--ink-500)}.student-create-field input:focus{outline:none;border-color:var(--blue-700);box-shadow:0 0 0 4px #007aff1f}.student-create-error{margin:0;border-radius:12px;border:1px solid rgba(255,117,117,.32);background:#b327272e;color:#ffd8d8;padding:.7rem .8rem;font-weight:700}.student-create-form-actions{display:flex;justify-content:flex-end;gap:.6rem}.student-secondary-button,.student-primary-button{border-radius:12px;padding:.65rem .9rem;font-weight:800;cursor:pointer}.student-danger-button{border-radius:12px;padding:.65rem .9rem;font-weight:800;cursor:pointer;border:1px solid rgba(201,43,43,.28);background:linear-gradient(180deg,#f25858,#d93a3a);color:#fff;box-shadow:0 10px 20px #c92b2b38}.student-danger-button:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.student-secondary-button{border:1px solid rgba(0,122,255,.18);background:#fff;color:var(--blue-700)}.student-primary-button{border:1px solid rgba(0,122,255,.28);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff;box-shadow:0 10px 20px #007aff38}.students-status{margin-top:1rem}.students-status-error{color:#ffd8d8}.students-empty{margin-top:1.25rem;min-height:220px;display:grid;place-items:center;gap:.6rem;align-content:center;border-radius:16px;border:1px dashed rgba(255,255,255,.24);background:#ffffff0a;padding:1.5rem;text-align:center}.students-empty p{margin:0}.students-empty-icon{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-size:1.6rem;background:#ffffff14}.students-grid{margin-top:1.2rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem 1.1rem}.student-tile{display:grid;justify-items:center;align-content:start;gap:.7rem;min-width:0}.student-avatar-wrap{position:relative;width:124px;height:124px}.student-tile-link{display:block;border-radius:50%}.student-avatar{width:124px;height:124px;border-radius:50%;object-fit:cover;display:block;background:#ffffff14;border:2px solid #ffffff}.student-delete-chip{position:absolute;top:-6px;right:-6px;width:34px;height:34px;border-radius:999px;border:2px solid #e14343;background:#fff;color:#e14343;display:grid;place-items:center;font-size:1.45rem;line-height:1;font-weight:900;cursor:pointer;box-shadow:0 8px 16px #1e15153d}.student-delete-chip:hover{background:#fff5f5}.student-delete-chip.selected{border-color:#fff;background:#e14343;color:#fff}.student-avatar-placeholder{display:grid;place-items:center;color:#80e7d8}.student-avatar-placeholder svg{width:74px;height:74px}.student-name{margin:0;font-size:1.2rem;font-weight:700;color:#fff;text-align:center;line-height:1.2;overflow-wrap:anywhere}.student-name-link{text-decoration:none}.student-name-link:hover{text-decoration:underline}.student-detail-backlink{display:inline-flex;align-items:center;gap:.35rem;color:#fff;text-decoration:none;font-weight:700;margin-bottom:1rem}.student-detail-backlink:hover{text-decoration:underline}.student-detail-header{display:grid;justify-items:center;text-align:center;gap:.8rem;padding:.25rem 0 1rem}.student-detail-avatar-button{appearance:none;border:0;background:transparent;padding:0;margin:0;cursor:pointer;border-radius:999px}.student-detail-avatar-button:focus-visible{outline:2px solid rgba(255,255,255,.85);outline-offset:4px}.student-detail-avatar{width:148px;height:148px;border-radius:50%;object-fit:cover;border:2px solid #ffffff;background:#ffffff14;flex-shrink:0}.student-detail-title h2{margin:0}.student-detail-name-button{appearance:none;border:0;background:transparent;padding:0;margin:0;color:#fff;font-size:1.8rem;font-weight:700;cursor:pointer}.student-detail-name-button:hover{text-decoration:underline}.student-detail-name-button:focus-visible{outline:2px solid rgba(255,255,255,.85);outline-offset:4px;border-radius:8px}.student-portfolios-panel{margin-top:.4rem;width:min(100%,760px);margin-left:auto;margin-right:auto;border-radius:16px;border:1px solid rgba(28,39,64,.08);background:#f2f2f7;padding:.9rem}.student-portfolios-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.65rem}.student-portfolios-header .students-header-controls{align-items:center}.student-portfolios-header h3{margin:0;color:var(--ink-950);font-size:1.1rem}.student-portfolios-header p{margin:0;color:var(--ink-500);font-size:.95rem}.student-portfolios-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.student-portfolios-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.student-portfolios-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.student-portfolios-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.student-transcript-button{border:1px solid var(--blue-700, #007AFF);background:#fff;color:var(--blue-700, #007AFF);border-radius:12px;padding:.65rem .9rem;font-weight:800;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.student-transcript-button:hover{background:#f0f5ff}.student-portfolios-panel .students-header-divider{background:#0003}.student-portfolios-panel .student-portfolios-empty{color:var(--ink-500);border-color:#1c274026;background:#00000005}.student-portfolios-panel .student-portfolios-empty p{color:var(--ink-500)}.student-create-portfolio-modal{width:min(100%,620px)}.portfolio-subjects-editor{display:grid;gap:.6rem;border-radius:12px;border:1px solid rgba(28,39,64,.12);background:#fff;padding:.75rem}.portfolio-subjects-editor-header{color:var(--ink-800);font-weight:700;font-size:.95rem}.portfolio-subjects-add-row{display:grid;grid-template-columns:1fr auto;gap:.55rem;align-items:center}.portfolio-subjects-empty{margin:0;color:var(--ink-500);font-size:.95rem}.portfolio-subjects-list{list-style:none;margin:0;padding:0;display:grid;gap:.45rem}.portfolio-subjects-list li{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center}.portfolio-subject-chip{display:inline-flex;align-items:center;min-height:38px;padding:.45rem .65rem;border-radius:10px;border:1px solid rgba(0,122,255,.12);background:#007aff0f;color:var(--ink-950);font-weight:700;overflow-wrap:anywhere}.portfolio-subject-remove{width:34px;height:34px;border-radius:999px;border:1px solid rgba(201,43,43,.18);background:#c92b2b14;color:#c92b2b;cursor:pointer;font-size:1.2rem;line-height:1}.transcript-modal{width:min(100%,1200px);height:92vh;display:flex;flex-direction:column}.transcript-editor-layout{flex:1 1 auto;display:flex;min-height:0}.transcript-live-preview-panel{flex:1 1 50%;display:flex;flex-direction:column;padding:.75rem;border-right:1px solid rgba(28,39,64,.1);min-width:0}.transcript-live-preview-iframe{flex:1 1 auto;border:1px solid rgba(28,39,64,.1);border-radius:8px;width:100%;min-height:0}.transcript-live-preview-placeholder{flex:1 1 auto;display:flex;align-items:center;justify-content:center;border:1px dashed rgba(28,39,64,.15);border-radius:8px;background:#fafafa}.transcript-live-preview-placeholder p{color:#999!important;font-size:.9rem}.transcript-live-preview-panel .transcript-pdf-actions{padding-top:.6rem}.transcript-form-scroll{flex:1 1 50%;overflow-y:auto;padding:.75rem 1.25rem 1.25rem;display:grid;gap:1rem;align-content:start;min-width:0}.transcript-modal .transcript-loading{text-align:center;color:#1c2740!important;padding:2rem 0}.transcript-section{display:grid;gap:.6rem}.transcript-section-label{font-weight:700;font-size:.95rem;color:var(--ink-800)}.transcript-color-swatches{display:flex;flex-wrap:wrap;gap:8px}.transcript-color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:transform .15s ease,border-color .15s ease}.transcript-color-swatch:hover{transform:scale(1.12)}.transcript-color-swatch.selected{border-color:#fff;box-shadow:0 0 0 2px #00000059}.transcript-color-swatch .swatch-check{width:16px;height:16px}.transcript-toggle-row{display:flex;align-items:center;gap:.6rem;font-size:.95rem;color:var(--ink-800);cursor:pointer}.transcript-toggle-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--blue-700)}.transcript-grade-book-card{border:1px solid rgba(28,39,64,.12);border-radius:10px;background:#fff;overflow:hidden}.transcript-gb-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;background:#f5f5fa;border-bottom:1px solid rgba(28,39,64,.08);gap:.5rem}.transcript-gb-name{font-weight:600;font-size:.95rem;color:var(--ink-950)}.transcript-gb-actions{display:flex;gap:.35rem}.transcript-gb-inline-btn{background:none;border:none;font-size:.82rem;color:var(--blue-700);cursor:pointer;padding:.2rem .5rem;border-radius:6px}.transcript-gb-inline-btn:hover{background:#007aff14}.transcript-gb-inline-btn.save{color:#34c759;font-weight:600}.transcript-gb-inline-btn.danger{color:#ff3b30}.transcript-gb-inline-btn.danger:hover{background:#ff3b3014}.transcript-gb-reorder-btn{background:none;border:none;font-size:.7rem;color:var(--ink-500);cursor:pointer;padding:.15rem .35rem;border-radius:4px;line-height:1;transition:color .12s,background .12s}.transcript-gb-reorder-btn:hover:not(:disabled){color:var(--blue-700);background:#007aff14}.transcript-gb-reorder-btn:disabled{opacity:.25;cursor:default}.transcript-gb-edit-name-row{display:flex;align-items:center;gap:.4rem;flex:1}.transcript-gb-name-input{flex:1;font-size:.9rem;padding:.3rem .5rem;border:1px solid rgba(28,39,64,.15);border-radius:6px}.transcript-grades-table{width:100%;border-collapse:collapse;font-size:.85rem}.transcript-grades-table th{text-align:left;padding:.4rem .6rem;font-weight:600;font-size:.78rem;color:var(--ink-500);border-bottom:1px solid rgba(28,39,64,.08);text-transform:uppercase;letter-spacing:.03em}.transcript-grades-table td{padding:.4rem .6rem;border-bottom:1px solid rgba(28,39,64,.05);color:var(--ink-950)}.transcript-grades-table tr:last-child td{border-bottom:none}.transcript-grade-reorder-cell{width:52px;padding:.2rem .3rem!important}.transcript-grade-reorder-cell-inner{display:flex;gap:4px;justify-content:center}.transcript-grade-move-btn{background:none;border:1px solid rgba(28,39,64,.12);border-radius:4px;color:var(--ink-500);cursor:pointer;font-size:.7rem;width:22px;height:22px;display:flex;align-items:center;justify-content:center;padding:0;transition:color .12s ease,background .12s ease}.transcript-grade-move-btn:hover:not(:disabled){color:var(--blue-700);background:#007aff14;border-color:#007aff33}.transcript-grade-move-btn:disabled{color:#0000001f;border-color:#0000000f;cursor:default}.transcript-grades-table th,.transcript-grades-table td{text-align:center}.transcript-grades-table th:nth-child(2),.transcript-grades-table td:nth-child(2){text-align:left;min-width:120px}.transcript-address-textarea{width:100%;resize:none;font-family:inherit;font-size:.92rem;line-height:1.4;padding:.35rem .5rem;border:1px solid rgba(28,39,64,.15);border-radius:6px;color:var(--ink-950);background:#fff}.transcript-address-textarea:focus{outline:none;border-color:var(--blue-700)}.transcript-grade-inline-input{width:100%;border:1px solid transparent;border-radius:4px;padding:.2rem .35rem;font-size:.85rem;color:var(--ink-950);background:transparent;transition:border-color .12s ease,background .12s ease}.transcript-grade-inline-input:hover{border-color:#1c274026;background:#fff}.transcript-grade-inline-input:focus{outline:none;border-color:var(--blue-700);background:#fff}.transcript-grade-inline-short{width:60px;text-align:center}.transcript-grade-course-input{resize:none;overflow:hidden;font-family:inherit;line-height:1.3;text-align:left;min-height:2.4em}.transcript-grade-remove-btn{background:none;border:none;color:#ff3b30;cursor:pointer;font-size:1.1rem;padding:0 .3rem;line-height:1}.transcript-empty-text{margin:0;color:#1c2740!important;font-size:.9rem;padding:.5rem 0}.transcript-empty-grades{padding:.75rem}.transcript-add-grade-form{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:.4rem;padding:.6rem .75rem;border-top:1px solid rgba(28,39,64,.08)}.transcript-add-grade-form input{font-size:.85rem;padding:.35rem .5rem;border:1px solid rgba(28,39,64,.15);border-radius:6px}.transcript-add-grade-actions{grid-column:1 / -1;display:flex;gap:.4rem;justify-content:flex-end}.transcript-add-grade-btn{background:none;border:none;color:var(--blue-700);cursor:pointer;font-size:.85rem;padding:.5rem .75rem;text-align:left;border-top:1px solid rgba(28,39,64,.08)}.transcript-add-grade-btn:hover{background:#007aff0d}.transcript-add-gb-row{display:grid;grid-template-columns:1fr auto;gap:.55rem;align-items:center}.transcript-add-gb-row input{font-size:.9rem;padding:.45rem .6rem;border:1px solid rgba(28,39,64,.15);border-radius:8px}.transcript-test-scores-list{list-style:none;margin:0;padding:0;display:grid;gap:.35rem}.transcript-test-scores-list li{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:#f5f5fa;border-radius:8px;font-size:.9rem;color:var(--ink-950)}.transcript-test-score-reorder{display:flex;gap:4px;flex-shrink:0}.transcript-test-score-text{flex:1;min-width:0}.transcript-pdf-actions{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap}.transcript-action-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .85rem;font-size:.85rem;font-weight:600;color:var(--ink-950);background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;transition:background .12s ease}.transcript-action-btn:hover{background:#e5e7eb}.student-portfolios-empty{border-radius:12px;border:1px dashed rgba(255,255,255,.22);background:#ffffff08;padding:1rem;text-align:center}.student-portfolios-empty p{margin:0}.textbooks-panel>.student-portfolios-empty,.resources-panel>.student-portfolios-empty{margin-top:.75rem}.student-portfolio-list{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}.student-portfolio-row-wrap{position:relative}.student-portfolio-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;border-radius:12px;border:1px solid rgba(28,39,64,.08);background:#fff;padding:.7rem .8rem;text-decoration:none;color:var(--ink-950)}.student-portfolio-row-editing{padding-left:3rem}.student-portfolio-row[aria-disabled=true]{cursor:default}.student-portfolio-row:hover{background:#f9f9fb;border-color:#1c27402e}.student-portfolio-icon{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;background:#fff}.student-portfolio-name{font-weight:400;color:var(--ink-950);min-width:0;overflow-wrap:anywhere}.student-portfolio-chevron{color:var(--ink-500);font-size:1.15rem}.student-portfolio-delete-chip{position:absolute;top:50%;left:10px;transform:translateY(-50%);width:28px;height:28px;font-size:1.2rem;border-width:1px;z-index:2;background:#fff;border-color:#e14343;color:#e14343}.student-portfolio-delete-chip:hover{background:#fff5f5}.student-portfolio-delete-chip.selected{background:#e14343;border-color:#fff;color:#fff}.portfolio-shell-topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.6rem;margin-bottom:.6rem}.portfolio-student-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:1px solid #ffffff;background:#ffffff14}.portfolio-shell-topbar h2{margin:0;text-align:center}.portfolio-title-button{border:1px solid transparent;background:transparent;color:#fff;font-size:1.85rem;font-weight:700;line-height:1.2;padding:.1rem .35rem;border-radius:10px;cursor:pointer}.portfolio-title-button:hover{border-color:#fff6}.portfolio-title-button:focus-visible{outline:2px solid rgba(255,255,255,.85);outline-offset:3px}.portfolio-backlink{margin-bottom:0}.portfolio-topbar-right{justify-self:end;min-width:72px;min-height:72px;display:grid;align-items:center;justify-items:center;gap:.28rem;text-align:center;padding-right:.7rem}.portfolio-sections-nav{display:flex;gap:.55rem;flex-wrap:wrap;justify-content:center;margin-bottom:.9rem}.portfolio-section-link{text-decoration:none;border:1px solid transparent;border-radius:12px;padding:.55rem .8rem;background:transparent;color:#fffffff5;font-weight:800;line-height:1.15;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.portfolio-section-link:hover{background:transparent;border-color:var(--orange);color:var(--orange)}.portfolio-section-link.active{background:#ffffff0f;border-color:var(--orange);color:var(--orange)}.portfolio-section-stub{border-radius:16px;border:1px solid rgba(255,255,255,.18);background:#ffffff0f;padding:1rem;min-height:220px}.student-rename-portfolio-modal{width:min(100%,520px)}.curriculum-panel{width:min(100%,860px);margin-left:auto;margin-right:auto;background:#f2f2f7}.curriculum-panel.portfolio-section-stub h3{color:var(--ink-950)}.curriculum-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.curriculum-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.curriculum-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.curriculum-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.curriculum-panel .students-header-divider{background:#0003}.curriculum-panel .student-portfolios-empty,.curriculum-panel .student-portfolios-empty p{color:var(--ink-500)}.curriculum-panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.curriculum-panel-header .students-header-controls{align-items:center}.portfolio-section-stub h3{margin:0;color:#fff;font-size:1.2rem}.portfolio-section-stub p{margin:.55rem 0 0;color:#ffffffdb}.work-samples-panel{width:min(100%,860px);margin-left:auto;margin-right:auto;background:#f2f2f7}.work-samples-panel.portfolio-section-stub h3{color:var(--ink-950)}.work-samples-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.work-samples-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.work-samples-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.work-samples-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.work-samples-panel .students-header-divider{background:#0003}.work-samples-panel .student-portfolios-empty,.work-samples-panel .student-portfolios-empty p{color:var(--ink-500)}.work-samples-panel .work-sample-row{background:#fff;border-color:#1c274014}.work-samples-panel .work-sample-row-meta{color:var(--ink-500)}.work-samples-panel .experience-divider{background:var(--border)}.work-samples-panel .work-sample-row p{color:var(--ink-950)}.work-samples-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.work-samples-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.work-samples-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.student-create-work-sample-modal{width:min(100%,620px);max-height:calc(100vh - 2rem);display:flex;flex-direction:column}.student-create-work-sample-modal .student-create-form{min-height:0;overflow-y:auto;padding-right:.2rem}.work-sample-time-shell{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem .6rem;align-items:end;padding-top:1.3rem}.work-sample-time-title{position:absolute;top:0;left:0;color:var(--ink-800);font-weight:700;font-size:.95rem;white-space:nowrap}.work-sample-time-label{display:block;font-size:.78rem;color:var(--ink-500);text-align:right}.work-sample-documents-helper{color:var(--ink-500);font-size:.8rem;font-weight:600}.work-sample-modal-preview-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.55rem}.work-sample-upload-progress{display:grid;gap:.35rem}.work-sample-upload-progress-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;color:var(--ink-800);font-size:.86rem;font-weight:700}.work-sample-upload-progress-track{width:100%;height:8px;border-radius:999px;background:#1c274024;overflow:hidden}.work-sample-upload-progress-track span{display:block;height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,var(--blue-700),var(--blue-800));transition:width .18s ease}.work-sample-modal-preview-cell{position:relative}.work-sample-preview-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:999px;border:1px solid #ffffff;background:#e14343;color:#fff;display:grid;place-items:center;font-size:1rem;line-height:1;font-weight:900;cursor:pointer;z-index:1;box-shadow:0 6px 12px #1e15153d}.work-sample-preview-remove:hover{background:#cd3535}.work-sample-additional-portfolios{border:1px solid rgba(28,39,64,.12);border-radius:12px;padding:.7rem .8rem;margin:0}.work-sample-additional-portfolios legend{padding:0 .25rem;color:var(--ink-800);font-size:.88rem;font-weight:700}.work-sample-additional-portfolios ul{list-style:none;margin:0;padding:0;display:grid;gap:.45rem;max-height:210px;overflow-y:auto;padding-right:.2rem}.work-sample-additional-portfolios li label{display:flex;align-items:center;gap:.55rem;color:var(--ink-950)}.work-sample-additional-portfolios li input[type=checkbox]{width:16px;height:16px}.work-sample-additional-empty{margin:0;color:var(--ink-500);font-size:.88rem}.work-sample-groups{display:grid;gap:.85rem}.work-sample-group h4{margin:0 0 .45rem;color:#fffffff0;font-size:.96rem;font-weight:800}.work-sample-list{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}.work-sample-row{border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;padding:.75rem .85rem}.work-sample-row-wrap{position:relative}.work-sample-row-editing{padding-left:3rem;padding-right:4.5rem}.work-sample-delete-chip{position:absolute;top:50%;left:10px;transform:translateY(-50%);width:28px;height:28px;font-size:1.2rem;border-width:1px;z-index:2;background:#fff;border-color:#e14343;color:#e14343}.work-sample-delete-chip:hover{background:#fff5f5}.work-sample-delete-chip.selected{background:#e14343;border-color:#fff;color:#fff}.work-sample-edit-chip{position:absolute;top:10px;right:10px;border-radius:10px;padding:.42rem .72rem;font-size:.9rem;line-height:1.2;z-index:2}.work-sample-row-meta{display:flex;align-items:center;justify-content:space-between;gap:.65rem;color:#ffffffdb;font-size:.82rem;margin-bottom:.45rem}.experience-divider{height:2px;background:#ffffff2e;margin-bottom:.45rem}.work-sample-row p{margin:0;color:#fff;font-weight:400;line-height:1.35;white-space:pre-wrap}.experiences-panel{background:#f2f2f7}.experiences-panel h3{color:var(--ink-950)}.experiences-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.experiences-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.experiences-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.experiences-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.experiences-panel .students-header-divider{background:#0003}.experiences-panel .student-portfolios-empty,.experiences-panel .student-portfolios-empty p{color:var(--ink-500)}.experiences-panel .work-sample-row{background:#fff;border-color:#1c274014}.experiences-panel .work-sample-row-meta{color:var(--ink-500)}.experiences-panel .experience-divider{background:var(--border)}.experiences-panel .work-sample-row p{color:var(--ink-950)}.experiences-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.experiences-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.assessments-panel{background:#f2f2f7}.assessments-panel h3{color:var(--ink-950)}.assessments-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.assessments-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.assessments-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.assessments-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.assessments-panel .students-header-divider{background:#0003}.assessments-panel .student-portfolios-empty,.assessments-panel .student-portfolios-empty p{color:var(--ink-500)}.assessments-panel .work-sample-row{background:#fff;border-color:#1c274014}.assessments-panel .work-sample-row-meta{color:var(--ink-500)}.assessments-panel .experience-divider{background:var(--border)}.assessments-panel .work-sample-row p{color:var(--ink-950)}.assessments-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.assessments-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.assessment-score-block{margin-top:.5rem;margin-bottom:.55rem}.assessment-score-divider{height:1px;background:#fff6}.assessments-panel .assessment-score-divider{height:1px;background:var(--border)}.assessments-panel .assessment-score-row{color:var(--ink-500)}.assessment-score-row{margin-bottom:0;margin-top:0;padding:.42rem 0}.work-sample-icon-grid{margin-top:.65rem;display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.55rem;width:100%}.work-sample-icon-cell{width:100%;aspect-ratio:1 / 1;border-radius:10px;overflow:hidden;background:#fff;border:1px solid rgba(255,255,255,.38)}.work-sample-icon-cell img{width:100%;height:100%;object-fit:cover;display:block}.work-sample-icon-cell{transition:transform .15s ease,box-shadow .15s ease}.work-sample-icon-cell:hover{transform:scale(1.06);box-shadow:0 4px 16px #00000038}.work-sample-thumbnail-button{width:100%;height:100%;border:0;padding:0;background:transparent;cursor:pointer}.work-sample-icon-cell:has(img.pdf){border:1px solid #9ca3af}.work-sample-icon-cell img.pdf{object-fit:contain;padding:4px}.work-sample-file-modal{width:min(100%,980px);max-height:calc(100vh - 2rem);display:flex;flex-direction:column}.work-sample-file-modal-body{min-height:360px;max-height:calc(100vh - 9rem);display:grid;place-items:center;overflow:auto;border-radius:12px;background:#fff;border:1px solid rgba(28,39,64,.14);padding:.6rem}.work-sample-file-loading{display:grid;justify-items:center;gap:.75rem}.work-sample-file-loading p{margin:0;color:var(--ink-800);font-weight:700}.work-sample-file-loading-spinner{width:42px;height:42px;border-radius:50%;border:4px solid rgba(0,122,255,.2);border-top-color:var(--blue-700);animation:work-sample-file-spin .8s linear infinite}@keyframes work-sample-file-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.work-sample-file-modal-header-actions{display:flex;align-items:center;gap:.5rem}.reading-log-panel{width:min(100%,860px);margin-left:auto;margin-right:auto;background:#f2f2f7}.reading-log-panel h3{color:var(--ink-950)}.reading-log-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.reading-log-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.reading-log-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.reading-log-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.reading-log-panel .students-header-divider{background:#0003}.reading-log-panel>.student-portfolios-empty{color:var(--ink-500)}.reading-log-panel>.student-portfolios-empty p{color:var(--ink-500)}.reading-log-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.reading-log-header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:nowrap}.reading-log-panel .student-create-work-sample-modal{overflow-y:auto}.reading-log-search-list{max-height:340px}.reading-log-panel>.student-portfolios-empty{margin-top:.75rem}.reading-log-total-books{margin:1.95rem 0 1.2rem;color:#fff;font-weight:800;font-size:1.02rem;text-align:center;padding-bottom:.7rem;border-bottom:1px solid rgba(255,255,255,.2)}.reading-log-panel p.reading-log-total-books{margin:1.95rem 0 1.2rem;color:var(--ink-950);border-bottom-color:#00000026}.reading-log-panel .reading-log-group h4{color:var(--ink-950)}.reading-log-groups{display:grid;gap:.9rem;padding-top:.8rem}.reading-log-group h4{margin:0 0 .45rem;color:#fffffff0;font-size:.96rem;font-weight:800}.reading-log-list{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}.reading-log-row{position:relative;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;padding:.68rem .8rem;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.65rem}.reading-log-row.reading-log-row-editing{padding-left:3rem;padding-right:4.5rem}.reading-log-delete-chip{position:absolute;top:50%;left:10px;transform:translateY(-50%);width:28px;height:28px;font-size:1.2rem;border-width:1px;z-index:2;background:#fff;border-color:#e14343;color:#e14343}.reading-log-delete-chip:hover{background:#fff5f5}.reading-log-delete-chip.selected{background:#e14343;border-color:#fff;color:#fff}.reading-log-thumbnail-wrap{width:52px;height:52px;display:grid;place-items:center}.reading-log-thumbnail{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain;display:block}.reading-log-thumbnail-placeholder{font-size:2rem}.reading-log-body{min-width:0;display:grid;gap:.25rem}.reading-log-title{color:#fff;font-weight:800;line-height:1.3;overflow-wrap:anywhere}.reading-log-meta{display:grid;gap:.2rem;color:#ffffffd1;font-size:.9rem}.textbooks-panel{width:min(100%,860px);margin-left:auto;margin-right:auto;background:#f2f2f7}.textbooks-panel.portfolio-section-stub h3{color:var(--ink-950)}.textbooks-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.textbooks-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.textbooks-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.textbooks-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.textbooks-panel .students-header-divider{background:#0003}.textbooks-panel .student-portfolios-empty,.textbooks-panel .student-portfolios-empty p{color:var(--ink-500)}.textbooks-panel .textbook-row{background:#fff;border-color:#1c274014}.textbooks-panel .textbook-title{color:var(--ink-950);font-weight:400}.textbooks-panel .textbook-author{color:var(--ink-500)}.textbook-list{list-style:none;margin:.75rem 0 0;padding:0;display:grid;gap:.85rem}.textbook-row-wrap{position:relative}.textbook-row{border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;padding:.72rem .82rem;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.75rem}.textbook-row-editing{padding-left:3rem}.textbook-thumbnail-wrap{width:96px;height:96px;display:flex;align-items:center;justify-content:center}.textbook-thumbnail{width:auto;height:auto;max-width:100%;max-height:100%;object-fit:contain!important;display:block}.textbook-thumbnail-placeholder{font-size:4rem}.textbook-body{display:grid;gap:.2rem;min-width:0}.textbook-title{color:#fff;font-weight:800;line-height:1.25;overflow-wrap:anywhere}.textbook-author{color:#ffffffd1;font-size:.9rem;line-height:1.2;overflow-wrap:anywhere}.textbook-search-list{list-style:none;margin:.35rem 0 .2rem;padding:0;display:grid;gap:.45rem;max-height:220px;overflow:auto}.reading-log-panel .textbook-search-list.reading-log-search-list{max-height:420px}.reading-log-panel .reading-log-row{background:#fff;border-color:#1c274014}.reading-log-panel .textbook-title{color:var(--ink-950);font-weight:500}.reading-log-panel .textbook-author,.reading-log-panel .reading-log-meta{color:var(--ink-500)}.reading-log-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.reading-log-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.textbook-search-item{width:100%;border-radius:10px;border:1px solid rgba(28,39,64,.2);background:#fff;color:var(--ink-950);text-align:left;padding:.45rem .6rem;cursor:pointer;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.55rem}.textbook-search-item:hover{border-color:#1c274059;background:#f7f9ff}.textbook-search-item-thumb{width:42px;height:42px;object-fit:contain;display:block}.textbook-search-item-thumb-placeholder{width:42px;height:42px;display:grid;place-items:center;font-size:1.2rem}.textbook-search-item-body{min-width:0;display:grid;gap:.1rem}.textbook-search-item-body>span{overflow-wrap:anywhere}.textbook-search-item-body small{color:var(--ink-500)}.textbook-title-input-row{display:block}.textbook-title-input-row-has-thumb{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:.55rem}.textbook-title-input-row input{width:100%;min-width:0}.textbook-title-input-thumb{width:96px;height:96px;object-fit:contain;border-radius:8px;border:0;background:transparent}.add-textbook-modal{color:var(--ink-950)}.add-textbook-modal .students-status{color:var(--ink-800)}.add-textbook-modal .students-status-error{color:#9f1d1d}.add-textbook-modal .student-create-error{border-color:#9f1d1d3d;background:#fdeaea;color:#9f1d1d}.add-textbook-modal .student-create-field span,.add-textbook-modal .work-sample-additional-portfolios legend,.add-textbook-modal .work-sample-additional-portfolios li label,.add-textbook-modal .work-sample-additional-empty{color:var(--ink-800)!important}.textbook-delete-chip{position:absolute;top:50%;left:10px;transform:translateY(-50%);width:28px;height:28px;font-size:1.2rem;border-width:1px;z-index:2;background:#fff;border-color:#e14343;color:#e14343}.textbook-delete-chip:hover{background:#fff5f5}.textbook-delete-chip.selected{background:#e14343;border-color:#fff;color:#fff}.work-sample-file-modal-download{text-decoration:none;padding:.45rem .7rem;font-size:.84rem}.work-sample-file-modal-body img{max-width:100%;max-height:calc(100vh - 11rem);object-fit:contain;display:block}.work-sample-file-modal-body iframe{width:min(920px,100%);height:calc(100vh - 12rem);border:0;border-radius:10px;background:#fff}.resources-panel{width:min(100%,860px);margin-left:auto;margin-right:auto;background:#f2f2f7}.resources-panel.portfolio-section-stub h3{color:var(--ink-950)}.resources-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.resources-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.resources-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.resources-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.resources-panel .students-header-divider{background:#0003}.resources-panel .student-portfolios-empty,.resources-panel .student-portfolios-empty p{color:var(--ink-500)}.resources-panel .resource-row{background:#fff;border-color:#1c274014}.resources-panel .work-sample-row-meta{color:var(--ink-500)}.resources-panel .experience-divider{background:var(--border)}.resources-panel .work-sample-row p{color:var(--ink-950)}.resources-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.resources-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.resources-panel .resource-field-block+.resource-field-block{border-top-color:#1c27401f}.resources-panel .resource-field-label{color:var(--ink-500)}.resources-panel .resource-title,.resources-panel .resource-description{color:var(--ink-950)}.resources-panel .resource-link{color:var(--blue-700)}.resources-panel .resource-notes{color:var(--ink-500)}.resource-list{list-style:none;margin:.75rem 0 0;padding:0;display:grid;gap:.55rem}.resource-row-wrap{position:relative}.resource-row{border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;padding:.72rem .82rem;display:grid;grid-template-columns:auto 1fr;align-items:start;gap:.85rem}.resource-row-editing{padding-left:3rem;padding-right:4.5rem}.resource-icon-wrap{width:75px;height:75px;border-radius:10px;overflow:hidden;border:1px solid #ffffff;background:#fff;display:grid;place-items:center}.resource-icon-button{border:0;background:transparent;padding:0;border-radius:10px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.resource-icon-button:hover{transform:scale(1.06);box-shadow:0 4px 16px #00000038}.resource-icon-wrap-empty{border:0;background:transparent;overflow:visible}.resource-icon{width:100%;height:100%;object-fit:cover;display:block}.resource-icon-placeholder{font-size:4rem}.resource-body{min-width:0;display:grid;gap:0}.resource-field-block{display:grid;gap:.2rem;min-width:0;padding:.35rem 0}.resource-field-block+.resource-field-block{border-top:1px solid rgba(255,255,255,.2)}.resource-field-label{color:#ffffffbd;font-weight:800;font-size:.8rem;letter-spacing:.02em}.resource-title{color:#fff;font-weight:800;line-height:1.25;overflow-wrap:anywhere}.resource-description{color:#ffffffe6;line-height:1.3;overflow-wrap:anywhere}.resource-link{color:#7fc9ff;text-decoration:underline;overflow-wrap:anywhere}.resource-notes{color:#ffffffc7;font-size:.9rem;line-height:1.3;overflow-wrap:anywhere}.resource-delete-chip{position:absolute;top:50%;left:10px;transform:translateY(-50%);width:28px;height:28px;font-size:1.2rem;border-width:1px;z-index:2}.resource-document-fieldset input[type=file]{border:1px solid rgba(28,39,64,.18);border-radius:10px;padding:.55rem .65rem;background:#fff}.resource-selected-document{margin-top:.65rem;display:grid;grid-template-columns:auto 1fr;gap:.7rem;align-items:center}.resource-selected-document-preview{width:72px;height:72px;border-radius:10px;overflow:hidden;border:1px solid rgba(28,39,64,.14);background:#fff;display:grid;place-items:center}.resource-selected-document-preview img{width:100%;height:100%;object-fit:contain;display:block}.resource-selected-document-meta{display:grid;gap:.35rem;min-width:0}.resource-selected-document-meta p{margin:0;color:var(--ink-800);font-size:.9rem;overflow-wrap:anywhere}.resource-selected-document-meta .student-danger-button{justify-self:start}.subject-shell-topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.6rem;margin-bottom:2.5rem}.subject-shell-topbar h3{margin:0;color:#fff;font-size:1.85rem;text-align:center}.subject-header-title{display:grid;justify-items:center;gap:.2rem}.subject-header-title p{margin:0;color:#ffffffdb;font-size:.92rem;font-weight:600;text-align:center}.subject-backlink{margin-bottom:0}.subject-topbar-right{justify-self:end;min-width:72px;min-height:72px;display:grid;align-items:center;justify-items:center;gap:.28rem;text-align:center;padding-right:.7rem}.subject-student-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:1px solid #ffffff;background:#ffffff14}.portfolio-student-name-topbar,.subject-student-name-topbar{color:#fffffff2;font-size:.84rem;font-weight:700;line-height:1.1;max-width:140px;overflow-wrap:anywhere}.subject-sections-nav{display:flex;justify-content:center;gap:.55rem;flex-wrap:wrap;margin-bottom:.9rem}.subject-section-link{text-decoration:none;border:1px solid transparent;border-radius:12px;padding:.55rem .8rem;background:transparent;color:#fffffff5;font-weight:800;line-height:1.15;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.subject-section-link:hover{background:transparent;border-color:var(--orange);color:var(--orange)}.subject-section-link.active{background:#ffffff0f;border-color:var(--orange);color:var(--orange)}.curriculum-subject-list{list-style:none;margin:.75rem 0 0;padding:0;display:grid;gap:.65rem}.curriculum-subject-row-wrap{position:relative}.curriculum-subject-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;padding:.7rem .85rem;text-decoration:none;transition:border-color .12s ease,background-color .12s ease}.curriculum-panel .curriculum-subject-row{background:#fff;border-color:#1c274014}.curriculum-panel .curriculum-subject-row:hover{border-color:#1c27402e;background:#f9f9fb}.curriculum-subject-row[aria-disabled=true]{cursor:default}.curriculum-subject-row-editing{padding-left:3rem}.curriculum-subject-icon{width:30px;height:30px;border-radius:10px;display:grid;place-items:center;background:#fff}.curriculum-subject-name{font-weight:400;color:var(--ink-950)}.curriculum-subject-chevron{color:var(--ink-500);font-size:1.2rem;font-weight:900}.curriculum-subject-delete-chip{position:absolute;top:50%;left:10px;transform:translateY(-50%);width:28px;height:28px;font-size:1.2rem;border-width:1px;z-index:2;background:#fff;border-color:#e14343;color:#e14343}.curriculum-subject-delete-chip:hover{background:#fff5f5}.curriculum-subject-delete-chip.selected{background:#e14343;border-color:#fff;color:#fff}@media(max-width:1050px){.hero-panel{position:static}.landing-main.auth-open{grid-template-columns:1fr}.hero-top{flex-direction:column;text-align:center}.hero-showcase-img{width:180px}.hero-actions{justify-content:center}}@media(max-width:820px){.site-header{align-items:flex-start;flex-direction:column}.site-nav{width:100%;justify-content:flex-start}.brand-tagline{white-space:normal}.transcript-editor-layout{flex-direction:column}.transcript-live-preview-panel{flex:0 0 auto;max-height:40vh;border-right:none;border-bottom:1px solid rgba(28,39,64,.1)}.transcript-form-scroll{flex:1 1 auto}}@media(max-width:560px){.landing-shell{padding:0}.landing-main{padding:0 1rem;gap:2rem}.app-shell{padding:0}.site-header,.hero-panel,.auth-card,.tab-panel,.app-topbar{border-radius:16px}.hero-panel{padding:1.5rem 1.25rem;margin-top:1.5rem}.hero-showcase-img{width:140px}.features-grid,.highlights-grid{grid-template-columns:1fr}.download-section{padding:1.5rem 1.25rem}.store-badges{flex-direction:column;gap:1rem}.landing-footer{flex-direction:column;text-align:center}.brand-name{font-size:1.35rem;transform:none}.brand-tagline{font-size:.8rem}.transcript-add-grade-form{grid-template-columns:1fr 1fr}.app-topbar{align-items:flex-start;flex-direction:column}.app-topbar-controls{width:100%;justify-content:space-between}.app-menu{justify-content:flex-start}.app-topbar-divider{display:none}.students-panel-header{align-items:flex-start;flex-direction:column;gap:.35rem}.student-create-button,.student-edit-button{width:100%}.students-header-controls{width:100%;flex-direction:column;align-items:stretch;gap:.5rem}.students-header-divider{display:none}.students-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.35rem .8rem}.student-portfolios-header{align-items:flex-start;flex-direction:column;gap:.3rem}.student-portfolios-header .students-header-controls{width:100%;justify-content:space-between}.student-portfolios-header .student-create-button,.student-portfolios-header .student-edit-button{width:100%}.portfolio-subjects-add-row{grid-template-columns:1fr}.portfolio-sections-nav,.subject-sections-nav{display:grid;grid-template-columns:1fr}.curriculum-panel-header{align-items:flex-start;flex-direction:column;gap:.3rem}.curriculum-panel-header .students-header-controls{width:100%;justify-content:space-between}.curriculum-panel-header .student-create-button,.curriculum-panel-header .student-edit-button{width:100%}.student-modal{padding:.9rem}.student-create-form-actions{flex-direction:column-reverse}.student-secondary-button,.student-primary-button,.student-danger-button{width:100%}}.attendance-panel{max-width:600px;margin-left:auto;margin-right:auto;background:#f2f2f7}.attendance-panel h3{color:var(--ink-950)}.attendance-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.attendance-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.attendance-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.attendance-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.attendance-panel .students-header-divider{background:#0003}.attendance-calendar-card{background:#fff;border:1px solid rgba(28,39,64,.08);border-radius:16px;padding:.75rem 1rem 1rem;margin-top:.75rem}.attendance-month-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0 .75rem}.attendance-nav-button{width:36px;height:36px;border-radius:999px;border:1px solid rgba(0,122,255,.18);background:var(--blue-700);color:#fff;cursor:pointer;display:grid;place-items:center;transition:background .12s ease}.attendance-nav-button:hover:not(:disabled){background:var(--blue-800)}.attendance-nav-button:disabled{opacity:.35;cursor:not-allowed}.attendance-month-label{font-size:1.15rem;font-weight:800;color:var(--ink-950);background:none;border:none;cursor:pointer;padding:.3rem .6rem;border-radius:10px;transition:background .12s ease}.attendance-month-label:hover{background:#007aff0f}.attendance-dow-row{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.attendance-dow{text-align:center;font-size:.72rem;font-weight:800;color:var(--ink-500);padding:.3rem 0;text-transform:uppercase}.attendance-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.attendance-cell{position:relative;aspect-ratio:1;display:grid;place-items:center;border:none;background:transparent;border-radius:999px;cursor:pointer;font-size:1.1rem;font-weight:700;color:var(--ink-950);transition:background .12s ease,color .12s ease;padding:0}.attendance-cell:not(.attendance-cell-empty):before{content:"";position:absolute;width:70%;height:70%;border-radius:999px;transition:background .12s ease}.attendance-cell:hover:not(.attendance-cell-empty):before{background:#007aff14}.attendance-cell-empty{cursor:default}.attendance-cell.attendance-active:before{background:#007affbf}.attendance-cell.attendance-active{color:#fff}.attendance-cell.attendance-active:hover:before{background:#007affd9}.attendance-cell.attendance-today:not(.attendance-active){color:#e74c3c}.attendance-cell.attendance-today:before{box-shadow:inset 0 0 0 2px #e74c3c}.attendance-cell.attendance-toggling{opacity:.5}.attendance-day-number{position:relative;z-index:1}.attendance-hours-badge{position:absolute;top:4px;right:4px;width:25px;height:25px;border-radius:999px;background:#e74c3c;color:#fff;font-size:.8rem;font-weight:800;display:grid;place-items:center;line-height:1;z-index:2}.attendance-totals{display:flex;align-items:center;justify-content:center;padding:.85rem 0 .2rem;border-top:1px solid var(--border);margin-top:.75rem}.attendance-totals-spread{justify-content:space-between}.attendance-total-item{font-size:.95rem;color:var(--ink-800);font-weight:700}.attendance-picker-modal{width:min(100%,380px)}.attendance-picker-year-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0}.attendance-picker-year{font-size:1.2rem;font-weight:800;color:var(--ink-950)}.attendance-picker-months{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:.5rem 0}.attendance-picker-month{border:1px solid rgba(0,122,255,.2);border-radius:8px;background:#fff;color:var(--blue-700);font-weight:800;font-size:.9rem;padding:.5rem 0;cursor:pointer;transition:background .12s ease,color .12s ease}.attendance-picker-month:hover{background:#007aff0f}.attendance-picker-month-selected{background:var(--blue-700);color:#fff;border-color:var(--blue-700)}.attendance-picker-month-selected:hover{background:var(--blue-800)}.attendance-log-hours-modal{width:min(100%,480px)}.attendance-log-hours-form{display:grid;gap:1rem}.attendance-select{width:100%;border-radius:12px;border:1px solid rgba(28,39,64,.18);background:#fff;color:var(--ink-950);padding:.75rem .85rem;font-size:1rem;cursor:pointer}.attendance-select:focus{outline:none;border-color:var(--blue-700);box-shadow:0 0 0 4px #007aff1f}.attendance-log-hours-calendar{background:#fff;border:1px solid var(--border);border-radius:12px;padding:.5rem}.attendance-log-hours-month-header{padding:.3rem 0 .5rem}.attendance-log-hours-month-label{font-size:.95rem;font-weight:800;color:var(--ink-950)}.attendance-log-hours-dow-row{margin-bottom:2px}.attendance-log-hours-dow-row .attendance-dow{font-size:.65rem}.attendance-log-hours-grid .attendance-cell{font-size:.82rem}.attendance-log-hours-grid .attendance-cell.attendance-active,.attendance-log-hours-grid .attendance-cell.attendance-active .attendance-day-number{color:#fff}.attendance-log-hours-grid .attendance-hours-badge{width:15px;height:15px;font-size:.55rem}.attendance-log-hours-count{margin:.5rem 0 0;font-size:.88rem;color:var(--blue-700);font-weight:700}@media(max-width:480px){.attendance-cell{font-size:.95rem}.attendance-hours-badge{width:15px;height:15px;font-size:.55rem}}.grade-book-panel .portfolio-section-stub p.grade-book-gpa,.grade-book-gpa{margin:1.95rem 0 1.2rem;color:#fff;font-weight:800;font-size:1.02rem;text-align:center;padding-bottom:.7rem;border-bottom:1px solid rgba(255,255,255,.2)}.grade-book-row,.grade-book-details{display:grid;gap:.5rem}.grade-book-panel .work-sample-groups{padding-top:.8rem}.grade-book-panel .work-sample-list{gap:.85rem}.grade-book-detail-row{display:flex;align-items:center;justify-content:space-between;gap:.65rem;color:#fff;font-size:.95rem}.grade-book-detail-row span:first-child{color:#ffffffe0}.grade-book-panel{background:#f2f2f7}.grade-book-panel h3{color:var(--ink-950)}.grade-book-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.grade-book-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.grade-book-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.grade-book-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.grade-book-panel .students-header-divider{background:#0003}.grade-book-panel .student-portfolios-empty,.grade-book-panel .student-portfolios-empty p{color:var(--ink-500)}.grade-book-panel .work-sample-row{background:#fff;border-color:#1c274014}.grade-book-panel .work-sample-row-meta{color:var(--ink-500)}.grade-book-panel .experience-divider{background:#1c274026}.grade-book-panel .assessment-score-divider{height:1px;background:#1c274026}.grade-book-panel .grade-book-detail-row{color:var(--ink-950)}.grade-book-panel .grade-book-detail-row span:first-child{color:var(--ink-500)}.grade-book-panel .grade-book-gpa{color:var(--ink-950);border-bottom-color:#00000026}.grade-book-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.grade-book-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.additional-documents-panel{background:#f2f2f7}.additional-documents-panel h3{color:var(--ink-950)}.additional-documents-panel .student-create-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.additional-documents-panel .student-create-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.additional-documents-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.additional-documents-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.additional-documents-panel .students-header-divider{background:#0003}.additional-documents-panel .student-portfolios-empty,.additional-documents-panel .student-portfolios-empty p{color:var(--ink-500)}.additional-documents-panel .work-sample-row{background:#fff;border-color:#1c274014}.additional-documents-panel .work-sample-row-meta{color:var(--ink-500)}.additional-documents-panel .experience-divider{background:var(--border)}.additional-documents-panel .work-sample-row p{color:var(--ink-950)}.additional-documents-panel .work-sample-edit-chip{border-color:var(--orange-700);background:linear-gradient(180deg,var(--orange),#ef9b1a);color:#fff}.additional-documents-panel .work-sample-edit-chip:hover{background:linear-gradient(180deg,var(--orange-700),var(--orange-700))}.export-portfolio-panel{background:#f2f2f7}.export-portfolio-panel h3{color:var(--ink-950)}.export-portfolio-panel .student-edit-button{border-color:var(--blue-800);background:linear-gradient(180deg,var(--blue-700),var(--blue-800));color:#fff}.export-portfolio-panel .student-edit-button:hover{background:linear-gradient(180deg,var(--blue-800),var(--blue-800))}.export-portfolio-panel .work-sample-row{background:#fff;border-color:#1c274014}.export-portfolio-panel .work-sample-row-meta{color:var(--ink-500)}.export-portfolio-panel .assessment-score-divider{height:1px;background:#1c274026}.dashboard-charts,.dashboard-items,.dashboard-filter-bar,.dashboard-tabs,.dashboard-error{max-width:900px;margin-left:auto;margin-right:auto}.dashboard-error{padding:3rem 1.5rem;text-align:center;color:#ffffffb3}.dashboard-error p{font-size:1rem;margin:0}.dashboard-filter-bar{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;background:#f2f2f7;border-radius:14px;border:1px solid var(--border);box-shadow:0 2px 8px #0912230f;width:fit-content;max-width:calc(100% - 2rem);margin:0 auto .75rem;flex-wrap:wrap}.dashboard-filter-left{display:flex;align-items:center;gap:.75rem}.dashboard-student-picker-wrap{position:relative}.dashboard-student-btn{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:#fff;border:1px solid var(--border);border-radius:10px;color:var(--ink-950);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s}.dashboard-student-btn:hover{background:#e8e8ed}.dashboard-student-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.dashboard-student-avatar-placeholder{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#00000014;color:var(--ink-500)}.dashboard-student-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:200px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000002e;z-index:100;padding:.35rem;overflow:hidden}.dashboard-student-option{display:flex;align-items:center;gap:.6rem;width:100%;padding:.6rem .75rem;border:none;background:none;border-radius:8px;font-size:1rem;color:var(--ink-950);cursor:pointer;transition:background .12s}.dashboard-student-option:hover{background:#007aff14}.dashboard-student-option.selected{font-weight:700}.dashboard-student-avatar-sm{width:32px;height:32px;border-radius:50%;object-fit:cover}.dashboard-check{margin-left:auto;color:var(--blue-700);font-weight:700}.dashboard-dropdown-backdrop{position:fixed;inset:0;z-index:99}.dashboard-filter-select{padding:.4rem .75rem;background:#fff;border:1px solid var(--border);border-radius:10px;color:var(--ink-950);font-size:.875rem;font-weight:600;cursor:pointer;appearance:none;-webkit-appearance:none}.dashboard-filter-select option{background:#fff;color:var(--ink-950)}.dashboard-custom-dates{display:flex;gap:.75rem;align-items:center}.dashboard-custom-dates label{display:flex;align-items:center;gap:.35rem;color:var(--ink-500);font-size:.8rem}.dashboard-custom-dates input[type=date]{padding:.3rem .5rem;background:#fff;border:1px solid var(--border);border-radius:8px;color:var(--ink-950);font-size:.8rem;width:auto}.dashboard-date-nav{display:flex;align-items:center;gap:.5rem}.dashboard-nav-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:var(--blue-700);border-radius:8px;color:#fff;cursor:pointer;transition:background .15s}.dashboard-nav-btn:hover:not(:disabled){background:var(--blue-800)}.dashboard-nav-btn:disabled{opacity:.3;cursor:default}.dashboard-date-title{color:var(--ink-950);font-size:.9rem;font-weight:700;min-width:120px;text-align:center}.dashboard-tabs{display:flex;gap:.5rem;margin:2.5rem auto 1rem;width:fit-content}.dashboard-tab{padding:.5rem 1.5rem;border:1px solid transparent;background:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.dashboard-tab.active{border-color:var(--orange);color:var(--orange)}.dashboard-tab:hover:not(.active){border-color:var(--orange);color:var(--orange)}.dashboard-charts{padding:0 1rem 2rem;display:flex;flex-direction:column;gap:1.25rem}.dashboard-chart-section{background:#fff;border-radius:16px;padding:1.25rem;border:1px solid var(--border);box-shadow:0 2px 8px #0912230f}.dashboard-section-title{margin:0 0 1rem;font-size:1rem;font-weight:700;color:var(--ink-950)}.dashboard-empty{color:var(--ink-500)!important;font-size:.875rem;text-align:center;padding:1.5rem 0;margin:0}.dashboard-items .dashboard-empty{color:#fff!important}.dashboard-bar-chart{display:flex;align-items:flex-end;gap:.5rem;padding:.5rem 0;overflow-x:auto;min-height:200px}.dashboard-bar-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:48px}.dashboard-bar-value{font-size:.75rem;font-weight:700;color:var(--ink-800)}.dashboard-bar{width:100%;max-width:40px;border-radius:6px 6px 2px 2px;transition:height .3s ease}.dashboard-bar-badge{font-size:.65rem;color:var(--ink-500);white-space:nowrap}.dashboard-bar-label{font-size:.65rem;color:var(--ink-500);text-align:center;line-height:1.15;word-break:break-word;max-width:64px}.dashboard-legend{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.dashboard-legend-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--ink-800)}.dashboard-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.dashboard-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.dashboard-calendar-title{color:var(--ink-950);font-size:.875rem;font-weight:600}.dashboard-chart-section .dashboard-nav-btn{background:#007aff;color:#fff}.dashboard-chart-section .dashboard-nav-btn:hover:not(:disabled){background:#005fcc}.dashboard-chart-section .dashboard-nav-btn:disabled{background:#4ea3ff;opacity:.6}.dashboard-calendar{width:100%;max-width:560px;margin:0 auto}.dashboard-calendar-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.dashboard-calendar-dow span{text-align:center;font-size:.7rem;font-weight:600;color:var(--ink-500);text-transform:uppercase}.dashboard-calendar-row{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dashboard-calendar-cell{aspect-ratio:1;position:relative;display:grid;place-items:center}.dashboard-calendar-day{position:relative;display:grid;place-items:center;width:100%;height:100%;border-radius:999px;font-size:1.1rem;font-weight:700;color:var(--ink-950);line-height:1}.dashboard-calendar-day:before{content:"";position:absolute;width:65%;height:65%;border-radius:999px}.dashboard-calendar-day.attendance-day:before{background:#007affbf}.dashboard-calendar-day.attendance-day{color:#fff}.dashboard-day-number{position:relative;z-index:1}.dashboard-attendance-hours{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:999px;background:#e74c3c;color:#fff;font-size:.8rem;font-weight:700;display:grid;place-items:center;line-height:1;z-index:2}.dashboard-heatmap-day{display:grid;place-items:center;width:65%;height:65%;border-radius:6px;font-size:1.1rem;font-weight:700;color:var(--ink-950);line-height:1}.dashboard-heatmap-legend{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:.75rem;font-size:.7rem;color:var(--ink-500)}.dashboard-heatmap-swatch{width:14px;height:14px;border-radius:3px}.dashboard-day-bar-chart{display:flex;align-items:flex-end;gap:3px;padding:.5rem 0;overflow-x:auto;min-height:180px}.dashboard-day-bar-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;min-width:20px}.dashboard-day-bar-value{font-size:.65rem;font-weight:700;color:var(--ink-800)}.dashboard-day-bar{width:100%;max-width:28px;border-radius:4px 4px 1px 1px;transition:height .3s ease}.dashboard-day-bar-label{font-size:.65rem;color:var(--ink-500)}.dashboard-day-bar-xaxis-label{text-align:center;font-size:.75rem;font-weight:600;color:var(--ink-500);margin-top:.25rem}.dashboard-items{padding:0 1rem 2rem}.dashboard-item-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem;margin-bottom:1rem;padding:.75rem 1rem;background:#fff;border-radius:12px;border:1px solid var(--border);box-shadow:0 2px 8px #0912230f}.dashboard-date-group{margin-bottom:1rem}.dashboard-date-header{font-size:.8rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.03em;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.2);margin-bottom:.5rem}.dashboard-item-card{display:flex;gap:.75rem;padding:.75rem;background:#fff;border-radius:12px;border:1px solid var(--border);box-shadow:0 2px 8px #0912230f;margin-bottom:.5rem;transition:background .15s}.dashboard-item-card:hover{background:#f8f9fb}.dashboard-item-indicator{width:4px;border-radius:2px;flex-shrink:0;align-self:stretch}.dashboard-item-content{flex:1;min-width:0}.dashboard-item-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.dashboard-item-type{font-size:.8rem;font-weight:700;color:var(--ink-950)}.dashboard-item-subject{font-size:.75rem;color:var(--ink-500);padding:1px 6px;background:#0000000d;border-radius:4px}.dashboard-item-desc{font-size:.95rem;color:var(--ink-800)!important;margin:.2rem 0 .4rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.dashboard-item-divider{border:none;height:2px;background:#00000014;margin:.4rem 0}.dashboard-item-grade-details{font-size:.8rem;color:var(--ink-800)}.dashboard-item-grade-row{display:flex;justify-content:space-between;padding:.25rem 0}.dashboard-item-desc-row{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.dashboard-item-score-row{display:flex;justify-content:space-between;font-size:.8rem;color:var(--ink-500)}.dashboard-item-reading-row{display:flex;align-items:flex-start;gap:.75rem}.dashboard-item-reading-details{display:flex;flex-direction:column;gap:.35rem;flex:1;min-width:0}.dashboard-item-reading-meta-text{font-size:.8rem;color:var(--ink-500)}.dashboard-item-hours,.dashboard-item-score{font-size:.75rem;color:var(--ink-500)}.dashboard-item-student{display:flex;align-items:center;gap:.5rem;margin-top:.4rem;font-size:1rem;color:var(--ink-800)}.dashboard-item-student-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover}.dashboard-item-thumbs{display:flex;gap:6px;margin-top:.5rem;overflow-x:auto}.dashboard-item-thumb{width:108px;height:108px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#f2f2f7}.dashboard-item-book-thumb{width:60px;height:90px;border-radius:6px;object-fit:cover;flex-shrink:0;background:#f2f2f7}@media(max-width:600px){.dashboard-filter-bar{width:calc(100% - 2rem);flex-direction:column;align-items:stretch;gap:.5rem}.dashboard-filter-left{justify-content:space-between}.dashboard-date-nav{justify-content:center}.dashboard-custom-dates{flex-direction:column;gap:.5rem}.dashboard-bar-chart{min-height:160px}.dashboard-bar-label{font-size:.55rem}}
