:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#18181b;background-color:#fafafa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:#fafafa;color:#18181b}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#14b8a6;color:#fff;cursor:pointer;transition:border-color .25s}button:hover{background-color:#0d9488}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:#fffffff2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--gray-100);z-index:1000;transition:all .3s ease}.header-container{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)}.logo{display:flex;align-items:center;gap:var(--space-2);text-decoration:none;font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--gray-900);transition:all .2s ease}.logo:hover{transform:scale(1.05)}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--primary-600),var(--primary-400));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.125rem}.logo-text{background:linear-gradient(135deg,var(--primary-600),var(--primary-400));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{display:flex;align-items:center;gap:var(--space-1)}.nav-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);color:var(--gray-600);text-decoration:none;font-weight:500;font-size:.875rem;border-radius:var(--radius-lg);transition:all .2s ease;position:relative}.nav-link:hover,.nav-link.active{color:var(--primary-600);background:var(--primary-50)}.nav-link.active:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:4px;height:4px;background:var(--primary-600);border-radius:50%}.nav-link.coming-soon{opacity:.6;cursor:not-allowed;position:relative}.nav-link.coming-soon:hover{color:var(--gray-400);background:var(--gray-50);transform:none}.nav-link.coming-soon span{display:flex;align-items:center;gap:var(--space-2);flex-direction:column}.coming-soon-badge{font-size:.625rem;font-weight:600;color:var(--primary-600);background:var(--primary-50);padding:1px 6px;border-radius:var(--radius-sm);margin-top:-2px;white-space:nowrap;border:1px solid var(--primary-200)}.user-menu{position:relative}.user-avatar{width:40px;height:40px;border-radius:var(--radius-xl);background:linear-gradient(135deg,var(--primary-500),var(--primary-600));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;border:2px solid white;box-shadow:var(--shadow-medium)}.user-avatar:hover{transform:scale(1.1);box-shadow:var(--shadow-large)}.user-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);border:1px solid var(--gray-100);min-width:240px;overflow:hidden;z-index:1001;animation:slideUp .2s ease}.user-info{padding:var(--space-6);border-bottom:1px solid var(--gray-100);background:var(--gray-50)}.user-name{font-weight:600;color:var(--gray-900);margin-bottom:var(--space-1)}.user-email{font-size:.875rem;color:var(--gray-500)}.dropdown-links{padding:var(--space-3)}.dropdown-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);color:var(--gray-700);text-decoration:none;border-radius:var(--radius-lg);transition:all .2s ease;font-size:.875rem}.dropdown-link:hover{background:var(--gray-50);color:var(--primary-600)}.logout-btn{width:100%;margin-top:var(--space-2);border-top:1px solid var(--gray-100);padding:var(--space-4);background:none;border:none;color:var(--red-500);font-size:.875rem;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background:#ef44440d}.auth-btn{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-weight:600;border:none;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-medium)}.auth-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-large)}.mobile-menu-btn{display:none;background:none;border:none;padding:var(--space-2);color:var(--gray-600);cursor:pointer;border-radius:var(--radius-md);transition:all .2s ease}.mobile-menu-btn:hover{background:var(--gray-100);color:var(--gray-900)}.mobile-nav{position:fixed;top:var(--header-height);left:0;right:0;background:#fff;border-bottom:1px solid var(--gray-100);box-shadow:var(--shadow-large);padding:var(--space-6);z-index:999;animation:slideUp .3s ease}.mobile-nav-links{display:flex;flex-direction:column;gap:var(--space-2)}.mobile-nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);color:var(--gray-700);text-decoration:none;border-radius:var(--radius-lg);transition:all .2s ease;font-weight:500}.mobile-nav-link:hover{background:var(--primary-50);color:var(--primary-600)}.mobile-nav-link.coming-soon{opacity:.6;cursor:not-allowed}.mobile-nav-link.coming-soon:hover{background:var(--gray-50);color:var(--gray-400)}.mobile-nav-link.coming-soon span{display:flex;align-items:center;gap:var(--space-2);flex-direction:column;align-items:flex-start}@media (max-width: 768px){.header-container{padding:0 var(--space-4)}.nav{display:none}.mobile-menu-btn{display:block}.logo{font-size:1.25rem}.logo-icon{width:28px;height:28px}}.location-picker{position:relative;width:100%}.location-status-indicator,.location-permission-message{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:8px;border-radius:6px;font-size:14px;font-weight:500}.location-status-indicator{background:linear-gradient(135deg,#e8f5e8,#f0f9f0);color:#166534;border:1px solid #bbf7d0}.location-permission-message{background:linear-gradient(135deg,#fef3cd,#fef7e0);color:#92400e;border:1px solid #fde68a}.ios-location-guidance{display:flex;align-items:flex-start;gap:8px;padding:12px;margin-bottom:8px;border-radius:6px;background:linear-gradient(135deg,#fef2f2,#fef7f7);color:#991b1b;border:1px solid #fecaca;font-size:13px}.ios-location-guidance .ios-guidance-content{flex:1}.ios-location-guidance strong{display:block;margin-bottom:6px;font-weight:600}.ios-location-guidance ul{margin:0;padding-left:16px}.ios-location-guidance li{margin-bottom:4px;line-height:1.4}.ios-location-guidance li:last-child{margin-bottom:0}.remove-location-btn{display:flex;align-items:center;justify-content:center;padding:2px;background:transparent;border:none;color:#166534;cursor:pointer;border-radius:4px;transition:all .2s ease;margin-left:auto}.remove-location-btn:hover{background:#1665341a;color:#15803d}.location-input{position:relative;display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s ease}.location-input:hover{border-color:#cbd5e1}.location-input-field{flex:1;width:100%;padding:12px 16px;background:transparent;border:none;font-size:16px;color:#1e293b;outline:none}.location-input-field::placeholder{color:#94a3b8}.location-input-field:disabled{background:#f8fafc;cursor:not-allowed}.location-input:focus-within{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.location-actions{display:flex;gap:8px;padding-right:12px}.clear-btn,.current-location-btn{display:flex;align-items:center;justify-content:center;padding:6px;background:transparent;border:none;color:#64748b;cursor:pointer;border-radius:6px;transition:all .2s ease}.clear-btn:hover,.current-location-btn:hover:not(:disabled){background:#f1f5f9;color:#334155}.current-location-btn:disabled{cursor:not-allowed;opacity:.5}.location-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;margin-top:4px;max-height:250px;overflow-y:auto;z-index:10;border:1px solid #e1e8ed}.suggestion-item{width:100%;padding:12px 16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:10px;border:none;background:none;color:inherit;text-align:left}.suggestion-content{flex:1;display:flex;flex-direction:column;gap:2px}.suggestion-text{color:#1e293b;font-size:14px}.suggestion-type{color:#64748b;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.suggestion-item:not(:last-child){border-bottom:1px solid #f0f0f0}.suggestion-item:hover{background-color:#f8f9fa}.suggestion-item.loading,.suggestion-item.no-results{cursor:default;color:#6c757d;justify-content:center}.suggestion-item.loading{gap:8px}.loading-spinner{animation:spin 1s linear infinite}.animate-spin{animation:spin 1s linear infinite}@media (max-width: 768px){.location-input-field{font-size:15px}.location-suggestions{max-height:200px}.suggestion-item{padding:10px 14px}.location-status-indicator,.location-permission-message{padding:6px 10px;font-size:13px}.suggestion-text{font-size:13px}.suggestion-type{font-size:11px}}.map-error-fallback{display:flex;align-items:center;justify-content:center;min-height:400px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;border:2px dashed #dee2e6;margin:1rem 0}.error-content{text-align:center;padding:2rem;max-width:500px}.error-details{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:1rem;margin:1rem 0;text-align:left}.error-details p{margin:0 0 .5rem;font-weight:600;color:#856404}.error-details ul{margin:0;padding-left:1.5rem;color:#856404}.error-details li{margin-bottom:.25rem}.error-icon{color:#dc3545;margin-bottom:1rem}.error-content h3{color:#495057;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.error-message{color:#6c757d;margin-bottom:1.5rem;line-height:1.5}.error-actions{display:flex;flex-direction:column;gap:1rem;align-items:center}.retry-btn{display:flex;align-items:center;gap:.5rem;background:#007bff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-btn:hover{background:#0056b3;transform:translateY(-1px)}.fallback-message{display:flex;align-items:center;gap:.5rem;color:#6c757d;font-size:.875rem;text-align:center;padding:1rem;background:#f8f9fa;border-radius:6px;border-left:3px solid #17a2b8}.map-loading-fallback{display:flex;align-items:center;justify-content:center;min-height:400px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px}.loading-content{text-align:center;padding:2rem}.loading-spinner{width:48px;height:48px;border:4px solid #e9ecef;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.loading-content h3{color:#495057;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.loading-content p{color:#6c757d;margin:0}@media (max-width: 768px){.map-error-fallback,.map-loading-fallback{min-height:300px;margin:.5rem 0}.error-content,.loading-content{padding:1.5rem}.fallback-message{font-size:.8rem;padding:.75rem}}.home{width:100%;background:var(--gray-50)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hero{background:linear-gradient(135deg,var(--primary-50) 0%,white 50%,var(--primary-50) 100%);padding:var(--space-20) 0 var(--space-16);position:relative;overflow:hidden;min-height:90vh;display:flex;align-items:center}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 20%,rgba(20,184,166,.1) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(20,184,166,.05) 0%,transparent 50%);pointer-events:none}.hero-content{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:0 var(--space-6);text-align:center;width:100%}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:#fff;border:1px solid var(--primary-200);border-radius:var(--radius-3xl);padding:var(--space-2) var(--space-4);font-size:.875rem;font-weight:600;color:var(--primary-700);margin-bottom:var(--space-6);box-shadow:var(--shadow-soft);animation:fadeIn .6s ease-out}.hero-title{font-size:clamp(2.5rem,6vw,4rem);font-weight:800;color:var(--gray-900);margin-bottom:var(--space-6);line-height:1.1;animation:fadeIn .6s ease-out .2s both}.hero-subtitle{font-size:clamp(1.125rem,2.5vw,1.5rem);color:var(--gray-600);margin-bottom:var(--space-10);max-width:600px;margin-left:auto;margin-right:auto;animation:fadeIn .6s ease-out .4s both}.search-container{background:#fff;border-radius:var(--radius-3xl);box-shadow:var(--shadow-large);padding:var(--space-8);margin:0 auto var(--space-10);max-width:1200px;border:1px solid var(--gray-100);animation:fadeIn .6s ease-out .6s both}.search-tabs{display:flex;background:var(--gray-50);border-radius:var(--radius-xl);padding:var(--space-1);margin-bottom:var(--space-6);position:relative;overflow:hidden}.tab-button{flex:1;padding:var(--space-4) var(--space-5);background:none;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;color:var(--gray-600);cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-2);position:relative;z-index:1;min-height:48px}.tab-button.active{background:#fff;color:var(--primary-600);box-shadow:var(--shadow-soft);transform:translateY(-1px)}.tab-button:hover:not(.active){color:var(--gray-800);background:#ffffff80}.tab-button:focus{outline:2px solid var(--primary-500);outline-offset:2px}.search-form-home{position:relative;margin-bottom:var(--space-6)}.search-input-wrapper{display:flex;background:#f9fafb;border-radius:24px;padding:8px;gap:8px;border:2px solid transparent;transition:all .2s ease}.search-input-wrapper:focus-within{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.search-input-group,.location-input-group{flex:1;position:relative;display:flex;align-items:center}.search-input,.location-input{width:100%;padding:16px 16px 16px 64px;border:none;border-radius:12px;font-size:16px;background:#fff!important;color:#1f2937!important;transition:all .2s ease;min-height:48px;position:relative;z-index:2;caret-color:#1f2937}.search-input:focus,.location-input:focus{outline:none;box-shadow:0 0 0 2px #14b8a633;background:#fff!important;color:#1f2937!important}.search-input::placeholder,.location-input::placeholder{color:#6b7280!important}.input-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#9ca3af;z-index:0;pointer-events:none}.search-divider{width:1px;background:var(--gray-200);height:40px;margin:auto var(--space-2);flex-shrink:0}.search-submit-btn{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border:none;border-radius:var(--radius-xl);color:#fff;padding:var(--space-4);min-width:48px;min-height:48px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.search-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-large)}.search-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.search-submit-btn:focus{outline:2px solid var(--primary-500);outline-offset:2px}.validation-error,.location-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;border-radius:var(--radius-lg);color:#dc2626;margin-top:var(--space-3);font-size:.875rem;animation:slideIn .3s ease-out}.dismiss-error{background:none;border:none;color:#dc2626;cursor:pointer;padding:0;margin-left:auto;font-size:1.25rem;line-height:1;opacity:.7;transition:opacity .2s ease}.dismiss-error:hover{opacity:1}.discover-hero-section{background:linear-gradient(135deg,#1e293b,#334155,#475569);border-radius:var(--radius-2xl);padding:var(--space-10) var(--space-8);margin-bottom:var(--space-6);position:relative;overflow:hidden;box-shadow:0 25px 50px #00000026;transition:all .3s ease}.discover-hero-section.loading{background:linear-gradient(135deg,#1e293b,#2563eb,#1e293b 60%,#334155);background-size:300% 100%;animation:gradientShift 2s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.discover-hero-section:hover{transform:translateY(-2px);box-shadow:0 30px 60px #0003}.discover-hero-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><g fill="%23ffffff" fill-opacity="0.05"><circle cx="30" cy="30" r="4"/></g></svg>') repeat;pointer-events:none}.discover-main{display:grid;grid-template-columns:1fr auto;gap:var(--space-8);align-items:center;position:relative;z-index:1;max-width:1000px;margin:0 auto}.discover-content{text-align:left}.discover-title{display:flex;align-items:center;gap:var(--space-3);font-size:3rem;font-weight:800;color:#fff;margin:0 0 var(--space-3) 0;text-shadow:2px 2px 4px rgba(0,0,0,.8),0 0 10px rgba(0,0,0,.5);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.discover-icon{font-size:3.5rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.discover-subtitle{font-size:1.375rem;color:#f8fafc;margin:0 0 var(--space-2) 0;font-weight:500;line-height:1.5;text-shadow:1px 1px 3px rgba(0,0,0,.7);max-width:500px}.discover-features{display:flex;gap:var(--space-4);margin-top:var(--space-4);flex-wrap:wrap}.discover-feature{display:flex;align-items:center;gap:var(--space-2);color:#ffffffe6;font-size:.875rem;font-weight:500}.discover-feature-icon{font-size:1rem;opacity:.8}.discover-btn-hero{background:linear-gradient(135deg,#10b981,#059669);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:var(--radius-2xl);padding:var(--space-6) var(--space-12);font-weight:700;font-size:1.375rem;cursor:pointer;transition:all .3s ease;min-height:72px;position:relative;transform:translateY(0);box-shadow:0 10px 30px #0003;flex-shrink:0;overflow:hidden}.discover-btn-hero:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.discover-btn-hero:hover:before{left:100%}.discover-btn-hero:hover:not(:disabled){transform:translateY(-4px) scale(1.02);box-shadow:0 20px 40px #0000004d;background:linear-gradient(135deg,#059669,#047857)}.discover-btn-hero:disabled{opacity:.8;cursor:not-allowed;transform:none}.discover-btn-hero:disabled:before{display:none}.discover-btn-hero:focus{outline:3px solid rgba(255,255,255,.5);outline-offset:4px}.discover-btn-content{display:flex;align-items:center;gap:var(--space-3);justify-content:center}.discover-btn-text{font-size:1.375rem;font-weight:700}.button-spinner-large{width:26px;height:26px;border:3px solid rgba(255,255,255,.3);border-top:3px solid #ffffff;border-radius:50%;animation:spin 1s linear infinite}.search-divider{display:flex;align-items:center;justify-content:center;margin:var(--space-8) 0;position:relative}.search-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gray-300),transparent)}.divider-text{background:var(--background);color:var(--gray-500);padding:0 var(--space-4);font-weight:600;font-size:.875rem;letter-spacing:.1em}.search-section-secondary{background:var(--gray-50);border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid var(--gray-200);max-width:900px;margin:0 auto}.search-secondary-title{text-align:center;font-size:1.25rem;font-weight:600;color:var(--gray-700);margin:0 0 var(--space-4) 0}.search-buttons{display:flex;justify-content:center;margin-top:var(--space-4)}.discover-btn{display:flex;align-items:center;gap:var(--space-2);background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;border:none;border-radius:var(--radius-xl);padding:var(--space-4) var(--space-8);font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease;min-height:48px;position:relative}.discover-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-large)}.discover-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.discover-btn:focus{outline:2px solid var(--primary-500);outline-offset:2px}.button-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.hero-features{display:flex;justify-content:center;gap:var(--space-8);margin:var(--space-8) 0;flex-wrap:wrap}.feature{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#fffc;border:1px solid var(--gray-200);border-radius:var(--radius-xl);font-size:.875rem;font-weight:600;color:var(--gray-700);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.feature-icon{font-size:1rem}.scroll-indicator{background:#ffffffe6;border:1px solid var(--gray-200);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;margin:var(--space-8) auto 0;color:var(--gray-600);animation:bounce 2s infinite}.scroll-indicator:hover{background:#fff;color:var(--primary-600);transform:translateY(-2px);box-shadow:var(--shadow-soft)}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.featured-section{padding:var(--space-20) 0;background:#fff}.featured-places-loading{text-align:center;padding:var(--space-16) 0}.loader{width:48px;height:48px;border:4px solid var(--gray-200);border-top:4px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--space-4)}.search-section{padding:var(--space-20) 0;background:var(--gray-50)}.search-tab{flex:1;padding:var(--space-3) var(--space-4);background:none;border:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;color:var(--gray-600);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.search-tab.active{background:#fff;color:var(--primary-600);box-shadow:var(--shadow-soft)}.search-form{position:relative}.search-input-group{display:flex;background:var(--gray-50);border-radius:var(--radius-2xl);padding:var(--space-2);gap:var(--space-2);margin-bottom:var(--space-6)}.search-input-wrapper{flex:1;position:relative}.search-input{width:100%;padding:var(--space-4) var(--space-4) var(--space-4) 4rem;border:none;border-radius:var(--radius-xl);font-size:1rem;background:#fff;color:#18181b!important;transition:all .2s ease;position:relative;z-index:2}.search-input:focus{outline:none;box-shadow:0 0 0 3px #14b8a61a}.search-icon{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%);color:var(--gray-400)}.search-submit{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));border:none;border-radius:var(--radius-xl);color:#fff;padding:var(--space-4) var(--space-8);font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.search-submit:hover{transform:translateY(-2px);box-shadow:var(--shadow-large)}.quick-actions{display:flex;justify-content:center;gap:var(--space-4);flex-wrap:wrap}.quick-action{display:flex;align-items:center;gap:var(--space-2);background:var(--primary-50);border:2px solid var(--primary-200);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-6);color:var(--primary-700);text-decoration:none;font-weight:600;font-size:.875rem;transition:all .2s ease;cursor:pointer;min-height:48px}.quick-action:hover{background:var(--primary-100);border-color:var(--primary-300);transform:translateY(-2px)}.features-section{padding:var(--space-20) 0;background:#fff}.features-content{max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)}.features-header{text-align:center;margin-bottom:var(--space-16)}.features-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--gray-900);margin-bottom:var(--space-4)}.features-subtitle{font-size:1.25rem;color:var(--gray-600);max-width:600px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-8)}.feature-card{background:#fff;border-radius:var(--radius-2xl);padding:var(--space-8);text-align:center;border:1px solid var(--gray-100);transition:all .3s ease;position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));transform:scaleX(0);transition:transform .3s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-large);border-color:var(--primary-200)}.feature-card:hover:before{transform:scaleX(1)}.feature-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--primary-500),var(--primary-400));border-radius:var(--radius-2xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-6);color:#fff;font-size:1.5rem}.feature-title{font-size:1.25rem;font-weight:700;color:var(--gray-900);margin-bottom:var(--space-3)}.feature-description{color:var(--gray-600);line-height:1.6}.places-section{padding:var(--space-20) 0;background:var(--gray-50)}.places-content{max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-6)}.places-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-12)}.places-title{font-size:clamp(1.75rem,3vw,2.5rem);font-weight:800;color:var(--gray-900)}.view-all-btn{background:var(--primary-600);color:#fff;padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);text-decoration:none;font-weight:600;transition:all .2s ease;display:flex;align-items:center;gap:var(--space-2);border:none;cursor:pointer}.view-all-btn:hover{background:var(--primary-700);transform:translateY(-2px)}.places-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-8)}.loading-section{padding:var(--space-16) 0;text-align:center}.loading-spinner-large{width:48px;height:48px;border:4px solid var(--gray-200);border-top:4px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--space-4)}.redesigned-placecard.place-card-skeleton,.place-card-skeleton.redesigned-placecard{background:#fff;border-radius:var(--radius-2xl);padding:var(--space-6);border:1px solid var(--gray-100);box-shadow:var(--shadow-soft);position:relative;min-height:400px}.skeleton-header{position:relative;margin-bottom:var(--space-6)}.skeleton-verification{background:var(--gray-200);border-radius:var(--radius-lg)}.skeleton-name{background:var(--gray-200);border-radius:var(--radius-md)}.skeleton-category{background:var(--gray-200);border-radius:var(--radius-full)}.skeleton-rating{background:var(--gray-200);border-radius:var(--radius-xl);position:absolute;top:0;right:0}.skeleton-essentials{margin-bottom:var(--space-6)}.skeleton-info{background:var(--gray-200);border-radius:var(--radius-md)}.skeleton-tags{margin-bottom:var(--space-6);display:flex;flex-wrap:wrap;gap:var(--space-2)}.skeleton-tag{background:var(--gray-200);border-radius:var(--radius-full)}.skeleton-community{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:var(--radius-xl);padding:var(--space-6);border:1px solid #bae6fd}.skeleton-community-header{background:var(--gray-200);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.skeleton-vote-btn{background:var(--gray-200);border-radius:var(--radius-2xl);margin:0 auto}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-weight:600;text-decoration:none;border:none;cursor:pointer;transition:all .2s ease;min-height:44px}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff}@media (min-width: 1400px){.hero-content{max-width:1600px}.search-container{max-width:1400px}.discover-hero-section{padding:var(--space-12) var(--space-10)}.discover-main{max-width:1200px}.discover-title{font-size:3.5rem}.discover-icon{font-size:4rem}.discover-subtitle{font-size:1.5rem;max-width:600px}.discover-btn-hero{font-size:1.5rem;padding:var(--space-7) var(--space-14);min-height:80px}.discover-btn-text{font-size:1.5rem}.button-spinner-large{width:28px;height:28px}}@media (max-width: 1024px){.hero{min-height:85vh;padding:var(--space-16) 0 var(--space-12)}.hero-content{max-width:1000px}.search-container{max-width:900px}.discover-main{grid-template-columns:1fr;gap:var(--space-6);text-align:center}.discover-content{text-align:center}.discover-title{justify-content:center;font-size:2.5rem}.discover-icon{font-size:3rem}.discover-subtitle{max-width:none;margin:0 auto var(--space-4) auto}.discover-features{justify-content:center}.discover-btn-hero{font-size:1.25rem;padding:var(--space-5) var(--space-10);min-height:64px}.discover-btn-text{font-size:1.25rem}.button-spinner-large{width:24px;height:24px}.features-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-6)}.places-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6)}}@media (max-width: 768px){.hero{min-height:80vh;padding:var(--space-12) 0 var(--space-8)}.hero-content{padding:0 var(--space-4)}.search-container{margin:0 var(--space-4) var(--space-8);padding:var(--space-6)}.discover-hero-section{padding:var(--space-6);margin-bottom:var(--space-4)}.discover-title{font-size:2rem;flex-direction:column;gap:var(--space-2)}.discover-icon{font-size:2.5rem}.discover-subtitle{font-size:1.1rem}.discover-btn-hero{padding:var(--space-4) var(--space-6);font-size:1.1rem;min-height:56px}.discover-btn-text{font-size:1.1rem}.search-divider{margin:var(--space-6) 0}.search-section-secondary{padding:var(--space-4)}.search-input-wrapper{flex-direction:column;gap:var(--space-3)}.search-divider{display:none}.location-input-group{order:1}.search-submit-btn{order:2;width:100%;border-radius:var(--radius-lg)}.hero-features{gap:var(--space-4);margin:var(--space-6) 0}.feature{padding:var(--space-2) var(--space-3);font-size:.8rem}.quick-actions{gap:var(--space-2)}.quick-action{padding:var(--space-2) var(--space-4);font-size:.8rem}.features-section,.places-section{padding:var(--space-12) 0}.features-content,.places-content{padding:0 var(--space-4)}.features-grid,.places-grid{grid-template-columns:1fr;gap:var(--space-6)}.places-header{flex-direction:column;gap:var(--space-4);align-items:flex-start}}@media (max-width: 480px){.hero{min-height:75vh;padding:var(--space-8) 0 var(--space-6)}.search-container{padding:var(--space-4);border-radius:var(--radius-2xl)}.discover-hero-section{padding:var(--space-4);border-radius:var(--radius-xl)}.discover-title{font-size:1.75rem}.discover-icon{font-size:2rem}.discover-subtitle{font-size:1rem}.discover-btn-hero{padding:var(--space-3) var(--space-5);font-size:1rem;min-height:50px}.discover-btn-text{font-size:1rem}.search-section-secondary{padding:var(--space-3)}.tab-button{padding:var(--space-3) var(--space-4);font-size:.8rem}.search-input,.location-input{padding:12px 12px 12px 56px;font-size:14px}.discover-btn{padding:var(--space-3) var(--space-6);font-size:.9rem}.hero-features{flex-direction:column;gap:var(--space-3);align-items:center}.feature{width:100%;max-width:280px;justify-content:center}.feature-card{padding:var(--space-6)}.place-content{padding:var(--space-4)}}.highlight-text{background:linear-gradient(135deg,var(--primary-400),var(--primary-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;position:relative}.highlight-text:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:3px;background:linear-gradient(135deg,var(--primary-400),var(--primary-500));border-radius:2px;opacity:.7}.trust-indicators{display:flex;gap:var(--space-4);margin-top:var(--space-6);flex-wrap:wrap;justify-content:center}.trust-badge{display:flex;align-items:center;gap:var(--space-2);background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-xl);color:#fff;font-size:.9rem;font-weight:500;transition:all .3s ease}.trust-badge:hover{background:#ffffff26;transform:translateY(-2px)}.verification-tag{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);text-align:center;transition:all .3s ease;min-width:140px}.verification-tag:hover{transform:translateY(-4px);box-shadow:var(--shadow-strong)}.verification-tag span{font-size:.9rem;font-weight:600;color:var(--gray-900)}.verification-tag small{font-size:.75rem;color:var(--gray-600);margin-top:var(--space-1)}.verification-tag.verified{border-left:4px solid #16a34a}.verification-tag.verified svg{color:#16a34a}.verification-tag.promising{border-left:4px solid #2563eb}.verification-tag.promising svg{color:#2563eb}.verification-tag.needs-verification{border-left:4px solid #ca8a04}.verification-tag.needs-verification svg{color:#ca8a04}.verification-tag.flagged{border-left:4px solid #dc2626}.verification-tag.flagged svg{color:#dc2626}.how-it-works-section{padding:var(--space-20) 0;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.section-header{text-align:center;margin-bottom:var(--space-16)}.section-title{font-size:2.5rem;font-weight:700;color:var(--gray-900);margin-bottom:var(--space-4)}.section-subtitle{font-size:1.2rem;color:var(--gray-600);max-width:600px;margin:0 auto;line-height:1.6}.verification-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-8);margin-bottom:var(--space-16)}.verification-card{background:#fff;padding:var(--space-8);border-radius:var(--radius-2xl);box-shadow:var(--shadow-soft);text-align:center;transition:all .3s ease}.verification-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-strong)}.verification-status{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-6);padding:var(--space-3) var(--space-6);border-radius:var(--radius-xl);font-weight:600}.verification-status.verified{background:#22c55e1a;color:#16a34a}.verification-status.promising{background:#3b82f61a;color:#2563eb}.verification-status.needs-verification{background:#eab3081a;color:#ca8a04}.verification-card h3{font-size:1.3rem;font-weight:600;color:var(--gray-900);margin-bottom:var(--space-4)}.verification-card p{color:var(--gray-600);line-height:1.6}@media (max-width: 768px){.trust-indicators{gap:var(--space-2)}.trust-badge{font-size:.8rem;padding:var(--space-2) var(--space-3)}.verification-tag{min-width:120px;padding:var(--space-3)}.verification-tag span{font-size:.8rem}.verification-tag small{font-size:.7rem}.section-title{font-size:2rem}.section-subtitle{font-size:1.1rem}.verification-grid{grid-template-columns:1fr;gap:var(--space-6)}.verification-card{padding:var(--space-6)}}.voting-section{border-top:none;background:transparent;margin-top:0;border-radius:0}.voting-summary{display:flex;align-items:center;justify-content:space-between;padding:0;gap:16px}.voting-tags{display:flex;flex-wrap:wrap;gap:8px;flex:1}.vote-tag{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap;border:1px solid;transition:all .15s ease;letter-spacing:.025em}.vote-tag.verified{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.vote-tag.promising{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.vote-tag.disputed{background:#fef2f2;color:#991b1b;border-color:#fecaca}.vote-tag.prayer{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.vote-tag.meat{background:#f0fdf4;color:#166534;border-color:#86efac}.vote-tag.neutral{background:#f8fafc;color:#64748b;border-color:#e2e8f0}.vote-tag.loading{background:#eff6ff;color:#1e40af;border-color:#bfdbfe;animation:pulse 2s infinite}.vote-tag.error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.voting-error{display:flex;align-items:center;gap:8px}.retry-btn{padding:6px 12px;border:1px solid rgba(239,68,68,.2);border-radius:8px;background:#ef44440d;color:#dc2626;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;letter-spacing:.025em}.retry-btn:hover{background:#ef44441a;border-color:#ef44444d;transform:translateY(-1px)}.expand-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:16px;color:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 4px 12px #3b82f64d;letter-spacing:.025em;text-transform:uppercase;position:relative;overflow:hidden}.expand-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.expand-btn:hover:before{left:100%}.expand-btn:hover{background:linear-gradient(135deg,#2563eb,#1e40af);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f666}.expand-btn:active{transform:translateY(0);box-shadow:0 4px 12px #3b82f64d}.expand-btn svg{color:#fff;width:16px;height:16px}.voting-expanded{background:#fff;border-top:1px solid #e0f2fe;padding:24px;margin-top:20px;border-radius:16px;box-shadow:0 4px 16px #00000014}.voting-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #f1f5f9}.voting-title{font-size:18px;font-weight:700;color:#1e293b;letter-spacing:-.01em}.collapse-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease;letter-spacing:.025em}.collapse-btn:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.collapse-btn:active{transform:translateY(0)}.voting-group{margin-bottom:24px;padding:24px;background:#fafbfc;border-radius:16px;border:1px solid #f1f5f9;transition:all .15s ease}.voting-group:hover{border-color:#e2e8f0;box-shadow:0 4px 12px #00000014}.voting-group-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.voting-group-title{font-size:15px;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:10px;letter-spacing:-.01em}.voting-group-title svg{color:#64748b;width:18px;height:18px}.voting-group-stats{display:flex;align-items:center;gap:8px;font-size:13px;color:#64748b}.voting-group-stats .stat{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#fff;border-radius:10px;border:1px solid #e2e8f0;font-weight:600}.voting-buttons{display:flex;gap:16px}.vote-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 20px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px;justify-content:center;letter-spacing:.025em;position:relative;overflow:hidden}.vote-btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:currentColor;opacity:0;transition:opacity .2s ease;z-index:-1}.vote-btn:hover:before{opacity:.05}.vote-btn:hover{border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.vote-btn:active{transform:translateY(0)}.vote-btn.active{border-color:#3b82f6;background:#eff6ff;color:#1e40af}.vote-btn.active.up{border-color:#16a34a;background:#f0fdf4;color:#166534}.vote-btn.active.down{border-color:#dc2626;background:#fef2f2;color:#991b1b}.vote-btn.up:hover{border-color:#16a34a;background:#f0fdf4}.vote-btn.down:hover{border-color:#dc2626;background:#fef2f2}.vote-btn .vote-count{font-weight:700;min-width:24px;text-align:center;color:inherit;background:#0000001a;padding:4px 8px;border-radius:8px;font-size:12px}.vote-btn svg{flex-shrink:0;width:16px;height:16px}.meat-voting-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:20px;margin-top:20px}.meat-voting-item{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px;background:#fff;border-radius:12px;border:1px solid #f1f5f9;transition:all .15s ease}.meat-voting-item:hover{border-color:#e2e8f0;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.meat-voting-item .meat-icon{font-size:28px;color:#64748b}.meat-voting-item .meat-name{font-size:14px;font-weight:600;color:#475569;text-transform:capitalize;text-align:center}.meat-voting-item .meat-votes{display:flex;gap:10px}.meat-voting-item .meat-votes .vote-btn{min-width:70px;padding:10px 14px;font-size:13px}.voting-loading{display:flex;align-items:center;justify-content:center;padding:24px;color:#64748b;font-size:14px;font-weight:500}.voting-error{display:flex;align-items:center;justify-content:center;padding:24px;color:#dc2626;font-size:14px;font-weight:500;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 768px){.voting-summary{padding:0;gap:12px}.voting-expanded{padding:20px;margin-top:16px}.voting-group{padding:20px;margin-bottom:20px}.voting-buttons{flex-direction:column;gap:12px}.vote-btn{min-width:auto;justify-content:space-between}.meat-voting-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px}.meat-voting-item{padding:16px}.meat-voting-item .meat-votes .vote-btn{min-width:60px;padding:8px 12px;font-size:12px}.expand-btn{padding:10px 16px;font-size:13px}}@media (max-width: 480px){.voting-summary{flex-direction:column;align-items:stretch;gap:16px}.expand-btn{justify-content:center;padding:14px 20px;font-size:14px}.voting-tags{justify-content:center}.voting-group-header{flex-direction:column;align-items:flex-start;gap:16px}.voting-group-stats{flex-wrap:wrap;gap:8px}.meat-voting-grid{grid-template-columns:1fr;gap:12px}.voting-expanded,.voting-group{padding:16px}}@media (prefers-reduced-motion: reduce){.vote-btn,.meat-voting-item,.voting-group,.expand-btn{transition:none}.vote-btn:hover,.meat-voting-item:hover,.expand-btn:hover{transform:none}.expand-btn:before{display:none}}@media (prefers-contrast: high){.voting-section,.voting-group{border-width:2px}.vote-btn{border-width:3px}.expand-btn{border:2px solid #ffffff}}.redesigned-placecard.place-card,.place-card.redesigned-placecard{background:#fff!important;border-radius:20px!important;border:1px solid #f1f5f9!important;box-shadow:0 2px 8px #00000014!important;overflow:hidden!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;position:relative!important;display:flex!important;flex-direction:column!important;height:100%!important}.redesigned-placecard.place-card:hover,.place-card.redesigned-placecard:hover{border-color:#e2e8f0!important;box-shadow:0 8px 25px #0000001f!important;transform:translateY(-2px)!important}.redesigned-placecard.place-card:focus-within,.place-card.redesigned-placecard:focus-within{outline:3px solid #3b82f6!important;outline-offset:2px!important}.redesigned-placecard .place-header{padding:24px 24px 20px!important;background:linear-gradient(135deg,#fafbfc,#fff)!important;border-bottom:1px solid #f8fafc!important;position:relative!important}.redesigned-placecard .verification-status{display:flex!important;align-items:center!important;gap:8px!important;margin-bottom:16px!important;padding:8px 12px!important;background:#f8fafc!important;border-radius:12px!important;border:1px solid #e2e8f0!important;width:fit-content!important}.verification-icon{flex-shrink:0}.verification-icon.verified{color:#16a34a}.verification-icon.promising{color:#3b82f6}.verification-icon.needs-verification{color:#f59e0b}.verification-icon.disputed{color:#dc2626}.verification-text{font-size:13px;font-weight:600;color:#475569;letter-spacing:.025em}.place-main-info{margin-bottom:16px}.redesigned-placecard .place-name{font-size:22px!important;font-weight:700!important;color:#1e293b!important;margin:0 0 8px!important;line-height:1.3!important;letter-spacing:-.02em!important}.place-category{display:inline-block;background:#f1f5f9;color:#64748b;padding:6px 14px;border-radius:20px;font-weight:500;font-size:12px;text-transform:capitalize;letter-spacing:.025em}.rating-display{position:absolute;top:24px;right:24px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000f}.stars-container{display:flex;align-items:center;gap:2px}.star{color:#fbbf24;width:16px;height:16px}.star.empty{color:#e2e8f0}.star.half{color:#fbbf24;opacity:.7}.rating-score{font-size:16px;font-weight:700;color:#1e293b}.review-count{font-size:11px;color:#64748b;font-weight:500}.place-essentials{padding:0 24px 20px;display:flex;flex-direction:column;gap:12px}.info-row{display:flex!important;align-items:center!important;gap:12px!important;color:#64748b!important;font-size:14px!important;line-height:1.5!important}.info-icon{flex-shrink:0!important;color:#94a3b8!important;width:16px!important;height:16px!important}.info-text{color:#475569!important;font-weight:500!important}.place-tags{padding:0 24px 24px;display:flex;flex-wrap:wrap;gap:10px;border-bottom:1px solid #f1f5f9}.tag{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:20px;font-size:12px;font-weight:600;text-transform:capitalize;transition:all .15s ease;cursor:default;letter-spacing:.025em;border:1px solid}.tag:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.tag-icon{font-size:14px;line-height:1}.tag.primary{background:#dbeafe;color:#1e40af;border-color:#93c5fd}.tag.secondary{background:#1e293b;color:#fff;border-color:#334155}.tag.highlight{background:#dcfce7;color:#166534;border-color:#86efac}.tag.feature{background:#fef3c7;color:#92400e;border-color:#fde68a}.community-section{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-top:1px solid #e0f2fe;padding:24px;margin-top:auto}.community-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #bae6fd}.community-icon{flex-shrink:0;color:#0284c7;margin-top:2px}.community-text{flex:1}.community-title{font-size:16px;font-weight:700;color:#0c4a6e;margin:0 0 6px;letter-spacing:-.01em}.community-subtitle{font-size:13px;color:#0369a1;margin:0;line-height:1.4;font-weight:500}.mobile-only{display:none}.desktop-only{display:block}@media (max-width: 768px){.place-card{border-radius:16px}.place-header{padding:20px 20px 16px}.place-essentials{padding:0 20px 16px}.place-tags{padding:0 20px 20px}.community-section{padding:20px}.place-name{font-size:20px}.rating-display{top:20px;right:20px;padding:10px}.rating-score{font-size:14px}.tag{font-size:11px;padding:6px 12px}}@media (max-width: 480px){.place-header{padding:16px 16px 12px}.place-essentials{padding:0 16px 12px}.place-tags{padding:0 16px 16px;gap:8px}.community-section{padding:16px}.community-header{flex-direction:column;gap:12px;text-align:center;margin-bottom:16px;padding-bottom:16px}.community-title{font-size:14px;margin-bottom:4px}.community-subtitle{font-size:11px;line-height:1.3}.mobile-only{display:block}.desktop-only{display:none}.place-name{font-size:18px}.rating-display{position:static;align-self:flex-end;margin-bottom:16px}.verification-status{margin-bottom:12px}.tag{font-size:10px;padding:5px 10px}}.place-card:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media (prefers-contrast: high){.place-card,.tag,.verification-status{border-width:2px}}@media (prefers-reduced-motion: reduce){.place-card,.tag{transition:none}.place-card:hover{transform:none}}.place-card.loading{pointer-events:none}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-radius:4px}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-text.large{height:24px}.skeleton-text.small{height:12px}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.map-view{width:100%!important;height:calc(100vh - var(--header-height-mobile, 60px) - var(--safe-area-inset-top, 0px) - var(--safe-area-inset-bottom, 0px));min-height:400px;position:relative;border-radius:0;overflow:hidden;box-shadow:none;display:block!important;min-width:300px!important}.map-container{position:relative;width:100%!important;height:100%;min-height:400px;display:block!important;min-width:300px!important}.map{width:100%!important;height:100%;min-height:400px;display:block!important;min-width:300px!important}.recenter-btn{position:absolute;top:calc(var(--safe-area-inset-top) + var(--space-4));right:var(--space-4);background:#fff;border:none;border-radius:var(--radius-lg);padding:var(--space-3);cursor:pointer;box-shadow:var(--shadow-lg);z-index:10;display:flex;align-items:center;justify-content:center;width:44px;height:44px}.recenter-btn:active{transform:scale(.95)}.map-legend{position:absolute;bottom:calc(var(--safe-area-inset-bottom) + var(--space-4));left:var(--space-4);background:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:10;font-size:.875rem}.legend-item{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);min-height:24px}.legend-item:last-child{margin-bottom:0}.legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.legend-dot.verified{background-color:#22c55e}.legend-dot.promising{background-color:#3b82f6}.legend-dot.needs-verification{background-color:#eab308}.legend-dot.flagged{background-color:#ef4444}.map-loading,.map-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f9fafbf2;padding:var(--space-6);text-align:center;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-spinner{width:40px;height:40px;border:3px solid var(--gray-200);border-top:3px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--space-4)}.map-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;background:#fffffff2;padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);text-align:center;max-width:min(90%,300px);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.no-results-message{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.no-results-message h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--gray-900)}.no-results-message p{margin:0;font-size:.875rem;color:var(--gray-600);line-height:1.5}@media (max-width: 768px){.map-view{border-radius:0;height:calc(100vh - var(--header-height-mobile) - var(--safe-area-inset-top) - var(--safe-area-inset-bottom))}.recenter-btn{top:calc(var(--safe-area-inset-top) + var(--space-3));right:var(--space-3)}.map-legend{bottom:calc(var(--safe-area-inset-bottom) + var(--space-3));left:var(--space-3);font-size:.75rem;padding:var(--space-2) var(--space-3)}.legend-item{gap:var(--space-2);margin-bottom:var(--space-1);min-height:20px}.legend-marker{width:10px;height:10px}.map-overlay{padding:var(--space-4);max-width:min(85%,280px)}.no-results-message{gap:var(--space-3)}.no-results-message h3{font-size:1rem}.no-results-message p{font-size:.813rem}}@media (max-height: 480px) and (orientation: landscape){.map-legend{max-width:200px}.map-overlay{max-width:min(70%,320px)}}@supports (padding-bottom: env(safe-area-inset-bottom)){.map-legend{bottom:calc(env(safe-area-inset-bottom) + var(--space-4))}}.filter-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.filter-panel{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026}.filter-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e1e8ed;background:#f8f9fa}.filter-header h2{display:flex;align-items:center;gap:12px;margin:0;color:#2c3e50;font-size:24px}.close-btn{background:none;border:none;padding:8px;border-radius:8px;cursor:pointer;color:#6c757d;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#e9ecef;color:#495057}.filter-content{flex:1;overflow-y:auto;padding:24px}.filter-section{margin-bottom:32px}.filter-section:last-child{margin-bottom:0}.filter-section h3{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:#2c3e50;font-size:18px;font-weight:600}.filter-group{margin-bottom:16px}.filter-group label{display:block;margin-bottom:8px;font-weight:500;color:#495057}.distance-slider{width:100%;height:6px;border-radius:3px;background:#e1e8ed;outline:none;-webkit-appearance:none;margin:12px 0}.distance-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#27ae60;cursor:pointer;box-shadow:0 2px 6px #27ae604d}.distance-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#27ae60;cursor:pointer;border:none;box-shadow:0 2px 6px #27ae604d}.distance-labels{display:flex;justify-content:space-between;font-size:14px;color:#6c757d}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.checkbox-item{display:flex;align-items:center;gap:8px;padding:8px;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.checkbox-item:hover{background:#f8f9fa}.checkbox-item input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#27ae60}.checkbox-item span{font-size:14px;color:#495057;-webkit-user-select:none;user-select:none}.status-label{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-label.green{background:#d4edda;color:#155724}.status-label.blue{background:#d1ecf1;color:#0c5460}.status-label.yellow{background:#fff3cd;color:#856404}.status-label.red{background:#f8d7da;color:#721c24}.rating-filter{display:flex;flex-direction:column;gap:12px}.star-buttons{display:flex;gap:4px}.star-btn{background:none;border:none;padding:8px;border-radius:6px;cursor:pointer;color:#dee2e6;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.star-btn:hover{background:#f8f9fa;color:#ffc107}.star-btn.active{color:#ffc107}.filter-actions{display:flex;gap:12px;padding:24px;border-top:1px solid #e1e8ed;background:#f8f9fa}.reset-btn{flex:1;background:#fff;color:#6c757d;border:2px solid #dee2e6;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;transition:all .2s ease}.reset-btn:hover{background:#f8f9fa;border-color:#adb5bd;color:#495057}.apply-btn{flex:2;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;transition:all .2s ease}.apply-btn:hover{background:linear-gradient(135deg,#229954,#27ae60);transform:translateY(-1px);box-shadow:0 4px 12px #2ecc714d}@media (max-width: 768px){.filter-panel-overlay{padding:12px}.filter-panel{max-height:95vh}.filter-header,.filter-content{padding:20px}.filter-section{margin-bottom:24px}.checkbox-grid{grid-template-columns:1fr;gap:8px}.filter-actions{padding:20px;flex-direction:column}.reset-btn,.apply-btn{flex:none}}body.search-results-page{background:linear-gradient(135deg,var(--gray-50) 0%,white 50%,var(--gray-50) 100%)!important;background-attachment:fixed}body.search-results-page:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:radial-gradient(circle at 20% 80%,rgba(20,184,166,.05) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(20,184,166,.03) 0%,transparent 50%);pointer-events:none;z-index:-1}.search-results{display:flex;flex-direction:column;min-height:calc(100vh - var(--header-height-desktop));padding-top:var(--header-height-desktop);background:transparent;position:relative}.search-header{position:fixed;top:var(--header-height-desktop);left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--gray-200);width:100%;z-index:900;box-shadow:0 4px 20px #00000014;transition:all .3s ease;height:80px}.search-content{margin-top:0;padding:var(--space-6) 0;flex:1;position:relative;z-index:1}.search-prompt{background:linear-gradient(135deg,var(--teal-50) 0%,white 100%);border-bottom:1px solid var(--teal-100);padding:var(--space-8) 0;margin-top:80px}.search-prompt-content{text-align:center;max-width:600px;margin:0 auto}.search-prompt-content h2{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:16px 0 12px}.search-prompt-content p{font-size:1.1rem;color:var(--gray-600);margin:0 0 24px;line-height:1.6}.prompt-icon{color:var(--teal-500);margin-bottom:8px}.search-prompt-btn{background:var(--teal-500);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.search-prompt-btn:hover{background:var(--teal-600);transform:translateY(-1px);box-shadow:0 4px 12px #14b8a64d}.search-prompt-btn:active{transform:translateY(0)}.search-header .container{width:100%!important;max-width:none!important;margin:0 auto;padding:0 var(--space-6)!important}.search-title{flex:1}.search-title h1{font-size:1.75rem;font-weight:700;color:var(--gray-900);margin:0 0 8px;line-height:1.2}.search-info{padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:20px;width:100%!important;max-width:none!important;margin:0 auto;padding-left:var(--space-6);padding-right:var(--space-6);position:relative;z-index:1}.search-info h1{font-size:clamp(1.5rem,3vw,2rem);font-weight:700;color:var(--gray-900);margin:0;text-shadow:0 1px 2px rgba(0,0,0,.05)}.results-count{font-size:1rem;color:var(--gray-600);margin:0;line-height:1.4}.geocoding-indicator{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;background:var(--blue-50);border:1px solid var(--blue-200);border-radius:6px;color:var(--blue-700);font-size:.9rem;font-weight:500}.geocoding-indicator .spinning{animation:spin 1s linear infinite}.geocoded-location-info{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;background:var(--green-50);border:1px solid var(--green-200);border-radius:6px;color:var(--green-700);font-size:.9rem;font-weight:500}.geocoding-failure-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:1px solid #f59e0b;padding:20px 0;margin-top:80px}.banner-content{display:flex;align-items:flex-start;gap:16px;max-width:800px;margin:0 auto}.banner-icon{color:#d97706;flex-shrink:0;margin-top:4px}.banner-text{flex:1}.banner-text h3{font-size:1.1rem;font-weight:700;color:#92400e;margin:0 0 8px;line-height:1.3}.banner-text p{font-size:.95rem;color:#78350f;margin:0 0 8px;line-height:1.5}.banner-text p:last-of-type{margin-bottom:0}.banner-note{font-size:.9rem!important;color:#92400e!important;font-style:italic}.banner-retry-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#d97706;color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex-shrink:0;white-space:nowrap}.banner-retry-btn:hover{background:#b45309;transform:translateY(-1px)}.banner-retry-btn:active{transform:translateY(0)}@media (max-width: 768px){.banner-content{flex-direction:column;gap:12px;text-align:center}.banner-text h3{font-size:1rem}.banner-text p{font-size:.9rem}.banner-retry-btn{align-self:center}}.view-controls{display:flex;align-items:center;gap:6px;background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:6px;border-radius:20px;border:1px solid rgba(0,0,0,.05);box-shadow:0 8px 32px #0000001f,0 4px 16px #0000000f,inset 0 1px #fffc;flex-wrap:wrap}.primary-controls{display:flex;align-items:center;gap:6px;flex:1}.sort-controls{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#ffffffb3;border-radius:10px;border:1px solid rgba(0,0,0,.05);min-width:0}.sort-label{font-size:.7rem;font-weight:600;color:var(--gray-600);white-space:nowrap}.sort-dropdown{background:transparent;border:none;font-size:.8rem;font-weight:600;color:var(--primary-600);cursor:pointer;outline:none;min-width:70px}.sort-dropdown:focus{outline:2px solid var(--primary-500);outline-offset:2px;border-radius:4px}.view-btn,.filter-btn{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-radius:16px;color:var(--gray-600);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;white-space:nowrap}.btn-text{transition:opacity .3s ease}.view-btn:before,.filter-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:translate(-100%);transition:transform .6s ease}.view-btn:hover,.filter-btn:hover{background:#fff9;color:var(--gray-800);transform:translateY(-1px)}.view-btn:hover:before,.filter-btn:hover:before{transform:translate(100%)}.view-btn:active,.filter-btn:active{transform:translateY(0) scale(.96);transition:transform .1s ease}.view-btn svg,.filter-btn svg{transition:all .2s cubic-bezier(.4,0,.2,1)}.view-btn:hover svg,.filter-btn:hover svg{transform:scale(1.1)}.view-btn.active svg,.filter-btn.active svg{transform:scale(1.05)}.view-btn.active,.filter-btn.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:0 4px 12px #14b8a666,0 2px 6px #14b8a633,inset 0 1px #fff3}.filter-indicator{position:absolute;top:-6px;right:-6px;width:16px;height:16px;background:linear-gradient(135deg,var(--red-500),var(--red-400));border:2px solid white;border-radius:50%;font-size:8px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;animation:pulseIndicator 2s infinite;box-shadow:0 2px 6px #ef444466}@keyframes pulseIndicator{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.search-content{flex:1;padding:100px 0 32px;width:100%;max-width:none;margin-top:0;position:relative;z-index:1;min-height:400px;background:#00ff001a}.search-results,.search-results .container,.search-results .search-content,.search-results .search-header,.search-results .search-info{max-width:none!important}.search-results .container{width:100%!important;max-width:none!important;margin:0 auto;padding:0 var(--space-6)!important}.search-results .container.map-view{width:100vw!important;max-width:none!important;padding:0!important;margin:0!important;left:0!important;right:0!important}.results-list{position:relative;z-index:1}.results-map{width:100%!important;height:calc(100vh - 80px);position:relative;display:block;margin:0;border-radius:0}.error-message{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:linear-gradient(135deg,#fef2f2,#fee2e2);border:2px solid #fca5a5;border-radius:var(--radius-xl);color:#dc2626;margin-bottom:var(--space-6);box-shadow:0 4px 12px #dc262626;animation:slideInFromTop .4s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.error-retry-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;border-radius:var(--radius-xl);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-left:auto;min-height:44px;box-shadow:0 4px 12px #dc262640,0 2px 4px #dc262626;position:relative;overflow:hidden}.error-retry-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.error-retry-btn:hover:before{left:100%}.error-retry-btn:hover{background:linear-gradient(135deg,#b91c1c,#991b1b);transform:translateY(-2px);box-shadow:0 8px 20px #dc262659,0 4px 8px #dc262633}.switch-to-list-btn{display:flex;align-items:center;gap:var(--space-2);background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;border:none;padding:var(--space-4) var(--space-6);border-radius:var(--radius-xl);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:48px;box-shadow:0 6px 16px #22c55e40,0 2px 6px #22c55e26;position:relative;overflow:hidden}.switch-to-list-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.switch-to-list-btn:hover:before{left:100%}.switch-to-list-btn:hover{background:linear-gradient(135deg,#15803d,#166534);transform:translateY(-2px);box-shadow:0 10px 24px #22c55e59,0 4px 8px #22c55e33}.results-list{width:100%;position:relative;z-index:1;min-height:200px}.places-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-6);width:100%;animation:fadeInUp .6s ease-out;justify-content:stretch;align-content:start;position:relative;z-index:1}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center;color:var(--gray-600);background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-2xl);border:2px dashed var(--gray-300);margin:var(--space-8) 0;max-width:700px;margin-left:auto;margin-right:auto;box-shadow:0 10px 30px #00000014;animation:fadeIn .6s ease-out}.no-results h3{margin:16px 0 8px;font-size:1.25rem;font-weight:600;color:#374151}.no-results p{margin:0 0 1.5rem;font-size:.875rem;max-width:400px;line-height:1.5;color:#6b7280}.suggestions-list{list-style:none;padding:0;margin:1rem 0 2rem;text-align:left;max-width:300px}.suggestions-list li{font-size:.875rem;color:#4b5563;position:relative;padding:.5rem 0 .5rem 1rem}.suggestions-list li:before{content:"•";color:#3b82f6;font-weight:700;position:absolute;left:0}.contact-info{margin:1.5rem 0;padding:1rem;background:#22c55e0d;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-lg);text-align:center}.contact-info p{margin:0 0 .5rem;font-weight:500;color:var(--gray-700)}.email-link{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;text-decoration:none;border-radius:var(--radius-lg);font-weight:600;font-size:.875rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #22c55e40}.email-link:hover{background:linear-gradient(135deg,#15803d,#166534);transform:translateY(-2px);box-shadow:0 6px 20px #22c55e59;text-decoration:none;color:#fff}.email-link:focus{outline:none;box-shadow:0 0 0 3px #22c55e4d}.no-results-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.adjust-filters-btn,.retry-search-btn{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;border:none;border-radius:var(--radius-xl);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.875rem;min-height:52px;min-width:160px;justify-content:center;position:relative;overflow:hidden;box-shadow:0 6px 16px #14b8a640,0 2px 6px #14b8a626;text-decoration:none}.adjust-filters-btn:before,.retry-search-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);transition:left .6s ease}.adjust-filters-btn:hover:before,.retry-search-btn:hover:before{left:100%}.adjust-filters-btn:hover,.retry-search-btn:hover{background:linear-gradient(135deg,var(--primary-700),var(--primary-600));transform:translateY(-3px);box-shadow:0 12px 28px #14b8a659,0 6px 12px #14b8a633}.adjust-filters-btn:active,.retry-search-btn:active{transform:translateY(-1px);box-shadow:0 4px 12px #14b8a64d}.retry-search-btn{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 6px 16px #22c55e40,0 2px 6px #22c55e26}.retry-search-btn:hover{background:linear-gradient(135deg,#15803d,#166534);box-shadow:0 12px 28px #22c55e59,0 6px 12px #22c55e33}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center;background:linear-gradient(135deg,#fffffff2,#f8fafce6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:32px;border:1px solid rgba(0,0,0,.05);margin:var(--space-8) 0;max-width:800px;margin-left:auto;margin-right:auto;box-shadow:0 20px 60px #0000001a,0 8px 25px #0000000d;animation:fadeInUp .8s ease-out;position:relative;overflow:hidden}.empty-state:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 50% 0%,rgba(20,184,166,.03) 0%,transparent 50%);pointer-events:none}.empty-state-icon{position:relative;margin-bottom:2rem}.empty-state-icon svg{color:var(--primary-500);filter:drop-shadow(0 4px 12px rgba(20,184,166,.2));animation:floatIcon 3s ease-in-out infinite}.icon-decoration{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));border-radius:50%;animation:pulse 2s infinite}.empty-state-content h2{font-size:2rem;font-weight:700;color:var(--gray-900);margin:0 0 1rem;background:linear-gradient(135deg,var(--gray-900),var(--gray-700));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.empty-state-description{font-size:1.125rem;color:var(--gray-600);margin:0 0 2rem;max-width:500px;line-height:1.6}.empty-state-stats{display:flex;gap:3rem;margin:2rem 0;padding:1.5rem;background:#ffffffb3;border-radius:20px;border:1px solid rgba(0,0,0,.05)}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-number{font-size:2rem;font-weight:800;color:var(--primary-600);line-height:1}.stat-label{font-size:.875rem;color:var(--gray-600);margin-top:.5rem;font-weight:500}.empty-state-actions{display:flex;gap:1rem;margin:2rem 0;flex-wrap:wrap;justify-content:center}.primary-action-btn{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;text-decoration:none;border-radius:16px;font-weight:600;font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 25px #14b8a640,0 3px 10px #14b8a626;border:none;cursor:pointer}.primary-action-btn:hover{background:linear-gradient(135deg,var(--primary-700),var(--primary-600));transform:translateY(-3px);box-shadow:0 15px 35px #14b8a659,0 6px 15px #14b8a633;color:#fff;text-decoration:none}.secondary-action-btn{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:#fffc;color:var(--gray-700);border:2px solid var(--gray-200);border-radius:16px;font-weight:600;font-size:1rem;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.secondary-action-btn:hover{background:#fff;border-color:var(--primary-300);transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}.empty-state-note{margin-top:2rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#3b82f60d,#9333ea0d);border:1px solid rgba(59,130,246,.1);border-radius:16px;max-width:400px}.empty-state-note p{margin:0;font-size:.875rem;color:var(--gray-600);line-height:1.5}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}@media (min-width: 1400px){.search-results .container,.search-header .container{padding-left:var(--space-8)!important;padding-right:var(--space-8)!important}.places-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-8)}}@media (min-width: 1920px){.search-results .container,.search-header .container{padding-left:var(--space-12)!important;padding-right:var(--space-12)!important}.places-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--space-10)}}@media (max-width: 1024px){.search-results .container:not(.map-view){padding-left:var(--space-4)!important;padding-right:var(--space-4)!important}.search-header .container{padding-left:var(--space-4)!important;padding-right:var(--space-4)!important}.places-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}}@media (max-width: 768px){.search-results{min-height:calc(100vh - var(--header-height-mobile));padding-top:var(--header-height-mobile)}.search-header{top:var(--header-height-mobile);padding:8px 0;height:auto}.search-info{flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) 0;padding-left:var(--space-4);padding-right:var(--space-4)}.search-title{width:100%}.search-info h1{font-size:1.25rem;line-height:1.3;margin-bottom:2px}.results-count{font-size:.8rem;margin:0}.view-controls{width:100%;justify-content:space-between;gap:4px;padding:4px;flex-wrap:nowrap}.primary-controls{gap:2px;flex:1}.view-btn,.filter-btn{flex:1;justify-content:center;min-height:36px;font-size:.75rem;padding:8px 6px;min-width:0;gap:4px}.view-btn svg,.filter-btn svg{width:16px;height:16px;flex-shrink:0}.sort-controls{padding:4px 8px;gap:4px;min-width:0;flex-shrink:0}.sort-label{font-size:.65rem}.sort-dropdown{font-size:.75rem;min-width:60px}.filter-indicator{width:12px;height:12px;top:-2px;right:-2px;border:1px solid white;font-size:8px}.places-grid{grid-template-columns:1fr;gap:var(--space-4)}.results-map{top:110px;height:calc(100vh - 110px)}.search-content{margin-top:95px}.search-results .container:not(.map-view){padding-left:var(--space-4)!important;padding-right:var(--space-4)!important}.search-header .container{padding-left:var(--space-4)!important;padding-right:var(--space-4)!important}.no-results{padding:var(--space-10) var(--space-4);margin:var(--space-4) 0}.no-results h3{font-size:1.125rem}.no-results-actions{flex-direction:column;width:100%;max-width:280px}.adjust-filters-btn,.retry-search-btn{width:100%;justify-content:center}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center;color:var(--gray-600);background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-2xl);margin:var(--space-8) 0;min-height:400px;box-shadow:0 10px 30px #00000014;animation:fadeIn .6s ease-out}.loading-spinner{width:56px;height:56px;border:4px solid var(--gray-200);border-top:4px solid var(--primary-500);border-radius:50%;animation:spinEnhanced 1s linear infinite;margin-bottom:var(--space-4);position:relative}.loading-spinner:after{content:"";position:absolute;top:2px;left:2px;right:2px;bottom:2px;border:2px solid transparent;border-top:2px solid var(--primary-300);border-radius:50%;animation:spinEnhanced 2s linear infinite reverse}@keyframes spinEnhanced{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.loading-state p{margin:0;font-size:1.125rem;font-weight:600;color:var(--gray-700)}.loading-more{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);text-align:center;color:var(--gray-600);margin:var(--space-4) 0;animation:fadeIn .4s ease-out}.loading-more .loading-spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top:3px solid var(--primary-500);margin-bottom:var(--space-2)}.loading-more .loading-spinner:after{border:2px solid transparent;border-top:2px solid var(--primary-300)}.loading-more p{margin:0;font-size:.875rem;font-weight:500;color:var(--gray-600)}.error-message{display:flex;align-items:center;gap:12px;padding:16px 20px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;border-radius:8px;color:#dc2626;margin-bottom:24px;box-shadow:0 2px 4px #dc26261a;animation:slideInFromTop .3s ease-out}.error-retry-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#dc2626;color:#fff;border:none;border-radius:4px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-left:auto}.error-retry-btn:hover{background:#b91c1c;transform:translateY(-1px)}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.view-btn:focus,.filter-btn:focus,.adjust-filters-btn:focus,.retry-search-btn:focus,.error-retry-btn:focus{outline:2px solid #3b82f6;outline-offset:2px}.view-btn:focus-visible,.filter-btn:focus-visible,.adjust-filters-btn:focus-visible,.retry-search-btn:focus-visible,.error-retry-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.filter-indicator{position:absolute;top:-4px;right:-4px;width:8px;height:8px;background:#ef4444;border-radius:50%;font-size:8px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.search-map-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:12px;border:2px dashed #fca5a5;margin:1rem 0;text-align:center;padding:2rem}.search-map-error .error-icon{color:#dc3545;margin-bottom:1rem}.search-map-error h3{color:#495057;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.search-map-error p{color:#6c757d;margin-bottom:1.5rem;line-height:1.5;max-width:400px}.search-map-error .error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.retry-btn{display:flex;align-items:center;gap:var(--space-2);background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:var(--space-4) var(--space-6);border-radius:var(--radius-xl);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:48px;box-shadow:0 6px 16px #3b82f640,0 2px 6px #3b82f626;position:relative;overflow:hidden}.retry-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s ease}.retry-btn:hover:before{left:100%}.retry-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 10px 24px #3b82f659,0 4px 8px #3b82f633}.view-btn:focus,.filter-btn:focus,.adjust-filters-btn:focus,.retry-search-btn:focus,.error-retry-btn:focus,.switch-to-list-btn:focus,.retry-btn:focus{outline:none;box-shadow:0 0 0 3px #14b8a64d}.view-btn:focus-visible,.filter-btn:focus-visible,.adjust-filters-btn:focus-visible,.retry-search-btn:focus-visible,.error-retry-btn:focus-visible,.switch-to-list-btn:focus-visible,.retry-btn:focus-visible{outline:3px solid var(--primary-400);outline-offset:2px}@media (max-width: 768px){.search-results{min-height:calc(100vh - var(--header-height-mobile));padding-top:var(--header-height-mobile)}.search-header{top:var(--header-height-mobile);padding:12px 0}.search-info{flex-direction:column;align-items:flex-start;gap:12px;padding:12px 0}.search-info h1{font-size:1.25rem;line-height:1.3}.view-controls{width:100%;justify-content:space-between;gap:8px}.view-btn,.filter-btn{flex:1;justify-content:center;min-height:44px;font-size:.875rem}.places-grid{grid-template-columns:1fr;gap:16px}.results-map{top:140px;height:calc(100vh - 140px)}.search-content{padding-top:120px}.container{padding:0 16px}.no-results{padding:40px 16px;margin:1rem 0}.no-results h3{font-size:1.125rem}.suggestions-list{max-width:100%}.no-results-actions{flex-direction:column;width:100%;max-width:280px}.adjust-filters-btn,.retry-search-btn{width:100%;justify-content:center}}@media (max-width: 480px){.search-info h1{font-size:1.125rem}.view-controls{flex-direction:column;gap:8px}.view-btn,.filter-btn{width:100%;justify-content:center}.results-map{top:180px;height:calc(100vh - 180px)}.search-content{padding-top:160px}.search-map-error{min-height:300px;padding:1.5rem}.places-grid{grid-template-columns:1fr;gap:12px}.no-results{padding:32px 12px}.no-results p,.suggestions-list li{font-size:.8rem}.adjust-filters-btn,.retry-search-btn{padding:10px 20px;font-size:.8rem}}@media (max-width: 480px){.empty-state{padding:2rem 1.5rem;margin:1rem 0;border-radius:24px}.empty-state-content h2{font-size:1.5rem}.empty-state-description{font-size:1rem}.empty-state-stats{gap:1.5rem;padding:1rem;flex-direction:column}.stat-item{flex-direction:row;gap:.5rem;justify-content:center}.stat-number{font-size:1.5rem}.empty-state-actions{flex-direction:column;width:100%;gap:.75rem}.primary-action-btn,.secondary-action-btn{width:100%;justify-content:center;padding:.875rem 1.5rem}.empty-state-note{padding:.875rem 1.25rem}}@media (max-width: 480px){.btn-text,.sort-label{display:none!important}.view-controls{padding:3px!important;gap:2px!important}.primary-controls{gap:1px!important}.view-btn,.filter-btn{min-height:32px!important;font-size:.7rem!important;padding:6px 4px!important;gap:3px!important}.view-btn svg,.filter-btn svg{width:14px!important;height:14px!important}.sort-controls{padding:3px 6px!important;gap:3px!important}.sort-dropdown{font-size:.7rem!important;min-width:50px!important}.results-map{top:85px!important;height:calc(100vh - 85px)!important}.search-content{margin-top:75px!important}.search-info h1{font-size:1.1rem!important}.results-count{font-size:.75rem!important}.search-results .container:not(.map-view){padding-left:var(--space-2)!important;padding-right:var(--space-2)!important}.places-grid{grid-template-columns:1fr!important;gap:var(--space-3)!important;margin:0!important;padding:0!important}.results-map{width:100vw!important;left:0!important;right:0!important;margin:0!important;padding:0!important}}.reviews-section{margin-top:30px}.reviews-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.reviews-title{font-size:1.5rem;font-weight:700;color:#2c3e50;margin:0;display:flex;align-items:center;gap:10px}.review-count{background:#e6f7ef;color:#27ae60;padding:4px 10px;border-radius:20px;font-size:14px;font-weight:600}.write-review-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;padding:10px 16px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.write-review-btn:hover{background:linear-gradient(135deg,#229954,#27ae60);transform:translateY(-1px);box-shadow:0 4px 12px #27ae604d}.reviews-list{display:flex;flex-direction:column;gap:20px}.review-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .2s ease}.review-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.review-header{display:flex;justify-content:space-between;margin-bottom:15px}.reviewer-info{display:flex;align-items:center;gap:12px}.reviewer-avatar{width:40px;height:40px;border-radius:50%;background:#e1e8ed;display:flex;align-items:center;justify-content:center;color:#6c757d;font-weight:600;font-size:16px}.reviewer-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.reviewer-details{display:flex;flex-direction:column}.reviewer-name{font-weight:600;color:#2c3e50;font-size:16px;margin:0}.review-date{font-size:13px;color:#6c757d}.review-rating{display:flex;gap:2px;color:#f59e0b;font-size:18px}.review-content{margin-bottom:15px;color:#4b5563;line-height:1.6}.review-photos{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px;margin-bottom:15px}.review-photo{width:80px;height:80px;border-radius:8px;overflow:hidden;cursor:pointer}.review-photo img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.review-photo:hover img{transform:scale(1.05)}.review-footer{display:flex;justify-content:space-between;align-items:center;margin-top:15px;padding-top:15px;border-top:1px solid #f0f0f0}.review-actions{display:flex;gap:15px}.review-action{display:flex;align-items:center;gap:6px;color:#6c757d;background:none;border:none;cursor:pointer;font-size:14px;transition:all .2s ease}.review-action:hover,.review-action.liked{color:#27ae60}.review-action.reported{color:#e74c3c}.review-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.review-tag{background:#f1f5f9;color:#475569;padding:4px 10px;border-radius:20px;font-size:13px}.load-more-btn{background:#fff;border:2px solid #27ae60;color:#27ae60;padding:10px 20px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:20px;display:block;width:100%;text-align:center}.load-more-btn:hover{background:#f0f9ff;transform:translateY(-1px)}.empty-reviews{text-align:center;padding:40px 20px;background:#f8f9fa;border-radius:12px;color:#6c757d}.empty-reviews-icon{font-size:40px;color:#cbd5e1;margin-bottom:16px}.empty-reviews-title{font-size:1.2rem;margin-bottom:8px;color:#475569}@media (max-width: 768px){.reviews-header{flex-direction:column;align-items:flex-start;gap:15px}.write-review-btn{width:100%;justify-content:center}.review-header{flex-direction:column;gap:10px}.review-photo{width:70px;height:70px}.review-footer{flex-wrap:wrap;gap:10px}}.image-gallery{width:100%;margin-bottom:2rem}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,200px);gap:8px;cursor:pointer}.gallery-item{position:relative;overflow:hidden;border-radius:8px}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-item:hover img{transform:scale(1.05)}.main-image{grid-column:span 2;grid-row:span 2}.more-images{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem}.fullscreen-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000}.close-btn{position:absolute;top:20px;right:20px;background:none;border:none;color:#fff;cursor:pointer;z-index:1010}.fullscreen-image-container{position:relative;width:80%;height:80%;display:flex;align-items:center;justify-content:center}.fullscreen-image{max-width:100%;max-height:100%;object-fit:contain}.nav-btn{position:absolute;background:#00000080;border:none;color:#fff;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .3s ease}.nav-btn:hover{background-color:#000c}.prev{left:10px}.next{right:10px}.image-counter{position:absolute;bottom:20px;left:20px;color:#fff;background-color:#00000080;padding:5px 10px;border-radius:4px}.image-caption{position:absolute;bottom:20px;left:50%;transform:translate(-50%);color:#fff;background-color:#00000080;padding:8px 16px;border-radius:4px;max-width:80%;text-align:center}.image-gallery-empty{padding:3rem;text-align:center;background-color:#f5f5f5;border-radius:8px;color:#666}@media (max-width: 768px){.gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,150px)}.main-image{grid-column:span 2;grid-row:span 1}}@media (max-width: 480px){.gallery-grid{display:flex;flex-direction:column;gap:8px}.gallery-item{height:200px}}.place-details{min-height:calc(100vh - var(--header-height-desktop));padding-top:var(--header-height-desktop);background:var(--gray-50)}.details-container{max-width:1280px;margin:0 auto;padding:var(--space-6) var(--space-4)}.place-details.loading,.place-details.error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;text-align:center;color:#666}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.place-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:32px 0}.place-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:32px}.place-main-info{flex:1}.place-name{font-size:2.5rem;font-weight:700;margin:0 0 8px;color:#111827}.place-type{font-size:1.125rem;color:#6b7280;margin:0 0 16px;text-transform:capitalize}.place-location{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:#6b7280}.place-rating{display:flex;align-items:center;gap:12px;margin-bottom:24px}.stars{display:flex;gap:2px}.star{color:#d1d5db}.star.filled{color:#f59e0b}.rating-text{font-size:.875rem;color:#6b7280}.halal-status-badge{display:flex;align-items:center;gap:12px;padding:16px;border-radius:8px;border:2px solid;max-width:400px}.halal-status-badge.verified{background-color:#ecfdf5;border-color:#22c55e}.halal-status-badge.promising{background-color:#eff6ff;border-color:#3b82f6}.halal-status-badge.flagged{background-color:#fef3c7;border-color:#f59e0b}.halal-status-badge.disputed{background-color:#fef2f2;border-color:#ef4444}.halal-status-badge.unverified{background-color:#f3f4f6;border-color:#9ca3af}.status-icon.verified{color:#22c55e}.status-icon.promising{color:#3b82f6}.status-icon.flagged{color:#f59e0b}.status-icon.disputed{color:#ef4444}.status-icon.unverified{color:#9ca3af}.status-text h3{margin:0 0 4px;font-size:1rem;font-weight:600;color:#111827}.status-text p{margin:0;font-size:.875rem;color:#6b7280}.place-actions{display:flex;flex-direction:column;gap:12px;min-width:120px}.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;text-decoration:none;font-size:.875rem;font-weight:500;transition:all .2s ease;cursor:pointer}.action-btn:hover{background-color:#f9fafb;border-color:#9ca3af;color:#111827}.place-content{padding:32px 0}.content-grid{display:grid;grid-template-columns:1fr 300px;gap:32px}.main-content{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.description-section{padding:24px;border-bottom:1px solid #e5e7eb}.description-section h2{margin:0 0 16px;font-size:1.25rem;font-weight:600;color:#111827}.description-section p{margin:0;line-height:1.6;color:#374151}.sidebar{display:flex;flex-direction:column;gap:24px}.place-info-card,.map-card{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.place-info-card h3,.map-card h3{margin:0 0 20px;font-size:1.125rem;font-weight:600;color:#111827}.info-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f3f4f6}.info-item:last-child{border-bottom:none}.info-item strong{color:#374151;font-weight:500}.info-item span{color:#6b7280;text-align:right}.map-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background-color:#f9fafb;border:1px dashed #d1d5db;border-radius:6px;text-align:center;color:#6b7280}.map-placeholder p{margin:8px 0 0;font-size:.875rem}.certification-info{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--gray-50);border-radius:var(--radius-lg);margin-bottom:var(--space-4)}.certification-info .icon{flex-shrink:0;width:32px;height:32px}.certification-info .icon.certified{color:var(--success-500)}.certification-info .icon.partially-halal{color:var(--warning-500)}.certification-info h4{margin:0 0 var(--space-2) 0;font-size:1.125rem;color:var(--gray-900)}.certification-info p{margin:0 0 var(--space-2) 0;color:var(--gray-700)}.halal-meat-list{list-style:none;padding:0;margin:var(--space-2) 0 0 0;display:flex;flex-wrap:wrap;gap:var(--space-2)}.halal-meat-list li{padding:var(--space-1) var(--space-2);background:var(--warning-50);color:var(--warning-700);border:1px solid var(--warning-200);border-radius:var(--radius-full);font-size:.875rem;text-transform:capitalize}.container{max-width:1200px;margin:0 auto;padding:0 20px}@media (max-width: 1024px){.content-grid{grid-template-columns:1fr 280px;gap:24px}}@media (max-width: 768px){.place-details{min-height:calc(100vh - var(--header-height-mobile));padding-top:var(--header-height-mobile)}.place-header{padding:16px 0}.place-hero{flex-direction:column;gap:16px}.place-name{font-size:1.5rem;line-height:1.3}.place-type,.place-location{font-size:.875rem}.place-actions{flex-direction:row;flex-wrap:wrap;width:100%;gap:8px}.action-btn{flex:1;min-width:100px;justify-content:center}.content-grid{grid-template-columns:1fr;gap:16px}.place-content{padding:16px var(--space-3)}.description-section,.place-info-card,.map-card{padding:16px;border-radius:var(--radius-lg)}.halal-status-badge{padding:12px;gap:8px}}@media (max-width: 480px){.place-header{padding:12px 0}.place-name{font-size:1.25rem}.halal-status-badge{flex-direction:column;align-items:center;text-align:center}.status-text h3{font-size:.875rem}.status-text p{font-size:.75rem}.place-actions{flex-direction:column}.action-btn{width:100%}.place-info-card .info-item{flex-direction:column;align-items:flex-start;gap:4px}}.add-place{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:2rem 0}.container{max-width:800px;margin:0 auto;padding:0 1.5rem}.page-header{text-align:center;margin-bottom:3rem;padding:2rem 0;background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a;border:1px solid #e2e8f0}.page-header h1{font-size:2.5rem;font-weight:700;color:#1e293b;margin-bottom:.5rem;background:linear-gradient(135deg,#14b8a6,#0ea5e9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-header p{font-size:1.125rem;color:#64748b;margin:0}.add-place-form{background:#fff;border-radius:1rem;box-shadow:0 10px 25px -5px #0000001a;overflow:hidden;border:1px solid #e2e8f0}.form-section{padding:2rem;border-bottom:1px solid #f1f5f9;position:relative}.form-section:last-child{border-bottom:none}.form-section h2{font-size:1.5rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.form-section h2:before{content:"";width:4px;height:24px;background:linear-gradient(135deg,#14b8a6,#0ea5e9);border-radius:2px}.google-maps-section{background:linear-gradient(135deg,#fef7ed,#fef3c7);border:2px solid #fed7aa;border-radius:1rem;margin-bottom:2rem;position:relative;overflow:hidden}.google-maps-section:before{content:"�";position:absolute;top:1rem;right:1rem;font-size:2rem;opacity:.3}.google-maps-section h2{color:#ea580c;margin-bottom:.75rem}.google-maps-section p{color:#9a3412;margin-bottom:1.5rem;font-weight:500}.auto-filled-section{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #bbf7d0}.auto-filled-section h2{color:#16a34a}.auto-filled-info{background:#fff;border-radius:.75rem;padding:1.5rem;border:1px solid #d1fae5}.info-item{margin-bottom:.75rem;padding:.5rem 0;border-bottom:1px solid #f0fdf4}.info-item:last-child{border-bottom:none;margin-bottom:0}.info-item strong{color:#16a34a;margin-right:.5rem}.info-item pre{margin:.5rem 0 0;white-space:pre-line;font-family:inherit;font-size:.875rem;color:#374151}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.5rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:.75rem;font-size:1rem;transition:all .2s ease;background:#fff;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a;transform:translateY(-1px)}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-group textarea{resize:vertical;min-height:100px}.error-text{color:#ef4444;font-size:.875rem;margin-top:.25rem;display:flex;align-items:center;gap:.25rem;font-weight:500}.error-text:before{content:"⚠️";font-size:.75rem}.form-help{font-size:.875rem;color:#64748b;margin-bottom:1rem;font-style:italic}.help-text{font-size:.875rem;color:#64748b;margin-top:.5rem;line-height:1.5;padding:.75rem;background:#f8fafc;border-radius:.5rem;border-left:4px solid #14b8a6}.url-input-group{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1rem}.url-input-group .form-group{flex:1;margin-bottom:0}.extract-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;height:fit-content;min-width:140px;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 6px -1px #0000001a}.extract-btn:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 8px 15px -3px #0003}.extract-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.radio-group{display:flex;flex-direction:column;gap:1rem;margin-top:.5rem}.radio-option{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s ease;font-weight:500}.radio-option:hover{background:#f1f5f9;border-color:#cbd5e1}.radio-option input[type=radio]{width:18px;height:18px;margin:0;accent-color:#14b8a6}.radio-option:has(input:checked){background:#f0fdfa;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.radio-option:has(input:checked) span{color:#0f766e;font-weight:600}.meat-types-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-top:1rem}.meat-type-checkbox{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;font-weight:500}.meat-type-checkbox:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.meat-type-checkbox input[type=checkbox]{width:18px;height:18px;margin:0;accent-color:#14b8a6}.meat-type-checkbox input[type=checkbox]:checked+span{color:#14b8a6;font-weight:600}.meat-type-checkbox:has(input:checked){background:#f0fdfa;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a61a}.image-upload{margin-bottom:1rem}.image-input{display:none}.upload-button{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:.75rem;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 4px 6px -1px #0000001a}.upload-button:hover{background:linear-gradient(135deg,#4f46e5,#7c3aed);transform:translateY(-2px);box-shadow:0 8px 15px -3px #0003}.image-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1rem}.image-item{position:relative;aspect-ratio:1;border-radius:.75rem;overflow:hidden;border:2px solid #e2e8f0;background:#f8fafc}.image-item img{width:100%;height:100%;object-fit:cover}.remove-image{position:absolute;top:.5rem;right:.5rem;background:#ef4444e6;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.remove-image:hover{background:#dc2626;transform:scale(1.1)}.form-actions{padding:2rem;background:#f8fafc;display:flex;gap:1rem;justify-content:flex-end;border-top:1px solid #e2e8f0}.cancel-btn,.submit-btn{padding:.875rem 2rem;border-radius:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;border:none;font-size:1rem}.cancel-btn{background:#fff;color:#64748b;border:2px solid #e2e8f0}.cancel-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px)}.submit-btn{background:linear-gradient(135deg,#14b8a6,#0ea5e9);color:#fff;box-shadow:0 4px 6px -1px #0000001a}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#0f766e,#0284c7);transform:translateY(-2px);box-shadow:0 8px 15px -3px #0003}.submit-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.container{padding:0 1rem}.page-header{margin-bottom:2rem;padding:1.5rem}.page-header h1{font-size:2rem}.form-section{padding:1.5rem}.url-input-group{flex-direction:column;align-items:stretch}.extract-btn{margin-top:.5rem}.form-actions{flex-direction:column;padding:1.5rem}.meat-types-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (max-width: 480px){.page-header h1{font-size:1.75rem}.meat-types-grid{grid-template-columns:1fr}.image-preview{grid-template-columns:repeat(3,1fr)}}.search-section{background:linear-gradient(135deg,#14b8a6,#0ea5e9);color:#fff;padding:2rem;border-radius:1rem;margin-bottom:2rem;box-shadow:0 10px 25px -5px #0000001a}.search-section h3{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.search-section p{margin-bottom:1.5rem;opacity:.9;font-size:1rem}.search-inputs{display:flex;flex-direction:column;gap:1rem}.search-input-group{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:.75rem 1rem;border:2px solid rgba(255,255,255,.2);border-radius:.5rem;background:#ffffff1a;color:#fff;font-size:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.search-input::placeholder{color:#ffffffb3}.search-input:focus{outline:none;border-color:#fff9;background:#ffffff26;box-shadow:0 0 0 3px #ffffff1a}.search-btn{padding:.75rem 1.5rem;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:160px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.search-btn:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.search-btn:disabled{opacity:.6;cursor:not-allowed}.divider{display:flex;align-items:center;margin:2rem 0;color:#64748b;font-weight:500}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.divider span{margin:0 1rem;background:#f8fafc;padding:.5rem 1rem;border-radius:.5rem;border:1px solid #e2e8f0}@media (max-width: 768px){.search-input-group{flex-direction:column}.search-input{min-width:unset;width:100%}.search-btn{width:100%}}.voting-demo{max-width:1400px;margin:0 auto;padding:24px;background:#f8fafc;min-height:100vh}.demo-header{text-align:center;margin-bottom:40px;padding:32px;background:linear-gradient(135deg,#fff,#f0f9ff);border-radius:24px;border:1px solid #e0f2fe;box-shadow:0 4px 16px #00000014}.demo-header h1{font-size:32px;font-weight:800;color:#0c4a6e;margin:0 0 16px;letter-spacing:-.02em}.demo-header p{font-size:18px;color:#0369a1;margin:0;font-weight:500;line-height:1.5}.demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:32px;margin-bottom:48px}.demo-section{background:#fff;border-radius:20px;padding:24px;border:1px solid #e2e8f0;box-shadow:0 4px 16px #00000014;transition:all .3s ease}.demo-section:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001f}.demo-section h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 12px;display:flex;align-items:center;gap:8px}.demo-description{font-size:14px;color:#64748b;margin:0 0 20px;font-weight:500;line-height:1.4}.demo-instructions{background:#fff;border-radius:20px;padding:32px;border:1px solid #e2e8f0;box-shadow:0 4px 16px #00000014}.demo-instructions h3{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 24px;text-align:center;letter-spacing:-.01em}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.feature{padding:24px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:16px;border:1px solid #e2e8f0;transition:all .2s ease}.feature:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.feature h4{font-size:16px;font-weight:700;color:#1e293b;margin:0 0 12px;display:flex;align-items:center;gap:8px}.feature p{font-size:14px;color:#475569;margin:0;line-height:1.5;font-weight:500}.instructions-list{margin-bottom:32px;padding:24px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:16px;border:1px solid #bae6fd}.instructions-list h4{font-size:18px;font-weight:700;color:#0c4a6e;margin:0 0 16px;display:flex;align-items:center;gap:8px}.instructions-list ul{margin:0;padding-left:20px}.instructions-list li{font-size:14px;color:#0369a1;margin-bottom:8px;line-height:1.5;font-weight:500}.instructions-list strong{color:#0c4a6e}.design-principles{padding:24px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:16px;border:1px solid #bbf7d0}.design-principles h4{font-size:18px;font-weight:700;color:#166534;margin:0 0 20px;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.principles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.principle{text-align:center;padding:20px;background:#fff;border-radius:12px;border:1px solid #bbf7d0;transition:all .2s ease}.principle:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.principle h5{font-size:16px;font-weight:700;color:#166534;margin:0 0 8px}.principle p{font-size:13px;color:#16a34a;margin:0;line-height:1.4;font-weight:500}@media (max-width: 768px){.voting-demo{padding:16px}.demo-header{padding:24px 20px;margin-bottom:32px}.demo-header h1{font-size:28px}.demo-header p{font-size:16px}.demo-grid{grid-template-columns:1fr;gap:24px;margin-bottom:32px}.demo-section{padding:20px}.demo-instructions{padding:24px 20px}.features-grid{grid-template-columns:1fr;gap:20px}.feature{padding:20px}.principles-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}}@media (max-width: 480px){.voting-demo{padding:12px}.demo-header{padding:20px 16px}.demo-header h1{font-size:24px}.demo-header p{font-size:14px}.demo-section{padding:16px}.demo-instructions{padding:20px 16px}.feature{padding:16px}.instructions-list,.design-principles{padding:20px 16px}.principles-grid{grid-template-columns:1fr;gap:12px}}:root{--primary-50: #f0fdf9;--primary-100: #ccfbef;--primary-200: #99f6e0;--primary-300: #5eead4;--primary-400: #2dd4bf;--primary-500: #14b8a6;--primary-600: #0d9488;--primary-700: #0f766e;--primary-800: #115e59;--primary-900: #134e4a;--gray-50: #fafafa;--gray-100: #f4f4f5;--gray-200: #e4e4e7;--gray-300: #d4d4d8;--gray-400: #a1a1aa;--gray-500: #71717a;--gray-600: #52525b;--gray-700: #3f3f46;--gray-800: #27272a;--gray-900: #18181b;--emerald-500: #10b981;--amber-500: #f59e0b;--red-500: #ef4444;--blue-500: #3b82f6;--font-display: "Poppins", -apple-system, BlinkMacSystemFont, sans-serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-3xl: 2rem;--shadow-soft: 0 2px 8px rgba(0, 0, 0, .04);--shadow-medium: 0 4px 16px rgba(0, 0, 0, .08);--shadow-large: 0 8px 32px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .16);--header-height: 72px;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-body);font-size:1rem;line-height:1.6;color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:var(--header-height)}.container{width:100%;max-width:var(--container-xl);margin:0 auto;padding:0 var(--space-4)}@media (min-width: 640px){.container{padding:0 var(--space-6)}}@media (min-width: 1024px){.container{padding:0 var(--space-8)}}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2;color:var(--gray-900)}h1{font-size:3.5rem}h2{font-size:2.75rem}h3{font-size:2rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1.125rem}p{color:var(--gray-600);line-height:1.7}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-body);font-weight:600;font-size:.875rem;border:none;border-radius:var(--radius-lg);cursor:pointer;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-500));color:#fff;padding:var(--space-3) var(--space-6);box-shadow:var(--shadow-medium)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-large)}.btn-secondary{background:#fff;color:var(--gray-700);border:2px solid var(--gray-200);padding:var(--space-3) var(--space-6)}.btn-secondary:hover{border-color:var(--primary-300);color:var(--primary-700)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:1rem}.btn-icon{padding:var(--space-3);border-radius:var(--radius-md)}.card{background:#fff;border-radius:var(--radius-2xl);box-shadow:var(--shadow-soft);border:1px solid var(--gray-100);overflow:hidden;transition:all .3s ease}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-large)}.form-input{width:100%;padding:var(--space-4);border:2px solid var(--gray-200);border-radius:var(--radius-lg);font-size:1rem;transition:all .2s ease;background:#fff}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #14b8a61a}.grid{display:grid;gap:var(--space-6)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.text-center{text-align:center}.relative{position:relative}.absolute{position:absolute}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.text-primary{color:var(--primary-600)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-900{color:var(--gray-900)}.bg-white{background-color:#fff}.bg-gray-50{background-color:var(--gray-50)}.bg-primary-50{background-color:var(--primary-50)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-slide-up{animation:slideUp .4s ease-out}.loading-spinner{width:24px;height:24px;border:2px solid var(--gray-200);border-top:2px solid var(--primary-500);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
