body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.navbar{background-color:#2c3e50;box-shadow:0 2px 4px #0000001a;left:0;padding:1rem 0;position:fixed;right:0;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem}.navbar-logo a{color:#ecf0f1;font-size:1.5rem;font-weight:700;text-decoration:none;transition:color .3s ease}.navbar-logo a:hover{color:#3498db}.navbar-menu{align-items:center;display:flex;gap:2rem;list-style:none;margin:0;padding:0}.navbar-item{margin:0}.navbar-link{border-radius:4px;font-size:1rem;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.navbar-link,.navbar-link:focus,.navbar-link:visited{color:#ecf0f1;text-decoration:none}.navbar-link:hover{background-color:#34495e;color:#3498db}.navbar-user{background-color:#34495e;border-radius:4px;color:#ecf0f1;padding:.5rem 1rem}.logout-btn,.navbar-user{font-size:1rem;font-weight:500}.logout-btn{background:none;border:none;cursor:pointer;font-family:inherit}.logout-btn:hover{background-color:#34495e;color:#3498db}@media (max-width:768px){.navbar-container{flex-direction:column;gap:1rem}.navbar-menu{gap:1rem}.navbar-link{padding:.5rem}}.navbar-logo img{height:30px;width:auto}.navbar-logo img:hover{color:#3498db}.home-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:2rem}.hero-section{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;color:#fff;margin-bottom:4rem;padding:4rem 0;text-align:center}.hero-section h1{font-size:3rem;font-weight:700;margin-bottom:1.5rem}.hero-subtitle{animation:fadeIn 1s ease-out .5s both;margin-bottom:2rem;margin-left:auto;margin-right:auto}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:1.1rem;font-weight:600;margin-top:2rem;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.btn-primary{background:#3498db;color:#fff}.btn-primary:hover{background:#2980b9;box-shadow:0 5px 15px #3498db4d;transform:translateY(-2px)}.btn-primary a:focus,.btn-primary a:visited,.btn-primary:hover,.btn-primary:visited{color:#fff;text-decoration:none}.btn-secondary{background:#0000;border:2px solid #fff;color:#fff}.btn-secondary:hover{background:#fff;color:#667eea;transform:translateY(-2px)}.features-section{text-align:center}.features-section h2{color:#2c3e50;font-size:2.5rem;margin-bottom:3rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.feature-card{animation:slideInFromBottom 1s ease-out both;background:#fff;border-radius:15px;box-shadow:0 5px 20px #0000001a;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.feature-card:first-child{animation-delay:.2s}.feature-card:nth-child(2){animation-delay:.4s}.feature-card:nth-child(3){animation-delay:.6s}.feature-card:hover{box-shadow:0 10px 30px #00000026;transform:translateY(-5px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2c3e50;font-size:1.5rem;margin-bottom:1rem}.feature-card p{color:#666;line-height:1.6}@media (max-width:768px){.home-container{padding:1rem}.hero-section{padding:3rem 1rem}.hero-section h1{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.hero-buttons{align-items:center;flex-direction:column}.btn-primary,.btn-secondary{max-width:300px;width:100%}.features-grid{grid-template-columns:1fr}}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.about-container{color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;margin:0 auto;max-width:1200px;padding:0 2rem}.about-hero{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0 0 20px 20px;color:#fff;margin:2rem -2rem 3rem;padding:4rem 0;text-align:center}.about-hero h1{font-size:3rem;font-weight:700;margin-bottom:1rem}.hero-subtitle{font-size:1.25rem;margin:0 auto;max-width:600px;opacity:.9}.about-content{padding-bottom:4rem}.about-content section{margin-bottom:3rem;padding:2rem 0}.about-content h2{border-bottom:3px solid #3498db;color:#2c3e50;display:inline-block;font-size:2rem;margin-bottom:1.5rem;padding-bottom:.5rem}.about-content p{color:#555;font-size:1.1rem;margin-bottom:1.5rem}.feature-list{list-style:none;margin:1.5rem 0;padding:0}.feature-list li{border-bottom:1px solid #eee;font-size:1.1rem;padding:.75rem 0}.feature-list li:last-child{border-bottom:none}.impact-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:2rem 0}.impact-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;padding:2rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.impact-item:hover{box-shadow:0 10px 25px #0000001a;transform:translateY(-5px)}.impact-item h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1rem}.impact-item p{color:#666;margin:0}.values-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:2rem 0}.value-item{background:#fff;border-left:4px solid #3498db;border-radius:10px;box-shadow:0 2px 10px #0000000d;padding:2rem;transition:box-shadow .3s ease}.value-item:hover{box-shadow:0 5px 20px #0000001a}.value-item h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1rem}.value-item p{color:#666;margin:0}.join-section{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:15px;margin-top:3rem;padding:3rem;text-align:center}.join-section h2{border:none;color:#2c3e50;margin-bottom:1.5rem}.join-section p{font-size:1.2rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px}.cta-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-primary,.cta-secondary{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.cta-primary{background:#3498db;color:#fff}.cta-primary:hover{background:#2980b9;box-shadow:0 5px 15px #3498db4d;transform:translateY(-2px)}.cta-secondary{background:#0000;border:2px solid #3498db;color:#3498db}.cta-secondary:hover{background:#3498db;box-shadow:0 5px 15px #3498db4d;color:#fff;transform:translateY(-2px)}@media (max-width:768px){.about-container{padding:0 1rem}.about-hero{margin:-1rem -1rem 2rem;padding:3rem 1rem}.about-hero h1{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.about-content h2{font-size:1.8rem}.impact-grid,.values-grid{grid-template-columns:1fr}.cta-buttons{align-items:center;flex-direction:column}.cta-primary,.cta-secondary{max-width:300px;width:100%}}.login-container{align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;justify-content:center;min-height:100vh;padding:2rem}.login-form-container{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000001a;max-width:400px;padding:3rem;text-align:center;width:100%}.login-form-container h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#666;font-size:1.1rem;margin-bottom:2rem}.login-form{text-align:left}.error-message{background-color:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem;margin-bottom:1rem;padding:.75rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{color:#2c3e50;display:block;font-weight:600;margin-bottom:.5rem}.form-group input{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:1rem;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.login-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease;width:100%}.login-btn:hover:not(:disabled){background:#2980b9;box-shadow:0 5px 15px #3498db4d;transform:translateY(-2px)}.login-btn:disabled{cursor:not-allowed;opacity:.6}.login-footer{text-align:center}.login-footer p{color:#666;margin:.5rem 0}.login-footer a{color:#3498db;font-weight:600;text-decoration:none}.login-footer a:hover{text-decoration:underline}@media (max-width:768px){.login-container{padding:1rem}.login-form-container{padding:2rem}.login-form-container h1{font-size:2rem}}.main-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:2rem}.main-header{margin-bottom:3rem;text-align:center}.main-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.main-header p{color:#666;font-size:1.2rem}.search-section{margin-bottom:3rem}.search-bar{display:flex;gap:1rem;margin:0 auto;max-width:600px}.location-input{border:2px solid #e9ecef;border-radius:8px;flex:1 1;font-size:1rem;padding:1rem;transition:border-color .3s ease,box-shadow .3s ease}.location-input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.current-location-btn,.search-btn{background:#3498db;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease;white-space:nowrap}.current-location-btn:hover,.search-btn:hover{background:#2980b9;box-shadow:0 5px 15px #3498db4d;transform:translateY(-2px)}.current-location-btn{font-size:1.2rem;padding:1rem}.map-section{margin-bottom:3rem}.map-placeholder{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:15px;color:#666;padding:4rem 2rem;text-align:center}.map-placeholder p:first-child{font-size:2rem;margin-bottom:1rem}.results-section h2{color:#2c3e50;font-size:2rem;margin-bottom:2rem;text-align:center}.restroom-list{grid-gap:1.5rem;display:grid;gap:1.5rem}.restroom-card{border-radius:15px;box-shadow:0 5px 20px #0000001a;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.restroom-card:hover{box-shadow:0 10px 30px #00000026;transform:translateY(-3px)}.restroom-card.highlighted{background:#fff5f5;border:2px solid #ff6b6b;box-shadow:0 10px 30px #ff6b6b4d;transform:translateY(-3px)}.restroom-card h3{color:#2c3e50;font-size:1.3rem;margin-bottom:.5rem}.restroom-card p{color:#666;margin-bottom:1rem}.rating{color:#f39c12;font-weight:600;margin-bottom:1rem}.features{display:flex;flex-wrap:wrap;gap:.5rem}.feature-tag{background:#e8f4fd;border-radius:20px;color:#3498db;font-size:.9rem;font-weight:600;padding:.3rem .8rem}@media (max-width:768px){.main-container{padding:1rem}.main-header h1{font-size:2rem}.search-bar{flex-direction:column}.search-btn{width:100%}.map-placeholder{padding:3rem 1rem}.restroom-card{padding:1.5rem}}.map-error,.map-loading{align-items:center;color:#2c3e50;display:flex;font-size:1.2rem;height:100vh;justify-content:center}.map-instructions{background:#fffffff2;border-radius:8px;box-shadow:0 2px 10px #0000001a;font-size:.9rem;font-weight:500;left:50%;padding:10px 20px;position:absolute;top:20px;transform:translateX(-50%);z-index:1000}.map-instructions p{margin:0}.washroom-info{max-width:300px}.washroom-info h3{color:#2c3e50;font-size:1.1rem;margin:0 0 8px}.washroom-info p{color:#555;font-size:.9rem;margin:4px 0}.modal-overlay{align-items:center;animation:fadeIn .2s ease-in;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.modal-content h2{color:#2c3e50;font-size:1.5rem;margin:0 0 20px}.modal-content .form-group{margin-bottom:15px}.modal-content label{color:#34495e;display:block;font-weight:500;margin-bottom:5px}.modal-content input[type=checkbox],.modal-content input[type=text]{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:10px;width:100%}.modal-content input[type=checkbox]{cursor:pointer;margin-right:8px;width:auto}.modal-content input[type=text]:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.modal-content .readonly-input{background-color:#f5f5f5;color:#555;cursor:not-allowed}.modal-content .readonly-input:focus{border-color:#ddd;box-shadow:none}.loading-text{color:#3498db;font-size:.85rem;font-style:italic;font-weight:400}.coordinates-display{background-color:#f0f8ff;border:1px solid #d0e8ff;border-radius:6px;color:#2c3e50;font-family:monospace;font-size:.9rem;padding:10px}.modal-buttons{display:flex;gap:10px;margin-top:20px}.modal-content .btn-primary,.modal-content .btn-secondary{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .2s ease}.modal-content .btn-primary{background:#3498db;color:#fff}.modal-content .btn-primary:hover{background:#2980b9;box-shadow:0 4px 12px #3498db4d;transform:translateY(-2px)}.modal-content .btn-secondary{background:#95a5a6;color:#fff}.modal-content .btn-secondary:hover{background:#7f8c8d}.btn-review{background-color:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;margin-top:10px;padding:8px 16px;transition:background-color .3s}.btn-review:hover{background-color:#2980b9}.rating-select{padding:10px;width:100%}.rating-select,.review-comment{border:1px solid #ddd;border-radius:6px;font-size:1rem;margin-top:5px}.review-comment{font-family:inherit;resize:vertical}.restrooms-list{background:#fffffff2;border-radius:12px;bottom:20px;box-shadow:0 4px 20px #0000001a;left:20px;max-height:300px;overflow-y:auto;padding:20px;position:absolute;right:20px;z-index:1000}.restrooms-list h3{color:#2c3e50;font-size:1.2rem;margin:0 0 15px}.restrooms-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.restroom-card{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;padding:15px;transition:all .3s ease}.restroom-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db33;transform:translateY(-2px)}.restroom-card.selected{background:#f0f8ff;border-color:#3498db}.restroom-card h4{color:#2c3e50;font-size:1rem;margin:0 0 8px}.restroom-address{color:#666;font-size:.9rem;line-height:1.3;margin:0 0 10px}.restroom-stats{display:flex;gap:15px;margin-bottom:8px}.restroom-stats span{color:#555;font-size:.85rem}.restroom-type{color:#3498db;font-size:.8rem;font-weight:500}@media (max-width:768px){.modal-content{padding:20px}.map-instructions{font-size:.8rem;padding:8px 15px}.restrooms-list{bottom:10px;left:10px;padding:15px;right:10px}.restrooms-grid{grid-template-columns:1fr}}.App{padding-top:80px;text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.1d61f93b.css.map*/