:root{--color-primary: #FF6B6B;--color-primary-light: #FF8E8E;--color-primary-dark: #E55555;--color-secondary: #4ECDC4;--color-secondary-light: #7EDDD6;--color-secondary-dark: #3EBDB4;--color-accent: #FFE66D;--color-accent-light: #FFED9E;--color-accent-dark: #F5D84A;--color-purple: #A28BD4;--color-orange: #FFA06D;--color-blue: #6BC5F8;--color-white: #FFFFFF;--color-gray-50: #FAFAFA;--color-gray-100: #F5F5F5;--color-gray-200: #EEEEEE;--color-gray-300: #E0E0E0;--color-gray-400: #BDBDBD;--color-gray-500: #9E9E9E;--color-gray-600: #757575;--color-gray-700: #616161;--color-gray-800: #424242;--color-gray-900: #212121;--color-black: #1A1A1A;--color-success: #66D9A0;--color-warning: #FFD166;--color-error: #FF6B6B;--color-info: #6BC5F8;--bg-primary: #FFFBF5;--bg-secondary: #FFF5F5;--bg-card: #FFFFFF;--font-family-base: "Quicksand", "M PLUS Rounded 1c", "Hiragino Maru Gothic ProN", sans-serif;--font-family-heading: "Quicksand", "M PLUS Rounded 1c", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-0: 0;--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;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--radius-full: 9999px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .15);--shadow-primary: 0 4px 14px rgba(255, 107, 107, .3);--shadow-secondary: 0 4px 14px rgba(78, 205, 196, .3);--shadow-accent: 0 4px 14px rgba(255, 230, 109, .4);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-toast: 500;--container-max-width: 1024px;--sidebar-width: 280px;--header-height: 64px;--bottom-nav-height: 72px;--color-status-open: var(--color-secondary);--color-status-confirmed: var(--color-success);--color-status-cancelled: var(--color-gray-400);--color-pref-like: var(--color-secondary);--color-pref-dislike: var(--color-orange);--color-pref-allergy: var(--color-error);--color-ai: var(--color-purple);--color-ai-light: rgba(162, 139, 212, .12);--color-score-high: var(--color-success);--color-score-mid: var(--color-warning);--color-score-low: var(--color-error);--color-rank-1: var(--color-accent);--color-rank-2: var(--color-gray-300);--color-rank-3: var(--color-orange)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-gray-800);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.text-xs{font-size:var(--font-size-xs)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-gray-900)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);line-height:1;text-decoration:none;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal);-webkit-user-select:none;user-select:none}.btn:active{transform:scale(.96)}.btn-primary{background:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-primary)}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:0 6px 20px #ff6b6b66;transform:translateY(-2px)}.btn-secondary{background:var(--color-secondary);color:var(--color-white);box-shadow:var(--shadow-secondary)}.btn-secondary:hover{background:var(--color-secondary-dark);box-shadow:0 6px 20px #4ecdc466;transform:translateY(-2px)}.btn-accent{background:var(--color-accent);color:var(--color-gray-800);box-shadow:var(--shadow-accent)}.btn-accent:hover{background:var(--color-accent-dark);transform:translateY(-2px)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:var(--color-white)}.btn-ghost{background:transparent;color:var(--color-gray-700)}.btn-ghost:hover{background:var(--color-gray-100)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg)}.btn-icon{width:48px;height:48px;padding:0;border-radius:var(--radius-full)}.btn-icon-sm{width:36px;height:36px}.btn-icon-lg{width:56px;height:56px}.card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.card-body{padding:var(--space-6)}.card-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-gray-100)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-gray-100);background:var(--color-gray-50)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700)}.form-input,.form-textarea,.form-select{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--color-gray-800);background:var(--color-white);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #ff6b6b26}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-gray-400)}.form-textarea{min-height:120px;resize:vertical}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);background:var(--color-gray-100);color:var(--color-gray-700)}.chip-primary{background:#ff6b6b26;color:var(--color-primary-dark)}.chip-secondary{background:#4ecdc426;color:var(--color-secondary-dark)}.chip-accent{background:#ffe66d4d;color:var(--color-gray-800)}.event-card{position:relative;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal);cursor:pointer}.event-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary))}.event-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.event-card-body{padding:var(--space-5) var(--space-6)}.event-card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--space-2)}.event-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--color-gray-600)}.event-card-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);border-top:1px solid var(--color-gray-100);background:var(--color-gray-50)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full)}.badge:before{content:"";width:6px;height:6px;border-radius:var(--radius-full)}.badge-open{background:#4ecdc426;color:var(--color-secondary-dark)}.badge-open:before{background:var(--color-status-open)}.badge-confirmed{background:#66d9a026;color:#2d8659}.badge-confirmed:before{background:var(--color-status-confirmed)}.badge-cancelled{background:#bdbdbd26;color:var(--color-gray-600)}.badge-cancelled:before{background:var(--color-status-cancelled)}.avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-white);background:var(--color-primary);border:2px solid var(--color-white);flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--font-size-base)}.avatar-stack{display:flex}.avatar-stack .avatar{margin-left:-8px}.avatar-stack .avatar:first-child{margin-left:0}.avatar-overflow{background:var(--color-gray-200);color:var(--color-gray-600);font-size:var(--font-size-xs)}.participant-list{list-style:none}.participant-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);transition:background var(--transition-fast)}.participant-item:hover{background:var(--color-gray-50)}.participant-name{flex:1;font-weight:var(--font-weight-medium);color:var(--color-gray-800)}.participant-status{display:flex;gap:var(--space-2)}.participant-indicator{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--color-gray-500)}.participant-indicator.done{color:var(--color-success)}.date-range{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-gray-50);border-radius:var(--radius-lg);font-size:var(--font-size-sm);color:var(--color-gray-700)}.date-range-separator{color:var(--color-gray-400)}.date-range-time{padding-left:var(--space-2);border-left:1px solid var(--color-gray-200);color:var(--color-gray-500)}.share-url{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-gray-50);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg)}.share-url-text{flex:1;font-size:var(--font-size-sm);font-family:monospace;color:var(--color-gray-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-url .btn-copy{flex-shrink:0;padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);background:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.share-url .btn-copy:hover{background:var(--color-primary-dark)}.share-url .btn-copy.copied{background:var(--color-success)}.chip-like{background:#4ecdc426;color:var(--color-secondary-dark)}.chip-dislike{background:#ffa06d33;color:#c46a30}.chip-allergy{background:#ff6b6b26;color:var(--color-primary-dark);border:1.5px solid rgba(255,107,107,.3);font-weight:var(--font-weight-semibold)}.chip-dietary{background:#a28bd426;color:#7b63b8}.chip-removable{padding-right:var(--space-2)}.chip-remove{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:var(--font-size-xs);line-height:1;border-radius:var(--radius-full);background:#0000001a;border:none;cursor:pointer;transition:background var(--transition-fast)}.chip-remove:hover{background:#0003}.budget-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.budget-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);background:var(--color-white);border:2px solid var(--color-gray-200);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.budget-option:hover{border-color:var(--color-primary-light);background:var(--bg-secondary)}.budget-option.selected{border-color:var(--color-primary);background:#ff6b6b14;box-shadow:0 0 0 3px #ff6b6b26}.budget-option-icon{font-size:var(--font-size-xl)}.budget-option-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.suggestion-card{position:relative;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal)}.suggestion-card:hover{box-shadow:var(--shadow-lg)}.suggestion-rank{position:absolute;top:var(--space-4);left:var(--space-4);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-800);border-radius:var(--radius-full);background:var(--color-rank-1)}.suggestion-rank.rank-2{background:var(--color-rank-2)}.suggestion-rank.rank-3{background:var(--color-rank-3);color:var(--color-white)}.suggestion-card-body{padding:var(--space-5) var(--space-6);padding-left:calc(var(--space-6) + 36px + var(--space-3))}.suggestion-datetime{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--space-3)}.suggestion-score{margin-bottom:var(--space-3)}.suggestion-card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-gray-100);background:var(--color-ai-light)}.restaurant-card{position:relative;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;transition:all var(--transition-normal)}.restaurant-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.restaurant-card-header{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-5) var(--space-6)}.restaurant-rank{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-800);border-radius:var(--radius-full);background:var(--color-rank-1)}.restaurant-rank.rank-2{background:var(--color-rank-2)}.restaurant-rank.rank-3{background:var(--color-rank-3);color:var(--color-white)}.restaurant-rank.rank-other{background:var(--color-gray-100);color:var(--color-gray-600);font-size:var(--font-size-sm)}.restaurant-info{flex:1;min-width:0}.restaurant-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-gray-900);margin-bottom:var(--space-1)}.restaurant-address{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--space-2)}.restaurant-meta{display:flex;align-items:center;gap:var(--space-3)}.restaurant-card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-gray-100);background:var(--color-ai-light)}.score-bar{display:flex;align-items:center;gap:var(--space-3)}.score-bar-track{flex:1;height:8px;background:var(--color-gray-200);border-radius:var(--radius-full);overflow:hidden}.score-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--color-score-high);transition:width var(--transition-slow)}.score-bar-fill.mid{background:var(--color-score-mid)}.score-bar-fill.low{background:var(--color-score-low)}.score-bar-value{flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-gray-800);min-width:40px;text-align:right}.star-rating{display:inline-flex;gap:2px;font-size:var(--font-size-sm);color:var(--color-accent-dark)}.star-rating .star-empty{color:var(--color-gray-300)}.price-level{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-600)}.price-level .active{color:var(--color-success)}.ai-callout{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--color-ai-light);border-radius:var(--radius-lg);border-left:3px solid var(--color-ai)}.ai-callout-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-ai)}.ai-callout-text{font-size:var(--font-size-sm);line-height:var(--line-height-relaxed);color:var(--color-gray-700)}.empty-state{display:flex;flex-direction:column;align-items:center;padding:var(--space-12) var(--space-6);text-align:center}.empty-state-icon{font-size:48px;margin-bottom:var(--space-4);color:var(--color-gray-300)}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-gray-700);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-gray-500);margin-bottom:var(--space-6);max-width:320px}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:var(--color-gray-200);border-radius:var(--radius-md);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-text.short{width:60%}.skeleton-heading{height:1.5em;width:40%;margin-bottom:var(--space-3)}.skeleton-card{height:120px;border-radius:var(--radius-xl)}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.loading-ai{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-12);text-align:center}.loading-ai-text{font-size:var(--font-size-sm);color:var(--color-gray-500)}.loading-ai .loading-spinner{border-top-color:var(--color-ai)}.nav-bottom{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--color-white);box-shadow:0 -4px 20px #00000014;display:flex;align-items:center;justify-content:space-around;padding:0 var(--space-4);z-index:var(--z-sticky)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-4);color:var(--color-gray-500);text-decoration:none;border-radius:var(--radius-lg);transition:all var(--transition-fast)}.nav-item.active{color:var(--color-primary)}.nav-item-icon{font-size:24px}.nav-item-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.header{position:sticky;top:0;height:var(--header-height);background:var(--bg-primary);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);z-index:var(--z-sticky)}.header-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);opacity:0;visibility:hidden;transition:all var(--transition-normal)}.modal-backdrop.active{opacity:1;visibility:visible}.modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%) scale(.9);width:90%;max-width:500px;max-height:85vh;background:var(--bg-card);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-normal);overflow:hidden}.modal.active{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-gray-100)}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.modal-body{padding:var(--space-6);overflow-y:auto;max-height:calc(85vh - 140px)}.modal-footer{display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-gray-100);background:var(--color-gray-50)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mt-4{margin-top:var(--space-4)}.w-full{width:100%}.text-center{text-align:center}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-secondary)}.text-gray-500{color:var(--color-gray-500)}.text-gray-700{color:var(--color-gray-700)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.bg-white{background-color:var(--color-white)}.page-container{max-width:800px;margin:0 auto;padding:var(--space-6) var(--space-4)}.main-content{min-height:calc(100vh - var(--header-height))}.header-logo{font-family:var(--font-heading);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none}.header-actions{display:flex;align-items:center;gap:var(--space-3)}.btn-login{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary);text-decoration:none;padding:var(--space-2) var(--space-4);border:1px solid var(--color-primary);border-radius:var(--radius-full);transition:all var(--transition-fast)}.btn-login:hover{background:var(--color-primary);color:var(--color-white)}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border:1px solid var(--color-gray-200);border-radius:var(--radius-full);background:var(--bg-primary);cursor:pointer;transition:border-color var(--transition-fast)}.user-menu-trigger:hover{border-color:var(--color-gray-300)}.user-avatar{width:28px;height:28px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.user-menu-dropdown{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:200px;background:var(--bg-primary);border:1px solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);padding:var(--space-2) 0}.user-menu-header{padding:var(--space-2) var(--space-4)}.user-menu-email{font-size:var(--font-size-xs);color:var(--color-gray-500)}.user-menu-divider{height:1px;background:var(--color-gray-200);margin:var(--space-1) 0}.user-menu-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--color-gray-700);width:100%;cursor:pointer;transition:background var(--transition-fast)}.user-menu-item:hover{background:var(--color-gray-100)}.user-menu-link{text-decoration:none;color:inherit}.user-menu-button{border:none;background:none;text-align:left}.hero{text-align:center;padding:var(--space-12) 0 var(--space-8)}.hero-badge{display:inline-block;padding:var(--space-1) var(--space-3);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-secondary);background:#4ecdc41f;border-radius:var(--radius-full);margin-bottom:var(--space-4)}.hero-title{font-family:var(--font-heading);font-size:clamp(1.75rem,5vw,2.5rem);font-weight:var(--font-weight-bold);line-height:1.3;color:var(--color-gray-900);margin-bottom:var(--space-4)}.hero-description{font-size:var(--font-size-lg);color:var(--color-gray-500);max-width:560px;margin:0 auto var(--space-6);line-height:1.6}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);padding:var(--space-4) 0}.step{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);animation:fadeInUp .4s ease both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.step-number{flex-shrink:0;width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-white);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);display:flex;align-items:center;justify-content:center}.step-content{display:flex;flex-direction:column;gap:var(--space-1)}.step-title{font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.step-description{font-size:var(--font-size-sm);color:var(--color-gray-500)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-error{color:var(--color-error);font-size:var(--font-size-sm);padding:var(--space-2) var(--space-3);background:#ef444414;border-radius:var(--radius-md)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.event-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3)}.event-card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-gray-900);margin:0}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm)}.btn-accent{background:var(--color-accent);color:var(--color-gray-900)}.btn-accent:hover{background:var(--color-accent);opacity:.9}.chip-group{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.suggestion-content{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.suggestion-time{font-weight:var(--font-weight-semibold);color:var(--color-gray-900)}.restaurant-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);color:var(--color-gray-900)}.restaurant-name a{color:inherit;text-decoration:none}.restaurant-name a:hover{color:var(--color-primary)}.text-sm{font-size:var(--font-size-sm)}html,body,#root{height:100%}.chat-container{display:flex;flex-direction:column;height:100dvh;max-width:480px;margin:0 auto;background:var(--bg-primary)}.chat-header{display:flex;align-items:center;justify-content:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-gray-100);flex-shrink:0}.chat-logo{font-family:var(--font-family-heading);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);letter-spacing:-.02em}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3);-webkit-overflow-scrolling:touch}.chat-msg{display:flex;gap:var(--space-2);max-width:85%;animation:chatSlideIn .3s ease}.chat-msg-bot{align-self:flex-start}.chat-msg-user{align-self:flex-end;flex-direction:row-reverse}.chat-avatar{width:32px;height:32px;border-radius:50%;background:var(--color-primary-light);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);flex-shrink:0;text-transform:uppercase}.chat-bubble{padding:var(--space-3) var(--space-4);border-radius:var(--radius-xl);line-height:var(--line-height-normal);font-size:var(--font-size-base);white-space:pre-wrap;word-break:break-word}.chat-msg-bot .chat-bubble{background:var(--bg-card);color:var(--color-gray-800);border-bottom-left-radius:var(--space-1);box-shadow:var(--shadow-sm)}.chat-msg-user .chat-bubble{background:var(--color-primary);color:var(--color-white);border-bottom-right-radius:var(--space-1)}.chat-link{color:var(--color-secondary);text-decoration:underline;word-break:break-all}.chat-msg-user .chat-link{color:var(--color-white)}.chat-typing-indicator{display:flex;gap:4px;padding:var(--space-3) var(--space-4);min-height:auto}.chat-typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--color-gray-400);animation:chatTypingDot 1.4s infinite}.chat-typing-indicator span:nth-child(2){animation-delay:.2s}.chat-typing-indicator span:nth-child(3){animation-delay:.4s}.chat-input-area{padding:var(--space-3) var(--space-4);padding-bottom:max(var(--space-4),env(safe-area-inset-bottom));border-top:1px solid var(--color-gray-100);background:var(--bg-primary);flex-shrink:0}.chat-input-empty{padding:var(--space-2);border-top:none}.chat-quick-replies{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.chat-qr-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:2px solid var(--color-primary);background:transparent;color:var(--color-primary);font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.chat-qr-btn:hover{background:var(--color-primary);color:var(--color-white)}.chat-qr-btn:active{transform:scale(.95)}.chat-text-form{display:flex;gap:var(--space-2)}.chat-text-input{flex:1;padding:var(--space-3) var(--space-4);border-radius:var(--radius-full);border:2px solid var(--color-gray-200);font-family:var(--font-family-base);font-size:var(--font-size-base);outline:none;transition:border-color var(--transition-fast);background:var(--bg-card);color:var(--color-gray-800);min-width:0}.chat-text-input:focus{border-color:var(--color-primary)}.chat-text-input::placeholder{color:var(--color-gray-400)}.chat-send-btn{width:44px;height:44px;border-radius:50%;border:none;background:var(--color-primary);color:var(--color-white);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.chat-send-btn:hover:not(:disabled){background:var(--color-primary-dark)}.chat-send-btn:disabled{background:var(--color-gray-200);cursor:not-allowed}@keyframes chatSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes chatTypingDot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}@media(min-width:481px){body{background:var(--bg-secondary)}.chat-container{box-shadow:var(--shadow-lg)}}
