:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}a{font-weight:500;color:#646cff;text-decoration:inherit;transition:color .2s}a:hover{color:#535bf2}.landing{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#333}.hero{background:linear-gradient(135deg,#667eea,#764ba2);min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;padding:2rem}.hero-content h1{font-size:3.5rem;margin-bottom:1rem;font-weight:800}.hero-content p{font-size:1.3rem;margin-bottom:2rem;opacity:.9}.login-box{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;border-radius:12px;max-width:400px;margin:0 auto;border:1px solid rgba(255,255,255,.2)}.login-box h3{margin-bottom:1.5rem;font-size:1.3rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form input{padding:12px;border:none;border-radius:6px;font-size:1rem;background:#ffffffe6}.login-form input:focus{outline:none;background:#fff}.login-btn{padding:12px;border:none;border-radius:6px;background:#ff6b6b;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.login-btn:hover{background:#ff5252;transform:translateY(-2px)}.error-message{color:#ff6b6b;margin:1rem 0;background:#ffffff1a;padding:.5rem;border-radius:4px}.signup-link{margin-top:1rem}.signup-link a{color:gold;text-decoration:none;font-weight:600}.signup-link a:hover{text-decoration:underline}.section{padding:4rem 2rem;text-align:center}.section.dark{background:#f8f9fa}.section h2{font-size:2.5rem;margin-bottom:3rem;color:#2d3748}.hotspots{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:900px;margin:0 auto}.spot{padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease}.spot:hover{transform:translateY(-5px)}.emoji{font-size:2.5rem;display:block;margin-bottom:1rem}.spot h3{margin-bottom:.5rem;color:#2d3748}.spot p{color:#718096}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;max-width:800px;margin:0 auto}.step{padding:1.5rem}.number{width:50px;height:50px;background:#667eea;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 1rem}footer{background:#2d3748;color:#fff;text-align:center;padding:2rem;margin-top:2rem}@media(max-width:768px){.hero-content h1{font-size:2.5rem}.hero-content p{font-size:1.1rem}.login-box{margin:0 1rem;padding:1.5rem}.section{padding:3rem 1rem}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#2d2d2d;padding:30px;border-radius:12px;border:1px solid #555;width:90%;max-width:600px;box-shadow:0 5px 15px #00000080;z-index:1001}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.create-button-full{background-color:#535bf2;color:#fff;border:none}.create-button-full:hover{background-color:#434cde}.auth-page-container{display:flex;justify-content:center;align-items:center;min-height:90vh;padding:20px}.auth-form-wrapper{background-color:#2d2d2d;padding:40px;border-radius:12px;border:1px solid #555;width:100%;max-width:600px;box-shadow:0 8px 25px #0006}.auth-form-wrapper h2{text-align:center;margin-bottom:30px;color:#fff;border-bottom:1px solid #555;padding-bottom:15px}.auth-form-wrapper .session-form-detailed{gap:20px 25px}.profile-pic-upload{align-items:center;border-bottom:1px solid #444;padding-bottom:20px}.file-input{border:none;padding:0;color:#ccc}.file-input::file-selector-button{margin-right:15px;border:none;padding:8px 12px;border-radius:4px;background-color:#555;color:#fff;cursor:pointer;transition:background-color .2s}.file-input::file-selector-button:hover{background-color:#777}.auth-switch-link{text-align:center;margin-top:25px;font-size:.9rem;color:#aaa}.auth-switch-link a{color:#646cff;text-decoration:none}.auth-switch-link a:hover{text-decoration:underline}h2{font-size:2.5rem;margin-top:0;border-bottom:1px solid #444;padding-bottom:10px}h3{margin:0;font-size:1.25rem}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}input{font-family:inherit;font-size:1em;border-radius:8px;border:1px solid #555;padding:.6em 1.2em;background-color:#2a2a2a;color:#fff}.home-layout{display:flex;flex-direction:row;padding:30px;gap:30px}.session-list-container{flex:1;max-width:700px}.map-placeholder{flex:1.5;background-color:#1a1a1a;border:1px solid #444;border-radius:12px;padding:20px;min-height:80vh;box-sizing:border-box}.session-form{display:flex;margin-bottom:25px;gap:10px}.session-form input{flex-grow:1;padding:12px;font-size:1rem;border:1px solid #444;background-color:#222;color:#fff;border-radius:6px}.session-form button{padding:0 20px;font-size:1rem;border:none;background-color:#007aff;color:#fff;cursor:pointer;border-radius:6px;transition:background-color .2s}.session-form button:hover{background-color:#0056b3}.session-items{display:flex;flex-direction:column;gap:15px}.session-item{display:none}.session-container{max-width:800px;margin:0 auto;padding:20px}.chat-box{border:1px solid #444;background-color:#2a2a2a;height:400px;overflow-y:auto;padding:10px;border-radius:8px;margin-bottom:15px}.chat-message{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:10px}.chat-sender{font-size:.8rem;color:#aaa;margin-bottom:2px}.chat-message p{margin:0;padding:8px 12px;background-color:#333;border-radius:10px;display:inline-block}.chat-message small{color:#999;margin-left:10px;font-size:.75rem}.chat-form{display:flex;gap:10px}.chat-form input{flex-grow:1}.chat-form button{background-color:#007aff;color:#fff;border:none}.chat-form button:hover{background-color:#0056b3}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:15px;overflow-y:auto}.modal-content{background:#2d2d2d;padding:30px;border-radius:12px;border:1px solid #555;width:100%;max-width:650px;max-height:flex;box-shadow:0 5px 15px #00000080;z-index:1001}.modal-content h2{margin-top:0;border-bottom:1px solid #555;padding-bottom:15px;color:#fff;font-weight:600}.modal-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:25px}.modal-actions.full-width{grid-column:1 / -1;border-top:1px solid #444;padding-top:20px;margin-top:10px}.button-secondary{background-color:#555;color:#fff;border:none}.modal-error{color:#ff6b6b;font-size:.9rem;margin-top:15px}.session-details-content{max-height:40vh;overflow-y:auto;padding-right:10px}.session-description-modal{background-color:#222;padding:15px;border-radius:8px;white-space:pre-wrap}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #444}.home-header>div{display:flex;gap:15px;align-items:center}.button-secondary{background-color:#555;color:#fff;border:none;padding:8px 16px;border-radius:6px;transition:background-color .2s}.button-secondary:hover{background-color:#777}.sign-out-button{background-color:#d9534f;color:#fff;border:none}.sign-out-button:hover{background-color:#c9302c;border-color:#ac2525}.session-item-condensed{display:flex;justify-content:space-between;align-items:center;background-color:#282828;padding:20px;border-radius:12px;border:1px solid #444;transition:all .2s ease}.session-item-condensed:hover{border-color:#646cff;transform:translateY(-2px);box-shadow:0 4px 10px #0003}.session-item-condensed h3{margin:0 0 5px}.session-item-condensed p{margin:0;color:#aaa}.session-item-condensed .session-time-start{font-size:.9rem;color:#ccc;margin-top:5px}.session-form-detailed{display:grid;grid-template-columns:1fr 1fr;gap:15px 20px}.form-group{display:flex;flex-direction:column;gap:5px;align-items:flex-start}.form-group label{font-weight:500;font-size:.9rem;color:#ccc;align-self:flex-start;margin-bottom:0}.form-group>:is(input,select,textarea){margin-top:0;align-self:stretch}.form-help-text{margin-top:5px;align-self:flex-start}.form-group.full-width{grid-column:1 / -1}.form-group.half-width{grid-column:auto}.session-form-detailed label{font-weight:500;font-size:.9rem;color:#ccc}.session-form-detailed input,.session-form-detailed textarea,.session-form-detailed select{width:100%;padding:12px;font-size:1rem;border:1px solid #444;background-color:#222;color:#fff;border-radius:6px;box-sizing:border-box}.session-form-detailed textarea{min-height:90px}.end-session-button{float:right;background-color:#d9534f;color:#fff;border:none}.end-session-button:hover{background-color:#c9302c}.join-button{background-color:#34c759;color:#fff;text-decoration:none;padding:8px 16px;border-radius:5px;font-weight:500;transition:background-color .2s}.join-button:hover{background-color:#28a745}.chat-message-with-pic{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}.chat-profile-pic{width:40px;height:40px;border-radius:50%;object-fit:cover;margin-top:2px}.chat-message{display:flex;flex-direction:column;align-items:flex-start}.chat-sender{font-size:.8rem;color:#aaa;margin-bottom:2px;font-weight:600}.chat-message p{margin-top:0}.chat-sender.clickable{cursor:pointer;text-decoration:underline;text-decoration-color:#888}.chat-sender.clickable:hover{text-decoration-color:#fff}.user-profile-modal .profile-details{display:flex;flex-direction:column;gap:15px}.user-profile-modal .profile-details p{margin:0;display:flex;justify-content:space-between}.user-profile-modal .profile-details p span{color:#ccc;font-weight:500;text-align:right}.user-profile-modal .profile-courses-list{margin:0;padding-left:20px}.user-profile-modal .profile-courses-list li{color:#ccc;margin-bottom:5px}.profile-pic-preview{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid #555;margin-bottom:10px}.map-wrapper{position:relative;width:600px;height:400px}.map-loading-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;font-weight:500;border-radius:8px;z-index:10}.session-location{margin:0;color:#ccc;font-size:.95rem}.session-location-details{margin:0 0 5px;color:#aaa;font-size:.85rem}.user-profile-modal{max-width:450px!important;text-align:center;padding:30px 40px}.profile-modal-pic{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid #646cff;margin-bottom:20px;display:block;margin-left:auto;margin-right:auto}.user-profile-modal h2{font-size:1.8rem;margin-bottom:20px;color:#fff;border-bottom:1px solid #444;padding-bottom:15px}.profile-details-grid{display:grid;grid-template-columns:1fr;gap:20px;text-align:left;margin-bottom:25px}.profile-detail-item{display:flex;flex-direction:column;background-color:#333;padding:15px;border-radius:8px;border:1px solid #444}.profile-detail-item strong{color:#646cff;font-weight:700;font-size:.9rem;margin-bottom:5px;text-transform:uppercase}.profile-detail-item span,.profile-courses-list li{color:#fff;font-size:1rem}.profile-courses-list{margin:5px 0 0;padding-left:20px;list-style:disc}
