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}h1{border-bottom:2px solid #ecf0f1;color:#ecf0f1;font-size:1.8em;letter-spacing:.5px;margin-bottom:20px;padding-bottom:5px;text-transform:uppercase}@media (max-width:768px){.container{flex-direction:column}.content,.sidebar{width:100%}}.container{padding:20px}.content{width:100%}@media (max-width:768px){.container{padding:10px}.content{width:100%}}:root{--primary:#34495e;--text:#535c68;--bg:#f9fbff}.home-wrapper{align-items:center;background-color:#f9fbff;background-color:var(--bg);color:#535c68;color:var(--text);display:flex;flex-direction:column;justify-content:flex-start;min-height:100vh;padding:80px 20px}.home-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px #00000008;margin-bottom:40px;max-width:750px;padding:50px;text-align:center;width:100%}.image-cropper{background:#eee;border-radius:50%;height:250px;margin:0 auto 20px;overflow:hidden;width:250px}.profile-pic{height:100%;object-fit:cover;width:100%}.tagline{color:#5dade2;color:var(--accent);font-size:.9rem}.firstname,.tagline{font-weight:600;letter-spacing:1.5px;margin-bottom:30px;text-transform:uppercase}.firstname{color:#3286b6;font-size:1.9rem}.bio-content{font-size:1.05rem;line-height:1.7;margin:0 auto;max-width:600px;text-align:left}.bio-content p{margin-bottom:20px}code{background:#f0f2f5;border-radius:4px;font-size:.95rem;padding:2px 5px}.btn-primary{background:#34495e;background:var(--primary);border-radius:8px;color:#fff;display:inline-block;font-weight:500;margin-top:20px;padding:14px 35px;text-decoration:none;transition:opacity .2s}.btn-primary:hover{opacity:.9}.contact-section{border-top:1px solid #e1e8ed;max-width:750px;padding:40px;text-align:center;width:100%}.contact-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-top:20px}.contact-item strong{color:#34495e;color:var(--primary);margin-bottom:5px}.social-links a{color:#5dade2;color:var(--accent);font-weight:500}.math-container{-webkit-overflow-scrolling:touch;align-items:center;box-sizing:border-box;display:flex;justify-content:center;margin:1.5rem 0;max-width:100%;overflow-x:auto;overflow-y:hidden;padding:.5rem;width:100%}.math-container::-webkit-scrollbar{height:4px}.math-container::-webkit-scrollbar-track{background:#0000}.math-container::-webkit-scrollbar-thumb{background-color:#c1c1c1;border-radius:4px}@media (max-width:600px){.contact-grid{grid-template-columns:1fr}.home-card{padding:30px}}.bio-link{border-bottom:1px solid #0000;color:#5dade2;color:var(--accent);font-weight:600;padding:0 2px;text-decoration:none;transition:all .3s ease}.bio-link:hover{background-color:#5dade21a;border-bottom:1px solid #5dade2;border-bottom:1px solid var(--accent);border-radius:4px}.social-links a{color:#34495e;color:var(--primary);font-weight:600;margin:0 10px;text-decoration:none;transition:color .2s}.social-links a:hover{color:#5dade2;color:var(--accent)}.contact-item strong{color:#95a5a6;display:block;font-size:.9rem;letter-spacing:1px;margin-bottom:10px;text-transform:uppercase}.content{background-color:#fff;border-radius:10px;box-shadow:0 4px 12px #0000001a;color:#2c3e50;line-height:1.6;margin:auto;max-width:1100px;padding:30px}h2{font-size:1.8em}h2,h3{color:#34495e;letter-spacing:.5px;margin-bottom:20px;text-transform:uppercase}h3{font-size:1.2em;padding-bottom:5px}p{color:#7f8c8d;font-size:1.1em;margin:15px 0}ul{list-style-type:disc;margin-bottom:20px;padding-left:20px}ul li{color:#34495e;font-size:1.1em;margin-bottom:10px}.languages-list,.skills-list{gap:20px}.languages-list ul,.skills-list ul{width:48%}.languages-list ul li,.skills-list ul li{background-color:#fff;border:1px solid #dfe6e9;border-radius:8px;color:#2c3e50;display:inline-block;font-size:1em;margin-bottom:8px;margin-left:.5px;margin-right:.5px;padding:8px 12px;transition:transform .2s,box-shadow .2s}.languages-list ul li:hover,.skills-list ul li:hover{box-shadow:0 2px 6px #0000001a;transform:translateY(-2px)}.citizenship,a{font-weight:700}a:hover{color:#2980b9}.teaching-examples{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;list-style-type:space-counter;margin:0;padding:0}.teaching-examples h2{border-bottom:2px solid #ecf0f1;color:#2c3e50;font-size:2em;margin-bottom:20px;padding-bottom:5px}.teaching-examples li{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;cursor:pointer;margin-bottom:20px;overflow:hidden;transition:transform .3s ease-in-out,box-shadow .3s ease-in-out;width:230px}.teaching-examples li:hover{box-shadow:0 8px 20px #0003;transform:translateY(-5px)}.teaching-examples li img{height:100px;object-fit:cover;transition:transform .3s ease-in-out;width:100%}.teaching-examples li:hover img{transform:scale(1.05)}.teaching-examples li a{color:#2c3e50;display:block;font-size:.7em;font-weight:700;padding:10px 15px;text-align:center;text-decoration:none;transition:color .3s ease-in-out}.teaching-examples li a:hover{color:#3498db}body{background-color:#f4f4f9}.container{background-color:#fff;box-shadow:0 4px 8px #0000001a;display:flex;margin:40px auto;max-width:1300px;overflow:hidden}.sidebar{background-color:#2c3e50;color:#fff;flex-shrink:0;margin-right:10px;padding:20px;width:250px}.sidebar h1{font-size:1.8em;margin-bottom:10px}.sidebar p{color:#ecf0f1;margin:10px 0}.sidebar a{color:#ecdbff;text-decoration:none}.sidebar a:hover{text-decoration:underline}.content{flex-grow:1;-webkit-hyphens:auto;hyphens:auto;padding:20px}h2{border-bottom:2px solid #ecf0f1;color:#2c3e50;font-size:1.4em;margin-bottom:10px;padding-bottom:5px}p{line-height:1.6;margin:10px 0}.languages-list,.skills-list{display:flex;flex-wrap:wrap}.languages-list ul,.skills-list ul{list-style-type:none;margin:0;padding:0;width:50%}ul li{margin-bottom:5px}a{color:#3498db;text-decoration:none}a:hover{text-decoration:underline}@media (max-width:768px){.container{flex-direction:column;margin:0;padding:0}.sidebar{margin-bottom:0}.content,.languages-list ul,.sidebar,.skills-list ul{width:100%}h2{font-size:1.2em}}@media (max-width:480px){.sidebar{padding:10px}h1{font-size:1.5em}p{font-size:14px}}.home{padding:40px;text-align:center}.home h1{color:#2c3e50;font-size:2em;margin-bottom:20px}.home p{color:#7f8c8d;font-size:1.2em;margin-bottom:30px}.home-links{display:flex;gap:15px;justify-content:center}.home-button{background-color:#3498db;border-radius:5px;color:#fff;font-size:1em;padding:10px 20px;text-decoration:none}.home-button:hover{background-color:#2980b9}:root{--header-height:70px;--bg-primary:#fff;--bg-dropdown:#f8f9fa;--text-primary:#111;--text-secondary:#555;--accent:#5dade2;--border:#e5e5e5}*{box-sizing:border-box}.site-header{background:#fff;background:var(--bg-primary);border-bottom:1px solid #e5e5e5;border-bottom:1px solid var(--border);height:70px;height:var(--header-height);position:relative;width:100%;z-index:1000}.header-inner{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 24px}.site-logo{color:#111;color:var(--text-primary);font-size:24px;font-weight:900;letter-spacing:-1px;text-decoration:none}.desktop-nav{height:100%}.desktop-list{display:flex;gap:40px;height:100%;list-style:none;margin:0;padding:0}.desktop-item{align-items:center;display:flex;height:100%}.desktop-link{color:#555;color:var(--text-secondary);font-size:15px;font-weight:500;padding:0 5px;position:relative;text-decoration:none;transition:color .2s}.desktop-link:hover{color:#5dade2;color:var(--accent)}.mega-dropdown{background:#fff;background:var(--bg-primary);border-bottom:1px solid #e5e5e5;border-bottom:1px solid var(--border);box-shadow:0 10px 30px #0000000d;left:0;opacity:0;position:absolute;top:100%;transform:translateY(10px);transition:all .2s ease-out;visibility:hidden;width:100%;z-index:999}.desktop-item:hover .mega-dropdown{opacity:1;transform:translateY(0);visibility:visible}.mega-content{display:flex;gap:60px;margin:0 auto;max-width:1400px;padding:40px 24px}.mega-column{display:flex;flex-direction:column;gap:12px;min-width:150px}.mega-header{color:#111;color:var(--text-primary);cursor:pointer;display:inline-block;font-size:14px;font-weight:700;letter-spacing:.5px;margin-bottom:8px;text-decoration:none;text-transform:uppercase;transition:color .2s}.mega-column:hover .mega-header{color:#5dade2;color:var(--accent)}.mega-sublist{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;max-height:0;opacity:0;overflow:hidden;padding:0;transform:translateY(-10px);transition:all .3s cubic-bezier(.25,.46,.45,.94)}.mega-column:hover .mega-sublist{max-height:500px;opacity:1;transform:translateY(0)}.mega-sublink{color:#555;color:var(--text-secondary);font-size:15px;text-decoration:none;transition:color .2s}.mega-sublink:hover{color:#5dade2;color:var(--accent);text-decoration:underline}.mobile-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:6px;padding:10px;z-index:1001}.toggle-line{background:#111;background:var(--text-primary);height:2px;transition:.3s;width:24px}.mobile-toggle.active .toggle-line:first-child{transform:rotate(45deg) translate(5px,6px)}.mobile-toggle.active .toggle-line:last-child{transform:rotate(-45deg) translate(5px,-6px)}.mobile-dropdown{background:#fff;background:var(--bg-primary);border-bottom:1px solid #e5e5e5;border-bottom:1px solid var(--border);box-shadow:0 10px 20px #0000000d;left:0;max-height:0;overflow:hidden;position:absolute;top:100%;transition:max-height .4s cubic-bezier(.165,.84,.44,1);width:100%}.mobile-dropdown.open{max-height:80vh;overflow-y:auto}.mobile-list{list-style:none;margin:0;padding:0}.mobile-item{border-bottom:1px solid #f0f0f0}.mobile-row{align-items:center;display:flex;justify-content:space-between;min-height:50px;padding:0 24px}.mobile-link{color:#111;color:var(--text-primary);flex:1 1;font-size:16px;font-weight:600;padding:15px 0;text-decoration:none}.mobile-expand{align-items:center;background:none;border:none;border-left:1px solid #f0f0f0;color:#555;color:var(--text-secondary);cursor:pointer;display:flex;font-size:20px;height:50px;justify-content:center;transition:transform .3s,background .2s;width:50px}.mobile-expand.expanded{background:#fafafa;color:#5dade2;color:var(--accent);transform:rotate(45deg)}.mobile-submenu{background:#f8f9fa;background:var(--bg-dropdown);display:none;padding:10px 24px 20px}.mobile-submenu.visible{display:block}.mobile-subgroup{margin-bottom:15px}.mobile-sub-header{color:#111;color:var(--text-primary);display:block;font-size:14px;font-weight:700;margin-bottom:8px;margin-top:10px;text-decoration:none}.mobile-nested-links{border-left:2px solid #e0e0e0;display:flex;flex-direction:column;gap:10px;padding-left:10px}.mobile-nested-link{color:#555;color:var(--text-secondary);font-size:14px;text-decoration:none}@media (max-width:900px){.desktop-nav{display:none}.mobile-toggle{display:flex}}body{color:#34495e;line-height:1.6}.pdf-viewer{animation:fadeIn 1s ease-in-out;background:linear-gradient(135deg,#fff,#f3f4f7);border:1px solid #ddd;border-radius:15px;box-shadow:0 8px 20px #00000026;margin:40px auto;max-width:900px;padding:50px;text-align:center}.pdf-viewer h1{color:#2c3e50;font-size:2.8em;font-weight:600;letter-spacing:1.5px;margin-bottom:20px;text-shadow:1px 2px 4px #0000001a;text-transform:uppercase}iframe{border:3px solid #d6d9e2;border-radius:12px;box-shadow:0 6px 15px #0000001a;height:500px;transition:transform .4s ease,box-shadow .4s ease;width:100%}iframe:hover{box-shadow:0 10px 30px #0003;transform:scale(1.03)}@media (max-width:768px){.pdf-viewer{padding:35px}.pdf-viewer h1{font-size:2.3em}iframe{height:400px}}@media (max-width:480px){.pdf-viewer{padding:25px}.pdf-viewer h1{font-size:1.8em}iframe{height:300px}}.pdf-grid{grid-gap:20px;box-sizing:border-box;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px;padding:20px}.pdf-item{background:linear-gradient(135deg,#fff,#f3f4f7);border-radius:10px;box-shadow:0 6px 15px #0000001a;padding:15px;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.pdf-item:hover{box-shadow:0 10px 30px #0003;transform:scale(1.02)}.pdf-item h1{color:#2c3e50;font-size:1.6em;margin-bottom:15px;text-shadow:1px 2px 4px #0000001a;word-break:break-word}.pdf-item iframe{border:2px solid #d6d9e2;border-radius:8px;box-shadow:0 4px 12px #0000001a;height:400px;width:100%}body{background:linear-gradient(180deg,#f4f4f9,#e9ebf1);box-sizing:border-box;font-family:Helvetica Neue,Arial,sans-serif;margin:0;padding:0}@media (max-width:768px){.pdf-grid{gap:15px;padding:15px}.pdf-item h1{font-size:1.4em}.pdf-item iframe{height:350px}}@media (max-width:480px){.pdf-item{padding:10px}.pdf-item h1{font-size:1.2em}.pdf-item iframe{height:300px}}.schedule-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.schedule-header{margin-bottom:30px;position:relative;text-align:center}.week-navigation-container{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr 1fr;margin:20px auto;max-width:600px}.nav-button{background-color:#4a6fa5;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 15px;transition:background-color .3s;width:17%}.nav-button:hover{background-color:#3a5a80}.prev-week{left:20px;position:absolute;top:50%;transform:translateY(-50%)}.current-week{justify-self:center}.next-week{position:absolute;right:20px;top:50%;transform:translateY(-50%)}@media (max-width:768px){.week-navigation-container{gap:10px;grid-template-columns:1fr;padding:0 20px}.nav-button{padding:10px 15px;width:100%}.current-week,.next-week,.prev-week{justify-self:stretch;position:static;transform:none}.schedule-header h2{font-size:1.5rem}.schedule-header h3{font-size:1.1rem}}.schedule-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.schedule-day{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:15px;transition:transform .2s,box-shadow .2s}.schedule-day:hover{box-shadow:0 5px 15px #0000001a;transform:translateY(-5px)}.schedule-day h4{border-bottom:2px solid #eee;color:#2c3e50;margin-top:0;padding-bottom:10px}.schedule-day.has-classes{border-top:4px solid #4a6fa5}.schedule-day.no-classes{border-top:4px solid #95a5a6;opacity:.8}.schedule-day ul{list-style:none;margin:10px 0 0;padding:0}.schedule-day li{background-color:#f8f9fa;border-radius:4px;margin-bottom:10px;padding:8px}.class-name{display:block;font-weight:700}.class-time{color:#7f8c8d;font-size:.9em}.day-modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.day-modal-content{background-color:#fff;border-radius:8px;max-height:80vh;max-width:600px;overflow-y:auto;padding:25px;position:relative;width:90%}.close-btn{background:none;border:none;color:#7f8c8d;cursor:pointer;font-size:1.2em;position:absolute;right:15px;top:15px}.class-list{list-style:none;padding:0}.class-item{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:20px}.class-header{display:flex;justify-content:space-between;margin-bottom:5px}.class-time{color:#4a6fa5;font-weight:700}.class-location{background-color:#e3f2fd;border-radius:12px;font-size:.8em;padding:2px 8px}.class-instructor{color:#7f8c8d;font-size:.9em;margin:5px 0}.class-description{color:#555;font-size:.9em}.loading-container{color:#7f8c8d;font-size:1.2em;padding:40px;text-align:center}.schedule-controls{align-items:center;display:flex;gap:15px;justify-content:center;margin:20px 0}.month-grid{grid-gap:10px;background-color:#fff;border-radius:8px;display:grid;gap:10px;grid-template-columns:repeat(7,1fr);padding:12px;-webkit-user-select:none;user-select:none}.month-day-header{border-bottom:1px solid #d0d7e0;color:#4a6fa5;font-size:.9rem;font-weight:600;padding-bottom:8px;text-align:center}.month-cell{background-color:#f9fbfd;border:1px solid #d6dce5;border-radius:8px;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;height:130px;overflow:hidden;padding:12px;position:relative;transition:background-color .2s ease,border-color .2s ease;width:130px}.month-cell:focus,.month-cell:hover{background-color:#e8f0fe;border-color:#4a6fa5;outline:none}.month-cell.empty{background:#0000;border:none;cursor:default;pointer-events:none}.day-number{color:#33475b;font-size:1.2rem;font-weight:700;position:absolute;right:12px;top:10px}.mini-class-list{flex-grow:1;list-style:none;margin-top:28px;overflow:hidden;padding-left:0}.mini-class-item{background-color:#dde6f7;border-radius:5px;color:#2c3e50;font-size:.85rem;margin-bottom:5px;overflow:hidden;padding:4px 6px;text-overflow:ellipsis;white-space:nowrap}.mini-class-time{color:#556a8a;font-weight:600;margin-left:6px}.more-classes{color:#4a6fa5;font-size:.75rem;font-style:italic;margin-top:auto;text-align:center}@media (max-width:900px){.month-grid{gap:8px;grid-template-columns:repeat(4,1fr)}.month-cell{height:110px;padding:10px;width:100%}.day-number{font-size:1rem;right:10px;top:8px}.mini-class-item{font-size:.8rem;padding:3px 5px}}@media (max-width:480px){.month-grid{gap:6px;grid-template-columns:repeat(2,1fr);padding:8px}.month-cell{height:90px;padding:8px;width:100%}.day-number{font-size:.9rem;right:8px;top:6px}.mini-class-list{margin-top:20px}.mini-class-item{font-size:.75rem;margin-bottom:3px;padding:2px 4px}.more-classes{font-size:.7rem;margin-top:6px}}:root{--accent-color:#9e0000;--bg-card:rgba(15,28,40,.805);--bg-hover:#ffffff14;--bg-active:#00f2ea1a;--text-main:#262222e2;--text-muted:#94a3b8}.player-wrapper{grid-gap:30px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:rgba(15,28,40,.805);background:var(--bg-card);border:1px solid #ffffff14;border-radius:24px;box-shadow:0 25px 60px #00000080;display:grid;gap:30px;grid-template-columns:1fr 1fr;padding:35px}.player-main{border-right:1px solid #ffffff0d;flex-direction:column;padding-right:25px;text-align:center}.album-art,.player-main{align-items:center;display:flex;justify-content:center}.album-art{background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #ffffff0d;border-radius:18px;box-shadow:0 15px 35px #0006;height:250px;margin-bottom:25px;overflow:hidden;position:relative;width:100%}.cover-image{object-fit:cover;z-index:0}.art-overlay,.cover-image{height:100%;left:0;position:absolute;top:0;width:100%}.art-overlay{background:linear-gradient(0deg,#000c,#0000);z-index:1}.default-icon{color:#ffffff0d;font-size:3.5rem}.track-info h3{color:#262222e2;color:var(--text-main);font-size:1.6rem;font-weight:900;letter-spacing:.5px;margin:0}.artist-label{color:#9e0000;color:var(--accent-color);display:block;font-size:.85rem;font-weight:600;letter-spacing:2px;margin-top:8px;text-shadow:0 0 10px #00f2ea4d;text-transform:uppercase}.visualizer-container{align-items:flex-end;bottom:0;display:flex;gap:4px;height:20%;justify-content:center;left:0;opacity:50%;padding-bottom:0;pointer-events:none;position:absolute;width:100%;z-index:2}.bar{background:#9e0000;background:var(--accent-color);border-radius:4px 4px 0 0;box-shadow:0 0 15px #9e0000;box-shadow:0 0 15px var(--accent-color);height:100%;transform:scaleY(.1);transform-origin:bottom;transition:transform .05s linear;width:4px;will-change:transform}.progress-area{margin:30px 0;width:100%}.time-stamps{color:#94a3b8;color:var(--text-muted);display:flex;font-family:monospace;font-size:.75rem;justify-content:space-between;margin-bottom:10px}.seek-slider{background:#ffffff1a;background-image:linear-gradient(#9e0000,#9e0000);background-image:linear-gradient(var(--accent-color),var(--accent-color));background-repeat:no-repeat;border-radius:4px;width:100%}.seek-slider::-webkit-slider-thumb{border:2px solid #9e0000;border:2px solid var(--accent-color);box-shadow:0 0 15px #9e0000;box-shadow:0 0 15px var(--accent-color);-webkit-transition:transform .2s;transition:transform .2s}.seek-slider::-webkit-slider-thumb:hover{background:#9e0000;background:var(--accent-color);transform:scale(1.3)}.controls-row{gap:30px}.controls-row,.ctrl-btn{align-items:center;display:flex}.ctrl-btn{background:none;border:none;color:#fff;cursor:pointer;justify-content:center;transition:all .2s}.ctrl-btn.secondary{color:#94a3b8;color:var(--text-muted);font-size:1.4rem}.ctrl-btn.secondary:hover{color:#262222e2;color:var(--text-main);transform:scale(1.1)}.ctrl-btn.primary{background:#9e0000;background:var(--accent-color);border-radius:50%;box-shadow:0 0 20px #00f2ea66;color:#0f172a;font-size:1.2rem;height:65px;width:65px}.ctrl-btn.primary:hover{background:#fff;box-shadow:0 0 30px #00f2ea99;transform:scale(1.05)}.playlist-side{display:flex;flex-direction:column;max-height:450px}.playlist-side h4{border-bottom:1px solid #ffffff0d;color:#94a3b8;color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:1.5px;margin:0 0 20px;padding-bottom:10px;text-transform:uppercase}.song-list{flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0;scrollbar-color:#ffffff1a #0000;scrollbar-width:thin}.song-list::-webkit-scrollbar{width:4px}.song-list::-webkit-scrollbar-thumb{background-color:#ffffff1a;border-radius:2px}.song-item{align-items:center;border-bottom:1px solid #ffffff05;border-radius:8px;cursor:pointer;display:flex;margin-bottom:4px;padding:14px 12px;transition:all .2s}.song-item:hover{background:#ffffff14;background:var(--bg-hover);padding-left:16px}.song-item.active{background:#00f2ea1a;background:var(--bg-active);border-left:3px solid #9e0000;border-left:3px solid var(--accent-color)}.song-index{color:#94a3b8;color:var(--text-muted);font-family:monospace;font-size:.85rem;text-align:center;width:35px}.song-item.active .song-index{color:#9e0000;color:var(--accent-color)}.song-details{flex-grow:1}.song-name{color:#262222e2;color:var(--text-main);display:block;font-size:1rem;font-weight:600}.song-item.active .song-name{color:#9e0000;color:var(--accent-color);font-weight:700}.mini-equalizer{align-items:flex-end;display:flex;gap:3px;height:14px;margin-right:10px}.mini-equalizer span{animation:mini-bounce .8s ease-in-out infinite;background:#9e0000;background:var(--accent-color);border-radius:2px;width:3px}.mini-equalizer span:first-child{animation-delay:0s;height:60%}.mini-equalizer span:nth-child(2){animation-delay:.2s;height:100%}.mini-equalizer span:nth-child(3){animation-delay:.4s;height:40%}@keyframes mini-bounce{0%,to{height:20%}50%{height:100%}}@media (max-width:900px){.player-wrapper{gap:0;grid-template-columns:1fr;padding:25px}.player-main{border-bottom:1px solid #ffffff0d;border-right:none;margin-bottom:30px;padding-bottom:30px;padding-right:0}.playlist-side{max-height:350px}}.gallery-container{box-sizing:border-box;margin:0 auto;max-width:1600px;padding:20px;width:100%}.gallery-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));width:100%}.gallery-item{aspect-ratio:1/1;background:#eee;border-radius:8px;cursor:pointer;overflow:hidden;position:relative;transform:translateZ(0)}.gallery-item img{display:block;height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.gallery-item:hover img{transform:scale(1.05)}.loader-area{align-items:center;display:flex;height:100px;justify-content:center;width:100%}.spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#333;height:30px;width:30px}.modal-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#000000f2;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:99999}.modal-backdrop,.modal-image-container{align-items:center;display:flex;justify-content:center}.modal-image-container{max-height:90vh;max-width:90vw}.modal-image-container img{box-shadow:0 0 50px #00000080;max-height:90vh;max-width:100%;object-fit:contain;-webkit-user-select:none;user-select:none}.modal-close{font-size:40px;padding:10px;right:30px;top:20px}.modal-close,.modal-nav{background:#0000;border:none;color:#fff;cursor:pointer;line-height:1;opacity:.7;position:absolute;transition:opacity .2s;z-index:100000}.modal-nav{font-size:60px;padding:20px;top:50%;transform:translateY(-50%);-webkit-user-select:none;user-select:none}.modal-close:hover,.modal-nav:hover{opacity:1}.modal-nav.prev{left:10px}.modal-nav.next{right:10px}@media (max-width:768px){.gallery-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.modal-nav{background:#0003;border-radius:5px;font-size:40px;padding:10px}.modal-close{right:10px;top:10px}}:root{--bg-dark:#121212;--bg-panel:#1e1e1e;--text-primary-music:#fff;--text-secondary:#b3b3b3}body{background-color:#121212;background-color:var(--bg-dark);color:#fff;color:var(--text-primary-music)}.music-page-container{min-height:100vh;overflow-x:hidden;padding-bottom:50px;position:relative}.music-background-blur{background:radial-gradient(circle,#bb86fc26 0,#0000 70%);border-radius:50%;height:50vw;left:-10%;pointer-events:none;position:absolute;top:-10%;width:50vw;z-index:0}.music-content-wrapper{margin:0 auto;max-width:1200px;padding:40px 20px;position:relative;z-index:1}.music-header{margin-bottom:50px;text-align:center}.music-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(90deg,#fff,#4290b4);-webkit-background-clip:text;font-size:3rem;font-weight:700;margin:0}.music-header p{color:#b3b3b3;color:var(--text-secondary);font-size:1.1rem;margin-top:10px}.studio-section{margin-top:80px}.studio-section h2{border-bottom:1px solid #ffffff1a;color:#b3b3b3;color:var(--text-secondary);font-size:1.2rem;font-weight:400;letter-spacing:2px;margin-bottom:30px;padding-bottom:10px;text-transform:uppercase}.school-home{color:#333;font-family:Segoe UI,Tahoma,sans-serif;margin:auto;max-width:1100px;padding:40px 20px}.school-home h1{font-size:32px;margin-bottom:30px;text-align:center}.card-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.class-card{background:#fff;border:1px solid #ddd;border-radius:12px;box-shadow:0 4px 10px #0000000d;overflow:hidden;transition:box-shadow .3s ease}.class-card:hover{box-shadow:0 6px 16px #00000014}.card-header{background:#f4f6f8;padding:16px 20px}.card-header h2{font-size:18px}.toggle-icon{font-size:22px;font-weight:700}.card-details{animation:fadeIn .3s ease-in-out;background-color:#fcfcfc;padding:16px 20px}.card-details li,.card-details p{line-height:1.5;margin:6px 0}.card-details ul{margin-top:8px;padding-left:20px}.card-details a{color:#06c}.filter-bar{gap:15px;margin-bottom:25px}.filter-bar,.filter-bar label{align-items:center;position:relative}.filter-bar label{cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:6px;-webkit-user-select:none;user-select:none}.filter-bar input[type=text]{border:1.5px solid #ccc;border-radius:6px;font-size:15px;padding:8px 12px;position:relative;transition:border-color .2s ease;width:220px}.filter-bar input[type=text]:focus{border-color:#07c;outline:none;position:relative}.add-note-button{background-color:#4caf50;margin-right:auto;padding:8px 14px}.add-note-button,.latex-delete-button{border:none;border-radius:5px;color:#fff;cursor:pointer;position:relative}.latex-delete-button{background-color:#f44336;margin-left:auto;padding:6px 12px}.latex-create-button{background-color:#1976d2;border:none;border-radius:8px;color:#fff;cursor:pointer;display:block;font-size:1rem;font-weight:600;margin:0 auto 30px;padding:10px 24px;position:inherit;transform:translateY(10%);transition:background-color .25s ease}.latex-create-button:hover{background-color:#145ea8}.notes-page-wrapper>div.latex-container{background:#fff;border-radius:10px;box-shadow:0 2px 6px #0000001f;margin-bottom:32px;padding:20px 24px;transition:box-shadow .2s ease}.notes-page-wrapper>div.latex-container:hover{box-shadow:0 4px 12px #0003}@media (max-width:600px){.notes-page-wrapper{padding:0 12px 30px}.notes-page-wrapper h2{font-size:1.6rem}.latex-create-button{font-size:1.1rem;padding:12px;width:100%}.notes-page-wrapper>div.latex-container{padding:16px}}.assignment-page{background-color:#fafafa;color:#1c1c1c;font-family:Segoe UI,sans-serif;margin:0 auto;max-width:900px;padding:2rem 1rem}.assignment-page h1{color:#333;font-size:2rem;margin-bottom:1.5rem;text-align:center}.new-assignment-button{background-color:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;font-size:1rem;margin:0 auto 2rem;padding:.75rem 1.5rem;position:inherit;transition:background-color .2s ease}.new-assignment-button:hover{background-color:#1e40af}.filter-bar{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-bottom:2rem}.filter-bar input{background:#fff;border:1px solid #ccc;border-radius:5px;font-size:.95rem;padding:.6rem 1rem;width:220px}.card-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.assignment-card{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 1px 3px #0000000d;padding:1rem 1.2rem;transition:box-shadow .2s ease}.assignment-card:hover{box-shadow:0 4px 12px #00000014}.card-header{cursor:pointer;justify-content:space-between}.card-header h2{flex:1 1;font-size:1.1rem;margin:0}.toggle-icon{color:#666;font-size:1.4rem;margin-left:.5rem}.card-details{color:#444;font-size:.95rem;margin-top:1rem}.card-details p{margin:.5rem 0}.card-details a{color:#2563eb;text-decoration:none}.card-details a:hover{text-decoration:underline}.modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000040;display:flex;flex-direction:column;gap:1.5rem;max-width:500px;padding:2rem;width:90%}.modal h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;text-align:center}.modal-body{gap:1rem}.modal-body,.modal-body label{display:flex;flex-direction:column}.modal-body label{color:#333;font-size:.95rem;gap:.4rem}.modal-body input{background:#fafafa;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.modal-buttons{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end}.modal-buttons button{border:none;border-radius:6px;cursor:pointer;font-size:.95rem;padding:.6rem 1.25rem;transition:background-color .2s ease}.modal-buttons .save{background-color:#22c55e;color:#fff;position:relative}.modal-buttons .save:hover{background-color:#15803d}.modal-buttons .cancel{background-color:#e5e7eb;color:#333;position:relative}.modal-buttons .cancel:hover{background-color:#cbd5e1}.delete-assignment-button{background-color:#e63946;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:1rem;padding:8px 12px;position:inherit}.delete-assignment-button:hover{background-color:#c92a35}@media (max-width:480px){.assignment-page h1{font-size:1.5rem}.modal h2{font-size:1.2rem}.modal-body input{font-size:.95rem}.modal-buttons button{font-size:.9rem;padding:.5rem 1rem}}.latex-container{align-items:stretch;display:flex;flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:40px auto;max-width:900px;padding:20px}.latex-header-bar{display:flex;justify-content:flex-end;margin-bottom:20px}.latex-edit-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;padding:10px 18px;position:relative;transition:background-color .2s ease;z-index:9999}.latex-edit-button:hover{background-color:#0056b3}.latex-textarea{background-color:#f9f9f9;border:1px solid #ccc;border-radius:6px;box-sizing:border-box;display:block;font-family:monospace;font-size:16px;margin-bottom:12px;min-height:300px;padding:12px;resize:vertical;width:100%}.button-container{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-end;margin-top:10px}.latex-cancel-button,.latex-save-button{background-color:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;flex-shrink:0;font-size:15px;padding:10px 20px;position:relative;white-space:nowrap}.latex-cancel-button{background-color:#6c757d}.latex-save-button:hover{background-color:#218838}.latex-cancel-button:hover{background-color:#5a6268}.latex-status{color:#444;font-style:italic;margin-top:10px}.latex-divider{border:none;border-top:1px solid #ddd;margin:30px 0}.latex-output-heading{border-bottom:1px solid #ddd;font-size:20px;font-weight:700;margin-bottom:20px;margin-top:0;padding-bottom:8px}.latex-output{background:#fff;border:1px solid #ddd;border-radius:8px;padding:20px}@media (max-width:600px){.latex-container{margin:20px 15px;padding:15px}.latex-edit-button{font-size:14px;padding:8px 14px}.latex-textarea{font-size:14px;min-height:200px}.button-container{gap:10px;justify-content:center}.latex-cancel-button,.latex-save-button{flex:1 1 45%;font-size:14px;padding:10px 0;white-space:normal}.latex-output-heading{font-size:18px}.latex-output{padding:15px}}.login-container{align-items:center;background:#f5f6fa;display:flex;height:100vh;justify-content:center}.login-form{background:#fff;border-radius:8px;box-shadow:0 4px 10px #0000001a;display:flex;flex-direction:column;padding:2rem;width:320px}.login-form h2{font-weight:500;margin-bottom:1.5rem;text-align:center}.login-form input{border:1px solid #ccc;border-radius:6px;font-size:1rem;margin-bottom:1rem;padding:10px}.login-form button{background-color:#2f80ed;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;padding:10px;transition:background-color .2s ease}.login-form button:hover{background-color:#1366d6}.error{color:red;margin-bottom:1rem;text-align:center}.logout-message{align-items:center;background-color:#f9f9f9;border:1px solid #ccc;border-radius:8px;display:flex;flex-direction:column;gap:2rem;justify-content:center;padding:2rem}.logout-message h2{color:#333;font-size:1.5rem;margin:0}.logout-message button{background-color:#c0392b;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:.5rem 1.5rem;position:relative}.logout-message button:hover{background-color:#e74c3c}:root{--primary:#6366f1;--primary-hover:#4f46e5;--success:#10b981;--error:#ef4444;--bg-subtle:#f8fafc;--border:#e2e8f0;--text-main:#1e293b;--text-muted:#64748b;--dark-editor:#1e1e1e}*,:after,:before{box-sizing:border-box}body,html{color:#1e293b;color:var(--text-main);font-family:Inter,sans-serif;margin:0;max-width:100%;overflow-x:hidden}.blog-editor-container,.blog-list-container{margin:clamp(24px,6vw,60px) auto;max-width:min(1100px,100%);padding-inline:clamp(16px,4vw,24px);width:100%}.list-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:clamp(24px,6vw,48px)}.viewer-cover{border-radius:12px;display:block;margin-bottom:30px;max-height:450px;object-fit:cover;width:100%}.list-header h1{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:800;letter-spacing:-.025em;margin:0}.status-message{align-items:center;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;display:flex;font-weight:600;inset:16px 16px auto 16px;margin-left:auto;max-width:520px;padding:14px 18px;position:fixed;z-index:1000}.status-message.success{background:#fff;border-left:6px solid #10b981;border-left:6px solid var(--success);color:#065f46}.status-message.error{background:#fff;border-left:6px solid #ef4444;border-left:6px solid var(--error);color:#991b1b}.status-message.loading{background:#fff;border-left:6px solid #6366f1;border-left:6px solid var(--primary);color:#3730a3}.blog-grid{grid-gap:clamp(20px,4vw,32px);display:grid;gap:clamp(20px,4vw,32px);grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))}.blog-card{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:20px;display:flex;flex-direction:column;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}.blog-card:hover{box-shadow:0 25px 50px -12px #00000014;transform:translateY(-6px)}.card-image-wrapper{aspect-ratio:16/9;overflow:hidden;width:100%}.card-img{height:100%;object-fit:cover;width:100%}.blog-card-content{display:flex;flex:1 1;flex-direction:column;gap:12px;padding:clamp(16px,4vw,24px)}.blog-card h3{font-size:clamp(1.1rem,3vw,1.4rem);line-height:1.3;margin:0}.blog-card p{color:#64748b;color:var(--text-muted);font-size:clamp(.9rem,2.5vw,1rem);line-height:1.6}.blog-card-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:auto}input[type=text]{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;font-size:1rem;padding:clamp(12px,3vw,16px);width:100%}.raw-html-area{background:#1e1e1e;background:var(--dark-editor);border:none;border-radius:16px;color:#d4d4d4;font-family:Fira Code,monospace;min-height:min(70vh,600px);padding:clamp(14px,3vw,24px);resize:vertical;width:100%}.create-new-btn,.save-btn{background:#6366f1;background:var(--primary);border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:700;padding:14px 24px;width:fit-content}.save-btn:hover{background:#4f46e5;background:var(--primary-hover)}@media (max-width:600px){.create-new-btn,.save-btn{width:100%}}.admin-controls{display:flex;flex-wrap:wrap;gap:10px}.delete-btn,.edit-btn{border-radius:8px;font-size:.85rem;padding:6px 12px}.edit-btn{border:1px solid #e2e8f0;border:1px solid var(--border);color:#64748b;color:var(--text-muted);text-decoration:none}.delete-btn{background:none;border:1px solid #fee2e2;color:#ef4444;color:var(--error)}.ql-container{border-bottom-left-radius:12px;border-bottom-right-radius:12px;font-size:1rem;min-height:40vh}.ql-toolbar{background:#f1f5f9;border-top-left-radius:12px;border-top-right-radius:12px}@media (max-width:768px){.viewer-cover{margin-bottom:20px;max-height:250px}}
/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre,.ql-editor ul{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;margin:0;padding:0}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"\2022"}.ql-editor ul[data-checked=false],.ql-editor ul[data-checked=true]{pointer-events:none}.ql-editor ul[data-checked=false]>li *,.ql-editor ul[data-checked=true]>li *{pointer-events:all}.ql-editor ul[data-checked=false]>li:before,.ql-editor ul[data-checked=true]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"\2611"}.ql-editor ul[data-checked=false]>li:before{content:"\2610"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-increment:list-0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow .ql-toolbar:after,.ql-snow.ql-toolbar:after{clear:both;content:"";display:table}.ql-snow .ql-toolbar button,.ql-snow.ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow .ql-toolbar button svg,.ql-snow.ql-toolbar button svg{float:left;height:100%}.ql-snow .ql-toolbar button:active:hover,.ql-snow.ql-toolbar button:active:hover{outline:none}.ql-snow .ql-toolbar input.ql-image[type=file],.ql-snow.ql-toolbar input.ql-image[type=file]{display:none}.ql-snow .ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow .ql-toolbar button:hover:not(.ql-active),.ql-snow.ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{margin-bottom:5px;margin-top:5px;padding:5px 10px;white-space:pre-wrap}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid #0000;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid #0000}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid #0000;box-shadow:0 2px 8px #0003}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.drive-container{background-color:#fff;color:#1f2937;display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;height:calc(100vh - 64px);overflow:hidden;position:relative;width:100%}.drive-sidebar{background-color:#f9fafb;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;flex-shrink:0;padding:20px 16px;width:260px}.drive-new-btn{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:12px;box-shadow:0 1px 2px #0000000d;color:#374151;cursor:pointer;display:flex;font-weight:600;gap:10px;justify-content:center;margin-bottom:12px;padding:12px 20px;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.drive-new-btn:hover{background-color:#f3f4f6;border-color:#9ca3af;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.drive-new-btn.secondary{background:#0000;border:2px dashed #3b82f6;box-shadow:none;color:#3b82f6}.drive-new-btn.secondary:hover{background:#eff6ff;border-color:#2563eb}.drive-nav{display:flex;flex-direction:column;flex-grow:1;gap:4px;margin-top:24px}.nav-item{border-radius:8px;color:#6b7280;cursor:pointer;font-size:.95rem;font-weight:500;padding:10px 16px;transition:all .2s}.nav-item:hover{background-color:#f3f4f6;color:#4b5563}.nav-item.active{background-color:#eff6ff;color:#2563eb;font-weight:600}.storage-info{background:#fff;border:1px solid #e5e7eb;border-radius:12px;font-size:.875rem;margin-top:auto;padding:16px}.storage-bar{background:#f3f4f6;border-radius:3px;height:6px;margin:10px 0;overflow:hidden}.storage-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;height:100%;transition:width .3s ease;width:25%}.drive-main{background-color:#fff;display:flex;flex-direction:column;flex-grow:1;overflow:hidden}.drive-toolbar{background:#fff;border-bottom:1px solid #e5e7eb;height:64px;justify-content:space-between;padding:0 24px;z-index:10}.breadcrumbs,.drive-toolbar{align-items:center;display:flex}.breadcrumbs{font-size:1rem;gap:8px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;white-space:nowrap}.breadcrumbs::-webkit-scrollbar{display:none}.bread-wrapper{align-items:center;display:flex}.bread-link{border-radius:6px;color:#6b7280;cursor:pointer;font-size:.95rem;padding:4px 8px;transition:all .2s}.bread-link:hover{background-color:#f3f4f6;color:#374151}.bread-link.current{color:#111827;font-weight:600;pointer-events:none}.separator{color:#9ca3af;font-size:.9rem;margin-right:4px}.upload-controls{align-items:center;display:flex;gap:12px}.quick-name-input{background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;outline:none;padding:8px 16px;transition:all .2s;width:200px}.quick-name-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.drive-content-area{background:#f9fafb;flex-grow:1;overflow-y:auto;padding:24px}.section-title{color:#6b7280;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin:24px 0 16px;text-transform:uppercase}.section-title:first-child{margin-top:0}.drive-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));padding-bottom:40px}.drive-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;overflow:hidden;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.drive-card:hover{border-color:#93c5fd;box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.drive-card.folder{align-items:center;background:#fff;display:flex;height:56px;justify-content:space-between;padding:0 16px}.folder-left{align-items:center;display:flex;flex:1 1;gap:12px;overflow:hidden}.card-icon{color:#4b5563;flex-shrink:0;height:24px;width:24px}.icon-folder{color:#fbbf24}.icon-file{color:#6b7280}.card-name{color:#1f2937;font-size:.95rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-del-btn{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;line-height:1;opacity:0;padding:4px 8px;transition:all .2s;width:32px}.drive-card.folder:hover .folder-del-btn{opacity:1}.folder-del-btn:hover{background-color:#fef2f2;color:#dc2626}.drive-card.file{aspect-ratio:1/1.1;display:flex;flex-direction:column}.card-preview{align-items:center;background:#f8fafc;border-bottom:1px solid #f1f5f9;display:flex;flex-grow:1;justify-content:center;overflow:hidden;position:relative}.card-preview img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.drive-card:hover .card-preview img{transform:scale(1.05)}.generic-icon{color:#9ca3af;height:48px;opacity:.7;width:48px}.card-details{background:#fff;display:flex;flex-direction:column;gap:8px;padding:12px}.card-header{align-items:center;display:flex;height:24px}.filename{color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filename,.rename-input{font-size:.875rem;width:100%}.rename-input{background:#fff;border:2px solid #3b82f6;border-radius:4px;outline:none;padding:4px 8px}.card-actions{align-items:center;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;padding-top:8px}.card-actions a,.card-actions button{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;min-height:32px;min-width:32px;padding:6px;transition:all .2s}.card-actions a:hover,.card-actions button:hover{background:#f3f4f6;color:#374151}.card-actions .del-btn{overflow:hidden;position:relative}.card-actions .del-btn:hover{background:#fee2e2;color:#dc2626}.card-actions .del-btn:active{transform:scale(.95)}.icon-download,.icon-trash{height:16px;width:16px}.back-btn-card{background:#eff6ff!important;border-color:#bfdbfe!important;margin-bottom:20px;padding:12px 20px;width:fit-content}.back-btn-card .card-icon{color:#3b82f6}.drive-drag-overlay{align-items:center;animation:pulse 2s infinite;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#3b82f60d;border:3px dashed #3b82f6;border-radius:16px;display:flex;inset:0;justify-content:center;margin:16px;pointer-events:none;position:absolute;z-index:100}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.drag-content{align-items:center;background:#fff;border:2px solid #dbeafe;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;color:#1f2937;display:flex;font-size:1.1rem;font-weight:600;gap:12px;padding:24px 48px}.empty-msg{background:#fff;border:2px dashed #e5e7eb;border-radius:12px;color:#9ca3af;font-size:.95rem;font-style:italic;grid-column:1/-1;padding:48px 24px;text-align:center}.upload-toast{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:#fff;border:1px solid #e5e7eb;border-radius:12px;bottom:24px;box-shadow:0 10px 25px -5px #0000001a,0 0 1px #0000001a;padding:16px;position:fixed;right:24px;width:320px;z-index:2000}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast-header{color:#374151;display:flex;font-size:.875rem;font-weight:600;justify-content:space-between;margin-bottom:10px}.progress-track{background:#f3f4f6;border-radius:3px;height:6px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#10b981,#34d399);border-radius:3px;height:100%;transition:width .3s ease}.mobile-fab-container{display:none}@media (max-width:768px){.drive-container{flex-direction:column;height:calc(100vh - 56px)}.drive-sidebar{display:none}.drive-toolbar{flex-wrap:wrap;gap:12px;height:auto;min-height:60px;padding:12px 16px}.breadcrumbs{font-size:.95rem;order:2;padding-bottom:8px;width:100%}.upload-controls{order:1;width:100%}.quick-name-input{width:100%}.drive-content-area{padding:16px}.drive-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.folder-del-btn{font-size:1.8rem;height:44px;margin-right:-8px;opacity:1!important;padding:8px;width:44px}.card-actions{opacity:1!important;padding:6px 0 0}.card-actions a,.card-actions button{min-height:40px;min-width:40px;padding:8px}.icon-download,.icon-trash{height:18px;width:18px}.mobile-fab-container{bottom:24px;display:flex;flex-direction:column;gap:16px;position:fixed;right:24px;z-index:1000}.fab-btn{align-items:center;background:#3b82f6;border:none;border-radius:50%;box-shadow:0 10px 15px -3px #3b82f666;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:56px;justify-content:center;transition:all .2s;width:56px}.fab-btn:active{transform:scale(.95)}.fab-btn.secondary{align-self:center;background:#fff;border:2px solid #e5e7eb;color:#3b82f6;font-size:1.2rem;height:48px;width:48px}.upload-toast{bottom:100px;left:16px;right:16px;width:auto}}@media (max-width:480px){.drive-grid{gap:12px;grid-template-columns:1fr}.drive-card.file{aspect-ratio:auto;flex-direction:row;height:80px;padding:12px}.card-preview{border:none;border-radius:8px;flex-grow:0;flex-shrink:0;height:56px;margin-right:12px;width:56px}.card-details{display:flex;flex-direction:column;flex-grow:1;justify-content:center;min-width:0;padding:0}.card-actions{border:none;gap:8px;justify-content:flex-start;padding-top:4px}.generic-icon{height:32px;width:32px}}.viewer-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:3000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.viewer-modal{background:#324a83;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;height:85vh;max-width:1000px;overflow:hidden;width:100%}.viewer-header{align-items:center;background:#1e293b;border-bottom:1px solid #334155;display:flex;flex-shrink:0;height:60px;justify-content:space-between;padding:0 20px}.viewer-title{color:#f8fafc;font-size:.95rem;font-weight:500;overflow:hidden;padding-right:16px;text-overflow:ellipsis;white-space:nowrap}.viewer-controls{flex-shrink:0;gap:12px}.viewer-btn,.viewer-controls{align-items:center;display:flex}.viewer-btn{background:#334155;border:none;border-radius:8px;color:#f8fafc;cursor:pointer;font-size:.875rem;gap:6px;justify-content:center;padding:8px 16px;text-decoration:none;transition:all .2s}.viewer-btn:hover{background:#475569}.viewer-btn.close{background:#dc2626;font-weight:700;padding:8px 16px}.viewer-btn.close:hover{background:#ef4444}.viewer-body{align-items:center;background:#0f172a;display:flex;flex-grow:1;justify-content:center;overflow:hidden;padding:20px}.viewer-content-img{object-fit:contain}.viewer-content-img,.viewer-content-media{border-radius:8px;max-height:100%;max-width:100%}.viewer-content-media{height:auto;width:auto}.viewer-content-pdf,.viewer-content-text{background:#fff;border:none;border-radius:8px;height:100%;width:100%}.custom-audio-player{background:#111;color:#fff;flex-direction:column;height:100%;width:100%}.audio-icon-large,.custom-audio-player{align-items:center;display:flex;justify-content:center}.audio-icon-large{background:#222;border-radius:20px;box-shadow:0 8px 16px #0000004d;font-size:5rem;height:150px;margin-bottom:40px;width:150px}.audio-controls-bar{background:#222;border-radius:50px;gap:16px;max-width:600px;padding:16px 24px;width:80%}.audio-controls-bar,.play-btn{align-items:center;display:flex}.play-btn{background:var(--primary);border:none;border-radius:50%;color:#fff;cursor:pointer;flex-shrink:0;font-size:1.2rem;height:40px;justify-content:center;width:40px}.play-btn:hover{background:#4f46e5}.time-text{color:#ccc;font-family:monospace;font-size:.85rem;text-align:center;width:45px}.seek-slider{-webkit-appearance:none;background:#444;border-radius:2px;cursor:pointer;flex-grow:1;height:4px;outline:none}.seek-slider::-webkit-slider-thumb{-webkit-appearance:none;background:#fff;border-radius:50%;cursor:pointer;height:12px;-webkit-transition:transform .1s;transition:transform .1s;width:12px}.seek-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.unsupported-wrapper{align-items:center;background:#1e293b;border-radius:12px;color:#f8fafc;display:flex;flex-direction:column;justify-content:center;max-width:400px;padding:32px;text-align:center}.unsupported-wrapper h3{font-size:1.25rem;margin-bottom:8px}.unsupported-wrapper p{color:#94a3b8;margin-bottom:20px}.loading-spinner{align-items:center;color:#fff;display:flex;font-size:1rem;gap:12px;justify-content:center;padding:32px}.loading-spinner:before{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.941fe051.css.map*/