.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#fafafa}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background-color:#fafafa}.error-title{font-size:2rem;font-weight:700;color:#dc2626;margin-bottom:1rem}.error-message{font-size:1rem;color:#6b7280;text-align:center;max-width:500px}.auth-home-container{min-height:100vh;background-color:#fafafa}.auth-nav{background-color:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100}.auth-nav-content{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.auth-logo-section{display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:opacity .3s ease}.auth-logo-section:hover{opacity:.8}.auth-logo-text{font-size:1.5rem;font-weight:700;letter-spacing:.05em;background:linear-gradient(135deg,#515e90,#6b77a9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-user-section{display:flex;align-items:center;gap:1rem}.auth-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem}.auth-signout-btn{padding:.5rem 1.25rem;background-color:#f3f4f6;color:#374151;border-radius:8px;font-weight:500;font-size:.95rem;transition:all .3s ease}.auth-signout-btn:hover{background-color:#e5e7eb;transform:translateY(-1px)}.auth-main-content{max-width:1400px;margin:0 auto;padding:2rem}.auth-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.auth-tab{padding:1rem 1.5rem;background:none;color:#6b7280;font-weight:500;font-size:1rem;border-bottom:3px solid transparent;transition:all .3s ease;position:relative}.auth-tab:hover{color:#515e90}.auth-tab-active{color:#515e90;border-bottom-color:#515e90}.auth-content-area{animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.auth-section-title{font-size:1.75rem;font-weight:700;color:#1f2937}.auth-action-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;border-radius:10px;font-weight:600;font-size:.95rem;box-shadow:0 4px 12px #515e9033;transition:all .3s ease}.auth-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #515e904d}.auth-action-btn:active{transform:translateY(0)}.auth-notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.auth-note-card{background:#fff;border-radius:12px;padding:1.5rem;border:1px solid #e5e7eb;transition:all .3s ease;cursor:pointer}.auth-note-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014;border-color:#515e90}.auth-note-title{font-size:1.1rem;font-weight:600;color:#1f2937;margin-bottom:.5rem}.auth-note-date{font-size:.85rem;color:#9ca3af;margin-bottom:.75rem}.auth-note-preview{font-size:.95rem;color:#6b7280;line-height:1.5}.auth-classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.auth-class-card{background:#fff;border-radius:12px;padding:1.75rem;border:1px solid #e5e7eb;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.auth-class-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#515e90,#6b77a9);transform:scaleX(0);transition:transform .3s ease}.auth-class-card:hover:before{transform:scaleX(1)}.auth-class-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.auth-class-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:.5rem}.auth-class-name{font-size:1.2rem;font-weight:700;color:#1f2937;flex:1}.auth-class-code{font-size:.85rem;font-weight:600;color:#515e90;background-color:#f0f1f5;padding:.25rem .75rem;border-radius:6px}.auth-class-university{font-size:.95rem;color:#6b7280;margin-bottom:1rem}.auth-class-stats{display:flex;gap:1.5rem;padding-top:1rem;border-top:1px solid #f3f4f6}.auth-class-stat{font-size:.9rem;color:#9ca3af}.auth-join-btn{margin-top:1rem;width:100%;padding:.75rem;background-color:#f9fafb;color:#515e90;border:1px solid #515E90;border-radius:8px;font-weight:600;font-size:.95rem;transition:all .3s ease}.auth-join-btn:hover{background-color:#515e90;color:#fff}.auth-search-input{padding:.75rem 1.25rem;border:1px solid #e5e7eb;border-radius:10px;font-size:.95rem;width:300px;transition:all .3s ease}.auth-search-input:focus{outline:none;border-color:#515e90;box-shadow:0 0 0 3px #515e901a}.auth-class-detail{max-width:1400px;margin:0 auto;padding:2rem;animation:fadeIn .5s ease}.auth-back-btn{padding:.75rem 1.25rem;background-color:#f3f4f6;color:#374151;border-radius:8px;font-weight:500;font-size:.95rem;margin-bottom:2rem;transition:all .3s ease}.auth-back-btn:hover{background-color:#e5e7eb;transform:translate(-4px)}.auth-class-detail-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid #e5e7eb}.auth-class-detail-name{font-size:2.5rem;font-weight:800;color:#1f2937;margin-bottom:.5rem}.auth-class-detail-code{font-size:1.1rem;color:#6b7280}.auth-class-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-bottom:3rem}.auth-feature-card-large{background:#fff;border-radius:16px;padding:2rem;border:1px solid #e5e7eb;position:relative;overflow:hidden;transition:all .3s ease}.auth-feature-card-large:before{content:"";position:absolute;top:0;left:0;right:0;height:100%;background:linear-gradient(135deg,#515e9008,#6b77a908);opacity:0;transition:opacity .3s ease}.auth-feature-card-large:hover:before{opacity:1}.auth-feature-card-large:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.auth-feature-badge{display:inline-block;padding:.4rem .9rem;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;border-radius:20px;font-size:.8rem;font-weight:600;margin-bottom:1rem;letter-spacing:.02em}.auth-feature-card-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.75rem;position:relative}.auth-feature-card-desc{font-size:1rem;color:#6b7280;line-height:1.6;margin-bottom:1.5rem}.auth-feature-btn{padding:.875rem 1.75rem;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;border-radius:10px;font-weight:600;font-size:1rem;box-shadow:0 4px 12px #515e9033;transition:all .3s ease}.auth-feature-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #515e904d}.auth-ai-chat{background:#fff;border-radius:16px;border:1px solid #e5e7eb;margin-bottom:3rem;overflow:hidden;animation:slideDown .4s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.auth-chat-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#515e900d,#6b77a90d)}.auth-chat-title{font-size:1.2rem;font-weight:700;color:#1f2937}.auth-chat-messages{padding:1.5rem;min-height:200px;max-height:400px;overflow-y:auto}.auth-chat-message{padding:1rem 1.25rem;border-radius:12px;margin-bottom:1rem;max-width:80%;animation:messageSlide .3s ease}@keyframes messageSlide{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.auth-chat-ai{background-color:#f3f4f6;color:#1f2937}.auth-chat-input-container{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid #e5e7eb}.auth-chat-input{flex:1;padding:.875rem 1.25rem;border:1px solid #e5e7eb;border-radius:10px;font-size:.95rem;transition:all .3s ease}.auth-chat-input:focus{outline:none;border-color:#515e90;box-shadow:0 0 0 3px #515e901a}.auth-chat-send-btn{padding:.875rem 1.75rem;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;border-radius:10px;font-weight:600;font-size:.95rem;transition:all .3s ease}.auth-chat-send-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #515e904d}@media (max-width: 768px){.auth-nav-content,.auth-main-content,.auth-class-detail{padding:1rem}.auth-section-title{font-size:1.5rem}.auth-class-detail-name{font-size:2rem}.auth-notes-grid,.auth-classes-grid,.auth-class-features{grid-template-columns:1fr}.auth-search-input{width:100%}.auth-tabs{overflow-x:auto}}.unauth-home-container{min-height:100vh;background-color:#fff}.unauth-nav{background-color:#fff;border-bottom:1px solid #f3f4f6;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2}.unauth-nav-content{max-width:1400px;margin:0 auto;padding:1.25rem 2rem;display:flex;justify-content:space-between;align-items:center}.unauth-logo-section{display:flex;align-items:center;gap:.75rem;cursor:pointer}.unauth-logo-text{font-size:1.75rem;font-weight:800;letter-spacing:.05em;background:linear-gradient(135deg,#515e90,#6b77a9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.unauth-signin-btn{padding:.75rem 1.75rem;background-color:#f9fafb;color:#1f2937;border:1px solid #e5e7eb;border-radius:10px;font-weight:600;font-size:.95rem;transition:all .3s ease}.unauth-signin-btn:hover{background-color:#f3f4f6;border-color:#515e90;color:#515e90;transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.unauth-hero{max-width:1400px;margin:0 auto;padding:6rem 2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.unauth-hero-content{animation:fadeInUp .8s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.unauth-hero-title{font-size:4rem;font-weight:900;color:#1f2937;line-height:1.1;margin-bottom:1.5rem;letter-spacing:-.02em}.unauth-hero-subtitle{font-size:1.35rem;color:#6b7280;line-height:1.6;margin-bottom:2.5rem}.unauth-cta-btn{padding:1.25rem 2.5rem;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;border-radius:12px;font-weight:700;font-size:1.1rem;box-shadow:0 8px 24px #515e9040;transition:all .3s ease}.unauth-cta-btn:hover{transform:translateY(-3px);box-shadow:0 12px 32px #515e9059}.unauth-cta-btn:active{transform:translateY(-1px)}.unauth-hero-visual{display:flex;align-items:center;justify-content:center;animation:fadeInUp .8s ease .2s both}.unauth-hero-image{width:100%;max-width:500px;height:auto;object-fit:contain}.unauth-features{max-width:1400px;margin:0 auto;padding:6rem 2rem;background-color:#fafafa}.unauth-section-title{font-size:2.75rem;font-weight:800;color:#1f2937;text-align:center;margin-bottom:4rem;letter-spacing:-.02em}.unauth-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.unauth-feature-card{background:#fff;border-radius:16px;padding:2.5rem;border:1px solid #e5e7eb;transition:all .4s ease;animation:fadeInUp .6s ease both}.unauth-feature-card:nth-child(1){animation-delay:.1s}.unauth-feature-card:nth-child(2){animation-delay:.2s}.unauth-feature-card:nth-child(3){animation-delay:.3s}.unauth-feature-card:nth-child(4){animation-delay:.4s}.unauth-feature-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px #0000001a;border-color:#515e90}.unauth-feature-icon{width:64px;height:64px;margin-bottom:1.5rem;background:linear-gradient(135deg,#515e901a,#6b77a91a);border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.unauth-feature-card:hover .unauth-feature-icon{transform:scale(1.1) rotate(5deg)}.unauth-icon-placeholder{font-size:.9rem;color:#515e90;font-weight:600}.unauth-feature-title{font-size:1.4rem;font-weight:700;color:#1f2937;margin-bottom:.75rem}.unauth-feature-desc{font-size:1rem;color:#6b7280;line-height:1.7}.unauth-stories{max-width:1400px;margin:0 auto;padding:6rem 2rem;background-color:#fff}.unauth-stories-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2.5rem}.unauth-story-card{background:#fff;border-radius:16px;padding:2.5rem;border:1px solid #e5e7eb;transition:all .4s ease;position:relative;overflow:hidden}.unauth-story-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#515e90,#6b77a9);transform:scaleX(0);transition:transform .4s ease}.unauth-story-card:hover:before{transform:scaleX(1)}.unauth-story-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px #00000014}.unauth-story-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#515e90,#6b77a9);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem;margin-bottom:1.5rem}.unauth-story-text{font-size:1.05rem;color:#374151;line-height:1.7;margin-bottom:1.5rem;font-style:italic}.unauth-story-author{padding-top:1rem;border-top:1px solid #f3f4f6}.unauth-author-name{font-size:1rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.unauth-author-role{font-size:.9rem;color:#9ca3af}.unauth-final-cta{background:linear-gradient(135deg,#515e900d,#6b77a90d);padding:6rem 2rem}.unauth-cta-content{max-width:800px;margin:0 auto;text-align:center}.unauth-cta-title{font-size:3rem;font-weight:900;color:#1f2937;margin-bottom:1rem;letter-spacing:-.02em}.unauth-cta-subtitle{font-size:1.25rem;color:#6b7280;margin-bottom:2.5rem}.unauth-cta-btn-large{padding:1.25rem 3rem;background:linear-gradient(135deg,#515e90,#6b77a9);color:#fff;border-radius:12px;font-weight:700;font-size:1.15rem;box-shadow:0 8px 24px #515e9040;transition:all .3s ease}.unauth-cta-btn-large:hover{transform:translateY(-3px);box-shadow:0 12px 32px #515e9059}.unauth-footer{background-color:#fafafa;border-top:1px solid #e5e7eb;padding:3rem 2rem}.unauth-footer-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.unauth-footer-logo{display:flex;align-items:center;gap:.5rem}.unauth-footer-text{font-size:1.25rem;font-weight:700;letter-spacing:.05em;background:linear-gradient(135deg,#515e90,#6b77a9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.unauth-footer-copy{font-size:.9rem;color:#9ca3af}@media (max-width: 1024px){.unauth-hero{grid-template-columns:1fr;gap:3rem;padding:4rem 2rem}.unauth-hero-content{text-align:center}.unauth-hero-title{font-size:3rem}.unauth-hero-visual{max-width:100%}.unauth-hero-image{max-width:400px}}@media (max-width: 768px){.unauth-nav-content{padding:1rem}.unauth-hero{padding:3rem 1rem}.unauth-hero-title{font-size:2.5rem}.unauth-hero-subtitle{font-size:1.1rem}.unauth-hero-image{max-width:300px}.unauth-cta-btn{padding:1rem 2rem;font-size:1rem}.unauth-section-title,.unauth-cta-title{font-size:2rem}.unauth-features,.unauth-stories,.unauth-final-cta{padding:4rem 1rem}.unauth-features-grid,.unauth-stories-grid{grid-template-columns:1fr}.unauth-footer-content{flex-direction:column;gap:1rem;text-align:center}}@media (max-width: 480px){.unauth-hero-title{font-size:2rem}.unauth-hero-image{max-width:250px}.unauth-cta-btn{padding:.875rem 1.75rem;font-size:.95rem}.unauth-cta-btn-large{width:100%}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;font-weight:400;--primary-blue: #2563eb;--secondary-blue: #3b82f6;--light-blue: #60a5fa;--dark-blue: #1e40af;--gradient-blue: linear-gradient(135deg, #2563eb 0%, #3b82f6 50%, #60a5fa 100%);--text-dark: #1f2937;--text-gray: #6b7280;--bg-white: #ffffff;--bg-light: #f9fafb;--border-gray: #e5e7eb}body{margin:0;background-color:var(--bg-white);color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .3s ease}a{text-decoration:none;color:inherit}input,textarea{font-family:inherit}.gradient-text{background:var(--gradient-blue);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}html{scroll-behavior:smooth}
