@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);.header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 20px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-container{height:70px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.header-container,.logo{align-items:center;display:flex}.logo{color:#fff;font-size:1.5rem;font-weight:700;gap:12px;text-decoration:none;transition:transform .3s ease}.logo:hover{transform:scale(1.05)}.logo-icon{font-size:1.8rem}.logo-text{background:linear-gradient(45deg,#fff,#e2e8f0)}.nav,.nav-link{align-items:center;display:flex;gap:8px}.nav-link{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:25px;color:#fff;font-weight:500;padding:12px 20px;position:relative;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:#fff3;transform:translateY(-2px)}.nav-link.active{background:#ffffff40;box-shadow:0 4px 15px #fff3}.nav-icon{font-size:1.1rem}.notification-badge{background:#e53e3e;border-radius:50%;font-size:.7rem;font-weight:700;height:20px;justify-content:center;position:absolute;right:-5px;top:-5px;width:20px}.logout-btn,.notification-badge{align-items:center;color:#fff;display:flex}.logout-btn{background:#ef4444cc;border:none;border-radius:25px;cursor:pointer;font-size:.95rem;font-weight:500;gap:8px;padding:12px 20px;transition:all .3s ease}.logout-btn:hover{background:#ef4444;transform:translateY(-2px)}.register-btn{background:#48bb78cc}.register-btn:hover{background:#48bb78}@media (max-width:768px){.header-container{height:60px;padding:0 15px}.logo-text{display:none}.nav{gap:5px}.nav-link{font-size:.9rem;padding:10px 15px}.nav-link span:not(.nav-icon){display:none}.nav-icon{font-size:1.2rem}}.footer{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;margin-top:auto}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:2fr 1fr 1fr 1fr;margin:0 auto;max-width:1200px;padding:3rem 2rem 2rem}.footer-section h4{color:#ecf0f1;font-size:1.1rem;font-weight:600;margin-bottom:1.2rem}.footer-logo{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.logo-icon{font-size:1.5rem}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#3498db,#9b59b6);-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:700}.footer-description{color:#bdc3c7;font-size:.9rem;line-height:1.6;margin-bottom:1.5rem}.social-links{display:flex;gap:1rem}.social-link{align-items:center;background:#ffffff1a;border-radius:50%;display:flex;height:40px;justify-content:center;text-decoration:none;transition:all .3s ease;width:40px}.social-link:hover{background:#3498db;transform:translateY(-2px)}.social-icon{font-size:1.2rem}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:.7rem}.footer-links a{color:#bdc3c7;font-size:.9rem;text-decoration:none;transition:color .3s ease}.footer-links a:hover{color:#3498db}.footer-bottom{border-top:1px solid #ffffff1a;padding:1.5rem 2rem}.footer-bottom-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.copyright{color:#95a5a6;font-size:.9rem}.footer-bottom-links{align-items:center;display:flex;gap:.5rem}.footer-bottom-links a{color:#bdc3c7;font-size:.85rem;text-decoration:none;transition:color .3s ease}.footer-bottom-links a:hover{color:#3498db}.separator{color:#7f8c8d;font-size:.8rem}@media (max-width:768px){.footer-content{gap:2rem;grid-template-columns:1fr;padding:2rem 1.5rem 1.5rem;text-align:center}.footer-bottom-content{flex-direction:column;gap:1rem;text-align:center}.footer-logo,.social-links{justify-content:center}}@media (max-width:480px){.footer-content{padding:1.5rem 1rem 1rem}.footer-bottom{padding:1rem}.footer-bottom-links{flex-wrap:wrap;justify-content:center}}.app{background:#f8f9fa;display:flex;flex-direction:column;min-height:100vh}.main-content{background-color:#f8f9fa;flex:1 1;width:100%}.main-content.full-screen{margin:0;padding:0}.notification-container{max-width:300px;position:fixed;right:20px;top:20px;z-index:1000}.notification{animation:slideIn .3s ease-out;border-radius:4px;box-shadow:0 2px 10px #0000001a;cursor:pointer;margin-bottom:10px;padding:12px 16px}.notification-info{background:#3498db;color:#fff}.notification-success{background:#27ae60;color:#fff}.notification-warning{background:#f39c12;color:#fff}.notification-error{background:#e74c3c;color:#fff}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.home-page{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:100vh}.hero{margin:0 auto;max-width:1200px}.hero-content h1{font-size:3.5rem;font-weight:700;line-height:1.1;margin-bottom:1.5rem;text-shadow:0 2px 10px #0000004d}.hero-content p{font-size:1.4rem;line-height:1.6;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:600px;opacity:.9}.user-welcome h2{color:#fff;font-size:2.5rem;margin-bottom:1rem}.user-welcome p{font-size:1.2rem;margin-bottom:2.5rem;opacity:.9}.guest-actions p{font-size:1.3rem;margin-bottom:2.5rem;opacity:.9}.action-buttons{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:0 auto;max-width:800px}.btn{align-items:center;border-radius:12px;display:flex;font-size:1.1rem;font-weight:600;gap:.8rem;justify-content:center;min-height:60px;padding:1.2rem 2rem}.btn-icon{font-size:1.3rem}.btn-primary{background:#fffffff2;box-shadow:0 4px 15px #0003;color:#667eea}.btn-primary:hover{background:#fff;box-shadow:0 8px 25px #0000004d;transform:translateY(-3px)}.btn-secondary{background:#2ecc71f2;box-shadow:0 4px 15px #0003}.btn-secondary:hover{background:#2ecc71;box-shadow:0 8px 25px #2ecc7166;transform:translateY(-3px)}.btn-accent{background:#e67e22f2;box-shadow:0 4px 15px #0003;color:#fff}.btn-accent:hover{background:#e67e22;box-shadow:0 8px 25px #e67e2266;transform:translateY(-3px)}.btn-outline{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000;border:2px solid #ffffff4d;color:#fff}.btn-outline:hover{background:#ffffff1a;border-color:#fff;transform:translateY(-3px)}.features{padding:4rem 2rem}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;padding:2.5rem 2rem;transition:all .3s ease}.feature-card:hover{background:#ffffff26;box-shadow:0 10px 30px #0003}.feature-icon{display:block;font-size:4rem}.feature-card h3{color:#fff;font-size:1.5rem;font-weight:600}.feature-card p{color:#fffc;font-size:1rem;line-height:1.6}.loading{align-items:center;color:#fff;display:flex;flex-direction:column;justify-content:center;padding:6rem 2rem}.spinner{border:4px solid #ffffff4d;border-top-color:#fff;height:60px;margin-bottom:1.5rem;width:60px}@media (max-width:768px){.hero{padding:3rem 1rem}.hero-content h1{font-size:2.5rem}.hero-content p{font-size:1.2rem}.action-buttons{gap:1rem;grid-template-columns:1fr}.features{gap:1.5rem;grid-template-columns:1fr;padding:3rem 1rem}.feature-card{padding:2rem 1.5rem}.btn{font-size:1rem;padding:1rem 1.5rem}}@media (max-width:480px){.hero-content h1{font-size:2rem}.hero-content p{font-size:1.1rem}.feature-card{padding:1.5rem 1rem}.feature-icon{font-size:3rem}}.user-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;height:600px;margin:0 auto;max-width:400px;overflow:hidden;width:100%}.user-card:hover{box-shadow:0 20px 50px #00000040;transform:translateY(-8px)}.card-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:0 1.5rem 1rem}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0;padding:1.2rem;text-align:center}.card-counter{font-size:.9rem;font-weight:500;opacity:.9}.user-image{flex-shrink:0;padding:2rem 1rem 1rem;position:relative;text-align:center}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#3498db,#2c3e50);border:5px solid #fff;border-radius:50%;box-shadow:0 8px 25px #00000026;color:#fff;display:flex;font-size:2.5rem;font-weight:700;height:100px;justify-content:center;margin:0 auto;width:100px}.user-info{display:flex;flex:1 1;flex-direction:column;min-height:0}.user-name{color:#2c3e50;flex-shrink:0;font-size:1.4rem;font-weight:700;line-height:1.2;margin:1rem 0;text-align:center}.user-meta{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #0000000d;border-radius:12px;flex-shrink:0;margin-bottom:1rem;padding:1rem}.meta-item{border-bottom:1px solid #0000000d;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:.5rem;padding:.3rem 0}.meta-item:last-child{border-bottom:none;margin-bottom:0}.meta-label{color:#6c757d;font-weight:600}.meta-value{color:#2c3e50;font-weight:600;max-width:60%;text-align:right;word-break:break-word}.user-bio{background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;flex-shrink:0;margin-bottom:1rem;max-height:80px;overflow-y:auto;padding:1rem}.user-bio h4{color:#2c3e50;font-size:1rem;font-weight:600;margin-bottom:.5rem}.user-bio p{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.9rem;font-style:italic;line-height:1.4;margin:0;overflow:hidden}.user-subjects{flex-shrink:0;margin-bottom:1rem}.user-subjects h4{color:#2c3e50;font-size:1rem;font-weight:600;margin-bottom:.8rem}.subjects-list{display:flex;flex-wrap:wrap;gap:.5rem;max-height:80px;overflow-y:auto}.subject-tag{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #90caf9;border-radius:15px;font-size:.8rem;font-weight:500;padding:.4rem .8rem}.subject-tag.more{background:#f8f9fa;border:1px solid #dee2e6;color:#6c757d}.swipe-indicators{display:flex;flex-shrink:0;justify-content:space-between;margin:1rem 0;padding:0 1rem}.indicator{border:2px solid;border-radius:20px;font-size:.8rem;font-weight:600;padding:.6rem 1.2rem;transform:scale(.9);transition:all .3s ease}.indicator.active{box-shadow:0 4px 15px #0003;transform:scale(1)}.indicator.left{background:#e74c3c1a;border-color:#e74c3c;color:#e74c3c}.indicator.right{background:#2ecc711a;border-color:#2ecc71;color:#2ecc71}.card-actions{display:flex;flex-shrink:0;gap:1rem;padding:0 1.5rem 1.5rem}.btn-like,.btn-pass{align-items:center;border:none;border-radius:50px;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:700;gap:.5rem;justify-content:center;padding:1rem;transition:all .3s ease}.btn-pass{background:#fff;border:2px solid #e74c3c;color:#e74c3c}.btn-pass:hover{background:#e74c3c;color:#fff;transform:translateY(-2px)}.btn-like{background:#fff;border:2px solid #2ecc71;color:#2ecc71}.btn-like:hover{background:#2ecc71;color:#fff;transform:translateY(-2px)}@keyframes cardAppear{0%{opacity:0;transform:scale(.9) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.user-card{animation:cardAppear .6s ease}.user-card.swipe-left{opacity:0;transform:translateX(-150%) rotate(-30deg);transition:all .5s ease}.user-card.swipe-right{opacity:0;transform:translateX(150%) rotate(30deg);transition:all .5s ease}.subjects-list::-webkit-scrollbar,.user-bio::-webkit-scrollbar{width:4px}.subjects-list::-webkit-scrollbar-track,.user-bio::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.subjects-list::-webkit-scrollbar-thumb,.user-bio::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.subjects-list::-webkit-scrollbar-thumb:hover,.user-bio::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:480px){.user-card{height:550px;margin:0 .5rem}.avatar-placeholder{font-size:2rem;height:80px;width:80px}.user-name{font-size:1.2rem}.card-actions{padding:0 1rem 1rem}.btn-like,.btn-pass{font-size:.9rem;padding:.8rem}.swipe-indicators{align-items:center;flex-direction:column;gap:.5rem}.indicator{text-align:center;width:80%}}.filters-panel{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:1.5rem}.filters-panel h3{color:#2c3e50;font-size:1.2rem}.filter-group,.filters-panel h3{margin-bottom:1rem}.filter-group label{color:#2c3e50;display:block;font-weight:500;margin-bottom:.5rem}.filter-group select{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:.8rem;transition:border-color .3s ease;width:100%}.filter-group select:focus{border-color:#3498db;outline:none}.btn-reset{background:#95a5a6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;padding:.8rem;transition:background .3s ease;width:100%}.btn-reset:hover{background:#7f8c8d}@media (max-width:768px){.filters-panel{padding:1rem}}.mutual-likes-container{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:1.5rem}.mutual-likes-container h3{color:#2c3e50;font-size:1.5rem;margin-bottom:.5rem}.mutual-likes-subtitle{color:#666;font-size:.95rem;margin-bottom:1.5rem}.mutual-likes-error,.mutual-likes-loading,.no-mutual-likes{color:#666;padding:2rem;text-align:center}.mutual-likes-error button{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:1rem;padding:.5rem 1rem}.mutual-likes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.mutual-like-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1.5rem;transition:all .3s ease}.mutual-like-card:hover{box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.mutual-like-header{align-items:center;display:flex;margin-bottom:1rem}.mutual-like-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.2rem;font-weight:700;height:50px;justify-content:center;margin-right:1rem;width:50px}.mutual-like-info h4{color:#2c3e50;font-size:1.1rem;margin:0 0 .3rem}.mutual-like-username{color:#666;font-size:.9rem;margin:0 0 .3rem}.mutual-like-faculty{color:#3498db;font-size:.85rem;font-weight:500;margin:0}.mutual-like-actions{display:flex;gap:.5rem;margin-bottom:1rem}.mutual-like-actions button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-weight:500;padding:.7rem;transition:all .3s ease}.btn-chat{background:#3498db;color:#fff}.btn-chat:hover{background:#2980b9;transform:translateY(-1px)}.btn-session{background:#2ecc71;color:#fff}.btn-session:hover{background:#27ae60;transform:translateY(-1px)}.mutual-like-meta{border-top:1px solid #e9ecef;color:#999;font-size:.8rem;padding-top:.8rem;text-align:center}@media (max-width:768px){.mutual-likes-grid{grid-template-columns:1fr}.mutual-like-actions{flex-direction:column}}.btn-invite{background:#9b59b6;color:#fff}.btn-invite:hover{background:#8e44ad;transform:translateY(-1px)}.matching-page{display:flex;flex-direction:column;margin:0 auto;max-width:500px;min-height:calc(100vh - 140px);padding:1rem}.matching-header{margin-bottom:1.5rem;text-align:center}.matching-header h1{color:#2c3e50;font-size:1.8rem;margin-bottom:.5rem}.matching-header p{color:#666;font-size:1rem}.matching-container{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:650px;position:relative}.cards-stack{height:600px;max-width:400px;position:relative;width:100%}.user-card{bottom:0;left:0;position:absolute;right:0;top:0}.no-users{background:#f8f9fa;border-radius:16px;color:#666;margin:1rem 0;padding:2rem;text-align:center}.no-users h2{color:#2c3e50;margin-bottom:1rem}.no-users button{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;margin-top:1rem;padding:.8rem 1.5rem}.no-users button:hover{background:#2980b9}.loading{color:#666;padding:3rem}.error-message{border-radius:8px;margin-bottom:1rem;text-align:center}.error-message button{background:#fff3;border:1px solid #fff;border-radius:4px;margin-left:10px;padding:.5rem 1rem}.error-message button:hover{background:#ffffff4d}@media (max-width:768px){.matching-page{padding:.5rem}.matching-header h1{font-size:1.5rem}.matching-header p{font-size:.9rem}.matching-container{min-height:600px}.cards-stack{height:550px}}@media (max-width:480px){.matching-header h1{font-size:1.3rem}.cards-stack{height:500px}}.profile-page{margin:0 auto;max-width:800px;padding:2rem}.profile-header{margin-bottom:2rem;text-align:center}.profile-header h1{color:#2c3e50;margin-bottom:1.5rem}.profile-tabs{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem}.tab{background:#fff;border:2px solid #e0e0e0;padding:1rem 2rem}.tab.active{border-color:#3498db}.tab:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.message{border-radius:8px;font-weight:500;margin-bottom:2rem;padding:1rem;text-align:center}.message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.profile-edit{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.form-section{border-bottom:1px solid #f0f0f0;margin-bottom:2.5rem;padding-bottom:2rem}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1.5rem}.form-group label{margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{font-family:inherit;transition:border-color .3s ease}.form-group textarea{min-height:120px}.char-count{color:#666;font-size:.8rem;margin-top:.5rem;text-align:right}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:1.2rem;transition:all .3s ease;width:100%}.save-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea4d;transform:translateY(-2px)}.save-btn:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}.profile-view{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.profile-card{align-items:flex-start;display:flex;gap:2rem}.profile-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:3rem;font-weight:700;height:120px;justify-content:center;width:120px}.profile-info{flex:1 1}.profile-info h2{color:#2c3e50;font-size:2rem;margin-bottom:.5rem}.username{color:#666;font-size:1.1rem;margin-bottom:2rem}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.info-item{background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:1rem}.info-item .label{color:#2c3e50;font-weight:600}.info-item .value{color:#666}.bio-section{background:#f8f9fa;border-radius:8px;padding:1.5rem}.bio-section h4{color:#2c3e50;margin-bottom:1rem}.bio-section p{color:#666;font-style:italic;line-height:1.6}@media (max-width:768px){.profile-page{padding:1rem}.profile-tabs{flex-direction:column}.form-row{gap:0;grid-template-columns:1fr}.profile-card{flex-direction:column;text-align:center}.profile-avatar{align-self:center}.info-grid{grid-template-columns:1fr}.info-item{flex-direction:column;gap:.5rem;text-align:center}}.subjects-management{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.add-subject-form{border-bottom:1px solid #f0f0f0;margin-bottom:2.5rem;padding-bottom:2rem}.add-subject-form h3{color:#2c3e50;margin-bottom:1.5rem}.subject-form .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1fr;margin-bottom:1rem}.add-btn{background:#27ae60;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:1rem 2rem;transition:all .3s ease}.add-btn:hover{background:#219653;transform:translateY(-2px)}.user-subjects-list h3{color:#2c3e50;margin-bottom:1.5rem}.no-subjects{background:#f8f9fa;border-radius:8px;color:#666;padding:3rem;text-align:center}.subjects-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.subject-card{align-items:center;background:#f8f9fa;border-left:4px solid #3498db;border-radius:8px;display:flex;justify-content:space-between;padding:1.5rem}.subject-info h4{color:#2c3e50;margin:0 0 .5rem}.level-badge{border-radius:20px;font-size:.8rem;font-weight:500;padding:.3rem .8rem}.level-badge.beginner{background:#e8f5e8;color:#27ae60}.level-badge.intermediate{background:#e3f2fd;color:#1976d2}.level-badge.advanced{background:#f3e5f5;color:#7b1fa2}.remove-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:.5rem;transition:background .3s ease}.remove-btn:hover{background:#e74c3c1a}.subjects-section{margin-top:2rem}.subjects-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.subject-tag{background:#e3f2fd;border:1px solid #bbdefb;border-radius:20px;color:#1976d2;font-size:.9rem;padding:.5rem 1rem}@media (max-width:768px){.subject-form .form-row,.subjects-grid{grid-template-columns:1fr}.subject-card{flex-direction:column;gap:1rem;text-align:center}.subjects-tags{justify-content:center}}.message-list{background:#f8f9fa;display:flex;flex:1 1;flex-direction:column;gap:15px;overflow-y:auto;padding:20px 30px}.no-messages p{font-size:1.2rem;margin:0 0 8px}.no-messages small{font-size:1rem}.message-group{display:flex;flex-direction:column;gap:5px}.message{animation:messageSlideIn .3s ease-out;gap:12px}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.message.own{flex-direction:row-reverse}.message-content-wrapper{display:flex;flex-direction:column;gap:5px}.message-sender-name{color:#718096;font-size:.8rem;font-weight:500;margin-bottom:4px}.message.own .message-sender-name{text-align:right}.message-content{position:relative}.message.own .message-content{background:linear-gradient(135deg,#667eea,#764ba2)}.message-text{font-size:.95rem}.message-time{align-items:center;display:flex;gap:5px}.read-status{color:#48bb78;font-size:.8rem}.message-sender-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:35px;justify-content:center;margin-top:auto;width:35px}.message.own .message-sender-avatar{background:#e2e8f0;color:#718096}.date-separator{margin:20px 0;position:relative;text-align:center}.date-separator:before{background:#e2e8f0;content:"";height:1px;left:0;position:absolute;right:0;top:50%;z-index:1}.date-separator span{background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#718096;font-size:.8rem;font-weight:500;padding:8px 16px;position:relative;z-index:2}.message-list::-webkit-scrollbar{width:6px}.message-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.message-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.message-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.enhanced-message-input{border:1px solid #ddd;border-radius:8px;margin:10px 0;padding:10px}.enhanced-message-input textarea{border:none;min-height:60px;outline:none;resize:none;width:100%}.enhanced-message-input-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}.chat-page{background:#f8f9fa;height:calc(100vh - 70px);margin:0;overflow:hidden;padding:0}.chat-container{background:#fff;box-shadow:none;display:flex;height:100%;margin:0;max-width:100%}.chat-sidebar{background:#fff;border-right:1px solid #e9ecef;display:flex;flex-direction:column;flex-shrink:0;width:350px}.sidebar-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;flex-shrink:0;justify-content:space-between;padding:20px}.sidebar-header h2{color:#2d3748;font-size:1.5rem;margin:0}.new-chat-btn{background:#667eea;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.2rem;height:40px;transition:all .3s ease;width:40px}.new-chat-btn:hover{background:#5a67d8;transform:scale(1.1)}.chat-list{background:#fff;flex:1 1;overflow-y:auto;padding:10px}.loading,.no-chats{background:#fff;color:#718096;padding:40px 20px}.no-chats{text-align:center}.no-chats-icon{font-size:3rem;margin-bottom:15px;opacity:.5}.chat-item{align-items:center;background:#fff;border:1px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:15px;margin-bottom:8px;padding:15px}.chat-item:hover{background:#f7fafc;border-color:#e2e8f0}.chat-item.active{background:#667eea;border-color:#667eea;color:#fff}.chat-avatar{align-items:center;background:#667eea;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:50px;justify-content:center;width:50px}.chat-item.active .chat-avatar{background:#fff;color:#667eea}.chat-info{flex:1 1;min-width:0}.chat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.chat-header strong{color:inherit;font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{background:#e53e3e;border-radius:10px;color:#fff;flex-shrink:0;font-size:.7rem;font-weight:700;padding:2px 8px}.last-message{color:#718096;font-size:.9rem;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item.active .last-message{color:#fffc}.chat-meta{color:#a0aec0;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item.active .chat-meta{color:#ffffffb3}.chat-main{background:#fff;display:flex;flex:1 1;flex-direction:column;min-width:0}.chat-header{background:#fff;border-bottom:1px solid #e9ecef;flex-shrink:0;padding:20px 30px}.chat-partner{gap:15px}.chat-partner,.partner-avatar{align-items:center;display:flex}.partner-avatar{background:#667eea;border-radius:50%;color:#fff;flex-shrink:0;font-size:1.2rem;font-weight:700;height:50px;justify-content:center;width:50px}.partner-info{min-width:0}.partner-info h3{color:#2d3748;font-size:1.3rem;margin:0 0 5px}.partner-info h3,.partner-info span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.partner-info span{color:#718096;font-size:.9rem}.messages-container{background:#f8f9fa;display:flex;flex:1 1;flex-direction:column;gap:15px;overflow-y:auto;padding:20px 30px}.no-messages{background:#f8f9fa;color:#718096;padding:60px 20px;text-align:center}.no-messages-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.message{display:flex;max-width:70%}.message.own{align-self:flex-end}.message.own .message-content{background:#667eea;color:#fff}.message-content{word-wrap:break-word;background:#fff;border-radius:18px;box-shadow:0 2px 8px #0000001a;max-width:100%;padding:12px 16px}.message-text{line-height:1.4;margin:0;word-break:break-word}.message-time{color:#a0aec0;font-size:.75rem;margin-top:4px;text-align:right}.message.own .message-time{color:#fffc}.message-input-container{background:#fff;border-top:1px solid #e9ecef;flex-shrink:0;padding:20px 30px}.input-wrapper{align-items:flex-end;display:flex;gap:12px}.message-input{background:#fff;border:1px solid #e2e8f0;border-radius:25px;flex:1 1;font-family:inherit;font-size:1rem;max-height:120px;min-height:44px;outline:none;padding:12px 20px;resize:none}.message-input:focus{border-color:#667eea}.send-btn{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.1rem;height:45px;justify-content:center;transition:all .3s ease;width:45px}.send-btn:disabled{background:#cbd5e0}.send-btn:not(:disabled):hover{background:#5a67d8;transform:scale(1.1)}.chat-welcome{align-items:center;background:#f8f9fa;display:flex;flex:1 1;justify-content:center;padding:20px}.welcome-content{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:40px;text-align:center}.welcome-icon{font-size:4rem;margin-bottom:20px}.welcome-content h2{color:#2d3748;font-size:2rem;margin-bottom:15px}.welcome-content p{color:#718096;font-size:1.1rem;margin-bottom:30px}.find-partners-btn{background:#667eea;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 24px;transition:all .3s ease}.find-partners-btn:hover{background:#5a67d8;transform:translateY(-2px)}.auth-required{padding:20px}.login-btn{border-radius:25px}.chat-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-thumb,.chat-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-track{border-radius:3px}@media (max-width:768px){.chat-container{flex-direction:column}.chat-sidebar{height:40vh;width:100%}.chat-main{height:60vh}.message{max-width:85%}.chat-header,.message-input-container,.messages-container,.sidebar-header{padding:15px 20px}}@media (max-width:480px){.chat-sidebar{height:35vh}.chat-main{height:65vh}.sidebar-header h2{font-size:1.2rem}.partner-info h3{font-size:1.1rem}.message{max-width:90%}.welcome-content{margin:10px;padding:20px}.welcome-content h2{font-size:1.5rem}}.sending-indicator{color:#a0aec0;font-size:.7rem;margin-left:8px}.message.own .sending-indicator{color:#ffffffb3}.chat-item{transition:all .3s ease}.message{animation:fadeIn .3s ease}.message-input:disabled{background-color:#f7fafc;cursor:not-allowed}.chat-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:8px}.chat-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.chat-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.chat-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover{background:#a0aec0}.app,.main-content,body{margin:0;padding:0}.connection-status{align-items:center;display:flex;gap:8px}.status-indicator{font-size:.8rem}.status-indicator.connected{color:#22c55e}.status-indicator.disconnected{color:#ef4444}.sending-indicator{align-items:center;background:#f3f4f6;border-radius:6px;color:#6b7280;display:flex;font-size:.8rem;gap:8px;margin-top:10px;padding:8px 12px}.sending-spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}.message.sending .message-content{background:#f3f4f6;opacity:.7}.message.sending.own .message-content{background:#a5b4fc}.emoji-btn:disabled,.quick-reply-btn:disabled,.send-btn:disabled,.session-options-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.connection-status,.sending-indicator{font-size:.7rem}}.session-card{background:#fff;border:1px solid #f0f0f0;border-radius:12px;box-shadow:0 4px 15px #0000001a;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.session-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.session-card.past{background:#f8f9fa;opacity:.7}.session-card.past:before{background:#95a5a6;color:#fff;content:"Завершена";font-size:.7rem;font-weight:700;padding:.3rem 2rem;position:absolute;right:-25px;top:10px;transform:rotate(45deg)}.session-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.session-title{color:#2c3e50;flex:1 1;font-size:1.3rem;line-height:1.3;margin:0}.session-subject{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;flex-shrink:0;font-size:.8rem;font-weight:700;padding:.3rem .8rem;white-space:nowrap}.session-description{font-style:italic;margin-bottom:1.5rem}.session-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column}.detail-label{color:#666;font-size:.8rem;font-weight:500;margin-bottom:.3rem}.detail-value{color:#2c3e50;font-size:.9rem;font-weight:700}.participants-preview{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:.8rem;margin:1.5rem 0;padding:1rem}.participants-label{color:#666;font-size:.9rem;font-weight:500;white-space:nowrap}.participants-avatars{display:flex;flex-wrap:wrap;gap:.5rem}.participant-avatar{background:linear-gradient(135deg,#3498db,#2c3e50);box-shadow:0 2px 4px #0000001a;font-size:.8rem}.more-participants,.participant-avatar{align-items:center;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-weight:700;height:32px;justify-content:center;width:32px}.more-participants{background:#bdc3c7;font-size:.7rem}.session-actions{margin-top:1rem}.action-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;letter-spacing:.5px;padding:.9rem;text-transform:uppercase;transition:all .3s ease;width:100%}.action-btn.join{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff}.action-btn.join:hover:not(:disabled){box-shadow:0 4px 12px #2ecc714d;transform:translateY(-2px)}.action-btn.leave{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.action-btn.leave:hover:not(:disabled){box-shadow:0 4px 12px #e74c3c4d;transform:translateY(-2px)}.action-btn.delete{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.action-btn.delete:hover:not(:disabled){box-shadow:0 4px 12px #e74c3c4d;transform:translateY(-2px)}.action-btn.disabled{background:#bdc3c7;box-shadow:none!important;color:#fff;cursor:not-allowed;transform:none!important}.session-form-modal{animation:modalAppear .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;padding:2.5rem;width:100%}@keyframes modalAppear{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.session-form-modal h2{color:#2c3e50;font-size:1.8rem;font-weight:600;margin-bottom:2rem;text-align:center}.form-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.form-group{margin-bottom:1.5rem}.form-group label{color:#2c3e50;display:block;font-size:.95rem;font-weight:600;margin-bottom:.7rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:1rem;transition:all .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.form-group textarea{font-family:inherit;min-height:80px;resize:vertical}.form-actions{border-top:1px solid #e0e0e0;display:flex;gap:1rem;margin-top:2.5rem;padding-top:1.5rem}.btn-cancel{background:#95a5a6;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:1.2rem;transition:all .3s ease}.btn-cancel:hover:not(:disabled){background:#7f8c8d;transform:translateY(-2px)}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:1.2rem;transition:all .3s ease}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-submit:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed;transform:none}@media (max-width:768px){.session-card{padding:1.2rem}.session-header{flex-direction:column;gap:.8rem}.session-details{gap:.8rem;grid-template-columns:1fr}.form-row{gap:0;grid-template-columns:1fr}.session-form-modal{margin:1rem;padding:1.5rem}.participants-preview{align-items:flex-start;flex-direction:column;gap:.8rem}.participants-avatars{justify-content:center;width:100%}}@media (max-width:480px){.session-card{padding:1rem}.session-title{font-size:1.1rem}.action-btn{font-size:.9rem}.action-btn,.form-group input,.form-group select,.form-group textarea{padding:.8rem}.form-actions{flex-direction:column}}.creator-badge{background:linear-gradient(135deg,#f39c12,#e67e22);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;margin-top:.5rem;padding:.5rem 1rem;text-align:center}.session-actions{display:flex;flex-direction:column;gap:.5rem}.no-invitations{background:#f8f9fa;border-radius:12px;color:#666;padding:3rem;text-align:center}.no-invitations h3{color:#2c3e50;margin-bottom:1rem}.action-btn.invite{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff}.action-btn.invite:hover{background:linear-gradient(135deg,#8e44ad,#7d3c98);transform:translateY(-2px)}.invitations-subtitle{color:#666;font-size:.95rem;margin-bottom:1.5rem}.no-invitations-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.response-date{color:#666;display:block;font-size:.8rem;margin-top:.3rem}.session-invitations{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:1.5rem}.session-invitations h3{color:#2c3e50;font-size:1.5rem;margin-bottom:1.5rem}.invitations-loading,.no-invitations{color:#666;padding:2rem;text-align:center}.invitations-error{background:#ffeaa7;border-radius:8px;margin-bottom:1rem;padding:1rem;text-align:center}.invitations-error button{background:#e17055;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:.5rem;padding:.5rem 1rem}.invitations-list{display:flex;flex-direction:column;gap:1rem}.invitation-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:1.5rem;transition:all .3s ease}.invitation-card:hover{box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.invitation-card.accepted{background:#f1fcf9;border-color:#00b894}.invitation-card.declined{background:#fff5f5;border-color:#e17055}.invitation-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.inviter-info{gap:1rem}.inviter-avatar,.inviter-info{align-items:center;display:flex}.inviter-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:1rem;font-weight:700;height:40px;justify-content:center;width:40px}.inviter-details h4{color:#2c3e50;margin:0 0 .3rem}.invitation-date{color:#666;font-size:.85rem}.invitation-status{border-radius:20px;font-size:.8rem;font-weight:500;padding:.3rem .8rem}.invitation-status.pending{background:#fff3cd;color:#856404}.invitation-status.accepted{background:#d1ecf1;color:#0c5460}.invitation-status.declined{background:#f8d7da;color:#721c24}.session-details{margin-bottom:1rem}.session-details h5{color:#2c3e50;font-size:1.1rem;margin:0 0 .5rem}.session-description{color:#666;line-height:1.5;margin:0 0 1rem}.session-meta{display:flex;flex-wrap:wrap;gap:1rem}.session-meta span{border-radius:15px;padding:.3rem .8rem}.invitation-actions{display:flex;gap:.5rem}.btn-accept,.btn-decline{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-weight:500;padding:.7rem;transition:all .3s ease}.btn-accept{background:#00b894;color:#fff}.btn-accept:hover{background:#00a885;transform:translateY(-1px)}.btn-decline{background:#e17055;color:#fff}.btn-decline:hover{background:#d15b40;transform:translateY(-1px)}.invitation-response{background:#fff;border-radius:6px;color:#666;padding:.5rem;text-align:center}@media (max-width:768px){.invitation-header{gap:1rem}.invitation-actions,.invitation-header,.session-meta{flex-direction:column}.session-meta{gap:.5rem}}.info-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;margin-bottom:1rem;padding:1rem;text-align:center}.invitations-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.refresh-btn{background:none;border:none;border-radius:50%;cursor:pointer;font-size:1.2rem;padding:.5rem;transition:all .3s ease}.refresh-btn:hover{background:#f0f0f0;transform:rotate(180deg)}.invitations-stats{display:flex;gap:1rem;margin-bottom:2rem}.stats-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;flex:1 1;padding:1.5rem;text-align:center}.stats-number{color:#3498db;display:block;font-size:2rem;font-weight:700;margin-bottom:.5rem}.inviter-username,.stats-label{color:#666;font-size:.9rem}.inviter-username{font-weight:400;margin-left:.5rem}.inviter-faculty{color:#666;font-size:.9rem;margin:.3rem 0}.demo-tips{background:#f8f9fa;border-radius:8px;margin-top:1.5rem;padding:1.5rem;text-align:left}.demo-tips h5{color:#2c3e50;margin-bottom:1rem}.demo-tips ul{margin:0;padding-left:1.5rem}.demo-tips li{color:#666;margin-bottom:.5rem}.session-meta{grid-gap:.8rem;display:grid;gap:.8rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem}.session-meta span{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:8px;color:#555;display:flex;font-size:.8rem;gap:.3rem;padding:.5rem .8rem}@media (max-width:768px){.invitations-stats{flex-direction:column}.session-meta{grid-template-columns:1fr}}.session-card-skeleton{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:1rem;padding:1.5rem}.skeleton-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.skeleton-tag{border-radius:12px;height:24px;width:80px}.skeleton-description,.skeleton-details{margin-bottom:1.5rem}.skeleton-details{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.skeleton-detail{display:flex;justify-content:space-between}.skeleton-actions{display:flex;gap:1rem}.skeleton-button{border-radius:8px;flex:1 1;height:44px}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.loading-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffffff2;bottom:0;left:0;position:fixed;right:0;top:0;z-index:9999}.spinner{display:inline-block;position:relative}.spinner-circle{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#3498db}.spinner-small .spinner-circle{border-width:2px;height:20px;width:20px}.spinner-medium .spinner-circle{border-width:3px;height:40px;width:40px}.spinner-large .spinner-circle{border-width:4px;height:60px;width:60px}.loading-text{color:#666;font-size:1rem;margin-top:1rem}.inline-loader{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.skeleton{animation:loading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:4px}.skeleton-text{height:1rem;margin-bottom:.5rem}.skeleton-title{height:1.5rem;margin-bottom:1rem;width:70%}.skeleton-avatar{border-radius:50%;height:50px;width:50px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.sessions-tabs{border-bottom:1px solid #e0e0e0;display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1rem}.tab{background:#f8f9fa;border:none;border-radius:8px;cursor:pointer;font-size:1rem;padding:.8rem 1.5rem;transition:all .3s ease}.tab.active{background:#3498db;color:#fff}.tab:hover:not(.active){background:#e9ecef}.no-sessions{background:#f8f9fa;border-radius:12px;color:#666;padding:3rem;text-align:center}.no-sessions h3{color:#2c3e50;margin-bottom:1rem}.App{background:#f8f9fa;display:flex;flex-direction:column;margin:0;min-height:100vh;padding:0}.error-message{align-items:center;background:#e74c3c;border-radius:6px;color:#fff;display:flex;justify-content:space-between;margin:1rem 0;padding:1rem}.error-message button{background:none;border:none;color:#fff;cursor:pointer;font-size:1.2rem}.success-message{background:#2ecc71;border-radius:6px;color:#fff;margin:1rem 0;padding:1rem;text-align:center}.loading{padding:2rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin:0 auto 1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.auth-required,.not-found{color:#666;padding:3rem}.hero,.not-found{text-align:center}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-bottom:3rem;padding:4rem 2rem}.hero h1{font-size:3rem;font-weight:700;line-height:1.2;margin-bottom:1rem}.hero p{font-size:1.3rem;line-height:1.5;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px;opacity:.9}.guest-actions,.user-welcome{margin-top:2rem}.user-welcome h2{font-size:1.8rem;margin-bottom:1.5rem}.action-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.features{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px;padding:0 2rem 3rem}.feature{background:#fff;border-radius:12px;box-shadow:0 5px 20px #0000001a;padding:2.5rem 2rem;text-align:center;transition:transform .3s ease}.feature:hover{transform:translateY(-5px)}.feature-icon{margin-bottom:1.5rem}.feature h3{color:#2c3e50;font-size:1.4rem;font-weight:600;margin-bottom:1rem}.feature p{color:#666;font-size:1rem;line-height:1.6}@media (max-width:768px){.hero{padding:3rem 1rem}.hero h1{font-size:2.2rem}.hero p{font-size:1.1rem}.features{gap:1.5rem;grid-template-columns:1fr;padding:0 1rem 2rem}.feature{padding:2rem 1.5rem}.action-buttons{align-items:center;flex-direction:column}.action-buttons .btn{width:200px}}@media (max-width:480px){.hero h1{font-size:1.8rem}.hero p{font-size:1rem}.feature{padding:1.5rem 1rem}.feature-icon{font-size:2.5rem}}.static-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:calc(100vh - 140px);padding:2rem 0}.static-container{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;margin:0 auto;max-width:800px;overflow:hidden}.static-container h1{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:2.5rem;margin:0;padding:2rem;text-align:center}.static-content{padding:2rem}.about-hero{margin-bottom:3rem;text-align:center}.about-hero h2{color:#2c3e50;font-size:1.8rem;margin-bottom:1rem}.about-hero p{color:#666;font-size:1.1rem;line-height:1.6}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:2rem}.feature-card{background:#f8f9fa;border-radius:12px;padding:2rem 1.5rem;text-align:center;transition:transform .3s ease}.feature-card:hover{transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2c3e50;margin-bottom:1rem}.feature-card p{color:#666;line-height:1.5}.privacy-section{margin-bottom:2rem}.privacy-section h2{color:#2c3e50;margin-bottom:1rem}.privacy-section h3{color:#34495e;margin:1.5rem 0 1rem}.privacy-section ul{color:#666;line-height:1.6;padding-left:1.5rem}.privacy-section li{margin-bottom:.5rem}.contact-info{text-align:center}.contact-methods{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.contact-method{align-items:center;background:#f8f9fa;border-radius:12px;display:flex;gap:1rem;padding:1.5rem;text-align:left}.contact-icon{flex-shrink:0;font-size:2.5rem}.contact-details h3{color:#2c3e50;margin-bottom:.5rem}.contact-details p{color:#666;margin:0}@media (max-width:768px){.static-page{padding:1rem}.static-container{border-radius:15px}.static-container h1{font-size:2rem;padding:1.5rem}.static-content{padding:1.5rem}.contact-method{flex-direction:column;text-align:center}}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;color:#2c3e50;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6}#root{min-height:100vh}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-family:inherit;font-size:1rem;font-weight:500;padding:12px 24px;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.btn-secondary{background:#95a5a6;color:#fff}.btn-secondary:hover{background:#7f8c8d;transform:translateY(-2px)}.auth-required,.chat-loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;height:100vh;justify-content:center}.auth-required{flex-direction:column;text-align:center}.auth-required h2{font-size:2rem;margin-bottom:20px}.login-btn{background:#fff;border:none;border-radius:12px;color:#667eea;cursor:pointer;font-size:1.1rem;font-weight:500;padding:12px 30px;transition:all .3s ease}.login-btn:hover{box-shadow:0 10px 20px #fff3;transform:translateY(-2px)}*{transition:background-color .2s ease,border-color .2s ease}button:focus{box-shadow:0 0 0 3px #667eea4d;outline:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-in}@media (max-width:768px){.container{padding:0 .5rem}.header-container{padding:0 1rem}.logo-text{font-size:1.2rem}.user-card{margin:0 .5rem}.user-info{padding:0 1rem 1rem}.card-actions{padding:1rem 1rem 2rem}.chat-container{flex-direction:column;height:calc(100vh - 60px)}.chat-list{height:40%;width:100%}.chat-main{height:60%}.auth-form{margin:0 .5rem}.action-buttons{flex-direction:column}.btn{margin-bottom:.5rem;width:100%}}@media (max-width:480px){.hero h1{font-size:1.8rem}.hero p{font-size:1rem}.feature,.session-card{padding:1rem}.message-input textarea{font-size:16px}}@media (max-width:768px) and (orientation:portrait){.chat-page{height:calc(100vh - 60px)}}@media (max-width:768px) and (orientation:landscape){.header{position:static}.chat-container{height:calc(100vh - 60px)}}@media (max-width:1024px){.container{max-width:100%;padding:0 1.5rem}.features,.sessions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.container{padding:0 1rem}.features{gap:1.5rem}.features,.recommendations-grid,.sessions-grid{grid-template-columns:1fr}body{-webkit-text-size-adjust:100%;font-size:16px}.btn,.nav-link,button{min-height:44px;min-width:44px}input,select,textarea{font-size:16px}}@media (max-width:480px){.container{padding:0 .8rem}.hero h1{font-size:1.8rem;line-height:1.2}.hero p{font-size:1rem;line-height:1.4}.recommendation-card,.session-card,.user-card{margin:0 .2rem}.chat-header,.chat-list-header,.page-header{padding:1rem}.info-grid{grid-template-columns:1fr}.nav-desktop{gap:.5rem}.nav-link{font-size:.9rem;padding:.5rem .8rem}}@media (max-width:360px){.container{padding:0 .5rem}.hero{padding:2rem 1rem}.hero h1{font-size:1.6rem}.btn{font-size:.9rem;padding:.7rem 1.2rem}.chat-item,.session-card,.user-info{padding:.8rem}}@media (max-height:500px) and (orientation:landscape){.chat-page{height:calc(100vh - 50px)}.hero{padding:1.5rem 1rem}.auth-container{padding:1rem}}@media (prefers-color-scheme:dark){:root{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--text-primary:#fff;--text-secondary:#b0b0b0;--border-color:#404040}}@media print{.action-btn,.btn,.footer,.header,.message-input{display:none!important}.chat-container,.session-card,.user-card{border:1px solid #000!important;box-shadow:none!important}body{background:#fff!important;color:#000!important}}@media (prefers-reduced-motion:no-preference){.fade-in{animation:fadeIn .5s ease-in}.slide-up{animation:slideUp .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.chat-avatar,.logo-icon,.participant-avatar{image-rendering:-webkit-optimize-contrast}}@media (min-width:1600px){.container{max-width:1400px}.features,.sessions-grid{grid-template-columns:repeat(4,1fr)}}
/*# sourceMappingURL=main.756c25fd.css.map*/