.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:linear-gradient(135deg,var(--pastel-blue) 0%,var(--pastel-pink) 100%)}.landing-container{max-width:900px;width:100%;text-align:center}.landing-hero{margin-bottom:60px}.book-icon{font-size:80px;margin-bottom:24px;display:flex;justify-content:center;align-items:center;transform:rotate(-5deg);animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:rotate(-5deg) translateY(0)}50%{transform:rotate(5deg) translateY(-10px)}}.landing-title{font-family:var(--font-heading);font-size:48px;font-weight:700;color:var(--text-dark);margin-bottom:16px}.landing-subtitle{font-family:var(--font-body);font-size:20px;color:var(--text-medium);max-width:600px;margin:0 auto}.role-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;margin-bottom:40px}.role-card{border:4px solid var(--text-dark);border-radius:24px;padding:40px 32px;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-crayon);position:relative;overflow:hidden}.role-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.role-card:hover:before{opacity:1}.student-card{background:linear-gradient(135deg,var(--pastel-blue) 0%,var(--pastel-mint) 100%)}.teacher-card{background:linear-gradient(135deg,var(--pastel-pink) 0%,var(--pastel-peach) 100%)}.role-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-medium)}.role-icon{font-size:64px;margin-bottom:20px;transition:transform .3s ease;display:flex;justify-content:center;align-items:center;color:var(--text-dark);position:relative;z-index:1}.role-icon svg{color:var(--text-dark);fill:currentColor;display:block;width:48px;height:48px}.role-card:hover .role-icon{transform:scale(1.1)}.role-title{font-family:var(--font-heading);font-size:28px;font-weight:600;color:var(--text-dark);margin-bottom:12px}.role-description{font-family:var(--font-body);font-size:16px;color:var(--text-medium)}.auth-links-container{margin-top:40px;display:flex;gap:16px;justify-content:center;align-items:center;flex-wrap:nowrap}.auth-link-btn{font-family:var(--font-button);font-size:16px;font-weight:500;color:var(--text-dark);background:var(--bg-white);border:3px solid var(--text-dark);border-radius:16px;padding:12px 32px;cursor:pointer;transition:all .2s ease;text-decoration:none;min-width:120px;flex:0 0 auto}.auth-link-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.signup-btn:hover{background-color:var(--pastel-green)}.login-btn:hover{background-color:var(--pastel-yellow)}@media (max-width: 768px){.landing-page{padding:20px 16px}.book-icon{font-size:60px}.landing-title{font-size:36px}.landing-subtitle{font-size:18px}.role-selection{grid-template-columns:1fr;gap:24px}.role-card{padding:32px 24px}.role-icon{font-size:48px}.role-title{font-size:24px}.auth-links-container{flex-direction:row;gap:12px}.auth-link-btn{font-size:14px;padding:10px 20px;min-width:100px}}@media (max-width: 480px){.auth-links-container{flex-direction:column;gap:12px}.auth-link-btn{width:100%;max-width:200px}}.login-page{min-height:100vh;background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-lavender) 100%)}.login-page .login-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:40px 20px}.login-page .login-card{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:48px 40px;max-width:450px;width:100%;box-shadow:var(--shadow-medium)}.login-page .login-icon{font-size:64px;text-align:center;margin-bottom:20px;display:flex;justify-content:center;align-items:center}.login-page .login-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark);text-align:center;margin-bottom:8px}.login-page .login-subtitle{font-family:var(--font-body);font-size:16px;color:var(--text-medium);text-align:center;margin-bottom:32px}.login-page .login-form{display:flex;flex-direction:column;gap:24px}.login-page .form-group{display:flex;flex-direction:column;gap:8px}.login-page .form-group label{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--text-dark)}.login-page .form-input{font-family:var(--font-body);font-size:16px;padding:14px 18px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);transition:all .2s ease}.login-page .form-input:focus{outline:none;border-color:var(--pastel-blue);background:var(--pastel-blue);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.login-page .password-input-wrapper{position:relative;display:flex;align-items:center}.login-page .password-input-wrapper .form-input{padding-right:50px;width:100%}.login-page .password-toggle-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:20px;padding:4px 8px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;z-index:1}.login-page .password-toggle-btn:hover{transform:scale(1.1)}.login-page .password-toggle-btn:active{transform:scale(.95)}.login-page .login-btn{width:100%;background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-mint) 100%);color:var(--text-dark);margin-top:8px;font-size:18px;font-weight:600}.login-page .login-btn:hover{background:linear-gradient(135deg,var(--pastel-mint) 0%,var(--pastel-green) 100%)}.login-page .login-btn:disabled{opacity:.6;cursor:not-allowed}.login-page .error-message{background:var(--pastel-coral);border:2px solid #FF6B6B;border-radius:12px;padding:12px;color:var(--text-dark);font-family:var(--font-body);font-size:14px;text-align:center}.login-page .forgot-password-link{text-align:center;margin-top:12px;margin-bottom:8px}.login-page .forgot-password-link a{font-family:var(--font-body);font-size:14px;color:var(--text-medium);text-decoration:none;transition:color .2s ease}.login-page .forgot-password-link a:hover{color:var(--text-dark);text-decoration:underline}.login-page .register-link{text-align:center;margin-top:16px}.login-page .register-link p{font-family:var(--font-body);font-size:16px;color:var(--text-medium);margin:0}.login-page .register-link a{color:var(--text-dark);font-weight:600;text-decoration:none;border-bottom:2px solid var(--text-dark);transition:all .2s ease}.login-page .register-link a:hover{color:var(--pastel-purple);border-bottom-color:var(--pastel-purple)}@media (max-width: 768px){.login-page .login-card{padding:32px 24px}.login-page .login-icon{font-size:48px}.login-page .login-title{font-size:28px}}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;border:3px solid var(--text-dark);border-radius:16px;box-shadow:var(--shadow-crayon);min-width:300px;max-width:500px;position:relative;animation:slideIn .3s ease-out;font-family:var(--font-body);z-index:10000}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-dark)}.toast-message{flex:1;color:var(--text-dark);font-size:16px;font-weight:500;line-height:1.4}.toast-close{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--text-dark);transition:transform .2s ease;flex-shrink:0;border-radius:4px}.toast-close:hover{transform:scale(1.1);background:#0000000d}.toast-close:active{transform:scale(.95)}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast-container>*{pointer-events:auto}@media (max-width: 768px){.toast{min-width:280px;max-width:calc(100vw - 40px);padding:14px 18px}.toast-message{font-size:14px}.toast-container{top:10px;right:10px;left:10px}.toast-container{align-items:stretch}.toast{width:100%;max-width:100%}}.forgot-password-page{min-height:100vh;background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-lavender) 100%)}.forgot-password-page .forgot-password-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:40px 20px}.forgot-password-page .forgot-password-card{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:48px 40px;max-width:450px;width:100%;box-shadow:var(--shadow-medium)}.forgot-password-page .forgot-password-icon{font-size:64px;text-align:center;margin-bottom:20px;display:flex;justify-content:center;align-items:center}.forgot-password-page .forgot-password-icon svg{color:var(--text-dark)}.forgot-password-page .forgot-password-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark);text-align:center;margin-bottom:8px}.forgot-password-page .forgot-password-subtitle{font-family:var(--font-body);font-size:16px;color:var(--text-medium);text-align:center;margin-bottom:32px}.forgot-password-page .forgot-password-form{display:flex;flex-direction:column;gap:24px}.forgot-password-page .form-group{display:flex;flex-direction:column;gap:8px}.forgot-password-page .form-group label{font-family:var(--font-button);font-size:16px;font-weight:500;color:var(--text-dark)}.forgot-password-page .form-input{font-family:var(--font-body);font-size:16px;padding:12px 16px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);transition:all .2s ease}.forgot-password-page .form-input:focus{outline:none;border-color:var(--pastel-blue);box-shadow:0 0 0 3px #add8e64d}.forgot-password-page .reset-btn{font-family:var(--font-button);font-size:18px;font-weight:600;padding:14px 24px;background:var(--pastel-blue);color:var(--text-dark);border:3px solid var(--text-dark);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-crayon)}.forgot-password-page .reset-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-medium)}.forgot-password-page .reset-btn:disabled{opacity:.6;cursor:not-allowed}.forgot-password-page .back-link{text-align:center;margin-top:8px}.forgot-password-page .back-link a{font-family:var(--font-body);font-size:14px;color:var(--text-medium);text-decoration:none;display:inline-flex;align-items:center;transition:color .2s ease}.forgot-password-page .back-link a:hover{color:var(--text-dark)}.forgot-password-page .success-message{text-align:center;padding:24px}.forgot-password-page .success-message p{font-family:var(--font-body);font-size:16px;color:var(--text-dark);margin:8px 0}.forgot-password-page .back-to-login-btn{font-family:var(--font-button);font-size:16px;font-weight:600;padding:12px 24px;background:var(--pastel-green);color:var(--text-dark);border:3px solid var(--text-dark);border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-crayon)}.forgot-password-page .back-to-login-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}@media (max-width: 768px){.forgot-password-page .forgot-password-card{padding:32px 24px}.forgot-password-page .forgot-password-title{font-size:28px}}.reset-password-page{min-height:100vh;background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-lavender) 100%)}.reset-password-page .reset-password-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:40px 20px}.reset-password-page .reset-password-card{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:48px 40px;max-width:450px;width:100%;box-shadow:var(--shadow-medium)}.reset-password-page .reset-password-icon{font-size:64px;text-align:center;margin-bottom:20px;display:flex;justify-content:center;align-items:center}.reset-password-page .reset-password-icon svg{color:var(--text-dark)}.reset-password-page .reset-password-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark);text-align:center;margin-bottom:8px}.reset-password-page .reset-password-subtitle{font-family:var(--font-body);font-size:16px;color:var(--text-medium);text-align:center;margin-bottom:32px}.reset-password-page .reset-password-form{display:flex;flex-direction:column;gap:24px}.reset-password-page .form-group{display:flex;flex-direction:column;gap:8px}.reset-password-page .form-group label{font-family:var(--font-heading);font-size:16px;font-weight:500;color:var(--text-dark)}.reset-password-page .password-input-wrapper{position:relative;display:flex;align-items:center}.reset-password-page .form-input{font-family:var(--font-body);font-size:16px;padding:12px 48px 12px 16px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);transition:all .2s ease;width:100%}.reset-password-page .form-input:focus{outline:none;border-color:var(--pastel-blue);box-shadow:0 0 0 3px #add8e64d}.reset-password-page .password-toggle-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;color:var(--text-medium);transition:color .2s ease}.reset-password-page .password-toggle-btn:hover{color:var(--text-dark)}.reset-password-page .password-toggle-btn svg{color:inherit}.reset-password-page .reset-btn{font-family:var(--font-heading);font-size:18px;font-weight:600;padding:14px 24px;background:var(--pastel-blue);color:var(--text-dark);border:3px solid var(--text-dark);border-radius:12px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-crayon)}.reset-password-page .reset-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-medium)}.reset-password-page .reset-btn:disabled{opacity:.6;cursor:not-allowed}.reset-password-page .back-link{text-align:center;margin-top:8px}.reset-password-page .back-link a{font-family:var(--font-body);font-size:14px;color:var(--text-medium);text-decoration:none;display:inline-flex;align-items:center;transition:color .2s ease}.reset-password-page .back-link a:hover{color:var(--text-dark)}.reset-password-page .success-message{text-align:center;padding:24px}.reset-password-page .success-message p{font-family:var(--font-body);font-size:16px;color:var(--text-dark);margin:8px 0}@media (max-width: 768px){.reset-password-page .reset-password-card{padding:32px 24px}.reset-password-page .reset-password-title{font-size:28px}}.register-page{min-height:100vh;background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-mint) 100%)}.register-page .register-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:40px 20px}.register-page .register-card{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:48px 40px;max-width:600px;width:100%;box-shadow:var(--shadow-medium)}.register-page .register-icon{font-size:64px;text-align:center;margin-bottom:20px;display:flex;justify-content:center;align-items:center}.register-page .register-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark);text-align:center;margin-bottom:8px}.register-page .register-subtitle{font-family:var(--font-body);font-size:16px;color:var(--text-medium);text-align:center;margin-bottom:32px}.register-page .register-form{display:flex;flex-direction:column;gap:20px}.register-page .form-group{display:flex;flex-direction:column;gap:8px}.register-page .form-group label{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--text-dark)}.register-page .form-input,.register-page .form-select{font-family:var(--font-body);font-size:16px;padding:14px 18px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);transition:all .2s ease}.register-page .form-select{cursor:pointer}.register-page .form-input:focus,.register-page .form-select:focus{outline:none;border-color:var(--pastel-green);background:var(--pastel-mint);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.register-page .password-input-wrapper{position:relative;display:flex;align-items:center}.register-page .password-input-wrapper .form-input{padding-right:50px;width:100%}.register-page .password-toggle-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:20px;padding:4px 8px;display:flex;align-items:center;justify-content:center;transition:transform .2s ease;z-index:1}.register-page .password-toggle-btn:hover{transform:scale(1.1)}.register-page .password-toggle-btn:active{transform:scale(.95)}.register-page .register-btn{width:100%;background:linear-gradient(135deg,var(--pastel-blue) 0%,var(--pastel-purple) 100%);color:var(--text-dark);margin-top:8px;font-size:18px;font-weight:600}.register-page .register-btn:hover{background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-blue) 100%)}.register-page .register-btn:disabled{opacity:.6;cursor:not-allowed}.register-page .error-message{background:var(--pastel-coral);border:2px solid #FF6B6B;border-radius:12px;padding:12px;color:var(--text-dark);font-family:var(--font-body);font-size:14px;text-align:center}.register-page .login-link{text-align:center;margin-top:16px}.register-page .login-link p{font-family:var(--font-body);font-size:16px;color:var(--text-medium);margin:0}.register-page .login-link a{color:var(--text-dark);font-weight:600;text-decoration:none;border-bottom:2px solid var(--text-dark);transition:all .2s ease}.register-page .login-link a:hover{color:var(--pastel-purple);border-bottom-color:var(--pastel-purple)}.register-page .username-display{background:var(--pastel-blue);border:2px solid var(--text-dark);border-radius:12px;padding:12px;text-align:center;margin-top:-8px}.register-page .username-display p{font-family:var(--font-body);font-size:14px;color:var(--text-dark);margin:0}.register-page .username-display strong{font-family:var(--font-body);font-size:18px;font-weight:600;letter-spacing:1px}@media (max-width: 768px){.register-page .register-card{padding:32px 24px}.register-page .register-icon{font-size:48px}.register-page .register-title{font-size:28px}}.student-dashboard{min-height:100vh;background:var(--bg-cream)}.student-dashboard .dashboard-container{max-width:1200px;margin:0 auto;padding:40px 20px}.student-dashboard .dashboard-header{text-align:center;margin-bottom:48px}.student-dashboard .dashboard-title{font-family:var(--font-heading);font-size:42px;font-weight:700;color:var(--text-dark);margin-bottom:12px}.student-dashboard .dashboard-subtitle{font-family:var(--font-body);font-size:20px;color:var(--text-medium)}.student-dashboard .standards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;max-width:800px;margin:0 auto}.student-dashboard .standard-card{border:4px solid var(--text-dark);border-radius:24px;padding:40px 32px;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-crayon);text-align:center;position:relative;overflow:hidden}.student-dashboard .standard-card:hover:before{opacity:1}.student-dashboard .standard-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-medium)}.student-dashboard .standard-icon{margin-bottom:20px;display:flex;justify-content:center;align-items:center;color:var(--text-dark);position:relative;z-index:1}.student-dashboard .standard-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark);margin:0;position:relative;z-index:1}@media (max-width: 768px){.student-dashboard .dashboard-title{font-size:32px}.student-dashboard .dashboard-subtitle{font-size:18px}.student-dashboard .standards-grid{grid-template-columns:repeat(2,1fr);gap:24px;max-width:100%}.student-dashboard .standard-card{padding:32px 24px}.student-dashboard .standard-icon{margin-bottom:16px}.student-dashboard .standard-title{font-size:28px}}@media (max-width: 480px){.student-dashboard .standards-grid{grid-template-columns:1fr;gap:20px}}.subjects-list-page{min-height:100vh;background:var(--bg-cream)}.subjects-list-page .subjects-container{max-width:1200px;margin:0 auto;padding:40px 20px}.subjects-list-page .page-header{display:flex;align-items:center;gap:16px;margin-bottom:40px}.subjects-list-page .back-btn{font-family:var(--font-button);font-size:32px;background:transparent;border:3px solid var(--text-dark);border-radius:12px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-dark);padding:0}.subjects-list-page .back-btn:hover{background:var(--pastel-blue);transform:translate(-4px)}.subjects-list-page .back-btn:active{transform:translate(-2px)}.subjects-list-page .page-title{font-family:var(--font-heading);font-size:36px;font-weight:700;color:var(--text-dark)}.subjects-list-page .subjects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;grid-auto-rows:minmax(180px,auto)}.subjects-list-page .subject-card{border:4px solid var(--text-dark);border-radius:24px;padding:32px 24px;cursor:pointer;transition:all .4s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-crayon);text-align:center;position:relative;overflow:hidden;animation:cardEntrance .6s ease-out backwards;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:180px}@keyframes cardEntrance{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.subjects-list-page .card-shine{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.5) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.subjects-list-page .subject-card:hover .card-shine{opacity:1}.subjects-list-page .subject-card:hover{transform:translateY(-12px)!important;box-shadow:0 12px 32px #0003}.subjects-list-page .subject-card:active{transform:translateY(-6px) rotate(1deg) scale(1.02)!important;transition:all .1s ease}.subjects-list-page .subject-icon{margin-bottom:16px;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;color:var(--text-dark);position:relative;z-index:1}.subjects-list-page .subject-card:hover .subject-icon{transform:scale(1.3) rotate(10deg);filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.subjects-list-page .subject-name{font-family:var(--font-button);font-size:22px;font-weight:500;color:var(--text-dark);margin:0;position:relative;z-index:1;transition:transform .3s ease}.subjects-list-page .subject-card:hover .subject-name{transform:scale(1.1)}.subjects-list-page .subject-card[style*="span 2"]{min-height:200px;padding:40px 28px}.subjects-list-page .subject-card[style*="span 2"] .subject-icon{margin-bottom:20px}.subjects-list-page .subject-card[style*="span 2"] .subject-name{font-size:24px}@media (max-width: 1024px){.subjects-list-page .subjects-grid{grid-template-columns:repeat(3,1fr)}.subjects-list-page .subject-card[style*="span 2"]{grid-column:span 2}}@media (max-width: 768px){.subjects-list-page .subjects-grid{grid-template-columns:repeat(2,1fr);gap:16px}.subjects-list-page .subject-card{padding:24px 16px;min-height:160px}.subjects-list-page .subject-card[style*="span 2"]{grid-column:span 2;min-height:180px}.subjects-list-page .subject-icon{margin-bottom:12px}.subjects-list-page .subject-name{font-size:18px}.subjects-list-page .subject-card[style*="span 2"] .subject-name{font-size:20px}.subjects-list-page .page-title{font-size:28px}}@media (max-width: 480px){.subjects-list-page .subjects-grid{grid-template-columns:1fr}.subjects-list-page .subject-card[style*="span 2"]{grid-column:span 1}.subjects-list-page .subject-card{min-height:140px}}.pdf-list-page{min-height:100vh;background:var(--bg-cream)}.pdf-list-page .pdf-list-container{max-width:1200px;margin:0 auto;padding:40px 20px}.pdf-list-page .page-header{display:flex;align-items:center;gap:16px;margin-bottom:32px}.pdf-list-page .back-btn{font-family:var(--font-heading);font-size:32px;background:transparent;border:3px solid var(--text-dark);border-radius:12px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-dark);padding:0}.pdf-list-page .back-btn:hover{background:var(--pastel-blue);transform:translate(-4px)}.pdf-list-page .back-btn:active{transform:translate(-2px)}.pdf-list-page .page-title{font-family:var(--font-heading);font-size:36px;font-weight:700;color:var(--text-dark);margin:0}.pdf-list-page .semester-selector{display:flex;gap:16px;margin-bottom:32px;justify-content:flex-end}.pdf-list-page .sem-btn{font-family:var(--font-heading);font-size:16px;font-weight:500;padding:10px 24px;border:3px solid var(--text-dark);border-radius:20px;background:var(--bg-white);color:var(--text-dark);cursor:pointer;transition:all .2s ease}.pdf-list-page .sem-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.pdf-list-page .sem-btn.active{background:var(--text-dark);color:var(--bg-white)}.pdf-list-page .loading{text-align:center;font-family:var(--font-body);font-size:20px;color:var(--text-medium);padding:40px}.pdf-list-page .empty-state{text-align:center;padding:80px 20px;max-width:600px;margin:0 auto}.pdf-list-page .empty-state-icon{color:var(--text-medium);margin-bottom:24px;opacity:.6}.pdf-list-page .empty-state-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark);margin:0 0 16px}.pdf-list-page .empty-state-message{font-family:var(--font-body);font-size:18px;color:var(--text-medium);margin:0 0 12px;line-height:1.6}.pdf-list-page .empty-state-message strong{color:var(--text-dark);font-weight:600}.pdf-list-page .empty-state-submessage{font-family:var(--font-body);font-size:16px;color:var(--text-medium);margin:0;opacity:.8}.pdf-list-page .pdf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:24px}.pdf-list-page .pdf-card{border:4px solid var(--text-dark);border-radius:20px;padding:32px 24px;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-crayon);text-align:center;position:relative;overflow:hidden;min-height:200px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(135deg,#ffffff4d,#0000001a)}.pdf-list-page .pdf-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.4) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.pdf-list-page .pdf-card:hover:before{opacity:1}.pdf-list-page .pdf-card:hover{transform:translateY(-8px) scale(1.05)!important;box-shadow:var(--shadow-medium)}.pdf-list-page .pdf-icon{font-size:64px;margin-bottom:16px;transition:transform .3s ease;display:flex;align-items:center;justify-content:center;color:var(--text-dark)}.pdf-list-page .pdf-card:hover .pdf-icon{transform:scale(1.1)}.pdf-list-page .pdf-name{font-family:var(--font-heading);font-size:18px;font-weight:600;color:var(--text-dark);word-wrap:break-word}@media (max-width: 768px){.pdf-list-page .semester-selector{justify-content:center}.pdf-list-page .pdf-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.pdf-list-page .pdf-card{padding:24px 16px;min-height:160px}.pdf-list-page .pdf-icon{font-size:48px}.pdf-list-page .pdf-name{font-size:16px}}@media (max-width: 480px){.pdf-list-page .pdf-grid{grid-template-columns:repeat(2,1fr)}}:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors: active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--scale-factor));width:100%;min-width:calc(180px * var(--scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) #888;border-radius:calc(2px * var(--scale-factor));padding:calc(6px * var(--scale-factor));margin-left:calc(5px * var(--scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--scale-factor));padding-top:calc(2px * var(--scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors: active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;top:0;right:0;bottom:0;left:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;top:100%;right:0;bottom:0;left:0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer .endOfContent.active{top:0}.pdf-viewer-page{min-height:100vh;background:var(--bg-cream)}.pdf-viewer-page .pdf-viewer-container{max-width:1400px;margin:0 auto;padding:40px 20px}.pdf-viewer-page .viewer-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.pdf-viewer-page .back-btn{font-family:var(--font-button);font-size:32px;background:transparent;border:3px solid var(--text-dark);border-radius:12px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-dark);padding:0}.pdf-viewer-page .back-btn:hover{background:var(--pastel-blue);transform:translate(-4px)}.pdf-viewer-page .back-btn:active{transform:translate(-2px)}.pdf-viewer-page .viewer-title{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--text-dark)}.pdf-viewer-page .viewer-note{background:var(--pastel-yellow);border:3px solid var(--text-dark);border-radius:16px;padding:16px;margin-bottom:24px;text-align:center}.pdf-viewer-page .viewer-note p{font-family:var(--font-body);font-size:16px;color:var(--text-dark);margin:0}.pdf-viewer-page .pdf-viewer-wrapper{border:4px solid var(--text-dark);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-medium);background:var(--bg-white);min-height:600px}.pdf-viewer-page .pdf-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px;background:var(--bg-white);border-bottom:3px solid var(--text-dark);border-radius:16px 16px 0 0}.pdf-viewer-page .page-nav-btn{font-family:var(--font-button);background:var(--pastel-blue);border:3px solid var(--text-dark);border-radius:12px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-dark);padding:0}.pdf-viewer-page .page-nav-btn:hover:not(:disabled){background:var(--pastel-purple);transform:translateY(-2px)}.pdf-viewer-page .page-nav-btn:disabled{opacity:.5;cursor:not-allowed}.pdf-viewer-page .page-info{font-family:var(--font-body);font-size:16px;font-weight:600;color:var(--text-dark);min-width:120px;text-align:center}.pdf-viewer-page .pdf-content{background:var(--bg-white);padding:20px;display:flex;justify-content:center;align-items:flex-start;min-height:600px;max-height:80vh;overflow-y:auto;border-radius:0 0 16px 16px}.pdf-viewer-page .pdf-content canvas{max-width:100%;height:auto!important;box-shadow:var(--shadow-medium);border:2px solid var(--text-dark);border-radius:8px}.pdf-viewer-page .pdf-page{display:flex;justify-content:center}.pdf-viewer-page .pdf-content .react-pdf__Page__textContent,.pdf-viewer-page .pdf-content .react-pdf__Page__annotations{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.pdf-viewer-page .pdf-loading{text-align:center;font-family:var(--font-body);font-size:18px;color:var(--text-medium);padding:40px}.pdf-viewer-page .loading{text-align:center;font-family:var(--font-body);font-size:20px;color:var(--text-medium);padding:40px}.pdf-viewer-page .error-state{text-align:center;padding:60px 20px;background:var(--bg-white);border:4px solid var(--text-dark);border-radius:20px;box-shadow:var(--shadow-medium)}.pdf-viewer-page .error-state p{font-family:var(--font-body);font-size:18px;color:var(--text-dark);margin:16px 0}.pdf-viewer-page .error-state .btn-crayon{background:var(--pastel-blue);color:var(--text-dark)}.pdf-viewer-page .error-state .btn-crayon:hover{background:var(--pastel-purple)}@media (max-width: 768px){.pdf-viewer-page .pdf-viewer-container{padding:20px 16px}.pdf-viewer-page .viewer-title{font-size:24px}.pdf-viewer-page .pdf-content{padding:12px}.pdf-viewer-page .pdf-page{max-width:100%}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10001;animation:fadeIn .2s ease-out;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--bg-white);border:3px solid var(--text-dark);border-radius:20px;padding:32px;max-width:450px;width:100%;box-shadow:var(--shadow-medium);animation:slideUp .3s ease-out;font-family:var(--font-heading)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-dialog-icon{display:flex;justify-content:center;margin-bottom:20px}.confirm-dialog-title{font-size:24px;font-weight:600;color:var(--text-dark);text-align:center;margin-bottom:16px}.confirm-dialog-message{font-size:16px;color:var(--text-medium);text-align:center;margin-bottom:28px;line-height:1.5}.confirm-dialog-buttons{display:flex;gap:12px;justify-content:center}.confirm-dialog-btn{font-family:var(--font-heading);font-weight:500;border:3px solid var(--text-dark);border-radius:12px;padding:12px 24px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-crayon);font-size:16px;min-width:100px}.confirm-dialog-btn-cancel{background:var(--bg-white);color:var(--text-dark)}.confirm-dialog-btn-cancel:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium);background:var(--pastel-yellow)}.confirm-dialog-btn-cancel:active{transform:translateY(0)}.confirm-dialog-btn-confirm{color:var(--text-dark)}.confirm-dialog-btn-confirm:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium);filter:brightness(1.05)}.confirm-dialog-btn-confirm:active{transform:translateY(0)}@media (max-width: 768px){.confirm-dialog{padding:24px;max-width:100%}.confirm-dialog-title{font-size:20px}.confirm-dialog-message{font-size:14px}.confirm-dialog-buttons{flex-direction:column}.confirm-dialog-btn{width:100%}}.teacher-dashboard{min-height:100vh;background:var(--bg-cream)}.teacher-dashboard .teacher-container{max-width:1400px;margin:0 auto;padding:40px 20px}.teacher-dashboard .dashboard-header{display:flex;align-items:center;justify-content:center;margin-bottom:40px}.teacher-dashboard .dashboard-title{font-family:var(--font-heading);font-size:42px;font-weight:700;color:var(--text-dark);margin:0}.teacher-dashboard .dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:32px}.teacher-dashboard .upload-section,.teacher-dashboard .my-pdfs-section{padding:32px;background:var(--bg-white)}.teacher-dashboard .section-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.teacher-dashboard .section-icon{font-size:32px;display:flex;align-items:center;justify-content:center}.teacher-dashboard .section-title{font-family:var(--font-heading);font-size:24px;font-weight:600;color:var(--text-dark)}.teacher-dashboard .upload-form{display:flex;flex-direction:column;gap:24px}.teacher-dashboard .form-group label{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--text-dark);display:block;margin-bottom:8px}.teacher-dashboard .form-select{font-family:var(--font-body);font-size:16px;padding:12px 16px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);width:100%;cursor:pointer;transition:all .2s ease}.teacher-dashboard .form-select:focus{outline:none;border-color:var(--pastel-blue);background:var(--pastel-blue)}.teacher-dashboard .semester-buttons{display:flex;gap:12px}.teacher-dashboard .semester-buttons .sem-btn{flex:1;font-family:var(--font-button);font-size:16px;font-weight:500;padding:10px 20px;border:3px solid var(--text-dark);border-radius:16px;background:var(--bg-white);color:var(--text-dark);cursor:pointer;transition:all .2s ease}.teacher-dashboard .semester-buttons .sem-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.teacher-dashboard .semester-buttons .sem-btn.active{background:var(--text-dark);color:var(--bg-white)}.teacher-dashboard .file-upload-area{position:relative}.teacher-dashboard .file-input{position:absolute;opacity:0;width:100%;height:100%;cursor:pointer}.teacher-dashboard .file-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:3px dashed var(--text-dark);border-radius:16px;background:var(--pastel-blue);cursor:pointer;transition:all .2s ease;min-height:150px}.teacher-dashboard .file-label:hover{background:var(--pastel-purple);border-color:var(--pastel-purple)}.teacher-dashboard .file-icon{font-size:48px;margin-bottom:12px;display:flex;justify-content:center;align-items:center}.teacher-dashboard .file-text{font-family:var(--font-body);font-size:16px;color:var(--text-dark);text-align:center;width:100%}.teacher-dashboard .upload-btn{background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-mint) 100%);color:var(--text-dark);width:100%;font-size:18px;font-weight:600}.teacher-dashboard .upload-btn:hover{background:linear-gradient(135deg,var(--pastel-mint) 0%,var(--pastel-green) 100%)}.teacher-dashboard .upload-btn:disabled{opacity:.6;cursor:not-allowed}.teacher-dashboard .pdfs-list{display:flex;flex-direction:column;gap:16px}.teacher-dashboard .pdf-item{display:flex;align-items:center;gap:16px;padding:16px;border:3px solid var(--text-dark);border-radius:16px;background:var(--bg-white);transition:all .2s ease}.teacher-dashboard .pdf-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.teacher-dashboard .pdf-item-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}.teacher-dashboard .pdf-item-info{flex:1;min-width:0}.teacher-dashboard .pdf-item-name{font-family:var(--font-button);font-size:18px;font-weight:600;color:var(--text-dark);margin-bottom:4px}.teacher-dashboard .pdf-item-meta{font-family:var(--font-body);font-size:14px;color:var(--text-medium);margin:0}.teacher-dashboard .delete-btn{background:transparent;border:none;font-size:24px;cursor:pointer;padding:8px;transition:transform .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.teacher-dashboard .delete-btn:hover{transform:scale(1.2)}.teacher-dashboard .loading,.teacher-dashboard .empty-state{text-align:center;font-family:var(--font-body);font-size:18px;color:var(--text-medium);padding:40px}@media (max-width: 768px){.teacher-dashboard .dashboard-grid{grid-template-columns:1fr;gap:24px}.teacher-dashboard .upload-section,.teacher-dashboard .my-pdfs-section{padding:24px}.teacher-dashboard .dashboard-title{font-size:32px}}.admin-dashboard{min-height:100vh;background:var(--bg-cream)}.admin-dashboard .admin-container{max-width:1400px;margin:0 auto;padding:40px 20px}.admin-dashboard .dashboard-title{font-family:var(--font-heading);font-size:42px;font-weight:700;color:var(--text-dark);margin-bottom:40px;text-align:center}.admin-dashboard .admin-tabs{display:flex;gap:16px;margin-bottom:32px;flex-wrap:wrap;justify-content:center}.admin-dashboard .tab-btn{font-family:var(--font-button);font-size:16px;font-weight:500;padding:12px 24px;border:3px solid var(--text-dark);border-radius:16px;background:var(--bg-white);color:var(--text-dark);cursor:pointer;transition:all .2s ease}.admin-dashboard .tab-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft);background:var(--pastel-blue)}.admin-dashboard .tab-btn.active{background:var(--text-dark);color:var(--bg-white)}.admin-dashboard .admin-content{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:40px;box-shadow:var(--shadow-crayon)}.admin-dashboard .content-section{text-align:center}.admin-dashboard .section-title{font-family:var(--font-heading);font-size:32px;font-weight:600;color:var(--text-dark);margin-bottom:24px}.admin-dashboard .section-description{font-family:var(--font-body);font-size:18px;color:var(--text-medium)}.admin-dashboard .action-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:32px}.admin-dashboard .action-btn{background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-pink) 100%);color:var(--text-dark);font-size:16px;padding:14px 28px}.admin-dashboard .action-btn:hover{background:linear-gradient(135deg,var(--pastel-pink) 0%,var(--pastel-purple) 100%)}.admin-dashboard .notification-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--pastel-coral);color:var(--text-dark);border-radius:10px;font-size:12px;font-weight:500;margin-left:8px;border:2px solid var(--text-dark)}.admin-dashboard .notification-banner{background:linear-gradient(135deg,var(--pastel-yellow) 0%,var(--pastel-orange) 100%);border:3px solid var(--text-dark);border-radius:16px;padding:20px;margin-bottom:32px;display:flex;align-items:flex-start;gap:16px;text-align:initial}.admin-dashboard .notification-banner svg{color:var(--text-dark);flex-shrink:0;margin-top:2px}.admin-dashboard .invite-form{margin-bottom:40px;text-align:left}.admin-dashboard .form-group{display:flex;flex-direction:column;gap:8px}.admin-dashboard .form-group label{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--text-dark)}.admin-dashboard .invite-input-group{display:flex;gap:12px}.admin-dashboard .form-input{font-family:var(--font-body);font-size:16px;padding:14px 18px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);flex:1;transition:all .2s ease}.admin-dashboard .form-input:focus{outline:none;border-color:var(--pastel-blue);background:var(--pastel-blue);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.admin-dashboard .invite-btn{background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-mint) 100%);color:var(--text-dark);font-size:16px;padding:14px 28px;white-space:nowrap}.admin-dashboard .invite-btn:hover{background:linear-gradient(135deg,var(--pastel-mint) 0%,var(--pastel-green) 100%)}.admin-dashboard .invites-list{text-align:left}.admin-dashboard .subsection-title{font-family:var(--font-heading);font-size:24px;font-weight:600;color:var(--text-dark);margin-bottom:24px}.admin-dashboard .empty-state{font-family:var(--font-body);font-size:16px;color:var(--text-medium);text-align:center;padding:40px}.admin-dashboard .invites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.admin-dashboard .invite-card{background:var(--bg-white);border:3px solid var(--text-dark);border-radius:16px;padding:20px;transition:all .2s ease}.admin-dashboard .invite-card.active{background:linear-gradient(135deg,var(--pastel-blue) 0%,var(--pastel-purple) 100%)}.admin-dashboard .invite-card.used{background:var(--pastel-green);opacity:.8}.admin-dashboard .invite-card.expired{background:var(--pastel-coral);opacity:.7}.admin-dashboard .invite-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-medium)}.admin-dashboard .invite-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.admin-dashboard .invite-email{font-family:var(--font-heading);font-size:18px;font-weight:600;color:var(--text-dark);margin:0 0 8px}.admin-dashboard .invite-status{margin:0}.admin-dashboard .status-badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-body);font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;border:2px solid var(--text-dark)}.admin-dashboard .status-badge.active{background:var(--pastel-green);color:var(--text-dark)}.admin-dashboard .status-badge.used{background:var(--pastel-blue);color:var(--text-dark)}.admin-dashboard .status-badge.expired{background:var(--pastel-coral);color:var(--text-dark)}.admin-dashboard .revoke-btn{background:var(--pastel-coral);border:2px solid var(--text-dark);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:var(--text-dark);padding:0}.admin-dashboard .revoke-btn:hover{background:var(--text-dark);color:var(--bg-white);transform:scale(1.1)}.admin-dashboard .invite-details{margin-top:12px;padding-top:12px;border-top:2px solid var(--text-dark)}.admin-dashboard .invite-meta{font-family:var(--font-body);font-size:13px;color:var(--text-medium);margin:4px 0;display:flex;align-items:center;gap:6px}@media (max-width: 768px){.admin-dashboard .admin-tabs{gap:12px}.admin-dashboard .tab-btn{font-size:14px;padding:10px 20px}.admin-dashboard .admin-content{padding:24px}.admin-dashboard .section-title{font-size:24px}.admin-dashboard .action-buttons{flex-direction:column;align-items:stretch}.admin-dashboard .action-btn{width:100%}.admin-dashboard .invite-input-group{flex-direction:column}.admin-dashboard .invite-btn{width:100%}.admin-dashboard .invites-grid{grid-template-columns:1fr}}.about-page{min-height:100vh;background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-pink) 100%);padding-bottom:60px}.about-page .about-container{max-width:1200px;margin:0 auto;padding:60px 20px}.about-page .about-hero{text-align:center;margin-bottom:80px}.about-page .about-icon{margin-bottom:24px;display:flex;justify-content:center;align-items:center;animation:float 3s ease-in-out infinite}.about-page .about-icon svg{color:var(--text-dark)}.about-page .about-title{font-family:var(--font-heading);font-size:48px;font-weight:700;color:var(--text-dark);margin-bottom:16px}.about-page .about-subtitle{font-family:var(--font-body);font-size:20px;color:var(--text-medium);max-width:600px;margin:0 auto}.about-page .timeline-wrapper{position:relative;max-width:1000px;margin:0 auto 60px;padding:40px 0}.about-page .timeline-line{position:absolute;left:50%;top:0;bottom:0;width:6px;background:var(--text-dark);border-radius:3px;transform:translate(-50%);box-shadow:var(--shadow-crayon);z-index:0}.about-page .timeline-item{position:relative;margin-bottom:60px;display:flex;align-items:center;z-index:1}.about-page .timeline-item-left{flex-direction:row}.about-page .timeline-item-right{flex-direction:row-reverse}.about-page .timeline-marker{position:absolute;left:50%;transform:translate(-50%);width:72px;height:72px;border:4px solid var(--text-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-crayon);z-index:2;transition:all .3s ease;background:var(--bg-white)}.about-page .timeline-marker:hover{transform:translate(-50%) scale(1.15) rotate(10deg);box-shadow:var(--shadow-medium)}.about-page .timeline-marker svg{color:var(--text-dark)}.about-page .timeline-card{width:45%;border:4px solid var(--text-dark);border-radius:24px;padding:32px;box-shadow:var(--shadow-crayon);position:relative;transition:all .3s ease}.about-page .timeline-item-left .timeline-card{margin-left:-30px;margin-right:auto}.about-page .timeline-item-right .timeline-card{margin-right:-20px;margin-left:auto}.about-page .timeline-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--shadow-medium)}.about-page .timeline-card-content{position:relative;z-index:1}.about-page .timeline-card-connector{position:absolute;top:50%;width:0;height:0;border-style:solid;transform:translateY(-50%);z-index:1}.about-page .timeline-item-left .timeline-card-connector{right:-24px;border-width:16px 0 16px 24px;border-color:transparent transparent transparent var(--text-dark)}.about-page .timeline-item-right .timeline-card-connector{left:-24px;border-width:16px 24px 16px 0;border-color:transparent var(--text-dark) transparent transparent}.about-page .timeline-title{font-family:var(--font-heading);font-size:24px;font-weight:600;color:var(--text-dark);margin-bottom:12px}.about-page .timeline-description{font-family:var(--font-body);font-size:16px;color:var(--text-medium);line-height:1.6;margin:0}.about-page .about-footer{text-align:center;padding:40px 20px;background:var(--bg-white);border:3px solid var(--text-dark);border-radius:20px;box-shadow:var(--shadow-crayon);max-width:600px;margin:0 auto}.about-page .footer-text{font-family:var(--font-body);font-size:18px;color:var(--text-dark);display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.about-page .about-container{padding:40px 16px}.about-page .about-title{font-size:36px}.about-page .about-subtitle{font-size:18px}.about-page .about-hero{margin-bottom:60px}.about-page .timeline-wrapper{padding:20px 0}.about-page .timeline-line{left:30px;transform:none}.about-page .timeline-item{flex-direction:row!important;margin-bottom:50px}.about-page .timeline-marker{left:30px;transform:translate(-50%);width:60px;height:60px}.about-page .timeline-marker svg{width:28px;height:28px}.about-page .timeline-card{width:calc(100% - 80px);margin-left:80px!important;margin-right:0!important}.about-page .timeline-item-left .timeline-card-connector,.about-page .timeline-item-right .timeline-card-connector{left:-20px;right:auto;border-width:15px 20px 15px 0;border-color:transparent var(--text-dark) transparent transparent}.about-page .timeline-title{font-size:20px}.about-page .timeline-description{font-size:15px}}@media (max-width: 480px){.about-page .timeline-card{padding:24px}.about-page .timeline-marker{width:56px;height:56px}.about-page .timeline-marker svg{width:24px;height:24px}}.contact-page{min-height:100vh;background:linear-gradient(135deg,var(--pastel-green) 0%,var(--pastel-blue) 100%);padding-bottom:60px}.contact-page .contact-container{max-width:1200px;margin:0 auto;padding:60px 20px}.contact-page .contact-hero{text-align:center;margin-bottom:60px}.contact-page .contact-icon{margin-bottom:24px;display:flex;justify-content:center;align-items:center;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.contact-page .contact-icon svg{color:var(--text-dark)}.contact-page .contact-title{font-family:var(--font-heading);font-size:48px;font-weight:700;color:var(--text-dark);margin-bottom:16px}.contact-page .contact-subtitle{font-family:var(--font-body);font-size:20px;color:var(--text-medium);max-width:600px;margin:0 auto}.contact-page .contact-content{display:grid;grid-template-columns:1fr 2fr;gap:32px;align-items:start}.contact-page .contact-info-card{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:32px;box-shadow:var(--shadow-crayon);display:flex;flex-direction:column;gap:24px}.contact-page .info-item{display:flex;gap:16px;align-items:flex-start}.contact-page .info-icon{background:var(--pastel-yellow);border:3px solid var(--text-dark);border-radius:12px;width:56px;height:56px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease}.contact-page .info-item:hover .info-icon{transform:scale(1.1) rotate(5deg)}.contact-page .info-icon svg{color:var(--text-dark)}.contact-page .info-content{flex:1}.contact-page .info-title{font-family:var(--font-heading);font-size:18px;font-weight:600;color:var(--text-dark)}.contact-page .info-text{font-family:var(--font-body);font-size:15px;color:var(--text-medium);margin:0}.contact-page .contact-form-card{background:var(--bg-white);border:4px solid var(--text-dark);border-radius:24px;padding:40px;box-shadow:var(--shadow-crayon)}.contact-page .form-title{font-family:var(--font-heading);font-size:28px;font-weight:600;color:var(--text-dark);margin-bottom:32px;text-align:center}.contact-page .contact-form{display:flex;flex-direction:column;gap:24px}.contact-page .form-group{display:flex;flex-direction:column;gap:8px}.contact-page .form-group label{font-family:var(--font-heading);font-size:16px;font-weight:500;color:var(--text-dark)}.contact-page .form-input,.contact-page .form-textarea{font-family:var(--font-body);font-size:16px;padding:14px 18px;border:3px solid var(--text-dark);border-radius:12px;background:var(--bg-white);color:var(--text-dark);transition:all .2s ease;resize:vertical}.contact-page .form-textarea{min-height:120px;font-family:var(--font-body)}.contact-page .form-input:focus,.contact-page .form-textarea:focus{outline:none;border-color:var(--pastel-blue);background:var(--pastel-blue);transform:translateY(-2px);box-shadow:var(--shadow-soft)}.contact-page .submit-btn{background:linear-gradient(135deg,var(--pastel-purple) 0%,var(--pastel-pink) 100%);color:var(--text-dark);font-size:18px;font-weight:600;width:100%;padding:16px 24px;display:flex;align-items:center;justify-content:center;margin-top:8px}.contact-page .submit-btn:hover{background:linear-gradient(135deg,var(--pastel-pink) 0%,var(--pastel-purple) 100%)}.contact-page .submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 968px){.contact-page .contact-content{grid-template-columns:1fr;gap:32px}.contact-page .contact-info-card{order:2}.contact-page .contact-form-card{order:1}}@media (max-width: 768px){.contact-page .contact-container{padding:40px 16px}.contact-page .contact-title{font-size:36px}.contact-page .contact-subtitle{font-size:18px}.contact-page .contact-form-card{padding:32px 24px}.contact-page .form-title{font-size:24px;margin-bottom:24px}.contact-page .contact-info-card{padding:24px}.contact-page .info-item{flex-direction:column;text-align:center}.contact-page .info-icon{margin:0 auto}}.navbar{background-color:var(--bg-white);border-bottom:3px solid var(--text-dark);padding:16px 24px;box-shadow:var(--shadow-soft);position:sticky;top:0;z-index:100}.navbar-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.navbar-logo{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--text-dark);text-decoration:none;transition:transform .2s ease}.navbar-logo:hover{transform:scale(1.05)}.navbar-links{display:flex;gap:24px;align-items:center;flex-wrap:wrap}.nav-link{font-family:var(--font-button);font-size:16px;font-weight:500;color:var(--text-dark);text-decoration:none;padding:8px 16px;border-radius:12px;transition:all .2s ease;background:transparent;border:none;cursor:pointer}.nav-link:hover{background-color:var(--pastel-blue);transform:translateY(-2px)}.logout-btn{color:#ff6b6b}.logout-btn:hover{background-color:var(--pastel-coral)}@media (max-width: 768px){.navbar{padding:12px 16px}.navbar-logo{font-size:24px}.navbar-links{gap:12px}.nav-link{font-size:14px;padding:6px 12px}}.footer{background-color:var(--bg-white);border-top:3px solid var(--text-dark);padding:24px 20px;box-shadow:var(--shadow-soft);width:100%;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.footer-text{font-family:var(--font-body);font-size:18px;color:var(--text-dark);display:flex;align-items:center;justify-content:center;gap:3px;margin:0}.footer-text svg{color:var(--text-dark);display:inline-block;vertical-align:middle}@media (max-width: 768px){.footer{padding:20px 16px}.footer-text{font-size:16px;margin-bottom:5px}.footer-container{flex-direction:column;text-align:center}}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:24px;color:var(--text-medium);font-family:var(--font-body)}*{margin:0;padding:0;box-sizing:border-box}:root{--font-heading: "Playpen Sans", cursive;--font-button: "Fredoka", sans-serif;--font-body: "Lexend", sans-serif;--pastel-pink: #FFD6E8;--pastel-blue: #D6E8FF;--pastel-yellow: #FFF4D6;--pastel-purple: #E8D6FF;--pastel-green: #D6FFE8;--pastel-orange: #FFE8D6;--pastel-peach: #FFE0CC;--pastel-lavender: #F0E6FF;--pastel-mint: #D6FFF0;--pastel-coral: #FFD6CC;--text-dark: #2D2D2D;--text-medium: #5A5A5A;--text-light: #8A8A8A;--bg-cream: #FFFBF5;--bg-white: #FFFFFF;--shadow-soft: 0 4px 12px rgba(0, 0, 0, .08);--shadow-medium: 0 6px 20px rgba(0, 0, 0, .12);--shadow-crayon: 0 2px 8px rgba(0, 0, 0, .1), 0 1px 3px rgba(0, 0, 0, .08)}body{font-family:var(--font-body);background-color:var(--bg-cream);color:var(--text-dark);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600}h1{font-weight:700}h2{font-weight:600}button,.btn,.btn-crayon{font-family:var(--font-button);font-weight:500}#root{min-height:100vh}.btn-crayon{font-family:var(--font-button);font-weight:500;border:3px solid var(--text-dark);border-radius:16px;padding:12px 24px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-crayon);position:relative;font-size:16px}.btn-crayon:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.btn-crayon:active{transform:translateY(0);box-shadow:var(--shadow-soft)}.card-crayon{border:3px solid var(--text-dark);border-radius:20px;background:var(--bg-white);box-shadow:var(--shadow-crayon);transition:all .2s ease}.card-crayon:hover{transform:translateY(-4px);box-shadow:var(--shadow-medium)}@media (max-width: 768px){.btn-crayon{font-size:14px;padding:10px 20px}}
