*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}html,body,#root{height:100%;width:100%}body{background:#f8fafc;color:#111827;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit;border:none;outline:none}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:8px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}:root{--primary: #4f46e5;--primary-dark: #4338ca;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-600: #4b5563;--gray-900: #111827}.container{max-width:1200px;margin:0 auto;padding:1rem 1.5rem}:root{--bg:#f3b8c7;--card-bg:#ffffff;--text:#111827;--muted:#6b7280;--primary:#5b61f6;--primary-press:#4a50d6;--ring: rgba(91,97,246,.35);--shadow: 0 10px 25px rgba(0,0,0,.08)}.auth,.hero,.card{min-width:0}.card{grid-area:card}.hero{grid-area:hero}.auth{min-height:100dvh;width:100%;display:grid;grid-template-columns:1fr minmax(360px,560px);grid-template-areas:"hero card";align-items:center;justify-content:end;gap:40px;padding:32px clamp(24px,6vw,72px);background:var(--bg);overflow-x:hidden}.hero{height:520px;border-radius:24px;background:#f6ccd7;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 25%,#ffffffaa 0 120px,transparent 121px),radial-gradient(circle at 75% 20%,#ffd9a8aa 0 110px,transparent 111px),radial-gradient(circle at 30% 80%,#b9e8c0aa 0 150px,transparent 151px);mix-blend-mode:multiply}.card{width:100%;max-width:560px;margin-inline:auto;background:var(--card-bg);border-radius:24px;box-shadow:var(--shadow);padding:32px 36px;justify-self:end;overflow:hidden;margin:0}.card h2{margin:0 0 20px;color:var(--text);font-weight:800;font-size:26px}.form{display:grid;gap:16px}.field{display:grid;gap:8px}.label{font-size:14px;color:var(--text);font-weight:600}.inputWrap{position:relative}.input{width:100%;height:48px;padding:0 14px;border:1px solid #e5e7eb;border-radius:12px;background:#f5f7fb;color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s,background .2s}.input::placeholder{color:#9ca3af}.input:focus{border-color:var(--primary);box-shadow:0 0 0 6px var(--ring);background:#fff}.eyeBtn{position:absolute;right:10px;top:50%;transform:translateY(-50%);border:0;background:transparent;cursor:pointer;padding:6px;color:#9ca3af}.btn{height:52px;border:0;border-radius:14px;background:linear-gradient(180deg,var(--primary),#676cf9);color:#fff;font-weight:700;cursor:pointer;box-shadow:0 8px 16px #5b61f659;transition:transform .05s ease,box-shadow .2s ease,background .2s ease,opacity .2s}.btn:active{transform:translateY(1px);background:var(--primary-press)}.btn:disabled{opacity:.7;cursor:not-allowed}.helper{margin-top:2px;font-size:12px;color:var(--muted)}.message{margin-top:12px;padding:10px 12px;background:#f3f4f6;border-radius:10px;font-size:13px;color:#374151;word-break:break-word}.switch{margin-top:12px;font-size:14px;color:var(--muted)}.switch-link{font-weight:700;text-decoration:none;color:var(--primary)}.switch-link:hover{text-decoration:underline}@media(max-width:980px){.auth{grid-template-columns:1fr}.hero{order:2;height:260px}.card{order:1}}:root{--bg:#f3b8c7;--card-bg:#ffffff;--text:#111827;--muted:#6b7280;--primary:#5b61f6;--ring: rgba(91,97,246,.35);--shadow: 0 16px 40px rgba(17, 24, 39, .15);--ok:#16a34a;--err:#dc2626;height:100%;margin:0;padding:0}.verify-wrap{height:100vh;display:grid;place-items:center;background:var(--bg);padding:32px clamp(24px,6vw,72px)}.verify-card{width:min(560px,92vw);background:var(--card-bg);border-radius:24px;box-shadow:var(--shadow);padding:32px 34px}.verify-title{margin:0 0 8px;font-size:28px;line-height:1.2;color:var(--text);font-weight:800;text-align:center}.verify-sub{margin:0 0 22px;color:var(--muted);font-size:14px;text-align:center}.verify-form{display:grid;gap:12px}.token-input{height:50px;border:1px solid #e5e7eb;border-radius:12px;padding:0 14px;background:#52565e;font-size:16px;outline:none;transition:border-color .2s,box-shadow .2s,background .2s}.token-input:focus{border-color:var(--primary);box-shadow:0 0 0 6px var(--ring);background:#52565e}.verify-btn{height:52px;border:0;border-radius:14px;background:linear-gradient(180deg,var(--primary),#676cf9);color:#fff;font-weight:700;cursor:pointer;box-shadow:0 10px 18px #5b61f659}.mock-row{display:flex;align-items:center;gap:10px;margin-top:6px;font-size:13px}.muted{color:var(--muted)}.code{background:#4d4f54;padding:2px 6px;border-radius:6px}.link-btn{border:0;background:transparent;color:var(--primary);font-weight:700;cursor:pointer}.status{margin-top:16px;padding:12px 14px;border-radius:12px;font-size:14px}.status.ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.status.err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}:root{--bg: #f3b8c7;--card-bg: #ffffff;--text: #111827;--muted: #6b7280;--primary: #5b61f6;--ring: rgba(91, 97, 246, .35);--shadow: 0 16px 40px rgba(17, 24, 39, .15);--ok: #16a34a;--err: #dc2626;height:100%;margin:0;padding:0}.authchange-wrap{height:100vh;display:grid;place-items:center;background:var(--bg);padding:32px clamp(24px,6vw,72px)}.authchange-card{width:min(560px,92vw);background:var(--card-bg);border-radius:24px;box-shadow:var(--shadow);padding:32px 34px;display:grid;gap:20px}.authchange-title{margin:0 0 8px;font-size:28px;line-height:1.2;color:var(--text);font-weight:800;text-align:center}.authchange-sub{margin:0 0 22px;color:var(--muted);font-size:14px;text-align:center}.authchange-form{display:grid;gap:14px}.label{font-size:14px;color:var(--text);font-weight:600;text-align:left}.input{height:50px;border:1px solid #e5e7eb;border-radius:12px;padding:0 14px;background:#52565e;font-size:16px;color:#fff;outline:none;transition:border-color .2s,box-shadow .2s,background .2s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 6px var(--ring);background:#52565e}.btn{height:52px;border:0;border-radius:14px;background:linear-gradient(180deg,var(--primary),#676cf9);color:#fff;font-weight:700;cursor:pointer;box-shadow:0 10px 18px #5b61f659;transition:transform .2s ease,box-shadow .2s ease}.btn:hover{transform:translateY(-2px);box-shadow:0 12px 22px #5b61f673}.pill{display:inline-block;padding:2px 8px;border-radius:999px;background:#f3f4f6;color:#374151;font-weight:600}.message{margin-top:16px;text-align:center;font-size:14px;padding:12px 14px;border-radius:12px}.message.ok{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.message.err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.menu{position:fixed;top:0;left:-280px;height:100vh;width:260px;background:#3b404bf2;color:#fff;box-shadow:4px 0 20px #0000001a;flex-direction:column;justify-content:space-between;transition:left .3s ease;z-index:999;padding:20px}.menu.open{left:0}.menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.menu-title{font-size:20px;font-weight:700}.close-btn{font-size:24px;cursor:pointer;transition:color .2s ease}.close-btn:hover{color:#5b61f6}.menu-links{display:flex;flex-direction:column;justify-content:flex-start;gap:0;margin-top:10px}.menu-item{display:flex;align-items:center;gap:12px;padding:12px 0;cursor:pointer;font-size:16px;font-weight:500;border-bottom:1px solid rgba(255,255,255,.12);transition:color .2s ease}.menu-item:hover{color:#5b61f6}.menu-item:last-child{border-bottom:none}.icon{font-size:18px}.menu-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:570px;display:flex;flex-direction:column;gap:12px}.bottom-item{display:flex;align-items:center;gap:10px;font-size:15px;cursor:pointer;color:#ddd;transition:color .2s ease}.bottom-item:hover{color:#5b61f6}:root{--nav-h: 54px}.navbar{position:absolute;top:0;left:0;right:0;width:100%;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 32px;background:#3b404be6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #313745;box-shadow:0 2px 6px #0000000d;z-index:1000}.menu-icon{display:flex;flex-direction:column;gap:4px;cursor:pointer}.menu-icon .bar{width:24px;height:2px;background:#f4f1f1;border-radius:2px}.nav-links{display:flex;gap:18px;font-weight:600}.nav-link{cursor:pointer;transition:color .2s ease}.nav-link:hover{color:#5b61f6}.profile{position:relative}.profile-btn{cursor:pointer;font-weight:600}.profile-menu{position:absolute;top:110%;right:0;background:#3b404be6;box-shadow:0 4px 12px #0000001a;border-radius:8px;display:flex;flex-direction:column;padding:8px 0;min-width:150px}.profile-menu span{padding:8px 14px;cursor:pointer;transition:background .2s}.profile-menu span:hover{background:#302b30}.home-page{padding:24px;max-width:1440px;margin:0 auto;background:var(--bg);min-height:100vh;margin-top:var(--nav-h)}.page-title{margin-bottom:20px;color:var(--text)}.tree-container{display:flex;flex-direction:column;gap:20px}.level-block{background:var(--card);border-radius:12px;box-shadow:var(--shadow);padding:16px 20px;color:var(--text)}.subbranch-block{margin-left:16px;padding-left:12px;border-left:3px solid var(--line);margin-top:8px;color:var(--text)}.unit-block{margin-left:16px;padding-left:12px;border-left:2px solid #e5e7eb;margin-top:6px;color:var(--text)}.subunit-block{margin-left:16px;padding-left:12px;border-left:1px dashed #d1d5db;margin-top:4px;color:var(--text)}.outcomes-list{margin-left:20px;list-style-type:disc;color:var(--text)}.error{color:#b91c1c;background:#221919;padding:8px 10px;border-radius:10px}:root{--bg:#f5f7fb;--card:#fff;--text:#111827;--muted:#6b7280;--primary:#5b61f6;--primary-2:#676cf9;--ring: rgba(91,97,246,.22);--line:#e5e7eb;--shadow: 0 16px 40px rgba(17,24,39,.08);--dark:#1f2937;--danger:#ef4444}.page-under-nav{padding-top:calc(var(--nav-h) + 12px)}.curriculum-wrap{width:min(1200px,96vw);margin:0 auto;padding:24px;display:grid;grid-template-columns:300px 1fr;gap:22px;background:var(--bg);min-height:100vh;margin-top:var(--nav-h)}.side{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:16px;display:flex;flex-direction:column;gap:12px}.side-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--line)}.side-title{margin:0;font-size:16px;font-weight:800;color:var(--text)}.side-subtitle{margin:6px 2px 2px;font-size:12px;letter-spacing:.02em;color:var(--muted);text-transform:uppercase}.side-section{display:flex;flex-direction:column;gap:10px}.side-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.side-item{width:100%;text-align:left;background:#f9fafb;border:1px solid var(--line);border-radius:12px;padding:10px 12px;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.side-item:hover{background:#f5f7fb;border-color:#dfe3ea}.side-item.active{background:#eef2ff;border-color:#c7d2fe;box-shadow:0 0 0 4px #5b61f61f}.item-title{display:block;color:var(--text);font-weight:700}.item-sub{display:block;color:var(--muted);font-size:12px;margin-top:2px}.link-add{align-self:flex-start;background:transparent;border:0;color:var(--primary);font-weight:700;display:flex;align-items:center;gap:6px;cursor:pointer}.main-card{background:var(--card);border-radius:16px;box-shadow:var(--shadow);padding:18px 20px}.main-head{display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:16px}.breadcrumb{display:flex;align-items:center;gap:8px;font-weight:800}.crumb{color:var(--text)}.crumb-sep{color:var(--muted)}.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;border-radius:12px;border:0;height:40px;padding:0 14px}.btn-sm{height:34px;border-radius:10px;padding:0 10px}.btn-xs{height:30px;border-radius:10px;padding:0 10px}.btn-primary{background:linear-gradient(180deg,var(--primary),var(--primary-2));color:#fff}.btn-dark{background:#111827;color:#fff}.btn:focus{outline:none;box-shadow:0 0 0 6px var(--ring)}.unit-list{display:flex;flex-direction:column;gap:10px}.unit-card{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;transition:border-color .15s,box-shadow .15s}.unit-card.open{border-color:#d9def5;box-shadow:0 6px 16px #1118270f}.unit-row{width:100%;display:flex;align-items:center;gap:10px;background:#fff;padding:10px 12px;border:0;cursor:pointer;text-align:left}.chev{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:#6b7280}.unit-name{margin:0;font-size:16px;font-weight:700;color:var(--text)}.unit-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.icon-btn{background:transparent;border:0;font-size:18px;color:#6b7280;cursor:pointer}.icon-btn:hover{color:var(--primary)}.icon-btn.danger:hover{color:var(--danger)}.subunit-panel{padding:0 12px 12px 44px;display:none;gap:6px;transition:grid-template-rows .22s ease,padding .22s ease}.unit-card:not(.open) .subunit-panel{grid-template-rows:0fr;padding:0 12px 0 44px}.unit-card.open .subunit-panel{display:block}.subunit-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;cursor:pointer;transition:background .15s;border:1px solid transparent;background:#fafbff}.subunit-item:hover{background:#f5f7ff;border-color:#e5e8ff}.dot{width:6px;height:6px;border-radius:999px;background:#9ca3af}.subunit-name{color:#374151;font-weight:600}.ghost{opacity:0}.subunit-item:hover .ghost{opacity:.35}.muted{color:var(--muted);font-size:13px}.error{color:#b91c1c;font-size:13px;background:#fef2f2;border:1px solid #fecaca;padding:8px 10px;border-radius:10px}.empty{color:var(--muted);font-size:13px;padding:10px 12px;border:1px dashed var(--line);border-radius:12px;background:#fbfcff}.empty.big{padding:16px 14px}.skeleton{border-radius:10px;background:linear-gradient(90deg,#eef1f7 25%,#f4f6fb 37%,#eef1f7 63%);background-size:400% 100%;animation:shine 1.2s infinite}.skeleton-line{height:14px}.skeleton-block{height:56px}@keyframes shine{0%{background-position:100% 0}to{background-position:-100% 0}}@media(max-width:980px){.curriculum-wrap{grid-template-columns:1fr}}.side-list{display:flex;flex-direction:column;gap:6px}.side-item-row{display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;transition:all .15s ease}.side-item-row:hover{background:#f1f5f9;border-color:#cbd5e1}.side-item.active{background:#e0f2fe;border:1px solid #38bdf8;box-shadow:inset 2px 0 #0284c7}.side-actions{display:flex;gap:6px}.icon-btn{border:none;background:transparent;padding:4px;border-radius:6px;transition:background .15s ease;cursor:pointer}.icon-btn:hover{background:#e2e8f0}.icon-btn.danger:hover{background:#fee2e2}.icon-btn.danger{color:#dc2626}.outcome-panel{margin-top:8px;padding-left:18px;display:flex;flex-direction:column;gap:8px}.outcome-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#f8fafc;border:1px solid var(--line);border-radius:10px}.outcome-row .tick{width:6px;height:6px;border-radius:999px;background:#10b981}.outcome-name{color:var(--text, #5e6471);font-weight:500}.reorder{cursor:grab;opacity:.85;border:1px dashed #999}.reorder:active{cursor:grabbing}.unit-card{display:flex;flex-direction:column;border:1px solid #eee;border-radius:6px;padding:10px;margin-bottom:10px}.unit-toggle-area{display:flex;align-items:center;gap:12px;cursor:pointer;padding:6px 0}.unit-actions{display:flex;gap:6px;margin-left:auto}.unit-children{margin-left:32px;margin-top:6px}.small-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;box-shadow:0 1px 3px #1118270a;transition:border-color .15s,box-shadow .15s,background .15s}.small-card:hover{border-color:#d5dbff;box-shadow:0 4px 10px #6f727a14;background:#fdfdff}.subunit-block{margin-top:8px}.subunit-header{display:flex;align-items:center;gap:10px;cursor:pointer}.subunit-index{font-weight:700;color:var(--muted)}.subunit-name{font-weight:700;color:var(--text)}.subunit-actions{margin-left:auto;display:flex;align-items:center;gap:6px}.subunit-content{margin-top:8px;padding-left:32px;display:flex;flex-direction:column;gap:6px}.chevron{font-size:16px;transition:transform .15s}.rot90{transform:rotate(180deg)}.outcome-row{display:flex;align-items:center;border-radius:12px;padding:8px 12px;background:#fff;border:1px solid var(--line);transition:background .15s,border-color .15s,box-shadow .15s}.outcome-row:hover{background:#fdfdff;border-color:#d5dbff;box-shadow:0 4px 10px #11182714}.outcome-index{font-weight:700;color:var(--muted)}.outcome-name{color:var(--text);font-weight:600}.outcome-actions{margin-left:auto;display:flex;gap:6px}.modal-overlay{position:fixed;inset:0;background:#1118276b;display:grid;place-items:center;z-index:1000}.modal-card{background:#fff;border-radius:16px;box-shadow:0 24px 64px #00000047;max-width:96vw;max-height:92vh;overflow:auto}.modal-head{padding:14px 18px;border-bottom:1px solid var(--line)}.modal-head h3{margin:0;font-size:18px;font-weight:800;color:var(--text)}.modal-body{padding:18px}.page{min-height:calc(100vh - var(--nav-h, 64px));display:grid;place-items:center}.form-page{min-height:calc(100vh - var(--nav-h, 64px));display:grid;place-items:center;padding:24px}.form-wrap{width:100%;max-width:680px;background:var(--card, #fff);border-radius:16px;box-shadow:var(--shadow, 0 16px 40px rgba(17,24,39,.08));padding:32px 28px}.form-title{margin-bottom:18px;font-size:22px;font-weight:800;color:var(--text, #111827);text-align:center}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;max-width:560px}.form-grid .full{grid-column:1 / -1}.label{display:block;font-size:13px;font-weight:700;color:var(--text,#111827);margin-bottom:6px}.input,.select,.textarea{width:100%;border:1px solid var(--line,#e5e7eb);border-radius:10px;padding:10px 12px;font-size:14px;background:#fff;color:var(--text);transition:border-color .15s,box-shadow .15s}.input:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--ring)}.textarea{min-height:92px;resize:vertical}.row{margin-top:12px;color:var(--text,#111827)}.checkbox{display:inline-flex;gap:8px;align-items:center;font-weight:600}.actions{margin-top:20px;display:flex;gap:10px;justify-content:center}.status{margin-top:10px;font-size:13px;text-align:center}.status.ok{color:#065f46}.status.err{color:#991b1b}.small-note{font-size:12px;color:var(--muted,#6b7280);text-align:center;margin-top:8px}.verifications-wrapper{max-width:1100px;margin:40px auto;padding:20px}.page-title{font-size:32px;font-weight:700;margin-bottom:40px;text-align:center}.section-title{font-size:22px;font-weight:600;margin-bottom:20px}.card-list{display:flex;flex-direction:column;gap:20px}.verify-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:14px;padding:20px;box-shadow:0 5px 18px #0000001f}.verify-left{display:flex;gap:18px}.verify-avatar{width:80px;height:80px;border-radius:12px;object-fit:cover}.verify-info p{margin:4px 0}.comment{margin-top:8px;font-style:italic}.verify-actions{display:flex;flex-direction:column;gap:10px}.approve-btn{background:#3ecf5d;color:#fff;padding:10px 18px;border-radius:8px;border:none;cursor:pointer;font-weight:600}.reject-btn{background:#ff5353;color:#fff;padding:10px 18px;border-radius:8px;border:none;cursor:pointer;font-weight:600}.empty{padding:15px;background:#fafafa;border-radius:8px;font-style:italic}.tabs{display:flex;gap:12px;margin-bottom:20px}.tabs button.active{background:#6366f1;color:#fff}.secondary-btn{background:#eef2ff;border:1px solid #c7d2fe;padding:6px 10px;border-radius:6px;cursor:pointer}.right-align{display:flex;justify-content:flex-end;margin-top:6px}.modal-backdrop{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.teacher-modal{background:#fff;width:520px;max-height:80vh;overflow-y:auto;border-radius:12px;box-shadow:0 20px 40px #0003}.teacher-modal-header{display:flex;gap:16px;padding:20px;border-bottom:1px solid #eee;align-items:center}.teacher-modal-header img{width:72px;height:72px;border-radius:50%;object-fit:cover}.teacher-modal-header h2{margin:0}.teacher-modal-header .status{font-size:14px;color:#666}.teacher-modal-body{padding:20px;display:flex;flex-direction:column;gap:20px}.teacher-modal-body section h3{margin-bottom:8px;font-size:16px}.teacher-modal-body p{margin:4px 0;color:#333}.teacher-modal-body .bio{background:#f7f7f7;padding:12px;border-radius:8px}.teacher-modal-footer{padding:16px;border-top:1px solid #eee;display:flex;justify-content:flex-end}.parent-profile{margin:4rem auto 2rem;padding:0 2rem;font-family:Inter,sans-serif;display:flex;flex-direction:column;align-items:flex-start;width:100%;overflow-x:hidden}.profile-page{margin:4rem auto 2rem;padding:0 2rem;font-family:Inter,sans-serif;display:flex;flex-direction:column;align-items:flex-start;overflow-x:hidden}.profile-title{font-size:1.8rem;font-weight:700;color:#18181b;margin-bottom:1.5rem;text-align:left}.profile-tabs{display:flex;justify-content:flex-start;align-items:flex-end;gap:2rem;border-bottom:1px solid #e5e7eb;padding-bottom:.5rem;margin-bottom:1.5rem;width:100%;flex-wrap:wrap;min-height:48px}.profile-tab{position:relative;padding-bottom:.75rem;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;text-decoration:none;transition:color .2s ease-in-out}.profile-tab:hover{color:#4f46e5}.profile-tab.active{color:#4f46e5;font-weight:600}.profile-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;height:2px;width:100%;background-color:#4f46e5;border-radius:1px}.profile-divider{border:none;border-bottom:1px solid #e5e7eb;width:100%;margin-bottom:2rem}.profile-tab-content{width:100%;margin-top:1.5rem;min-height:600px}@media(max-width:768px){.profile-tabs{gap:1.2rem}.profile-tab{font-size:.95rem}}.profile-info-form{display:flex;flex-direction:column;gap:2rem}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem 2rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.95rem;font-weight:500;color:#374151}.form-group input{border:1px solid #d1d5db;border-radius:8px;padding:.7rem .8rem;font-size:.95rem;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.form-group input:focus{outline:none;border-color:#7a5af8;box-shadow:0 0 0 3px #7a5af826}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.save-btn{background-color:#7a5af8;color:#fff;border:none;border-radius:8px;padding:.75rem 1.25rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:background-color .2s ease-in-out}.save-btn:hover{background-color:#6b47f2}.preview-btn{background-color:transparent;border:1px solid #7a5af8;color:#7a5af8;border-radius:8px;padding:.75rem 1.25rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.school-form{margin-top:2rem;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 1px 4px #00000014}.dropdown-list{max-height:200px;overflow-y:auto;border:1px solid #ddd;border-radius:8px;margin-top:4px;background:#fff}.dropdown-item{padding:8px 12px;cursor:pointer}.dropdown-item:hover{background:#f3f3f3}.selected-value{margin-top:6px;font-weight:600;color:#444}.preview-btn:hover{background-color:#f4f3ff}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.form-actions{flex-direction:column;align-items:stretch}}.profile-picture-editor{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}.editor-avatar-wrapper{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid #7a5af8;box-shadow:0 0 8px #7a5af833;flex-shrink:0}.editor-avatar-image{width:100%;height:100%;object-fit:cover}.editor-actions{display:flex;flex-direction:column;gap:1rem}.editor-upload-btn{display:inline-flex;align-items:center;gap:.5rem;background-color:#f4f3ff;color:#7a5af8;border:1px dashed #7a5af8;border-radius:10px;padding:.8rem 1rem;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.editor-upload-btn:hover{background-color:#ede9fe}.editor-upload-btn svg{font-size:1.2rem}.editor-action-buttons{display:flex;gap:.8rem}.editor-save-btn,.editor-cancel-btn{border:none;border-radius:8px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease-in-out}.editor-save-btn{background-color:#7a5af8;color:#fff}.editor-save-btn:hover{background-color:#6944f3}.editor-cancel-btn{background-color:transparent;border:1px solid #d1d5db;color:#374151}.editor-cancel-btn:hover{background-color:#f3f4f6}@media(max-width:640px){.profile-picture-editor{flex-direction:column;align-items:flex-start}.editor-avatar-wrapper{width:100px;height:100px}}.admin-course-wrapper{padding:24px}.admin-actions{margin-top:20px;display:flex;gap:12px}.admin-action-bar{position:fixed;bottom:0;left:0;right:0;padding:16px;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:center;gap:16px;z-index:20}.lecture-wrapper{padding-bottom:60px;padding-top:100px}.lecture-layout{max-width:1400px;margin:0 auto;padding:24px;display:flex;gap:32px}.lecture-main{flex:1}.lecture-tabs{display:flex;gap:12px;margin-bottom:24px}.lecture-tab{padding:10px 18px;border-radius:8px;background:#f3f3f3;cursor:pointer;text-decoration:none;color:#444;font-weight:500;transition:.2s}.lecture-tab.active{background:#6b4eff;color:#fff}.lecture-tab.locked{opacity:.5;cursor:not-allowed}.lock-icon{margin-left:6px}.lecture-sidebar{width:320px;position:sticky;top:20px}.calendar-box,.events-box{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 2px 10px #0000000f}.calendar-placeholder{height:240px;background:#f7f7f7;border-radius:12px;display:flex;align-items:center;justify-content:center}.floating-cart-btn{position:fixed;right:40px;bottom:40px;background:#6b4eff;color:#fff;padding:14px 28px;border:none;font-size:16px;border-radius:50px;cursor:pointer;box-shadow:0 4px 12px #0003;transition:.2s}.floating-cart-btn:hover{background:#593be8}.floating-cart-btn:disabled{opacity:.6;cursor:not-allowed}.announcements-box{margin-top:20px}.announcement-mini{padding:6px;border-radius:6px;cursor:pointer}.announcement-mini.unseen{background:#eef2ff}.class-tab{display:flex;flex-direction:column;gap:24px}.class-hero{position:relative;border-radius:12px;overflow:hidden}.class-hero img{width:100%;height:240px;object-fit:cover}.class-hero-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#0009);padding:20px}.hero-content{color:#fff}.teacher-mini{display:flex;align-items:center;gap:10px}.teacher-mini img{width:36px;height:36px;border-radius:50%}.class-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 10px #0000000d}.class-card h3{margin-bottom:12px}.two-col{display:flex;gap:20px}.two-col>div{flex:1}.syllabus-item summary{cursor:pointer;padding:10px 0;font-weight:500}.syllabus-item ul{padding-left:20px;margin-top:6px}.syllabus-item li{margin-bottom:4px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg, #f3b8c7);overflow-x:hidden}
