:root{--color-primary: #FF4458;--color-primary-hover: #E8364A;--color-secondary: #4CD964;--color-danger: #FF3B30;--color-background: #F3F5F7;--color-card-bg: #FFFFFF;--color-text-main: #11142D;--color-text-secondary: #808191;--color-border: #E4E4E4;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-size-base: 16px;--font-size-sm: 14px;--font-size-lg: 20px;--font-size-xl: 28px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--shadow-sm: 0px 2px 8px rgba(0, 0, 0, .05);--shadow-card: 0px 10px 40px rgba(0, 0, 0, .08);--shadow-float: 0px 16px 32px rgba(0, 0, 0, .12)}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-text-main);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;min-height:-webkit-fill-available;overflow:hidden;position:fixed;width:100%;height:100%}#root{width:100%;height:100%;display:flex;flex-direction:column;max-width:600px;margin:0 auto;background-color:var(--color-background);position:relative}button{border:none;background:none;cursor:pointer;font-family:inherit;outline:none}img{max-width:100%;display:block}.flex-center{display:flex;align-items:center;justify-content:center}.flex-col{display:flex;flex-direction:column}.full-height{height:100%}.app-layout{width:100%;height:100%;position:relative;overflow:hidden}.card-container{position:absolute;width:100%;height:100%;max-width:unset;border-radius:0;overflow:hidden;box-shadow:var(--shadow-card);background-color:var(--color-card-bg);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;transform-origin:50% 100%;will-change:transform,opacity}.card-container:active{cursor:grabbing}.card-image{width:100%;height:100%;object-fit:cover;pointer-events:none}.card-info{position:absolute;top:0;left:0;width:100%;padding:var(--spacing-lg);background:linear-gradient(to bottom,#000c,#0006,#0000);color:#fff;pointer-events:none}.card-title{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-xs);text-shadow:0 2px 4px rgba(0,0,0,.3)}.card-restaurant{font-size:var(--font-size-base);opacity:.9;display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.card-details{display:flex;gap:var(--spacing-md);font-size:var(--font-size-sm);opacity:.8}.card-tag{background:#fff3;padding:4px 8px;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-size:13px;font-weight:600}.card-meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.card-tag.cuisine{background:#ffffff40}.card-tag.dietary{background:#4cd9644d;border:1px solid rgba(76,217,100,.5)}.card-tag.allergens{background:#ff3b304d;border:1px solid rgba(255,59,48,.5);font-size:12px}.action-buttons-container{display:flex;gap:var(--spacing-xl);justify-content:center;align-items:center;padding:var(--spacing-md);width:100%;pointer-events:auto}.action-btn-circle{width:64px;height:64px;border-radius:50%;border:none;background:#fff;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;transition:transform .1s,box-shadow .1s}.action-btn-circle:active{transform:scale(.95);box-shadow:0 2px 6px #0000001a}.btn-dislike{color:var(--color-danger);border:1px solid #ffeae8}.btn-like{color:var(--color-secondary);color:#4cd964;border:1px solid #e8f9eb}.filter-modal-content{background:#fff;width:100%;max-width:500px;height:80vh;border-top-left-radius:20px;border-top-right-radius:20px;display:flex;flex-direction:column;position:relative;animation:slideUp .3s ease-out forwards;transform:translateY(100%)}@media(min-width:600px){.filter-modal-content{height:auto;max-height:80vh;border-radius:20px}}.filter-header{padding:16px 20px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.filter-header h3{font-size:18px;font-weight:700}.close-text-btn{background:none;border:none;color:var(--color-text-secondary);font-size:16px;cursor:pointer}.filter-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:24px}.filter-section h4{font-size:16px;font-weight:600;margin-bottom:8px}.filter-subtitle{font-size:12px;color:var(--color-text-secondary);margin-bottom:12px;margin-top:-4px}.chip-grid{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:8px 16px;border-radius:20px;border:1px solid var(--color-border);background:#f8f9fa;color:var(--color-text-main);font-size:14px;cursor:pointer;transition:all .2s}.filter-chip.selected{background:#fff2f2;border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.distance-control{display:flex;align-items:center;gap:16px}.distance-slider{flex:1;accent-color:var(--color-primary)}.filter-footer{padding:16px 20px;border-top:1px solid #eee;background:#fff}.apply-btn{width:100%;padding:14px;background:linear-gradient(45deg,var(--color-primary),#FF7D54);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #ff3e3b33}.apply-btn:active{transform:scale(.98)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;z-index:2000;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;animation:fadeIn .3s forwards}@keyframes fadeIn{to{opacity:1}}.modal-content{background:#fff;width:100%;max-width:500px;height:85vh;border-top-left-radius:24px;border-top-right-radius:24px;overflow-y:auto;position:relative;transform:translateY(100%);animation:slideUp .3s cubic-bezier(.16,1,.3,1) forwards;display:flex;flex-direction:column}@media(min-width:600px){.modal-overlay{align-items:center}.modal-content{height:auto;max-height:85vh;border-radius:24px;transform:translateY(20px);opacity:0;animation:scaleIn .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes scaleIn{to{transform:translateY(0);opacity:1}}}@keyframes slideUp{to{transform:translateY(0)}}.modal-close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;background:#00000080;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:10;font-size:20px;cursor:pointer;border:none}.modal-image{width:100%;height:300px;object-fit:cover;flex-shrink:0}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-title{font-size:24px;font-weight:800;color:var(--color-text-main);line-height:1.2}.modal-restaurant-info{display:flex;align-items:center;gap:8px;color:var(--color-text-secondary);font-size:14px;font-weight:500}.modal-meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.modal-tag{padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600}.modal-tag.cuisine{background:#f0f0f0;color:var(--color-text-secondary)}.modal-tag.dietary{background:#4cd96426;color:#2d8a3c;border:1px solid rgba(76,217,100,.3)}.modal-tag.allergens{background:#ff3b301a;color:#d32f2f;border:1px solid rgba(255,59,48,.3)}.modal-price{font-size:18px;font-weight:600;color:var(--color-primary)}.modal-description{font-size:16px;line-height:1.6;color:#4a4a4a}.modal-actions{display:flex;flex-direction:column;gap:12px;margin-top:12px}.map-link-container{display:block;width:100%;height:120px;border-radius:12px;overflow:hidden;position:relative;border:1px solid var(--color-border);text-decoration:none}.map-placeholder-image{width:100%;height:100%;object-fit:cover;background-image:url(https://images.unsplash.com/photo-1524661135-423995f22d0b?auto=format&fit=crop&w=600&q=80);background-size:cover;background-position:center;transition:transform .3s}.map-link-container:hover .map-placeholder-image{transform:scale(1.05)}.map-overlay-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;padding:8px 16px;border-radius:20px;font-weight:600;font-size:14px;color:var(--color-text-main);box-shadow:0 2px 8px #0003;display:flex;align-items:center;gap:6px}.opentable-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px;background-color:#da3743;color:#fff;font-weight:700;font-size:16px;border-radius:12px;text-decoration:none;box-shadow:0 4px 12px #da37434d;transition:transform .1s}.opentable-btn:active{transform:scale(.98)}.likes-container{padding:var(--spacing-md);padding-top:80px;padding-bottom:40px}.likes-grid{display:grid;gap:var(--spacing-md);grid-template-columns:1fr}@media(min-width:500px){.likes-grid{grid-template-columns:repeat(2,1fr)}}.like-item{background:var(--color-card-bg);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;transition:transform .2s;position:relative}.like-item:active{transform:scale(.98)}.like-image{width:100px;height:100px;object-fit:cover;flex-shrink:0}.like-content{padding:var(--spacing-sm);display:flex;flex-direction:column;justify-content:center;flex:1}.like-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:4px}.like-restaurant{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.like-actions{display:flex;gap:var(--spacing-sm);margin-top:auto}.action-btn{font-size:12px;padding:6px 12px;border-radius:var(--radius-full);text-decoration:none;font-weight:600;display:flex;align-items:center;justify-content:center;flex:1;text-align:center}.btn-map{background-color:#ebf0ff;color:#007aff}.btn-reserve{background-color:#fff2f2;color:#ff3b30}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh}.bottom-nav{position:fixed;bottom:0;left:0;width:100%;height:60px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--color-border);display:flex;justify-content:space-around;align-items:center;z-index:1000;padding-bottom:env(safe-area-inset-bottom)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:var(--color-text-secondary);height:100%;padding:8px 0;transition:color .2s}.nav-item.active{color:var(--color-primary)}.nav-icon{font-size:20px;margin-bottom:2px}.nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.profile-container{padding-top:80px;padding-bottom:80px;background:#f8f9fa;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column}.profile-header{display:flex;flex-direction:column;align-items:center;padding:20px;background:#fff;box-shadow:0 1px 3px #0000000d;margin-bottom:16px}.profile-avatar{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid white;box-shadow:0 4px 12px #0000001a;margin-bottom:12px}.profile-name{font-size:24px;font-weight:700;color:var(--color-text-main);margin:0}.profile-email{font-size:14px;color:var(--color-text-secondary);margin:4px 0 0}.profile-scroll-content{padding:0 16px;display:flex;flex-direction:column;gap:16px}.profile-section{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 8px #0000000d}.section-title{font-size:18px;font-weight:700;margin-bottom:12px;color:var(--color-text-main)}.section-subtitle{font-size:14px;color:var(--color-text-secondary);margin-bottom:16px}.info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #eee}.info-row:last-child{border-bottom:none}.info-label{color:var(--color-text-secondary);font-weight:500}.info-value{font-weight:600;color:var(--color-text-main)}.allergy-grid{display:flex;flex-wrap:wrap;gap:10px}.allergy-chip{padding:8px 16px;border-radius:20px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-secondary);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.allergy-chip.selected{background:#fff2f2;border-color:var(--color-primary);color:var(--color-primary)}.check-icon{font-size:12px}.settings-btn{width:100%;text-align:left;padding:12px 0;background:none;border:none;border-bottom:1px solid #eee;font-size:16px;color:var(--color-text-main);cursor:pointer}.settings-btn.logout{color:#ff3b30;font-weight:600;border-bottom:none}.profile-close-btn{position:fixed;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:#fff;box-shadow:0 4px 12px #00000026;border:none;font-size:20px;font-weight:700;color:#333;z-index:1100;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s}.profile-close-btn:active{transform:scale(.9)}
