@charset "UTF-8";@import url(https://fonts.cdnfonts.com/css/geist);@import url(https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700;800&display=swap);@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.notification{word-wrap:break-word;align-items:center;background-color:#fff;border-radius:12px;box-shadow:0 8px 16px #0003;display:flex;left:50%;max-width:90vw;min-width:250px;opacity:0;padding:16px;pointer-events:none;position:fixed;top:4rem;transform:translateX(-50%) translateY(20px);transition:opacity .3s ease,transform .3s ease;white-space:normal;width:auto}.notification.active{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}.notification.hidden{display:none;opacity:0;pointer-events:none;transform:translateX(-50%) translateY(20px)}.notification img{flex-shrink:0;height:40px;margin-right:12px;width:40px}.notification .details{display:flex;flex:1 1;flex-direction:column;margin-right:12px;min-width:0}.notification .message,.notification .name{overflow-wrap:break-word;white-space:normal}.material-icons-round.btn{cursor:pointer;font-size:20px;-webkit-user-select:none;user-select:none}.navbar{align-items:center;background-color:#1e293b;color:#fff;display:flex;font-family:Geist,sans-serif;justify-content:space-between;padding:2.5rem 5rem}.navbar-left{margin-right:auto}.navbar-left .logo{color:#fff;font-size:1.25rem;font-weight:700;text-decoration:none}.navbar-center .nav-links{display:flex;list-style-type:none;margin:0;padding:0}.navbar-center .nav-links li{font-size:1.25rem;margin-right:2.5rem}.navbar-center .nav-links a{color:#fff;text-decoration:none}.navbar-right{align-items:center;display:flex;font-size:1.25rem}.CustomButton{background-color:#1e293b;border:none;color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:1.25rem}.notification-button{background:none;border:none;color:#fff;font:inherit;padding:0}.class-card,.class-name-input{position:relative}.class-name-input input{background:#fff;border:2px solid #d1d5db;border-radius:20px;color:#6b7280;font-size:1rem;outline:none;padding:.75rem 1rem;transition:border-color .2s;width:90%}.class-name-input input:focus{border-color:#3b82f6}.class-name-input input::placeholder{color:#9ca3af}.remove-class-button{align-items:center;background:#ef4444;border:2px solid #fff;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:1.5rem;justify-content:center;position:absolute;right:-.5rem;top:-.5rem;transition:background .2s;width:1.5rem;z-index:10}.remove-class-button:hover{background:#dc2626}.upload-zone{align-items:center;background:#fff;border:2px dashed #d1d5db;border-radius:12px;display:flex;flex-direction:column;justify-content:center;min-height:120px;padding:2rem 1rem;text-align:center;transition:all .3s ease}.upload-zone.dragged-over{background-color:#eff6ff;border-color:#3b82f6;transform:scale(1.02)}.upload-zone.has-file{background-color:#f0fdf4;border-color:#22c55e;border-style:solid}.hidden{display:none}.upload-prompt{align-items:center;display:flex;flex-direction:column;gap:.75rem}.upload-prompt .icon{color:#9ca3af;height:2.5rem;margin-bottom:.5rem;width:2.5rem}.upload-prompt .attach-button{background:#1e293b;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background .2s}.upload-prompt .attach-button:hover{background:#334155}.upload-prompt .hint{color:#9ca3af;font-size:.875rem;margin:0}.file-info{align-items:center;display:flex;flex-direction:column;gap:.5rem}.file-info .icon{color:#22c55e;height:2.5rem;margin-bottom:.5rem;width:2.5rem}.filename{color:#22c55e;font-size:.9rem;font-weight:600;margin:0;text-align:center;word-break:break-word}.filesize{color:#6b7280;font-size:.75rem;margin:0}.file-actions{display:flex;gap:.75rem;justify-content:center;margin-top:.5rem}.remove-button,.replace-button{border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.4rem .875rem;transition:all .2s}.replace-button{background-color:#3b82f6}.replace-button:hover{background-color:#2563eb}.remove-button{background-color:#ef4444}.remove-button:hover{background-color:#dc2626}.error-banner{align-items:flex-start;background-color:#ef44441a;border:1px solid #ef444466;border-radius:8px;display:flex;gap:.75rem;margin-bottom:2rem;padding:1rem}.error-icon{color:#f87171;flex-shrink:0;height:1.25rem;margin-top:.25rem;width:1.25rem}.error-title{color:#ee9696;font-weight:500;margin:0}.error-message{color:#761212;font-size:.875rem;margin-top:.25rem}.add-class-wrapper{display:flex;justify-content:center;margin:2rem 0}.add-class-button{align-items:center;background:#0000;border:2px dashed #d1d5db;border-radius:12px;color:#6b7280;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;min-height:60px;min-width:200px;padding:1rem 2rem;transition:all .2s ease}.add-class-button:hover{background:#f9fafb;border-color:#9ca3af;color:#4b5563}.add-class-button:active{transform:scale(.98)}.plan-classes-wrapper{align-items:center;background:#fff;color:#1e293b;display:flex;flex-direction:column;min-height:100vh;padding:3rem 1rem}.header-section{margin-bottom:3rem;text-align:center}.header-section h1{font-size:2.25rem;font-weight:700;margin-bottom:.5rem}.header-section p{color:#cbd5e1;font-size:1.125rem}.schedule-container{background:#f9f9f9;border:3px solid #1e293b;border-radius:24px;box-shadow:0 4px 6px -1px #0000001a;max-width:900px;padding:2rem;position:relative;width:100%}.schedule-header{align-items:center;background:#1e293b;border-radius:16px;color:#fff;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1rem 1.5rem}.schedule-title{font-family:Geist,sans-serif;font-size:1.25rem;font-weight:600}.edit-button{background:#1e293b;border:1px solid #38667c;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background .2s}.edit-button:hover{background:#334155}.class-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.class-grid>*{align-items:center;box-sizing:border-box;display:flex;flex-direction:column;height:260px}.class-grid .file-name,.class-grid h3,.class-grid p{-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;display:-webkit-box;line-height:1.25;margin:.75rem 0 0;max-height:2.5em;max-width:100%;min-height:2.5em;overflow:hidden;text-align:center;text-overflow:ellipsis;word-break:break-word}.class-grid>* button{margin-top:auto}@media (max-width:1024px){.class-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.class-grid{grid-template-columns:1fr}.schedule-container{padding:1.5rem}.schedule-header{flex-direction:column;gap:1rem;text-align:center}}.add-class-section{display:flex;justify-content:center;margin-bottom:2rem}.notes-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem;position:absolute;right:-15.5vw;top:15.25vh;width:13vw}.notes-title{color:#374151;font-weight:600;margin-bottom:.5rem}.notes-content{color:#6b7280;font-size:.875rem;line-height:1.5}.notes-section-left{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;left:1vw;padding:1.5rem;position:absolute;top:97.5vh;width:13vw}@media (max-width:1400px){.notes-section{display:none}}.submit-section{display:flex;justify-content:center;margin-top:2rem}.submit-button{background-color:#1e293b;border:1px solid #38667c;border-radius:8px;color:#fff;cursor:pointer;font-size:1.125rem;font-weight:500;padding:.75rem 2rem;transition:background .2s}.submit-button:hover{background-color:#334155}.submit-button.disabled{background-color:#6b7280;cursor:not-allowed}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{appearance:button;cursor:pointer;overflow:visible;text-transform:none}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{align-items:stretch;box-sizing:border-box;display:flex;flex-direction:column;height:100%}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar :after,.rbc-calendar :before{box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.rbc-ellipsis,.rbc-event-label,.rbc-row-segment .rbc-event-content,.rbc-show-more{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{border-bottom:1px solid #ddd;flex:1 0;font-size:90%;font-weight:700;min-height:0;overflow:hidden;padding:0 3px;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{background:none;border:none;color:inherit;cursor:pointer;margin:0;padding:0;-webkit-user-select:text;user-select:text}.rbc-row-content{position:relative;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:flex;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{-ms-overflow-style:none;height:100%;overflow-y:scroll;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{align-items:center;display:flex;flex-wrap:wrap;font-size:16px;justify-content:center;margin-bottom:10px}.rbc-toolbar .rbc-toolbar-label{flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{background:none;background-image:none;border:1px solid #ccc;border-radius:4px;color:#373a3c;display:inline-block;line-height:normal;margin:0;padding:.375rem 1rem;text-align:center;vertical-align:middle;white-space:nowrap}.rbc-toolbar button.rbc-active,.rbc-toolbar button:active{background-color:#e6e6e6;background-image:none;border-color:#adadad;box-shadow:inset 0 3px 5px rgba(0,0,0,.125)}.rbc-toolbar button.rbc-active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button:active:hover{background-color:#d4d4d4;border-color:#8c8c8c;color:#373a3c}.rbc-toolbar button:focus,.rbc-toolbar button:hover{background-color:#e6e6e6;border-color:#adadad;color:#373a3c}.rbc-toolbar button:hover{cursor:pointer}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:4px;border-bottom-left-radius:0;border-top-left-radius:0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px;border-bottom-right-radius:0;border-top-right-radius:0}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media (max-width:767px){.rbc-toolbar{flex-direction:column}}.rbc-day-slot .rbc-background-event,.rbc-event{background-color:#3174ad;border:none;border-radius:5px;box-shadow:none;box-sizing:border-box;color:#fff;cursor:pointer;margin:0;padding:2px 5px;text-align:left;width:100%}.rbc-day-slot .rbc-slot-selecting .rbc-background-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-slot-selecting .rbc-event{cursor:inherit;pointer-events:none}.rbc-day-slot .rbc-selected.rbc-background-event,.rbc-event.rbc-selected{background-color:#265985}.rbc-day-slot .rbc-background-event:focus,.rbc-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{box-shadow:-1px 1px 5px 0 #33333380}.rbc-event-continues-prior{border-bottom-left-radius:0;border-top-left-radius:0}.rbc-event-continues-after{border-bottom-right-radius:0;border-top-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:flex;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;color:#3174ad;font-size:85%;font-weight:700;height:auto;line-height:normal;z-index:4}.rbc-show-more:focus,.rbc-show-more:hover{color:#265985}.rbc-month-view{border:1px solid #ddd;display:flex;flex:1 0;flex-direction:column;height:100%;position:relative;user-select:none;-webkit-user-select:none;width:100%}.rbc-month-header{display:flex;flex-direction:row}.rbc-month-row{display:flex;flex:1 0;flex-basis:0px;flex-direction:column;height:100%;overflow:hidden;position:relative}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{flex:1 1;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:flex;flex:1 0;flex-direction:row;overflow:hidden;right:1px}.rbc-day-bg{flex:1 0}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{background-color:#fff;border:1px solid #e5e5e5;box-shadow:0 5px 15px #00000040;padding:10px;position:absolute;z-index:5}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:flex;flex:1 0;flex-direction:column;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{border:1px solid #ddd;border-collapse:collapse;border-spacing:0;width:100%}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{border-bottom:1px solid #ddd;padding:3px 5px;text-align:left}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:flex;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{flex:1 1}.rbc-timeslot-group{border-bottom:1px solid #ddd;display:flex;flex-flow:column nowrap;min-height:40px}.rbc-header-gutter,.rbc-time-gutter{flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{bottom:0;left:0;margin-right:10px;position:absolute;right:0;top:0}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-event{align-items:flex-start;border:1px solid #265985;display:flex;flex-flow:column wrap;max-height:100%;min-height:20px;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{word-wrap:break-word;flex:1 1;height:100%;line-height:1;min-height:1em;width:100%}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{background-color:#fff;border-right:1px solid #ddd;left:0;margin-right:-1px;position:sticky;z-index:10}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{flex:1 0;flex-basis:0px;min-width:auto}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-day-bg,.rbc-time-view-resources .rbc-header{flex:1 1;flex-basis:0 px;width:140px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{flex:1 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{background-color:#00000080;color:#fff;font-size:75%;padding:3px;position:absolute;width:100%;z-index:10}.rbc-slot-selecting{cursor:move}.rbc-time-view{border:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-height:0;width:100%}.rbc-time-view .rbc-time-gutter{text-align:right;white-space:nowrap}.rbc-time-view .rbc-allday-cell{box-sizing:initial;height:100%;position:relative;width:100%}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{box-sizing:border-box;min-height:20px}.rbc-time-header{display:flex;flex:0 0 auto;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-left:1px solid #ddd;border-right-width:0}.rbc-time-header>.rbc-row.rbc-row-resource,.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{border-left:1px solid #ddd;display:flex;flex:1 1;flex-direction:column;min-width:0}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;flex-shrink:0}.rbc-time-content{align-items:flex-start;border-top:2px solid #ddd;display:flex;flex:1 0;overflow-y:auto;position:relative;width:100%}.rbc-time-content>.rbc-time-gutter{flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{user-select:none;-webkit-user-select:none;width:100%}.rbc-current-time-indicator{background-color:#74ad31;height:1px;left:0;pointer-events:none;position:absolute;right:0;z-index:3}.rbc-resource-grouping.rbc-time-header-content{display:flex;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.plan-calendar-container{background-color:#f5f5f7;font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;padding:1.5rem 2rem}.header-nav{background-color:#1e293b;border-radius:.5rem;color:#fff;margin-bottom:1.5rem;padding:1rem}.breadcrumb,.nav-links{font-size:.875rem}.nav-links{display:flex;gap:1.5rem}.main-content{max-width:112rem}.page-title{color:#0f172a;font-family:Geist,sans-serif;font-size:2.6rem;letter-spacing:-.015em;line-height:1.2;margin:1.5rem 0 2rem 6.5rem;text-align:left}.content-layout{align-items:flex-start;flex-wrap:nowrap}.calendar-section{align-items:flex-start;flex:1 1;gap:1.5rem}.preview-tab{align-self:flex-start;background-color:#111827;margin-top:8.5rem;min-height:420px!important;padding:.8rem;width:2rem!important}.preview-text{font-size:.7rem;font-weight:500;text-transform:uppercase}.calendar-container{background-color:#fcfcff;border-radius:.75rem;box-shadow:0 10px 30px -18px #0f172a4d;max-width:100%;padding:0}.calendar-wrapper{height:620px;overflow:hidden;width:100%}.custom-toolbar{background-color:#fff;border-bottom:1px solid #e5e7eb;border-radius:.75rem .75rem 0 0;color:#111827;padding:.75rem 1.25rem}.toolbar-btn{background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:9999px;color:#4b5563;font-size:.8rem;padding:.35rem .85rem;transition:background-color .12s ease,transform .12s ease}.toolbar-btn:hover{background-color:#e5e7eb;transform:translateY(-.5px)}.toolbar-title{font-size:.95rem;letter-spacing:.05em;text-transform:uppercase}.toolbar-subtitle{color:#6b7280;font-size:.75rem;margin:.2rem 0 0}.sidebar{background-color:initial;border:none;flex:0 0 22rem;max-height:670px;max-width:22rem;padding-top:.25rem}.sidebar-actions{align-items:stretch;gap:1rem}.sidebar-actions,.sidebar-pill{display:flex;flex-direction:column}.sidebar-pill{align-items:flex-start;border:none;border-radius:.9rem;box-shadow:0 12px 24px -18px #0f172abf;cursor:pointer;padding:.7rem 1.1rem;text-align:left;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease;width:100%}.sidebar-pill-primary{background:linear-gradient(135deg,#7ec8ff,#2c6fdf);color:#fff}.sidebar-pill-secondary{background:linear-gradient(135deg,#a9ddff,#6ea8e9);color:#fff}.sidebar-pill:hover{box-shadow:0 16px 30px -20px #0f172ae6;opacity:.97;transform:translateY(-1px)}.sidebar-pill:disabled{cursor:default;opacity:.7}.sidebar-pill-title{font-size:.9rem;font-weight:600}.sidebar-pill-subtext{font-size:.78rem;margin-top:.15rem;opacity:.95}.sidebar-pill-cta{font-size:.78rem;font-weight:600;margin-top:.4rem;text-decoration:underline}.rbc-header{background-color:#fff;height:52px;line-height:1.2!important;overflow:visible;padding:8px 4px}.rbc-custom-header{align-items:center;display:flex;flex-direction:column;justify-content:center}.rbc-custom-header-day{color:#374151;font-size:1.3rem;font-weight:600;letter-spacing:.03em}.rbc-custom-header-date{color:#9ca3af;font-size:.8rem;letter-spacing:.08em;margin-top:.1rem;text-transform:uppercase}.rbc-time-gutter .rbc-timeslot-group{color:#9ca3af;font-size:.7rem}.rbc-day-slot .rbc-timeslot-group,.rbc-time-gutter .rbc-timeslot-group{min-height:70px}.rbc-time-view .rbc-day-bg:nth-child(2n){background-color:#f5f5f7}.rbc-time-view .rbc-day-bg:nth-child(odd){background-color:#fff}.rbc-day-slot .rbc-time-slot{border-color:#d1d5db #eceff3 #eceff3;border-top:1px solid #eceff3}.rbc-time-view .rbc-day-slot{border-left:1px solid #d1d5db}.rbc-time-view .rbc-day-slot:last-child{border-right:1px solid #d1d5db}.rbc-today{background-color:#81d4fa2e!important}.rbc-event{border-radius:6px;box-shadow:0 8px 16px -10px #0f172a99;font-size:.7rem;margin:2px 4px;padding:2px 6px}.rbc-show-more{color:#2563eb;font-size:.7rem}.test-countdown{color:#ef4444;font-weight:600;margin:12px 0 8px}.notification-message{color:#111;font-weight:500;margin-top:12px}@media (max-width:1024px){.plan-calendar-container{padding:1.25rem}.page-title{font-size:2.2rem;margin:.5rem 0 1rem 1rem}.content-layout{align-items:stretch;flex-direction:column}.calendar-section,.sidebar{width:100%}.sidebar{flex:0 0 auto;max-width:100%}.calendar-wrapper{height:540px}}@media (max-width:640px){.plan-calendar-container{padding:1rem .75rem}.page-title{font-size:1.8rem;margin:.25rem 0 .75rem .25rem}.content-layout{gap:1.25rem}.calendar-section{flex-direction:column;gap:.75rem}.preview-tab{border-radius:9999px;justify-content:center;min-height:auto;padding:.5rem 1rem;width:100%}.preview-text{font-size:.75rem;transform:none}.calendar-container{width:100%}.calendar-wrapper{height:480px}.sidebar-header{text-align:left}.sidebar-pill{padding:.6rem .9rem}.rbc-custom-header-day{font-size:1rem}.rbc-custom-header-date{font-size:.7rem}.rbc-day-slot .rbc-timeslot-group,.rbc-time-gutter .rbc-timeslot-group{min-height:55px}}.plan-calendar-container{background-color:#f9fafb;box-sizing:border-box;min-height:100vh;padding:2rem;width:100%}.main-content{box-sizing:border-box;margin:0 auto;max-width:1400px;padding:0;width:100%}.page-title{color:#1f2937;font-size:2.5rem;font-weight:700;margin-bottom:2.5rem;text-align:center}.content-layout{align-items:center;display:flex;flex-direction:row;gap:2rem;max-width:none;width:100%}.calendar-section{display:flex;gap:1rem;min-width:0;width:70%}.preview-tab{align-items:center;background-color:#1e293b;border-radius:9999px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;color:#fff;display:flex;flex-shrink:0;justify-content:center;min-height:60px;padding:1rem;width:5rem}.preview-text{font-size:.875rem;font-weight:600;letter-spacing:.05em;transform:rotate(-90deg);white-space:nowrap}.calendar-container{background-color:#f8f9fa;border:1px solid #e5e7eb;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-sizing:border-box;flex:1 1;min-width:0;padding:1.5rem}.custom-toolbar{align-items:center;background-color:#1e293b;border-radius:.75rem;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;margin-bottom:1.25rem;padding:1rem 1.25rem}.toolbar-btn{background-color:#475569;border:none;border-radius:.5rem;box-shadow:0 1px 2px #0000001a;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s ease}.toolbar-btn:hover{background-color:#334155;box-shadow:0 2px 4px #00000026;transform:translateY(-1px)}.toolbar-btn:active{transform:translateY(0)}.toolbar-title{font-size:1.375rem;font-weight:600;letter-spacing:-.025em;margin:0}.sidebar{background-color:#f8f9fa;border:1px solid #e5e7eb;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-sizing:border-box;display:flex;flex-direction:column;flex-shrink:0;gap:1.5rem;height:1000px;overflow-x:hidden;overflow-y:auto;padding:1.5rem;width:30%}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.card{background-color:#fff;border:none;border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;transition:box-shadow .2s ease}.card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card-title{color:#1f2937;font-size:1.125rem;letter-spacing:-.025em;margin-bottom:1rem}.card-divider{border:none;border-top:1px solid #e5e7eb;margin:1rem 0}.note-content{color:#4b5563;font-size:.875rem;gap:.75rem;line-height:1.625}.legend-items,.note-content{display:flex;flex-direction:column}.legend-items{gap:.875rem}.legend-item{align-items:center;display:flex;gap:.875rem}.legend-color{border-radius:.25rem;box-shadow:0 1px 2px #0000001a;flex-shrink:0;height:1.125rem;width:1.125rem}.quiz-color{background-color:#3b82f6}.exam-color{background-color:#ef4444}.assignment-color{background-color:#10b981}.legend-item span{color:#374151;font-size:.875rem;font-weight:500}.study-plan-btn{background:linear-gradient(135deg,#7ec8ff,#2c6fdf);border:none;border-radius:.75rem;box-shadow:0 8px 16px -6px #2c6fdf66;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.625rem 1.25rem;transition:all .25s ease;width:100%}.study-plan-btn:hover{background:linear-gradient(135deg,#6ab8ff,#1f5fd8);box-shadow:0 10px 20px -8px #2c6fdf99;transform:translateY(-2px)}.study-plan-btn:active{box-shadow:0 6px 12px -6px #2c6fdf80;transform:translateY(0)}.rbc-calendar{font-family:"system-ui",-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.rbc-month-view{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;overflow:visible}.rbc-header{background-color:#f8fafc;border-bottom:1px solid #e5e7eb;color:#374151;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:12px 8px;text-align:center;text-transform:uppercase}.rbc-date-cell{padding:8px;transition:background-color .15s ease}.rbc-date-cell:hover{background-color:#f9fafb}.rbc-date-cell>a{color:#374151;font-size:.875rem;font-weight:500}.rbc-today{background-color:#dbeafe!important;font-weight:600}.rbc-today>a{color:#1e40af!important}.rbc-event{border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;margin:2px 0;overflow:hidden;padding:3px 6px;text-overflow:ellipsis;transition:opacity .2s ease;white-space:nowrap}.rbc-event:hover{opacity:.9}.rbc-show-more{border-radius:4px;color:#4f46e5;font-size:11px;font-weight:500;padding:2px 4px;transition:background-color .2s ease}.rbc-show-more:hover{background-color:#eef2ff}.rbc-day-bg{border:1px solid #f3f4f6}.rbc-off-range-bg{background-color:#f9fafb}.rbc-month-row{border-bottom:1px solid #f3f4f6;height:auto;min-height:100px}.rbc-month-row:last-child{border-bottom:none}.notification-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.notification-list li{align-items:center;border-radius:8px;display:flex;font-size:14px;font-weight:500;justify-content:space-between;padding:10px 12px}.notif-exam{background-color:#fee2e2;border-left:4px solid #f87171;color:#7f1d1d}.notif-quiz{background-color:#dbeafe;border-left:4px solid #3b82f6;color:#1e3a8a}.notification-list li strong{font-weight:600;max-width:70%}.notification-list li span{font-size:12px;font-weight:600;opacity:.85;white-space:nowrap}.note-content{color:#6b7280;font-size:14px}.notification-list li:hover{transform:translateY(-1px);transition:transform .15s ease}.checkmark-style{align-items:center;border-radius:8px;cursor:pointer;display:flex;padding:12px;transition:background .2s ease;-webkit-user-select:none;user-select:none}.checkmark-style:hover{background:#f8fafc}.checkmark-style .check-box{border:2px solid #d1d5db;border-radius:6px;height:22px;margin-right:12px;position:relative;transition:all .3s ease;width:22px}.checkmark-style .check-box:after{border:solid #fff;border-width:0 2.5px 2.5px 0;content:"";height:11px;left:6px;position:absolute;top:2px;transform:rotate(45deg) scale(0);transition:all .3s cubic-bezier(.68,-.55,.265,1.55);width:5px}.hidden-checkbox{opacity:0;pointer-events:none;position:absolute}input[type=checkbox]:checked+.checkmark-style .check-box{background:#8b5cf6;border-color:#8b5cf6}input[type=checkbox]:checked+.checkmark-style .check-box:after{transform:rotate(45deg) scale(1)}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}:root{--primary:#1e293b;--secondary:#334155}.btn{border:none;border-radius:8px;cursor:pointer;outline:none;padding:8px 20px}.btn--primary{background-color:#1e293b;background-color:var(--primary);border:1px solid #1e293b;border:1px solid var(--primary);color:#fff;transition:background .2s,transform .1s}.btn--outline{background-color:initial;border:1px solid #334155;border:1px solid var(--secondary);color:#334155;color:var(--secondary);padding:8px 20px;transition:all .3s ease-out}.btn--medium{font-size:20px;padding:8px 20px}.btn--large{font-size:20px;padding:12px 26px}.btn--large:hover,.btn--medium:hover{background:#334155;background:var(--secondary);color:#fff;transition:all .3s ease-out}.hero-container{align-items:center;box-shadow:inset 0 0 0 1000px #0003;color:#38667c;display:flex;flex-direction:column;height:100vh;justify-content:center;object-fit:contain;width:100%}.hero-container>h1{color:#1e293b;font-size:100px;margin-top:-100px}.hero-container>p{color:#1e293b;font-family:Trebuchet MS,Lucida Sans Unicode,Lucida Grande,Lucida Sans,Arial,sans-serif;font-size:32px;margin-top:-40px}.hero-btns{margin-top:32px}.hero-btns .btn{margin:6px}.fa-play-circle{margin-left:4px}@media screen and (max-width:960px){.hero-container>h1{font-size:70px;margin-top:-150px}}@media screen and (max-width:768px){.hero-container>h1{font-size:50px;margin-top:-100px}.hero-container>p{font-size:30px}.btn-mobile{display:block;text-decoration:none}.btn{width:100%}}.get-to-know-container{align-items:center;display:flex;flex-direction:column;font-family:Helvetica Neue,sans-serif;font-size:2.5rem;font-weight:300;height:80vh;justify-content:center;text-align:center}@keyframes typing{0%,3%{content:""}4%,6%{content:"L"}7%,9%{content:"Le"}10%,12%{content:"Let"}13%,15%{content:"Let'"}16%,18%{content:"Let's"}19%,21%{content:"Let's "}22%,24%{content:"Let's g"}25%,27%{content:"Let's ge"}28%,30%{content:"Let's get"}31%,33%{content:"Let's get "}34%,36%{content:"Let's get t"}37%,39%{content:"Let's get to"}40%,42%{content:"Let's get to "}43%,45%{content:"Let's get to k"}46%,48%{content:"Let's get to kn"}49%,51%{content:"Let's get to kno"}52%,54%{content:"Let's get to know"}55%,57%{content:"Let's get to know "}58%,60%{content:"Let's get to know y"}61%,63%{content:"Let's get to know yo"}64%,66%{content:"Let's get to know you"}67%,69%{content:"Let's get to know you "}70%,72%{content:"Let's get to know you b"}73%,75%{content:"Let's get to know you be"}76%,78%{content:"Let's get to know you bet"}79%,81%{content:"Let's get to know you bett"}82%,84%{content:"Let's get to know you bette"}85%,87%{content:"Let's get to know you better"}88%,to{content:"Let's get to know you better!"}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.typewriter{--caret:#1e293b;color:#1e293b;font-family:Lato,sans-serif;font-weight:700;position:relative}.typewriter:before{animation:typing 4s steps(40) forwards;content:"";display:inline-block;overflow:hidden;white-space:nowrap}.typewriter:after{animation:blink .7s step-end infinite;border-right:2px solid var(--caret);content:"";position:absolute;right:-.5ch}.fade-in-button{animation:fadeIn 1s ease-in forwards;animation-delay:4s;margin-top:2rem;opacity:0;transform:translateY(10px)}.fade-in-button:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.container{background-color:#f3f4f6;font-family:system-ui,-apple-system,sans-serif;min-height:100vh;padding:20px}.carousel-container,.container{align-items:center;display:flex;justify-content:center}.carousel-container{flex-direction:column}.carousel-wrapper{gap:30px;max-width:1200px;position:relative;width:100%}.carousel-wrapper,.side-card{align-items:center;display:flex;justify-content:center}.side-card{background-color:#e5e7eb;border-radius:30px;box-shadow:0 10px 25px #0000001a;color:#9ca3af;height:400px;width:300px}.main-card-container{position:relative}.main-card{background-color:#fff;border:3px solid #374151;border-radius:30px;box-shadow:0 20px 40px #00000026;flex-direction:column;height:500px;padding:30px;position:relative;width:400px}.card-number,.main-card{align-items:center;display:flex}.card-number{background-color:#374151;border-radius:50%;color:#fff;font-size:18px;font-weight:700;height:35px;justify-content:center;left:30px;position:absolute;top:25px;width:35px}.card-content{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;margin-top:20px;text-align:center}.card-title{color:#374151;font-size:24px;font-weight:600;margin-bottom:30px}.sleep-text{margin-bottom:15px}.sleep-question,.sleep-text{color:#6b7280;font-size:16px}.sleep-question{line-height:1.5;margin-bottom:30px}.slider-instruction{color:#9ca3af;font-size:14px;margin-bottom:20px}.slider-container{margin-bottom:15px;position:relative;width:100%}.slider-track{background-color:#a8c8d7;border:1px solid #386e88;border-radius:4px;height:8px;position:relative;width:100%}.slider-input{appearance:none;background:#0000;cursor:pointer;height:100%;left:0;outline:none;position:absolute;top:0;width:100%}.slider-input::-webkit-slider-thumb{appearance:none;background:#0000;border-radius:50%;cursor:pointer;height:20px;width:20px}.slider-input::-moz-range-thumb{background:#0000;border:none;border-radius:50%;cursor:pointer;height:20px;width:20px}.slider-thumb{background-color:#1e293b;border:1px solid #334155;border-radius:50%;box-shadow:0 2px 8px #0003;cursor:pointer;height:20px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.slider-labels{color:#9ca3af;display:flex;font-size:14px;justify-content:space-between;margin-bottom:20px}.hours-display{color:#374151;font-size:20px;font-weight:700}.card-text{color:#6b7280;font-size:16px;line-height:1.6}.card\,container{align-items:center;display:flex;justify-content:center}.GPA-text,.Major-text,.Technique-text{color:#6b7280}.GPA-text,select{text-align:center}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;border:2px solid #ccc;border-radius:9999px;color:#4c8eae;cursor:pointer;font-size:14px;outline:none;padding:8px 14px;transition:.2s ease;width:220px}select:hover{border-color:#888}select:focus{border-color:#4a90e2;box-shadow:0 0 4px #4a90e299}select option{text-align:center}.GPA{flex-direction:column;text-align:center}.GPA,.GPA-header{align-items:center;display:flex}.GPA-header{gap:8px}.info-button{background:none;border:none;cursor:pointer;font-size:18px;padding:0}.info-button:hover{opacity:.7}.GPA input{border:2px solid #ccc;border-radius:9999px;font-size:16px;outline:none;padding:8px 14px;text-align:center;transition:.2s ease;width:200px}.submitInfo{border:none;border-radius:9999px;height:30px;margin-top:40px;width:100px}.nav-button,.submitInfo{background-color:#1e293b;color:#fff}.nav-button{align-items:center;border:1px solid #3c5f70;border-radius:50%;box-shadow:0 4px 12px #0003;cursor:pointer;display:flex;height:50px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s ease;width:50px;z-index:10}.nav-button:hover:not(.disabled){background-color:#334155}.nav-button.disabled{background-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.prev-button{left:-25px}.next-button{right:-25px}.progress-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}.dot{background-color:#d1d5db;height:8px;width:8px}.dot.active{background-color:#374151}.skip-button{background:#0000;border:none;color:#4c8eae;cursor:pointer;font-size:16px;padding:8px 16px;position:absolute;right:20px;top:20px;transition:all .2s;z-index:100}.skip-button:hover{color:#336882;transform:translateX(4px)}.gpa-input:focus{border-color:#336882;outline:none}body{margin:0;padding:0}.study-materials-wrapper{background:#fff;color:#1b2640;font-family:Geist,sans-serif;min-height:100vh;padding-bottom:2rem;width:100%}.materials-inner{align-items:flex-start;box-sizing:border-box;display:flex;flex-direction:column;padding-left:2.2rem;padding-right:3rem;padding-top:2rem;width:100%}.breadcrumb{align-items:center;display:flex;font-size:.95rem;gap:.45rem;margin-bottom:.8rem;padding-left:0}.breadcrumb span{cursor:pointer;text-decoration:underline}.breadcrumb-separator{color:#1b2640;cursor:default;text-decoration:none!important}.breadcrumb .active{font-weight:600}.page-header{display:flex;flex-direction:column;gap:1rem;width:100%}.page-header>div:last-child{align-items:center;display:flex;justify-content:space-between;width:100%}.back-btn{background:#1e293b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Geist,sans-serif;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background .2s;white-space:nowrap}.back-btn:hover{background:#334155}.page-title{color:#1b2640;display:inline-block!important;font-size:40px;font-weight:800;letter-spacing:-2px;margin:1rem 0 2.8rem 3rem!important;position:relative;text-align:left!important;width:auto!important}.title-underline{border-bottom:3px solid #1e293b;display:inline-block;padding-bottom:6px;width:auto}.content-container{align-items:flex-start;clear:both;display:flex;gap:3rem;justify-content:flex-start;margin-top:3rem;width:100%}.note-wrapper{background:#f9f9f9;border-radius:16px;box-sizing:border-box;flex-shrink:0;min-width:400px;padding:2rem 2.5rem;width:400px}.note-box{background:#fff;border:2px solid #1e293b;border-radius:16px;box-sizing:border-box;padding:1.5rem 1.8rem;width:100%}.note-title{align-items:center;display:flex;font-size:1rem;font-weight:800;margin-bottom:.6rem;width:100%}.note-title:after{background-color:#1b2640;content:"";flex:1 1;height:1px;margin-left:.5rem;transform:translateY(-2px)}.note-text{font-size:.9rem;line-height:1.6;text-align:left}.right-pane{background:#f9f9f9;border-radius:16px;box-sizing:border-box;flex:1 1;padding:2rem 2.5rem}.class-materials-grid{grid-gap:2.5rem 2rem;display:grid;gap:2.5rem 2rem;grid-template-columns:repeat(3,1fr);justify-content:center;max-width:900px;width:100%}.class-card{align-items:center;display:flex;flex-direction:column;gap:1rem}.class-top{background:#fff;border:2px solid #1e293b;border-radius:25px;gap:.8rem;height:50px;justify-content:flex-start;max-width:240px;padding-left:1rem;width:100%}.class-number,.class-top{align-items:center;display:flex;font-family:Geist,sans-serif}.class-number{background:#1e293b;border-radius:50%;color:#fff;flex-shrink:0;font-size:.9rem;font-weight:700;height:34px;justify-content:center;width:34px}.class-name{color:#1e293b}.class-name,.upload-btn{font-family:Geist,sans-serif;font-size:1rem;font-weight:500}.upload-btn{background:#1e293b;border:none;border-radius:25px;color:#fff;cursor:pointer;height:50px;max-width:240px;transition:opacity .2s;width:100%}.upload-btn:hover{opacity:.9}.action-buttons-container{border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:1rem;margin-top:auto;padding-top:2rem;width:100%}.action-buttons-container h2{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.action-buttons{flex-wrap:wrap}.action-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-family:Geist,sans-serif;font-size:1rem;font-weight:500;min-width:200px;padding:.75rem 1.5rem;transition:all .2s}.calendar-btn{background:#1e293b;color:#fff}.calendar-btn:hover{background:#334155}.quiz-btn{background:#3b82f6;color:#fff}.quiz-btn:hover{background:#2563eb}@media (max-width:1024px){.class-materials-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.content-container{flex-direction:column}.class-materials-grid{grid-template-columns:1fr}.note-wrapper{min-width:100%;width:100%}}.login-page{align-items:center;background-color:#f7f7f7;display:flex;justify-content:center;min-height:calc(100vh - 60px)}.login-card{background-color:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;max-width:400px;padding:50px 40px;text-align:center;width:100%}.login-title{color:#1e2a38;font-size:28px;font-weight:700;margin-bottom:15px}.login-subtitle{color:#4a4a4a;font-size:15px;line-height:1.4;margin-bottom:40px}.login-button{background-color:#1e293b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background-color .2s ease;width:100%}.login-button:hover{background-color:#334155}.practice-test-container{background:#f5f7fa;margin:0 auto;max-width:900px;min-height:100vh;padding:2rem 1rem}.test-header{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem}.test-info h1{color:#1a1a1a;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.test-meta{color:#666;display:flex;font-size:.875rem;gap:1.5rem}.answered-count{color:#4c8eae;gap:.25rem}.answered-count,.timer{align-items:center;display:flex}.timer{background:#fff3cd;border-radius:8px;color:#856404;font-size:1.125rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem}.progress-bar-container{background:#e9ecef;border-radius:3px;height:6px;margin-bottom:2rem;overflow:hidden}.progress-bar{background:linear-gradient(90deg,#4c8eae,#336882);border-radius:3px;height:100%;transition:width .3s ease}.question-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;padding:2rem}.question-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.question-type{background:#e3f2fd;border-radius:20px;color:#1976d2;display:inline-block;padding:.375rem .875rem}.question-number,.question-type{font-size:.875rem;font-weight:500}.question-number{color:#666}.question-content h2{color:#1a1a1a;font-size:1.25rem;font-weight:500;line-height:1.6;margin:0 0 1.5rem}.options-container{display:flex;flex-direction:column;gap:.875rem}.option{align-items:center;background:#f8f9fa;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;display:flex;gap:1rem;padding:1rem 1.25rem;transition:all .2s ease}.option:hover{background:#e7f3f8;border-color:#4c8eae;transform:translateX(4px)}.option.selected{background:#e3f2fd;border-color:#4c8eae;box-shadow:0 4px 12px #4c8eae26}.option-radio{align-items:center;border:2px solid #4c8eae;border-radius:50%;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.radio-dot{background:#1e293b;border-radius:50%;height:10px;width:10px}.option-text{color:#333;font-size:1rem}.short-answer-input{border:2px solid #e9ecef;border-radius:10px;font-family:inherit;font-size:1rem;padding:1rem;resize:vertical;transition:border-color .2s ease;width:100%}.short-answer-input:focus{border-color:#4c8eae;box-shadow:0 0 0 3px #4c8eae1a;outline:none}.test-navigation{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;gap:1rem;justify-content:space-between;padding:1.5rem}.nav-btn,.test-navigation{align-items:center;display:flex}.nav-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.nav-btn.primary{background:#1e293b;color:#fff}.nav-btn.primary:hover:not(:disabled){background:#334155;box-shadow:0 4px 12px #4c8eae4d;transform:translateY(-2px)}.nav-btn.secondary{background:#f8f9fa;border:2px solid #e9ecef;color:#333}.nav-btn.secondary:hover:not(:disabled){background:#e9ecef;border-color:#dee2e6}.nav-btn:disabled{cursor:not-allowed;opacity:.5}.question-dots{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.dot{background:#e9ecef;border-radius:50%;cursor:pointer;height:12px;transition:all .2s ease;width:12px}.dot:hover{transform:scale(1.3)}.dot.active{background:#1e293b;transform:scale(1.4)}.dot.answered{background:#28a745}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:400px;padding:2rem;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content h3{color:#1a1a1a;font-size:1.5rem;margin:0 0 1rem}.modal-content p{color:#666;line-height:1.6;margin:.5rem 0}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.modal-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:.75rem;transition:all .2s ease}.modal-btn.primary{background:#1e293b;color:#fff}.modal-btn.primary:hover{background:#334155;transform:translateY(-2px)}.modal-btn.secondary{background:#f8f9fa;border:2px solid #e9ecef;color:#333}.modal-btn.secondary:hover{background:#e9ecef}@media (max-width:768px){.practice-test-container{padding:1rem .5rem}.test-header{flex-direction:column;gap:1rem}.timer{align-self:flex-start}.test-meta{flex-direction:column;gap:.5rem}.question-card{padding:1.5rem}.test-navigation{flex-wrap:wrap}.question-dots{order:-1;width:100%}}.test-setup-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:100px auto;max-width:600px;padding:40px;text-align:center}.test-setup-card h1{color:#1a1a1a;margin-bottom:10px}.test-setup-card p{color:#666;margin-bottom:30px}.class-selector{margin:30px 0;text-align:left}.class-selector label{color:#1a1a1a;display:block;font-weight:600;margin-bottom:10px}.class-dropdown{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:16px;padding:12px 16px;transition:all .2s;width:100%}.class-dropdown:hover{border-color:#6366f1}.class-dropdown:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.generate-test-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:20px;padding:14px 24px;transition:all .3s;width:100%}.generate-test-btn:hover:not(:disabled){box-shadow:0 4px 12px #6366f166;transform:translateY(-2px)}.generate-test-btn:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;margin:20px 0;padding:16px;text-align:left}.loading-state{padding:100px 20px;text-align:center}.loading-state h2{color:#1a1a1a;margin-bottom:10px}.loading-state p{color:#666}.test-results-container{background:#f5f7fa;margin:0 auto;max-width:1000px;min-height:100vh;padding:2rem 1rem}.score-card{background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;padding:3rem 2rem;text-align:center}.score-card,.score-header{margin-bottom:2rem}.award-icon{animation:bounce 1s ease;color:#ffc107;margin-bottom:1rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.score-header h1{color:#1a1a1a;font-size:2rem;margin:0 0 .5rem}.class-info{color:#666;font-size:1rem;margin:0}.score-display{margin:2rem 0}.score-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4c8eae,#336882);-webkit-background-clip:text;background-clip:text;font-size:5rem;font-weight:700;line-height:1;margin-bottom:.5rem}.score-label{color:#666;font-size:1.25rem;font-weight:500}.score-details{border-bottom:2px solid #f0f0f0;border-top:2px solid #f0f0f0;display:flex;gap:3rem;justify-content:center;margin:2rem 0;padding:2rem 0}.detail-item{align-items:center;display:flex;flex-direction:column;gap:.5rem}.detail-label{color:#666;font-size:.875rem;font-weight:500}.detail-value{color:#1a1a1a;font-size:1.5rem;font-weight:600}.icon-correct{color:#28a745}.icon-incorrect{color:#dc3545}.icon-time{color:#4c8eae}.action-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.btn-primary,.btn-secondary{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s ease}.btn-primary{background:#1e293b;color:#fff}.btn-primary:hover{background:#334155;box-shadow:0 6px 20px #1e293b4d;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid #1e293b;color:#1e293b}.btn-secondary:hover{background:#f8f9fa;transform:translateY(-2px)}.questions-breakdown{margin-bottom:2rem}.questions-breakdown h2{color:#1a1a1a;font-size:1.5rem;margin:0 0 1.5rem}.question-review{background:#fff;border-left:4px solid #0000;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1rem;padding:1.5rem;transition:all .2s ease}.question-review.correct{border-left-color:#28a745}.question-review.incorrect{border-left-color:#dc3545}.question-review:hover{box-shadow:0 4px 16px #0000001f;transform:translateX(4px)}.question-review-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.question-review-number{align-items:center;color:#1a1a1a;display:flex;font-size:1rem;font-weight:600;gap:.75rem}.result-badge{border-radius:20px;font-size:.875rem;font-weight:600;padding:.375rem .875rem}.badge-correct{background:#d4edda;color:#155724}.badge-incorrect{background:#f8d7da;color:#721c24}.question-review-content{margin-top:1rem}.question-text{color:#333;font-size:1rem;font-weight:500;line-height:1.6;margin:0 0 1rem}.answer-comparison{display:flex;flex-direction:column;gap:.75rem}.answer-box{background:#f8f9fa;border-radius:8px;padding:1rem}.answer-box.your-answer{border:2px solid #e9ecef}.answer-box.correct-answer{background:#d4edda;border:2px solid #c3e6cb}.answer-label{color:#666;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.answer-text{color:#1a1a1a;display:block;font-size:1rem}.performance-summary{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:2rem}.performance-summary h3{color:#1a1a1a;font-size:1.25rem;margin:0 0 1.5rem}.summary-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-item{background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem;text-align:center}.summary-label{color:#666;font-size:.875rem;font-weight:500}.summary-value{color:#4c8eae;font-size:1.5rem;font-weight:700}@media (max-width:768px){.test-results-container{padding:1rem .5rem}.score-card{padding:2rem 1rem}.score-number{font-size:3.5rem}.score-details{gap:1rem}.action-buttons,.score-details{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.summary-grid{grid-template-columns:1fr}}:root{--bg-primary:#f0f2f5;--bg-secondary:#fff;--bg-tertiary:#f8f9fa;--text-primary:#1a1a2e;--text-secondary:#64748b;--text-muted:#94a3b8;--accent-purple:#6366f1;--accent-purple-light:#818cf8;--accent-green:#10b981;--accent-amber:#f59e0b;--accent-red:#ef4444;--border-color:#00000014;--card-shadow:0 2px 8px #00000014,0 1px 2px #0000000a;--card-shadow-hover:0 12px 24px #0000001f,0 4px 8px #0000000f;--font-display:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace}.dashboard-wrapper{background:#f0f2f5;background:var(--bg-primary);min-height:100vh;padding:24px}.dashboard-container{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font-display);margin:0 auto;max-width:1400px}.dashboard-header{margin-bottom:32px}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.header-text h1{color:#1a1a2e;color:var(--text-primary);font-size:2.5rem;font-weight:800;letter-spacing:-.02em;margin:0}.header-subtitle{color:#64748b;color:var(--text-secondary);font-size:1rem;margin:8px 0 0}.cta-button{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:linear-gradient(135deg,var(--accent-purple) 0,#8b5cf6 100%);border:none;border-radius:12px;box-shadow:0 4px 14px #6366f166;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.cta-button:hover{box-shadow:0 6px 20px #6366f180;transform:translateY(-2px)}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr 1fr 1fr;margin-bottom:32px}.stat-card{background:#fff;background:var(--bg-secondary);border:1px solid #00000014;border:1px solid var(--border-color);border-radius:20px;padding:24px;transition:all .3s ease}.stat-card:hover{border-color:#6366f14d;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000000f;box-shadow:var(--card-shadow-hover);transform:translateY(-4px)}.score-card{align-items:center;display:flex;flex-direction:column;grid-column:span 1;justify-content:center;overflow:hidden;position:relative}.score-card:before{background:linear-gradient(90deg,#6366f1,#10b981);background:linear-gradient(90deg,var(--accent-purple),var(--accent-green));content:"";height:4px;left:0;position:absolute;right:0;top:0}.score-visual{display:flex;justify-content:center;position:relative;width:100%}.score-center{left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.score-value{color:#1a1a2e;color:var(--text-primary);display:block;font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:2.5rem;font-weight:800;line-height:1}.score-label{color:#94a3b8;color:var(--text-muted);display:block;font-size:.75rem;letter-spacing:.1em;margin-top:4px;text-transform:uppercase}.score-meta{margin-top:8px}.grade-badge{border-radius:20px;color:#fff;display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.05em;padding:6px 16px;text-transform:uppercase}.mini-stat{gap:16px}.mini-stat,.mini-stat-icon{align-items:center;display:flex}.mini-stat-icon{border-radius:16px;color:#fff;flex-shrink:0;height:56px;justify-content:center;width:56px}.mini-stat-content{display:flex;flex-direction:column}.mini-stat-value{color:#1a1a2e;color:var(--text-primary);font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:1.75rem;font-weight:800;line-height:1.2}.mini-stat-label{color:#64748b;color:var(--text-secondary);font-size:.85rem}.chart-section{background:#fff;background:var(--bg-secondary);border:1px solid #00000014;border:1px solid var(--border-color);border-radius:20px;margin-bottom:32px;padding:24px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.section-header h2{align-items:center;color:#1a1a2e;color:var(--text-primary);display:flex;font-size:1.25rem;font-weight:700;gap:10px;margin:0}.section-header h2 svg{color:#6366f1;color:var(--accent-purple)}.time-toggle{background:#f8f9fa;background:var(--bg-tertiary);border-radius:10px;display:flex;padding:4px}.toggle-btn{background:#0000;border:none;border-radius:8px;color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 16px;transition:all .2s ease}.toggle-btn.active{background:#6366f1;background:var(--accent-purple);color:#fff}.toggle-btn:hover:not(.active){color:#1a1a2e;color:var(--text-primary)}.chart-container{height:280px}.chart-empty{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;height:100%;justify-content:center}.custom-tooltip{background:#fff;background:var(--bg-secondary);border:1px solid #00000014;border:1px solid var(--border-color);border-radius:10px;box-shadow:0 2px 8px #00000014,0 1px 2px #0000000a;box-shadow:var(--card-shadow);padding:12px 16px}.tooltip-label{color:#64748b;color:var(--text-secondary);font-size:.8rem;margin:0 0 4px}.tooltip-value{color:#818cf8;color:var(--accent-purple-light);font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:1.25rem;font-weight:700;margin:0}.content-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:32px}.content-card{background:#fff;background:var(--bg-secondary);border:1px solid #00000014;border:1px solid var(--border-color);border-radius:20px;padding:24px}.card-header{justify-content:space-between;margin-bottom:20px}.card-header,.card-header h2{align-items:center;display:flex}.card-header h2{color:#1a1a2e;color:var(--text-primary);font-size:1.1rem;font-weight:700;gap:10px;margin:0}.card-header h2 svg{color:#6366f1;color:var(--accent-purple)}.see-all-btn{align-items:center;background:#0000;border:none;color:#818cf8;color:var(--accent-purple-light);cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:4px;transition:all .2s ease}.see-all-btn:hover{color:#1a1a2e;color:var(--text-primary)}.test-list{display:flex;flex-direction:column;gap:12px}.test-item{align-items:center;animation:slideIn .3s ease forwards;background:#f8f9fa;background:var(--bg-tertiary);border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;opacity:0;padding:14px 16px;transition:all .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.test-item:hover{background:#6366f114;transform:translateX(4px)}.test-item-left{align-items:center;display:flex;gap:14px}.test-score-ring{align-items:center;border-radius:50%;display:flex;height:44px;justify-content:center;position:relative;width:44px}.test-score-ring span{background:#fff;background:var(--bg-secondary);border-radius:50%;color:#1a1a2e;color:var(--text-primary);font-family:JetBrains Mono,Fira Code,monospace;font-family:var(--font-mono);font-size:.75rem;font-weight:700;padding:6px}.test-info{display:flex;flex-direction:column}.test-class{color:#1a1a2e;color:var(--text-primary);font-size:.95rem;font-weight:600}.test-date{color:#94a3b8;color:var(--text-muted);font-size:.8rem}.test-item-right{align-items:center;display:flex;gap:12px}.test-questions{background:#fff;background:var(--bg-secondary);border-radius:6px;color:#64748b;color:var(--text-secondary);font-size:.8rem;padding:4px 10px}.test-arrow{color:#94a3b8;color:var(--text-muted);transition:all .2s ease}.test-item:hover .test-arrow{color:#818cf8;color:var(--accent-purple-light);transform:translate(2px,-2px)}.class-list{display:flex;flex-direction:column}.class-stats{border-top:1px solid #00000014;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;padding-top:16px}.class-stat-item{background:#f8f9fa;background:var(--bg-tertiary);border-radius:10px;display:flex;flex-direction:column;padding:10px 16px}.class-stat-item .class-name{color:#1a1a2e;color:var(--text-primary);font-size:.9rem;font-weight:600}.class-stat-item .class-tests{color:#94a3b8;color:var(--text-muted);font-size:.8rem}.no-data{color:#94a3b8;color:var(--text-muted);padding:40px 0;text-align:center}.quick-actions{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.action-card{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #00000014;border:1px solid var(--border-color);border-radius:16px;cursor:pointer;display:flex;gap:16px;padding:20px 24px;transition:all .3s ease}.action-card:hover{border-color:#6366f14d;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000000f;box-shadow:var(--card-shadow-hover);transform:translateY(-4px)}.action-icon{align-items:center;border-radius:14px;color:#fff;display:flex;flex-shrink:0;height:52px;justify-content:center;width:52px}.action-icon.purple{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:linear-gradient(135deg,var(--accent-purple),#8b5cf6)}.action-icon.green{background:linear-gradient(135deg,#10b981,#059669);background:linear-gradient(135deg,var(--accent-green),#059669)}.action-icon.amber{background:linear-gradient(135deg,#f59e0b,#d97706);background:linear-gradient(135deg,var(--accent-amber),#d97706)}.action-text{flex:1 1}.action-text h3{color:#1a1a2e;color:var(--text-primary);font-size:1rem;font-weight:700;margin:0}.action-text p{color:#64748b;color:var(--text-secondary);font-size:.85rem;margin:4px 0 0}.action-arrow{color:#94a3b8;color:var(--text-muted);transition:all .2s ease}.action-card:hover .action-arrow{color:#818cf8;color:var(--accent-purple-light);transform:translateX(4px)}.empty-state,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:40px;text-align:center}.loader{animation:spin 1s linear infinite;border:4px solid #00000014;border-top-color:#6366f1;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-purple);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.loading-state p{color:#64748b;color:var(--text-secondary);margin-top:16px}.empty-state .empty-icon{align-items:center;animation:pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#6366f133,#8b5cf633);border-radius:50%;color:#818cf8;color:var(--accent-purple-light);display:flex;height:120px;justify-content:center;margin-bottom:24px;width:120px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.empty-state h2{color:#1a1a2e;color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0 0 12px}.empty-state p{color:#64748b;color:var(--text-secondary);line-height:1.6;margin:0 0 24px;max-width:400px}@media (max-width:1200px){.stats-grid{grid-template-columns:1fr 1fr}.score-card{grid-column:span 2}}@media (max-width:900px){.content-grid,.quick-actions{grid-template-columns:1fr}}@media (max-width:600px){.dashboard-wrapper{padding:16px}.header-text h1{font-size:1.75rem}.stats-grid{grid-template-columns:1fr}.score-card{grid-column:span 1}.section-header{align-items:flex-start;flex-direction:column;gap:12px}.time-toggle{justify-content:space-between;width:100%}.toggle-btn{flex:1 1;text-align:center}}
/*# sourceMappingURL=main.4036a95a.css.map*/