.flex-row{display:flex;align-items:center}.flex-column{display:flex;flex-direction:column}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}body{margin:0;height:100dvh;color:#fff;background:linear-gradient(140deg,#1b292c,#445e62 30%,#b2c7c7 90%);background-size:160% 160%;-webkit-tap-highlight-color:transparent;overflow:hidden}#root{box-sizing:border-box;display:flex;flex-direction:row;height:100dvh;color:#fff}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}.home-navbar{justify-content:space-between;padding:8px 8px 8px 0;box-sizing:border-box;align-items:center}.custom-dropdown-container{position:relative;display:inline-block;min-width:40px;margin-right:5px;-webkit-user-select:none;user-select:none}.custom-dropdown-selected{background:transparent;color:#e0f7fa;padding:7px 10px 7px 12px;border-radius:10px;cursor:pointer;font-size:.9rem;box-shadow:0 2px 8px #00000014;border:2px solid #7e7e7e71;transition:border .2s;display:flex;align-items:center;justify-content:space-between;gap:8px}.custom-dropdown-selected.open{border:2px solid #c7c9c771}.custom-dropdown-list{position:absolute;top:110%;left:0;background-color:#354548;border:2px solid #7e7e7e71;border-radius:5px;box-shadow:0 5px 15px #0000001a;min-width:120px;z-index:100;padding:6px 0}.custom-dropdown-item{padding:10px 18px;color:#e0f7fa;cursor:pointer;font-size:1rem;transition:background .15s}.custom-dropdown-item:hover{background:#5d645d}.custom-dropdown-item.selected{background:#7d867d;color:#fff}.glow{position:absolute;top:0;left:50%;transform:translate(-50%);width:30%;height:1px;border-radius:5px;border-top:1px solid #0f3946;background:linear-gradient(180deg,#316457,#294d40);box-shadow:0 4px 15px #29756f80,0 0 10px #53f2a5b3}.fade-in{opacity:0;transition:opacity 1s ease-in-out}.fade-in.visible{opacity:1}#profile-picture{width:25px;height:25px;object-fit:cover;object-position:center;border-radius:50%}.right-navbar{align-items:center;border-radius:10px;box-sizing:border-box;border:2px solid #7e7e7e71;padding:1px}.mail{height:20px;padding:7px 15px;border-radius:8px 2px 2px 8px;margin-right:1px;margin-bottom:-2px;margin-top:-2px;cursor:pointer;transition:background-color .2s ease}.mail:hover{background-color:#696969}.student-info{border-left:2px solid #7e7e7e71;align-items:center;box-sizing:border-box;padding:5px 15px;border-radius:2px 8px 8px 2px;cursor:pointer;transition:background-color .2s ease}.student-info:hover{background-color:#696969}.profile-menu{position:absolute;background-color:#354548;border:1px solid rgb(125,125,125);border-radius:5px;box-shadow:0 5px 15px #0000001a;display:flex;flex-direction:column;z-index:10;opacity:0;transition:opacity .2s ease;pointer-events:none}.profile-menu.show{opacity:1;pointer-events:auto}.profile-menu button{background:none;outline:none;border:none;cursor:pointer;text-align:left;transition:background-color .2s ease}.profile-menu button:focus{outline:none;background-color:#682020}.profile-menu button:hover{background-color:#523838}.content{height:100dvh;min-height:0;gap:14px;padding:16px 18px 18px 16px;box-sizing:border-box;display:flex;flex-direction:column;width:100%;overflow:hidden;opacity:0;transition:.3s ease-in-out}.content.loaded{opacity:1}.content>*:last-child{flex:1;min-height:0}.main-content{display:flex;flex-direction:column;height:fit-content;max-height:100%;overflow:hidden}h1{font-size:3.2em;line-height:1.1}h2{margin:0;font-size:1.4rem}h3{margin:0}h6{font-size:.83rem;font-weight:700;margin:0}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.classes{display:flex;flex-direction:column;border:1px solid rgb(125,125,125);border-radius:10px;overflow:scroll}.course-info{display:flex;flex-wrap:wrap}.course-info p{margin:0}.course-info p:not(:last-child):after{content:"•";margin:10px}.course{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;padding:5px 10px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:background-color .23s ease}.course:hover{background-color:#677e70e9}.course:after{content:"";position:absolute;bottom:0;left:5%;width:90%;height:1px;background-color:#b3afaf4b}.course:last-child:after{content:none}.main-cards{gap:10px;margin-bottom:20px}@media (max-width: 768px){.main-cards{display:flex;width:100%;margin:20px 0}.card{flex:1;height:60px}}.card{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:8px 10px;max-width:190px;width:15%;border:1px solid rgb(125,125,125);border-radius:10px;display:flex;flex-direction:column;justify-content:center;cursor:pointer}.card p{margin:0;font-size:1rem}.name{font-size:1.2rem;margin:10px;color:#fff}.a{color:#58cf58}.a-{color:#8adb83}.b{color:#5ad0ed}.c{color:#b2d02b}.f{color:red}.na{color:#1a1111;font-size:.94rem;margin:0}.grade{font-size:1.5rem;margin:0}.grades-header{margin-bottom:10px;gap:10px;align-items:end;justify-content:space-between}.refresh{align-items:end;gap:6px;cursor:pointer}.refresh-text{margin-bottom:0}.close-icon{cursor:pointer;padding:10px;border-radius:30px;background-color:#3f5055}.gradebook-assignments{display:flex;flex-direction:column;align-items:start;gap:10px;padding:10px}.gradebook-header{display:flex;align-items:center;justify-content:space-between;gap:15px;width:100%}.header-left{display:flex;align-items:center;gap:15px}.header-right{padding:9px 20px;background-color:#54676d;border-radius:8px;border:1px solid #92929271}.header-right h3{margin:0;font-size:1.4em}.assignment{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:10px 15px;box-sizing:border-box;border-radius:10px;width:100%;display:flex;align-items:center;justify-content:space-between}.assignment-left{display:flex;flex-direction:column}.assignment-name{font-size:1.25em;margin:0}.assignment-description{margin:0;color:#bcbcbc}.assignment-notes{margin:0;color:#bcbcbc;font-style:italic}.assignment-date{font-size:.9rem;margin:0;color:#bcbcbc}.assignment-grade{font-size:1.8rem;margin:0}.sidebar{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:2px solid #7e7e7e71;border-radius:15px;margin:15px 5px;min-width:56px;display:flex;flex-direction:column;padding:15px 5px;box-sizing:border-box;align-items:center;justify-content:center}.sidebar.mobile-hidden{display:none;position:absolute;height:98%}.sidebar.mobile-visible{display:block}.logo{position:absolute;top:15px}.tabs{display:flex;flex-direction:column;gap:10px;width:100%}.tab-row{align-items:center;padding:8px;border-radius:8px;transition:background-color .3s;cursor:pointer}.tab-row.active{background-color:#8c8c8c}.tab-row:hover:not(.active){background-color:#63635f}.tab-row p{margin:0 10px;font-size:1.1rem}canvas{width:100%}.canvas-container{position:relative;top:10px;display:flex;flex-direction:column;overflow:scroll;border:1px solid rgb(125,125,125);border-radius:10px}.action{position:absolute;top:10px;width:35px;height:35px;border-radius:50%;padding:0;background-color:#3b3b3bdd;border:none;cursor:pointer}.close{right:10px}.download{right:55px}.schedule-container{position:relative;top:10px;display:flex;flex-direction:column;gap:0;border:1px solid rgba(125,125,125,.5);border-radius:12px;overflow:hidden}.schedule-header{padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.08);font-size:1.2rem;font-weight:600;letter-spacing:.03em;color:#eafafa}.schedule-list{display:flex;flex-direction:column;overflow-y:auto;max-height:calc(100dvh - 140px)}.schedule-card{border-bottom:1px solid rgba(255,255,255,.07);transition:background .15s}.schedule-card:last-child{border-bottom:none}.schedule-card-header{display:flex;align-items:center;gap:20px;padding:14px 18px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.schedule-card-header:hover{background:#ffffff0d}.schedule-card.expanded .schedule-card-header{background:#ffffff0a}.period-badge{flex-shrink:0;width:36px;height:36px;border-radius:10px;background:#2e403e4d;border:1.5px solid rgba(110,179,172,.45);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:#fff;letter-spacing:0}.card-main{flex:1;min-width:0}.course-name{font-size:.95rem;font-weight:600;color:#f0fafa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-time{font-size:.78rem;color:#c8dcdcb3;margin-top:2px}.room-pill{flex-shrink:0;font-size:.72rem;font-weight:200;color:#fff;padding:3px 10px;white-space:nowrap}.chevron{flex-shrink:0;font-size:.7rem;color:#c9d8d880;transition:transform .2s;margin-left:4px}.schedule-card.expanded .chevron{transform:rotate(180deg)}.schedule-details{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease;background:#00000026;border-top:1px solid rgba(255,255,255,.05)}.schedule-card.expanded .schedule-details{grid-template-rows:1fr}.schedule-details-inner{overflow:hidden}.schedule-details-content{padding:12px 18px 16px 68px;display:flex;flex-direction:column;gap:8px}.detail-row{display:flex;align-items:baseline;gap:8px;font-size:.82rem}.detail-label{color:#b2dfdb99;font-weight:600;min-width:72px;flex-shrink:0;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}.detail-value{color:#dff0ee}.detail-value a{color:#80cbc4;text-decoration:none;border-bottom:1px dashed rgba(128,203,196,.4);transition:color .15s,border-color .15s}.detail-value a:hover{color:#b2dfdb;border-bottom-color:#b2dfdb}.schedule-empty{padding:32px 20px;text-align:center;color:#c8dcdc80;font-size:.9rem}.attendance-container{--surface-border: rgba(184, 225, 223, .16);--surface-soft: rgba(255, 255, 255, .045);--surface-strong: rgba(255, 255, 255, .08);--text-main: #effbfa;--text-muted: rgba(214, 236, 234, .72);--text-faint: rgba(214, 236, 234, .48);position:relative;top:10px;display:flex;flex:1;flex-direction:column;gap:14px;min-height:0;height:100%;overflow:auto;scrollbar-gutter:stable;padding:16px;border:1px solid rgba(164,205,202,.22);border-radius:18px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.attendance-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.attendance-title{margin:0;color:var(--text-main);font-size:1.35rem;font-weight:700;letter-spacing:.01em}.attendance-summary-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}.summary-card{border-radius:12px;border:1px solid rgba(173,222,220,.14);background:var(--surface-soft);min-width:0;padding:7px 9px}.summary-card.warning{border-color:#ff90864d;background:#be42361a}.summary-label{color:var(--text-faint);font-size:.64rem;text-transform:uppercase;letter-spacing:.08em;line-height:1.15}.summary-value{margin-top:3px;font-size:.95rem;line-height:1.05;font-weight:700;color:var(--text-main)}.attendance-legend{display:flex;flex-wrap:wrap;gap:8px 12px;padding:2px 1px 0}.legend-item{display:flex;align-items:center;gap:7px;min-width:0;color:var(--text-muted);font-size:.77rem}.status-icon{width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.56rem;font-weight:800;border:1px solid transparent;flex-shrink:0}.status-icon.activity{background:#4f8cff33;border-color:#75a4ff80;color:#dbe8ff}.status-icon.excused{background:#2eba7333;border-color:#51d78e73;color:#d9ffe8}.status-icon.unexcused{background:#e5495040;border-color:#ff797e73;color:#ffe5e6}.status-icon.tardy,.status-icon.unexcused-tardy{background:#f1a4423b;border-color:#ffbc6773;color:#fff0dc}.status-icon.other{background:#bcc7d533;border-color:#ced8e659;color:#eff3f8}.attendance-month-controls{display:flex;align-items:center;justify-content:center;gap:8px;align-self:center;padding:6px;border:1px solid rgba(198,233,231,.12);border-radius:999px;background:#ffffff0a}.month-nav{border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#def4f3;border-radius:999px;width:34px;height:34px;padding:0;cursor:pointer;transition:background .14s ease,transform .14s ease,border-color .14s ease}.month-nav:hover{background:#ffffff24;border-color:#ffffff47}.month-nav:active{transform:scale(.95)}.month-label{min-width:142px;padding:0 8px;text-align:center;font-weight:700;color:#d8efec;font-size:.92rem}.calendar-grid-wrapper{width:min(100%,648px);align-self:center;display:flex;flex-direction:column;gap:8px;min-height:0;padding:14px;border:1px solid var(--surface-border);border-radius:18px;background:linear-gradient(180deg,#ffffff0b,#ffffff05);overflow:hidden}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.calendar-weekdays div{text-align:center;color:#cce3e1a3;font-size:.66rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.calendar-grid{align-content:start}.calendar-cell{aspect-ratio:1;min-height:0;border:1px solid rgba(171,204,203,.12);background:#ffffff08;border-radius:12px;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:default;color:#dff0ef;transition:transform .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease}.calendar-cell.today{border-color:#82d2cd99;background:#64c8c31c;box-shadow:inset 0 0 0 1px #8ce2de2e}.calendar-cell.has-event{cursor:pointer}.calendar-cell.has-event:hover{transform:translateY(-1px);border-color:#a3d8d66b;background:#ffffff14}.calendar-cell.selected{border-color:#b6eae8bf;background:#58bbb624;box-shadow:0 0 0 2px #9be6e329}.day-number{font-weight:700;font-size:.84rem;line-height:1}.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-dot.activity{background:#7fb0ff}.status-dot.excused{background:#66d895}.status-dot.unexcused{background:#ef656d}.status-dot.tardy,.status-dot.unexcused-tardy{background:#f6b35f}.status-dot.other{background:#d4dce7}.attendance-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#040c0e6a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.attendance-modal-overlay.open{animation:attendanceOverlayIn .18s ease-out forwards}.attendance-modal-overlay.closing{animation:attendanceOverlayOut .18s ease-in forwards}.attendance-modal{width:min(760px,100%);max-height:min(88dvh,900px);overflow:auto;border-radius:16px;border:1px solid rgba(193,230,228,.25);background:linear-gradient(180deg,#223d45fa,#024d43fa);padding:16px;box-shadow:0 30px 80px #0000001f}.attendance-modal.open{animation:attendanceModalIn .2s ease-out forwards}.attendance-modal.closing{animation:attendanceModalOut .18s ease-in forwards}@keyframes attendanceOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes attendanceOverlayOut{0%{opacity:1}to{opacity:0}}@keyframes attendanceModalIn{0%{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes attendanceModalOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(10px) scale(.985)}}.attendance-modal-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.attendance-modal-header h2{margin:0;font-size:1.08rem;color:azure}.close-modal{border:1px solid rgba(200,225,224,.28);border-radius:999px;background:#ffffff0f;color:#def6f5;cursor:pointer;padding:8px 12px;transition:background .14s ease,transform .14s ease}.close-modal:hover{background:#ffffff1f}.close-modal:active{transform:scale(.96)}.day-note-block{margin-bottom:12px;padding:10px 12px;border:1px solid rgba(176,217,214,.18);border-radius:12px;background:#ffffff0d}.day-note-block p{margin:4px 0;color:#d7ecea;font-size:.84rem}.period-list{display:flex;flex-direction:column;gap:10px}.period-item{border:1px solid rgba(180,215,214,.18);border-radius:12px;padding:10px;background:#ffffff0a}.period-main-row{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.period-title{display:flex;align-items:center;gap:8px;font-weight:600;color:#e8f7f6}.period-number{font-size:.72rem;border:1px solid rgba(171,216,214,.3);border-radius:999px;padding:2px 8px;color:#bcedebf2}.period-status{display:flex;align-items:center;gap:7px;color:#ddf3f1;font-size:.8rem}.period-sub-row{margin-top:8px;display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap;font-size:.8rem;color:#cee5e3d9}.period-sub-row a{color:#8fd8d4;text-decoration:none}.period-sub-row a:hover{text-decoration:underline}.attendance-empty{margin:10px 0 0;color:#d6eceabd;text-align:center}@media (max-width: 900px){.attendance-container{padding:14px}.attendance-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.calendar-grid-wrapper{width:100%}}@media (max-width: 600px){.attendance-container{top:0;gap:12px;padding:12px;border-radius:16px}.attendance-title{font-size:1.2rem}.attendance-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.summary-card{padding:6px 7px;border-radius:10px}.summary-label{font-size:.56rem;letter-spacing:.06em;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;min-height:1.3em}.summary-value{font-size:.86rem;margin-top:2px}.attendance-legend{gap:6px 10px}.legend-item{font-size:.72rem}.attendance-month-controls{width:100%}.month-label{min-width:0;flex:1}.calendar-grid-wrapper{width:100%;padding:8px}.calendar-weekdays,.calendar-grid{gap:2px}.calendar-weekdays div{font-size:.58rem}.calendar-cell{min-height:0;border-radius:8px}.day-number{font-size:.74rem}.status-dot{width:8px;height:8px}.attendance-modal-overlay{padding:10px}.attendance-modal{max-height:calc(100dvh - 20px);padding:12px}.attendance-modal-header{align-items:flex-start}.attendance-modal-header h2{font-size:.98rem}.period-main-row,.period-sub-row{flex-direction:column;align-items:flex-start}}.body{background:linear-gradient(140deg,#1b292c,#445e62 30%,#b2c7c7 90%);background-size:160% 160%;background-repeat:no-repeat;animation:rotateGradient 10s infinite ease-in-out;color:#f2f2f2;margin:0;width:100vw;height:100vh}@keyframes rotateGradient{0%{background-position:0% 0%}25%{background-position:20% 10%}50%{background-position:10% 40%}75%{background-position:0% 10%}to{background-position:0% 0%}}.navbar{position:absolute;height:50px;width:100vw;top:0;align-items:center;justify-content:space-between;padding:8px 15px;box-sizing:border-box}.branding{gap:6px}.login-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);align-items:center;width:30%;min-width:300px;max-width:500px;background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:10px;padding:20px 25px}h1{margin-bottom:7px;margin-top:25px;font-size:1.7rem;color:#e6e6e6}p{margin:0 0 18px;font-size:.8rem;color:#e6e6e6}.details{gap:5px;align-self:start;align-items:center}input{background-color:transparent;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;border:none;border-bottom:1px solid rgb(163,163,163);outline:none;padding-bottom:8px;margin-top:7px;margin-bottom:15px;width:100%;color:#f2f2f2}.input:focus{border-bottom:1px solid rgb(255,255,255)}input:-webkit-autofill{background-color:transparent!important;-webkit-text-fill-color:#f2f2f2!important;transition:background-color 5000s ease-in-out 0s}.label{align-self:flex-start;color:#a3a3a3;font-size:.8rem}button{width:100%;height:50px;display:flex;justify-content:center;align-items:center;padding:10px 20px;font-size:18px;color:#fff;background:#b5b5b580;border-radius:4px;cursor:pointer;outline:none;border:none;transition:backdrop-filter 1s ease}button.success{background-color:#5aab79}button:hover{-webkit-backdrop-filter:blur(500px);backdrop-filter:blur(500px);border:none}button:focus{outline:1px solid white}.error-message{margin-top:-7px;margin-bottom:5px;font-size:.8rem;color:#efc24f;height:20px;display:inline;text-align:center}.spinner{border:2px solid #c2c2c2;border-top:2px solid #f0f0f0;border-radius:50%;width:20px;height:20px;animation:spin 1s cubic-bezier(.1,.1,.3,0) infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.container{position:relative}.help{opacity:.5;height:15px;cursor:pointer;padding:0;display:block}.popup{position:absolute;top:-100px;left:50%;transform:translate(-50%);width:300px;padding:5px 10px;background-color:#282828;font-size:.7rem;color:#fff;display:flex;justify-content:center;align-items:center;border-radius:6px;pointer-events:none;box-shadow:0 4px 6px #0003;opacity:0;transition:opacity .2s ease}.popup.visible{opacity:1}body{margin:0;font-family:Arial,sans-serif}.menu-btn{position:absolute;top:20px;left:20px;background:#333;color:#fff;border:none;padding:10px 15px;cursor:pointer;font-size:20px}.sidebar2{position:fixed;left:0;top:0;width:250px;height:100vh;background:#222;color:#fff;padding:20px;box-shadow:3px 0 5px #0003;transition:transform .1s ease-out}.close-btn{background:red;color:#fff;border:none;padding:10px;cursor:pointer;display:block;margin-top:20px}
