:root{--primary-color:#5372f0;--secondary-color:#1a2744;--background-color:#121220;--card-background:#1a2744;--border-color:#2a3858;--text-color:#e0e0e0;--heading-color:#fff;--subtle-text-color:#a0a0c0;--input-background:#0f172a;--error-color:#e94560;--success-color:#1abc9c;--warning-color:#f39c12;--gradient-primary:linear-gradient(90deg,#5372f0,#6a53f0);--gradient-primary-hover:linear-gradient(90deg,#405de6,#5a40e6);--gradient-card-background:linear-gradient(145deg,#1a2744,#121c33);--gradient-card-border:linear-gradient(145deg,#2a3858,#3a4b6b);--gradient-auth-background:linear-gradient(135deg,#1f2e5a,#121c33);--gradient-auth-border:linear-gradient(135deg,#3a4b6b,#2a3858);--gradient-auth-button-hover:linear-gradient(90deg,#e973b8,#5a40e6)}.visually-hidden{clip:rect(0 0 0 0);border:0;clip-path:inset(100%);margin:-1px;padding:0}*,:after,:before{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{background-color:#121220;background-color:var(--background-color);color:#e0e0e0;color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;margin:0;overflow-x:hidden}.app-wrapper,body{display:flex;flex-direction:column;min-height:100vh}.app-wrapper{animation:fadeIn .5s ease-in-out}.container{display:flex;flex:1 1;flex-direction:column;margin:0 auto;max-width:1200px;padding:2rem;width:100%}h1,h2,h3{border-bottom:2px solid #5372f0;border-bottom:2px solid var(--primary-color);color:#fff;color:var(--heading-color);margin-bottom:1.5rem;padding-bottom:.5rem}.visually-hidden{clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;overflow:hidden;position:absolute;white-space:nowrap;width:1px}h1{font-size:2.5rem}h2{font-size:2rem}h3{border:none;font-size:1.75rem;margin-bottom:1rem;padding:0}.navbar{background-color:#1a2744;background-color:var(--secondary-color);box-shadow:0 2px 10px #0003;flex-shrink:0;height:70px;justify-content:center;padding:0 2rem;position:sticky;top:0;z-index:1000}.navbar,.navbar-container{align-items:center;display:flex}.navbar-container{flex-wrap:nowrap;justify-content:space-between;max-width:1200px;width:100%}.navbar-brand{color:#fff;color:var(--heading-color);flex-shrink:0;font-size:1.6rem;font-weight:700;text-decoration:none;transition:transform .2s ease}.navbar-brand:hover{transform:scale(1.05)}.nav-menu{align-items:center;flex-grow:1;flex-wrap:nowrap;justify-content:flex-end}.nav-menu,.navbar-links{display:flex;gap:1.5rem;min-width:0}.nav-link,.navbar-links{flex-shrink:1}.nav-link{color:#e0e0e0;color:var(--text-color);font-size:1rem;min-width:30px;overflow:hidden;text-decoration:none;text-overflow:ellipsis;transition:color .2s ease-in-out;white-space:nowrap}.nav-link:hover{color:#5372f0;color:var(--primary-color)}.search-form-nav{align-items:center;display:flex;flex-shrink:1;height:40px;min-width:180px;width:300px}.search-input{background-color:#0f172a;background-color:var(--input-background);border:1px solid #3a3a5c;border-radius:20px 0 0 20px;box-shadow:inset 0 1px 3px #0003;color:#fff;color:var(--heading-color);flex-grow:1;font-size:1rem;height:100%;outline:none;padding:.5rem 1.1rem;transition:all .3s ease-in-out;vertical-align:middle}.search-input::placeholder{color:#888;opacity:.8}.search-input:focus{background-color:#0f172a;border-color:#5372f0;border-color:var(--primary-color);box-shadow:inset 0 1px 3px #0000004d,0 0 0 3px #5372f04d}.search-button{align-items:center;background-color:#5372f0;background-color:var(--primary-color);border:1px solid #5372f0;border:1px solid var(--primary-color);border-radius:0 20px 20px 0;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:100%;justify-content:center;line-height:1;padding:0 1.4rem;transition:all .2s ease-in-out}.search-button:hover{background-color:#3554b3;border-color:#3554b3;box-shadow:0 4px 12px #0000004d;transform:translateY(-1px)}.search-button:active{background-color:#2c4a9a;box-shadow:inset 0 1px 3px #0000004d;transform:translateY(0)}@media screen and (max-width:1024px){.search-form-nav{width:220px}.search-input{padding:.4rem 1rem}.search-button{padding:0 1.2rem}}@media screen and (max-width:860px){.nav-menu.active .search-input{border-radius:5px;box-shadow:inset 0 1px 3px #0003;height:auto;padding:.7rem 1.2rem}.nav-menu.active .search-input:focus{box-shadow:inset 0 1px 3px #0000004d,0 0 0 2px #5372f033}.nav-menu.active .search-button{border-radius:5px;box-shadow:none;height:auto;margin-top:.8rem;padding:.7rem 1.2rem}.nav-menu.active .search-button:active,.nav-menu.active .search-button:hover{box-shadow:none;transform:none}.search-form-nav{height:auto}}@media screen and (max-width:480px){.search-input{font-size:.9rem;padding:.5rem .9rem}.search-button{font-size:.9rem;padding:.5rem 1.1rem}}.navbar-auth{gap:1rem}.nav-button,.navbar-auth{align-items:center;display:flex;flex-shrink:0}.nav-button{background-color:initial;border:1px solid #5372f0;border:1px solid var(--primary-color);border-radius:5px;color:#5372f0;color:var(--primary-color);cursor:pointer;height:40px;justify-content:center;line-height:1;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease-in-out;white-space:nowrap}.nav-button:hover{transform:translateY(-2px)}.nav-button.signup-btn,.nav-button:hover{background-color:#5372f0;background-color:var(--primary-color);color:#fff}.logout-btn{background-color:#e94560;background-color:var(--error-color);border-color:#e94560;border-color:var(--error-color);color:#fff}.logout-btn:hover{background-color:#c73048}.hamburger{background:none;border:none;color:#fff;cursor:pointer;display:none;flex-shrink:0;font-size:2rem;margin-left:1rem;z-index:1100}@media screen and (max-width:1200px){.navbar{padding:0 1.5rem}}@media screen and (max-width:1024px){.search-form-nav{width:220px}.search-input{padding:.4rem 1rem}.search-button{padding:0 1.2rem}.nav-menu,.navbar-links{gap:.8rem}.nav-link{font-size:.95rem}.navbar-auth{gap:.8rem}.nav-button{font-size:.9rem;height:35px;padding:.4rem .8rem}.navbar-avatar{height:35px;width:35px}}@media screen and (max-width:860px){.nav-menu{display:none}.hamburger{display:block;margin-left:auto}.navbar-container{justify-content:space-between}.nav-menu.active{background-color:#1a2744;background-color:var(--secondary-color);border-right:2px solid #5372f0;border-right:2px solid var(--primary-color);box-shadow:4px 0 15px #0006;display:flex;flex-direction:column;gap:.8rem;height:100vh;justify-content:flex-start;left:0;max-width:320px;overflow-y:auto;padding:1.5rem 1rem;position:fixed;top:0;transform:translateX(0);transition:all .3s ease-in-out;width:80%;z-index:1050}.nav-menu-overlay{animation:fadeIn .3s ease-in-out;background-color:#00000080;display:none;height:100%;left:0;position:fixed;top:0;width:100%;z-index:1040}.nav-menu.active+.nav-menu-overlay{display:block}.mobile-menu-header{align-items:center;border-bottom:1px solid #2a3858;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.mobile-menu-header .navbar-brand{color:#5372f0;color:var(--primary-color);font-size:1.8rem}.mobile-menu-close-btn{background:none;border:none;color:#e0e0e0;color:var(--text-color);cursor:pointer;font-size:2.2rem;transition:color .2s ease,transform .2s ease}.mobile-menu-close-btn:hover{color:#e94560;color:var(--error-color);transform:rotate(90deg)}.mobile-user-profile{align-items:center;border-bottom:1px solid #2a3858;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem}.mobile-user-profile .navbar-avatar{border:3px solid #5372f0;border:3px solid var(--primary-color);box-shadow:0 0 15px #5372f04d;height:70px;width:70px}.mobile-user-profile span{color:#fff;color:var(--heading-color);font-size:1.1rem;font-weight:700}.nav-menu.active .search-form-nav{align-items:stretch;flex-direction:column;margin-bottom:1.5rem;order:-1;position:relative;width:100%}.nav-menu.active .search-input{background-color:#0f172a;background-color:var(--input-background);border:1px solid #3a3a5c;border-radius:25px;box-shadow:inset 0 1px 3px #0003;color:#e0e0e0;color:var(--text-color);font-size:1rem;padding:.8rem 1.2rem}.nav-menu.active .search-button{background:linear-gradient(90deg,#5372f0,#6a53f0);background:var(--gradient-primary);border-radius:25px;box-shadow:0 4px 10px #0003;font-size:1.05rem;margin-top:.8rem;padding:.8rem 1.2rem}.nav-menu.active .search-button:hover{background:linear-gradient(90deg,#405de6,#5a40e6);background:var(--gradient-primary-hover);transform:translateY(-2px)}.nav-menu.active .search-button:active{box-shadow:inset 0 1px 5px #0000004d;transform:translateY(0)}.nav-menu.active .navbar-links{border-bottom:1px solid #2a3858;border-bottom:1px solid var(--border-color);flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;text-align:left;width:100%}.nav-menu.active .nav-link{border-radius:8px;font-size:1.1rem;padding:.7rem 1rem;text-align:left;transition:background-color .2s ease,color .2s ease,transform .2s ease;width:100%}.nav-menu.active .nav-link:hover{background-color:#1a2744;background-color:var(--card-background);color:#5372f0;color:var(--primary-color);transform:translateX(5px)}.nav-menu.active .nav-link.active{background-color:#5372f01a;color:#5372f0;color:var(--primary-color);font-weight:700}.nav-menu.active .navbar-auth{flex-direction:column;gap:.8rem;margin-top:1rem;width:100%}.nav-menu.active .logout-btn,.nav-menu.active .nav-button{border-radius:25px;box-shadow:0 2px 8px #0003;font-size:1.1rem;height:auto;padding:.8rem 1.2rem;width:100%}.nav-menu.active .nav-button:hover{box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}}@media screen and (max-width:480px){.navbar{height:55px;padding:0 .8rem}.navbar-brand{font-size:1.3rem}.hamburger{font-size:1.6rem}.nav-menu.active{max-width:280px;padding:1rem .8rem;width:95%}.mobile-menu-header .navbar-brand{font-size:1.5rem}.mobile-menu-close-btn{font-size:1.8rem}.mobile-user-profile .navbar-avatar{height:60px;width:60px}.mobile-user-profile span{font-size:1rem}.nav-menu.active .nav-button,.nav-menu.active .nav-link,.nav-menu.active .search-button,.nav-menu.active .search-input{font-size:.95rem;padding:.6rem 1rem}.nav-menu.active .search-input{padding:.6rem 1rem}.nav-menu.active .search-button{margin-top:.6rem}}.notes-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,340px);justify-content:center;margin-top:2rem}.project-card{animation:fadeUp .6s ease-out;background-color:#1a2744;background-color:var(--card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{box-shadow:0 10px 30px #0006;transform:translateY(-5px)}.card-thumbnail{background-color:#0f172a;display:block;height:200px;object-fit:cover;width:100%}.card-content{display:flex;flex-direction:column;flex-grow:1;padding:1.5rem}.card-title{border:none;color:#fff;color:var(--heading-color);font-size:1.5rem;font-weight:700;margin:0 0 1rem;padding:0}.card-details{color:#a0a0c0;color:var(--subtle-text-color);flex-grow:1;font-size:.95rem;list-style:none;margin:0;padding:0}.card-details li{margin-bottom:.5rem}.card-details li strong{color:#d0d0d0}.card-actions{border-top:1px solid #2a3858;border-top:1px solid var(--border-color);display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1rem}.action-button{border:1px solid #0000;border-radius:5px;flex-grow:1;font-weight:700;padding:.6rem;text-align:center;text-decoration:none;transition:all .2s ease}.view-btn{background-color:#2c3e50;color:#fff}.view-btn:hover{background-color:#3e5670;cursor:pointer}.download-btn{background-color:#5372f0;background-color:var(--primary-color);color:#fff}.download-btn:hover{background-color:#405de6;cursor:pointer}@media (max-width:768px){.notes-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.card-content{padding:1rem}.card-title{font-size:1.3rem}.action-button,.card-details{font-size:.9rem}.action-button{flex-basis:calc(50% - 0.375rem);padding:.5rem}}@media (max-width:480px){.notes-grid{gap:1rem;grid-template-columns:1fr}.card-thumbnail{height:180px}.card-content{padding:.8rem}.card-title{font-size:1.2rem;margin-bottom:.8rem}.card-actions{flex-direction:column;gap:.5rem;padding-top:.8rem}.action-button{max-width:none;padding:.6rem;width:100%}}.auth-card,.contact-form,.content-page,.form-container,.review-form,.upload-form{animation:fadeIn .5s ease-in-out;background-color:#1a2744;background-color:var(--card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:12px;margin:2rem auto;max-width:800px;padding:2.5rem;width:100%}.auth-card{animation:slideInUp .8s ease-out forwards;background:linear-gradient(135deg,#1f2e5a,#121c33);background:var(--gradient-auth-background);border:1px solid linear-gradient(135deg,#3a4b6b,#2a3858);border:1px solid var(--gradient-auth-border);border-radius:16px;box-shadow:0 10px 40px #0009;display:flex;flex-direction:column;gap:1.2rem;max-width:450px;overflow:hidden;padding:2.5rem;position:relative}.auth-card:before{animation:rotateAndFade 10s linear infinite forwards;background:radial-gradient(circle,#5372f01a 0,#0000 70%);left:-50px;top:-50px}.auth-card:after,.auth-card:before{border-radius:50%;content:"";height:200px;position:absolute;width:200px;z-index:0}.auth-card:after{animation:rotateAndFadeReverse 12s linear infinite forwards;background:radial-gradient(circle,#1a27441a 0,#0000 70%);bottom:-50px;right:-50px}.auth-card>*{position:relative;z-index:1}.auth-card h2{align-items:center;border-bottom:2px solid #5372f0;border-bottom:2px solid var(--primary-color);color:#fff;color:var(--heading-color);display:flex;font-size:2.5rem;gap:.8rem;justify-content:center;margin-bottom:1.5rem;padding-bottom:.8rem;text-align:center}.auth-card h2 .icon{animation:bounceIn .8s ease-out;color:#fd0;filter:drop-shadow(0 2px 5px rgba(255,221,0,.3));font-size:2.8rem}@media (max-width:768px){.auth-card,.contact-form,.content-page,.form-container,.review-form,.upload-form{margin:1.5rem auto;padding:1.5rem}h2{font-size:1.8rem}.auth-card{border-radius:12px;gap:1rem;margin:1.5rem auto;padding:1.5rem}.auth-card h2{font-size:2rem}.auth-card h2 .icon{font-size:2.2rem}}@media (max-width:480px){.auth-card,.contact-form,.content-page,.form-container,.review-form,.upload-form{margin:1rem auto;padding:1rem}h2{font-size:1.6rem;margin-bottom:1.5rem}.auth-card{border-radius:10px;gap:.8rem;margin:1rem auto;padding:1rem}.auth-card:after,.auth-card:before{bottom:-30px;height:150px;left:-30px;right:-30px;top:-30px;width:150px}.auth-card h2{font-size:1.8rem;gap:.5rem}.auth-card h2 .icon{font-size:2rem}}.form-group{margin-bottom:1.5rem;position:relative}.auth-card .form-group{margin-bottom:0}.form-group label{color:#a0a0c0;color:var(--subtle-text-color);display:block;font-size:.9rem;font-weight:700;margin-bottom:.5rem;transition:color .2s ease}.auth-input,.contact-form input,.contact-form textarea,.filter-bar input,.form-container input,.form-container textarea,.review-form textarea,input[type=number],input[type=text]{background-color:#0f172a;background-color:var(--input-background);border:1px solid #3a3a5c;border-radius:5px;box-sizing:border-box;color:#fff;color:var(--heading-color);font-size:1rem;padding:.8rem 1rem;transition:all .3s ease;width:100%}.auth-input{border-radius:8px;box-shadow:inset 0 2px 5px #0003}.auth-card .auth-input:-webkit-autofill,.auth-card .auth-input:-webkit-autofill:active,.auth-card .auth-input:-webkit-autofill:focus,.auth-card .auth-input:-webkit-autofill:hover{-webkit-text-fill-color:#fff!important;-webkit-text-fill-color:var(--heading-color)!important;background-color:#0f172a!important;background-color:var(--input-background)!important;box-shadow:inset 0 0 0 1000px #0f172a!important;box-shadow:0 0 0 1000px var(--input-background) inset!important;color:#fff!important;color:var(--heading-color)!important}.auth-input[type=email],.auth-input[type=password],.auth-input[type=text]{padding-right:2.8rem}.input-icon{color:#a0a0c0;color:var(--subtle-text-color);font-size:1.2rem;pointer-events:none;position:absolute;right:1rem;top:calc(50% + .25rem);transition:color .3s ease}.form-group:has(input.auth-input:focus) .input-icon{color:#5372f0;color:var(--primary-color)}.contact-form input:focus,.contact-form textarea:focus,.filter-bar input:focus,.form-container input:focus,.form-container textarea:focus,.review-form textarea:focus{background-color:#0f172a;background-color:var(--input-background);border-color:#5372f0;border-color:var(--primary-color);box-shadow:0 0 0 3px #5372f04d;outline:none}.auth-input:focus{background-color:#0d1421;border-color:#5372f0;border-color:var(--primary-color);box-shadow:0 0 0 3px #5372f04d,inset 0 2px 8px #0000004d;outline:none}.contact-form textarea,.form-container textarea,.review-form textarea{min-height:120px;resize:vertical}.auth-btn,.contact-form button,.form-container button,.review-form button{background-color:#5372f0;background-color:var(--primary-color);border:none;border-radius:5px;color:#fff;color:var(--heading-color);cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:1rem;padding:.9rem 1rem;transition:background-color .3s ease,transform .2s ease,box-shadow .2s ease;width:100%}.auth-btn{background:linear-gradient(90deg,#5372f0,#6a53f0);background:var(--gradient-primary);border-radius:8px;box-shadow:0 4px 15px #0000004d;font-size:1.15rem;margin-bottom:0;margin-top:1.5rem;padding:1rem 0;transition:all .3s ease-in-out}.auth-btn:hover{background:linear-gradient(90deg,#e973b8,#5a40e6);background:var(--gradient-auth-button-hover);box-shadow:0 8px 25px #0006;transform:translateY(-5px)}.auth-btn:active{box-shadow:inset 0 2px 5px #0000004d;transform:translateY(0)}.contact-form button:hover,.form-container button:hover,.review-form button:hover{background-color:#3554b3;box-shadow:0 4px 12px #0003;transform:translateY(-3px)}.auth-hint{animation:fadeIn 1s ease-out .8s forwards;color:#a0a0c0;color:var(--subtle-text-color);font-size:1rem;margin-top:1.2rem;text-align:center}.auth-hint a{color:#5372f0;color:var(--primary-color);font-weight:700;text-decoration:none;transition:color .2s ease,text-shadow .2s ease}.auth-hint a:hover{color:#8c73f0;text-decoration:underline;text-shadow:0 0 5px #5372f080}.welcome-section{background-color:#16213e80;border-radius:8px;margin-left:auto;margin-right:auto;margin-top:4rem;max-width:900px;padding:2rem;text-align:center;width:100%}@media (max-width:768px){.welcome-section{margin-top:2.5rem;padding:1.5rem}}@media (max-width:480px){.welcome-section{margin-top:1.5rem;padding:1rem}}.note-viewer-container{animation:scaleIn .8s ease-out forwards;background:linear-gradient(145deg,#1a2744,#121c33);background:var(--gradient-card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #00000080;margin:2rem auto;max-width:1200px;overflow:hidden;padding:2.5rem;position:relative;width:100%}@media (max-width:768px){.note-viewer-container{box-shadow:0 6px 25px #0006;margin:1.5rem auto;padding:1.5rem}}@media (max-width:480px){.note-viewer-container{border-radius:8px;box-shadow:0 4px 15px #0000004d;margin:1rem auto;padding:1rem}}.note-viewer-container iframe{animation:iframeLoad 1s ease-out .5s forwards;background-color:#f0f0f0;border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:8px;box-shadow:inset 0 0 15px #0006;display:block;height:85vh;min-height:500px;transform:scale(.98);transition:all .5s ease-in-out;width:100%}@media (max-width:768px){.note-viewer-container iframe{border-radius:6px;height:70vh;min-height:400px}}@media (max-width:480px){.note-viewer-container iframe{border-radius:4px;box-shadow:inset 0 0 10px #0000004d;height:60vh;min-height:300px}}.note-viewer-container h2{word-wrap:break-word;animation:slideInLeft .7s ease-out;border-bottom:2px solid #5372f0;border-bottom:2px solid var(--primary-color);color:#fff;color:var(--heading-color);font-size:2.2rem;margin-bottom:1.5rem;overflow-wrap:break-word;padding-bottom:.5rem;text-align:left}.note-viewer-container:before{background:radial-gradient(circle at top left,#5372f01a 0,#0000 50%),radial-gradient(circle at bottom right,#1a27441a 0,#0000 50%);border-radius:12px;bottom:0;content:"";left:0;opacity:.8;position:absolute;right:0;top:0;z-index:-1}.footer{background-color:#0f172a;background-color:var(--input-background);color:#a0a0c0;color:var(--subtle-text-color);flex-shrink:0;margin-top:3rem;padding:3rem 2rem;width:100%}.footer-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:1200px}@media (max-width:768px){.footer{padding:2.5rem 1.5rem}.footer-container{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:600px){.footer{padding:2rem 1rem}.footer-container{grid-template-columns:1fr;text-align:center}.footer-section h4{margin-bottom:.5rem}.footer-section ul{margin-bottom:1rem}}.footer-section h4{color:#fff;color:var(--heading-color);margin-bottom:1rem}.footer-section ul{list-style:none;padding:0}.footer-section ul a{color:#a0a0c0;color:var(--subtle-text-color);text-decoration:none;transition:color .2s}.footer-section ul a:hover{color:#5372f0;color:var(--primary-color)}.footer-bottom{border-top:1px solid #1f2e5a;margin-top:2rem;padding-top:2rem;text-align:center}.contact-page>p{color:#a0a0c0;color:var(--subtle-text-color);font-size:1.1rem;margin-bottom:2rem;text-align:center}.contact-form .form-group{margin-bottom:1.5rem}.contact-form label{color:#a0a0c0;color:var(--subtle-text-color);display:block;font-weight:700;margin-bottom:.5rem}.contact-form textarea{resize:vertical}.form-status{font-size:1.1rem;font-weight:700;margin-top:1.5rem;text-align:center}.content-page section{margin-bottom:2.5rem}.content-page h2{border-bottom-color:#3a3a5c;font-size:1.8rem}.content-page li,.content-page p{color:#a0a0c0;color:var(--subtle-text-color);font-size:1.1rem;line-height:1.6}.content-page ul{list-style-type:"📚";padding-left:2rem}.content-page ul li{margin-bottom:1rem;padding-left:1rem}.profile-header{align-items:center;animation:fadeUp .5s ease-in-out;background-color:#1a2744;background-color:var(--card-background);border-radius:12px;display:flex;flex-direction:column;gap:1.5rem;margin:2rem auto;max-width:900px;padding:2rem;text-align:center;width:100%}@media screen and (min-width:768px){.profile-header{flex-direction:row;gap:2rem;text-align:left}}@media screen and (max-width:600px){.profile-header{gap:1rem;margin:1.5rem auto;padding:1.5rem}.profile-info h1{font-size:1.8rem}.profile-info p{font-size:1rem}}.avatar-container{border-radius:50%;box-shadow:0 4px 15px #0003;cursor:pointer;flex-shrink:0;height:120px;position:relative;width:120px}.profile-avatar{border:3px solid #5372f0;border:3px solid var(--primary-color);border-radius:50%;display:block;height:100%;object-fit:cover;transition:filter .3s ease;width:100%}.avatar-upload-label{align-items:center;background-color:#0009;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.avatar-container:hover .avatar-upload-label{opacity:1}.avatar-container:hover .profile-avatar{filter:brightness(.5)}.profile-info h1{border:none;font-size:2.2rem;margin:0;padding-bottom:0}.profile-info p{color:#a0a0c0;color:var(--subtle-text-color);font-size:1.1rem;margin:.5rem 0 0}.profile-tabs{border-bottom:1px solid #2a3858;border-bottom:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:800px;padding-bottom:5px;width:100%}.profile-tabs button{background-color:initial;border:none;border-bottom:3px solid #0000;color:#a0a0c0;color:var(--subtle-text-color);cursor:pointer;flex-shrink:0;font-size:1.1rem;padding:.8rem 1.5rem;transition:all .2s ease;white-space:nowrap}.profile-tabs button.active{border-bottom-color:#5372f0;border-bottom-color:var(--primary-color);color:#fff;color:var(--heading-color)}@media (max-width:600px){.profile-tabs{gap:.25rem;justify-content:center;margin-bottom:1.5rem}.profile-tabs button{font-size:1rem;padding:.6rem 1rem}}.save-btn{background-color:#3e5670;color:#fff;cursor:pointer;transition:background-color .2s ease}.save-btn:hover{background-color:#4f6d8a}.save-btn.saved{background-color:#1abc9c;background-color:var(--success-color)}.save-btn.saved:hover{background-color:#16a085}.navbar-avatar{border:2px solid #5372f0;border:2px solid var(--primary-color);border-radius:50%;cursor:pointer;flex-shrink:0;height:40px;object-fit:cover;transition:transform .2s ease;width:40px}.navbar-avatar:hover{transform:scale(1.1)}.name-display,.name-edit-form{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-start}@media (max-width:600px){.name-display,.name-edit-form{justify-content:center;text-align:center}}.edit-name-btn{background:none;border:1px solid #3e5670;border-radius:5px;color:#a0a0c0;color:var(--subtle-text-color);cursor:pointer;flex-shrink:0;padding:.3rem .8rem;transition:all .2s ease}.edit-name-btn:hover{background-color:#3e5670;color:#fff}.name-edit-input{background-color:#0f172a;background-color:var(--input-background);border:1px solid #5372f0;border:1px solid var(--primary-color);border-radius:5px;box-sizing:border-box;color:#fff;color:var(--heading-color);flex-grow:1;font-size:1.5rem;font-weight:700;max-width:100%;min-width:150px;outline:none;padding:.6rem 1rem}.name-edit-form .cancel-btn,.name-edit-form .save-btn{border:none;border-radius:5px;cursor:pointer;flex-shrink:0;font-weight:700;padding:.6rem 1rem}.name-edit-form .save-btn{background-color:#5372f0;background-color:var(--primary-color);color:#fff}.name-edit-form .cancel-btn{background-color:#2c3e50;color:#fff}@media (max-width:768px){.name-edit-input{font-size:1.3rem;padding:.5rem .8rem}.edit-name-btn,.name-edit-form .cancel-btn,.name-edit-form .save-btn{font-size:.9rem;padding:.4rem .7rem}.name-display,.name-edit-form{gap:.8rem}}@media (max-width:480px){.name-edit-input{font-size:1rem;margin-bottom:.5rem;min-width:0;min-width:auto;padding:.4rem .6rem;width:100%}.edit-name-btn{padding:.6rem .8rem;text-align:center;width:100%}.name-edit-form{align-items:stretch;flex-direction:column;gap:.5rem}.name-edit-form .cancel-btn,.name-edit-form .save-btn{padding:.6rem 1rem;width:100%}}.donate-page .donate-intro{animation:fadeUp .5s ease-out;margin:0 auto 3rem;max-width:700px;text-align:center;width:100%}@media (max-width:600px){.donate-page .donate-intro{margin-bottom:2rem;padding:0 1rem}}.support-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:4rem;padding:0}@media (max-width:480px){.support-grid{gap:1rem;grid-template-columns:1fr}}.support-item{animation:fadeUp .5s ease-out forwards;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#1a274499;border:1px solid #ffffff1a;border-radius:12px;opacity:0;padding:1.5rem;transition:all .3s ease;word-break:break-word}.support-item:first-child{animation-delay:.2s}.support-item:nth-child(2){animation-delay:.3s}.support-item:nth-child(3){animation-delay:.4s}.support-item:hover{border-color:#5372f080;transform:translateY(-5px)}.support-item h3{align-items:center;color:#5372f0;color:var(--primary-color);display:flex;font-size:1.5rem;gap:.75rem;margin-top:0}.donation-methods{align-items:stretch;flex-wrap:wrap;gap:2rem;margin-top:2rem;padding:0}.donation-card,.donation-methods{display:flex;justify-content:center}.donation-card{align-items:center;animation:fadeUp .5s ease-out .5s forwards;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#1a274499;border:1px solid #ffffff1a;border-radius:16px;flex:1 1;flex-direction:column;max-width:420px;min-width:280px;opacity:0;padding:2.5rem;text-align:center;transition:all .3s ease}@media (max-width:600px){.donation-methods{gap:1.5rem}.donation-card{max-width:350px;min-width:0;min-width:auto;padding:1.5rem;width:100%}}.donation-card:hover{border-color:#5372f080;box-shadow:0 8px 30px #0003;transform:scale(1.03)}.donation-card h3{color:#fff;color:var(--heading-color);font-size:1.8rem;margin-top:0}.qr-code-wrapper{background-color:#fff;border-radius:8px;margin:1rem auto;max-width:100%;padding:1rem;width:fit-content}.qr-code-img{display:block;height:auto;max-width:180px;width:100%}.bmac-button{background:linear-gradient(45deg,#fd0,#ffc400);border-radius:8px;box-shadow:0 4px 15px #fd03;color:#000;display:inline-block;font-size:1.1rem;font-weight:700;margin-top:2rem;max-width:100%;overflow:hidden;padding:.9rem 2.5rem;text-decoration:none;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap}.bmac-button:hover{box-shadow:0 6px 20px #ffdd004d;transform:scale(1.05) translateY(-2px)}.star-rating{color:#a0a0c0;color:var(--subtle-text-color);display:flex;flex-wrap:nowrap;font-size:1.5rem}.star-rating:not(.read-only) .star{cursor:pointer}.star.filled{color:#f39c12}.card-rating{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.card-rating .star-rating{font-size:1.1rem}.card-rating span{color:#a0a0c0;color:var(--subtle-text-color);font-size:.9rem}.reviews-section{border-top:1px solid #2a3858;border-top:1px solid var(--border-color);margin-left:auto;margin-right:auto;margin-top:3rem;max-width:800px;padding-top:2rem;width:100%}.reviews-section h2{border:none;margin-bottom:2rem;text-align:left}.reviews-list{margin-bottom:2.5rem}.no-reviews{color:#a0a0c0;color:var(--subtle-text-color);font-style:italic;padding:2rem;text-align:center}.no-reviews,.review-card{background-color:#1a2744;background-color:var(--card-background);border-radius:8px}.review-card{animation:fadeUp .5s ease-out;border:1px solid #2a3858;border:1px solid var(--border-color);margin-bottom:1.5rem;padding:1.5rem;word-break:break-word}@media (max-width:600px){.reviews-section{margin-top:2rem;padding-top:1.5rem}.review-card{padding:1rem}}.review-author{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.review-avatar{border-radius:50%;flex-shrink:0;height:45px;object-fit:cover;width:45px}.review-author-info{display:flex;flex-direction:column}.review-author-info strong{color:#fff;color:var(--heading-color);font-size:1rem}.review-author-info span{color:#a0a0c0;color:var(--subtle-text-color);font-size:.8rem}.review-content .star-rating{margin-bottom:.5rem}.review-content p{color:#e0e0e0;color:var(--text-color);line-height:1.6;margin:0}.review-form h3{border:none;font-size:1.5rem;margin-top:0;text-align:center}.review-form .form-group{margin-bottom:1.5rem}.review-form label{color:#a0a0c0;color:var(--subtle-text-color);display:block;font-weight:700;margin-bottom:.5rem}.review-form textarea{background-color:#0f172a;background-color:var(--input-background);border:1px solid #3a3a5c;border-radius:5px;box-sizing:border-box;color:#fff;color:var(--heading-color);font-size:1rem;min-height:120px;padding:.8rem 1rem;resize:vertical;transition:all .3s ease;width:100%}.review-form textarea:focus{border-color:#5372f0;border-color:var(--primary-color);box-shadow:0 0 0 3px #5372f04d;outline:none}.review-form button{font-size:1.1rem;margin-top:1.5rem;padding:.9rem 1rem;width:100%}.sort-container{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:flex-end;margin-bottom:1rem;padding-right:0;position:relative}.sort-container label{color:#a0a0c0;color:var(--subtle-text-color);flex-shrink:0;font-weight:700}.sort-container select{appearance:none;background-color:#1a2744;background-color:var(--card-background);border:1px solid #3a3a5c;border-radius:8px;color:#fff;color:var(--heading-color);cursor:pointer;flex-grow:0;flex-shrink:1;font-size:1rem;max-width:200px;min-width:150px;padding:.6rem 2.5rem .6rem 1rem;transition:border-color .2s ease}.sort-container select:hover{border-color:#5372f0;border-color:var(--primary-color)}.sort-container:after{color:#a0a0c0;color:var(--subtle-text-color);content:"▼";font-size:.8rem;pointer-events:none;position:absolute;right:1.8rem;top:50%;transform:translateY(-50%)}@media (max-width:600px){.sort-container{justify-content:center;margin-bottom:1.5rem;padding:0}.sort-container select{margin-top:.5rem;max-width:250px;width:100%}.sort-container:after{right:calc(50% - 110px)}}.filter-bar{grid-gap:1rem;background-color:#1a2744;background-color:var(--card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:12px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:1200px;padding:1.5rem;width:100%}@media (max-width:768px){.filter-bar{gap:.8rem;padding:1rem}}@media (max-width:600px){.filter-bar{grid-template-columns:1fr;padding:.8rem}}.filter-bar input{background-color:#0f172a;background-color:var(--input-background);border:1px solid #3a3a5c;border-radius:5px;color:#fff;color:var(--heading-color);font-size:1rem;padding:.7rem 1rem;width:100%}.filter-bar button{background-color:#5372f0;background-color:var(--primary-color);border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:700;padding:.7rem 1rem;transition:background-color .2s}.filter-bar button:hover{background-color:#405de6}.admin-list{animation:fadeUp .5s ease-out}.admin-list-item{align-items:center;background-color:#1a2744;background-color:var(--card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:8px;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:1rem 1.5rem;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.admin-list-item:hover{border-color:#5372f0;border-color:var(--primary-color);box-shadow:0 4px 20px #0003;transform:translateY(-3px)}.admin-list-item img{border-radius:50%;flex-shrink:0;height:45px;object-fit:cover;width:45px}.admin-note-thumbnail{border-radius:4px;flex-shrink:0;height:60px;object-fit:cover;width:80px}.admin-list-item .user-info{flex-grow:1;min-width:0}.user-info strong{color:#fff;color:var(--heading-color);display:block;overflow-wrap:break-word;white-space:normal;word-break:break-word}.user-info span{color:#a0a0c0;color:var(--subtle-text-color);font-size:.9rem}.admin-user-actions{display:flex;flex-shrink:0;gap:.75rem}.admin-user-actions .action-button,.delete-btn-admin{border:none;border-radius:5px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:transform .2s ease,filter .2s ease;white-space:nowrap}.admin-user-actions .action-button:hover,.delete-btn-admin:hover{filter:brightness(1.15);transform:scale(1.05)}.admin-user-actions .role-btn{background-color:#f39c12;background-color:var(--warning-color);color:#fff}.admin-user-actions .delete-btn,.delete-btn-admin{background-color:#e94560;background-color:var(--error-color);color:#fff}.admin-user-actions button:disabled{background-color:#3e5670;cursor:not-allowed;filter:none;transform:none}@media screen and (max-width:768px){.admin-list-item{align-items:flex-start;flex-direction:column;padding:.8rem 1rem}.admin-list-item img,.admin-note-thumbnail{margin-bottom:.5rem}.admin-user-actions{flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1rem;width:100%}.admin-user-actions .action-button,.delete-btn-admin{flex-basis:calc(50% - 0.25rem);flex-grow:1;font-size:.85rem;padding:.4rem .8rem}}@media screen and (max-width:480px){.admin-list-item{padding:.7rem .8rem}.admin-list-item img,.admin-note-thumbnail{height:35px;width:35px}.user-info strong{font-size:.95rem}.user-info span{font-size:.8rem}.admin-user-actions .action-button,.delete-btn-admin{flex-basis:100%;padding:.6rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes iframeLoad{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes bounceIn{0%,20%,40%,60%,80%,to{transition-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:scale3d(.3,.3,.3)}20%{transform:scale3d(1.1,1.1,1.1)}40%{transform:scale3d(.9,.9,.9)}60%{opacity:1;transform:scale3d(1.03,1.03,1.03)}80%{transform:scale3d(.97,.97,.97)}to{opacity:1;transform:scaleX(1)}}@keyframes rotateAndFade{0%{opacity:.1;transform:rotate(0deg) scale(.8)}50%{opacity:.2;transform:rotate(180deg) scale(1.1)}to{opacity:.1;transform:rotate(1turn) scale(.8)}}@keyframes rotateAndFadeReverse{0%{opacity:.2;transform:rotate(0deg) scale(1.1)}50%{opacity:.1;transform:rotate(-180deg) scale(.8)}to{opacity:.2;transform:rotate(-1turn) scale(1.1)}}.upload-form h2{border-bottom:none;font-size:2rem;margin-bottom:2.5rem;padding-bottom:0;text-align:center}.upload-form input[type=file]{display:none}.upload-form .file-input-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.5rem}.upload-form .custom-file-upload{background-color:initial;border:1px solid #5372f0;border:1px solid var(--primary-color);border-radius:5px;color:#5372f0;color:var(--primary-color);cursor:pointer;display:inline-block;flex-shrink:0;font-size:1rem;padding:.8rem 1.2rem;transition:background-color .2s ease,color .2s ease;white-space:nowrap}.upload-form .custom-file-upload:hover{background-color:#5372f0;background-color:var(--primary-color);color:#fff}.upload-form .file-name-display{color:#a0a0c0;color:var(--subtle-text-color);flex-grow:1;font-size:1rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-form button[type=submit]{background:linear-gradient(90deg,#5372f0,#6a53f0);background:var(--gradient-primary);border:none;border-radius:8px;box-shadow:0 4px 15px #0003;color:#fff;cursor:pointer;font-size:1.2rem;margin-top:2rem;padding:1rem;transition:all .3s ease-in-out;width:100%}.upload-form button[type=submit]:hover{background:linear-gradient(90deg,#e973b8,#5a40e6);background:var(--gradient-auth-button-hover);box-shadow:0 6px 20px #0000004d;transform:translateY(-3px)}.upload-form button[type=submit]:disabled{background:#3e5670;box-shadow:none;cursor:not-allowed;transform:none}@media (max-width:480px){.upload-form h2{font-size:1.8rem;margin-bottom:1.5rem}.upload-form .custom-file-upload{font-size:.9rem;padding:.6rem 1rem}.upload-form .file-name-display{font-size:.9rem}.upload-form button[type=submit]{font-size:1.1rem;margin-top:1.5rem;padding:.8rem}}.pagination-container{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:3rem;padding-bottom:2rem}.pagination-button{background-color:#1a2744;background-color:var(--card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:5px;color:#e0e0e0;color:var(--text-color);cursor:pointer;padding:.6rem 1.2rem;transition:all .2s ease}.pagination-button:hover:not(:disabled){background-color:#5372f0;background-color:var(--primary-color);border-color:#5372f0;border-color:var(--primary-color);color:#fff}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-info{font-weight:700}.owner-actions{border-top:1px solid #2a3858;border-top:1px solid var(--border-color);display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem}.owner-actions .action-button{border:1px solid #0000;border-radius:8px;cursor:pointer;flex-grow:1;font-size:.95rem;font-weight:700;padding:.6rem;text-align:center;transition:all .2s ease-in-out}.owner-actions .edit-btn{background-color:initial;border-color:#2a3858;border-color:var(--border-color);color:#a0a0c0;color:var(--subtle-text-color)}.owner-actions .edit-btn:hover{background-color:#5372f0;background-color:var(--primary-color);border-color:#5372f0;border-color:var(--primary-color);box-shadow:0 4px 10px #5372f033;color:#fff;color:var(--heading-color);transform:translateY(-2px)}.owner-actions .delete-btn{background-color:#e94560;background-color:var(--error-color);color:#fff;color:var(--heading-color)}.owner-actions .delete-btn:hover{background-color:#c73048;box-shadow:0 4px 10px #e9456033;transform:translateY(-2px)}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);background-color:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{animation:slideUpFade .4s ease-out;background:linear-gradient(145deg,#1a2744,#121c33);background:var(--gradient-card-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px #0009;color:#e0e0e0;color:var(--text-color);max-width:90%;min-width:450px;padding:2rem 2.5rem}@media (max-width:600px){.modal-content{min-width:90%;padding:1.5rem}}.modal-content h2{border-bottom:2px solid #5372f0;border-bottom:2px solid var(--primary-color);color:#fff;color:var(--heading-color);font-size:1.8rem;font-weight:600;margin-bottom:2rem;margin-top:0;padding-bottom:.8rem;text-align:center}.modal-form .form-group{margin-bottom:1.25rem}.modal-form label{color:#a0a0c0;color:var(--subtle-text-color);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.modal-form input{background-color:#0f172a;background-color:var(--input-background);border:1px solid #2a3858;border:1px solid var(--border-color);border-radius:8px;box-shadow:inset 0 2px 5px #0003;box-sizing:border-box;color:#fff;color:var(--heading-color);font-size:1rem;padding:.8rem 1.2rem;transition:all .3s ease;width:100%}.modal-form input:focus{background-color:#0d1421;border-color:#5372f0;border-color:var(--primary-color);box-shadow:0 0 0 3px #5372f04d,inset 0 2px 8px #0000004d;outline:none}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.modal-actions button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:700;padding:.75rem 1.5rem;transition:all .2s ease-in-out}.modal-actions button:active{transform:scale(.98)}.modal-actions .save-btn{background:linear-gradient(90deg,#5372f0,#6a53f0);background:var(--gradient-primary);box-shadow:0 4px 15px #0000004d;color:#fff}.modal-actions .save-btn:hover{background:linear-gradient(90deg,#405de6,#5a40e6);background:var(--gradient-primary-hover);box-shadow:0 6px 20px #5372f04d;transform:translateY(-2px)}.modal-actions .cancel-btn{background-color:#1a2744;background-color:var(--secondary-color);color:#e0e0e0;color:var(--text-color)}.modal-actions .cancel-btn:hover{background-color:#2a3858}.modal-actions button:disabled{background:#3e5670;box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.linktag{color:#5372f0;color:var(--primary-color);text-decoration:none;transition:color .2s ease-in-out,-webkit-text-decoration .2s ease-in-out;transition:color .2s ease-in-out,text-decoration .2s ease-in-out;transition:color .2s ease-in-out,text-decoration .2s ease-in-out,-webkit-text-decoration .2s ease-in-out}.linktag:hover{color:#8c73f0;text-decoration:underline}.linktag:visited{color:#5372f0;color:var(--primary-color)}
/*# sourceMappingURL=main.d0e3d5a4.css.map*/