:root{--primary-50: #f0f9ff;--primary-100: #e0f2fe;--primary-200: #bae6fd;--primary-300: #7dd3fc;--primary-400: #38bdf8;--primary-500: #0ea5e9;--primary-600: #0284c7;--primary-700: #0369a1;--primary-800: #075985;--primary-900: #0c4a6e;--secondary-50: #fef3c7;--secondary-100: #fde68a;--secondary-200: #fcd34d;--secondary-300: #fbbf24;--secondary-400: #f59e0b;--secondary-500: #d97706;--secondary-600: #b45309;--secondary-700: #92400e;--secondary-800: #78350f;--secondary-900: #652b0e;--success-50: #ecfdf5;--success-100: #d1fae5;--success-200: #a7f3d0;--success-300: #6ee7b7;--success-400: #34d399;--success-500: #10b981;--success-600: #059669;--success-700: #047857;--success-800: #065f46;--success-900: #064e3b;--error-50: #fef2f2;--error-100: #fee2e2;--error-200: #fecaca;--error-300: #fca5a5;--error-400: #f87171;--error-500: #ef4444;--error-600: #dc2626;--error-700: #b91c1c;--error-800: #991b1b;--error-900: #7f1d1d;--neutral-50: #f9fafb;--neutral-100: #f3f4f6;--neutral-200: #e5e7eb;--neutral-300: #d1d5db;--neutral-400: #9ca3af;--neutral-500: #6b7280;--neutral-600: #4b5563;--neutral-700: #374151;--neutral-800: #1f2937;--neutral-900: #111827;--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;--font-family-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-family-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--font-family-display: var(--font-family-sans);--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-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25);--shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05);--radius-sm: .125rem;--radius: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-3xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--neutral-800);background-color:var(--neutral-50);min-height:100vh;overflow-x:hidden;font-weight:var(--font-weight-normal)}h1,h2,h3,h4,h5,h6{line-height:var(--line-height-tight);font-weight:var(--font-weight-bold);margin-bottom:var(--space-4);color:var(--neutral-900)}h1{font-size:var(--font-size-5xl);font-weight:var(--font-weight-extrabold)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}p{margin-bottom:var(--space-4);line-height:var(--line-height-relaxed);color:var(--neutral-600)}a{color:var(--primary-600);text-decoration:none;transition:all var(--transition-fast);position:relative}a:hover{color:var(--primary-700);text-decoration:underline}.container{max-width:1440px;margin:0 auto;padding:0 var(--space-4);width:100%}.main-content{min-height:calc(100vh - 160px);padding-top:80px;position:relative}.hidden{display:none!important}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--primary-600)}.text-secondary{color:var(--secondary-600)}.text-success{color:var(--success-600)}.text-error{color:var(--error-600)}.text-neutral{color:var(--neutral-600)}.header{position:fixed;top:0;left:0;right:0;background-color:#fff;box-shadow:var(--shadow-sm);z-index:1000;transition:all var(--transition-normal)}.nav-arrow{color:var(--primary-500);font-size:var(--font-size-xl);font-weight:900;display:flex;align-items:center;justify-content:center;transition:all .3s ease;margin:0 var(--space-3)}.nav-menu:hover .nav-arrow{color:var(--primary-600);transform:translate(3px)}.navbar{padding:var(--space-3) 0}.nav-container{display:flex;align-items:center;justify-content:space-between;max-width:1440px;margin:0 auto;padding:0 var(--space-4)}.nav-brand h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--primary-700);margin:0}.nav-menu{display:flex;align-items:center;gap:var(--space-6)}.nav-link{color:var(--neutral-700);font-weight:var(--font-weight-medium);padding:var(--space-2) 0;position:relative}.nav-link:hover,.nav-link.active{color:var(--primary-600)}.nav-link.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background-color:var(--primary-500);border-radius:var(--radius-full)}.user-status{display:flex;align-items:center;gap:var(--space-3)}.premium-badge{display:inline-block;background-color:var(--secondary-100);color:var(--secondary-800);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.hero-section{position:relative;padding:var(--space-20) 0;background:linear-gradient(135deg,var(--primary-50) 0%,var(--neutral-50) 100%);overflow:hidden}.hero-section:before{content:"";position:absolute;top:0;right:0;width:50%;height:100%;background-image:url(https://images.pexels.com/photos/403571/pexels-photo-403571.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=2);background-size:cover;background-position:center;opacity:.1;border-radius:var(--radius-3xl) 0 0 var(--radius-3xl)}.hero-content{max-width:800px;margin:0 auto;text-align:center;position:relative;z-index:1}.hero-title{font-size:var(--font-size-5xl);margin-bottom:var(--space-4);line-height:1.2;color:var(--neutral-900)}.hero-subtitle{font-size:var(--font-size-xl);margin-bottom:var(--space-8);color:var(--neutral-600);line-height:1.5}.search-container{max-width:600px;margin:0 auto}.search-box{display:flex;gap:var(--space-2);padding:var(--space-1);background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md)}.city-input{flex:1;padding:var(--space-3) var(--space-4);border:none;outline:none;font-size:var(--font-size-base);color:var(--neutral-800);border-radius:var(--radius-lg)}.city-input::-moz-placeholder{color:var(--neutral-400)}.city-input::placeholder{color:var(--neutral-400)}.search-icon{margin-right:var(--space-1)}.city-info-section{padding:var(--space-16) 0;background:#fff}.city-header{text-align:center;margin-bottom:var(--space-10);padding-bottom:var(--space-6);border-bottom:1px solid var(--neutral-200)}.city-name{font-size:var(--font-size-4xl);margin-bottom:var(--space-2);color:var(--primary-800)}.city-meta{display:flex;justify-content:center;gap:var(--space-6);flex-wrap:wrap}.city-province,.city-population{color:var(--neutral-600);font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.city-content{margin-top:var(--space-8)}.city-overview{margin-bottom:var(--space-10)}.city-overview h3{margin-bottom:var(--space-4);color:var(--primary-700)}.city-description{font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);color:#000!important;margin-bottom:var(--space-8);font-weight:400!important}.info-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.info-card{background:var(--neutral-50);padding:var(--space-6);border-radius:var(--radius-xl);border:1px solid var(--neutral-200);transition:all var(--transition-normal)}.info-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-200)}.info-card h4{font-size:var(--font-size-xl);margin-bottom:var(--space-3);color:var(--primary-700)}.footer{background-color:var(--neutral-900);color:#fff;padding:var(--space-10) 0}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-8);margin-bottom:var(--space-8)}.footer-section h4{color:#fff;margin-bottom:var(--space-4);font-size:var(--font-size-xl)}.footer-section p{color:var(--neutral-400);margin-bottom:var(--space-2)}.footer-section ul{list-style:none}.footer-section li{margin-bottom:var(--space-2)}.footer-section a{color:var(--neutral-400);transition:color var(--transition-fast)}.footer-section a:hover{color:#fff;text-decoration:none}.footer-bottom{text-align:center;padding-top:var(--space-6);border-top:1px solid var(--neutral-800)}.footer-bottom p{color:var(--neutral-500);font-size:var(--font-size-sm);margin:0}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:9999}.loading-spinner{text-align:center}.spinner{width:50px;height:50px;border:3px solid var(--neutral-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto var(--space-4)}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .5s ease-out}.pulse{animation:pulse 2s ease-in-out infinite}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-4) var(--space-8);border-radius:var(--radius-xl);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);border:none;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;text-decoration:none;gap:var(--space-2)}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:linear-gradient(135deg,var(--primary-500),var(--primary-600))}.btn-primary:active{transform:translateY(0);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--neutral-100);color:var(--neutral-700);border:1px solid var(--neutral-200)}.btn-secondary:hover{background-color:var(--neutral-200);border-color:var(--neutral-300)}.btn-outline{background-color:transparent;color:var(--primary-600);border:2px solid var(--primary-200)}.btn-outline:hover{background-color:var(--primary-50);border-color:var(--primary-300)}.btn-sm{padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-5) var(--space-10);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.btn-icon{padding:var(--space-3);aspect-ratio:1;width:-moz-fit-content;width:fit-content}.btn-success{background:linear-gradient(135deg,var(--success-500),var(--success-600));color:#fff}.btn-success:hover{background:linear-gradient(135deg,var(--success-400),var(--success-500))}.card{background:#fff;border-radius:var(--radius-xl);border:1px solid var(--neutral-200);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-image{width:100%;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover}.card-content{padding:var(--space-6)}.card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-3);color:var(--neutral-900)}.card-description{color:#000!important;font-size:var(--font-size-lg);margin-bottom:var(--space-4);font-weight:400!important}.card-footer{padding:0 var(--space-6) var(--space-6);display:flex;justify-content:space-between;align-items:center}.premium-notice{background:linear-gradient(135deg,var(--secondary-50),var(--primary-50));border:2px solid var(--secondary-200);border-radius:var(--radius-xl);padding:var(--space-6);text-align:center;margin:var(--space-8) 0;position:relative;overflow:hidden}.premium-notice:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--secondary-400),var(--primary-400))}.premium-notice p{color:var(--secondary-800);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin:0}.attractions-section{padding:var(--space-16) 0;background-color:#fff}.attractions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.attraction-card{background:#fff;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--neutral-200)}.attraction-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-200)}.attraction-image{width:100%;aspect-ratio:16/9;-o-object-fit:cover;object-fit:cover}.attraction-content{padding:var(--space-5)}.attraction-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2);color:var(--primary-800)}.attraction-meta{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-3)}.attraction-rating{display:flex;align-items:center;gap:var(--space-1);color:var(--secondary-500);font-weight:var(--font-weight-semibold)}.attraction-location{color:var(--neutral-500);font-size:var(--font-size-sm)}.attraction-description{color:#000!important;font-size:var(--font-size-lg);margin-bottom:var(--space-4);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-weight:400!important}.selected-attractions{background:#fff;border-radius:var(--radius-xl);border:2px solid var(--neutral-200);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:all var(--transition-normal);width:100%;max-width:none;margin:0 auto}.selected-attractions:hover{border-color:var(--primary-200);box-shadow:var(--shadow-md)}.selected-attractions h3{margin-bottom:var(--space-4);color:var(--primary-800);font-size:var(--font-size-xl)}.attraction-list{min-height:300px;max-height:500px;overflow-y:auto;margin-bottom:var(--space-5);padding:var(--space-4);background-color:var(--neutral-50);border-radius:var(--radius-lg);border:1px solid var(--neutral-100)}.empty-state{text-align:center;color:var(--neutral-500);padding:var(--space-8) 0}.trip-settings{margin-bottom:var(--space-5)}.input-group{margin-bottom:var(--space-3)}.input-group label{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-medium);color:var(--neutral-700)}.trip-days-select{padding:var(--space-2) var(--space-3);border:1px solid var(--neutral-300);border-radius:var(--radius-md);margin-left:var(--space-2);width:80px}.itinerary-display{background:#fff;border-radius:var(--radius-xl);border:2px solid var(--neutral-200);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:all var(--transition-normal);min-height:600px;width:100%;max-width:none;margin:0 auto}.itinerary-display:hover{border-color:var(--primary-200);box-shadow:var(--shadow-md)}.itinerary-display h3{margin-bottom:var(--space-4);color:var(--primary-700);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);text-align:center;background:linear-gradient(90deg,var(--primary-500),var(--secondary-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;padding-bottom:var(--space-2);border-bottom:2px solid var(--primary-200)}.itinerary-content{min-height:500px;overflow-y:auto;padding:var(--space-6);background-color:var(--neutral-50);border-radius:var(--radius-lg);border:1px solid var(--neutral-100);font-family:var(--font-family-sans);line-height:1.8;color:var(--neutral-800)}.itinerary-content h4{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--primary-700);margin:var(--space-4) 0 var(--space-2);background:linear-gradient(90deg,var(--primary-600),var(--secondary-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.itinerary-content h5{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--secondary-700);margin:var(--space-3) 0 var(--space-1)}.itinerary-content p{margin-bottom:var(--space-3);font-size:var(--font-size-base);color:var(--neutral-700);line-height:1.8}.itinerary-content ul,.itinerary-content ol{margin-bottom:var(--space-4);padding-left:var(--space-6)}.itinerary-content li{margin-bottom:var(--space-2);color:var(--neutral-700);line-height:1.6}.itinerary-content strong{font-weight:var(--font-weight-semibold);color:var(--primary-700)}.itinerary-content em{font-style:italic;color:var(--secondary-600)}.schedule-text{display:flex;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);font-size:var(--font-size-base)}.schedule-time{font-weight:var(--font-weight-bold);color:#000;min-width:80px;text-align:right;font-family:var(--font-family-mono);font-size:var(--font-size-lg)}.schedule-activity{font-weight:var(--font-weight-bold);color:#000;margin-bottom:var(--space-1);font-size:var(--font-size-lg);font-family:var(--font-family-sans)}.schedule-description{color:#000!important;font-size:var(--font-size-lg);line-height:1.6;padding-left:var(--space-2);font-family:var(--font-family-sans);font-weight:400!important}.schedule-duration{color:var(--secondary-700);font-weight:var(--font-weight-semibold);background-color:var(--secondary-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);margin-right:var(--space-3);display:inline-block;font-family:var(--font-family-mono)}.schedule-tips{color:var(--primary-700);background-color:var(--primary-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);display:inline-block;font-family:var(--font-family-sans)}.schedule-transport{color:var(--tertiary-600);background-color:var(--tertiary-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);display:inline-block;margin-left:var(--space-3)}.schedule-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.schedule-details{flex:1}.attraction-number{background-color:var(--primary-600);color:#fff;border-radius:50%;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);margin-right:var(--space-2);vertical-align:middle}.attractions-filters{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-6);justify-content:center}.filter-btn{padding:var(--space-3) var(--space-5);background-color:#fff;border:2px solid var(--neutral-200);border-radius:var(--radius-xl);font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--neutral-700);cursor:pointer;transition:all var(--transition-normal);min-width:140px;text-align:center}.filter-btn:hover{border-color:var(--primary-300);background-color:var(--primary-50);transform:translateY(-2px)}.filter-btn.active{background-color:var(--primary-600);color:#fff;border-color:var(--primary-600);font-weight:var(--font-weight-bold);box-shadow:0 4px 12px #3b82f64d}.filter-btn[data-filter=all]{font-size:var(--font-size-xl);padding:var(--space-4) var(--space-6);min-width:160px}.attractions-actions{text-align:center;margin:var(--space-4) 0 var(--space-6) 0}#selectedAttractionsBtn{background:linear-gradient(135deg,var(--secondary-500),var(--secondary-600));color:#fff;border:none;padding:var(--space-4) var(--space-8);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md)}#selectedAttractionsBtn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:linear-gradient(135deg,var(--secondary-400),var(--secondary-500))}#selectedAttractionsBtn:active{transform:translateY(0);box-shadow:var(--shadow-md)}.planner-content{display:grid;grid-template-columns:1fr 1.5fr;gap:var(--space-6);align-items:start;width:100%;max-width:none}@media (max-width: 1023px){.planner-content{grid-template-columns:1fr}}.planner-content>.selected-attractions,.planner-content>.itinerary-display{width:100%;max-width:none;margin:0 auto}.itinerary-card{display:flex;gap:var(--space-4);padding:var(--space-5);border:1px solid var(--neutral-200);border-radius:var(--radius-xl);background:#fff;margin-bottom:var(--space-4);transition:all var(--transition-normal);box-shadow:var(--shadow-sm)}.itinerary-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary-200)}.itinerary-time{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--primary-500);min-width:80px;text-align:right;margin-right:var(--space-5);display:flex;align-items:flex-start;padding-top:var(--space-1);background:linear-gradient(90deg,var(--primary-400),var(--secondary-400));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.itinerary-main{flex:1}.itinerary-activity{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--primary-600);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2);background:linear-gradient(90deg,var(--primary-500),var(--secondary-500));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;padding:var(--space-1) 0}.itinerary-desc{color:var(--neutral-700);margin-bottom:var(--space-3);font-size:var(--font-size-base);padding-left:var(--space-6);position:relative}.itinerary-desc:before{content:"→";position:absolute;left:0;color:var(--primary-400)}.itinerary-info{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.itinerary-visit{font-size:var(--font-size-sm);color:var(--secondary-600);font-weight:var(--font-weight-medium);background-color:var(--secondary-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full)}.itinerary-tips{font-size:var(--font-size-sm);color:var(--primary-600);background-color:var(--primary-50);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-weight:var(--font-weight-medium)}.form-input{width:100%;padding:var(--space-4) var(--space-5);border:1px solid var(--neutral-300);border-radius:var(--radius-lg);background:#fff;color:var(--neutral-800);font-size:var(--font-size-base);transition:all var(--transition-normal)}input[type=checkbox]{width:20px;height:20px;margin-right:var(--space-3);cursor:pointer;accent-color:var(--primary-600)}.attraction-checkbox{position:relative;display:inline-block}.attraction-checkbox input[type=checkbox]{width:24px;height:24px;margin-right:0}.attraction-checkbox label{cursor:pointer}.trip-settings input[type=checkbox]{width:22px;height:22px}.form-input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px #0ea5e91a}.form-input::-moz-placeholder{color:var(--neutral-400)}.form-input::placeholder{color:var(--neutral-400)}.form-label{display:block;margin-bottom:var(--space-2);font-weight:var(--font-weight-medium);color:var(--neutral-700)}.form-group{margin-bottom:var(--space-5)}.form-select{width:100%;padding:var(--space-4) var(--space-5);border:1px solid var(--neutral-300);border-radius:var(--radius-lg);background:#fff;color:var(--neutral-800);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-normal)}.form-select:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px #0ea5e91a}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.badge-primary{background-color:var(--primary-100);color:var(--primary-700)}.badge-secondary{background-color:var(--secondary-100);color:var(--secondary-700)}.badge-success{background-color:var(--success-100);color:var(--success-700)}.badge-warning{background-color:var(--error-100);color:var(--error-700)}.badge-info{background-color:var(--neutral-100);color:var(--neutral-700)}.progress-bar{height:8px;background-color:var(--neutral-100);border-radius:var(--radius-full);overflow:hidden;margin:var(--space-3) 0}.progress-value{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);transition:width var(--transition-normal)}.tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:1px solid var(--neutral-200);overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-3) var(--space-5);background:transparent;border:none;cursor:pointer;font-weight:var(--font-weight-medium);color:var(--neutral-600);position:relative;white-space:nowrap;transition:color var(--transition-fast)}.tab:hover{color:var(--primary-600)}.tab.active{color:var(--primary-700);font-weight:var(--font-weight-semibold)}.tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:3px;background-color:var(--primary-500);border-radius:var(--radius-full)}.accordion{border:1px solid var(--neutral-200);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-4)}.accordion-item{border-bottom:1px solid var(--neutral-200)}.accordion-item:last-child{border-bottom:none}.accordion-header{padding:var(--space-4);background-color:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color var(--transition-fast)}.accordion-header:hover{background-color:var(--neutral-50)}.accordion-title{font-weight:var(--font-weight-medium);color:var(--neutral-800)}.accordion-icon{transition:transform var(--transition-fast)}.accordion-item.active .accordion-icon{transform:rotate(180deg)}.accordion-content{padding:0 var(--space-4) var(--space-4);max-height:0;overflow:hidden;transition:max-height var(--transition-normal),padding var(--transition-normal);background-color:#fff}.accordion-item.active .accordion-content{max-height:500px;padding-top:var(--space-4)}.notification{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);margin-bottom:var(--space-4);display:flex;align-items:flex-start;gap:var(--space-3);border-left:4px solid}.notification-success{background-color:var(--success-50);border-left-color:var(--success-500);color:var(--success-700)}.notification-error{background-color:var(--error-50);border-left-color:var(--error-500);color:var(--error-700)}.notification-info{background-color:var(--primary-50);border-left-color:var(--primary-500);color:var(--primary-700)}.notification-warning{background-color:var(--secondary-50);border-left-color:var(--secondary-500);color:var(--secondary-700)}.notification-close{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.tooltip{position:relative;display:inline-block}.tooltip-text{visibility:hidden;width:120px;background-color:var(--neutral-800);color:#fff;text-align:center;border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);position:absolute;z-index:1;bottom:125%;left:50%;margin-left:-60px;opacity:0;transition:opacity var(--transition-fast);font-size:var(--font-size-xs)}.tooltip-text:after{content:"";position:absolute;top:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:var(--neutral-800) transparent transparent transparent}.tooltip:hover .tooltip-text{visibility:visible;opacity:1}.travel-mode-selector{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.travel-mode{padding:var(--space-3) var(--space-5);border:2px solid var(--neutral-200);background:#fff;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-medium);color:var(--neutral-700)}.travel-mode:hover{border-color:var(--primary-300);color:var(--primary-600)}.travel-mode.active{border-color:var(--primary-500);background-color:var(--primary-50);color:var(--primary-700)}.featured-cities{padding:var(--space-16) 0}.featured-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-6);margin-top:var(--space-8)}.city-card{position:relative;border-radius:var(--radius-xl);overflow:hidden;height:280px;box-shadow:var(--shadow-md);transition:all var(--transition-normal)}.city-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.city-card-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform var(--transition-slow)}.city-card:hover .city-card-image{transform:scale(1.05)}.city-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#000c,#0000);padding:var(--space-8) var(--space-6) var(--space-6);color:#fff}.city-card-name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-1)}.city-card-desc{font-size:var(--font-size-sm);opacity:.9;margin-bottom:var(--space-3)}.premium-features{padding:var(--space-16) 0;background:linear-gradient(135deg,var(--primary-50) 0%,white 100%);text-align:center}.premium-features-header{max-width:800px;margin:0 auto var(--space-12)}.premium-features-header h2{color:var(--primary-800);margin-bottom:var(--space-4)}.premium-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-8);max-width:1200px;margin:0 auto}.premium-feature-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--neutral-200)}.premium-feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary-200)}.premium-feature-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--primary-100),var(--primary-50));border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-4);color:var(--primary-600)}.premium-feature-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-3);color:var(--primary-800)}.premium-feature-desc{color:var(--neutral-600)}.pricing-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-8);max-width:1200px;margin:var(--space-12) auto}.pricing-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--neutral-200);position:relative;overflow:hidden}.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}.pricing-card.popular{border-color:var(--primary-400);box-shadow:var(--shadow-md)}.pricing-card.popular:before{content:"Popular";position:absolute;top:20px;right:-35px;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));color:#fff;padding:var(--space-1) var(--space-8);transform:rotate(45deg);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-md)}.pricing-plan{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--space-2);color:var(--neutral-900)}.pricing-desc{color:var(--neutral-600);margin-bottom:var(--space-6)}.pricing-amount{font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);margin-bottom:var(--space-6);color:var(--primary-700)}.pricing-amount span{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--neutral-500)}.pricing-features{margin-bottom:var(--space-8)}.pricing-feature{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);color:var(--neutral-700)}.pricing-feature:last-child{margin-bottom:0}.pricing-feature.included{color:var(--success-600)}.pricing-feature.excluded{color:var(--neutral-400);opacity:.6}.testimonials-section{padding:var(--space-16) 0;background-color:var(--neutral-50)}.testimonials-header{text-align:center;margin-bottom:var(--space-10)}.testimonials-header h2{color:var(--primary-800);margin-bottom:var(--space-4)}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-6);max-width:1200px;margin:0 auto}.testimonial-card{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--neutral-200)}.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.testimonial-quote{font-size:var(--font-size-3xl);color:var(--primary-200);margin-bottom:var(--space-3);line-height:1}.testimonial-text{color:var(--neutral-700);font-style:italic;margin-bottom:var(--space-4);line-height:var(--line-height-relaxed)}.testimonial-author{display:flex;align-items:center;gap:var(--space-3)}.testimonial-avatar{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.testimonial-name{font-weight:var(--font-weight-semibold);color:var(--neutral-900)}.testimonial-role{font-size:var(--font-size-sm);color:var(--neutral-500)}.faq-section{padding:var(--space-16) 0;background-color:#fff}.faq-header{text-align:center;margin-bottom:var(--space-10)}.faq-header h2{color:var(--primary-800);margin-bottom:var(--space-4)}.faq-container{max-width:800px;margin:0 auto}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-top:var(--space-2);max-height:250px;overflow-y:auto;z-index:10;border:1px solid var(--neutral-200)}.suggestion-item{padding:var(--space-3) var(--space-5);border-bottom:1px solid var(--neutral-100);cursor:pointer;transition:all var(--transition-fast);color:var(--neutral-700)}.suggestion-item:hover{background-color:var(--primary-50);color:var(--primary-700)}.suggestion-item:last-child{border-bottom:none}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--space-2);margin-top:var(--space-8)}.pagination-item{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);border:1px solid var(--neutral-200);background:#fff;cursor:pointer;transition:all var(--transition-fast);color:var(--neutral-700)}.pagination-item:hover{border-color:var(--primary-300);color:var(--primary-700)}.pagination-item.active{background-color:var(--primary-500);color:#fff;border-color:var(--primary-500)}.pagination-item.disabled{opacity:.5;cursor:not-allowed}.pagination-item.disabled:hover{border-color:var(--neutral-200);color:var(--neutral-700)}.switch{position:relative;display:inline-block;width:48px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--neutral-300);transition:var(--transition-fast);border-radius:var(--radius-full)}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:var(--transition-fast);border-radius:var(--radius-full)}input:checked+.slider{background-color:var(--primary-500)}input:focus+.slider{box-shadow:0 0 1px var(--primary-500)}input:checked+.slider:before{transform:translate(24px)}.loader{border:4px solid var(--neutral-200);border-radius:50%;border-top:4px solid var(--primary-500);width:32px;height:32px;animation:spin 1s linear infinite;margin:var(--space-4) auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;visibility:hidden;transition:all var(--transition-normal)}.modal.active{opacity:1;visibility:visible}.modal-content{background:#fff;border-radius:var(--radius-xl);padding:var(--space-6);max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-xl);transform:scale(.9);transition:transform var(--transition-normal)}.modal.active .modal-content{transform:scale(1)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--neutral-900)}.modal-close{background:none;border:none;cursor:pointer;color:var(--neutral-500);font-size:var(--font-size-xl)}.modal-body{margin-bottom:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3)}.scroll-top{position:fixed;bottom:var(--space-6);right:var(--space-6);width:50px;height:50px;background:#fff;border:1px solid var(--neutral-200);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-normal);box-shadow:var(--shadow-md);opacity:0;visibility:hidden;z-index:99;color:var(--primary-700)}.scroll-top.visible{opacity:1;visibility:visible}.scroll-top:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-300);color:var(--primary-600)}.upgrade-section{background-color:var(--primary-50);border-top:1px solid var(--primary-200);border-bottom:1px solid var(--primary-200);padding:2rem 0;text-align:center;margin-top:2rem}.upgrade-content{max-width:600px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}.upgrade-content h3{color:var(--primary-800);font-size:1.5rem;margin:0}.footer{background-color:var(--primary-900);color:#fff;padding:2rem 0;margin-top:0}.upgrade-section{padding:var(--space-5) 0}.upgrade-content h3{font-size:var(--font-size-xl)}@media (min-width: 640px){.upgrade-section{padding:var(--space-6) 0}.upgrade-content h3{font-size:var(--font-size-2xl)}}@media (min-width: 768px){.upgrade-section{padding:var(--space-7) 0}}@media (min-width: 1024px){.upgrade-content{flex-direction:row;justify-content:center;align-items:center;gap:var(--space-4)}.upgrade-content h3{margin:0}}.container{width:100%;padding-right:var(--space-4);padding-left:var(--space-4);margin-right:auto;margin-left:auto}.grid-cols-1,.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(1,1fr)}.flex-direction-row{flex-direction:column}.justify-content-between{justify-content:center}.gap-1{gap:var(--space-2)}.gap-2{gap:var(--space-3)}.gap-3{gap:var(--space-4)}.gap-4{gap:var(--space-5)}.header-nav{display:none}.mobile-menu-btn{display:block}.hero-title{font-size:var(--font-size-2xl);line-height:var(--line-height-tight)}.hero-subtitle{font-size:var(--font-size-base)}.city-stats{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.attractions-grid{grid-template-columns:repeat(1,1fr);gap:var(--space-5)}.premium-features-grid,.pricing-cards{grid-template-columns:repeat(1,1fr);gap:var(--space-6)}.testimonials-grid,.featured-grid{grid-template-columns:repeat(1,1fr);gap:var(--space-5)}.footer-grid{grid-template-columns:repeat(1,1fr);gap:var(--space-6)}.footer-bottom{flex-direction:column;text-align:center;gap:var(--space-3)}.itinerary-cards{gap:var(--space-3)}.itinerary-card{flex-direction:column;gap:var(--space-3)}.itinerary-time{min-width:auto;text-align:left;margin-right:0;padding-top:0}.schedule-item{flex-direction:column;gap:var(--space-2)}.schedule-time{min-width:auto;padding-right:0}.summary-stats,.day-summary,.item-details,.search-bar{flex-direction:column;gap:var(--space-3)}.search-input{width:100%}.transport-options{flex-direction:column;gap:var(--space-3)}@media (min-width: 640px){.container{max-width:640px}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.city-stats{grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.hero-title{font-size:var(--font-size-3xl)}.hero-subtitle{font-size:var(--font-size-lg)}.attractions-grid{grid-template-columns:repeat(1,1fr);gap:var(--space-6)}.footer-grid,.featured-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.testimonials-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-5)}}@media (min-width: 768px){.container{max-width:768px}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.city-stats{grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.hero-title{font-size:var(--font-size-4xl)}.hero-subtitle{font-size:var(--font-size-lg)}.attractions-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.premium-features-grid,.pricing-cards{grid-template-columns:repeat(2,1fr);gap:var(--space-7)}.testimonials-grid,.featured-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.footer-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.footer-bottom{flex-direction:row;justify-content:space-between;text-align:left}.itinerary-card{flex-direction:row}.itinerary-time{min-width:80px;text-align:right;margin-right:var(--space-5);padding-top:var(--space-1)}.search-bar{flex-direction:row}.search-input{width:auto;flex:1}.transport-options{flex-direction:column}}@media (min-width: 1024px){.container{max-width:1024px}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.header-nav{display:flex}.mobile-menu-btn{display:none}.hero-title{font-size:var(--font-size-5xl)}.hero-subtitle{font-size:var(--font-size-xl)}.attractions-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.premium-features-grid,.pricing-cards{grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.testimonials-grid,.featured-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.footer-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.transport-options{flex-direction:column}}@media (min-width: 1280px) and (max-width: 1535px){.container{max-width:1440px}.hero-title{font-size:var(--font-size-6xl)}.attractions-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.premium-features-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.testimonials-grid,.featured-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-6)}}@media (min-width: 1536px){.container{max-width:1800px}.hero-title{font-size:var(--font-size-6xl)}.attractions-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.premium-features-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-8)}.testimonials-grid,.featured-grid{grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.planner-content{grid-template-columns:1fr 2fr}}@media (max-width: 639px){:root{--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-size-5xl: 3rem;--font-size-6xl: 3.75rem}}@media (min-width: 640px) and (max-width: 1023px){:root{--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-size-5xl: 3rem;--font-size-6xl: 3.75rem}}@media (min-width: 1024px){:root{--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-size-5xl: 3rem;--font-size-6xl: 3.75rem}}@media (max-width: 639px){:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 2rem;--space-8: 2.5rem;--space-9: 3rem;--space-10: 4rem;--space-11: 5rem;--space-12: 6rem;--space-13: 8rem;--space-14: 10rem;--space-15: 12rem;--space-16: 16rem}}@media (min-width: 640px) and (max-width: 1023px){:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 2rem;--space-8: 2.5rem;--space-9: 3rem;--space-10: 4rem;--space-11: 5rem;--space-12: 6rem;--space-13: 8rem;--space-14: 10rem;--space-15: 12rem;--space-16: 16rem}}@media (min-width: 1024px){:root{--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 2rem;--space-8: 2.5rem;--space-9: 3rem;--space-10: 4rem;--space-11: 5rem;--space-12: 6rem;--space-13: 8rem;--space-14: 10rem;--space-15: 12rem;--space-16: 16rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media (prefers-contrast: high){:root{--primary-500: #0066cc;--primary-600: #0052a3;--secondary-500: #d4380d;--secondary-600: #aa2a00;--neutral-100: #f9f9f9;--neutral-200: #e5e5e5;--neutral-700: #404040;--neutral-800: #292929;--neutral-900: #141414;--success-500: #2d8e43;--error-500: #c72127}.btn-primary,.btn-secondary,.btn-outline,.card,.attraction-card,.premium-feature-card{border-width:2px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.hero-image,.city-card-image,.attraction-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (max-width: 767px) and (orientation: landscape){.city-stats{grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.attractions-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-4)}.premium-features-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-5)}.featured-grid,.footer-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-4)}}@media (min-width: 1536px){.container{max-width:1800px}.city-content{display:flex;flex-wrap:wrap;gap:var(--space-8)}.city-overview{flex:1;min-width:400px}.info-cards{flex:1;min-width:400px;align-self:flex-start}}@media print{*{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}body{font-size:12pt;line-height:1.5;margin:0;padding:0}.container{width:100%;max-width:100%;padding:0}.header,.footer,.btn,.mobile-menu-btn,.search-suggestions{display:none!important}h1,h2,h3,h4,h5,h6{page-break-after:avoid;orphans:3;widows:3}p{orphans:3;widows:3}.card,.attraction-card,.premium-feature-card{page-break-inside:avoid;border:1px solid #ddd;border-radius:4px}.attractions-grid,.premium-features-grid,.featured-grid{display:block}.city-stats{display:flex;flex-wrap:wrap;gap:1rem}.city-stat{flex:1 1 200px;border:1px solid #ddd;padding:.5rem;border-radius:4px}}
