*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #FF6B35;--primary-dark: #e55a28;--secondary: #004E89;--accent: #F7C948;--bg: #FEFAE0;--bg-dark: #1A1A2E;--card-bg: #ffffff;--text: #2D3436;--text-light: #636e72;--text-muted: #b2bec3;--border: #e0d8c8;--shadow: 0 4px 20px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .15);--radius: 12px;--radius-sm: 8px;--radius-lg: 20px}html,body,#root{height:100%;width:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text);background:var(--bg);background-image:radial-gradient(circle,rgba(0,0,0,.04) 1px,transparent 1px);background-size:20px 20px;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:Fredoka,sans-serif}button{cursor:pointer;font-family:inherit}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main{flex:1;position:relative;display:flex;flex-direction:column;overflow:hidden}.header{display:flex;align-items:center;gap:24px;padding:12px 24px;background:linear-gradient(135deg,var(--bg-dark) 0%,#16213E 100%);color:#fff;z-index:1000;box-shadow:0 4px 20px #0003;border-bottom:3px solid transparent;border-image:linear-gradient(90deg,var(--primary),var(--accent)) 1}.header-brand{display:flex;align-items:center;gap:12px;flex-shrink:0}.header-icon{font-size:2rem;animation:wobble 2s ease-in-out infinite}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.header-title{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.header-subtitle{font-size:.75rem;color:#fff9;font-weight:400}.header-search{flex:1;max-width:500px;display:flex;gap:8px}.search-input-wrapper{flex:1;position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted)}.search-input{width:100%;padding:10px 36px 10px 40px;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius);background:#ffffff14;color:#fff;font-size:.9rem;transition:all .3s;outline:none}.search-input::placeholder{color:#fff6}.search-input:focus{border-color:var(--primary);background:#ffffff1f}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#ffffff80;font-size:.85rem;padding:4px}.search-btn{padding:10px 20px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius);font-weight:600;font-size:.85rem;transition:all .2s}.search-btn:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));transform:translateY(-1px);box-shadow:0 4px 12px #ff6b3566}.header-count{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.count-number{font-family:Fredoka,sans-serif;font-size:1.5rem;font-weight:700;color:var(--accent);line-height:1;text-shadow:0 0 12px rgba(247,201,72,.5)}.count-label{font-size:.65rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.map-wrapper{flex:1;position:relative}.map-container{width:100%;height:100%;z-index:1}.map-legend{position:absolute;bottom:12px;left:12px;right:12px;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-sm);padding:6px 8px;z-index:999;box-shadow:var(--shadow);display:flex;flex-wrap:wrap;gap:2px 4px;max-height:64px;overflow-y:auto}.legend-item{display:inline-flex;align-items:center;gap:4px;font-size:.65rem;font-weight:500;color:var(--text);padding:2px 6px;border-radius:10px;border:1.5px solid transparent;background:none;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1.2}.legend-item:hover{background:#0000000f}.legend-item-active{border-color:var(--text);background:#00000014;font-weight:700}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 2px #0000000f}.map-popup .leaflet-popup-content-wrapper{border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important;padding:0!important}.map-popup .leaflet-popup-content{margin:0!important;width:280px!important}.popup-content{padding:16px}.popup-category{display:inline-block;padding:3px 10px;border-radius:20px;color:#fff;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.popup-name{font-family:Fredoka,sans-serif;font-size:1rem;font-weight:600;margin-bottom:4px;color:var(--text)}.popup-location{font-size:.8rem;color:var(--text-light);margin-bottom:8px}.popup-description{font-size:.8rem;color:var(--text-light);line-height:1.4;margin-top:8px}.popup-btn{display:block;width:100%;margin-top:12px;padding:8px 16px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.8rem;transition:all .2s}.popup-btn:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));box-shadow:0 4px 12px #ff6b3559}.filter-toggle{position:absolute;top:80px;left:16px;z-index:999;display:flex;align-items:center;gap:8px;padding:10px 18px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid transparent;border-radius:var(--radius);font-weight:600;font-size:.85rem;color:var(--text);box-shadow:var(--shadow);transition:all .3s}.filter-toggle:hover{border-color:var(--primary)}.filter-toggle-open{border-color:var(--primary);background:#fff}.filter-badge{width:8px;height:8px;background:var(--primary);border-radius:50%;animation:badgePulse 2s ease-in-out infinite}@keyframes badgePulse{0%,to{box-shadow:0 0 #ff6b3566}50%{box-shadow:0 0 0 4px #ff6b3500}}.filter-panel{position:absolute;top:124px;left:16px;z-index:999;width:300px;background:#fffffff7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:20px;transform:translateY(-10px);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.16,1,.3,1)}.filter-panel-open{transform:translateY(0);opacity:1;pointer-events:auto}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.filter-header h3{font-size:1rem;font-weight:600}.filter-clear{background:none;border:none;color:var(--primary);font-size:.8rem;font-weight:600}.filter-section{margin-bottom:16px}.filter-label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:8px}.filter-chips{display:flex;flex-wrap:wrap;gap:6px}.filter-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;background:var(--bg);border:2px solid var(--border);border-radius:20px;font-size:.75rem;font-weight:500;color:var(--text);transition:all .2s}.filter-chip:hover{border-color:var(--primary);transform:translateY(-1px)}.filter-chip-active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px #ff6b354d}.chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.filter-select{width:100%;padding:8px 12px;border:2px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:.85rem;color:var(--text);outline:none;transition:border-color .2s}.filter-select:focus{border-color:var(--primary)}.filter-range{width:100%;accent-color:var(--primary);margin-top:4px}.range-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);margin-top:2px}.action-bar{position:relative;z-index:100;display:flex}.list-toggle{flex:1;padding:10px;background:linear-gradient(135deg,var(--bg-dark),#16213E);color:#fff;border:none;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;transition:all .2s}.list-toggle:hover{background:linear-gradient(135deg,#16213E,var(--bg-dark));letter-spacing:2px}.random-pick-btn{padding:10px 20px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:1px;transition:all .2s;white-space:nowrap}.random-pick-btn:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary));letter-spacing:2px}.restaurant-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:20px 24px;max-height:40vh;overflow-y:auto;background:var(--bg)}.restaurant-card{background:var(--card-bg);border-radius:var(--radius);padding:16px;border-left:4px solid;box-shadow:var(--shadow);cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);animation:cardEnter .4s cubic-bezier(.16,1,.3,1) backwards}.restaurant-card:nth-child(1){animation-delay:0ms}.restaurant-card:nth-child(2){animation-delay:50ms}.restaurant-card:nth-child(3){animation-delay:.1s}.restaurant-card:nth-child(4){animation-delay:.15s}.restaurant-card:nth-child(5){animation-delay:.2s}.restaurant-card:nth-child(6){animation-delay:.25s}.restaurant-card:nth-child(7){animation-delay:.3s}.restaurant-card:nth-child(8){animation-delay:.35s}.restaurant-card:nth-child(9){animation-delay:.4s}.restaurant-card:nth-child(10){animation-delay:.45s}.restaurant-card:nth-child(11){animation-delay:.5s}.restaurant-card:nth-child(12){animation-delay:.55s}@keyframes cardEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.restaurant-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 12px 32px #0000001f}.restaurant-card:hover .card-name{color:var(--primary)}.restaurant-card-active{outline:2px solid var(--primary);outline-offset:2px;box-shadow:0 0 0 4px #ff6b3526,var(--shadow)}.card-header{margin-bottom:8px}.card-category{display:inline-block;padding:2px 8px;border-radius:12px;color:#fff;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.card-name{font-size:1rem;font-weight:600;margin-bottom:2px;transition:color .2s}.card-location{font-size:.8rem;color:var(--text-light);margin-bottom:6px}.card-description{font-size:.8rem;color:var(--text-light);line-height:1.4;margin-top:8px}.rating-stars{display:flex;align-items:center;gap:6px}.stars-container{display:flex;gap:1px}.star{color:var(--border);transition:all .15s;-webkit-user-select:none;user-select:none}.star-filled{color:var(--accent)}.star-half{color:var(--accent);opacity:.5}.star-interactive{cursor:pointer}.star-interactive:hover{transform:scale(1.2)}.stars-sm .star{font-size:.85rem}.stars-md .star{font-size:1.1rem}.stars-lg .star{font-size:1.6rem}.rating-count{font-size:.75rem;color:var(--text-light)}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.detail-modal{background:#fff;border-radius:var(--radius-lg);max-width:540px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s cubic-bezier(.16,1,.3,1);position:relative}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.detail-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:50%;border:none;background:#0000000f;color:var(--text-light);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1}.detail-close:hover{background:#0000001f;color:var(--text);transform:rotate(90deg)}.detail-header{padding:28px 28px 20px;border-bottom:3px solid;background:linear-gradient(180deg,rgba(254,250,224,.3) 0%,transparent 100%)}.detail-category{display:inline-block;padding:4px 14px;border-radius:20px;color:#fff;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.detail-name{font-size:1.5rem;font-weight:700;margin-bottom:6px;line-height:1.2}.detail-location{font-size:.85rem;color:var(--text-light)}.detail-body{padding:24px 28px 28px}.detail-rating-section{margin-bottom:16px}.detail-description{font-size:.95rem;line-height:1.65;color:var(--text);margin-bottom:20px}.detail-quirky{background:linear-gradient(135deg,#fff8e7,#fff3d0);border-radius:var(--radius);padding:16px 16px 16px 20px;margin-bottom:20px;border-left:4px solid var(--accent);position:relative}.detail-quirky:before{content:"“";position:absolute;top:-8px;left:12px;font-size:3rem;font-family:Fredoka,serif;color:var(--accent);opacity:.3;line-height:1}.quirky-label{font-family:Fredoka,sans-serif;font-size:.85rem;font-weight:600;color:var(--primary);margin-bottom:6px}.quirky-text{font-size:.85rem;line-height:1.5;color:var(--text)}.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}.detail-tag{padding:5px 12px;background:linear-gradient(135deg,var(--bg),#f0ead6);border-radius:20px;font-size:.75rem;color:var(--text-light);font-weight:500;transition:all .2s}.detail-tag:hover{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;transform:translateY(-1px)}.detail-rate{background:linear-gradient(135deg,#f8f9fa,#fff8e7);border-radius:var(--radius);padding:20px;text-align:center}.detail-rate h4{font-size:1rem;margin-bottom:12px;color:var(--text)}.detail-rate .rating-stars{justify-content:center}.rate-thanks{color:var(--primary);font-weight:600}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fefae0d9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:998;gap:12px}.loading-spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-right-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay p{font-family:Fredoka,sans-serif;font-size:1rem;color:var(--text-light)}.error-banner{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:998;background:#ffeef0;border:2px solid #ffb8c1;border-radius:var(--radius);padding:12px 24px;display:flex;align-items:center;gap:12px;animation:slideDown .3s cubic-bezier(.16,1,.3,1)}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.error-banner p{font-size:.85rem;color:var(--text)}.error-banner button{padding:6px 16px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.8rem}.empty-state{grid-column:1 / -1;text-align:center;padding:40px}.empty-icon{font-size:3rem;margin-bottom:12px;animation:emptyBounce 2s ease-in-out infinite}@keyframes emptyBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.empty-state p{color:var(--text-light);margin-bottom:12px}.empty-state button{padding:8px 20px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600}.restaurant-list::-webkit-scrollbar{width:6px}.restaurant-list::-webkit-scrollbar-track{background:transparent}.restaurant-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--primary),var(--accent));border-radius:3px}.detail-modal::-webkit-scrollbar{width:6px}.detail-modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-dark)}.admin-login-form{background:#fff;padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:360px;text-align:center}.admin-login-form h2{font-family:Fredoka,sans-serif;margin-bottom:24px;color:var(--text)}.admin-login-form input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;margin-bottom:16px;outline:none;transition:border-color .2s}.admin-login-form input:focus{border-color:var(--primary)}.admin-login-form button{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;transition:background .2s}.admin-login-form button:hover{background:var(--primary-dark)}.admin-error{color:#c4302b;font-size:.85rem;margin-top:12px}.admin-page{min-height:100vh;background:#f0f0f0}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--bg-dark);color:#fff}.admin-header h1{font-family:Fredoka,sans-serif;font-size:1.3rem}.admin-header button{padding:8px 20px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);font-weight:500;transition:all .2s}.admin-header button:hover{background:#fff3}.admin-message{display:flex;align-items:center;justify-content:space-between;padding:12px 32px;background:#d4edda;color:#155724;font-weight:500;font-size:.9rem}.admin-message-error{background:#f8d7da;color:#721c24}.admin-message button{background:none;border:none;color:inherit;font-weight:600;text-decoration:underline;font-size:.8rem}.admin-form-section{padding:24px 32px}.admin-form-section h2{font-family:Fredoka,sans-serif;font-size:1.1rem;margin-bottom:16px}.admin-form{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.admin-field{display:flex;flex-direction:column;gap:4px}.admin-field-full{grid-column:1 / -1}.admin-field label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light)}.admin-field input,.admin-field textarea{padding:10px 12px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s;resize:vertical}.admin-field input:focus,.admin-field textarea:focus{border-color:var(--primary)}.admin-form-actions{display:flex;gap:12px;margin-top:20px}.admin-form-actions button{padding:10px 24px;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;transition:all .2s}.admin-form-actions button[type=submit]{background:var(--primary);color:#fff}.admin-form-actions button[type=submit]:hover{background:var(--primary-dark)}.admin-form-actions button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.admin-btn-cancel{background:#e0e0e0!important;color:var(--text)!important}.admin-btn-cancel:hover{background:#d0d0d0!important}.admin-table-section{padding:0 32px 32px}.admin-table-section h2{font-family:Fredoka,sans-serif;font-size:1.1rem;margin-bottom:16px}.admin-table-wrapper{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:12px 16px;background:#f8f9fa;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);border-bottom:2px solid var(--border);white-space:nowrap}.admin-table td{padding:10px 16px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.admin-table tr:hover{background:#fafafa}.admin-row-editing{background:#fff8e7!important}.admin-cell-name{font-weight:600;max-width:280px}.admin-cell-actions{white-space:nowrap;display:flex;gap:6px}.admin-btn-edit,.admin-btn-delete{padding:4px 12px;border:none;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.admin-btn-edit{background:var(--secondary);color:#fff}.admin-btn-edit:hover{opacity:.85}.admin-btn-delete{background:#c4302b;color:#fff}.admin-btn-delete:hover{opacity:.85}@media (max-width: 768px){.header{flex-wrap:wrap;gap:12px;padding:12px 16px}.header-subtitle{white-space:normal}.header-search{order:3;max-width:100%;flex-basis:100%}.header-count{margin-left:auto}.filter-panel{width:calc(100% - 32px)}.map-legend{bottom:8px;left:8px;right:8px;padding:4px 6px;max-height:56px;gap:2px 3px}.legend-item{font-size:.55rem;padding:1px 4px;gap:3px}.legend-dot{width:7px;height:7px}.restaurant-list{grid-template-columns:1fr;padding:12px}.detail-modal{max-height:90vh;border-radius:var(--radius) var(--radius) 0 0}.detail-overlay{align-items:flex-end;padding:0}.admin-form-grid{grid-template-columns:1fr}.admin-form-section{padding:16px}.admin-table-section{padding:0 16px 16px}.admin-table-wrapper{-webkit-overflow-scrolling:touch}.admin-table{min-width:600px}.admin-header{padding:12px 16px}}.header-brand-link{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}.header-auth{flex-shrink:0}.header-auth-buttons{display:flex;gap:8px}.header-login-btn,.header-signup-btn{padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:.8rem;text-decoration:none;transition:all .2s}.header-login-btn{color:#fff;background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.header-login-btn:hover{background:#fff3}.header-signup-btn{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-dark))}.header-signup-btn:hover{box-shadow:0 4px 12px #ff6b3566}.header-user{position:relative}.header-user-btn{display:flex;align-items:center;gap:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:6px 12px;color:#fff;font-size:.85rem;transition:all .2s}.header-user-btn:hover{background:#ffffff26}.header-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff;flex-shrink:0}.header-username{font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-points-badge{background:var(--accent);color:var(--bg-dark);padding:2px 8px;border-radius:12px;font-size:.7rem;font-weight:700}.header-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:200px;z-index:1001;overflow:hidden;animation:slideDown .2s cubic-bezier(.16,1,.3,1)}.header-dropdown-info{padding:12px 16px;border-bottom:1px solid var(--border)}.header-dropdown-name{display:block;font-weight:600;color:var(--text);font-size:.9rem}.header-dropdown-rank{font-size:.75rem;color:var(--primary);font-weight:600}.header-dropdown-divider{height:1px;background:var(--border)}.header-dropdown-item{display:block;padding:10px 16px;font-size:.85rem;color:var(--text);text-decoration:none;transition:background .15s;border:none;background:none;width:100%;text-align:left;cursor:pointer;font-family:inherit}.header-dropdown-item:hover{background:var(--bg)}.header-dropdown-logout{color:#c4302b}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-dark);padding:20px}.auth-form{background:#fff;padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px}.auth-form h2{font-family:Fredoka,sans-serif;font-size:1.5rem;margin-bottom:4px;color:var(--text);text-align:center}.auth-subtitle{text-align:center;color:var(--text-light);font-size:.85rem;margin-bottom:24px}.auth-field{margin-bottom:16px}.auth-field label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin-bottom:6px}.auth-field input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;outline:none;transition:border-color .2s;font-family:inherit}.auth-field input:focus{border-color:var(--primary)}.auth-hint{font-size:.7rem;color:var(--text-muted);margin-top:4px;display:block}.auth-error{color:#c4302b;font-size:.85rem;text-align:center;margin-bottom:12px;padding:8px 12px;background:#ffeef0;border-radius:var(--radius-sm)}.auth-submit{width:100%;padding:12px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;transition:all .2s;cursor:pointer}.auth-submit:hover{box-shadow:0 4px 12px #ff6b3566;transform:translateY(-1px)}.auth-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-switch{text-align:center;margin-top:20px;font-size:.85rem;color:var(--text-light)}.auth-switch a{color:var(--primary);font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.user-badge{display:inline-flex;align-items:center;gap:6px}.user-badge-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.65rem;color:#fff;flex-shrink:0}.user-badge-name{font-weight:600;font-size:.85rem;color:var(--text)}.user-badge-name:hover{color:var(--primary)}.user-badge-rank{font-size:.65rem;font-weight:600;color:var(--primary);background:#ff6b351a;padding:1px 6px;border-radius:8px}.profile-page{min-height:100vh;background:var(--bg)}.profile-header-bar,.leaderboard-header-bar,.suggest-header-bar{display:flex;align-items:center;gap:16px;padding:16px 32px;background:var(--bg-dark);color:#fff}.profile-header-bar h1,.leaderboard-header-bar h1,.suggest-header-bar h1{font-family:Fredoka,sans-serif;font-size:1.3rem}.back-link{color:#ffffffb3;text-decoration:none;font-size:.85rem;font-weight:500;transition:color .2s}.back-link:hover{color:#fff}.profile-card{max-width:700px;margin:24px auto;background:#fff;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow);display:flex;gap:24px;align-items:flex-start}.profile-avatar-large{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.8rem;color:#fff;flex-shrink:0}.profile-info{flex:1}.profile-display-name{font-size:1.5rem;font-weight:700;margin-bottom:2px}.profile-username{font-size:.85rem;color:var(--text-light);margin-bottom:8px}.profile-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}.profile-rank-badge{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:3px 10px;border-radius:12px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.profile-points{font-size:.8rem;font-weight:600;color:var(--accent)}.profile-joined{font-size:.75rem;color:var(--text-muted)}.profile-bio{font-size:.9rem;color:var(--text-light);line-height:1.5}.profile-stats{display:flex;gap:20px;flex-shrink:0}.profile-stat{text-align:center}.profile-stat-number{display:block;font-family:Fredoka,sans-serif;font-size:1.3rem;font-weight:700;color:var(--text)}.profile-stat-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.profile-tabs{display:flex;justify-content:center;gap:4px;max-width:700px;margin:0 auto;padding:0 32px}.profile-tab{padding:10px 20px;background:none;border:none;border-bottom:3px solid transparent;font-weight:600;font-size:.85rem;color:var(--text-light);transition:all .2s}.profile-tab:hover{color:var(--text)}.profile-tab-active{color:var(--primary);border-bottom-color:var(--primary)}.profile-tab-content{max-width:700px;margin:16px auto;padding:0 32px}.profile-items{display:flex;flex-direction:column;gap:8px}.profile-item{background:#fff;padding:12px 16px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 1px 4px #0000000f}.profile-item-comment{flex-direction:column;align-items:flex-start}.profile-item-comment p{font-size:.85rem;color:var(--text-light);margin-top:4px}.profile-item-date{font-size:.75rem;color:var(--text-muted)}.profile-item-rating{color:var(--accent);font-size:.9rem;letter-spacing:1px}.leaderboard-page{min-height:100vh;background:var(--bg)}.leaderboard-content{max-width:700px;margin:24px auto;padding:0 32px}.leaderboard-table{width:100%;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border-collapse:collapse}.leaderboard-table th{text-align:left;padding:12px 16px;background:#f8f9fa;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);border-bottom:2px solid var(--border)}.leaderboard-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.leaderboard-position{font-family:Fredoka,sans-serif;font-weight:700;font-size:1.1rem;color:var(--text-muted);width:40px}.leaderboard-top-1 .leaderboard-position{color:gold}.leaderboard-top-2 .leaderboard-position{color:silver}.leaderboard-top-3 .leaderboard-position{color:#cd7f32}.leaderboard-user{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}.leaderboard-user:hover .leaderboard-name{color:var(--primary)}.leaderboard-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}.leaderboard-name{font-weight:600;transition:color .2s}.leaderboard-rank{font-size:.75rem;font-weight:600;color:var(--primary)}.leaderboard-points{font-family:Fredoka,sans-serif;font-weight:700;color:var(--accent)}.suggest-page{min-height:100vh;background:var(--bg)}.suggest-content{max-width:700px;margin:24px auto;padding:0 32px}.suggest-type-toggle{display:flex;gap:4px;margin-bottom:20px;background:#fff;border-radius:var(--radius);padding:4px;box-shadow:var(--shadow)}.suggest-type-btn{flex:1;padding:10px;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;background:none;color:var(--text-light);transition:all .2s}.suggest-type-active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #ff6b354d}.suggest-search{margin-bottom:20px}.suggest-search label{display:block;font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:8px}.suggest-search-input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;outline:none;font-family:inherit}.suggest-search-input:focus{border-color:var(--primary)}.suggest-search-results{background:#fff;border:2px solid var(--border);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);max-height:250px;overflow-y:auto}.suggest-search-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-family:inherit;font-size:.85rem;cursor:pointer;transition:background .15s}.suggest-search-item:hover{background:var(--bg)}.suggest-search-item span{color:var(--text-light);font-size:.8rem}.suggest-form{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.suggest-correcting{padding:10px 16px;background:#fff8e7;border-radius:var(--radius-sm);margin-bottom:16px;font-size:.85rem;display:flex;align-items:center;gap:8px}.suggest-change-btn{background:none;border:none;color:var(--primary);font-weight:600;font-size:.8rem;margin-left:auto;cursor:pointer}.suggest-correction-link{color:var(--primary);font-size:.8rem;font-weight:600;text-decoration:none}.suggest-correction-link:hover{text-decoration:underline}.suggest-success{color:#155724;background:#d4edda;padding:10px 16px;border-radius:var(--radius-sm);font-size:.85rem;text-align:center;margin-bottom:12px}.suggestion-status{padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:600;text-transform:uppercase}.suggestion-status-pending{background:#fff3cd;color:#856404}.suggestion-status-approved{background:#d4edda;color:#155724}.suggestion-status-rejected{background:#f8d7da;color:#721c24}.visit-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:2px solid var(--primary);border-radius:var(--radius);background:#fff;font-weight:600;font-size:.9rem;color:var(--primary);transition:all .2s;cursor:pointer}.visit-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}.visit-btn-visited{background:var(--secondary);border-color:var(--secondary);color:#fff}.visit-btn-visited:hover{opacity:.9;border-color:var(--secondary);color:#fff}.visit-count{font-size:.75rem;color:var(--text-muted);margin-top:4px}.comments-section{margin-top:24px;border-top:2px solid var(--border);padding-top:20px}.comments-section h4{margin-bottom:16px}.comment-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.comment-item{padding:12px;background:#f8f9fa;border-radius:var(--radius-sm)}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.comment-meta{display:flex;align-items:center;gap:8px}.comment-date{font-size:.7rem;color:var(--text-muted)}.comment-actions{display:flex;gap:8px}.comment-action-btn{background:none;border:none;font-size:.75rem;color:var(--text-muted);cursor:pointer;padding:2px 4px}.comment-action-btn:hover{color:var(--primary)}.comment-text{font-size:.85rem;color:var(--text);line-height:1.5}.comment-form{display:flex;gap:8px}.comment-input{flex:1;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;font-family:inherit;resize:none;outline:none;min-height:60px}.comment-input:focus{border-color:var(--primary)}.comment-submit{align-self:flex-end;padding:10px 16px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.8rem;cursor:pointer;transition:background .2s}.comment-submit:hover{background:var(--primary-dark)}.comment-submit:disabled{opacity:.6;cursor:not-allowed}.comment-login-prompt{text-align:center;padding:16px;color:var(--text-light);font-size:.85rem}.comment-login-prompt a{color:var(--primary);font-weight:600;text-decoration:none}.admin-suggestions{padding:0 32px 24px}.admin-suggestions h2{font-family:Fredoka,sans-serif;font-size:1.1rem;margin-bottom:16px;display:flex;align-items:center;gap:8px}.admin-pending-badge{background:var(--primary);color:#fff;padding:2px 10px;border-radius:12px;font-size:.75rem}.suggestion-cards{display:grid;gap:16px}.suggestion-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.suggestion-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.suggestion-card-type{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:3px 10px;border-radius:8px}.suggestion-card-type-new{background:#d4edda;color:#155724}.suggestion-card-type-correction{background:#cce5ff;color:#004085}.suggestion-card-data{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:.8rem;margin-bottom:12px}.suggestion-card-data dt{font-weight:600;color:var(--text-light)}.suggestion-card-data dd{color:var(--text)}.suggestion-card-reason{font-size:.85rem;color:var(--text-light);font-style:italic;margin-bottom:16px;padding:8px 12px;background:#f8f9fa;border-radius:var(--radius-sm)}.suggestion-card-actions{display:flex;gap:8px}.suggestion-approve-btn,.suggestion-reject-btn{flex:1;padding:8px 16px;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.8rem;cursor:pointer;transition:opacity .2s}.suggestion-approve-btn{background:#28a745;color:#fff}.suggestion-reject-btn{background:#dc3545;color:#fff}.suggestion-approve-btn:hover,.suggestion-reject-btn:hover{opacity:.9}.admin-moderation{padding:0 32px 24px}.admin-moderation h2{font-family:Fredoka,sans-serif;font-size:1.1rem;margin-bottom:16px}.moderation-section{margin-bottom:24px}.moderation-section h3{font-size:.95rem;margin-bottom:12px;display:flex;align-items:center;gap:8px}.moderation-cards{display:grid;gap:12px}.moderation-card{background:#fff;border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow)}.moderation-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.moderation-card-author{font-weight:600;font-size:.85rem;color:var(--text)}.moderation-card-context{margin-left:6px;font-size:.8rem;color:var(--text-light)}.moderation-card-date{font-size:.75rem;color:#b2bec3;white-space:nowrap}.moderation-card-text{font-size:.85rem;color:var(--text);margin-bottom:12px;padding:8px 12px;background:#f8f9fa;border-radius:var(--radius-sm);word-break:break-word}.moderation-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.75rem;flex-shrink:0}.moderation-user-meta{display:flex;gap:12px;font-size:.8rem;color:var(--text-light);margin-bottom:12px}.moderation-card-actions{display:flex;justify-content:flex-end}.moderation-protected{font-size:.75rem;font-weight:600;color:#636e72;padding:4px 12px;background:#f0f0f0;border-radius:var(--radius-sm)}.page-loading{text-align:center;padding:60px 20px;color:var(--text-light);font-size:1rem}.page-error{text-align:center;padding:60px 20px}.page-error h2{margin-bottom:12px}.page-error a{color:var(--primary);font-weight:600}.tab-loading,.tab-empty{text-align:center;padding:32px;color:var(--text-light)}@media (max-width: 768px){.header{flex-wrap:wrap;gap:12px;padding:12px 16px}.header-subtitle{white-space:normal}.header-search{order:3;max-width:100%;flex-basis:100%}.header-count{margin-left:auto}.header-auth{order:2}.header-username{display:none}.filter-panel{width:calc(100% - 32px)}.map-legend{bottom:8px;left:8px;right:8px;padding:4px 6px;max-height:56px;gap:2px 3px}.legend-item{font-size:.55rem;padding:1px 4px;gap:3px}.legend-dot{width:7px;height:7px}.restaurant-list{grid-template-columns:1fr;padding:12px}.detail-modal{max-height:90vh;border-radius:var(--radius) var(--radius) 0 0}.detail-overlay{align-items:flex-end;padding:0}.admin-form-grid{grid-template-columns:1fr}.admin-form-section{padding:16px}.admin-table-section{padding:0 16px 16px}.admin-table-wrapper{-webkit-overflow-scrolling:touch}.admin-table{min-width:600px}.admin-header{padding:12px 16px}.profile-card{flex-direction:column;align-items:center;text-align:center;margin:16px;padding:24px 16px}.profile-meta{justify-content:center}.profile-tabs{padding:0 16px}.profile-tab{padding:8px 12px;font-size:.8rem}.profile-tab-content,.leaderboard-content,.suggest-content{padding:0 16px}.profile-header-bar,.leaderboard-header-bar,.suggest-header-bar{padding:12px 16px}.admin-suggestions,.admin-moderation{padding:0 16px 24px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
