:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;background:#020617;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}.app-shell{color:#fff;background:radial-gradient(circle at 0 0,#38bdf847,#0000 34%),radial-gradient(circle at 100% 100%,#0ea5e933,#0000 30%),#020617;place-items:center;min-height:100vh;padding:32px 16px;display:grid}.login-card,.dashboard-card{width:100%;max-width:440px}.login-card{text-align:center}.brand-badge{color:#020617;background:#38bdf8;border-radius:24px;place-items:center;width:64px;height:64px;margin:0 auto 18px;font-size:28px;font-weight:950;display:grid;box-shadow:0 22px 42px #38bdf847}.eyebrow{color:#7dd3fc;letter-spacing:.24em;text-transform:uppercase;margin:0;font-size:12px;font-weight:900}.eyebrow.dark{color:#0284c7}h1{letter-spacing:-.05em;margin:12px 0 0;font-size:clamp(30px,7vw,42px);line-height:1.02}.muted-text{color:#cbd5e1;max-width:360px;margin:14px auto 0;font-size:15px;line-height:1.6}.muted-text.dark{color:#475569}.form-card,.dashboard-card{color:#0f172a;text-align:left;background:#fff;border:1px solid #ffffff1f;border-radius:30px;margin-top:28px;padding:22px;box-shadow:0 28px 90px #0206178c}label{color:#334155;margin:0 0 8px;font-size:14px;font-weight:850;display:block}label:not(:first-child){margin-top:18px}input{color:#0f172a;background:#f8fafc;border:1px solid #cbd5e1;border-radius:18px;outline:none;width:100%;padding:14px 16px;transition:border-color .18s,box-shadow .18s,background .18s}input:focus{background:#fff;border-color:#38bdf8;box-shadow:0 0 0 4px #38bdf82e}.primary-button,.secondary-button{cursor:pointer;border:0;border-radius:18px;width:100%;margin-top:22px;padding:14px 18px;font-weight:950;transition:transform .16s,opacity .16s,background .16s}.primary-button{color:#fff;background:#0ea5e9;box-shadow:0 18px 34px #0ea5e947}.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.primary-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.secondary-button{color:#fff;background:#0f172a}.error-box{color:#b91c1c;background:#fef2f2;border-radius:18px;margin-top:18px;padding:13px 14px;font-size:14px;font-weight:750}.support-text{color:#94a3b8;margin:22px auto 0;font-size:12px;line-height:1.6}.info-box,.warning-box{border-radius:20px;margin-top:18px;padding:16px}.info-box{background:#f8fafc}.warning-box{color:#92400e;background:#fffbeb}.info-label{color:inherit;margin:0 0 4px;font-size:13px;font-weight:900}.info-box p,.warning-box p{margin:0}@media (width>=768px){.app-shell{padding:48px 24px}.form-card,.dashboard-card{padding:28px}}.text-button{color:#0284c7;cursor:pointer;background:0 0;border:0;width:100%;margin-top:14px;padding:10px;font-weight:850}.text-button:hover{text-decoration:underline}.login-brand{justify-content:center;margin-bottom:1rem;display:flex}.login-logo{object-fit:contain;max-width:75px;height:auto}.brand-subtitle{text-align:center;color:#64748b;margin:-.35rem 0 1rem;font-size:.9rem;font-weight:700}.login-support{text-align:center;margin-top:1.25rem}.login-support p{color:#475569;margin:0 0 .65rem;font-size:.9rem}.support-button{color:#fff;background:#0f172a;border-radius:999px;justify-content:center;align-items:center;min-height:42px;padding:.65rem 1.2rem;font-weight:700;text-decoration:none;display:inline-flex;box-shadow:0 12px 24px #0f172a2e}.support-button:hover{transform:translateY(-1px)}.app-shell{background:radial-gradient(circle at 12% 18%,#facc1547 0 34px,#0000 35px),radial-gradient(circle at 88% 16%,#7dd3fc4d 0 42px,#0000 43px),radial-gradient(circle at 18% 82%,#f472b633 0 46px,#0000 47px),radial-gradient(circle at 82% 78%,#86efac3d 0 38px,#0000 39px),linear-gradient(#94a3b824 1px,#0000 1px) 0 0/28px 28px,linear-gradient(90deg,#94a3b824 1px,#0000 1px) 0 0/28px 28px,#fffaf0;min-height:100vh;position:relative;overflow:hidden}.app-shell:before,.app-shell:after{content:"";z-index:0;pointer-events:none;position:absolute}.app-shell:before{background:#c4b5fd3d;border-radius:34px;width:140px;height:140px;top:8%;left:-42px;transform:rotate(16deg)}.app-shell:after{clip-path:polygon(50% 0%,100% 88%,0% 88%);background:#fbbf2438;width:130px;height:130px;bottom:10%;right:-36px;transform:rotate(-12deg)}.login-card{z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff0;border:1px solid #ffffffe6;position:relative}.login-logo{max-width:75px}@media (width<=640px){.app-shell{background-size:auto,auto,auto,auto,24px 24px,24px 24px,auto}.app-shell:before{width:100px;height:100px;top:4%;left:-52px}.app-shell:after{width:96px;height:96px;bottom:5%;right:-44px}.login-logo{max-width:68px}}.login-card{border-radius:2rem;width:min(92vw,460px);padding:2.35rem 2rem 2rem}.login-brand{margin-top:.35rem;margin-bottom:.95rem}.login-logo{max-width:68px;display:block}.login-card h1{margin-top:.6rem;margin-bottom:1.15rem;font-size:clamp(1.55rem,5vw,2rem);line-height:1.08}.form-card{background:#f8fafceb;border:1px solid #e2e8f0f2;border-radius:1.55rem;padding:1.15rem}.form-card input,.primary-button{border-radius:1rem}.login-support{margin-top:1.6rem;padding-top:.4rem}.support-button{border-radius:1rem;min-width:150px}.products-home-card{z-index:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff0;border:1px solid #ffffffe6;border-radius:2rem;width:min(94vw,980px);margin:2rem auto;padding:2rem;position:relative;box-shadow:0 24px 70px #0f172a24}.products-header h1{color:#0f172a;margin:.35rem 0 .5rem;font-size:clamp(1.6rem,4vw,2.3rem);line-height:1.08}.logout-button,.small-link-button{color:#2563eb;cursor:pointer;background:0 0;border:0;font-weight:800}.logout-button{white-space:nowrap;background:#eff6ff;border-radius:999px;padding:.65rem .85rem}.status-card{color:#475569;background:#f8fafc;border-radius:1.25rem;padding:1rem;font-weight:700}.students-list{gap:1rem;display:grid}.student-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:1.5rem;padding:1.25rem}.grade-pill{color:#1d4ed8;white-space:nowrap;background:#dbeafe;border-radius:999px;align-items:center;min-height:34px;padding:.35rem .8rem;font-size:.85rem;font-weight:900;display:inline-flex}.student-meta-grid div{background:#fff;border:1px solid #e2e8f0;border-radius:1.15rem;padding:.85rem}.student-meta-grid span{color:#64748b;margin-bottom:.25rem;font-size:.82rem;font-weight:700;display:block}.product-pin-box{background:#fff7ed;border:1px solid #fed7aa;border-radius:1rem;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem;display:flex}@media (width<=720px){.products-home-card{border-radius:1.6rem;margin:1rem auto;padding:1.25rem}.products-header,.student-card-header,.product-pin-box{flex-direction:column;align-items:stretch}.student-meta-grid{grid-template-columns:1fr}.logout-button{width:100%}}.products-home-card{width:min(100%,980px);margin:0 auto;padding:1.5rem}.products-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.products-header h1{color:#102a43;margin:.25rem 0}.logout-button,.small-link-button{color:#102a43;cursor:pointer;background:#0f172a14;border:0;border-radius:999px;padding:.7rem 1rem;font-weight:700}.student-card{background:#fffffff0;border:1px solid #ffffffe6;border-radius:28px;padding:1.25rem;box-shadow:0 22px 60px #0f172a1f}.student-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.student-label,.product-label{text-transform:uppercase;letter-spacing:.08em;color:#64748b;margin:0;font-size:.72rem;font-weight:800}.student-card h2,.product-card h3{color:#102a43;margin:.25rem 0}.grade-pill{color:#0369a1;white-space:nowrap;background:#e0f2fe;border-radius:999px;padding:.55rem .85rem;font-size:.85rem;font-weight:800}.student-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;margin-bottom:1rem;display:grid}.student-meta-grid div{background:#f8fafc;border-radius:18px;padding:.9rem}.student-meta-grid span{color:#64748b;margin-bottom:.25rem;font-size:.78rem;display:block}.student-meta-grid strong{color:#0f172a}.products-list{gap:.9rem;display:grid}.product-card{background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid #e2e8f0;border-radius:24px;gap:.85rem;padding:1rem;display:grid}.product-card p{color:#475569;margin:.25rem 0 0}.product-pin-box{background:#eef6ff;border-radius:18px;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem;display:flex}.product-pin-box span{color:#475569;font-size:.82rem;font-weight:700}.product-pin-box strong{color:#0f172a;letter-spacing:.12em}.product-action-button{width:100%}@media (width<=720px){.products-home-card{padding:1rem}.products-header,.student-card-header{flex-direction:column}.logout-button{width:100%}.grade-pill{white-space:normal}.student-meta-grid{grid-template-columns:1fr}.student-card{border-radius:24px;padding:1rem}.product-pin-box{flex-direction:column;align-items:flex-start}}.password-field{width:100%;position:relative}.password-field input{width:100%;padding-right:3rem}.password-toggle{color:#64748b;cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;padding:.25rem;display:inline-flex;position:absolute;top:50%;right:.85rem;transform:translateY(-50%)}.password-toggle:hover{color:#0f172a}.books-shell{background:radial-gradient(circle at 0 0,#38bdf840,#0000 32rem),radial-gradient(circle at 100% 100%,#a855f72e,#0000 28rem),linear-gradient(135deg,#f8fbff 0%,#eef7ff 48%,#fff7ed 100%);min-height:100vh;padding:1rem}.books-home{width:min(100%,1040px);margin:0 auto;padding:1rem 0 2rem}.books-topbar{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.books-brand{align-items:center;gap:.9rem;display:flex}.books-logo{object-fit:contain;background:#ffffffbf;border-radius:20px;width:58px;height:58px;padding:.45rem;box-shadow:0 14px 32px #0f172a1f}.books-brand-label,.credential-label,.book-status{text-transform:uppercase;letter-spacing:.09em;color:#0284c7;margin:0;font-size:.72rem;font-weight:900}.books-topbar h1{color:#0f172a;margin:.1rem 0 0;font-size:clamp(1.35rem,4.8vw,2.15rem);line-height:1}.books-logout{color:#0f172a;cursor:pointer;background:#ffffffd1;border:0;border-radius:999px;padding:.75rem 1rem;font-weight:900;box-shadow:0 12px 28px #0f172a1a}.books-welcome{color:#475569;margin:0 0 1rem;font-size:1rem;line-height:1.45}.student-credential{color:#fff;background:radial-gradient(circle at 100% 0,#ffffff52,#0000 16rem),linear-gradient(135deg,#0f3b68 0%,#0ea5e9 52%,#38bdf8 100%);border-radius:32px;margin-bottom:1rem;padding:1.1rem;position:relative;overflow:hidden;box-shadow:0 24px 60px #0e749042}.student-credential:after{content:"";background:#ffffff29;border-radius:999px;width:12rem;height:12rem;position:absolute;bottom:-4rem;right:-4rem}.student-hero{z-index:1;align-items:center;gap:.9rem;margin-bottom:1rem;display:flex;position:relative}.student-avatar{color:#fff;background:#ffffff38;border:1px solid #ffffff59;border-radius:22px;place-items:center;width:58px;height:58px;font-size:1.6rem;font-weight:1000;display:grid}.student-hero h2{color:#fff;margin:.15rem 0;font-size:1.35rem}.student-hero p{margin:0}.student-hero .credential-label{color:#ffffffc7}.student-info-row{z-index:1;grid-template-columns:1.4fr .6fr;gap:.75rem;display:grid;position:relative}.student-info-row div{background:#ffffff2b;border:1px solid #fff3;border-radius:20px;padding:.85rem}.student-info-row span{color:#ffffffb8;margin-bottom:.25rem;font-size:.78rem;display:block}.student-info-row strong{color:#fff;font-size:.95rem}.books-grid{grid-template-columns:1.25fr .85fr .85fr;gap:1rem;display:grid}.book-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffdb;border:1px solid #fffffff2;border-radius:32px;min-height:260px;position:relative;overflow:hidden;box-shadow:0 22px 60px #0f172a1c}.book-card-featured{background:linear-gradient(145deg,#fffffff5,#eff9ffeb)}.book-card-glow{background:#0ea5e92e;border-radius:999px;width:13rem;height:13rem;position:absolute;inset:auto -4rem -5rem auto}.book-card-content{z-index:1;flex-direction:column;gap:.9rem;min-height:100%;padding:1.1rem;display:flex;position:relative}.book-icon{background:linear-gradient(135deg,#e0f2fe,#fff7ed);border-radius:24px;place-items:center;width:62px;height:62px;font-size:2rem;display:grid;box-shadow:inset 0 0 0 1px #0ea5e91f}.book-card h3{color:#0f172a;margin:.2rem 0;font-size:1.2rem;line-height:1.1}.book-description{color:#475569;margin:0;font-size:.95rem;line-height:1.4}.book-access-box{background:#eff6ff;border:1px solid #dbeafe;border-radius:22px;margin-top:auto;padding:.9rem}.book-access-box span{color:#475569;margin-bottom:.25rem;font-size:.78rem;font-weight:800;display:block}.book-access-box strong{color:#0f172a;letter-spacing:.16em;font-size:1.15rem}.book-main-button,.book-secondary-button{cursor:pointer;border:0;border-radius:999px;width:100%;padding:.9rem 1rem;font-weight:1000}.book-main-button{color:#fff;background:linear-gradient(135deg,#0284c7,#0ea5e9);box-shadow:0 16px 28px #0ea5e940}.book-secondary-button{color:#075985;background:#e0f2fe}@media (width<=920px){.books-grid{grid-template-columns:1fr}.book-card{min-height:auto}}@media (width<=620px){.books-shell{padding:.85rem}.books-topbar{align-items:flex-start}.books-logo{border-radius:18px;width:52px;height:52px}.books-logout{padding:.65rem .85rem}.student-credential,.book-card{border-radius:26px}.student-info-row{grid-template-columns:1fr}.book-card-content{padding:1rem}}
