.sidebar{height:100dvh;background:#fff;border-right:1px solid #e5e7eb;box-shadow:4px 0 24px #0000000d;display:none;flex-direction:column;transition:all .6s cubic-bezier(.16,1,.3,1);padding:var(--spacing-md);z-index:var(--z-dropdown);position:relative}[data-theme=dark] .sidebar{background:#1a1f2e;border-right:1px solid #2d333b;box-shadow:4px 0 24px #0000004d;overflow:hidden;flex-shrink:0;transform:translateZ(0);backface-visibility:hidden;will-change:width,background}@media(min-width:768px){.sidebar{display:flex}}.sidebar.expanded{width:var(--sidebar-width-expanded)}.sidebar.collapsed{width:var(--sidebar-width-collapsed);align-items:center}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);height:36px;width:100%;flex-shrink:0}.sidebar.collapsed .sidebar-header{justify-content:center}.logo-container{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.logo-box{width:48px;height:48px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.logo-text{font-weight:700;font-size:1.5rem;letter-spacing:-.5px;color:#1e3a8a}[data-theme=dark] .logo-text{color:#fff}.logo-icon{width:100%;height:100%;object-fit:contain;transition:var(--transition-smooth)}.logo-container:hover .logo-icon{opacity:.8}.collapse-btn{color:#6b7280;padding:8px;border-radius:var(--radius-sm);background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px}[data-theme=dark] .collapse-btn{color:#fff9}.sidebar.collapsed .collapse-btn{display:none}.collapse-btn:hover{background-color:#f3f4f6;color:#1a1a1a}[data-theme=dark] .collapse-btn:hover{background-color:#ffffff1a;color:#fff}.sidebar-nav{display:flex;flex-direction:column;gap:4px;width:100%;flex-shrink:0}.nav-group{display:flex;flex-direction:column;gap:6px}.nav-separator{height:1px;background-color:var(--border-subtle);margin:6px 0}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:10px 12px;border-radius:var(--radius-sm);color:#6b7280;font-weight:500;font-size:.95rem;cursor:pointer;transition:var(--transition-fast);width:100%;min-height:44px}.nav-item:hover{background-color:#f3f4f6;color:#1a1a1a;transform:translate(2px)}.nav-item.active{background-color:#007bff1a;color:#007bff;box-shadow:inset 0 0 0 1px #007bff}[data-theme=dark] .nav-item{color:#ffffffb3}[data-theme=dark] .nav-item:hover{background-color:#ffffff1a;color:#fff}[data-theme=dark] .nav-item.active{background-color:#007bff33;color:#60a5fa;box-shadow:inset 0 0 0 1px #60a5fa}.nav-item.glow-effect{position:relative;animation:membershipGlow 2s ease-in-out infinite}.nav-item.glow-effect:before{content:"";position:absolute;inset:-2px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary-blue),#667eea);opacity:.3;filter:blur(4px);z-index:-1;animation:glowPulse 2s ease-in-out infinite}@keyframes membershipGlow{0%,to{box-shadow:0 0 8px #007bff66}50%{box-shadow:0 0 16px #007bff99}}@keyframes glowPulse{0%,to{opacity:.3}50%{opacity:.5}}.nav-item.icon-only{justify-content:center;padding:8px 0}.nav-icon{display:flex;align-items:center;justify-content:center;color:#007bff}[data-theme=dark] .nav-icon{color:#fff}.nav-item:hover .nav-icon{color:#0056b3}[data-theme=dark] .nav-item:hover .nav-icon{color:#fff}.nav-item.active .nav-icon{color:#007bff}[data-theme=dark] .nav-item.active .nav-icon{color:#60a5fa}.nav-label{flex:1 1 0%}.submenu-arrow{margin-left:auto;opacity:.5}.nav-subtext{font-size:.8rem;color:#9ca3af;padding:4px 10px 4px 42px;cursor:pointer;transition:var(--transition-fast)}[data-theme=dark] .nav-subtext{color:#ffffff7f}.nav-subtext:hover{color:#007bff}[data-theme=dark] .nav-subtext:hover{color:#60a5fa}.sidebar-spacer{flex:1 1 0%;overflow:hidden auto;display:flex;flex-direction:column;min-height:0}.sidebar-spacer::-webkit-scrollbar{width:6px}.sidebar-spacer::-webkit-scrollbar-track{background:transparent}.sidebar-spacer::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px;transition:background .2s}.sidebar-spacer::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.sidebar-footer{flex-shrink:0;margin-top:0;padding-top:var(--spacing-sm);border-top:1px solid var(--glass-border)}.sidebar-social-media{padding:4px 0 6px;margin-bottom:0;display:flex;flex-direction:column;align-items:center;gap:4px;opacity:.8;transition:opacity .3s ease}.sidebar-social-media:hover{opacity:1}.social-section-label{font-size:12px;color:var(--text-secondary);opacity:.6;margin:0;padding:0;font-weight:500;text-transform:uppercase;letter-spacing:.5px;line-height:1}@media(max-width:767px){.sidebar-social-media{padding:8px 0 0;margin-top:8px;gap:6px;background:transparent;box-shadow:none;border:none}.social-section-label{font-size:12px;letter-spacing:.5px;opacity:.6;font-weight:600}.sidebar-legal{padding:8px 0 0;margin-bottom:0}}.legal-separator{height:1px;background:var(--border-color, rgb(255 255 255 / 10%));margin:12px 0 8px;opacity:.3}.sidebar-legal{padding:0;margin-bottom:0;display:grid;gap:6px;font-size:12px;opacity:.6;transition:opacity .3s ease}.sidebar-legal:hover{opacity:.8}.legal-row-top{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;text-align:center}.legal-row-bottom{display:grid;grid-template-columns:1fr;text-align:center}.sidebar-legal a{color:var(--text-secondary);text-decoration:none;transition:color .2s ease}.sidebar-legal a:hover{color:var(--text-main);text-decoration:underline}.user-profile{display:flex;align-items:center;gap:8px;padding:6px 0;position:relative}.avatar img{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-info{display:flex;flex-direction:column;flex:1 1 0%}.user-name{font-weight:600;font-size:.95rem;color:#1e3a8a}[data-theme=dark] .user-name{color:#fff}.user-handle{font-size:.85rem;color:#1e3a8a}[data-theme=dark] .user-handle{color:#ffffff7f}.sidebar-actions{display:flex;align-items:center;gap:4px}.settings-cog-btn{width:40px;height:40px;padding:0;border-radius:50%;background:var(--glass-bg);border:1px solid var(--glass-border);color:#6b7280;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}[data-theme=dark] .settings-cog-btn{color:#fff9}.settings-cog-btn:hover{background:var(--glass-hover-bg);color:#1a1a1a;box-shadow:0 4px 12px #00000026;transform:scale(1.05)}[data-theme=dark] .settings-cog-btn:hover{color:#fff}.auth-buttons{display:flex;flex-direction:column;gap:6px;padding:6px 0}.auth-buttons-row{display:flex;align-items:center;gap:6px;width:100%}.login-btn,.signup-btn{padding:8px 14px;border-radius:var(--radius-md);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;width:100%}.login-btn-compact{padding:8px 14px;border-radius:var(--radius-md);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;flex:1 1 0%;background:var(--glass-bg-subtle);color:#1a1a1a;border:1.5px solid #007bff}[data-theme=dark] .login-btn-compact{color:#fff}.login-btn-compact:hover{background:var(--glass-hover-bg);border-color:#007bff;box-shadow:0 2px 8px #007bff33}.login-btn{background:var(--glass-bg-subtle);color:#1a1a1a;border:1.5px solid #007bff}[data-theme=dark] .login-btn{color:#fff}.login-btn:hover{background:var(--glass-hover-bg);border-color:#007bff;box-shadow:0 2px 8px #007bff33}.signup-btn{background:#007bff;color:#fff;box-shadow:0 2px 8px #007bff33}.signup-btn:hover{background:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-1px)}.login-btn-collapsed{width:40px;height:40px;border-radius:50%;background:var(--bg-page);border:1px solid var(--border-subtle);color:var(--text-main);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.login-btn-collapsed:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.sidebar-divider{height:1px;background-color:var(--border-subtle);margin:8px 0;flex-shrink:0}.trip-action-buttons{display:flex;gap:6px;margin-bottom:8px;flex-shrink:0}.trip-action-btn{flex:1 1 0%;display:flex;align-items:center;justify-content:center;gap:4px;padding:10px 12px;background:var(--glass-bg-subtle);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px}.trip-action-btn:hover{background:var(--glass-bg);color:var(--text-main);border-color:var(--primary-blue);box-shadow:var(--shadow-glow-subtle)}.folders-section-primary{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--spacing-sm)}.folder-group{position:relative;display:flex;flex-direction:column}.folder-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px 6px 12px;cursor:pointer;border-radius:0 var(--radius-sm) var(--radius-sm) 0;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;background:var(--glass-bg-subtle);border:1px solid var(--glass-border);border-left:3px solid var(--primary-blue);margin-left:-8px;box-shadow:2px 2px 4px #0000000d}.folder-header:hover{background:var(--glass-bg);border-left-color:var(--primary-blue);transform:translate(4px);box-shadow:3px 3px 8px #00000014}.folder-header.expanded{background:var(--glass-bg);border-left-color:var(--primary-blue);box-shadow:3px 3px 8px #0000001a}.folder-left{display:flex;align-items:center;gap:6px;color:var(--text-main);font-size:.75rem;flex:1 1 0%}.folder-name{font-weight:600;letter-spacing:.3px;text-transform:uppercase;font-size:.75rem}.uncategorized-tab{background:var(--glass-bg);border:1px solid var(--glass-border)}.uncategorized-tab:hover{background:var(--glass-bg-hover);border-color:#6495ed4d}.uncategorized-glow{color:var(--text-main);font-weight:600}.folder-count{font-size:.75rem;color:var(--text-muted);background:var(--glass-bg-strong);padding:2px 5px;border-radius:4px;font-weight:600;min-width:18px;text-align:center}.folder-group-simple{margin-bottom:.25rem}.folder-item-simple{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;color:var(--text-secondary);font-size:.8125rem;transition:all .2s}.folder-item-simple:hover{color:var(--text-main);background:var(--glass-bg-subtle)}.folder-item-simple span{font-weight:500}.folder-children{display:flex;flex-direction:column;gap:2px;padding:4px 0 4px 16px;margin-top:2px}.folder-child-item{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:.72rem;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:move;transition:all .2s;background:var(--glass-bg-subtle);border-left:2px solid transparent}.folder-child-item:hover{background:var(--glass-bg);color:var(--text-main);border-left-color:var(--primary-blue);transform:translate(2px)}.folder-child-item:active{opacity:.7;cursor:grabbing}.uncategorized-chats-section{margin-top:var(--spacing-xs);display:flex;flex-direction:column;gap:3px;flex-shrink:0}.section-header-collapsible{font-size:.75rem;font-weight:700;color:var(--text-muted);padding:3px 6px;letter-spacing:.8px;display:flex;align-items:center;gap:4px;cursor:pointer;border-radius:var(--radius-sm);transition:background .2s}.section-header-collapsible:hover{background-color:var(--bg-page)}.chat-items-list{display:flex;flex-direction:column;gap:1px}.chat-item-primary{display:flex;align-items:center;gap:6px;padding:5px 8px;font-size:.72rem;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:move;transition:all .2s;position:relative;background:var(--glass-bg-subtle);border-left:2px solid transparent}.chat-item-primary:hover{background:var(--glass-bg);color:var(--text-main);border-left-color:var(--primary-blue)}.chat-item-primary:active{opacity:.7;cursor:grabbing}.chat-item-primary.active{background:var(--primary-blue);color:#fff;border-left-color:#fff;box-shadow:0 0 12px #1e3a8a66}.chat-name{flex:1 1 0%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-indicator{width:5px;height:5px;border-radius:50%;flex-shrink:0}.chat-indicator.green{background-color:#22c55e}.chat-indicator.orange{background-color:#f97316}.folder-group[data-drag-over=true]{background-color:#e6f2ff;border:1px dashed var(--primary-blue)}.section-item-container{display:flex;flex-direction:column}.section-header-item{cursor:pointer}.item-count-badge{margin-left:auto;font-size:.75rem;color:var(--text-muted);background-color:#f1f5f9;padding:1px 5px;border-radius:99px;font-weight:600}.section-items-list{display:flex;flex-direction:column;gap:1px;padding-left:28px;margin-top:2px}.section-item{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:.75rem;color:var(--text-muted);border-radius:var(--radius-sm);transition:all .2s;line-height:1.2}.section-item:hover{background-color:#00000008;color:var(--text-secondary)}.item-content-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 0%;font-size:.75rem}.planner-login-prompt{padding:16px 12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;background:linear-gradient(135deg,#f8f9ff,#e6f2ff);border-radius:var(--radius-md);margin:8px 0;border:1px solid var(--border-subtle);flex-shrink:0}.planner-login-icon{width:44px;height:44px;background:var(--glass-accent-bg);border:1px solid var(--glass-accent-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary-blue);box-shadow:var(--shadow-glow-subtle)}.planner-login-prompt h3{margin:0;font-size:.95rem;font-weight:600;color:var(--primary-blue);text-shadow:0 0 20px var(--glow-blue);filter:drop-shadow(0 0 8px var(--glow-blue))}.planner-login-prompt p{margin:0;font-size:.72rem;color:var(--text-secondary);line-height:1.4}.planner-login-btn{padding:10px 20px;background:var(--primary-blue);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #007bff33}.planner-login-btn:hover{background:var(--primary-blue-hover);transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}@media(max-width:768px),(hover:none)and (pointer:coarse){.nav-item{min-height:44px;padding:12px 14px}.nav-item.icon-only{min-width:44px;min-height:44px;padding:10px}.collapse-btn,.settings-cog-btn,.login-btn-collapsed{min-width:44px;min-height:44px;width:44px;height:44px}.trip-action-btn{min-height:44px;padding:12px 14px}.folder-header,.folder-child-item,.chat-item-primary,.section-item{min-height:44px;padding:10px 12px}.login-btn,.signup-btn,.login-btn-compact{min-height:44px}}.settings-panel{position:absolute;bottom:80px;left:12px;width:260px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026,0 0 0 1px #0000000d;padding:8px 0;z-index:1000;overflow:hidden;transform-origin:bottom left}.settings-section{padding:8px 0}.settings-section:first-child{padding-top:4px}.section-header{padding:8px 16px;font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.settings-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:all .2s;color:#334155;font-size:.95rem;font-weight:500}.settings-item:hover{background-color:#f1f5f9;color:#1e3a8a}.settings-item.danger{color:#ef4444}.settings-item.danger:hover{background-color:#fef2f2}.divider{height:1px;background-color:#e2e8f0;margin:4px 0}.settings-item svg{color:#64748b;transition:color .2s}.settings-item:hover svg{color:#1e293b}.settings-item.danger svg{color:#ef4444}.explore-panel{position:absolute;top:220px;left:100%;margin-left:10px;width:240px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a,0 0 0 1px #0000000d;padding:8px 0;z-index:1000;overflow:hidden;transform-origin:top left}.explore-close-btn{position:absolute;top:8px;right:8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:transparent;border:none;color:#94a3b8;cursor:pointer;transition:all .2s;z-index:10}.explore-close-btn:hover{background-color:#f1f5f9;color:#64748b}.explore-items-container{padding-top:12px}.explore-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:all .2s;color:#334155;font-size:.9rem;font-weight:500}.explore-item:hover{background-color:#f1f5f9;color:#1e3a8a}.explore-item svg{color:#64748b;transition:color .2s}.explore-item:hover svg{color:#1e3a8a}.explore-item svg.heart-icon{color:#64748b}.explore-item:hover svg.heart-icon{color:#ef4444}.theme-toggle{position:relative;width:40px;height:40px;background:transparent;border:none;cursor:pointer;padding:0;outline:none;display:flex;align-items:center;justify-content:center}.theme-toggle-track{width:40px;height:40px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:50%;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;justify-content:center}.theme-toggle:hover .theme-toggle-track{background:var(--glass-bg-strong);box-shadow:0 4px 12px #00000026;transform:scale(1.05)}.theme-toggle-thumb{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);animation:iconRotate .5s cubic-bezier(.4,0,.2,1)}.theme-toggle-thumb.light{color:#fbbf24}.theme-toggle-thumb.dark{color:#6366f1}.theme-icon{width:20px;height:20px}.theme-toggle:focus-visible{outline:2px solid var(--primary-blue);outline-offset:2px;border-radius:50%}@keyframes iconRotate{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.2)}to{transform:rotate(360deg) scale(1)}}.icon-animated{display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease}.icon-animated:hover,.nav-item:hover .icon-animated,.search-pill:hover .icon-animated,button:hover .icon-animated{transform:scale(1.15)}.icon-rotate:hover,.nav-item:hover .icon-rotate,.search-pill:hover .icon-rotate,button:hover .icon-rotate{transform:rotate(15deg) scale(1.1)}.icon-bounce:hover,.nav-item:hover .icon-bounce,.search-pill:hover .icon-bounce,button:hover .icon-bounce{animation:simpleBounce .5s ease}@keyframes simpleBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.icon-pulse:hover,.nav-item:hover .icon-pulse,.search-pill:hover .icon-pulse,button:hover .icon-pulse{animation:simplePulse .5s ease}@keyframes simplePulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.icon-wiggle:hover,.nav-item:hover .icon-wiggle,.search-pill:hover .icon-wiggle,button:hover .icon-wiggle{animation:simpleWiggle .5s ease}@keyframes simpleWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.markdown-message{font-size:15px;line-height:1.6;color:#1f2937}.markdown-message.has-rich-content{margin-bottom:16px;animation:fadeInUp .3s ease-out}.markdown-h1{font-size:24px;font-weight:700;margin:20px 0 12px;color:#111827;border-bottom:2px solid rgb(0 102 204 / 30%);padding-bottom:8px}.markdown-h2{font-size:20px;font-weight:600;margin:18px 0 10px;color:#111827}.markdown-h3{font-size:17px;font-weight:600;margin:16px 0 8px;color:#1f2937}.markdown-paragraph{margin:0 0 12px;line-height:1.7;color:#374151}.markdown-paragraph:last-child{margin-bottom:0}.markdown-list{margin:12px 0;padding-left:24px}.markdown-list.numbered{list-style-type:decimal}.markdown-list:not(.numbered){list-style-type:disc}.markdown-list-item{margin:6px 0;padding-left:4px;line-height:1.6;color:#374151}.markdown-list-item::marker{color:#00d9ff}.markdown-message strong{font-weight:600;color:#111827}.markdown-message em{font-style:italic;color:#4b5563}.markdown-link{color:#00d9ff;text-decoration:none;border-bottom:1px solid transparent;transition:all .2s ease}.markdown-link:hover{border-bottom-color:#00d9ff}.markdown-inline-image{max-width:100%;max-height:300px;border-radius:8px;margin:8px 0;display:block}.markdown-inline-code{background:#0000004d;padding:2px 6px;border-radius:4px;font-family:Fira Code,Monaco,Consolas,monospace;font-size:13px;color:#feca57}.markdown-code-block{background:#0006;border-radius:8px;padding:16px;margin:12px 0;overflow-x:auto}.markdown-code-block code{font-family:Fira Code,Monaco,Consolas,monospace;font-size:13px;color:#e0e0e0;line-height:1.5;white-space:pre}.markdown-blockquote{border-left:4px solid #00d9ff;margin:12px 0;padding:8px 16px;background:#00d9ff1a;border-radius:0 8px 8px 0;font-style:italic;color:#b0b0b0}.markdown-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}.markdown-table td{padding:10px 12px;border-bottom:1px solid rgb(255 255 255 / 10%)}.markdown-table tr.table-header td{font-weight:600;color:#fff;border-bottom:2px solid rgb(0 217 255 / 30%)}.markdown-table tr:hover td{background:#ffffff0d}.markdown-message.concert .markdown-h2,.markdown-message.concert .markdown-h3{color:#ff6b6b}.markdown-message.sports .markdown-h2,.markdown-message.sports .markdown-h3{color:#feca57}.markdown-message.festival .markdown-h2,.markdown-message.festival .markdown-h3{color:#a55eea}.markdown-h1 svg,.markdown-h2 svg,.markdown-h3 svg{vertical-align:middle;margin-right:8px}.markdown-message.concert .markdown-list-item{position:relative;padding-left:8px}.markdown-message.concert .markdown-list-item strong{color:#ff6b6b}@media(max-width:640px){.markdown-message{font-size:14px}.markdown-h1{font-size:20px}.markdown-h2{font-size:18px}.markdown-h3{font-size:16px}.markdown-list{padding-left:20px}.markdown-code-block{padding:12px;font-size:12px}.markdown-table{font-size:13px}.markdown-table td{padding:8px}}.markdown-code-block::-webkit-scrollbar{height:8px}.markdown-code-block::-webkit-scrollbar-track{background:#0003;border-radius:4px}.markdown-code-block::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.markdown-code-block::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.markdown-message ::selection{background:#00d9ff4d;color:#fff}[data-theme=dark] .markdown-message{color:#e0e0e0}[data-theme=dark] .markdown-paragraph{color:#d1d5db}[data-theme=dark] .markdown-h1{color:#fff;border-bottom-color:#00d9ff4d}[data-theme=dark] .markdown-h2,[data-theme=dark] .markdown-h3,[data-theme=dark] .markdown-message strong{color:#fff}[data-theme=dark] .markdown-message em{color:#b0b0b0}[data-theme=dark] .markdown-list-item{color:#d1d5db}[data-theme=dark] .markdown-list-item::marker{color:#00d9ff}[data-theme=dark] .markdown-link{color:#00d9ff}[data-theme=dark] .markdown-link:hover{border-bottom-color:#00d9ff}[data-theme=dark] .markdown-inline-code{background:#0000004d;color:#feca57}[data-theme=dark] .markdown-code-block{background:#0006;border:none}[data-theme=dark] .markdown-code-block code{color:#e0e0e0}[data-theme=dark] .markdown-blockquote{background:#00d9ff1a;border-left-color:#00d9ff;color:#b0b0b0}[data-theme=dark] .markdown-table td{border-bottom-color:#ffffff1a;color:#d1d5db}[data-theme=dark] .markdown-table tr.table-header td{border-bottom-color:#00d9ff4d;color:#fff}[data-theme=dark] .markdown-table tr:hover td{background:#ffffff0d}.rich-search-results{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;padding:20px;margin:12px 0;color:#fff;box-shadow:0 8px 32px #0000004d}.concert-results{background:linear-gradient(135deg,#2d1b4e,#1a1a2e)}.result-hero-image{position:relative;width:100%;height:200px;border-radius:12px;overflow:hidden;margin-bottom:16px}.result-hero-image img{width:100%;height:100%;object-fit:cover}.hero-overlay{position:absolute;top:12px;right:12px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:20px;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.concert-header{text-align:center;margin-bottom:20px}.artist-name{font-size:28px;font-weight:700;margin:0 0 8px;background:linear-gradient(90deg,#ff6b6b,#feca57);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.tour-name{font-size:16px;color:#a0a0a0;margin:0 0 12px}.tour-stats{display:flex;justify-content:center;gap:12px}.stat-badge{background:#ffffff1a;padding:6px 14px;border-radius:20px;font-size:14px;display:flex;align-items:center;gap:6px}.tour-dates-list{margin-top:20px}.tour-dates-list h4{font-size:16px;margin:0 0 12px;color:#e0e0e0}.dates-grid{display:grid;gap:10px}.date-card{background:#ffffff0d;border-radius:10px;padding:12px;display:flex;justify-content:space-between;align-items:flex-start;border:1px solid rgb(255 255 255 / 10%);transition:all .2s ease}.date-card:hover{background:#ffffff1a;border-color:#fff3}.date-info{display:flex;flex-direction:column;gap:4px}.date-text{font-weight:600;color:#fff;font-size:14px}.venue-text{color:#b0b0b0;font-size:13px}.location-text{color:#888;font-size:12px;display:flex;align-items:center;gap:4px}.ticket-link{background:linear-gradient(90deg,#ff6b6b,#ee5a5a);color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;text-decoration:none;display:flex;align-items:center;gap:6px;transition:all .2s ease;white-space:nowrap}.ticket-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.more-dates{text-align:center;color:#888;font-size:14px;margin-top:12px;font-style:italic}.sports-results{background:linear-gradient(135deg,#1e3a5f,#0f2027)}.sports-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgb(255 255 255 / 10%)}.sports-icon{color:#feca57}.team-name{font-size:24px;font-weight:700;margin:0 0 4px}.game-count{color:#888;font-size:14px}.games-list{display:flex;flex-direction:column;gap:8px}.game-card{display:flex;align-items:center;gap:12px;background:#ffffff0d;padding:12px;border-radius:10px;border:1px solid rgb(255 255 255 / 10%)}.game-number{width:28px;height:28px;background:#feca5733;color:#feca57;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}.game-info{display:flex;flex-direction:column;gap:2px;flex:1}.game-date{font-weight:600;font-size:14px}.game-title{color:#b0b0b0;font-size:13px}.game-venue{color:#888;font-size:12px;display:flex;align-items:center;gap:4px}.more-games{text-align:center;color:#888;font-size:14px;margin-top:12px;font-style:italic}.festival-results{background:linear-gradient(135deg,#2d1b4e,#1a0f2e)}.festival-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgb(255 255 255 / 10%)}.festival-icon{color:#a55eea}.festival-name{font-size:24px;font-weight:700;margin:0}.festival-events{display:flex;flex-direction:column;gap:12px}.festival-event-card{background:#ffffff0d;padding:16px;border-radius:12px;border:1px solid rgb(255 255 255 / 10%)}.festival-event-card h4{margin:0 0 8px;font-size:16px}.event-date,.event-location{display:flex;align-items:center;gap:6px;font-size:13px;color:#b0b0b0;margin-top:4px}.event-link{display:inline-flex;align-items:center;gap:6px;color:#a55eea;text-decoration:none;font-size:13px;margin-top:8px;font-weight:500}.event-link:hover{text-decoration:underline}.general-results{background:linear-gradient(135deg,#1a1a2e,#16213e)}.image-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.gallery-image{border-radius:10px;overflow:hidden;aspect-ratio:16/9}.gallery-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-image:hover img{transform:scale(1.05)}.search-results-list{display:flex;flex-direction:column;gap:10px}.search-result-link{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:#ffffff0d;padding:14px;border-radius:10px;text-decoration:none;color:inherit;border:1px solid rgb(255 255 255 / 10%);transition:all .2s ease}.search-result-link:hover{background:#ffffff1a;border-color:#fff3}.result-content{flex:1}.result-content h4{margin:0 0 6px;font-size:15px;color:#fff}.result-content p{margin:0 0 6px;font-size:13px;color:#a0a0a0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-source{font-size:12px;color:#00d9ff}.action-section{margin-top:20px;padding-top:20px;border-top:1px solid rgb(255 255 255 / 10%);text-align:center}.action-text{color:#b0b0b0;font-size:14px;margin:0 0 12px}.action-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.action-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.action-btn.primary{background:linear-gradient(90deg,#00d9ff,#00a8e8);color:#fff}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00d9ff66}.action-btn.secondary{background:#ffffff1a;color:#fff}.action-btn.secondary:hover{background:#fff3}.default-results{background:#ffffff0d}.message-content{white-space:pre-wrap;line-height:1.6}@media(max-width:640px){.rich-search-results{padding:16px}.artist-name{font-size:22px}.team-name,.festival-name{font-size:20px}.date-card{flex-direction:column;gap:10px}.ticket-link{width:100%;justify-content:center}.image-gallery{grid-template-columns:1fr}.action-btn{width:100%;justify-content:center}}@media(prefers-color-scheme:light){.rich-search-results{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#1f2937;box-shadow:0 4px 20px #0000001a}.concert-results{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}.sports-results{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.festival-results{background:linear-gradient(135deg,#f3e5f5,#ce93d8)}.artist-name{background:linear-gradient(90deg,#7c4dff,#651fff);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.tour-name{color:#4b5563}.stat-badge{background:#0000000d;color:#374151}.date-card,.game-card,.festival-event-card,.search-result-link{background:#fff;border-color:#0000001a}.date-text{color:#111827}.venue-text{color:#4b5563}.location-text{color:#6b7280}.team-name,.festival-name{color:#111827}.game-count{color:#6b7280}.game-date{color:#111827}.game-title{color:#4b5563}.game-venue{color:#6b7280}.festival-event-card h4{color:#111827}.event-date,.event-location,.action-text{color:#4b5563}.action-btn.secondary{background:#0000000d;color:#374151}.action-btn.secondary:hover{background:#0000001a}.result-content h4{color:#111827}.result-content p{color:#4b5563}.result-source{color:#06c}}.journii-bar-container{position:fixed;bottom:24px;z-index:var(--z-sticky);display:flex;flex-direction:column;align-items:center;pointer-events:none;left:var(--primary-width, 80px);right:0;width:calc(100% - var(--primary-width, 80px));transition:left .3s ease,width .3s ease}.journii-bar-container.primary-collapsed{--primary-width: 80px}.journii-bar-container.primary-expanded{--primary-width: 260px}.journii-bar-container>*{pointer-events:auto}.journii-bar-toggle{align-self:center;margin-bottom:6px;width:32px;height:20px;border-radius:10px;border:1px solid var(--border-subtle, #e5e7eb);background:var(--surface-white, #fff);color:var(--text-secondary, #6b7280);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000014;transition:all .2s ease;z-index:1;pointer-events:auto;opacity:.6}.journii-bar-toggle:hover{background:var(--surface-subtle, #f3f4f6);color:var(--text-main, #111827);opacity:1}.journii-bar-toggle.minimized{opacity:1;background:var(--primary-blue, #2563eb);border-color:var(--primary-blue, #2563eb);color:#fff}.journii-bar-inner{width:100%;max-width:720px;display:flex;flex-direction:column;align-items:center;max-height:900px;opacity:1;overflow:hidden;transition:max-height .35s ease,opacity .25s ease}.journii-bar-inner.minimized{max-height:0;opacity:0;pointer-events:none}.journii-chat-window{width:100%;max-width:min(720px,calc(100vw - var(--primary-width, 80px) - var(--secondary-width, 0px) - 48px));margin-bottom:16px;background:var(--surface-white, #fff);border-radius:16px;box-shadow:0 4px 24px #0000001f;border:1px solid var(--border-subtle, #e5e7eb);max-height:400px;min-height:200px;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}.journii-chat-window.expanded{max-height:600px;min-height:400px}.journii-chat-window-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-subtle, #e5e7eb);background:var(--surface-subtle, #f9fafb)}.journii-chat-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--primary-blue, #2563eb)}.journii-chat-actions{display:flex;gap:8px}.journii-expand-btn,.journii-close-btn{width:36px;height:36px;border-radius:6px;border:none;background:transparent;color:var(--text-secondary, #6b7280);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.journii-expand-btn:hover,.journii-close-btn:hover{background:var(--surface-hover, #f3f4f6);color:var(--text-main, #111827)}.journii-chat-messages{flex:1 1 0%;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.journii-chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:100%;min-height:300px;color:var(--text-muted, #9ca3af);text-align:center;padding:20px}.journii-welcome-title{font-size:18px;font-weight:600;color:var(--text-main);margin:8px 0 4px}.journii-welcome-message{font-size:14px;line-height:1.5;color:var(--text-secondary);margin:0 0 8px;max-width:400px}.journii-welcome-cta{font-size:13px;line-height:1.5;color:var(--text-muted);margin:0;max-width:400px;padding:12px 16px;background:var(--surface-hover);border-radius:8px;border-left:3px solid #667eea}.journii-message{max-width:85%;animation:fadeIn .3s ease}.journii-message.user{align-self:flex-end}.journii-message.ai{align-self:flex-start}.journii-user-message{background:var(--primary-blue, #2563eb);color:#fff;padding:12px 16px;border-radius:16px 16px 4px;font-size:.95rem;line-height:1.5}.journii-user-message p{margin:0}.journii-ai-message{background:var(--surface-subtle, #f3f4f6);color:var(--text-main, #111827);padding:12px 16px;border-radius:16px 16px 16px 4px;font-size:.95rem;line-height:1.5}.journii-suggestions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.journii-suggestion-chip{padding:6px 12px;background:var(--surface-white, #fff);border:1px solid var(--border-subtle, #e5e7eb);border-radius:16px;font-size:.85rem;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .2s ease}.journii-suggestion-chip:hover{background:var(--primary-blue, #3b82f6);color:#fff;border-color:var(--primary-blue, #3b82f6);transform:translateY(-1px)}.journii-message-media{margin-top:8px}.journii-message-media img{max-width:200px;max-height:150px;border-radius:8px;object-fit:cover;border:1px solid var(--border-subtle, #e5e7eb)}.journii-bar-wrapper{width:100%;display:flex;flex-direction:column;gap:8px}.journii-media-chips-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.journii-media-chip{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 4px;background:var(--surface-white, #fff);border-radius:20px;font-size:.8rem;color:var(--text-secondary, #6b7280);border:1px solid var(--border-subtle, #e5e7eb);box-shadow:0 1px 3px #0000001a}.journii-media-chip img{width:24px;height:24px;object-fit:cover;border-radius:12px}.journii-media-chip.link-chip{padding-left:4px;position:relative}.journii-media-chip .link-thumbnail{width:40px;height:28px;object-fit:cover;border-radius:6px;background:var(--surface-subtle, #f3f4f6)}.platform-badge{position:absolute;bottom:-4px;left:-2px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 1px 3px #0003;border:2px solid var(--surface-white, #fff)}.platform-badge.youtube{background:red}.platform-badge.tiktok{background:#000}.platform-badge.instagram{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}.platform-badge.vimeo{background:#1ab7ea}.journii-media-chip .chip-label{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.journii-media-chip .chip-remove{width:24px;height:24px;border-radius:50%;border:none;background:var(--border-subtle, #e5e7eb);color:var(--text-secondary, #6b7280);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s}.journii-media-chip .chip-remove:hover{background:#fecaca;color:#dc2626}.journii-error-row{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.85rem;justify-content:center}.journii-error-row button{background:none;border:none;color:#dc2626;cursor:pointer;padding:2px}.journii-bar{width:100%;background:var(--surface-white, #fff);border:1px solid var(--border-subtle, #e5e7eb);border-radius:24px;box-shadow:0 4px 20px #00000014;display:flex;flex-direction:column;overflow:hidden;transition:all .2s ease}.journii-bar:hover{box-shadow:0 6px 24px #0000001f}.journii-bar:focus-within{border-color:var(--primary-blue, #2563eb);box-shadow:0 0 0 3px #2563eb1a,0 6px 24px #0000001f}.journii-row-input{padding:12px 16px 8px}.journii-textarea{width:100%;min-height:24px;max-height:200px;border:none;background:transparent;font-size:1rem;color:var(--text-main, #111827);resize:none;outline:none;line-height:1.5;font-family:inherit}.journii-textarea::placeholder{color:var(--text-muted, #9ca3af)}.journii-row-actions{display:flex;align-items:center;gap:8px;padding:8px 12px 12px;border-top:1px solid var(--border-subtle, #e5e7eb)}.journii-plus-wrapper{position:relative}.journii-btn{width:40px;height:40px;border-radius:50%;border:none;background:transparent;color:var(--text-secondary, #6b7280);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.journii-btn:hover{background:var(--surface-subtle, #f3f4f6);color:var(--text-main, #111827)}.journii-btn-plus:hover{background:var(--primary-blue, #2563eb);color:#fff}.journii-plus-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:var(--surface-white, #fff);border-radius:12px;box-shadow:0 4px 24px #00000026;border:1px solid var(--border-subtle, #e5e7eb);padding:8px;min-width:160px;z-index:1001;animation:fadeIn .2s ease}.journii-plus-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;color:var(--text-main, #111827);font-size:.9rem;cursor:pointer;transition:all .2s}.journii-plus-menu button:hover{background:var(--surface-subtle, #f3f4f6)}.journii-tools{display:flex;align-items:center;gap:4px}.journii-tool-btn{width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:var(--text-muted, #9ca3af);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.journii-tool-btn:hover{background:var(--surface-subtle, #f3f4f6);color:var(--text-secondary, #6b7280)}.journii-divider{width:1px;height:24px;background:var(--border-subtle, #e5e7eb);margin:0 4px}.journii-right-actions{display:flex;align-items:center;gap:4px;margin-left:auto}.journii-btn-mic.recording{background:#fecaca;color:#dc2626;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.journii-btn-send{opacity:.4}.journii-btn-send.active{opacity:1;background:var(--primary-blue, #2563eb);color:#fff}.journii-btn-send.active:hover{background:var(--primary-blue-hover, #1d4ed8)}@media(max-width:767px){.journii-bar-container,.journii-bar-container.primary-collapsed,.journii-bar-container.primary-expanded,.journii-bar-container.has-secondary,.journii-bar-container.no-secondary,.journii-bar-container.secondary-collapsed,.journii-bar-container.secondary-expanded{left:0;right:0;width:100%;bottom:0}.journii-btn,.journii-tool-btn,.journii-expand-btn,.journii-close-btn,.journii-mobile-action-btn{min-width:44px;min-height:44px;width:44px;height:44px}.journii-media-chip .chip-remove{width:32px;height:32px;min-width:32px;min-height:32px}.journii-mobile-sheet-overlay{position:fixed;inset:0;background:#0000007f;z-index:2000;display:flex;flex-direction:column;justify-content:flex-end;animation:fadeIn .2s ease}.journii-mobile-sheet{background:var(--surface-white, #fff);border-radius:20px 20px 0 0;max-height:85vh;min-height:200px;display:flex;flex-direction:column;animation:slideUpSheet .3s ease;height:auto}.journii-mobile-sheet.has-messages{max-height:90vh}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.journii-mobile-sheet-header{padding:12px 16px;border-bottom:1px solid var(--border-subtle, #e5e7eb);background:var(--surface-subtle, #f9fafb);border-radius:20px 20px 0 0;flex-shrink:0}.journii-sheet-handle{width:40px;height:4px;background:var(--border-subtle, #e5e7eb);border-radius:2px;margin:0 auto 12px}.journii-sheet-title-row{display:flex;align-items:center;justify-content:space-between}.journii-sheet-title-row .journii-close-btn{width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text-secondary, #6b7280);display:flex;align-items:center;justify-content:center;cursor:pointer}.journii-mobile-sheet-content{flex:1 1 0%;overflow-y:auto;padding:16px;display:flex;flex-direction:column;justify-content:flex-start;min-height:150px}.journii-messages-list{display:flex;flex-direction:column;gap:12px;width:100%}.journii-mobile-sheet-content .journii-chat-empty{min-height:150px;padding:40px 20px}.journii-chat-hint{font-size:.85rem;color:var(--text-muted, #9ca3af);margin-top:8px}.journii-mobile-sheet-input{padding:12px 16px calc(12px + var(--safe-area-bottom, 0px));border-top:1px solid var(--border-subtle, #e5e7eb);background:var(--surface-white, #fff);flex-shrink:0}.journii-mobile-media-row{display:flex;gap:8px;margin-bottom:8px;overflow-x:auto;padding-bottom:4px}.journii-mobile-media-row .journii-media-chip{flex-shrink:0}.journii-mobile-media-row .journii-media-chip img{width:40px;height:40px}.journii-mobile-input-wrapper{display:flex;align-items:flex-end;gap:8px;position:relative}.journii-mobile-action-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--surface-subtle, #f3f4f6);color:var(--text-secondary, #6b7280);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .2s}.journii-mobile-action-btn:active{transform:scale(.95)}.journii-mobile-action-btn.send.active{background:var(--primary-blue, #2563eb);color:#fff}.journii-mobile-plus-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:var(--surface-white, #fff);border-radius:12px;box-shadow:0 4px 24px #00000026;border:1px solid var(--border-subtle, #e5e7eb);padding:8px;display:flex;gap:8px;z-index:1001}.journii-mobile-plus-menu button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 16px;border:none;background:transparent;border-radius:8px;color:var(--text-main, #111827);font-size:.8rem;cursor:pointer}.journii-mobile-plus-menu button:hover{background:var(--surface-subtle, #f3f4f6)}.journii-mobile-textarea{flex:1 1 0%;min-height:40px;max-height:120px;border:1px solid var(--border-subtle, #e5e7eb);border-radius:20px;padding:10px 14px;font-size:16px;resize:none;outline:none;font-family:inherit;background:var(--surface-white, #fff)}.journii-mobile-textarea:focus{border-color:var(--primary-blue, #2563eb)}.journii-mobile-fab{position:fixed;bottom:calc(var(--bottom-nav-height, 60px) + var(--safe-area-bottom, 0px) + 16px);right:16px;width:56px;height:56px;border-radius:50%;border:none;background:var(--primary-blue, #2563eb);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #2563eb66;cursor:pointer;z-index:1000;transition:transform .2s,box-shadow .2s}.journii-mobile-fab:active{transform:scale(.95)}.journii-mobile-bottom-bar{position:fixed;bottom:calc(var(--bottom-nav-height, 60px) + var(--safe-area-bottom, 0px));left:0;right:0;padding:12px 16px;background:var(--surface-white, #fff);border-top:1px solid var(--border-subtle, #e5e7eb);z-index:1000}[data-theme=dark] .journii-mobile-sheet{background:var(--surface-elevated, #1f2937)}[data-theme=dark] .journii-mobile-sheet-header,[data-theme=dark] .journii-mobile-bottom-bar{background:var(--surface-subtle, #111827);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-mobile-sheet-input{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-mobile-textarea{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #4b5563);color:var(--text-main, #f9fafb)}[data-theme=dark] .journii-mobile-action-btn{background:var(--surface-subtle, #374151);color:var(--text-secondary, #9ca3af)}[data-theme=dark] .journii-mobile-action-btn.send.active{background:var(--primary-blue, #2563eb);color:#fff}[data-theme=dark] .journii-mobile-plus-menu{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-mobile-sheet-overlay{background:#000000b3}[data-theme=dark] .journii-media-chip.link-chip{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .platform-badge{border-color:var(--surface-elevated, #1f2937)}}[data-theme=dark] .journii-chat-window{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-chat-window-header{background:var(--surface-subtle, #111827);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-chat-title{color:var(--primary-blue, #60a5fa)}[data-theme=dark] .journii-ai-message{background:var(--surface-subtle, #374151);color:var(--text-main, #f9fafb)}[data-theme=dark] .journii-bar{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-bar:focus-within{border-color:var(--primary-blue, #60a5fa);box-shadow:0 0 0 3px #60a5fa33,0 6px 24px #0000004d}[data-theme=dark] .journii-row-actions{border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-textarea{color:var(--text-main, #f9fafb)}[data-theme=dark] .journii-textarea::placeholder{color:var(--text-muted, #6b7280)}[data-theme=dark] .journii-btn{color:var(--text-secondary, #9ca3af)}[data-theme=dark] .journii-btn:hover{background:var(--surface-subtle, #374151);color:var(--text-main, #f9fafb)}[data-theme=dark] .journii-btn-send.active{background:var(--primary-blue, #2563eb);color:#fff}[data-theme=dark] .journii-tool-btn{color:var(--text-muted, #6b7280)}[data-theme=dark] .journii-tool-btn:hover{background:var(--surface-subtle, #374151);color:var(--text-secondary, #9ca3af)}[data-theme=dark] .journii-divider{background:var(--border-subtle, #374151)}[data-theme=dark] .journii-media-chip{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151);color:var(--text-secondary, #9ca3af)}[data-theme=dark] .journii-media-chip .chip-remove{background:var(--border-subtle, #4b5563);color:var(--text-secondary, #9ca3af)}[data-theme=dark] .journii-plus-menu{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .journii-plus-menu button{color:var(--text-main, #f9fafb)}[data-theme=dark] .journii-plus-menu button:hover{background:var(--surface-subtle, #374151)}[data-theme=dark] .journii-error-row{background:#dc26261a;border-color:#dc26264d;color:#fca5a5}[data-theme=dark] .journii-media-chip.link-chip{background:var(--surface-elevated, #1f2937);border-color:var(--border-subtle, #374151)}[data-theme=dark] .platform-badge{border-color:var(--surface-elevated, #1f2937)}@media(min-width:768px)and (max-width:1023px){.journii-bar-container{transition:left .3s ease,right .3s ease,width .3s ease}.journii-bar-inner,.journii-chat-window{max-width:640px}}@media(min-width:1024px){.journii-bar-container{transition:left .3s ease,right .3s ease,width .3s ease}}@media(min-width:1440px){.journii-bar-inner,.journii-chat-window{max-width:800px}}.journii-url-modal-backdrop{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.journii-url-modal{background:var(--surface-white, #fff);border-radius:12px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}.journii-url-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-subtle, #e5e7eb)}.journii-url-modal-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-main, #111827)}.journii-url-modal-close{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-secondary, #6b7280);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.journii-url-modal-close:hover{background:var(--surface-subtle, #f3f4f6);color:var(--text-main, #111827)}.journii-url-modal-body{padding:24px}.journii-url-input{width:100%;padding:12px 16px;border:2px solid var(--border-subtle, #e5e7eb);border-radius:8px;font-size:15px;font-family:inherit;outline:none;transition:border-color .2s}.journii-url-input:focus{border-color:var(--primary-blue, #2563eb)}.journii-url-error{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px 12px;background:#dc26261a;border:1px solid rgb(220 38 38 / 20%);border-radius:6px;color:#dc2626;font-size:14px}.journii-url-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-subtle, #e5e7eb)}.journii-url-btn{padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.journii-url-btn-cancel{background:transparent;color:var(--text-secondary, #6b7280)}.journii-url-btn-cancel:hover{background:var(--surface-subtle, #f3f4f6);color:var(--text-main, #111827)}.journii-url-btn-submit{background:var(--primary-blue, #2563eb);color:#fff}.journii-url-btn-submit:hover:not(:disabled){background:#1d4ed8}.journii-url-btn-submit:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .journii-url-modal{background:var(--surface-dark, #1f2937)}[data-theme=dark] .journii-url-modal-header{border-bottom-color:var(--border-dark, #374151)}[data-theme=dark] .journii-url-modal-header h3{color:var(--text-light, #f9fafb)}[data-theme=dark] .journii-url-input{background:var(--surface-darker, #111827);border-color:var(--border-dark, #374151);color:var(--text-light, #f9fafb)}[data-theme=dark] .journii-url-modal-footer{border-top-color:var(--border-dark, #374151)}.mobile-bottom-nav{display:flex;align-items:center;justify-content:space-around;position:fixed;bottom:0;left:0;right:0;height:56px;background:var(--surface-white);border-top:1px solid var(--border-subtle);padding-bottom:var(--safe-area-bottom);z-index:var(--z-bottom-nav);box-shadow:0 -2px 10px #0000000d}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1 1 0%;height:100%;background:transparent;border:none;color:var(--text-muted);font-size:.65rem;font-weight:500;cursor:pointer;transition:var(--transition-fast);padding:4px 2px}.mobile-nav-item svg{color:var(--primary-blue)}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:var(--text-muted)}.mobile-nav-item.active svg{color:var(--primary-blue)}.mobile-menu-drawer{display:flex;flex-direction:column;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom));z-index:calc(var(--z-drawer) + 10)}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-subtle)}.menu-header-actions{display:flex;align-items:center;gap:12px}.menu-logo{display:flex;align-items:center;gap:8px;cursor:pointer}.menu-logo-img{width:32px;height:32px;object-fit:contain}.menu-logo span{font-size:1.1rem;font-weight:700;color:var(--text-main)}.menu-close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);border-radius:50%;cursor:pointer;transition:var(--transition-fast)}.menu-close-btn svg{width:22px;height:22px}.menu-close-btn:hover{background:var(--bg-page);color:var(--text-main)}.mobile-menu-user{padding:12px 14px;border-top:1px solid var(--border-subtle);margin-top:auto}.menu-user-info{display:flex;align-items:center;gap:10px}.menu-avatar{width:42px;height:42px;border-radius:50%;object-fit:cover}.menu-user-details{display:flex;flex-direction:column;gap:2px}.menu-user-name{font-weight:600;font-size:.9rem;color:var(--text-main)}.menu-user-handle{font-size:.75rem;color:var(--text-muted)}.menu-auth-buttons{display:flex;gap:12px}.menu-login-btn,.menu-signup-btn{flex:1 1 0%;padding:12px 16px;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:var(--transition-fast)}.menu-login-btn{background:transparent;color:var(--text-main);border:1px solid var(--border-subtle)}.menu-signup-btn{background:var(--primary-blue);color:#fff;border:none}.mobile-menu-items{flex:1 1 0%;padding:6px 0;overflow-y:auto}.mobile-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;background:transparent;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:var(--transition-fast);text-align:left}.mobile-menu-item svg{width:18px;height:18px;color:var(--primary-blue)}.mobile-menu-item:active{background:var(--bg-page)}.mobile-menu-item.active{color:var(--text-secondary);background:#e6f2ff}.mobile-menu-item span{flex:1 1 0%}.menu-item-arrow{color:var(--primary-blue);width:16px;height:16px}.menu-divider{height:1px;background:var(--border-subtle);margin:6px 14px}.mobile-menu-trips{padding:8px 14px 12px;border-top:1px solid var(--border-subtle)}.menu-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.menu-section-header span{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.menu-add-trip-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-page);border:1px solid var(--border-subtle);border-radius:50%;color:var(--text-muted);cursor:pointer;transition:var(--transition-fast)}.menu-add-trip-btn svg{width:14px;height:14px}.menu-add-trip-btn:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.menu-trips-list{display:flex;flex-direction:column;gap:3px}.menu-trip-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:var(--transition-fast);text-align:left}.menu-trip-item svg{width:16px;height:16px}.menu-trip-item:active{background:var(--bg-page)}.mobile-menu-footer{padding:10px 14px 12px;border-top:1px solid var(--border-subtle);margin-top:auto}.mobile-menu-social{padding:16px 12px;margin-bottom:12px;text-align:center}.mobile-menu-social .social-section-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.menu-user-section{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-page);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast);margin-bottom:8px}.menu-user-section:hover{background:var(--border-subtle)}.menu-user-section .menu-avatar{flex-shrink:0}.menu-user-section .menu-user-details{flex:1 1 0%;display:flex;flex-direction:column;gap:2px}.menu-user-section .menu-user-name{font-weight:600;font-size:.9rem;color:var(--text-main)}.menu-user-section .menu-user-handle{font-size:.75rem;color:var(--text-muted)}.menu-user-section .settings-icon{color:var(--text-muted);flex-shrink:0}.menu-settings-panel{display:flex;flex-direction:column;gap:4px;margin-bottom:8px;padding:8px;background:var(--bg-page);border-radius:var(--radius-md)}.menu-footer-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:var(--transition-fast);text-align:left}.menu-footer-btn svg{width:18px;height:18px}.menu-footer-btn:active{background:var(--bg-page)}.menu-footer-btn.admin{color:var(--primary-blue);font-weight:600}.menu-footer-btn.logout{color:#ef4444}.mobile-menu-legal{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px;padding:12px 16px 0;font-size:.75rem;color:var(--text-muted)}.mobile-menu-legal a{color:var(--text-muted);text-decoration:none;transition:color .2s}.mobile-menu-legal a:hover{color:var(--text-primary)}.mobile-menu-legal .legal-separator{color:var(--border-subtle)}@media(max-width:767px),(hover:none)and (pointer:coarse){.mobile-nav-item{min-height:56px;padding:6px 4px}.mobile-menu-item,.menu-trip-item{min-height:48px;padding:12px 16px}.menu-close-btn,.menu-add-trip-btn{min-width:44px;min-height:44px;width:44px;height:44px}.menu-login-btn,.menu-signup-btn{min-height:48px}.menu-footer-btn{min-height:48px;padding:12px 16px}.menu-user-section{min-height:56px;padding:16px}}@media(min-width:768px){.mobile-bottom-nav,.mobile-menu-drawer{display:none}}.skip-to-content{position:absolute;top:-40px;left:0;background:var(--primary-blue);color:#fff;padding:8px 16px;text-decoration:none;font-weight:600;border-radius:0 0 4px;z-index:var(--z-system);transition:top .2s ease}.skip-to-content:focus{top:0;outline:3px solid var(--primary-blue);outline-offset:2px}.main-layout{display:flex;height:100dvh;width:100vw;overflow:hidden;background-color:transparent;position:relative}.main-layout.mobile{flex-direction:column;padding-top:var(--safe-area-top)}.main-layout.mobile .content-area{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 80px);padding-left:var(--container-padding);padding-right:var(--container-padding)}.content-area{flex:1 1 0%;display:flex;flex-direction:column;transform:translateZ(0);backface-visibility:hidden;perspective:1000px;position:relative;overflow:hidden auto;height:100%;min-height:0;width:100%;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior:none auto}.content-area.home-page{overflow-y:hidden}.content-area.stays-tab{overflow:hidden;padding-bottom:150px}@media(max-width:767px){.content-area{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 80px)}}.content-area-inner{flex:1 1 0%;display:flex;flex-direction:column;position:relative;overflow:hidden auto;height:100%;min-height:0;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;width:100%}.content-area::-webkit-scrollbar{width:8px}@media(max-width:767px){.content-area::-webkit-scrollbar{width:0;display:none}}.content-area::-webkit-scrollbar-track{background:transparent}.content-area::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}.content-area::-webkit-scrollbar-thumb:hover{background:#cbd5e1}@media(min-width:768px){.main-layout{flex-direction:row}.main-layout.mobile .content-area{padding-bottom:100px;padding-left:0;padding-right:0}.content-area{overflow-y:auto}}@media(min-width:1024px){.content-area{padding-bottom:100px}}@media(max-width:767px){.content-area{-webkit-user-select:none;user-select:none}.content-area *{-webkit-user-select:text;user-select:text}.content-area button,.content-area a,.content-area input,.content-area textarea{-webkit-user-select:none;user-select:none}}@media(prefers-reduced-motion:reduce){.content-area{scroll-behavior:auto;transition:none}}.collapsible-sec-sidebar{display:flex;height:100%;flex-shrink:0;gap:0;position:relative}.sec-sidebar-content{height:100%;overflow:hidden;transition:opacity .3s ease}.sec-sidebar-content>*{height:100%;width:100%}.sec-divider-collapse-btn{width:24px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-white, #fff);border:1px solid var(--border-subtle, #e5e7eb);border-radius:6px;cursor:pointer;color:var(--text-muted, #9ca3af);transition:all .2s ease;box-shadow:0 2px 8px #00000014;flex-shrink:0;opacity:.6}.sec-divider-collapse-btn:hover{background:var(--bg-page, #f8fafc);border-color:var(--primary-blue, #3b82f6);color:var(--primary-blue, #3b82f6);opacity:1;box-shadow:0 4px 12px #3b82f626}.collapsible-sec-sidebar.collapsed .sec-divider-collapse-btn{opacity:.8;background:var(--surface-white, #fff)}.collapsible-sec-sidebar.collapsed .sec-divider-collapse-btn:hover{opacity:1}[data-theme=dark] .sec-divider-collapse-btn{background:#1e293be5;border-color:#ffffff1a;color:#fff9}[data-theme=dark] .sec-divider-collapse-btn:hover{background:#1e293b;border-color:#60a5fa;color:#60a5fa}.sec-sidebar-collapsed-tab{width:0;height:100%;background:transparent;border:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease;position:relative;z-index:10}.sec-sidebar-collapsed-tab .sec-divider-collapse-btn{position:absolute;left:0;opacity:1;width:20px;height:64px;background:var(--surface-white, #fff);border:1px solid var(--border-subtle, #e5e7eb);border-radius:0 6px 6px 0;box-shadow:2px 0 8px #00000014}.sec-sidebar-collapsed-tab .sec-divider-collapse-btn:hover{width:24px;background:var(--bg-page, #f8fafc);border-color:var(--primary-blue, #3b82f6);box-shadow:2px 0 12px #3b82f633}[data-theme=dark] .sec-sidebar-collapsed-tab .sec-divider-collapse-btn{background:#1e293bf2;border-color:#ffffff1a;box-shadow:2px 0 8px #0000004d}[data-theme=dark] .sec-sidebar-collapsed-tab .sec-divider-collapse-btn:hover{background:#1e293b;border-color:#60a5fa;box-shadow:2px 0 12px #60a5fa4d}.collapsible-sec-sidebar.collapsed .sec-sidebar-content{display:none}@media(max-width:768px){.collapsible-sec-sidebar{display:none}}.mobile-secondary-drawer-toggle{display:none}@media(max-width:767px){.mobile-secondary-drawer-toggle{display:flex;align-items:center;justify-content:center;position:fixed;left:0;top:50%;transform:translateY(-50%);width:28px;height:40px;background:#3b82f6f2;color:#fff;border:none;border-radius:0 12px 12px 0;cursor:pointer;z-index:calc(var(--z-bottom-nav) - 1);box-shadow:2px 0 12px #3b82f64d;transition:all .25s cubic-bezier(.4,0,.2,1)}.mobile-secondary-drawer-toggle:hover{background:#3b82f6;width:32px;box-shadow:2px 0 16px #3b82f666}.mobile-secondary-drawer-toggle:active{transform:translateY(-50%) scale(.92)}.mobile-secondary-drawer-toggle:has(+.drawer-backdrop.open){left:280px;border-radius:8px 0 0 8px}.mobile-secondary-drawer{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 16px)}.mobile-secondary-drawer>*{height:100%;overflow-y:auto}}[data-theme=dark] .mobile-secondary-drawer-toggle{background:var(--primary-blue);box-shadow:2px 0 8px #0000004d}[data-theme=dark] .mobile-secondary-drawer-toggle:hover{background:var(--primary-blue-hover)}.mobile-secondary-drawer-toggle:focus-visible{outline:2px solid var(--primary-blue);outline-offset:2px}@media(prefers-reduced-motion:reduce){.mobile-secondary-drawer-toggle{transition:none}}.date-picker-overlay{position:absolute;top:100%;left:0;z-index:100;margin-top:12px}.date-picker-overlay.in-modal{position:fixed;z-index:1100;margin-top:0}.date-picker-overlay.placement-center{transform:translateY(0)}.date-picker-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #00000040;padding:24px;width:360px;border:1px solid rgb(0 0 0 / 5%);font-family:Inter,sans-serif;max-height:inherit;overflow-y:auto}.date-picker-overlay.placement-center .date-picker-card{box-shadow:0 25px 70px #0000004d}.date-picker-top-header{display:flex;justify-content:flex-end;align-items:center;padding:8px 8px 0;margin-bottom:8px}.date-picker-top-header .close-btn{background:transparent;border:none;color:#64748b;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;border-radius:4px}.date-picker-top-header .close-btn:hover{color:#1e293b;background:#0000000d}.nav-btn:hover,.close-btn:hover{background:#f1f5f9;color:#1e3a8a}.calendar-day.empty{cursor:default}.in-range-text{color:#1e3a8a}.range-bg{position:absolute;inset:4px 0;background-color:#e0e7ffb3;z-index:0}.range-bg.range-start{border-top-left-radius:999px;border-bottom-left-radius:999px}.range-bg.range-end{border-top-right-radius:999px;border-bottom-right-radius:999px}.date-picker-footer{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:16px;display:flex;justify-content:space-between;align-items:center}.selection-info{font-size:.85rem;color:#64748b;font-weight:500;text-align:center;flex:1}.apply-btn{background:#1e3a8a;color:#fff;border:none;padding:10px 20px;border-radius:999px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;box-shadow:0 4px 6px #1e3a8a33}.apply-btn:hover{background:#1e40af;transform:translateY(-1px)}[data-theme=dark] .nav-btn,[data-theme=dark] .close-btn{color:var(--text-secondary)}[data-theme=dark] .nav-btn:hover,[data-theme=dark] .close-btn:hover{background:var(--button-bg-hover);color:var(--primary-blue)}[data-theme=dark] .in-range-text{color:var(--primary-blue)}[data-theme=dark] .range-bg{background-color:var(--glass-accent-bg)}[data-theme=dark] .date-picker-footer{border-top:1px solid var(--border-subtle)}[data-theme=dark] .selection-info{color:var(--text-secondary)}[data-theme=dark] .apply-btn{background:var(--primary-blue);box-shadow:0 4px 6px var(--glow-blue)}[data-theme=dark] .apply-btn:hover{background:var(--primary-blue-hover)}.input-area-container{width:100%;max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md)}.transport-search-bar{background:transparent;border:none;border-radius:var(--radius-lg);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md);position:relative;width:100%;max-width:800px;margin:0 auto;box-shadow:none;transition:all .6s cubic-bezier(.16,1,.3,1);will-change:box-shadow,width,padding;font-size:117.647%}.transport-search-bar.has-active-tab{box-shadow:none;border-color:transparent}[data-theme=dark] .transport-search-bar{background:transparent;border-color:transparent;box-shadow:none}[data-theme=dark] .transport-search-bar.has-active-tab{box-shadow:none}.add-destination-link{display:inline-flex;align-items:center;gap:4px;padding:0;margin-top:0;margin-left:0;border:none;background:transparent;color:var(--primary-blue);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.add-destination-link:hover{color:#2563eb;text-decoration:underline}[data-theme=dark] .add-destination-link{color:#60a5fa}[data-theme=dark] .add-destination-link:hover{color:#93c5fd}.transport-search-bar .search-pill-group{justify-content:space-evenly}.transport-search-bar .search-pill{padding:8px 12px;gap:6px;flex:1 1 0%;max-width:120px}.transport-search-bar .icon-box{width:52px;height:52px}.transport-search-bar .tab-label{font-size:.75rem}.transport-search-bar .transport-content-area{max-height:500px;opacity:1}.transport-content-area{width:100%;overflow:visible;display:flex;flex-direction:column;gap:12px}.search-pill-group{display:flex;justify-content:space-evenly;align-items:flex-start;width:100%;padding:0 8px 8px;gap:0;border-bottom:1px solid transparent;transition:all .6s cubic-bezier(.16,1,.3,1)}.search-pill{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.882rem;color:var(--text-secondary);background:transparent;padding:8px 4px;border:none;border-radius:0;font-weight:500;position:relative;cursor:pointer;flex:0 1 auto;width:20%;max-width:none;transition:all .6s cubic-bezier(.16,1,.3,1)}.search-pill:hover{color:var(--text-main);background:transparent}.search-pill .icon-box{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;color:#007bff;box-shadow:0 2px 4px #0000001a,0 4px 8px #00000014;transition:all .3s cubic-bezier(.4,0,.2,1)}[data-theme=dark] .search-pill .icon-box{background:#3a3f4b;color:#fff;box-shadow:0 2px 4px #0000004d,0 4px 8px #0003}.search-pill:hover .icon-box{background:#f0f0f5;color:#0056b3;transform:scale(1.05) translateY(-2px);box-shadow:0 4px 8px #00000026,0 8px 16px #0000001a}[data-theme=dark] .search-pill:hover .icon-box{background:#4a4f5c;color:#fff;transform:scale(1.05) translateY(-2px);box-shadow:0 4px 8px #0006,0 8px 16px #0000004d}.search-pill .tab-label{font-size:.882rem;font-weight:500;white-space:nowrap;background:#fff;padding:6px 12px;border-radius:10px;color:var(--text-secondary);box-shadow:0 2px 4px #00000014,0 1px 2px #0000000d;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:80px;text-align:center}[data-theme=dark] .search-pill .tab-label{background:#3a3f4b;color:var(--text-secondary);box-shadow:0 2px 4px #0000004d,0 1px 2px #0003;border-radius:10px;min-width:80px;text-align:center}.search-pill.active{color:var(--text-main);font-weight:600}.search-pill.active .tab-label{background:#007bff;color:#fff;font-weight:600;box-shadow:0 2px 6px #007bff4d,0 4px 10px #007bff26}[data-theme=dark] .search-pill.active .tab-label{background:#007bff;color:#fff;box-shadow:0 2px 6px #007bff4d,0 4px 10px #007bff26}.search-pill:hover .tab-label{background:#f0f0f5;color:var(--text-main)}[data-theme=dark] .search-pill:hover .tab-label{background:#4a4f5c;color:var(--text-main)}.search-pill.active .icon-box{background:#007bff;color:#fff;box-shadow:0 4px 12px #007bff66,0 8px 20px #007bff33}.search-pill.active:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:40px;height:3px;background-color:#22c55e;border-radius:2px}@keyframes slideIn{0%{transform:scaleX(0);opacity:0}to{transform:scaleX(1);opacity:1}}.search-inputs-row{display:grid;grid-template-rows:auto auto;gap:8px;background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:8px;box-shadow:var(--glass-shadow);min-height:100px;overflow:visible;transition:none}.search-row-1{display:grid;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--glass-border)}.search-row-2{display:grid;grid-template-columns:2fr 1.5fr 1.5fr auto;gap:8px;align-items:center}.search-row-2-group,.search-row-2-left,.search-row-2-right{display:contents}.currency-selector-wrapper{position:relative}.currency-full{display:block}.currency-code-only{display:none;font-size:.75rem;font-weight:500;color:var(--text-muted);margin-left:4px}.grid-action-mobile{display:none}.search-inputs-row.grid-stays .search-row-1{grid-template-columns:1fr auto;gap:0}.search-inputs-row.grid-flights .search-row-1{grid-template-columns:1fr 1fr}.search-inputs-row.grid-experiences .search-row-1{grid-template-columns:1fr}.search-inputs-row.grid-cars .search-row-1{grid-template-columns:1fr 1fr}.search-inputs-row.grid-cruises .search-row-1{grid-template-columns:1fr}.search-inputs-row.grid-multicity{grid-template-rows:auto;min-height:60px;margin-bottom:8px}.search-inputs-row.grid-multicity .search-row-1{grid-template-columns:1fr 1fr 1fr auto;border-bottom:none;padding-bottom:0}.search-inputs-row.grid-multi-origin{display:grid;grid-template-columns:1fr 1fr;gap:16px;min-height:200px;padding:16px}.multi-origin-left-column{display:flex;flex-direction:column;gap:12px;padding-right:16px;border-right:1px solid var(--border-subtle)}.multi-origin-input-row{display:flex;flex-direction:column;gap:4px}.multi-origin-input-row .input-label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.multi-origin-input-wrapper{display:flex;align-items:center;gap:8px}.multi-origin-input-wrapper .location-autocomplete-wrapper{flex:1}.remove-origin-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .2s ease;flex-shrink:0}.remove-origin-btn:hover{background:#fee2e2;color:#dc2626}.add-origin-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px dashed var(--border-subtle);border-radius:8px;background:transparent;color:var(--primary-blue);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;align-self:flex-start;margin-top:4px}.add-origin-btn:hover{border-color:var(--primary-blue);background:#007bff0d}.multi-origin-right-column{display:flex;flex-direction:column;gap:16px;padding-left:8px}.multi-origin-field{display:flex;flex-direction:column;gap:4px}.multi-origin-field .input-label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.multi-origin-field .input-with-icon{background:#ffffff7f;border-radius:8px;padding:10px 12px;border:1px solid var(--border-subtle);transition:all .2s ease}.multi-origin-field .input-with-icon:hover{border-color:var(--primary-blue);background:#fffc}.multi-origin-search-btn{margin-top:auto;padding-top:8px}.multi-origin-search-btn .search-action-btn{width:100%;margin:0}[data-theme=dark] .multi-origin-field .input-with-icon{background:#3a3f4b7f;border-color:var(--glass-border)}[data-theme=dark] .multi-origin-field .input-with-icon:hover{background:#3a3f4bcc;border-color:var(--primary-blue)}@media(max-width:640px){.search-inputs-row.grid-multi-origin{grid-template-columns:1fr;gap:20px}.multi-origin-left-column{padding-right:0;border-right:none;border-bottom:1px solid var(--border-subtle);padding-bottom:16px}.multi-origin-right-column{padding-left:0}}[data-theme=dark] .search-inputs-row{background:var(--glass-bg-strong);border-color:var(--glass-border)}.grid-location,.grid-date,.grid-travelers,.grid-country,.grid-action,.grid-residency{display:flex;flex-direction:column;justify-content:center;background-color:transparent;padding:0 var(--spacing-sm);border-radius:0;gap:2px;min-height:38px;align-items:center;position:relative;overflow:visible;min-width:0}.grid-residency{padding:0 8px 0 12px;border-left:1px solid var(--border-subtle);min-width:auto;width:auto}.residency-selector-compact{display:flex;align-items:center;gap:4px;cursor:pointer;padding:6px 10px;border-radius:6px;background-color:transparent;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.residency-selector-compact:hover{background-color:#3b82f614}.residency-compact-text{font-size:.85rem;font-weight:500;color:#1e293b;white-space:nowrap}.residency-compact-icon{color:#64748b;flex-shrink:0}.grid-date .date-input,.grid-travelers .date-input,.grid-country .date-input{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-size:.85rem}.location-input-group,.date-input-group{display:flex;flex-direction:column;justify-content:center;background-color:transparent;padding:0 var(--spacing-sm);border-radius:0;gap:2px;min-height:38px;align-items:center;position:relative;overflow:visible}.search-row-2 .grid-travelers,.search-row-2 .grid-country{border-left:1px solid var(--border-subtle)}.search-row-1 .grid-location:not(:first-child){border-left:1px solid var(--border-subtle)}.input-label{display:none}.input-with-icon{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:100%;position:relative;cursor:text}.input-inner-icon{color:var(--text-muted)}.location-input,.date-input{border:none;background:transparent;width:100%;outline:none;font-size:.95rem;color:var(--text-main);padding:0;text-align:center}.location-input::placeholder{opacity:1;color:var(--text-muted);font-weight:500}.date-input::placeholder{opacity:0;color:transparent}.search-action-btn{background-color:#1e3a8a;width:auto;min-width:100px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-left:8px;flex-shrink:0;transition:var(--transition-fast);box-shadow:var(--shadow-sm),0 0 0 var(--glow-blue);padding:0 24px}.search-action-btn:hover{background-color:#1e40af;transform:scale(1.05);box-shadow:var(--shadow-button-hover),var(--shadow-glow-subtle)}.traveler-select{border:none;background:transparent;font-size:.95rem;color:var(--text-main);outline:none;cursor:pointer;text-align:center;text-align-last:center;width:100%;appearance:none}.location-autocomplete-wrapper{width:100%;height:100%;display:flex;flex-direction:column}.location-autocomplete-wrapper .input-with-icon{flex:1 1 0%}.autocomplete-dropdown{background:var(--surface-white);border-radius:12px;box-shadow:var(--shadow-xl);border:1px solid var(--border-subtle);padding:8px 0;max-height:400px;overflow-y:auto}.autocomplete-city-header{display:flex;align-items:center;padding:8px 16px;gap:8px;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--glass-bg-subtle);margin-top:4px;cursor:default}.autocomplete-city-header:first-child{margin-top:0}.autocomplete-item{display:flex;align-items:center;padding:10px 16px 10px 32px;cursor:pointer;transition:background .1s;gap:12px}.autocomplete-item:hover{background-color:var(--button-bg-hover)}.autocomplete-icon{color:var(--text-secondary);display:flex;align-items:center;flex-shrink:0}.autocomplete-text{flex:1 1 0%;display:flex;flex-direction:column;min-width:0;overflow:hidden}.autocomplete-text .main-text{font-size:.95rem;font-weight:500;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.autocomplete-text .sub-text{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.autocomplete-item .code-text{font-size:.8rem;font-weight:600;color:var(--text-secondary);background:var(--glass-bg-subtle);padding:2px 6px;border-radius:4px;flex-shrink:0;margin-left:8px}.chat-input-wrapper{background-color:var(--surface-white);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-md);border:1px solid var(--border-subtle);display:flex;flex-direction:column;gap:var(--spacing-sm);min-height:80px;position:relative}.chat-textarea{border:none;resize:none;width:100%;font-family:inherit;font-size:1rem;outline:none;color:var(--text-main);background:transparent;flex:1 1 0%}.chat-actions{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.attach-btn{color:var(--text-muted);transition:color .2s}.attach-btn:hover{color:var(--text-main)}.right-actions{display:flex;align-items:center;gap:var(--spacing-md)}.voice-btn{color:var(--text-muted)}.send-btn{background-color:var(--primary-blue);width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;transition:background .2s}.send-btn:hover{background-color:var(--primary-blue-hover);transform:scale(1.05);box-shadow:var(--shadow-button-hover)}.sub-tabs-row{display:flex;gap:24px;padding-left:8px;justify-content:center}.sub-tab{background:transparent;border:none;font-size:.9rem;color:var(--text-secondary);padding:4px 0;cursor:pointer;position:relative;font-weight:500}.sub-tab.active{color:var(--primary-blue);font-weight:600}.sub-tab.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background-color:var(--primary-blue)}.extra-options-row{display:flex;gap:48px;padding-left:8px;align-items:center;justify-content:center;position:relative}.extra-options-row:has(.icon-toggle-button):before{content:"+";position:absolute;left:50%;top:50%;transform:translate(-20%,-50%);font-size:20px;font-weight:600;color:#22c55e;text-shadow:0 0 8px rgb(34 197 94 / 50%);pointer-events:none;z-index:1}.icon-toggle-button{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background-color:var(--glass-bg-subtle);border:1px solid var(--border-subtle);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--text-secondary)}.icon-toggle-button:hover{background-color:var(--button-bg-hover);border-color:var(--primary-blue);color:var(--text-main);transform:translateY(-2px);box-shadow:var(--shadow-md)}.icon-toggle-button.active{background-color:var(--primary-blue);border-color:var(--primary-blue);color:#fff;box-shadow:var(--shadow-glow-subtle)}.icon-toggle-button .plus-icon{display:none}.toggle-button{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-secondary);background-color:var(--glass-bg-subtle);border:1px solid var(--border-subtle);padding:8px 16px;border-radius:var(--radius-full);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-weight:500}.toggle-button:hover{background-color:var(--button-bg-hover);border-color:var(--primary-blue);color:var(--text-main);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.toggle-button.active{background-color:var(--primary-blue);border-color:var(--primary-blue);color:#fff;box-shadow:var(--shadow-glow-subtle)}.toggle-button .toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:1.2rem;font-weight:600;line-height:1}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-secondary);cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary-blue)}.pill-btn{background:#fff;border:1px solid var(--border-subtle);padding:6px 12px;border-radius:999px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:all .2s}.pill-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue)}.sub-text{font-size:.85rem;color:var(--text-muted)}.coming-soon-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;gap:var(--spacing-md);min-height:200px}.coming-soon-icon{color:var(--primary-blue);opacity:.8;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.coming-soon-title{font-size:1.5rem;font-weight:700;color:var(--text-main);margin:0}.coming-soon-text{font-size:1rem;color:var(--text-secondary);max-width:500px;line-height:1.6;margin:0}.coming-soon-contact{font-size:.9rem;color:var(--text-secondary);margin:var(--spacing-sm) 0 0 0}.coming-soon-contact a{color:var(--primary-blue);text-decoration:none;font-weight:600;transition:color .2s}.coming-soon-contact a:hover{color:var(--primary-blue-hover);text-decoration:underline}.search-loading-overlay{position:absolute;inset:0;background:#fffffff2;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);z-index:100;animation:fadeIn .2s ease-out}[data-theme=dark] .search-loading-overlay{background:#0f172af2}.search-loading-content{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.search-loading-text{font-size:1rem;color:#6b7280;font-weight:500;text-align:center;margin:0}[data-theme=dark] .search-loading-text{color:#94a3b8}@media(min-width:768px)and (max-width:1023px){.search-inputs-row.grid-stays{display:flex;flex-direction:column;gap:8px;padding:12px}.search-inputs-row.grid-stays .search-row-1{display:grid;grid-template-columns:1fr auto;gap:0;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.search-inputs-row.grid-stays .grid-residency{padding:0 6px 0 10px;border-left:1px solid var(--border-subtle)}.search-inputs-row.grid-stays .search-row-2{display:grid;grid-template-columns:1fr 1.5fr;grid-template-rows:auto auto;gap:12px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.search-inputs-row.grid-stays .grid-date{grid-column:1;grid-row:1}.search-inputs-row.grid-stays .grid-travelers{grid-column:2;grid-row:1;border-left:1px solid var(--border-subtle);display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px}.search-inputs-row.grid-stays .grid-country{grid-column:1;grid-row:2;display:none}.search-inputs-row.grid-stays .grid-action{grid-column:2;grid-row:2;justify-self:end;display:none}.search-inputs-row.grid-flights{display:flex;flex-direction:column;gap:12px;padding:12px}.search-inputs-row.grid-flights .search-row-1{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.search-inputs-row.grid-flights .search-row-2{display:grid;grid-template-columns:1fr 1.5fr;gap:12px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.search-inputs-row.grid-flights .grid-location:nth-of-type(1){grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle)}.search-inputs-row.grid-flights .grid-location:nth-of-type(2){grid-column:2;grid-row:1;border-left:none}.search-inputs-row.grid-flights .grid-date{grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle)}.search-inputs-row.grid-flights .grid-travelers{grid-column:2;grid-row:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;border-left:none}.search-inputs-row.grid-flights .grid-country,.search-inputs-row.grid-flights .grid-action{display:none}.search-inputs-row.grid-flights .grid-action-mobile{grid-column:1 / -1;display:flex;justify-content:center;width:100%;margin-top:8px;padding-top:12px;border-top:1px solid var(--border-subtle)}.search-inputs-row.grid-experiences{display:flex;flex-direction:column;gap:12px;padding:12px}.search-inputs-row.grid-experiences .search-row-1{width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.search-inputs-row.grid-experiences .search-row-2{display:grid;grid-template-columns:1fr 1.5fr;gap:12px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:8px}.search-inputs-row.grid-experiences .grid-location{grid-column:1;grid-row:1}.search-inputs-row.grid-experiences .grid-date{grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle)}.search-inputs-row.grid-experiences .grid-travelers{grid-column:2;grid-row:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;border-left:none}.search-inputs-row.grid-experiences .grid-action{display:none}.search-inputs-row.grid-experiences .grid-action-mobile{grid-column:1 / -1;display:flex;justify-content:center;width:100%;margin-top:8px;padding-top:12px;border-top:1px solid var(--border-subtle)}.grid-location,.grid-date,.grid-travelers,.grid-country{border-left:none}.grid-date,.grid-travelers{border-right:1px solid var(--border-subtle)}.currency-full,.currency-icon-desktop{display:none}.currency-code-only{display:inline-flex;font-size:.75rem;margin-left:6px}.search-inputs-row.grid-stays .grid-action-mobile{grid-column:1 / -1;display:flex;justify-content:center;width:100%;margin-top:8px;padding-top:12px;border-top:1px solid var(--border-subtle)}.search-action-btn{width:auto;min-width:120px;height:44px;padding:8px 28px;border-radius:8px}.grid-action-mobile .search-action-btn{min-width:140px;height:48px;padding:10px 32px;border-radius:8px;margin-left:0}.search-action-btn svg{width:20px;height:20px}}@media(max-width:767px){.transport-search-bar{padding:4px;max-width:100%}.transport-search-bar.expanded{padding:4px}.search-pill{padding:4px 0;gap:2px;max-width:none;flex:1 1 0;min-width:0}.transport-search-bar .search-pill{padding:4px 0;gap:2px;flex:1 1 0;max-width:none;min-width:0}.search-pill-group{gap:8px;justify-content:space-between;padding:0 8px 8px}.icon-box{width:40px;height:40px}.icon-box svg{width:20px;height:20px}.tab-label{font-size:.7rem;padding:6px 0;min-width:0;display:none}.search-pill.active .tab-label{display:block}.search-inputs-row{min-height:auto;padding:6px;gap:6px;grid-template-columns:1fr;grid-template-rows:auto auto}.icon-toggle-button,.toggle-button,.search-action-btn,.send-btn{min-width:44px;min-height:44px}.icon-toggle-button{width:32px;height:32px}.search-action-btn,.send-btn{width:48px;height:48px}.checkbox-label{min-height:44px}.checkbox-label input[type=checkbox]{width:24px;height:24px}.input-label{font-size:.65rem}.location-input,.date-input,.traveler-select{font-size:16px}.grid-location,.grid-date,.grid-travelers,.grid-country,.grid-action,.location-input-group,.date-input-group{border-left:none}.grid-travelers{border-left:1px solid var(--border-subtle)}.search-inputs-row.grid-flights .grid-location:nth-of-type(2){grid-column:2;grid-row:1;border-left:none;min-height:32px}.grid-location .input-with-icon,.grid-date .input-with-icon,.grid-travelers .input-with-icon,.grid-country .input-with-icon,.location-input-group .input-with-icon,.date-input-group .input-with-icon{justify-content:center}.grid-date .date-input,.grid-travelers .date-input,.grid-country .date-input{font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.2}.grid-travelers .input-with-icon{gap:4px}.grid-travelers .date-input{font-size:.65rem;font-weight:500}.grid-date,.grid-travelers,.grid-country,.grid-location,.grid-action{padding:0 2px;min-height:28px}.grid-date .input-inner-icon,.grid-travelers .input-inner-icon,.grid-country .input-inner-icon{width:14px;height:14px}.currency-full,.currency-icon-desktop{display:none}.currency-code-only{display:inline-flex;font-size:.7rem;font-weight:500;color:var(--text-muted);margin-left:4px;padding:0;background:none;border:none}.search-inputs-row.grid-stays{display:flex;flex-direction:column;gap:6px;padding:8px;position:relative}.search-inputs-row.grid-stays .search-row-1{display:grid;grid-template-columns:1fr auto;gap:0;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:6px;min-height:36px}.search-inputs-row.grid-stays .grid-residency{padding:0 4px 0 8px;border-left:1px solid var(--border-subtle)}.search-inputs-row.grid-stays .residency-selector-compact{padding:4px 6px}.search-inputs-row.grid-stays .residency-compact-text{font-size:.75rem}.search-inputs-row.grid-stays .residency-compact-icon{width:12px;height:12px}.search-inputs-row.grid-stays .search-row-2{display:grid;grid-template-columns:1fr 1.5fr;gap:8px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:6px}.search-inputs-row.grid-stays .grid-date{grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle);padding-right:8px;min-height:32px}.search-inputs-row.grid-stays .grid-travelers{grid-column:2;grid-row:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;border-left:none;padding-left:8px;min-height:32px}.search-inputs-row.grid-stays .grid-country,.search-inputs-row.grid-stays .grid-action{display:none}.search-inputs-row.grid-stays .grid-action-mobile{grid-column:1 / -1;display:flex;justify-content:center;width:100%;margin-top:8px;padding:12px 0 0;border-top:1px solid var(--border-subtle)}.search-inputs-row.grid-flights{display:flex;flex-direction:column;gap:6px;padding:8px}.search-inputs-row.grid-flights .search-row-1{display:grid;grid-template-columns:1fr 1fr;gap:6px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:6px;min-height:36px}.search-inputs-row.grid-flights .search-row-2{display:grid;grid-template-columns:1fr 1.5fr;gap:8px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:6px}.search-inputs-row.grid-flights .grid-location:nth-of-type(1){grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle);min-height:32px}.search-inputs-row.grid-flights .grid-date{grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle);min-height:32px}.search-inputs-row.grid-flights .grid-travelers{grid-column:2;grid-row:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;border-left:none;min-height:32px}.search-inputs-row.grid-flights .grid-country,.search-inputs-row.grid-flights .grid-action{display:none}.search-inputs-row.grid-flights .grid-action-mobile{grid-column:1 / -1;display:flex;justify-content:center;width:100%;margin-top:8px;padding-top:12px;border-top:1px solid var(--border-subtle)}.search-inputs-row.grid-experiences{display:flex;flex-direction:column;gap:6px;padding:8px}.search-inputs-row.grid-experiences .search-row-1{width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:6px;min-height:36px}.search-inputs-row.grid-experiences .search-row-2{display:grid;grid-template-columns:1fr 1.5fr;gap:8px;width:100%;border-bottom:1px solid var(--border-subtle);padding-bottom:6px}.search-inputs-row.grid-experiences .grid-location{grid-column:1;grid-row:1;min-height:32px}.search-inputs-row.grid-experiences .grid-date{grid-column:1;grid-row:1;border-right:1px solid var(--border-subtle);min-height:32px}.search-inputs-row.grid-experiences .grid-travelers{grid-column:2;grid-row:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:4px;border-left:none;min-height:32px}.search-inputs-row.grid-experiences .grid-action{display:none}.search-inputs-row.grid-experiences .grid-action-mobile{grid-column:1 / -1;display:flex;justify-content:center;width:100%;margin-top:8px;padding-top:12px;border-top:1px solid var(--border-subtle)}.search-inputs-row.grid-multicity{grid-template-columns:1fr 1fr auto}.grid-location,.location-input-group{width:100%}.grid-location .location-autocomplete-wrapper,.grid-location .multi-destination-container,.grid-location .destination-input-wrapper,.grid-location .input-with-icon,.location-input-group .location-autocomplete-wrapper,.location-input-group .multi-destination-container,.location-input-group .destination-input-wrapper,.location-input-group .input-with-icon{width:100%;max-width:100%}.grid-location .input-with-icon,.location-input-group .input-with-icon{justify-content:flex-start}.search-action-btn,.grid-action .search-action-btn{width:auto;min-width:100px;height:40px;padding:6px 20px;border-radius:8px}.grid-action-mobile .search-action-btn{width:auto;min-width:120px;height:44px;padding:8px 24px;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;margin-left:0}.search-action-btn svg{width:18px;height:18px}}.search-inputs-row.grid-multi-origin .search-row-1{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.multi-origin-input{display:flex;flex-direction:column;gap:4px}.multi-origin-input .input-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.origin-actions{display:flex;gap:8px;align-items:center}.origin-actions .add-origin-btn{gap:4px;padding:6px 12px;border-radius:6px;font-size:.85rem}.origin-actions .remove-origin-btn{width:24px;height:24px}.search-row-shared-destination{display:grid;grid-template-columns:1fr auto;gap:8px;padding:8px 0;border-bottom:1px solid var(--glass-border)}.destination-label{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary)}.destination-label:before{content:"→";color:var(--primary-blue);font-weight:700}.multi-origin-results{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:16px}.origin-column{background:var(--surface-white);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden;display:flex;flex-direction:column;max-height:80vh}.origin-column-header{background:var(--primary-blue);color:#fff;padding:12px 16px;font-weight:600;display:flex;align-items:center;justify-content:space-between}.origin-column-header .price-badge{background:#fff3;padding:4px 8px;border-radius:4px;font-size:.85rem}.origin-column-flights{flex:1;overflow-y:auto;padding:8px}.origin-column-empty{padding:32px 16px;text-align:center;color:var(--text-muted)}@media(max-width:1024px){.multi-origin-results{grid-template-columns:1fr}.origin-column{max-height:50vh}}@media(max-width:1200px)and (min-width:1025px){.multi-origin-results{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.search-inputs-row.grid-multi-origin .search-row-1{grid-template-columns:1fr}}.multi-origin-skeleton{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.origin-column-skeleton{background:var(--surface-white);border-radius:var(--radius-lg);height:400px;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}[data-theme=dark] .origin-column{background:var(--glass-bg-strong)}[data-theme=dark] .add-origin-btn:hover{background:#007bff1a}.autocomplete-dropdown{background:var(--surface-white, #fff);border:1px solid var(--border-subtle, #e2e8f0);border-radius:12px;box-shadow:0 8px 24px #0000001f;overflow:hidden;max-height:400px;overflow-y:auto;z-index:10000}.autocomplete-dropdown--portal{z-index:10000}.autocomplete-results-info{padding:8px 16px;font-size:12px;color:var(--text-muted, #64748b);background:var(--surface-subtle, #f1f5f9);border-bottom:1px solid var(--border-subtle, #e2e8f0)}.autocomplete-city-header{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--surface-subtle, #f1f5f9);color:var(--text-secondary, #475569);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.autocomplete-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .15s ease;border-bottom:1px solid transparent}.autocomplete-item:hover,.autocomplete-item.selected{background:var(--surface-hover, #f8fafc);border-bottom-color:var(--border-subtle, #e2e8f0)}.autocomplete-item.selected{background:var(--primary-light, #dbeafe)}.autocomplete-item:focus{outline:2px solid var(--primary-blue, #3b82f6);outline-offset:-2px}.autocomplete-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--surface-subtle, #f1f5f9);border-radius:8px;color:var(--primary-blue, #3b82f6);flex-shrink:0}.autocomplete-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.autocomplete-text .main-text{font-size:14px;font-weight:500;color:var(--text-primary, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.autocomplete-text .sub-text{font-size:12px;color:var(--text-secondary, #64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.code-text{font-size:11px;font-weight:700;color:var(--primary-blue, #3b82f6);background:var(--surface-subtle, #f1f5f9);padding:2px 8px;border-radius:4px;margin-left:auto;flex-shrink:0;font-family:SF Mono,Monaco,monospace;letter-spacing:.5px}.hid-badge{font-size:10px;font-weight:400;color:var(--text-muted, #94a3b8);background:var(--surface-subtle, #f1f5f9);padding:2px 6px;border-radius:4px;margin-left:8px;flex-shrink:0;opacity:.7}.autocomplete-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px 16px;color:var(--text-secondary, #64748b);font-size:14px}.autocomplete-loading .animate-spin{animation:spin 1s linear infinite}.autocomplete-error{display:flex;align-items:center;gap:10px;padding:16px;color:var(--error-text, #dc2626);background:var(--error-bg, #fef2f2);font-size:14px}.autocomplete-error svg{flex-shrink:0;color:var(--error-icon, #ef4444)}.autocomplete-no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 16px;text-align:center;color:var(--text-secondary, #64748b)}.autocomplete-no-results svg{color:var(--text-muted, #94a3b8);margin-bottom:4px}.autocomplete-no-results p{margin:0;font-size:14px;font-weight:500;color:var(--text-primary, #1e293b)}.autocomplete-no-results .no-results-hint{font-size:12px;color:var(--text-muted, #94a3b8)}.input-loading-icon{position:absolute;right:12px;color:var(--text-muted, #94a3b8);animation:spin 1s linear infinite}[data-theme=dark] .autocomplete-dropdown{background:var(--surface-dark, #1e293b);border-color:var(--border-subtle-dark, #334155)}[data-theme=dark] .autocomplete-results-info{background:var(--surface-subtle-dark, #334155);border-color:var(--border-subtle-dark, #475569);color:var(--text-muted-dark, #94a3b8)}[data-theme=dark] .autocomplete-city-header{background:var(--surface-subtle-dark, #334155);color:var(--text-secondary-dark, #94a3b8)}[data-theme=dark] .autocomplete-icon{background:var(--surface-subtle-dark, #334155)}[data-theme=dark] .autocomplete-item:hover,[data-theme=dark] .autocomplete-item.selected{background:var(--surface-hover-dark, #334155)}[data-theme=dark] .autocomplete-item.selected{background:var(--primary-dark, #1e3a5f)}[data-theme=dark] .code-text{background:var(--surface-subtle-dark, #334155);color:var(--primary-light, #60a5fa)}[data-theme=dark] .autocomplete-text .main-text{color:var(--text-primary-dark, #f1f5f9)}[data-theme=dark] .autocomplete-text .sub-text{color:var(--text-secondary-dark, #94a3b8)}[data-theme=dark] .autocomplete-no-results p{color:var(--text-primary-dark, #f1f5f9)}[data-theme=dark] .autocomplete-no-results .no-results-hint{color:var(--text-muted-dark, #64748b)}[data-theme=dark] .autocomplete-error{background:var(--error-bg-dark, #450a0a);color:var(--error-text-dark, #fca5a5)}[data-theme=dark] .autocomplete-error svg{color:var(--error-icon-dark, #f87171)}[data-theme=dark] .hid-badge{background:var(--surface-subtle-dark, #334155);color:var(--text-muted-dark, #64748b)}.traveler-selector-popup{position:absolute;top:50px;right:0;width:300px;background:var(--surface-white);box-shadow:var(--shadow-xl);border:1px solid var(--border-subtle);border-radius:12px;padding:16px;z-index:100;max-height:inherit;overflow-y:auto}.traveler-selector-popup.placement-center{box-shadow:var(--shadow-xl);transform:translateY(0)}.traveler-selector-popup.in-modal{position:fixed;z-index:1100;top:auto;right:auto}.selector-header{font-size:.9rem;font-weight:600;margin-bottom:12px;color:var(--primary-blue);letter-spacing:-.01em}.selector-grid{display:flex;flex-direction:column;gap:8px}.traveler-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.traveler-type{font-size:.85rem;font-weight:500;color:var(--text-main);line-height:1.2}.counter-controls{display:flex;align-items:center;gap:8px}.counter-btn{width:24px;height:24px;border-radius:6px;border:1px solid var(--border-subtle);background:var(--surface-white);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all .2s;padding:0}.counter-btn:hover:not(:disabled){border-color:var(--primary-blue);color:var(--primary-blue);background:var(--glass-accent-bg)}.counter-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--glass-bg-subtle);border-color:var(--border-subtle)}.counter-value{width:16px;text-align:center;font-weight:600;font-size:.85rem;color:var(--primary-blue)}.cabin-class-section{margin-top:16px;border-top:1px solid var(--border-subtle);padding-top:16px}.cabin-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.cabin-btn{padding:8px 4px;border:1px solid var(--border-subtle);border-radius:8px;background:var(--surface-white);color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:center}.cabin-btn:hover:not(.active){border-color:var(--border-focus);color:var(--text-main)}.cabin-btn.active{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue);box-shadow:var(--shadow-glow-subtle)}.selector-header+.selector-grid{margin-top:-4px}.simple-traveler-selector-popup{position:absolute;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;padding:12px;z-index:1000;min-width:220px;display:flex;flex-direction:column;gap:10px}.simple-traveler-selector-popup.in-modal{position:fixed}.simple-traveler-row{display:flex;justify-content:space-between;align-items:center}.traveler-info{display:flex;flex-direction:column}.traveler-label{font-size:.9rem;font-weight:500;color:#334155}.counter-controls{display:flex;align-items:center;gap:10px}.counter-btn{width:28px;height:28px;border-radius:50%;border:1.5px solid #cbd5e1;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#475569;padding:0}.counter-btn:hover:not(:disabled){border-color:#3b82f6;background:#eff6ff;color:#3b82f6}.counter-btn:disabled{opacity:.4;cursor:not-allowed}.counter-value{font-size:.95rem;font-weight:600;color:#1e293b;min-width:20px;text-align:center}.traveler-ok-btn{width:100%;padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s ease}.traveler-ok-btn:hover{background:#2563eb}.traveler-ok-btn:active{transform:translateY(1px)}.hotel-room-selector-popup{position:absolute;background:#fffffffa;border:1px solid var(--glass-border);border-radius:16px;padding:20px;box-shadow:0 8px 32px #0000001f;z-index:1000;min-width:380px;max-width:420px;overflow-y:auto;overscroll-behavior:contain}[data-theme=dark] .hotel-room-selector-popup{background:#1f2937f2;border-color:#ffffff1a}.hotel-room-selector-popup.in-modal{z-index:var(--z-modal-content)}.hotel-room-selector-popup .selector-header{font-size:1rem;font-weight:600;color:var(--text-main);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--glass-border)}.rooms-container{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.room-card{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:12px;padding:16px}[data-theme=dark] .room-card{background:#3741517f}.room-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.room-title{font-size:.95rem;font-weight:600;color:var(--text-main)}.remove-room-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .2s}.remove-room-btn:hover{background:#ef44441a;color:#ef4444}.room-travelers{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.traveler-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.traveler-info{display:flex;flex-direction:column;gap:2px}.traveler-type{font-size:.9rem;font-weight:500;color:var(--text-main)}.traveler-age{font-size:.75rem;color:var(--text-secondary)}.child-ages-container{margin-top:12px;padding:12px;background:#3b82f60d;border:1px solid rgb(59 130 246 / 20%);border-radius:8px}[data-theme=dark] .child-ages-container{background:#3b82f61a;border-color:#3b82f64d}.child-ages-label{font-size:.8rem;font-weight:600;color:var(--text-main);margin-bottom:8px;display:flex;align-items:center;gap:6px}.child-ages-label:before{content:"👶";font-size:1rem}.child-ages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.child-age-input-wrapper{display:flex;flex-direction:column;gap:4px}.child-age-input-wrapper label{font-size:.75rem;font-weight:500;color:var(--text-secondary)}.child-age-select{padding:8px 10px;border-radius:6px;border:1px solid var(--glass-border);background:var(--bg-secondary);color:var(--text-main);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.child-age-select:hover{border-color:var(--primary-blue)}.child-age-select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .child-age-select{background:#3741517f}.counter-controls{display:flex;align-items:center;gap:12px}.counter-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid var(--glass-border);background:var(--bg-secondary);color:var(--primary-blue);cursor:pointer;transition:all .2s}.counter-btn:hover:not(:disabled){background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.counter-btn:disabled{opacity:.3;cursor:not-allowed}.counter-value{font-size:.95rem;font-weight:600;color:var(--text-main);min-width:24px;text-align:center}.room-class-section{margin-top:12px;padding-top:12px;border-top:1px solid var(--glass-border)}.room-class-label{font-size:.85rem;font-weight:600;color:var(--text-main);margin-bottom:8px}.room-class-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.room-class-btn{padding:8px 12px;border-radius:8px;border:1px solid var(--glass-border);background:var(--bg-secondary);color:var(--text-main);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.room-class-btn:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.room-class-btn.active{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue);font-weight:600}.add-room-btn{width:100%;padding:12px;border-radius:10px;border:2px dashed var(--glass-border);background:transparent;color:var(--primary-blue);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.add-room-btn:hover{background:#3b82f61a;border-color:var(--primary-blue)}.done-btn{width:100%;padding:12px;border-radius:10px;border:none;background:var(--primary-blue);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.done-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.hotel-room-selector-popup::-webkit-scrollbar{width:6px}.hotel-room-selector-popup::-webkit-scrollbar-track{background:transparent}.hotel-room-selector-popup::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:3px}.hotel-room-selector-popup::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media(max-width:480px){.hotel-room-selector-popup{min-width:320px;max-width:90vw;max-height:80vh}}@media(max-height:700px){.hotel-room-selector-popup{max-height:85vh}}.residency-currency-selector-popup{position:absolute;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0000001f;padding:16px;z-index:10000;min-width:320px;max-width:400px;max-height:500px;display:flex;flex-direction:column}.residency-currency-selector-popup.in-modal{z-index:var(--z-modal-content)}.residency-currency-selector-popup.placement-top{transform-origin:bottom center}.residency-currency-selector-popup.placement-center{transform-origin:center center}.residency-currency-selector-popup.placement-bottom{transform-origin:top center}.country-search{margin-bottom:12px}.country-search-input{width:100%;padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;outline:none;transition:border-color .2s}.country-search-input:focus{border-color:var(--primary-blue)}.current-selection{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f8fafc;border-radius:8px;margin-bottom:12px;font-size:.85rem}.current-label{font-weight:600;color:var(--text-secondary)}.current-value{color:var(--text-main);font-weight:500}.country-list{overflow-y:auto;max-height:320px;display:flex;flex-direction:column;gap:4px}.country-list::-webkit-scrollbar{width:6px}.country-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.country-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.country-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.country-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s}.country-item:hover{background:#f1f5f9}.country-item.selected{background:#e0f2fe;border:1px solid var(--primary-blue)}.country-flag{font-size:1.5rem;line-height:1}.country-info{display:flex;flex-direction:column;gap:2px;flex:1 1 0%}.country-name{font-size:.85rem;font-weight:500;color:var(--text-main)}.country-currency{font-size:.75rem;color:var(--text-secondary)}.no-results{padding:20px;text-align:center;color:var(--text-secondary);font-size:.85rem}.multi-destination-container{display:flex;flex-direction:column;gap:8px;width:100%}.destination-row{display:flex;align-items:center;gap:8px;width:100%}.destination-input-wrapper{flex:1 1 0%;width:100%;min-width:0}.destination-input-wrapper .location-autocomplete-wrapper{width:100%}.remove-destination-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;border-radius:50%;background:transparent;border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0}.remove-destination-btn:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.add-destination-btn{display:inline-flex;align-items:center;gap:4px;padding:0;border:none;background:transparent;color:var(--primary-blue);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:6px;margin-left:2px}.add-destination-btn:hover{color:#2563eb;text-decoration:underline}.add-destination-btn span{font-weight:500}[data-theme=dark] .remove-destination-btn{border-color:#ffffff1a}[data-theme=dark] .add-destination-btn{border-color:#fff3}@media(max-width:768px){.destination-row{gap:6px}.remove-destination-btn{width:28px;height:28px;min-width:28px}.add-destination-btn{font-size:.8rem;padding:6px 10px}}.flight-route-container{width:100%;height:50px;display:flex;align-items:center;justify-content:center;background:transparent;margin-bottom:0;overflow:visible;position:relative}.flight-route-container svg{position:relative;z-index:1}.compact-flight-card{position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px;transition:all .2s ease;cursor:pointer;display:flex;flex-direction:column;gap:10px}.compact-flight-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a;transform:translateY(-1px)}.compact-flight-card.selected{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 2px #3b82f633}.compact-flight-card.disabled{opacity:.5;cursor:not-allowed}.compact-flight-card.disabled:hover{border-color:#e5e7eb;box-shadow:none;transform:none}@media(prefers-color-scheme:dark){.compact-flight-card{background:#1e293b;border-color:#334155}.compact-flight-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f633}.compact-flight-card.selected{background:#1e3a5f;border-color:#3b82f6}.compact-flight-card.disabled:hover{border-color:#334155}}.compact-card-checkbox{position:absolute;top:8px;right:8px;z-index:2}.compact-card-checkbox input[type=checkbox]{display:none}.compact-card-checkbox label{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:2px solid #d1d5db;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s ease}.compact-card-checkbox label svg{opacity:0;color:#fff;transition:opacity .2s ease}.compact-card-checkbox input[type=checkbox]:checked+label{background:#3b82f6;border-color:#3b82f6}.compact-card-checkbox input[type=checkbox]:checked+label svg{opacity:1}.compact-card-checkbox input[type=checkbox]:disabled+label{cursor:not-allowed;opacity:.5}@media(prefers-color-scheme:dark){.compact-card-checkbox label{background:#334155;border-color:#475569}.compact-card-checkbox input[type=checkbox]:checked+label{background:#3b82f6;border-color:#3b82f6}}.compact-card-airline{display:flex;align-items:center;gap:8px;padding-right:28px}.compact-airline-logo{width:24px;height:24px;object-fit:contain;border-radius:4px}.compact-airline-name{font-size:13px;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(prefers-color-scheme:dark){.compact-airline-name{color:#f1f5f9}}.compact-card-times{display:flex;align-items:center;justify-content:space-between;gap:8px}.compact-time-block{display:flex;flex-direction:column;gap:2px;flex:1}.compact-time{font-size:16px;font-weight:700;color:#111827;line-height:1.2}.compact-airport{font-size:11px;color:#6b7280;text-transform:uppercase;font-weight:500}@media(prefers-color-scheme:dark){.compact-time{color:#f1f5f9}.compact-airport{color:#94a3b8}}.compact-route-animation{flex:1;display:flex;align-items:center;justify-content:center;min-width:0;max-width:200px;margin:0 8px}.compact-route-animation .flight-route-container{transform:scale(.7);transform-origin:center}.compact-route-animation svg{width:100%;height:auto}.compact-card-details{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6}.compact-duration,.compact-stops{font-size:12px;color:#6b7280;font-weight:500}@media(prefers-color-scheme:dark){.compact-card-details{border-top-color:#334155;border-bottom-color:#334155}.compact-duration,.compact-stops{color:#94a3b8}}.compact-card-price{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.compact-price-amount{font-size:20px;font-weight:700;color:#111827;line-height:1}.compact-price-label{font-size:11px;color:#9ca3af;font-weight:500}@media(prefers-color-scheme:dark){.compact-price-amount{color:#f1f5f9}.compact-price-label{color:#64748b}}.booking-flow-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:20px}.booking-flow-content{background:var(--surface-white);border-radius:16px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-xl);border:1px solid var(--border-subtle);z-index:var(--z-modal-content)}.close-btn{position:absolute;top:20px;right:20px;background:none;border:none;font-size:32px;cursor:pointer;color:var(--text-secondary);z-index:10;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background:var(--bg-page);color:var(--text-main)}.booking-steps{display:flex;justify-content:space-between;padding:30px 40px;border-bottom:1px solid var(--border-subtle);background:var(--bg-page)}.step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1 1 0%;position:relative}.step:not(:last-child):after{content:"";position:absolute;top:15px;left:50%;width:100%;height:2px;background:var(--border-subtle);z-index:0}.step.active:not(:last-child):after,.step.completed:not(:last-child):after{background:var(--primary-blue)}.step-circle{width:32px;height:32px;border-radius:50%;background:var(--border-subtle);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-weight:600;z-index:1;transition:all .3s}.step.active .step-circle{background:var(--primary-blue);color:#fff}.step.completed .step-circle{background:var(--success-text);color:#fff}.step-label{font-size:12px;color:var(--text-secondary);font-weight:500}.step.active .step-label{color:var(--primary-blue);font-weight:600}.booking-flow-body{padding:40px}.booking-flow-body h2{font-size:24px;margin-bottom:24px;color:var(--text-main);display:flex;align-items:center;gap:10px}.booking-flow-body h3{font-size:18px;margin:24px 0 16px;color:var(--text-main)}.item-summary{background:var(--bg-page);padding:20px;border-radius:12px;margin-bottom:24px;border:1px solid var(--border-subtle)}.item-summary h3{margin-top:0;margin-bottom:16px}.flight-details p,.hotel-details p{margin:8px 0;color:var(--text-secondary)}.price-breakdown{background:var(--bg-page);padding:20px;border-radius:12px;margin-bottom:24px;border:1px solid var(--border-subtle)}.price-row{display:flex;justify-content:space-between;padding:8px 0;color:var(--text-secondary)}.price-row.total{border-top:2px solid var(--border-subtle);margin-top:8px;padding-top:16px;font-size:18px;color:var(--text-main);font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group label{font-weight:500;color:var(--text-main);font-size:14px;display:flex;align-items:center;gap:6px}.field-hint{font-weight:400;color:var(--text-secondary);font-size:11px;margin-left:auto}.field-help{display:block;color:var(--text-secondary);font-size:11px;margin-top:4px}.form-group input{padding:12px;border:1px solid var(--border-subtle);border-radius:8px;font-size:14px;transition:all .2s;background:var(--surface-white);color:var(--text-main)}.form-group input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px var(--glow-blue)}.security-note{color:var(--success-text);font-size:14px;margin-bottom:24px;display:flex;align-items:center;gap:6px}.total-summary{background:var(--bg-page);padding:16px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;margin:24px 0;font-size:18px;font-weight:600;border:1px solid var(--border-subtle);color:var(--text-main)}.total-amount{color:var(--primary-blue);font-size:24px}.form-actions{display:flex;gap:12px;margin-top:24px}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:8px;justify-content:center;flex:1 1 0%}.btn-primary:hover:not(:disabled){background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-glow-blue)}.btn-primary:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.5}.btn-secondary{background:var(--bg-page);color:var(--text-main);border:1px solid var(--border-subtle)}.btn-secondary:hover:not(:disabled){background:var(--border-subtle)}.error-message{background:var(--error-bg);color:var(--error-text);padding:12px;border-radius:8px;margin:16px 0;font-size:14px;border:1px solid var(--error-border)}.booking-confirmation{text-align:center;padding:40px 20px}.success-icon{width:80px;height:80px;background:var(--success-text);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff}.booking-confirmation h2{font-size:28px;color:var(--text-main);margin-bottom:12px;justify-content:center}.booking-confirmation>p{color:var(--text-secondary);font-size:16px;margin-bottom:32px}.confirmation-details{background:var(--bg-page);padding:24px;border-radius:12px;margin:24px 0;text-align:left;border:1px solid var(--border-subtle)}.confirmation-details p{margin:12px 0;color:var(--text-secondary)}.confirmation-actions{display:flex;gap:12px;justify-content:center;margin-top:32px}.confirmation-actions .btn-primary,.confirmation-actions .btn-secondary{flex:0 1 auto;min-width:150px}.legal-acceptance{margin:20px 0;padding:15px;background:var(--bg-page);border-radius:8px;border:1px solid var(--border-subtle)}.legal-acceptance h4{margin-bottom:12px;font-size:14px;font-weight:600;color:var(--text-main)}.checkbox-label{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:13px;cursor:pointer;color:var(--text-secondary)}.checkbox-label input{margin-top:2px;flex-shrink:0}.checkbox-label a{color:var(--primary-blue);text-decoration:underline}.checkbox-label a:hover{color:var(--primary-blue-hover)}.modal-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:20px}.modal-content{background:var(--surface-white);border-radius:12px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;padding:24px;box-shadow:var(--shadow-xl);position:relative;z-index:var(--z-modal-content)}.modal-content h3{margin-top:0;margin-bottom:16px;font-size:20px;color:var(--text-main)}.modal-content p{color:var(--text-secondary);margin-bottom:12px}.modal-content ul{margin:12px 0;padding-left:20px;color:var(--text-secondary)}.modal-content button{margin-top:16px;width:100%;padding:12px;background:var(--primary-blue);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer}.modal-content button:hover{background:var(--primary-blue-hover)}@media(max-width:768px){.form-grid{grid-template-columns:1fr}.booking-flow-body{padding:24px}.booking-steps{padding:20px}.step-label{font-size:10px}.form-actions{flex-direction:column}}.flight-error-display{display:flex;flex-direction:column;gap:16px;padding:20px;border-radius:12px;border:1px solid transparent;background-color:#fef2f2;animation:flight-error-slide-in .3s ease-out}.flight-error-content{display:flex;align-items:flex-start;gap:16px}.flight-error-icon-wrapper{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background-color:#dc26261a}.flight-error-icon{color:#dc2626}.flight-error-message-wrapper{flex:1;min-width:0}.flight-error-title{margin:0 0 8px;font-size:16px;font-weight:600;color:#991b1b;line-height:1.4}.flight-error-message{margin:0;font-size:14px;color:#7f1d1d;line-height:1.5}.flight-error-retry-count,.flight-error-max-retries{display:block;margin-top:8px;font-size:13px;color:#9ca3af}.flight-error-max-retries{color:#dc2626;font-weight:500}.flight-error-payment-info{margin-top:12px;padding:10px 12px;background-color:#00000008;border-radius:6px}.payment-info-label{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:#dc2626}.payment-info-label.payment-info-refund{color:#059669}.flight-error-next-steps{margin-top:16px;padding:14px 16px;background-color:#3b82f60d;border-left:3px solid #3b82f6;border-radius:6px}.next-steps-title{display:flex;align-items:center;gap:8px;margin:0 0 10px;font-size:14px;font-weight:600;color:#1e40af}.next-steps-list{margin:0;padding-left:20px;list-style-type:disc}.next-steps-list li{margin-bottom:6px;font-size:13px;line-height:1.5;color:#1e3a8a}.next-steps-list li:last-child{margin-bottom:0}.flight-error-dismiss{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background-color:transparent;color:#9ca3af;cursor:pointer;transition:all .2s ease}.flight-error-dismiss:hover{background-color:#0000000d;color:#6b7280}.flight-error-dismiss:focus{outline:2px solid #dc2626;outline-offset:2px}.flight-error-actions{display:flex;flex-wrap:wrap;gap:12px;padding-top:12px;border-top:1px solid rgb(0 0 0 / 8%)}.flight-error-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.flight-error-btn:disabled{opacity:.6;cursor:not-allowed}.flight-error-btn-primary{background-color:#dc2626;color:#fff}.flight-error-btn-primary:hover:not(:disabled){background-color:#b91c1c}.flight-error-btn-primary:focus{outline:2px solid #dc2626;outline-offset:2px}.flight-error-btn-secondary{background-color:#fff;color:#4b5563;border-color:#e5e7eb}.flight-error-btn-secondary:hover:not(:disabled){background-color:#f9fafb;border-color:#d1d5db}.flight-error-btn-secondary:focus{outline:2px solid #9ca3af;outline-offset:2px}.flight-error-spinning{animation:flight-error-spin 1s linear infinite}@keyframes flight-error-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes flight-error-slide-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.flight-error-compact{padding:12px 16px;gap:12px}.flight-error-compact .flight-error-content{gap:12px}.flight-error-compact .flight-error-icon-wrapper{width:36px;height:36px}.flight-error-compact .flight-error-message{font-size:13px}.flight-error-compact .flight-error-actions{padding-top:8px}.flight-error-compact .flight-error-btn{padding:8px 16px;font-size:13px}.flight-error-display.error-network{background-color:#eff6ff;border-color:#bfdbfe}.flight-error-display.error-network .flight-error-icon-wrapper{background-color:#2563eb1a}.flight-error-display.error-network .flight-error-icon{color:#2563eb}.flight-error-display.error-network .flight-error-title{color:#1e40af}.flight-error-display.error-network .flight-error-message{color:#1e3a8a}.flight-error-display.error-timeout,.flight-error-display.error-rate-limit{background-color:#fffbeb;border-color:#fcd34d}.flight-error-display.error-timeout .flight-error-icon-wrapper,.flight-error-display.error-rate-limit .flight-error-icon-wrapper{background-color:#f59e0b1a}.flight-error-display.error-timeout .flight-error-icon,.flight-error-display.error-rate-limit .flight-error-icon{color:#f59e0b}.flight-error-display.error-timeout .flight-error-title,.flight-error-display.error-rate-limit .flight-error-title{color:#b45309}.flight-error-display.error-timeout .flight-error-message,.flight-error-display.error-rate-limit .flight-error-message{color:#92400e}.flight-error-display.error-server{background-color:#faf5ff;border-color:#e9d5ff}.flight-error-display.error-server .flight-error-icon-wrapper{background-color:#9333ea1a}.flight-error-display.error-server .flight-error-icon{color:#9333ea}.flight-error-display.error-server .flight-error-title{color:#7e22ce}.flight-error-display.error-server .flight-error-message{color:#6b21a8}.flight-error-display.error-validation{background-color:#fffbeb;border-color:#fcd34d}.flight-error-display.error-validation .flight-error-icon-wrapper{background-color:#f59e0b1a}.flight-error-display.error-validation .flight-error-icon{color:#f59e0b}.flight-error-display.error-validation .flight-error-title{color:#b45309}.flight-error-display.error-validation .flight-error-message{color:#92400e}.flight-error-display.error-auth{background-color:#fef2f2;border-color:#fecaca}.flight-error-display.error-auth .flight-error-icon-wrapper{background-color:#dc26261a}.flight-error-display.error-auth .flight-error-icon{color:#dc2626}.flight-error-display.error-auth .flight-error-title{color:#991b1b}.flight-error-display.error-auth .flight-error-message{color:#7f1d1d}@media(max-width:640px){.flight-error-display{padding:16px}.flight-error-content{gap:12px}.flight-error-icon-wrapper{width:40px;height:40px}.flight-error-title{font-size:15px}.flight-error-message{font-size:13px}.flight-error-actions{flex-direction:column}.flight-error-btn{width:100%;justify-content:center}}@media(prefers-contrast:high){.flight-error-display{border-width:2px}.flight-error-btn:focus{outline-width:3px}}@media(prefers-reduced-motion:reduce){.flight-error-display,.flight-error-spinning{animation:none}.flight-error-btn,.flight-error-dismiss{transition:none}}.multileg-booking-flow{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.booking-modal{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px -12px #00000040}.close-btn{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:#f3f4f6;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#6b7280;transition:all .2s;z-index:10}.close-btn:hover{background:#e5e7eb;color:#374151}.booking-steps{display:flex;justify-content:center;padding:24px;border-bottom:1px solid #e5e7eb;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.booking-steps::-webkit-scrollbar{display:none}.step{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;max-width:120px;min-width:80px;flex-shrink:0}.step-circle{width:36px;height:36px;border-radius:50%;background:#e5e7eb;color:#6b7280;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;transition:all .3s;flex-shrink:0}.step.active .step-circle{background:#3b82f6;color:#fff}.step.completed .step-circle{background:#10b981;color:#fff}.step-label{font-size:12px;color:#6b7280;font-weight:500;text-align:center;white-space:nowrap}.step.active .step-label{color:#3b82f6}.step.completed .step-label{color:#10b981}.booking-content{padding:32px}.booking-step-content h2{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:600;color:#111827;margin:0 0 24px}.step-description{color:#6b7280;margin-bottom:24px}.booking-summary{margin-bottom:24px}.booking-summary h3{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600;color:#374151;margin-bottom:16px}.flight-summary-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:16px}.flight-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.leg-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:20px}.flight-date{display:flex;align-items:center;gap:6px;font-size:14px;color:#6b7280}.flight-route{display:flex;align-items:center;gap:16px;margin-bottom:16px}.route-point{display:flex;align-items:center;gap:8px}.route-point>div{display:flex;flex-direction:column}.route-point strong{font-size:20px;font-weight:700;color:#111827}.route-point span{font-size:14px;color:#6b7280}.route-arrow{color:#9ca3af}.flight-info{display:flex;gap:16px;font-size:14px;color:#6b7280;padding-top:16px;border-top:1px solid #e5e7eb}.flight-price{text-align:right;font-size:20px;font-weight:700;color:#059669;margin-top:12px}.price-breakdown{background:#f9fafb;border-radius:12px;padding:20px;margin-bottom:24px}.price-breakdown h3{font-size:16px;font-weight:600;color:#374151;margin-bottom:16px}.price-row{display:flex;justify-content:space-between;padding:8px 0;color:#6b7280;font-size:14px}.price-row.total{border-top:2px solid #e5e7eb;margin-top:8px;padding-top:16px;font-size:18px;color:#111827}.passenger-forms{display:flex;flex-direction:column;gap:20px}.passenger-form-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.passenger-form-card h4{margin:0 0 20px;font-size:16px;font-weight:600;color:#374151}.passport-name-warning{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:linear-gradient(135deg,#ef44440d,#dc26260d);border-left:4px solid #ef4444;border-radius:8px;margin-bottom:20px;font-size:13px;line-height:1.5;color:#374151}.passport-name-warning svg{color:#ef4444;flex-shrink:0;margin-top:2px}.passport-name-warning strong{color:#ef4444;font-weight:600}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:13px;font-weight:500;color:#374151;display:flex;align-items:center;gap:6px}.field-hint{font-weight:400;color:#6b7280;font-size:11px;margin-left:auto}.field-help{display:block;color:#6b7280;font-size:11px;margin-top:4px}.error-hint{font-size:12px;margin-top:4px;color:#dc2626}.form-group input,.form-group select{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;transition:border-color .2s;min-height:44px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6}.payment-summary{background:#f9fafb;border-radius:12px;padding:20px;margin-bottom:24px}.payment-summary h4{margin:0 0 16px;font-size:16px;font-weight:600}.summary-row{display:flex;justify-content:space-between;padding:8px 0;font-size:14px;color:#6b7280}.summary-row.total{border-top:2px solid #e5e7eb;margin-top:8px;padding-top:16px;font-size:18px;font-weight:600;color:#111827}.payment-form{max-width:500px;width:100%}.payment-form h3{display:flex;align-items:center;gap:8px;margin:0 0 8px}.security-note{color:#6b7280;font-size:14px;margin-bottom:20px}.card-element-container{margin-bottom:24px;width:100%;overflow-x:hidden}.card-element-container label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:8px}.card-element-container>div{padding:12px;border:1px solid #d1d5db;border-radius:8px;background:#fff;min-height:44px}.payment-error{display:flex;align-items:center;gap:8px;padding:12px;background:#fef2f2;color:#dc2626;border-radius:8px;margin-bottom:16px;font-size:14px}.step-actions{display:flex;justify-content:space-between;margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:#fff;color:#4b5563;border:1px solid #d1d5db;border-radius:10px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;min-height:44px}.btn-secondary:hover:not(:disabled){background:#f3f4f6;color:#374151}.booking-step-content.confirmation{text-align:center}.success-icon{width:100px;height:100px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 24px;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.confirmation h2{justify-content:center;color:#059669}.confirmation-message{color:#6b7280;margin-bottom:32px}.confirmation-details{text-align:left;max-width:600px;margin:0 auto 32px}.detail-card{background:#f9fafb;border-radius:12px;padding:24px;margin-bottom:24px}.detail-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e5e7eb}.detail-row:last-child{border-bottom:none}.detail-row .label{color:#6b7280}.detail-row .value{font-weight:600;color:#111827}.detail-row .value.code{font-family:monospace;font-size:18px;background:#e5e7eb;padding:4px 12px;border-radius:6px;color:#374151}.airline-pnrs-section,.eticket-section{margin:16px 0;padding:16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px}.airline-pnrs-section h4,.eticket-section h4{display:flex;align-items:center;gap:8px;margin:0 0 12px;font-size:14px;font-weight:600;color:#0369a1}.airline-pnr .airline-code,.eticket-row .eticket-code{background:#dbeafe;color:#1e40af;font-weight:700}.detail-row.total-row{margin-top:12px;padding-top:12px;border-top:2px solid #e5e7eb}.booking-instructions{margin:20px 0;padding:16px;background:#ecfdf5;border-radius:8px;border-left:4px solid #10b981}.booking-instructions h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#047857}.booking-instructions ul{margin:0;padding-left:20px;color:#065f46}.booking-instructions li{margin-bottom:6px;font-size:13px}.voucher-preview{margin-top:24px}.voucher-preview h4{text-align:center;margin-bottom:16px}.voucher-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.voucher-header{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.voucher-logo{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700}.voucher-ref{font-family:monospace;font-size:16px;background:#fff3;padding:8px 16px;border-radius:6px}.voucher-legs{padding:20px}.voucher-leg{padding:16px;border-bottom:1px solid #e5e7eb}.voucher-leg:last-child{border-bottom:none}.leg-header{display:flex;justify-content:space-between;margin-bottom:12px}.leg-number{font-weight:600;color:#374151}.leg-status{font-size:12px;text-transform:uppercase;color:#10b981;background:#ecfdf5;padding:4px 10px;border-radius:20px}.leg-route{display:flex;align-items:center;gap:16px;margin-bottom:8px}.leg-route .airport{font-size:24px;font-weight:700;color:#111827}.leg-route .arrow{color:#9ca3af}.leg-details{display:flex;gap:16px;font-size:14px;color:#6b7280}.voucher-passengers{padding:20px;background:#f9fafb;border-top:1px solid #e5e7eb}.voucher-passengers h5{margin:0 0 12px;font-size:14px;color:#6b7280}.voucher-passengers .passenger{display:flex;align-items:center;gap:8px;padding:8px 0}.voucher-passengers .type{color:#9ca3af;font-size:14px}.voucher-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.confirmation-actions{display:flex;gap:16px;justify-content:center}.legal-acceptance{margin:20px 0;padding:15px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.legal-acceptance h4{margin-bottom:12px;font-size:14px;font-weight:600;color:#111827}.checkbox-label{display:flex;align-items:flex-start;gap:8px;margin-bottom:10px;font-size:13px;cursor:pointer;color:#4b5563;min-height:44px}.checkbox-label input{margin-top:2px;flex-shrink:0;min-width:20px;min-height:20px}.checkbox-label a{color:#3b82f6;text-decoration:underline}.checkbox-label a:hover{color:#2563eb}.modal-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:1100;padding:20px}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;padding:24px;box-shadow:0 25px 50px -12px #00000040}.modal-content h3{margin-top:0;margin-bottom:16px;font-size:20px;color:#111827}.modal-content p{color:#6b7280;margin-bottom:12px}.modal-content ul{margin:12px 0;padding-left:20px;color:#6b7280}.modal-content li{margin-bottom:8px}.modal-content button{margin-top:16px;width:100%;padding:12px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;min-height:44px}.modal-content button:hover{background:#2563eb}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;color:#dc2626;border-radius:8px;margin-bottom:16px;font-size:14px}.offer-expiration-warning{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:500;color:#92400e}.offer-expiration-warning svg{color:#f59e0b;flex-shrink:0}.offer-expiration-warning.urgent{background:#fee2e2;border-color:#ef4444;color:#dc2626;animation:pulse-warning 2s infinite}.offer-expiration-warning.urgent svg{color:#dc2626}.offer-expiration-warning.expired{background:#fee2e2;border-color:#dc2624;color:#dc2626}.offer-expiration-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:20px;font-size:14px;font-weight:500;color:#92400e}.offer-expiration-banner svg{color:#f59e0b}.offer-expiration-banner.urgent{background:#fee2e2;border-color:#ef4444;color:#dc2626;animation:pulse-warning 2s infinite}.offer-expiration-banner.urgent svg{color:#dc2626}.offer-expired-error{display:flex;align-items:flex-start;gap:16px;padding:20px;background:#fee2e2;border:2px solid #dc2626;border-radius:12px;margin-bottom:20px}.offer-expired-error svg{color:#dc2626;flex-shrink:0}.offer-expired-error h4{margin:0 0 4px;color:#dc2626;font-size:16px}.offer-expired-error p{margin:0;color:#7f1d1d;font-size:14px}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:768px){.multileg-booking-flow{padding:0}.booking-modal{border-radius:0;max-height:100vh;max-height:100dvh}.booking-content{padding:20px}.form-grid{grid-template-columns:1fr;gap:12px}.flight-route{flex-direction:column;align-items:flex-start;gap:12px}.route-arrow{transform:rotate(90deg)}.flight-info{flex-wrap:wrap;gap:8px}.step-actions{flex-direction:column-reverse;gap:12px}.btn-primary,.btn-secondary{width:100%;min-height:48px}.leg-route{flex-direction:column;gap:8px}.leg-route .arrow{transform:rotate(90deg)}.airline-pnrs-section,.eticket-section{padding:12px}.airline-pnrs-section h4,.eticket-section h4{font-size:13px}.detail-row .value.code{font-size:14px;padding:3px 8px}.modal-overlay{padding:16px}.modal-content{max-height:90vh;padding:20px}.voucher-header{flex-direction:column;gap:12px;text-align:center}.voucher-ref{font-size:14px;padding:6px 12px}.leg-details{flex-wrap:wrap;gap:8px}}@media(max-width:640px){.booking-steps{padding:16px 12px 12px;gap:4px;justify-content:flex-start}.step{min-width:70px;max-width:100px}.step-circle{width:32px;height:32px;font-size:12px}.step-label{font-size:11px}.booking-content{padding:16px;padding-bottom:env(safe-area-inset-bottom,16px)}.booking-step-content h2{font-size:20px;margin-bottom:16px}.passenger-form-card{padding:16px}.passenger-form-card h4{font-size:15px;margin-bottom:16px}.form-group input,.form-group select{padding:12px 14px;font-size:16px;min-height:48px}.payment-form{max-width:100%}.card-element-container>div{padding:14px;min-height:48px}.flight-summary-card{padding:16px}.flight-header{flex-direction:column;align-items:flex-start;gap:8px}.route-point strong,.flight-price{font-size:18px}.price-breakdown{padding:16px}.price-row.total{font-size:16px}.success-icon{width:80px;height:80px}.confirmation h2{font-size:20px}.confirmation-message{font-size:14px}.detail-card{padding:16px}.detail-row{flex-direction:column;gap:4px;padding:10px 0}.detail-row .label{font-size:12px}.detail-row .value{font-size:14px}.voucher-preview{margin-top:16px}.voucher-legs{padding:16px}.voucher-leg{padding:12px}.leg-route .airport{font-size:20px}.voucher-passengers{padding:16px}.legal-acceptance{padding:12px;margin:16px 0}.checkbox-label{font-size:12px;min-height:44px}.close-btn{width:40px;height:40px;top:12px;right:12px}.offer-expiration-warning,.offer-expiration-banner{font-size:13px;padding:10px 12px}.offer-expired-error{flex-direction:column;gap:12px;padding:16px}.booking-instructions{padding:12px;margin:16px 0}.booking-instructions h4{font-size:13px}.booking-instructions li{font-size:12px}.confirmation-actions{flex-direction:column;gap:12px}.voucher-actions{flex-direction:column;gap:8px}}@media(max-width:480px){.booking-steps{padding:12px 8px;gap:2px}.step{min-width:60px;max-width:80px}.step-circle{width:28px;height:28px;font-size:11px}.step-label{font-size:10px}.booking-content{padding:12px;padding-bottom:env(safe-area-inset-bottom,12px)}.booking-step-content h2{font-size:18px;gap:8px;margin-bottom:12px}.booking-step-content h2 svg{width:24px;height:24px}.step-description{font-size:13px;margin-bottom:16px}.passenger-form-card{padding:12px;border-radius:8px}.passenger-form-card h4{font-size:14px;margin-bottom:12px}.form-grid{gap:10px}.form-group label{font-size:12px}.form-group input,.form-group select{padding:10px 12px;font-size:16px;min-height:44px;border-radius:6px}.flight-summary-card{padding:12px;border-radius:8px;margin-bottom:12px}.leg-label{font-size:10px;padding:3px 8px}.flight-date{font-size:12px}.route-point{gap:6px}.route-point strong{font-size:16px}.route-point span{font-size:12px}.flight-info{font-size:12px;padding-top:12px}.flight-price{font-size:16px;margin-top:8px}.price-breakdown{padding:12px;border-radius:8px}.price-breakdown h3{font-size:14px;margin-bottom:12px}.price-row{font-size:13px;padding:6px 0}.price-row.total{font-size:15px;padding-top:12px}.payment-summary{padding:12px;border-radius:8px;margin-bottom:16px}.payment-summary h4{font-size:14px;margin-bottom:12px}.summary-row{font-size:13px;padding:6px 0}.summary-row.total,.payment-form h3{font-size:16px}.security-note{font-size:12px;margin-bottom:16px}.card-element-container{margin-bottom:16px}.card-element-container label{font-size:12px}.card-element-container>div{padding:10px;min-height:44px}.step-actions{margin-top:16px;padding-top:16px;gap:8px}.btn-primary,.btn-secondary{padding:12px 20px;font-size:15px;min-height:44px;border-radius:8px}.success-icon{width:64px;height:64px;margin-bottom:16px}.confirmation h2{font-size:18px}.confirmation-message{font-size:13px;margin-bottom:20px}.confirmation-details{margin-bottom:20px}.detail-card{padding:12px;border-radius:8px;margin-bottom:16px}.detail-row{padding:8px 0}.detail-row .value.code{font-size:14px;padding:3px 8px}.voucher-card{border-radius:8px}.voucher-header{padding:12px}.voucher-logo{font-size:16px}.voucher-ref{font-size:12px;padding:4px 10px}.voucher-legs{padding:12px}.voucher-leg{padding:10px}.leg-header{margin-bottom:8px}.leg-number{font-size:13px}.leg-status{font-size:10px;padding:3px 8px}.leg-route .airport{font-size:18px}.leg-details{font-size:12px;gap:8px}.voucher-passengers{padding:12px}.voucher-passengers h5{font-size:12px;margin-bottom:8px}.voucher-passengers .passenger{font-size:13px;padding:6px 0}.legal-acceptance{padding:10px;margin:12px 0}.legal-acceptance h4{font-size:13px;margin-bottom:10px}.checkbox-label{font-size:11px;gap:6px;margin-bottom:8px}.checkbox-label input{min-width:18px;min-height:18px}.modal-overlay{padding:12px}.modal-content{padding:16px;border-radius:8px}.modal-content h3{font-size:18px;margin-bottom:12px}.modal-content p,.modal-content li{font-size:13px}.modal-content button{padding:10px;font-size:15px;min-height:44px;margin-top:12px}.error-message{font-size:13px;padding:10px 12px}.offer-expiration-warning,.offer-expiration-banner{font-size:12px;padding:8px 10px;gap:6px}.offer-expired-error{padding:12px}.offer-expired-error h4{font-size:14px}.offer-expired-error p{font-size:12px}.booking-instructions{padding:10px;margin:12px 0}.booking-instructions h4{font-size:12px;margin-bottom:8px}.booking-instructions ul{padding-left:16px}.booking-instructions li{font-size:11px;margin-bottom:4px}.airline-pnrs-section,.eticket-section{padding:10px;margin:12px 0}.airline-pnrs-section h4,.eticket-section h4{font-size:12px;margin-bottom:8px}}@media(max-height:600px)and (orientation:landscape){.multileg-booking-flow{padding:8px;align-items:flex-start}.booking-modal{max-height:95vh;max-height:95dvh}.booking-steps{padding:12px}.step-circle{width:28px;height:28px;font-size:12px}.step-label{font-size:10px}.booking-content{padding:16px}.booking-step-content h2{font-size:18px;margin-bottom:12px}}.resume-booking-prompt{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:10000}.resume-prompt-content{background:#fff;border-radius:12px;padding:32px;max-width:500px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:24px}.resume-prompt-icon{display:flex;justify-content:center;color:#3b82f6}.resume-prompt-message h3{margin:0 0 12px;font-size:20px;font-weight:600;color:#1f2937}.resume-prompt-message p{margin:0;font-size:14px;line-height:1.6;color:#6b7280}.resume-prompt-actions{display:flex;gap:12px}.resume-prompt-actions button{flex:1}@media(prefers-reduced-motion:reduce){.success-icon,.offer-expiration-warning.urgent,.offer-expiration-banner.urgent{animation:none}.btn-primary,.btn-secondary,.close-btn,.step-circle{transition:none}}.seat-map-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-lg)}.seat-map-modal{background:#fff;border-radius:var(--radius-lg);max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;overflow:hidden}.seat-map-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--border-subtle);background:linear-gradient(135deg,#f5f7fa,#fff)}.header-content h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-main)}.flight-route{margin:4px 0 0;font-size:.9rem;color:var(--text-muted);font-weight:500}.cabin-info{margin:4px 0 0;font-size:.85rem;color:var(--primary);font-weight:600;text-transform:capitalize}.aircraft-info{margin:4px 0 0;font-size:.8rem;color:var(--text-secondary);font-weight:500}.cabin-filter-buttons{display:flex;gap:8px;padding:12px var(--spacing-lg);border-bottom:1px solid var(--border-subtle);background:#f9fafb}.filter-btn{flex:1 1 0%;padding:8px 16px;border:1px solid var(--border-subtle);background:#fff;border-radius:6px;font-size:.875rem;font-weight:500;color:var(--text-main);cursor:pointer;transition:all .2s ease}.filter-btn:hover{border-color:var(--primary);background:var(--primary-light)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.close-button{background:none;border:none;cursor:pointer;padding:8px;border-radius:var(--radius-sm);color:var(--text-muted);transition:all .2s}.close-button:hover{background-color:#f1f5f9;color:var(--text-main)}.seat-legend{display:flex;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background-color:#f5f7fa;border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary)}.legend-seat{width:20px;height:20px;border-radius:4px;border:2px solid transparent}.seat-map-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);color:var(--text-muted)}.seat-map-loading .spinner{animation:spin 1s linear infinite;color:var(--primary)}.seat-map-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-lg);gap:4px;background-color:#fef2f2;border-bottom:1px solid #fecaca}.seat-map-error .error-message{color:#dc2626;font-size:.9rem;font-weight:500;margin:0}.seat-map-error .fallback-message{color:#6b7280;font-size:.8rem;margin:0}.aircraft-container{flex:1 1 0%;overflow-y:auto;padding:var(--spacing-lg);background:linear-gradient(to bottom,#f5f7fa,#fff,#f5f7fa);position:relative}.aircraft-cockpit{display:flex;justify-content:center;margin-bottom:var(--spacing-md)}.cockpit-shape{width:80px;height:40px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50% 50% 0 0;position:relative;box-shadow:0 4px 6px #3b82f64d}.cockpit-shape:before{content:"";position:absolute;top:10px;left:50%;transform:translate(-50%);width:20px;height:15px;background:#ffffff4d;border-radius:50%}.seats-grid{background:#fff;border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:0 4px 6px #0000000d;border:2px solid #e2e8f0}.column-headers{display:flex;justify-content:center;gap:30px;margin-bottom:var(--spacing-sm);font-size:.75rem;font-weight:600;color:var(--text-muted)}.header-group{display:flex;gap:8px}.header-group span{width:32px;text-align:center}.seat-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:6px}.row-number{font-size:.75rem;font-weight:600;color:var(--text-muted);width:20px;text-align:center}.seat-group{display:flex;gap:8px}.aisle{width:30px}.seat{width:48px;height:48px;border-radius:8px;cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:.7rem;font-weight:600;transition:all .2s;border:2px solid transparent;padding:4px}.seat-location{font-size:.7rem;font-weight:700;line-height:1}.seat-price{font-size:.55rem;font-weight:500;opacity:.8;line-height:1}.seat-label{opacity:.6;font-size:.65rem}.seat.available{background-color:#e6f2ff;border-color:#7dd3fc;color:#0369a1}.seat.available:hover{background-color:#bae6fd;box-shadow:0 0 0 3px #7dd3fc4d}.seat.premium{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24;color:#92400e}.seat.premium:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);box-shadow:0 0 0 3px #fbbf244d}.seat.business{background:linear-gradient(135deg,#ddd6fe,#c4b5fd);border-color:#a78bfa;color:#5b21b6}.seat.business:hover{background:linear-gradient(135deg,#c4b5fd,#a78bfa);box-shadow:0 0 0 3px #a78bfa4d}.seat.occupied{background-color:#f1f5f9;border-color:#cbd5e1;color:#94a3b8;cursor:not-allowed;opacity:.6}.seat.selected{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#1d4ed8;color:#fff;box-shadow:0 0 0 3px #3b82f666,0 4px 12px #3b82f67f;transform:scale(1.1)}.seat.selected .seat-label,.seat.selected .seat-location,.seat.selected .seat-price{opacity:1}.seat.filtered-out{opacity:.3;cursor:not-allowed;filter:grayscale(80%)}.seat.filtered-out:hover{transform:none;box-shadow:none}.wing-marker{position:absolute;top:280px;display:flex;align-items:center}.wing-marker.left-wing{left:0}.wing-marker.right-wing{right:0}.wing-shape{width:40px;height:20px;background:linear-gradient(90deg,transparent 0%,#cbd5e1 50%,transparent 100%);opacity:.4}.left-wing .wing-shape{transform:skewY(-20deg)}.right-wing .wing-shape{transform:skewY(20deg)}.seat-map-footer{padding:var(--spacing-lg);border-top:1px solid var(--border-subtle);background:linear-gradient(135deg,#fff,#f5f7fa)}.selection-info{display:flex;justify-content:space-between;align-items:center}.selected-seat-display{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-main);font-weight:600}.confirm-button{padding:10px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #3b82f64d}.confirm-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 12px #3b82f666;transform:translateY(-1px)}.no-selection{text-align:center;color:var(--text-muted);margin:0;font-size:.9rem}@media(max-width:768px){.seat-map-modal{max-width:100%;max-height:-webkit-fill-available;border-radius:0}.seat{width:42px;height:42px;font-size:.6rem}.seat-location{font-size:.65rem}.seat-price{font-size:.5rem}.seat-legend{gap:var(--spacing-sm)}.legend-item{font-size:.75rem}}.cabin-comparison-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.cabin-comparison-modal{background:#fff;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.cabin-comparison-header{display:flex;justify-content:space-between;align-items:flex-start;padding:32px;border-bottom:1px solid #e5e7eb}.cabin-comparison-header h2{font-size:28px;font-weight:700;color:#06c;margin:0 0 8px}.cabin-comparison-header p{font-size:14px;color:#6b7280;margin:0}.close-btn:hover{background:#f3f4f6;color:#111827}.cabin-comparison-table{padding:32px}.cabin-comparison-grid{display:flex;flex-direction:column;gap:0}.comparison-row{display:grid;grid-template-columns:200px repeat(4,1fr);gap:16px;padding:16px 0;border-bottom:1px solid #f3f4f6}.comparison-row.header-row{background:linear-gradient(135deg,#e0f2fe,#dbeafe);padding:20px 16px;border-radius:12px;margin-bottom:8px;border-bottom:none}.feature-cell{font-weight:600;color:#374151;display:flex;align-items:center;font-size:14px}.cabin-header-cell{display:flex;flex-direction:column;align-items:center;gap:8px;color:#06c}.cabin-header-label{font-weight:700;font-size:16px}.value-cell{display:flex;gap:6px;font-size:13px;color:#4b5563;flex-direction:column;align-items:flex-start}.value-cell svg{color:#10b981;flex-shrink:0}.no-feature{color:#9ca3af}[data-theme=dark] .cabin-comparison-modal{background:#1f2937}[data-theme=dark] .cabin-comparison-header{border-color:#374151}[data-theme=dark] .cabin-comparison-header h2{color:#60a5fa}[data-theme=dark] .cabin-comparison-header p,[data-theme=dark] .close-btn{color:#9ca3af}[data-theme=dark] .close-btn:hover{background:#374151;color:#f3f4f6}[data-theme=dark] .comparison-row{border-color:#374151}[data-theme=dark] .comparison-row.header-row{background:linear-gradient(135deg,#1e3a5f,#1e40af)}[data-theme=dark] .feature-cell{color:#d1d5db}[data-theme=dark] .cabin-header-cell{color:#60a5fa}[data-theme=dark] .value-cell{color:#9ca3af}@media(max-width:1024px){.comparison-row{grid-template-columns:150px repeat(4,1fr);gap:12px;font-size:12px}}@media(max-width:768px){.cabin-comparison-modal{max-height:95vh}.cabin-comparison-header{padding:20px}.cabin-comparison-table{padding:20px;overflow-x:auto}.comparison-row{grid-template-columns:120px repeat(4,minmax(100px,1fr));gap:8px;font-size:11px}}.flight-detail-modal{background:#fff;border-radius:var(--radius-lg);max-width:900px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);border:1px solid var(--border-subtle)}[data-theme=dark] .flight-detail-modal{background:#1a1f2e;border:1px solid #2d333b}.flight-header-info{display:flex;align-items:center;gap:16px}.airline-logo-large{width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;background:#f9fafb;display:flex;align-items:center;justify-content:center}[data-theme=dark] .airline-logo-large{background:#2d333b}.airline-logo-large img{width:100%;height:100%;object-fit:contain;padding:8px}.flight-route-info{display:flex;align-items:center;gap:12px;margin-top:8px;color:var(--text-secondary);font-size:14px}.route-text{font-weight:600;color:var(--text-primary)}.flight-duration,.flight-stops{display:flex;align-items:center;gap:4px}.flight-timeline{display:flex;align-items:center;justify-content:space-between;padding:24px;background:#f9fafb;border-radius:var(--radius-md);margin:24px;border:1px solid var(--border-subtle)}[data-theme=dark] .flight-timeline{background:#2d333b}.timeline-point{flex:1 1 0%}.timeline-point .time{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.timeline-point .airport{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px}.timeline-line{flex:2;height:2px;background:linear-gradient(to right,var(--primary-blue),var(--primary-purple));position:relative;margin:0 16px;display:flex;align-items:center;justify-content:center}.timeline-line svg{background:#fff;padding:6px;border-radius:50%;color:var(--primary-blue);box-shadow:0 0 0 3px #fff}[data-theme=dark] .timeline-line svg{background:#1a1f2e;box-shadow:0 0 0 3px #1a1f2e}.fare-options-section{padding:0 24px 24px}.fare-options-section h3{font-size:18px;font-weight:700;margin-bottom:16px;color:var(--text-primary)}.fare-options-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.fare-option{border:2px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;cursor:pointer;transition:all .2s ease;background:#f9fafb}[data-theme=dark] .fare-option{background:#2d333b}.fare-option:hover{border-color:var(--primary-blue);box-shadow:0 4px 12px var(--shadow-color-blue);transform:translateY(-2px)}.fare-option.selected{border-color:var(--primary-blue);background:#e6f2ff;box-shadow:0 4px 16px var(--shadow-color-blue)}[data-theme=dark] .fare-option.selected{background:#1e3a5f}.fare-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.fare-header h4{font-size:16px;font-weight:600;margin:0;color:var(--text-primary)}.fare-price{font-size:20px;font-weight:700;color:var(--primary-blue)}.fare-details{font-size:13px}.baggage-info{display:flex;align-items:center;gap:6px;margin-bottom:8px;color:var(--text-secondary)}.amenities-list{list-style:none;padding:0;margin:0}.amenities-list li{padding:4px 0;color:var(--text-secondary);font-size:12px}.amenities-list li:before{content:"âœ“ ";color:var(--success-green);font-weight:700;margin-right:4px}.modal-footer{padding:24px;border-top:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center;gap:16px;background:#f9fafb}[data-theme=dark] .modal-footer{background:#2d333b}.total-price{display:flex;flex-direction:column;gap:4px}.total-price span:first-child{font-size:14px;color:var(--text-secondary)}.price-amount{font-size:28px;font-weight:700;color:var(--primary-blue)}.modal-actions{display:flex;gap:12px;align-items:center}.btn-add-to-chat,.btn-add-to-planner,.btn-book-flight{padding:12px 20px;border-radius:var(--radius-md);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;border:none;white-space:nowrap}.btn-add-to-chat{background:#fff;color:var(--text-primary);border:2px solid var(--border-subtle)}[data-theme=dark] .btn-add-to-chat{background:#1a1f2e}.btn-add-to-chat:hover{background:#e6f2ff;border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow-color-blue)}[data-theme=dark] .btn-add-to-chat:hover{background:#1e3a5f}.btn-add-to-planner{background:#fff;color:var(--text-primary);border:2px solid var(--primary-purple)}[data-theme=dark] .btn-add-to-planner{background:#1a1f2e}.btn-add-to-planner:hover{background:var(--primary-purple);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #764ba24d}.btn-book-flight{background:linear-gradient(135deg,var(--primary-blue),var(--primary-purple));color:#fff;border:none}.btn-book-flight:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow-color-blue)}@media(max-width:768px){.fare-options-grid{grid-template-columns:1fr}.flight-timeline{flex-direction:column;gap:16px}.timeline-line{width:2px;height:40px;margin:0}.modal-footer{flex-direction:column;align-items:stretch}.modal-actions{flex-direction:column;width:100%}.btn-add-to-chat,.btn-add-to-planner,.btn-book-flight{width:100%;justify-content:center}}.baggage-allowance-section{padding:24px;background:#f9fafb;border-top:1px solid #e5e7eb}[data-theme=dark] .baggage-allowance-section{background:#1a1f2e;border-top:1px solid #2d333b}.baggage-allowance-section h3{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:600;color:#111827;margin:0 0 20px}[data-theme=dark] .baggage-allowance-section h3{color:#f9fafb}.baggage-content{display:flex;flex-direction:column;gap:20px}.baggage-category{background:#fff;border-radius:12px;padding:20px;border:1px solid #e5e7eb}[data-theme=dark] .baggage-category{background:#2d333b;border:1px solid #3d444d}.baggage-category-header{display:flex;align-items:center;gap:16px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}[data-theme=dark] .baggage-category-header{border-bottom:1px solid #3d444d}.baggage-icon-wrapper{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.baggage-icon-wrapper.carry-on{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.baggage-icon-wrapper.checked{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.baggage-category-info h4{font-size:16px;font-weight:600;color:#111827;margin:0 0 4px}[data-theme=dark] .baggage-category-info h4{color:#f9fafb}.baggage-subtitle{font-size:14px;color:#6b7280;margin:0}[data-theme=dark] .baggage-subtitle{color:#9ca3af}.baggage-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.baggage-detail-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}[data-theme=dark] .baggage-detail-item{background:#1a1f2e;border:1px solid #3d444d}.detail-label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}[data-theme=dark] .detail-label{color:#9ca3af}.detail-value{font-size:14px;font-weight:600;color:#111827}[data-theme=dark] .detail-value{color:#f9fafb}.baggage-notes{display:flex;flex-direction:column;gap:12px;margin-top:8px}.baggage-note-item{display:flex;gap:12px;padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5}.baggage-note-item.info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}[data-theme=dark] .baggage-note-item.info{background:#3b82f61a;border:1px solid rgb(59 130 246 / 30%);color:#93c5fd}.baggage-note-item.warning{background:#fef3c7;border:1px solid #fde68a;color:#92400e}[data-theme=dark] .baggage-note-item.warning{background:#fbbf241a;border:1px solid rgb(251 191 36 / 30%);color:#fcd34d}.baggage-note-item.tip{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}[data-theme=dark] .baggage-note-item.tip{background:#22c55e1a;border:1px solid rgb(34 197 94 / 30%);color:#86efac}.note-icon{font-size:20px;flex-shrink:0;line-height:1}.note-content{flex:1}.note-content strong{font-weight:600;display:block;margin-bottom:4px}.baggage-policy-footer{margin-top:12px;padding:16px;background:#fff;border-radius:8px;border:1px solid #e5e7eb}[data-theme=dark] .baggage-policy-footer{background:#2d333b;border:1px solid #3d444d}.policy-text{font-size:14px;color:#6b7280;margin:0;line-height:1.6}[data-theme=dark] .policy-text{color:#9ca3af}@media(max-width:768px){.baggage-details-grid{grid-template-columns:1fr}.baggage-allowance-section{padding:20px 16px}.baggage-category{padding:16px}.baggage-category-header{flex-direction:column;align-items:flex-start;gap:12px}.baggage-icon-wrapper{width:40px;height:40px}}@media(max-width:480px){.baggage-allowance-section h3{font-size:16px}.baggage-note-item{flex-direction:column;gap:8px}.note-icon{font-size:24px}}.flight-results-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);animation:fadeIn .3s ease;padding:20px}.flight-results-glass{background:#fffffffa;border-radius:24px;border:1px solid rgb(255 255 255 / 30%);box-shadow:0 20px 60px #0000004d;max-width:1200px;width:100%;max-height:90vh;position:relative;animation:slideUp .4s ease;overflow:hidden;display:flex;flex-direction:column}[data-theme=dark] .flight-results-glass{background:#1e1e23fa;border:1px solid rgb(255 255 255 / 10%)}.flight-results-close{position:absolute;top:20px;right:20px;background:#0000001a;border:1px solid rgb(0 0 0 / 10%);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:all .2s ease;z-index:10}.flight-results-close:hover{background:#0003;transform:rotate(90deg)}[data-theme=dark] .flight-results-close{background:#ffffff1a;border:1px solid rgb(255 255 255 / 10%)}[data-theme=dark] .flight-results-close:hover{background:#fff3}.flight-results-header{text-align:center;padding:40px 40px 24px;border-bottom:1px solid rgb(0 0 0 / 10%)}[data-theme=dark] .flight-results-header{border-bottom:1px solid rgb(255 255 255 / 10%)}.flight-results-icon{font-size:32px;color:var(--primary-color);margin-bottom:16px;animation:float 3s ease-in-out infinite}.flight-results-header h2{margin:0 0 8px;font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.flight-results-subtitle{margin:0;font-size:14px;color:var(--text-secondary)}.flight-results-grid{flex:1 1 0%;overflow-y:auto;min-height:0;padding:24px 40px;display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:20px;align-content:start}.flight-results-grid::-webkit-scrollbar{width:8px}.flight-results-grid::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.flight-results-grid::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.flight-results-grid::-webkit-scrollbar-thumb:hover{background:#0000004d}[data-theme=dark] .flight-results-grid::-webkit-scrollbar-track{background:#ffffff0d}[data-theme=dark] .flight-results-grid::-webkit-scrollbar-thumb{background:#fff3}[data-theme=dark] .flight-results-grid::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.flight-results-footer{padding:16px 40px;border-top:1px solid rgb(0 0 0 / 10%);text-align:center}[data-theme=dark] .flight-results-footer{border-top:1px solid rgb(255 255 255 / 10%)}.flight-results-footer p{margin:0;font-size:12px;color:var(--text-secondary)}@media(max-width:900px){.flight-results-grid{grid-template-columns:1fr;padding:20px}.flight-results-header{padding:32px 20px 20px}.flight-results-header h2{font-size:24px}.flight-results-footer{padding:12px 20px}}.hotel-results-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);animation:fadeIn .3s ease;padding:20px}.hotel-results-glass{background:#fffffffa;border-radius:24px;border:1px solid rgb(255 255 255 / 30%);box-shadow:0 20px 60px #0000004d;max-width:1200px;width:100%;max-height:90vh;position:relative;animation:slideUp .4s ease;overflow:hidden;display:flex;flex-direction:column}[data-theme=dark] .hotel-results-glass{background:#1e1e23fa;border:1px solid rgb(255 255 255 / 10%)}.hotel-results-close{position:absolute;top:20px;right:20px;background:#0000001a;border:1px solid rgb(0 0 0 / 10%);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:all .2s ease;z-index:10}.hotel-results-close:hover{background:#0003;transform:rotate(90deg)}[data-theme=dark] .hotel-results-close{background:#ffffff1a;border:1px solid rgb(255 255 255 / 10%)}[data-theme=dark] .hotel-results-close:hover{background:#fff3}.hotel-results-header{text-align:center;padding:40px 40px 24px;border-bottom:1px solid rgb(0 0 0 / 10%)}[data-theme=dark] .hotel-results-header{border-bottom:1px solid rgb(255 255 255 / 10%)}.hotel-results-icon{font-size:32px;color:var(--primary-color);margin-bottom:16px;animation:float 3s ease-in-out infinite}.hotel-results-header h2{margin:0 0 8px;font-size:28px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.hotel-results-subtitle{margin:0;font-size:14px;color:var(--text-secondary)}.hotel-results-modal .hotel-results-grid{flex:1 1 0%;overflow-y:auto;min-height:0;padding:24px 40px;display:grid;grid-template-columns:1fr;gap:20px;align-content:start}.hotel-results-modal .hotel-results-grid::-webkit-scrollbar{width:8px}.hotel-results-modal .hotel-results-grid::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.hotel-results-modal .hotel-results-grid::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.hotel-results-modal .hotel-results-grid::-webkit-scrollbar-thumb:hover{background:#0000004d}[data-theme=dark] .hotel-results-modal .hotel-results-grid::-webkit-scrollbar-track{background:#ffffff0d}[data-theme=dark] .hotel-results-grid::-webkit-scrollbar-thumb{background:#fff3}[data-theme=dark] .hotel-results-grid::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.no-results{grid-column:1 / -1;text-align:center;padding:60px 20px;color:var(--text-secondary)}.no-results svg{opacity:.3;margin-bottom:16px}.no-results p{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--text-primary)}.no-results span{font-size:14px}.hotel-results-footer{padding:16px 40px;border-top:1px solid rgb(0 0 0 / 10%);text-align:center}[data-theme=dark] .hotel-results-footer{border-top:1px solid rgb(255 255 255 / 10%)}.hotel-results-footer p{margin:0;font-size:12px;color:var(--text-secondary)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(min-width:768px){.hotel-results-modal .hotel-results-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.hotel-results-modal .hotel-results-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:767px){.hotel-results-modal .hotel-results-grid{padding:20px}.hotel-results-header{padding:32px 20px 20px}.hotel-results-header h2{font-size:24px}.hotel-results-footer{padding:12px 20px}}.card-actions{display:flex;gap:8px;align-items:center}.card-actions.compact{gap:6px}.card-actions .action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border-radius:var(--radius-sm, 6px);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid var(--border-subtle, #e2e8f0);background:var(--glass-bg-subtle, rgb(255 255 255 / 50%));color:var(--text-secondary, #64748b)}.card-actions.compact .action-btn{padding:6px;min-width:32px;justify-content:center}.card-actions .action-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.card-actions .action-btn:active{transform:translateY(0)}.card-actions .action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.card-actions .action-btn.bucket-list{color:var(--accent-pink, #ec4899);border-color:var(--accent-pink-light, #fce7f3)}.card-actions .action-btn.bucket-list:hover{background:var(--accent-pink-light, #fce7f3);border-color:var(--accent-pink, #ec4899)}.card-actions .action-btn.bucket-list.saved{background:var(--accent-pink, #ec4899);color:#fff;border-color:var(--accent-pink, #ec4899)}.card-actions .action-btn.bucket-list.saved:hover{background:var(--accent-pink-dark, #db2777)}.card-actions .action-btn.planner{background:var(--glass-bg);border-color:var(--primary-blue);color:var(--primary-blue)}.card-actions .action-btn.planner:hover{color:var(--text-secondary, #64748b);border-color:var(--border-subtle, #e2e8f0);background:var(--glass-bg-subtle, rgb(255 255 255 / 50%))}.card-actions .action-btn.itinerary{color:var(--accent-purple, #8b5cf6);border-color:var(--accent-purple-light, #ede9fe)}.card-actions .action-btn.itinerary:hover{background:var(--accent-purple-light, #ede9fe);border-color:var(--accent-purple, #8b5cf6)}.card-actions .action-btn.favorite{color:var(--text-secondary)}.card-actions .action-btn.favorite.favorited{background:#ff4757;border-color:#ff4757;color:#fff}.card-actions .action-btn.favorite.favorited svg{fill:#fff}@media(max-width:768px){.card-actions{gap:8px}.card-actions .action-btn{padding:10px 14px;font-size:.8125rem;min-height:44px;min-width:44px;justify-content:center}.card-actions.compact .action-btn{padding:6px;min-width:44px;min-height:44px;position:relative}.card-actions .action-btn span{display:none}}@media(prefers-color-scheme:dark){.card-actions .action-btn{background:var(--glass-bg-dark, rgb(30 41 59 / 50%));border-color:var(--border-dark, #334155);color:var(--text-secondary-dark, #94a3b8)}.card-actions .action-btn:hover{box-shadow:0 2px 8px #0000004d}}.search-bar-collapsed{background:linear-gradient(135deg,#fffffff2,#f9fafbf2);border-bottom:1px solid var(--border-subtle);padding:8px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease;min-height:40px}.search-bar-collapsed:hover{background:linear-gradient(135deg,#f8fafcfa,#f1f5f9fa)}.collapsed-content{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-primary);flex-wrap:wrap}.collapsed-icon{color:var(--primary-blue);flex-shrink:0}.collapsed-icon-small{color:var(--text-muted);flex-shrink:0}.collapsed-route{font-weight:600;display:flex;align-items:center;gap:6px}.collapsed-divider{color:var(--text-muted);margin:0 4px}.collapsed-dates,.collapsed-travelers{color:var(--text-secondary)}.collapsed-class{background:var(--primary-blue);color:#fff;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.expand-btn{display:flex;align-items:center;gap:4px;padding:8px 16px;background:transparent;border:1px solid var(--border-subtle);border-radius:16px;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;min-height:36px}.expand-btn:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.search-bar-persistent{background:var(--bg-primary, #fff);border-bottom:1px solid var(--border-color, #e5e7eb);padding:var(--spacing-sm) var(--spacing-lg) var(--spacing-md)}.search-bar-persistent.expanded{animation:slideDown .2s ease-out}.search-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.search-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.collapse-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border-subtle);border-radius:50%;cursor:pointer;color:var(--text-muted);transition:all .2s ease}.collapse-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.search-fields-row{display:flex;gap:var(--spacing-sm);align-items:flex-end}.search-field{display:flex;flex-direction:column;gap:2px;flex:1 1 0%}.search-field label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.search-field input,.search-field select{padding:6px 10px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:16px}.nearby-checkbox{display:flex;align-items:center;gap:4px;font-size:.7rem;font-weight:400;color:var(--text-muted);cursor:pointer;margin-top:2px}.nearby-checkbox input[type=checkbox]{width:12px;height:12px}.travelers-class{display:flex;gap:6px}.travelers-input{width:45px}.class-select{flex:1 1 0%}.search-button-persistent{padding:8px 20px;background-color:var(--primary-blue);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;cursor:pointer;white-space:nowrap}.search-button-persistent:hover{background-color:#0056b3}[data-theme=dark] .search-bar-collapsed{background:linear-gradient(135deg,#1e293bf2,#0f172af2);border-color:var(--border-subtle)}[data-theme=dark] .search-bar-collapsed:hover{background:linear-gradient(135deg,#334155fa,#1e293bfa)}[data-theme=dark] .search-bar-persistent{background-color:var(--bg-secondary)}[data-theme=dark] .search-field input,[data-theme=dark] .search-field select{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-subtle)}[data-theme=dark] .expand-btn{border-color:var(--border-subtle);color:var(--text-secondary)}[data-theme=dark] .expand-btn:hover{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}[data-theme=dark] .collapse-btn{border-color:var(--border-subtle);color:var(--text-muted)}[data-theme=dark] .collapse-btn:hover{background:var(--bg-hover)}.results-info-bar{background:var(--glass-bg);border-bottom:1px solid var(--glass-border)}.results-secondary-sidebar{position:relative;width:280px;min-width:280px;max-width:280px;height:-webkit-fill-available;background:var(--bg-primary, #fff);border-left:1px solid var(--border-color, #e5e7eb);box-shadow:-4px 0 24px #0000000d;display:flex;flex-direction:column;overflow:hidden;padding-left:8px;padding-bottom:80px;box-sizing:border-box}.results-secondary-sidebar-collapsed{position:relative;width:8px;background-color:transparent;border-left:1px solid var(--glass-border);display:flex;flex-shrink:0;height:100%}.sidebar-divider{height:1px;background-color:var(--border-subtle);margin:var(--spacing-md) 0}.recent-searches-section{padding:var(--spacing-md)}.recent-searches-section h4{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem;font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-main)}.no-searches{font-size:.85rem;color:var(--text-muted);text-align:center;padding:var(--spacing-lg) 0}.recent-searches-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.recent-search-item{padding:var(--spacing-sm);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.recent-search-item:hover{background-color:var(--button-bg-hover);border-color:var(--primary-blue)}.recent-search-item .search-label{display:block;font-size:.85rem;font-weight:500;color:var(--text-main);margin-bottom:4px}.recent-search-item .search-meta{display:block;font-size:.75rem;color:var(--text-muted)}.filters-collapsible-section{padding:var(--spacing-md)}.filters-header-collapsible{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:var(--spacing-sm) 0;-webkit-user-select:none;user-select:none}.filters-header-collapsible h4{font-size:.9rem;font-weight:600;margin:0}.filters-content{padding-top:var(--spacing-md)}.clear-all-btn-inline{background:none;border:none;color:var(--primary-blue);font-size:.8rem;cursor:pointer;padding:4px 0;margin-bottom:var(--spacing-md);text-decoration:underline}.filter-section h5{font-size:.85rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-main)}.flight-origin{display:flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;text-align:center;justify-content:center;padding:4px 8px;border-radius:var(--radius-sm);margin-bottom:8px}.flight-origin.main{color:var(--primary-blue);background-color:#eff6ff}.flight-origin.nearby{color:#f59e0b;background-color:#fef3c7}.flight-results-container{height:100%;display:flex;flex-direction:column;background-color:transparent}.search-tabs{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:transparent}.search-tab{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.search-tab.active{background-color:var(--primary-blue);color:#fff;box-shadow:var(--shadow-sm),0 0 8px var(--glow-blue)}.search-tab:hover:not(.active){background-color:#f1f5f9}.results-count{margin-left:auto;color:var(--text-muted);font-size:.9rem}.price-mode-toggle{display:flex;align-items:center;gap:4px;background:var(--glass-bg-subtle);border:1px solid var(--glass-border);border-radius:20px;padding:3px;margin-left:auto;margin-right:12px}.price-mode-btn{padding:6px 16px;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:13px;cursor:pointer;border-radius:16px;transition:all .2s;white-space:nowrap}.price-mode-btn.active{background:var(--primary-blue);color:#fff;box-shadow:0 2px 8px #3b82f64d}.price-mode-btn:hover:not(.active){background:var(--glass-bg)}.flight-results-main{flex:1 1 0%;padding:var(--spacing-lg);overflow-y:auto}.flight-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-lg)}.flight-results-container>div{scrollbar-width:thin;scrollbar-color:rgb(59 130 246 / 30%) transparent}.flight-results-container>div::-webkit-scrollbar{width:8px}.flight-results-container>div::-webkit-scrollbar-track{background:transparent}.flight-results-container>div::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:4px}.flight-results-container>div::-webkit-scrollbar-thumb:hover{background:#3b82f67f}.flight-row-grid{display:grid;grid-template-columns:1fr;gap:0;padding:0 var(--spacing-lg)}@media(max-width:767px){.flight-row-grid{grid-template-columns:1fr;gap:12px;padding:0 12px 12px}}@media(min-width:768px)and (max-width:1023px){.flight-row-grid{gap:16px;padding:0 16px 16px}}.flight-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;flex-direction:column;gap:8px;transition:var(--transition-smooth);box-shadow:var(--glass-shadow)}.flight-card:hover{background:var(--glass-hover-bg);box-shadow:var(--glass-shadow-strong);transform:translateY(-4px)}.route-image-placeholder{width:100%;height:80px;background:var(--bg-secondary, #f3f4f6);border:1px solid var(--border-color, #e5e7eb);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.75rem;margin-bottom:4px}.flight-option-label{font-size:.75rem;color:var(--text-muted);text-align:center}.flight-price{font-size:1.3rem;font-weight:600;color:var(--primary-blue);text-align:center;margin:4px 0}.flight-detail{font-size:.8rem;color:var(--text-muted);text-align:center}.flight-detail strong{color:var(--text-secondary)}.seat-map-link{font-size:.75rem;color:var(--primary-blue);text-align:center;text-decoration:none}.seat-map-link:hover{text-decoration:underline}.carbon-footprint{font-size:.7rem;color:var(--text-muted);text-align:center;margin-top:4px}.flight-card-actions{display:flex;gap:var(--spacing-sm);margin-top:8px}.btn-add-itinerary{flex:1 1 0%;padding:8px 12px;background:var(--glass-bg-subtle);border:1.5px solid var(--primary-blue);color:var(--primary-blue);border-radius:var(--radius-sm);font-weight:600;font-size:.8rem;cursor:pointer;transition:var(--transition-smooth);display:flex;align-items:center;justify-content:center;gap:6px}.btn-add-itinerary:hover{background:var(--glass-bg);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-book-now{flex:1 1 0%;padding:10px 24px;background:var(--primary-blue);border:none;color:#fff;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-glow-subtle)}.btn-book-now:hover{background:var(--primary-blue-hover);transform:translateY(-2px);box-shadow:var(--shadow-glow-blue)}.flight-card-horizontal{position:relative;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:0;transition:var(--transition-smooth);box-shadow:var(--glass-shadow);overflow:hidden}.flight-card-horizontal:hover{background:var(--glass-bg-strong);box-shadow:var(--glass-shadow-strong),var(--shadow-glow-subtle);transform:translateY(-2px)}.flight-card-horizontal.selected-for-comparison{border-color:var(--primary-blue);box-shadow:0 0 0 2px var(--primary-blue)}.low-fare-banner{position:absolute;top:12px;left:12px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:4px 12px;border-radius:4px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px;z-index:10;box-shadow:0 2px 8px #10b9814d}.flight-card-main-content{display:flex;padding:10px 14px;gap:14px}.flight-info-section{flex:1 1 0%;display:flex;flex-direction:column;gap:8px}.flight-main-row{display:grid;grid-template-columns:180px 1fr;align-items:center;gap:16px}.flight-comparison-checkbox-inline{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.flight-comparison-checkbox-inline input[type=checkbox]{width:16px;height:16px;cursor:pointer}.flight-comparison-checkbox-inline label{cursor:pointer;-webkit-user-select:none;user-select:none}.airline-info{display:flex;align-items:center;gap:12px;width:180px}.airline-logo{width:40px;height:40px;object-fit:contain;border-radius:8px;background:#fff;padding:4px}.airline-logo-placeholder{width:40px;height:40px;background:var(--primary-blue);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.airline-details{display:flex;flex-direction:column;gap:2px}.airline-name{font-weight:600;font-size:14px;color:var(--text-primary)}.flight-meta{font-size:12px;color:var(--text-muted)}.flight-times-route{display:flex;align-items:center;justify-content:center;gap:8px;padding:0;flex:1 1 0%}.time-block{display:flex;flex-direction:column;gap:4px}.time{font-size:18px;font-weight:700;color:var(--text-primary)}.airport-code{font-size:13px;font-weight:600;color:var(--text-muted)}.route-visual{flex:1 1 0%;display:flex;flex-direction:column;align-items:center;gap:0;min-width:200px;max-width:250px}.duration-text{font-size:16px;color:var(--text-muted);font-weight:500;margin-top:-8px}.flight-additional-info{display:flex;flex-direction:column;gap:8px}.nearby-airport-notice{display:flex;align-items:center;gap:6px;font-size:12px;color:#f59e0b;background:#f59e0b1a;padding:6px 10px;border-radius:6px}.cabin-selector-section{position:relative;display:flex;flex-direction:column;align-items:flex-start;border-left:1px solid var(--glass-border);padding-left:12px;gap:6px;align-self:stretch}.compare-cabins-link{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--primary-blue);text-decoration:none;font-weight:500;cursor:pointer;transition:all .2s}.compare-cabins-link:hover{color:var(--primary-blue-hover);text-decoration:underline}.cabin-options{display:flex;gap:8px;flex:1 1 0%;align-items:stretch}.cabin-option{display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:8px;background:var(--glass-bg);border:1.5px solid var(--glass-border);border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:75px;max-width:85px;flex:1 1 0%;position:relative;overflow:hidden}.cabin-option:hover:not(.unavailable){background:var(--glass-bg-strong);border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.cabin-option.selected{background:linear-gradient(135deg,#3b82f626,#2563eb26);border-color:var(--primary-blue);box-shadow:0 0 0 2px var(--primary-blue),0 8px 16px #3b82f633}.cabin-option.unavailable{opacity:.4;cursor:not-allowed;filter:grayscale(1)}.cabin-label{font-size:16px;font-weight:700;color:var(--text-primary);text-align:center;text-transform:capitalize;z-index:2;position:relative;line-height:1.2}.cabin-option.selected .cabin-label{color:var(--primary-blue)}.cabin-image-container{flex:1 1 0%;display:flex;align-items:center;justify-content:center;width:100%;padding:4px 0;position:relative;max-height:60px}.cabin-seat-image{width:100%;height:100%;object-fit:contain;max-height:50px;max-width:60px;filter:drop-shadow(0 1px 2px rgb(0 0 0 / 10%))}.cabin-price{font-size:15px;font-weight:700;color:var(--text-primary);z-index:2;position:relative;line-height:1.2}.cabin-option.selected .cabin-price{color:var(--primary-blue)}.cabin-trip-type{font-size:16px;color:var(--text-muted);font-weight:500;z-index:2;position:relative;line-height:1.2}.flight-card-bottom-actions{display:flex;justify-content:space-between;align-items:center;padding:8px 0;margin-top:12px;background:transparent;border-top:1px solid var(--glass-border)}.bottom-actions-left,.bottom-actions-right{display:flex;gap:8px;align-items:center}.btn-seats,.btn-details{display:flex;align-items:center;gap:6px;padding:6px 14px;background:transparent;border:none;color:var(--primary-blue);border-radius:6px;font-weight:500;font-size:13px;cursor:pointer;transition:all .2s}.btn-seats:hover,.btn-details:hover{background:#3b82f61a;color:var(--primary-blue)}.round-trip-indicator{display:flex;gap:12px;margin-bottom:8px;font-size:12px;font-weight:600}.round-trip-indicator span{padding:4px 12px;border-radius:4px;background:var(--surface-secondary);color:var(--text-secondary)}.round-trip-indicator span.active{background:var(--primary-blue);color:#fff}.round-trip-indicator span.completed{background:var(--success-green);color:#fff}.add-to-dropdown-container{position:relative}.btn-add-to{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--surface-primary);border:2px solid var(--primary-purple);color:var(--primary-purple);border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.btn-add-to:hover{background:var(--primary-purple);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #764ba24d}.add-to-dropdown{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:#141923fa;border:1px solid rgb(255 255 255 / 10%);border-radius:8px;box-shadow:0 8px 24px #0006;min-width:160px;z-index:100;overflow:hidden}.add-to-dropdown button{width:100%;padding:12px 16px;text-align:left;background:transparent;border:none;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.add-to-dropdown button:hover{background:#667eea33;color:#fff}.add-to-dropdown button:not(:last-child){border-bottom:1px solid var(--border-subtle)}@media(max-width:1024px){.flight-card-main-content{flex-direction:column;gap:16px}.cabin-selector-section{border-left:none;border-top:1px solid var(--glass-border);padding-left:0;padding-top:12px}.cabin-options{width:100%;justify-content:space-between}.cabin-option{flex:1 1 0%;min-width:70px}}@media(max-width:768px){.flight-main-row{flex-direction:column;gap:12px;align-items:flex-start}.airline-info{min-width:auto}.flight-times-route{gap:12px;width:100%}.time{font-size:16px}.airport-code{font-size:11px}.route-visual{min-width:150px}.cabin-options{gap:8px}.cabin-option{padding:8px 10px;min-width:60px}.cabin-label{font-size:10px}.cabin-price{font-size:14px}.bottom-actions-right{width:100%;justify-content:space-between}.btn-seats,.btn-details{flex:1 1 0%;justify-content:center}}.btn-view-details{display:flex;align-items:center;gap:4px;padding:8px 12px;background:var(--glass-bg-subtle);border:1.5px solid var(--text-muted, #6b7280);color:var(--text-muted, #6b7280);border-radius:var(--radius-sm);font-weight:600;font-size:.75rem;cursor:pointer;transition:var(--transition-smooth)}.btn-view-details:hover{background:var(--glass-bg);border-color:var(--primary-blue);color:var(--primary-blue);transform:translateY(-1px)}.price-slider{width:100%;height:6px;border-radius:5px;background:#ddd;outline:none;margin-bottom:var(--spacing-sm)}.price-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-blue);cursor:pointer}.price-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-blue);cursor:pointer;border:none}.price-range-values{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted)}.checkbox-group,.toggle-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.9rem;color:var(--text-secondary);cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}@media(max-width:767px){.flight-results-container{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom))}.search-tabs{padding:8px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.search-tabs::-webkit-scrollbar{display:none}.search-tab{padding:6px 12px;font-size:.8rem;white-space:nowrap;flex-shrink:0}.results-count{font-size:.8rem;white-space:nowrap}.search-bar-persistent{padding:8px 12px}.search-fields-row{flex-direction:column;gap:8px}.search-field{width:100%}.travelers-class{flex-direction:column;gap:8px}.travelers-input{width:100%}.search-button-persistent{width:100%;margin-top:8px;min-height:var(--touch-target-min)}.results-info-bar{padding:8px 12px}.results-info-bar .info-row{flex-direction:column;gap:8px;align-items:flex-start}.flight-results-main{padding:12px;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 80px)}.flight-results-grid{grid-template-columns:1fr;gap:12px}.flight-card{padding:12px;gap:6px}.route-image-placeholder{height:60px;font-size:.7rem}.flight-option-label{font-size:.7rem}.flight-price{font-size:1.1rem}.flight-detail{font-size:.75rem}.flight-card-actions{gap:8px;margin-top:6px}.btn-add-itinerary,.btn-book-now,.btn-view-details{padding:10px 12px;font-size:.75rem;min-height:var(--touch-target-min)}}@media(min-width:768px)and (max-width:1023px){.flight-results-main{padding:16px}.flight-results-grid{grid-template-columns:repeat(2,1fr);gap:16px}.search-tab{padding:7px 14px;font-size:.85rem}}@media(min-width:1024px)and (max-width:1279px){.flight-results-main{padding:var(--spacing-lg)}.flight-results-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-lg)}}@media(min-width:1280px){.flight-results-main{padding:var(--spacing-xl)}.flight-results-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-xl);max-width:1600px;margin:0 auto}}@media(hover:none)and (pointer:coarse){.search-tab,.search-button-persistent,.btn-add-itinerary,.btn-book-now,.btn-view-details{min-height:var(--touch-target-min)}.flight-card:hover,.btn-add-itinerary:hover,.btn-book-now:hover,.btn-view-details:hover{transform:none}.flight-card:active{opacity:.95}.btn-add-itinerary:active{background:var(--glass-bg)}.btn-book-now:active{opacity:.9}}.flight-comparison-checkbox{position:absolute;top:16px;right:16px;z-index:10}.flight-comparison-checkbox input[type=checkbox]{display:none}.flight-comparison-checkbox label{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fffffff2;border:1.5px solid #e5e7eb;border-radius:20px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s ease;box-shadow:0 2px 8px #0000000f}.flight-comparison-checkbox label:hover{background:#fff;border-color:#3b82f6;color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-1px)}.flight-comparison-checkbox label:before{content:"";width:18px;height:18px;border:2px solid #d1d5db;border-radius:4px;background:#fff;transition:all .2s ease;flex-shrink:0}.flight-comparison-checkbox input[type=checkbox]:checked+label{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;color:#fff;box-shadow:0 4px 16px #3b82f64d}.flight-comparison-checkbox input[type=checkbox]:checked+label:before{background:#fff;border-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233b82f6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-size:14px;background-position:center;background-repeat:no-repeat}.flight-card.selected-for-comparison{border:2px solid #3b82f6;box-shadow:0 8px 24px #3b82f626;transform:translateY(-2px)}.comparison-bar{position:sticky;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;padding:16px 24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 -4px 12px #0000000d;z-index:100}.comparison-bar span{font-weight:500;color:#374151}.comparison-bar-actions{display:flex;gap:12px}.btn-compare,.btn-clear-comparison{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-weight:500;transition:all .2s}.btn-compare{background:#3b82f6;color:#fff}.btn-compare:hover{background:#2563eb}.btn-compare:disabled{background:#9ca3af;cursor:not-allowed}.btn-clear-comparison{background:#f3f4f6;color:#374151}.btn-clear-comparison:hover{background:#e5e7eb}[data-theme=dark] .flight-card-horizontal{background:#1e293b99;border-color:#4755697f}[data-theme=dark] .flight-card-horizontal:hover{background:#1e293bcc;border-color:#60a5fa}[data-theme=dark] .low-fare-banner{background:linear-gradient(135deg,#059669,#047857)}[data-theme=dark] .airline-logo-placeholder{background:#60a5fa}[data-theme=dark] .airline-name,[data-theme=dark] .time{color:#f3f4f6}[data-theme=dark] .cabin-selector-section{border-color:#4755697f}[data-theme=dark] .cabin-option{background:#0f172acc;border-color:#47556999}[data-theme=dark] .cabin-option:hover:not(.unavailable){background:#1e293be5;border-color:#60a5fa;box-shadow:0 8px 16px #0000004d}[data-theme=dark] .cabin-option.selected{background:linear-gradient(135deg,#60a5fa33,#3b82f633);border-color:#60a5fa;box-shadow:0 0 0 2px #60a5fa,0 8px 16px #60a5fa4d}[data-theme=dark] .cabin-label{color:#e5e7eb}[data-theme=dark] .cabin-option.selected .cabin-label,[data-theme=dark] .cabin-option.selected .cabin-price{color:#60a5fa}[data-theme=dark] .cabin-price{color:#f3f4f6}[data-theme=dark] .cabin-seat-image{filter:drop-shadow(0 2px 4px rgb(0 0 0 / 50%)) brightness(.95)}[data-theme=dark] .flight-card-bottom-actions{background:#0f172a99;border-color:#4755697f}[data-theme=dark] .compare-cabins-link{color:#60a5fa}[data-theme=dark] .compare-cabins-link:hover{color:#93c5fd}[data-theme=dark] .btn-seats,[data-theme=dark] .btn-details{background:#1e293b99;border-color:#4755697f;color:#9ca3af}[data-theme=dark] .btn-seats:hover,[data-theme=dark] .btn-details:hover{background:#1e293bcc;border-color:#60a5fa;color:#60a5fa}[data-theme=dark] .price-mode-toggle{background:#0f172a99;border-color:#4755697f}[data-theme=dark] .price-mode-btn{color:#9ca3af}[data-theme=dark] .price-mode-btn.active{background:#60a5fa;color:#1f2937}[data-theme=dark] .price-mode-btn:hover:not(.active){background:#1e293bcc}.sort-dropdown-container{display:flex;align-items:center;gap:8px;padding:8px 20px;background:transparent;position:sticky;top:0;z-index:10}.sort-dropdown-container label{font-size:.8rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.sort-dropdown{padding:4px 28px 4px 10px;font-size:.8rem;color:var(--text-main);background-color:#ffffff7f;border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer;transition:all .15s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%236b7280' d='M5 7L1 3h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:10px 10px;min-width:160px;box-shadow:none;text-indent:0;text-overflow:""}.sort-dropdown:hover{border-color:var(--primary-blue);background-color:#3b82f614}.sort-dropdown:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 2px #3b82f61a}[data-theme=dark] .sort-dropdown-container{background:transparent}[data-theme=dark] .sort-dropdown-container label{color:#fff9}[data-theme=dark] .sort-dropdown{background-color:#1e293b99;border-color:#ffffff26;color:#ffffffe5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath fill='%239ca3af' d='M5 7L1 3h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:10px 10px;box-shadow:none}[data-theme=dark] .sort-dropdown:hover{border-color:var(--primary-blue);background-color:#3b82f626}[data-theme=dark] .sort-dropdown:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #3b82f626}.sort-dropdown option{background:var(--surface-white);color:var(--text-main);padding:8px}[data-theme=dark] .sort-dropdown option{background:#1e293b;color:#ffffffe5}@media(max-width:768px),(hover:none)and (pointer:coarse){.collapse-btn,.expand-btn,.search-button-persistent,.search-tab,.price-mode-btn,.btn-add-itinerary,.btn-book-now,.btn-view-details,.btn-seats,.btn-details,.btn-add-to{min-width:44px;min-height:44px}.collapse-btn{width:44px;height:44px}.flight-comparison-checkbox-inline{min-height:44px;padding:8px}.checkbox-label input[type=checkbox],.flight-comparison-checkbox-inline input[type=checkbox]{width:44px;height:44px;min-width:44px;min-height:44px}.sort-dropdown{min-height:44px;padding:8px 32px 8px 14px}.filter-section-header{min-height:44px}.clear-all-btn,.clear-all-btn-inline{min-height:44px;min-width:44px;padding:8px 12px}}@media(prefers-reduced-motion:reduce){.flight-card,.btn-add-itinerary,.btn-book-now,.btn-view-details{transition:none}}.flight-results-with-selection{max-width:1400px;margin:0 auto;padding:20px}.results-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.btn-back{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:transparent;border:1px solid #d1d5db;border-radius:8px;color:#4b5563;font-size:14px;cursor:pointer;transition:all .2s;margin-bottom:16px}.btn-back:hover{background:#f3f4f6;color:#1f2937}.results-header h2{display:flex;align-items:center;gap:12px;font-size:24px;font-weight:600;color:#111827;margin:0 0 8px}.route-info{color:#6b7280;font-size:14px;margin:0}.flight-selection-progress{margin-bottom:24px;padding:16px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.progress-steps{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.progress-step{display:flex;align-items:center;gap:12px;padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;transition:all .2s;min-width:180px}.progress-step:hover:not(:disabled){border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.progress-step.current{border-color:#3b82f6;background:#eff6ff}.progress-step.completed{border-color:#10b981;background:#ecfdf5}.progress-step.pending{opacity:.6;cursor:not-allowed}.progress-step .step-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#e5e7eb;color:#6b7280;flex-shrink:0}.progress-step.current .step-icon{background:#3b82f6;color:#fff}.progress-step.completed .step-icon{background:#10b981;color:#fff}.progress-step .step-info{display:flex;flex-direction:column;text-align:left}.progress-step .step-label{font-weight:600;font-size:14px;color:#374151}.progress-step .step-route{font-size:12px;color:#6b7280}.step-connector{color:#d1d5db;flex-shrink:0}.step-connector.completed{color:#10b981}.results-layout{display:grid;grid-template-columns:1fr 320px;gap:24px}@media(max-width:1024px){.results-layout{grid-template-columns:1fr}}.flight-filters{display:flex;gap:16px;margin-bottom:20px;padding:16px;background:#fff;border-radius:10px;border:1px solid #e5e7eb;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.filter-group select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff;min-width:140px;cursor:pointer}.filter-group select:focus{outline:none;border-color:#3b82f6}.flight-list{display:flex;flex-direction:column;gap:12px}.no-flights{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#6b7280;background:#fff;border-radius:12px;border:2px dashed #e5e7eb}.no-flights h3{margin:16px 0 8px;color:#374151}.no-flights button{margin-top:16px;padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}.results-sidebar{position:sticky;top:20px;height:fit-content}.selected-flights-summary{background:#fff;border-radius:12px;border:1px solid #e5e7eb;padding:20px;box-shadow:0 2px 8px #0000000d}.selected-flights-summary h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#111827;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.selected-flight-item{display:flex;justify-content:space-between;align-items:flex-start;padding:12px 0;border-bottom:1px solid #f3f4f6}.selected-flight-item:last-of-type{border-bottom:none}.selected-flight-info{display:flex;flex-direction:column;gap:4px}.selected-flight-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#6b7280}.selected-flight-route{font-weight:600;color:#111827;font-size:14px}.selected-flight-time{display:flex;align-items:center;gap:4px;font-size:12px;color:#6b7280}.selected-flight-price{font-weight:700;color:#059669;font-size:16px}.selected-total{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:2px solid #e5e7eb}.selected-total span:first-child{font-weight:600;color:#374151}.total-price{font-size:24px;font-weight:700;color:#059669}.btn-proceed{width:100%;margin-top:16px;padding:14px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.btn-proceed:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.flight-results-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.flight-results-loading p{color:#6b7280;font-size:16px}.flight-results-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#ef4444}.flight-results-error h3{margin:16px 0 8px;color:#dc2626}.flight-results-error p{color:#6b7280;margin-bottom:16px}.flight-results-error button{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500}@media(max-width:768px){.flight-results-with-selection{padding:12px}.progress-steps{flex-direction:column;align-items:stretch}.progress-step{min-width:auto}.step-connector{transform:rotate(90deg);align-self:center}.flight-filters{flex-direction:column}.filter-group select{width:100%}}.flight-card-skeleton{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid #e5e7eb}.skeleton-row{display:flex;align-items:center;margin-bottom:16px}.skeleton-row:last-child{margin-bottom:0}.skeleton-airline-logo{width:40px;height:40px;border-radius:50%;margin-right:12px;flex-shrink:0}.skeleton-airline-name{width:120px;height:16px}.flight-times{justify-content:space-between}.skeleton-time-block{display:flex;flex-direction:column;align-items:center}.skeleton-time{width:60px;height:24px;margin-bottom:4px}.skeleton-airport{width:40px;height:14px}.skeleton-route{flex:1;display:flex;flex-direction:column;align-items:center;margin:0 20px}.skeleton-line{width:100%;height:2px;margin-bottom:8px;max-width:150px}.skeleton-duration{width:80px;height:12px}.skeleton-cabin-options{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding-top:16px;border-top:1px solid #e5e7eb}.skeleton-cabin-option{display:flex;flex-direction:column;align-items:center;padding:12px;border:1px solid #e5e7eb;border-radius:8px}.skeleton-cabin-label{width:60px;height:14px;margin-bottom:8px}.skeleton-cabin-price{width:50px;height:20px}@media(max-width:768px){.skeleton-cabin-options{grid-template-columns:repeat(2,1fr)}.skeleton-route{margin:0 10px}.skeleton-line{max-width:80px}}@media(max-width:480px){.skeleton-cabin-options{grid-template-columns:1fr}.skeleton-header{flex-direction:column;gap:12px}.skeleton-title,.skeleton-sort{width:100%}}.flight-comparison-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.flight-comparison-modal{background:var(--surface-white, #fff);border-radius:12px;box-shadow:0 20px 60px #0003;max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}@media(prefers-color-scheme:dark){.flight-comparison-modal{background:var(--surface-dark, #1e293b);border:1px solid var(--border-dark, #334155)}}.comparison-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle, #e2e8f0)}@media(prefers-color-scheme:dark){.comparison-header{border-bottom-color:var(--border-dark, #334155)}}.comparison-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;color:var(--text-primary, #1e293b);margin:0}@media(prefers-color-scheme:dark){.comparison-title{color:var(--text-primary-dark, #f1f5f9)}}.comparison-close{background:transparent;border:none;color:var(--text-secondary, #64748b);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.comparison-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--text-primary, #1e293b)}@media(prefers-color-scheme:dark){.comparison-close{color:var(--text-secondary-dark, #94a3b8)}.comparison-close:hover{background:var(--bg-hover-dark, #334155);color:var(--text-primary-dark, #f1f5f9)}}.comparison-grid{flex:1;overflow-y:auto;padding:16px 20px}.grid-cell{padding:12px;border-bottom:1px solid var(--border-subtle, #e2e8f0);display:flex;align-items:center;justify-content:center;text-align:center}@media(prefers-color-scheme:dark){.grid-cell{border-bottom-color:var(--border-dark, #334155)}}.header-cell{padding:10px 12px;font-size:13px;font-weight:600;color:var(--text-secondary, #64748b);border-bottom:2px solid var(--border-subtle, #e2e8f0);text-transform:uppercase;letter-spacing:.5px}@media(prefers-color-scheme:dark){.header-cell{color:var(--text-secondary-dark, #94a3b8);border-bottom-color:var(--border-dark, #334155)}}.label-cell{justify-content:flex-start;text-align:left;font-weight:600;font-size:13px;color:var(--text-secondary, #64748b);gap:6px}@media(prefers-color-scheme:dark){.label-cell{color:var(--text-secondary-dark, #94a3b8)}}.flight-header-cell{flex-direction:column;gap:6px}.comparison-airline-logo{width:32px;height:32px;border-radius:6px;object-fit:contain}.comparison-airline-name{font-size:12px;font-weight:600;color:var(--text-primary, #1e293b)}@media(prefers-color-scheme:dark){.comparison-airline-name{color:var(--text-primary-dark, #f1f5f9)}}.data-cell{font-size:14px;color:var(--text-primary, #1e293b)}@media(prefers-color-scheme:dark){.data-cell{color:var(--text-primary-dark, #f1f5f9)}}.route-code{font-size:14px;font-weight:600;color:var(--primary-blue, #3b82f6)}.route-arrow{margin:0 4px;color:var(--text-secondary, #64748b)}.price-label{background:var(--bg-subtle, #f8fafc)}.price-cell{font-size:18px;font-weight:700;color:var(--primary-blue, #3b82f6);background:var(--bg-subtle, #f8fafc)}@media(prefers-color-scheme:dark){.price-label,.price-cell{background:var(--bg-subtle-dark, #0f172a)}}.action-cell{background:var(--bg-subtle, #f8fafc);border-top:2px solid var(--border-subtle, #e2e8f0);padding:16px 12px}@media(prefers-color-scheme:dark){.action-cell{background:var(--bg-subtle-dark, #0f172a);border-top-color:var(--border-dark, #334155)}}.btn-book-flight{padding:8px 16px;background:var(--primary-blue, #3b82f6);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100%;max-width:150px}.btn-book-flight:hover{background:var(--primary-blue-dark, #2563eb);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-book-flight:active{transform:translateY(0)}@media(max-width:768px){.flight-comparison-modal{max-width:100%;max-height:95vh}.comparison-grid{padding:12px;grid-template-columns:80px repeat(auto-fit,1fr)!important}.grid-cell{padding:8px 6px;font-size:13px}.label-cell{font-size:11px}.comparison-airline-logo{width:24px;height:24px}.comparison-airline-name{font-size:11px}.btn-book-flight{font-size:12px;padding:8px 12px;max-width:none}}.multi-origin-results~.journii-bar-container,body:has(.multi-origin-results) .journii-bar-container{display:none!important}.multi-origin-results{display:block!important;max-width:1600px;margin:0 auto;padding:20px;min-height:100vh;background:var(--bg-primary, #f8fafc)}.multi-origin-header{display:block!important;width:100%!important;margin-bottom:12px;padding:12px 16px;background:linear-gradient(135deg,#fffffff2,#f9fafbf2);border:1px solid var(--border-subtle, #e2e8f0);border-radius:12px;box-shadow:0 2px 8px #00000008;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);grid-column:auto!important;flex:none!important}.btn-back-search{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--border-subtle, #d1d5db);border-radius:6px;color:var(--text-secondary, #6b7280);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-bottom:8px}.btn-back-search:hover{background:var(--bg-hover, #f3f4f6);color:var(--text-primary, #111827);border-color:var(--primary-blue, #3b82f6)}.header-content{display:flex;flex-direction:column;gap:4px}.header-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:var(--text-primary, #111827);margin:0}.header-title svg{color:var(--primary-blue, #3b82f6);width:18px;height:18px}.header-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;color:var(--text-secondary, #6b7280);font-size:13px}.meta-item{display:flex;align-items:center;gap:4px}.meta-item svg{width:14px;height:14px;color:var(--primary-blue, #3b82f6)}.meta-divider{color:var(--text-muted, #9ca3af)}.selection-summary{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding:12px 16px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:8px;border:1px solid var(--primary-blue, #3b82f6)}.summary-content{display:flex;align-items:center;gap:16px}.summary-count{font-size:13px;color:var(--text-secondary, #4b5563);font-weight:600}.btn-compare-flights{display:flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,var(--primary-blue, #3b82f6),#2563eb);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3b82f64d}.btn-compare-flights:hover{transform:translateY(-1px);box-shadow:0 4px 16px #3b82f666}.btn-compare-flights:active{transform:translateY(0)}.multi-origin-columns{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:20px;align-items:start;width:100%!important}.origin-column{background:#fff;border:1px solid var(--border-subtle, #e5e7eb);border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000a;display:flex;flex-direction:column;max-height:calc(100vh - 250px)}.origin-column-header{padding:12px 16px;background:linear-gradient(135deg,var(--primary-blue, #3b82f6),#2563eb);color:#fff;text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;gap:3px}.origin-header-top{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:4px;opacity:.9}.origin-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}.origin-city{font-size:26px;font-weight:700;margin:0;letter-spacing:-.5px;line-height:1;display:block;width:100%}.origin-code{font-size:13px;opacity:.85;font-weight:500;margin:0 0 8px;display:block;width:100%}.origin-cheapest{display:flex;flex-direction:column;align-items:center;gap:2px;padding-top:8px;border-top:1px solid rgb(255 255 255 / 20%)}.cheapest-label{font-size:10px;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.cheapest-price{font-size:22px;font-weight:800}.origin-flights-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;scrollbar-width:thin;scrollbar-color:rgb(59 130 246 / 30%) transparent}.origin-flights-list::-webkit-scrollbar{width:6px}.origin-flights-list::-webkit-scrollbar-track{background:transparent}.origin-flights-list::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:3px}.origin-flights-list::-webkit-scrollbar-thumb:hover{background:#3b82f67f}.origin-flight-wrapper{position:relative;transition:all .2s ease}.origin-flight-wrapper.selected{transform:scale(1.02)}.origin-flight-wrapper.selected:before{content:"";position:absolute;inset:-2px;border:2px solid var(--primary-blue, #3b82f6);border-radius:12px;pointer-events:none;z-index:1}.selected-indicator{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:12px;font-weight:600;border-radius:0 0 8px 8px;margin-top:-4px;position:relative;z-index:2}.origin-column-footer{padding:16px;border-top:1px solid var(--border-subtle, #e5e7eb);background:var(--bg-secondary, #f9fafb)}.btn-select-origin{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:#fff;border:2px solid var(--primary-blue, #3b82f6);border-radius:10px;color:var(--primary-blue, #3b82f6);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-select-origin:hover{background:var(--primary-blue, #3b82f6);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-select-origin.selected{background:linear-gradient(135deg,#10b981,#059669);border-color:#059669;color:#fff}.btn-select-origin:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.origin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-secondary, #6b7280)}.loading-spinner-small{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:var(--primary-blue, #3b82f6);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.origin-loading p{font-size:14px;margin:0}.origin-no-flights{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-muted, #9ca3af);background:var(--bg-secondary, #f9fafb);border-radius:12px;border:2px dashed var(--border-subtle, #e5e7eb)}.origin-no-flights svg{color:var(--text-muted, #d1d5db);margin-bottom:12px}.origin-no-flights p{font-size:14px;font-weight:600;color:var(--text-secondary, #6b7280);margin:0 0 4px}.origin-no-flights span{font-size:12px}.multi-origin-error,.multi-origin-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center;background:#fff;border-radius:16px;border:1px solid var(--border-subtle, #e5e7eb);box-shadow:0 4px 20px #0000000d}.multi-origin-error svg{color:#ef4444;margin-bottom:16px}.multi-origin-empty svg{color:var(--primary-blue, #3b82f6);margin-bottom:16px}.multi-origin-error h3,.multi-origin-empty h3{font-size:20px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 8px}.multi-origin-error p,.multi-origin-empty p{color:var(--text-secondary, #6b7280);margin:0 0 24px}.btn-back-error,.btn-back-empty{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--primary-blue, #3b82f6);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-back-error:hover,.btn-back-empty:hover{background:#2563eb;transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.skeleton-header{margin-bottom:24px}.skeleton-title{height:32px;width:60%;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;border-radius:8px;margin-bottom:12px;animation:shimmer 1.5s infinite}.skeleton-subtitle{height:16px;width:40%;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;border-radius:4px;animation:shimmer 1.5s infinite}.origin-column-skeleton{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000a}.skeleton-column-header{height:120px;background:linear-gradient(90deg,#e0e0e0 25%,#d0d0d0,#e0e0e0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.shimmer{background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.mobile-selection-bar{display:none;position:fixed;bottom:0;left:0;right:0;padding:16px 20px;background:#fff;border-top:1px solid var(--border-subtle, #e5e7eb);box-shadow:0 -4px 20px #0000001a;z-index:100;align-items:center;justify-content:space-between;gap:16px}.mobile-summary{display:flex;flex-direction:column;gap:2px}.mobile-summary span{font-size:14px;font-weight:600;color:var(--text-primary, #1e293b)}.btn-compare-mobile{display:flex;align-items:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--primary-blue, #3b82f6),#2563eb);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;white-space:nowrap}@media(max-width:1024px){.multi-origin-columns{grid-template-columns:repeat(2,1fr)}.multi-origin-columns>*:nth-child(3){grid-column:1 / -1}}@media(max-width:768px){.multi-origin-results{padding:12px 12px 100px}.multi-origin-header{padding:16px;margin-bottom:16px}.header-title{font-size:20px}.header-meta{font-size:12px;gap:8px}.selection-summary{flex-direction:column;gap:12px;text-align:center}.summary-content{flex-direction:column;gap:8px}.btn-compare-flights{width:100%;justify-content:center}.multi-origin-columns{grid-template-columns:1fr;gap:16px}.multi-origin-columns>*:nth-child(3){grid-column:auto}.origin-column{max-height:none}.origin-column-header{padding:16px}.origin-city{font-size:18px}.cheapest-price{font-size:24px}.mobile-selection-bar{display:flex}}@media(max-width:480px){.header-title{font-size:18px}.origin-column-header{padding:12px}.origin-city{font-size:16px}.origin-flights-list{padding:12px}}[data-theme=dark] .multi-origin-results{background:var(--bg-primary, #0f172a)}[data-theme=dark] .multi-origin-header{background:linear-gradient(135deg,#1e293bf2,#0f172af2);border-color:var(--border-subtle, #334155)}[data-theme=dark] .origin-column{background:var(--bg-secondary, #1e293b);border-color:var(--border-subtle, #334155)}[data-theme=dark] .origin-flights-list{scrollbar-color:rgb(59 130 246 / 50%) transparent}[data-theme=dark] .origin-column-footer{background:var(--bg-primary, #0f172a)}[data-theme=dark] .btn-select-origin{background:var(--bg-secondary, #1e293b);color:var(--primary-blue, #60a5fa)}[data-theme=dark] .btn-select-origin:hover{background:var(--primary-blue, #3b82f6);color:#fff}[data-theme=dark] .origin-no-flights{background:var(--bg-primary, #0f172a);border-color:var(--border-subtle, #334155)}[data-theme=dark] .multi-origin-error,[data-theme=dark] .multi-origin-empty,[data-theme=dark] .mobile-selection-bar{background:var(--bg-secondary, #1e293b);border-color:var(--border-subtle, #334155)}.flight-booking-integration{position:fixed!important;inset:0!important;background:#fff;z-index:9999!important;overflow-y:auto}.flight-booking-integration>*{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hotel-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);transition:var(--transition-smooth);display:flex;flex-direction:column;height:auto;max-height:100%;overflow:hidden;width:100%;max-width:100%}.hotel-card:hover{background:var(--glass-hover-bg);box-shadow:var(--glass-shadow-strong);transform:translateY(-4px);z-index:10}.hotel-card .hotel-image-container{position:relative;width:100%;height:140px;overflow:hidden;flex-shrink:0}.hotel-card .hotel-main-image{width:100%;height:100%;object-fit:cover}.hotel-card .hotel-badge{position:absolute;top:8px;left:8px;padding:3px 8px;border-radius:var(--radius-sm);font-size:.6rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgb(0 0 0 / 50%);z-index:5}.hotel-select-circle{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;background:#ffffffe5;border:2px solid #cbd5e1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.hotel-select-circle:hover{background:#fff;border-color:#3b82f6;transform:scale(1.05)}.hotel-select-circle.selected{background:#3b82f6;border-color:#3b82f6}.select-checkmark{color:#fff;font-size:16px;font-weight:700;line-height:1}.hotel-card .hotel-badge.best-cancellation{background-color:#10b981}.hotel-card .hotel-badge.pay-later{background-color:#3b82f6}.hotel-card .hotel-badge.best-value{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b66;animation:pulse-glow 2s ease-in-out infinite;font-weight:700;letter-spacing:.3px}@keyframes pulse-glow{0%,to{box-shadow:0 2px 8px #f59e0b66}50%{box-shadow:0 2px 12px #f59e0b99}}.hotel-card .hotel-badge.best-eco{background-color:#059669}.hotel-card .hotel-fav-btn{position:absolute;top:10px;right:10px;width:36px;height:36px;background:#fffffff2;border:1px solid rgb(0 0 0 / 10%);border-radius:50%;box-shadow:0 2px 8px #0003;z-index:5;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth);color:var(--text-main)}.hotel-card .hotel-fav-btn:hover{background:var(--glass-accent-bg);border-color:var(--glass-accent-border);color:#ef4444;transform:scale(1.1)}.hotel-card .hotel-info-section{padding:8px 10px;border-bottom:1px solid var(--glass-border);flex-shrink:0;background:var(--glass-bg-subtle)}.hotel-card .hotel-name{font-size:.9rem;font-weight:700;color:var(--text-main);margin:0 0 3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hotel-card .hotel-location{display:flex;align-items:center;gap:3px;font-size:.75rem;color:var(--text-muted);margin-bottom:4px}.hotel-card .hotel-rating-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.hotel-card .hotel-stars{display:flex;gap:1px}.hotel-card .hotel-review-score{display:flex;align-items:center;gap:4px;font-size:.75rem}.hotel-card .hotel-description{font-size:.8rem;color:var(--text-secondary);line-height:1.4;margin:6px 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hotel-card .score{font-weight:700;color:var(--text-main)}.hotel-card .reviews{color:var(--text-muted)}.hotel-card .hotel-amenities{display:flex;flex-wrap:wrap;gap:6px;align-items:flex-start;margin-top:8px;min-height:52px;max-height:52px;overflow:hidden}.hotel-card .amenity-item{display:flex;align-items:center;gap:4px;font-size:.6rem;color:var(--text-secondary);padding:3px 6px;background:var(--glass-bg-subtle);border:1px solid var(--glass-border);border-radius:var(--radius-sm)}.hotel-card .amenity-item svg{color:var(--primary-blue)}.hotel-card .more-amenities{font-size:.7rem;color:var(--primary-blue);font-weight:600}.hotel-card .room-types-section{padding:6px 8px 8px;background:var(--glass-bg-subtle);border-bottom:1px solid var(--glass-border);flex-shrink:0}.hotel-card .room-types-title{font-size:.75rem;font-weight:600;color:var(--text-main);margin:0 0 4px}.hotel-card .room-carousel-container{position:relative;height:130px;display:flex;align-items:center}.hotel-card .room-types-scroll{display:flex;gap:10px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;padding:2px;width:100%;justify-content:center}.hotel-card .room-types-scroll::-webkit-scrollbar{display:none}.hotel-card .room-option{min-width:110px;flex-shrink:0;background:var(--glass-bg);border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--glass-border);transition:var(--transition-smooth);cursor:pointer}.hotel-card .room-option:hover{background:var(--glass-bg-strong);box-shadow:var(--glass-shadow);transform:translateY(-2px) scale(1.02)}.hotel-card .room-image{width:100%;height:85px;object-fit:cover}.hotel-card .room-details{padding:4px;display:flex;flex-direction:column;gap:1px}.hotel-card .room-type-name{font-size:.7rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hotel-card .room-meal{font-size:.65rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:1px 0}.hotel-card .room-price{font-size:.75rem;font-weight:600;color:#fff;background:#0009;padding:2px 6px;border-radius:4px}.hotel-card .room-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);background:#fff;border:1px solid var(--border-subtle);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;box-shadow:0 2px 8px #00000026;transition:all .2s}.hotel-card .room-scroll-btn:hover{background-color:var(--primary-blue);color:#fff}.hotel-card .room-scroll-btn.left,.hotel-card .room-scroll-btn-left{left:-5px}.hotel-card .room-scroll-btn.right,.hotel-card .room-scroll-btn-right{right:-5px}.hotel-card .hotel-card-footer{padding:6px 8px 8px;flex-shrink:0;background:var(--glass-bg-subtle);border-top:1px solid var(--glass-border);margin-top:auto}.hotel-card .hotel-pricing{margin-bottom:6px}.hotel-card .price-info{display:flex;flex-direction:column;gap:2px}.hotel-card .price-label{font-size:.7rem;color:var(--text-muted)}.hotel-card .price-range{font-size:1rem;font-weight:700;color:#fff;background:#000000a6;padding:4px 10px;border-radius:6px;text-shadow:0 1px 2px rgb(0 0 0 / 50%)}.hotel-card .price-per-room{font-size:.7rem;color:var(--text-secondary);font-style:italic;margin-top:2px}.hotel-card .excluded-taxes-notice{margin-top:8px;padding:6px 8px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm)}.hotel-card .excluded-taxes-label{display:block;font-size:.65rem;font-weight:600;color:#dc2626;margin-bottom:4px}.hotel-card .excluded-tax-item{display:flex;justify-content:space-between;align-items:center;font-size:.65rem;color:#991b1b;padding:2px 0}.hotel-card .tax-name{text-transform:capitalize;color:#991b1b}.hotel-card .tax-amount{font-weight:600;color:#dc2626}.hotel-card .hotel-actions{display:flex;gap:6px}.hotel-card .hotel-actions>button{flex:1 1 0%;display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 8px;border-radius:var(--radius-sm);font-weight:600;font-size:.65rem;cursor:pointer;transition:var(--transition-smooth);box-sizing:border-box}.hotel-card .btn-view-details{background:var(--glass-bg-subtle);border:1.5px solid var(--border-subtle);color:var(--text-secondary)}.hotel-card .btn-view-details:hover{background:var(--glass-bg);border-color:var(--primary-blue);color:var(--primary-blue);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.hotel-card .btn-add-planner{background:var(--glass-bg);border:1.5px solid var(--primary-blue);color:var(--primary-blue)}.hotel-card .btn-add-planner:hover{color:var(--text-secondary);border-color:var(--border-subtle);background:var(--glass-bg-subtle);transform:translateY(-1px)}.hotel-card .btn-add-primary{background:var(--primary-blue);border:1.5px solid var(--primary-blue);color:#fff;box-shadow:var(--shadow-glow-subtle)}.hotel-card .btn-add-primary:hover{background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-glow-blue)}@media(max-width:768px),(hover:none)and (pointer:coarse){.hotel-card .hotel-fav-btn,.hotel-card .hotel-select-circle,.hotel-card .room-scroll-btn{width:44px;height:44px;min-width:44px;min-height:44px}.hotel-card .hotel-actions>button{min-height:44px;padding:10px 12px}}.hotel-card .hotel-image-container:after{content:"";position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(to top,rgb(0 0 0 / 70%) 0%,rgb(0 0 0 / 30%) 50%,transparent 100%);pointer-events:none}.hotel-card .hotel-image-container .text-on-dark,.hotel-card .hotel-image-container h3,.hotel-card .hotel-image-container h4,.hotel-card .hotel-image-container .price-display{color:#fff;text-shadow:0 1px 3px rgb(0 0 0 / 60%)}.hotel-card .hotel-select-circle{background:#fffffff2;border:2px solid #3b82f6;box-shadow:0 2px 8px #00000040;z-index:5}.welcome-message{text-align:center;margin:0 0 24px;display:flex;flex-direction:column;align-items:center;gap:16px}.welcome-logo{width:180px;height:180px;margin-bottom:0;animation:logoFadeIn .6s ease-out}.welcome-logo .logo-image{width:100%;height:100%;object-fit:contain}@keyframes logoFadeIn{0%{opacity:0;transform:scale(.8) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.welcome-text{font-size:3rem;font-weight:700;color:var(--primary-blue);margin:0;letter-spacing:-.02em;line-height:1.2;animation:fadeIn .5s ease-out;-webkit-text-stroke:5px white;paint-order:stroke fill}.welcome-text-long{font-size:2.6rem;letter-spacing:-.015em}.typing-cursor{display:inline-block;margin-left:4px;animation:blink 1s step-end infinite;color:var(--primary-blue)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}[data-theme=dark] .welcome-text{-webkit-text-stroke:5px #1e3a8a}.welcome-social-links{margin-top:24px;opacity:.7;transition:opacity .3s ease;animation:fadeIn .8s ease-out .3s both}.welcome-social-links:hover{opacity:1}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.welcome-logo{width:140px;height:140px}.welcome-text{font-size:2.5rem}.welcome-text-long{font-size:2rem}}@media(max-width:480px){.welcome-logo{width:120px;height:120px}.welcome-text{font-size:2rem}.welcome-text-long{font-size:1.6rem}}.voice-input{display:flex;align-items:center;gap:8px;position:relative}.voice-button{width:40px;height:40px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#6b7280}.voice-button:hover:not(:disabled){background:#f3f4f6;border-color:#667eea;color:#667eea}.voice-button:disabled{opacity:.5;cursor:not-allowed}.voice-button.listening{background:#ef4444;border-color:#dc2626;color:#fff;animation:pulse 1.5s infinite}.voice-button.speaking{background:#10b981;border-color:#059669;color:#fff;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.voice-transcript{position:absolute;bottom:50px;left:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #0000001a;max-width:300px;z-index:10}.transcript-text{font-size:14px;color:#374151;line-height:1.5}.voice-error{position:absolute;bottom:50px;left:0;background:#fee2e2;border:1px solid #dc2626;border-radius:8px;padding:8px 12px;font-size:12px;color:#991b1b;max-width:250px;z-index:10}.processing-status-message{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;margin:12px 0;color:#fff;box-shadow:0 4px 12px #667eea4d;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 4px 12px #667eea4d}50%{box-shadow:0 4px 20px #667eea7f}}.processing-status-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.processing-icon{flex-shrink:0;width:40px;height:40px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center}.processing-content{flex:1 1 0%}.processing-title{font-size:15px;font-weight:600;margin-bottom:8px;opacity:.95}.processing-step{display:flex;align-items:center;gap:8px;font-size:13px;opacity:.85}.processing-step svg{flex-shrink:0}.processing-progress-container{display:flex;align-items:center;gap:12px;margin-top:12px}.processing-progress-bar{flex:1 1 0%;height:8px;background:#fff3;border-radius:4px;overflow:hidden}.processing-progress-fill{height:100%;background:linear-gradient(90deg,#fff,#fffc);border-radius:4px;transition:width .3s ease;box-shadow:0 0 10px #ffffff7f}.processing-progress-text{font-size:13px;font-weight:600;min-width:40px;text-align:right;opacity:.9}.processing-estimate{margin-top:12px;font-size:12px;opacity:.75;text-align:center;font-style:italic}.animate-spin{animation:spin 1s linear infinite}.bucket-list-result-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000001a;margin:16px 0;max-width:600px}.result-card-header{position:relative;height:240px;overflow:hidden}.result-card-image{width:100%;height:100%;object-fit:cover}.result-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgb(0 0 0 / 80%),transparent);padding:20px;display:flex;justify-content:space-between;align-items:flex-end}.result-card-title-section{flex:1 1 0%}.result-card-title{color:#fff;font-size:24px;font-weight:700;margin:0 0 4px}.result-card-country{color:#ffffffe5;font-size:14px;display:flex;align-items:center;gap:4px;margin:0}.confidence-badge{background:#4caf50e5;color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.result-card-description{padding:16px 20px;border-bottom:1px solid #f0f0f0}.result-card-description p{margin:0;color:#555;font-size:14px;line-height:1.6;transition:max-height .3s ease}.result-card-description p.collapsed{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.result-card-description p.expanded{display:block}.read-more-btn{background:none;border:none;color:var(--primary-blue, #667eea);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;margin-top:8px;padding:4px 0;transition:all .2s}.read-more-btn:hover{color:var(--primary-purple, #764ba2);transform:translate(2px)}[data-theme=dark] .result-card-description p{color:var(--text-main, #e0e0e0)}.travel-times-section{padding:16px 20px;background:#f8f9fa;border-bottom:1px solid #f0f0f0}.travel-time-item{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:13px}.travel-time-item svg{color:#667eea;flex-shrink:0}.time-label{color:#666;flex:1 1 0%}.time-value{font-weight:600;color:#333}.travel-time-item.total{margin-top:4px;padding-top:10px;border-top:1px solid #e0e0e0;font-weight:600}.cost-breakdown-section{padding:16px 20px;border-bottom:1px solid #f0f0f0}.section-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;margin:0 0 12px;color:#333}.section-title svg{color:#667eea}.cost-items{display:flex;flex-direction:column;gap:8px}.cost-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 0}.cost-item svg{color:#667eea;flex-shrink:0}.cost-item span:nth-child(2){flex:1 1 0%;color:#666}.cost-value{font-weight:600;color:#333}.cost-item.total{margin-top:8px;padding-top:12px;border-top:2px solid #667eea;font-size:14px}.total-label{font-weight:700;color:#333}.total-value{font-size:16px;color:#667eea}.tags-section{border-top:1px solid var(--border-subtle)}.tags-header{padding:10px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.tags-header:hover{background:var(--bg-hover)}.tags-header-content{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-main)}.tags-header-content svg{color:var(--primary-blue)}.tags-count{background:var(--primary-blue);color:#fff;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.tags-header svg:last-child{color:var(--text-muted);transition:transform .2s}.tags-list{display:flex;flex-wrap:wrap;gap:8px;padding:0 20px;max-height:0;overflow:hidden;transition:all .3s ease}.tags-list.expanded{max-height:500px;padding:0 20px 12px}.tags-list.collapsed{max-height:0;padding:0 20px}.tag{background:#e3f2fd;color:#1976d2;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}[data-theme=dark] .tag{background:#1976d233;color:#64b5f6}.result-card-actions{padding:16px 20px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.action-btn.details{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.details:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.action-btn.add-to-planner{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.action-btn.add-to-planner:hover{transform:translateY(-2px);box-shadow:0 4px 12px #38ef7d66}.action-btn.book-now{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.action-btn.book-now:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f5576c66}[data-theme=dark] .action-btn.details{background:linear-gradient(135deg,#667eea,#764ba2)}[data-theme=dark] .action-btn.add-to-planner{background:linear-gradient(135deg,#11998e,#38ef7d)}[data-theme=dark] .action-btn.book-now{background:linear-gradient(135deg,#f093fb,#f5576c)}.itinerary-preview-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;margin:16px 0;color:#fff;box-shadow:0 8px 24px #667eea40;transition:transform .2s ease,box-shadow .2s ease}.itinerary-preview-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px #667eea59}.itinerary-preview-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.itinerary-preview-icon{background:#fff3;border-radius:12px;padding:12px;display:flex;align-items:center;justify-content:center}.itinerary-preview-title-section{flex:1 1 0%}.itinerary-preview-title{font-size:20px;font-weight:600;margin:0 0 8px;color:#fff}.itinerary-preview-subtitle{display:flex;align-items:center;gap:6px;font-size:14px;color:#ffffffe5;margin:0}.itinerary-preview-details{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.itinerary-preview-detail{display:flex;align-items:center;gap:8px;font-size:14px;color:#fffffff2}.itinerary-preview-detail svg{flex-shrink:0}.itinerary-preview-description{font-size:14px;line-height:1.6;color:#ffffffe5;margin:0 0 16px;padding:12px;background:#ffffff1a;border-radius:8px}.itinerary-preview-actions{display:flex;gap:12px;margin-top:16px}.itinerary-preview-btn{flex:1 1 0%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.itinerary-preview-btn.primary{background:#fff;color:#667eea}.itinerary-preview-btn.primary:hover{background:#fffffff2;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.itinerary-preview-btn.secondary{background:#fff3;color:#fff;border:1px solid rgb(255 255 255 / 30%)}.itinerary-preview-btn.secondary:hover{background:#ffffff4d;border-color:#ffffff7f}.itinerary-preview-btn svg{flex-shrink:0}@media(max-width:768px){.itinerary-preview-card{padding:16px}.itinerary-preview-title{font-size:18px}.itinerary-preview-actions{flex-direction:column}.itinerary-preview-btn{width:100%}}.suggestions-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-bottom:24px;position:relative;z-index:1}.suggestions-card.compact{box-shadow:0 1px 3px #0000001a}.suggestions-header{display:flex;align-items:center;gap:8px;padding:16px 20px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.suggestions-header h3{flex:1 1 0%;margin:0;font-size:16px;font-weight:600}.suggestions-count{background:#ffffff4d;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.suggestions-loading{display:flex;align-items:center;justify-content:center;padding:40px}.suggestions-loading .spinner{width:32px;height:32px;border:3px solid #f3f4f6;border-top-color:#f5576c;border-radius:50%;animation:spin 1s linear infinite}.suggestions-list{display:flex;flex-direction:column}.suggestion-item{position:relative;display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:all .2s}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#fef3f2}.dismiss-btn{position:absolute;top:8px;right:8px;background:transparent;border:none;padding:4px;cursor:pointer;color:#9ca3af;border-radius:4px;transition:all .2s;opacity:0}.suggestion-item:hover .dismiss-btn{opacity:1}.dismiss-btn:hover{background:#fee2e2;color:#ef4444}.suggestion-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:10px;color:#fff}.suggestion-content{flex:1 1 0%;display:flex;flex-direction:column;gap:4px}.suggestion-text{margin:0;font-size:14px;color:#111827;font-weight:500;line-height:1.4}.suggestion-date{display:flex;align-items:center;gap:4px;font-size:12px;color:#f5576c;font-weight:500}.suggestion-date svg{color:#f5576c}.suggestion-arrow{flex-shrink:0;color:#d1d5db;transition:all .2s}.suggestion-item:hover .suggestion-arrow{color:#f5576c;transform:translate(4px)}.suggestions-footer{padding:12px 20px;background:#f9fafb;border-top:1px solid #f3f4f6}.view-all-btn{width:100%;padding:8px;background:transparent;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.view-all-btn:hover{background:#fff;border-color:#f5576c;color:#f5576c}.chat-interface{flex:1 1 0%;display:flex;flex-direction:column;height:100%;position:relative;background-color:transparent;transition:all .3s ease;overflow:hidden}.chat-scroll-area{flex:1 1 0%;min-height:0;overflow-y:auto;padding:var(--spacing-xl) var(--spacing-md);padding-bottom:100px;display:flex;align-items:center;justify-content:center;scroll-behavior:smooth}.chat-interface.chat-mode .chat-scroll-area{align-items:flex-start;justify-content:flex-start}.chat-scroll-area::-webkit-scrollbar{width:8px}.chat-scroll-area::-webkit-scrollbar-track{background:transparent}.chat-scroll-area::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}.chat-scroll-area::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.empty-state-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:0;width:100%;max-width:900px;height:100%;min-height:auto;padding:90px 1rem 2rem;animation:fadeIn .5s ease-out}.home-social-media{position:absolute;top:20px;right:20px;z-index:10;opacity:.7;transition:opacity .3s ease}.home-social-media:hover{opacity:1}@media(max-width:767px){.home-social-media{display:none}}.chat-interface.home-screen{overflow:hidden}.chat-interface.home-screen .chat-scroll-area{overflow-y:hidden;align-items:center;justify-content:center;padding-bottom:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-visual{width:100%;display:flex;justify-content:center}.welcome-message{width:100%;text-align:center}.empty-state-container>.recent-search-carousel{width:100%;max-width:1200px}.hero-icon-placeholder{font-size:2rem}.hero-title{font-size:2rem;font-weight:700;color:var(--primary-blue);letter-spacing:-1px}.hero-logo-img{max-width:500px;width:100%;height:auto;margin-bottom:-120px;object-fit:contain;margin-top:-100px;transition:var(--transition-smooth)}.hero-logo-img:hover{opacity:.9}.hero-subtitle{color:var(--text-secondary);font-size:1.1rem;max-width:600px}.suggestions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);width:100%;margin-top:var(--spacing-lg)}.suggestion-card{height:180px;background-color:#e2e8f0;border-radius:var(--radius-lg);background-size:cover;background-position:center;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-md);cursor:pointer;transition:var(--transition-smooth);box-shadow:var(--shadow-sm),0 0 0 var(--glow-blue)}.suggestion-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-card-hover),var(--shadow-glow-subtle)}.card-content{color:#fff;z-index:2}.card-content h3{font-size:1rem;font-weight:600;margin-bottom:4px}.card-content p{font-size:.85rem;opacity:.9}.quick-actions-row{display:flex;gap:var(--spacing-lg);margin-top:var(--spacing-md);justify-content:center}.quick-action-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-sm);font-weight:500;font-size:.8rem;background-color:#e6f2ff;color:var(--primary-blue);border:1px solid transparent;transition:var(--transition-fast);box-shadow:var(--shadow-sm)}.quick-action-btn:before{content:"(";margin-right:-2px}.quick-action-btn:after{content:")";margin-left:-2px}.quick-action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-button-hover);background-color:#dbeafe}.quick-action-btn.secondary{background-color:#fff;color:var(--text-main);border:1px solid var(--border-subtle)}.quick-action-btn.secondary:hover{border-color:var(--primary-blue);color:var(--primary-blue)}.input-section-wrapper{padding:var(--spacing-md);background:transparent;width:100%}.footer-text{text-align:center;font-size:.75rem;color:var(--text-muted);margin-top:var(--spacing-md)}.search-results-container{max-width:800px;width:100%;display:flex;flex-direction:column;gap:var(--spacing-lg);padding-bottom:var(--spacing-xl)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid rgb(255 255 255 / 20%);background:var(--bg-primary, #fff)}[data-theme=dark] .chat-header{background:var(--bg-primary, #1f2937);border-bottom:1px solid var(--border-color, #374151)}.chat-header-right{display:flex;align-items:center;gap:var(--spacing-md)}.chat-title{font-size:1.1rem;font-weight:600;color:var(--text-main);margin:0}.chat-menu-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s}.chat-menu-btn:hover{background:var(--bg-hover);color:var(--text-main)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-conversation-view{display:flex;flex-direction:column;gap:var(--spacing-lg);width:100%;max-width:100%;padding:var(--spacing-lg);animation:fadeIn .3s ease-out}.chat-message{display:flex;flex-direction:column;margin-bottom:16px;width:100%}.chat-message.user-message{align-items:flex-end}.chat-message.ai-message{align-items:flex-start}.chat-message:last-child{margin-bottom:0}.user-bubble{padding:12px 18px;background:var(--primary-blue);border:1px solid rgb(255 255 255 / 15%);color:#fff;border-radius:18px 18px 4px;max-width:fit-content;align-self:flex-end;box-shadow:0 4px 16px #00000040;margin-bottom:8px;transition:all .3s ease;animation:messagePop .3s cubic-bezier(.175,.885,.32,1.275)}.user-bubble:hover{background:var(--primary-blue-hover);box-shadow:0 6px 20px #00000059}.user-bubble p{margin:0;font-size:.95rem;line-height:1.5;font-weight:500}.user-image-preview{display:block;max-width:300px;max-height:200px;width:auto;height:auto;margin-top:8px;border-radius:12px;object-fit:cover;box-shadow:0 2px 8px #00000026;transition:transform .2s ease}.user-image-preview:hover{transform:scale(1.02);cursor:pointer}.user-video-indicator{margin-top:8px;padding:6px 12px;background:#ffffff1a;border-radius:8px;font-size:.85rem;display:inline-block}.ai-response{max-width:75%;align-self:flex-start;padding:14px 18px;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:18px 18px 18px 4px;box-shadow:0 4px 12px #0000000f;margin-bottom:8px;transition:all .3s ease;overflow:hidden;animation:messagePop .3s cubic-bezier(.175,.885,.32,1.275);color:var(--text-main, #1f2937);line-height:1.7}.ai-response:hover{background:var(--bg-page);box-shadow:0 6px 16px #00000014}.ai-response-content{color:var(--text-main, #1f2937);line-height:1.7;transition:color .3s ease}@media(prefers-color-scheme:dark){.user-bubble{background:#323232b3;border:1px solid rgb(255 255 255 / 20%);color:#fff;box-shadow:0 4px 16px #0006}.user-bubble:hover{background:#3c3c3ccc;box-shadow:0 6px 20px #0000007f}.ai-response{background:#1f2937cc;border:1px solid rgb(255 255 255 / 15%);box-shadow:0 4px 12px #0000004d;color:#f9fafb}.ai-response:hover{background:#1f2937e5;box-shadow:0 6px 16px #0006}.ai-response-content,.ai-response-content p,.ai-response-content strong,.ai-response-content span{color:#f9fafb}}@media(prefers-color-scheme:light){.ai-response{background:#fff;border:1px solid #e5e7eb;box-shadow:0 4px 12px #00000014;color:#1f2937}.ai-response:hover{background:#fafafa;box-shadow:0 6px 16px #0000001a}.ai-response-content{color:#1f2937}.ai-response-content p,.ai-response-content span,.ai-response-content li{color:#374151}.ai-response-content strong,.ai-response-content h1,.ai-response-content h2,.ai-response-content h3{color:#111827}}.ai-intro{margin:0 0 var(--spacing-md) 0;font-size:.95rem}.ai-section{margin-bottom:var(--spacing-md)}.ai-section-title{font-size:.95rem;font-weight:600;color:var(--text-main);margin:0 0 var(--spacing-sm) 0}.ai-section-list{margin:0;padding-left:20px;font-size:.9rem}.ai-section-list li{margin-bottom:4px;color:var(--text-secondary)}.ai-suggestions{margin-top:var(--spacing-lg)}.suggestions-label{font-size:.85rem;color:var(--text-muted, #9ca3af);margin:0 0 var(--spacing-sm) 0;font-weight:500}.suggestion-chips{display:flex;flex-direction:column;gap:var(--spacing-xs)}.suggestion-chip{padding:10px 16px;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:10px;font-size:.9rem;color:var(--text-main, #1f2937);cursor:pointer;text-align:left;transition:all .2s ease;font-weight:500}.suggestion-chip:hover{background:#3b82f61a;border-color:#3b82f64d;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f61a}@media(prefers-color-scheme:dark){.suggestion-chip{background:#1f29377f;border:1px solid rgb(255 255 255 / 10%);color:var(--text-main-dark, #f9fafb)}.suggestion-chip:hover{background:#6366f126;border-color:#6366f14d;box-shadow:0 4px 8px #6366f126}}.journii-chat-bar{position:fixed;bottom:0;left:0;right:0;background:transparent;padding:16px 24px;z-index:50;pointer-events:none}.journii-chat-container{max-width:1400px;width:80%;margin:0 auto;display:flex;align-items:center;gap:12px;background:var(--glass-bg-strong);border:1px solid var(--glass-border);border-radius:28px;padding:10px 20px;transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:auto;box-shadow:var(--glass-shadow);min-height:52px}.journii-chat-container:focus-within{border-color:var(--primary-blue);box-shadow:var(--shadow-glow-subtle, 0 0 0 3px rgb(74 158 255 / 20%));background:var(--surface-white)}[data-theme=dark] .journii-chat-container{background:var(--glass-bg-strong);border-color:var(--glass-border)}[data-theme=dark] .journii-chat-container:focus-within{background:#ffffff0d;border-color:var(--primary-blue)}.journii-chat-icon{display:flex;align-items:center;justify-content:center;color:var(--primary-blue);flex-shrink:0}.journii-chat-input{flex:1 1 0%;border:none;outline:none;background:transparent;font-size:.95rem;color:var(--text-main);resize:none;font-family:inherit;line-height:1.6;max-height:120px;overflow-y:auto;padding:0;min-height:24px}.journii-chat-input::placeholder{color:var(--text-muted);opacity:1;transition:opacity .3s ease-in-out}.journii-chat-input::-webkit-scrollbar{width:4px}.journii-chat-input::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}.journii-chat-send{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-page);color:var(--text-muted);cursor:pointer;transition:all .2s;flex-shrink:0}.journii-chat-send.voice-mode{background:transparent;border:2px solid var(--primary-blue);color:var(--primary-blue)}.journii-chat-send.voice-mode:hover:not(:disabled){background:var(--primary-blue);color:#fff;transform:scale(1.05)}.journii-chat-send.active{background:var(--primary-blue);color:#fff;border:none}.journii-chat-send.active:hover:not(:disabled){background:var(--primary-blue-hover);transform:scale(1.05)}.journii-chat-send:disabled{cursor:not-allowed;opacity:.5}.section-title{font-size:1.25rem;font-weight:700;color:var(--text-main);margin-top:var(--spacing-md)}.results-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.more-flights-btn-row{display:flex;justify-content:center;margin-top:var(--spacing-md)}.more-flights-btn{color:var(--primary-blue);font-weight:600;display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:var(--radius-sm);transition:background .2s}.more-flights-btn:hover{background-color:#e6f2ff}.airline-logo{background-color:transparent}.chat-interface.split-view{flex-direction:row;overflow:hidden}.chat-content-column{flex:1 1 0%;display:flex;flex-direction:column;height:100%;min-width:0;min-height:0;position:relative;z-index:10;background-color:transparent;box-shadow:2px 0 10px #0000000d}.map-column{flex:1 1 0%;height:100%;min-height:0;background-color:#e2e8f0;position:relative}.map-placeholder{width:100%;height:100%;position:relative;background-color:#e2e8f0}.map-overlay-btn{position:absolute;top:20px;right:20px;background-color:var(--primary-blue);color:#fff;padding:8px 16px;border-radius:var(--radius-sm);font-weight:600;box-shadow:var(--shadow-md);cursor:pointer;z-index:20}.top-search-container{background:var(--surface-white);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--border-subtle);z-index:50}.input-section-stack{display:flex;flex-direction:column;align-items:center;width:100%;max-width:800px;margin-top:0}.fixed-bottom{margin-top:auto;border-top:1px solid var(--border-subtle)}@media(max-width:767px){.chat-scroll-area{padding:var(--spacing-md)}.empty-state-container{gap:0;padding:0 1rem 2rem}.hero-logo-img{max-width:280px;margin-bottom:-60px;margin-top:-50px}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.95rem;padding:0 var(--spacing-sm)}.suggestions-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.suggestion-card{height:140px}.card-content h3{font-size:.9rem}.card-content p{font-size:.75rem}.quick-actions-row{flex-wrap:wrap;justify-content:center}.quick-action-btn{padding:8px 14px;font-size:.85rem}.chat-interface.split-view{flex-direction:column}.map-column{height:200px;flex:none}.message-bubble,.user-bubble{max-width:fit-content;padding:var(--spacing-md)}.section-title{font-size:1.1rem}}@media(max-width:767px){.chat-scroll-area{padding:var(--spacing-md) var(--spacing-sm)}.chat-scroll-area::-webkit-scrollbar{width:0;display:none}.empty-state-container{padding:0 1rem 2rem;gap:0;min-height:auto}.hero-logo-img{max-width:280px;margin-bottom:-60px;margin-top:-50px}.hero-title{font-size:var(--font-size-hero);letter-spacing:-.5px}.hero-subtitle{font-size:var(--font-size-base)}.suggestions-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.suggestion-card{height:140px;padding:var(--spacing-sm)}.top-search-container,.chat-conversation-view{padding:var(--spacing-sm)}.message-bubble,.user-bubble{max-width:fit-content;font-size:var(--font-size-sm)}.ai-response{max-width:85%;font-size:var(--font-size-sm)}.message-bubble,.user-bubble,.ai-response{padding:12px 16px;border-radius:16px}}@media(min-width:768px)and (max-width:1023px){.chat-scroll-area{padding:var(--spacing-lg) var(--spacing-md)}.empty-state-container{padding:0 2rem 2rem;gap:0}.hero-logo-img{max-width:400px;margin-bottom:-90px;margin-top:-75px}.suggestions-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.suggestion-card{height:160px}.message-bubble,.user-bubble{max-width:fit-content}.ai-response{max-width:80%}}@media(min-width:1024px){.chat-scroll-area{padding:var(--spacing-xl) var(--spacing-lg)}.empty-state-container{padding:0 2rem 2rem;gap:0}.suggestions-grid{grid-template-columns:repeat(3,1fr)}.message-bubble,.user-bubble{max-width:fit-content}.ai-response{max-width:75%}}@media(min-width:1280px){.empty-state-container{max-width:1100px}.hero-logo-img{max-width:550px}}@media(hover:none)and (pointer:coarse){.suggestion-card{min-height:160px}.quick-action-btn{min-height:var(--touch-target-min);padding:8px 16px}.suggestion-card:hover,.hero-logo-img:hover{transform:none;filter:drop-shadow(0 0 30px var(--glow-blue))}}.journii-thinking{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:var(--surface-elevated);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.thinking-dots{display:flex;gap:.4rem;align-items:center}.thinking-dots span{width:8px;height:8px;background:var(--primary-blue);border-radius:50%;animation:thinkingBounce 1.4s infinite ease-in-out}.thinking-dots span:nth-child(1){animation-delay:-.32s}.thinking-dots span:nth-child(2){animation-delay:-.16s}.thinking-text{margin:0;font-size:.9rem;color:var(--text-muted);font-style:italic}@keyframes thinkingBounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.search-results-in-chat{display:flex;flex-direction:column;gap:1rem;width:100%}.search-results-in-chat .ai-response{padding:0;background:transparent;border:none}.search-results-in-chat .results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;width:100%}.see-all-btn{align-self:center;width:100%;padding:var(--spacing-md);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease}.see-all-btn:hover{transform:translateY(-2px);background:var(--glass-bg-strong);box-shadow:var(--shadow-glow-subtle)}.see-all-btn:active{transform:translateY(0)}[data-theme=dark] .see-all-btn{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d}[data-theme=dark] .see-all-btn:hover{box-shadow:0 6px 20px #667eea66}.results-message{width:100%}@media(prefers-reduced-motion:reduce){.empty-state-container,.suggestion-card,.message-bubble,.user-bubble,.ai-response{animation:none;transition:none}.thinking-dots span{animation:none;opacity:.7}}.inline-results-container{margin:var(--spacing-lg) 0;width:100%;max-width:100%;overflow:visible;align-self:flex-start}.inline-results-grid{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-md);width:100%;max-width:100%}.experience-card-inline{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--spacing-md);transition:all .3s ease}.experience-card-inline:hover{background:var(--glass-bg-strong);transform:translateY(-4px);box-shadow:var(--shadow-glow-subtle)}.experience-card-inline h4{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.experience-card-inline .price{font-size:1.25rem;font-weight:700;color:var(--accent-primary);margin-bottom:var(--spacing-xs)}.experience-card-inline .duration,.experience-card-inline .rating{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--spacing-xs)}@keyframes messagePop{0%{opacity:0;transform:scale(.8) translateY(10px)}50%{transform:scale(1.02) translateY(-2px)}to{opacity:1;transform:scale(1) translateY(0)}}.user-message-container{display:flex;flex-direction:column;align-items:flex-end;max-width:80%}.message-status{display:flex;align-items:center;gap:6px;margin-top:4px;padding-right:4px}.message-status .status-icon{display:flex;align-items:center;justify-content:center}.message-status .status-icon.sending svg{animation:spin 1s linear infinite}.message-status .status-text{font-size:.75rem;line-height:1}.message-status .timestamp{color:var(--text-muted);font-size:.75rem}.retry-button{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:500;color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;border-radius:9999px;cursor:pointer;transition:all .2s ease}.retry-button:hover{background-color:#fee2e2;border-color:#f87171}.retry-button:active{transform:scale(.95)}.retry-button svg{width:10px;height:10px}.offline-banner{position:sticky;top:0;z-index:50;background-color:#fffbeb;border-bottom:1px solid #fcd34d;padding:12px 16px}.offline-banner .offline-icon svg{width:20px;height:20px;color:#d97706}.offline-banner .offline-content p{color:#92400e;font-size:.875rem;font-weight:500;margin:0}.offline-banner .offline-indicator{width:8px;height:8px;background-color:#f59e0b;border-radius:50%;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}[data-theme=dark] .offline-banner{background-color:#451a03;border-bottom-color:#78350f}[data-theme=dark] .offline-banner .offline-icon svg{color:#fbbf24}[data-theme=dark] .offline-banner .offline-content p{color:#fde68a}@media(prefers-color-scheme:dark){.offline-banner{background-color:#451a03;border-bottom-color:#78350f}.offline-banner .offline-icon svg{color:#fbbf24}.offline-banner .offline-content p{color:#fde68a}.offline-banner .offline-indicator{background-color:#fbbf24}}.message-status-container{display:flex;justify-content:flex-end;margin-top:2px;padding-right:8px}@media(max-width:767px){.user-message-container{max-width:90%}.offline-banner{padding:10px 12px}.offline-banner .offline-content p{font-size:.8rem}.message-status{gap:4px}.message-status .status-text{font-size:.7rem}}.chat-history-section{margin-bottom:var(--spacing-sm)}.chat-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease;-webkit-user-select:none;user-select:none}.chat-section-header:hover{background:var(--bg-secondary)}.section-left{display:flex;align-items:center;gap:8px;color:var(--text-secondary)}.section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.section-count{font-size:.75rem;color:var(--text-tertiary);background:var(--bg-secondary);padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.chat-section-items{display:flex;flex-direction:column;gap:2px;padding-left:8px;margin-top:4px}.chat-history-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;position:relative;color:var(--text-main)}.chat-history-item:hover{background:var(--bg-secondary)}.chat-history-item.active{background:#3b82f61a;color:var(--primary-blue)}.chat-history-item.active .chat-icon{color:var(--primary-blue)}.chat-icon{flex-shrink:0;color:var(--text-secondary)}.chat-title{flex:1 1 0%;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-menu-container{position:relative;flex-shrink:0}.chat-menu-btn{display:none;padding:4px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.chat-history-item:hover .chat-menu-btn{display:flex;align-items:center;justify-content:center}.chat-menu-btn:hover{background:var(--bg-tertiary);color:var(--text-main)}.chat-context-menu{position:absolute;right:0;top:100%;margin-top:4px;background:var(--surface-white, #fff);border:1px solid var(--border-subtle, #e5e7eb);border-radius:var(--radius-md);box-shadow:0 4px 20px #0003;z-index:9999;min-width:160px;padding:4px}.chat-context-menu .menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;color:var(--text-main);transition:all .2s ease;text-align:left}.chat-context-menu .menu-item:hover{background:var(--bg-secondary)}.chat-context-menu .menu-item.danger{color:#dc2626}.chat-context-menu .menu-item.danger:hover{background:#ef44441a}[data-theme=dark] .chat-context-menu{background:var(--surface-dark, #1f1f1f);border-color:var(--border-subtle, #3a3a3a);box-shadow:0 4px 20px #0000007f}.secondary-sidebar{width:280px;background:var(--surface-white);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;height:100%;padding:var(--spacing-md);padding-bottom:100px;flex-shrink:0;font-family:inherit;overflow:hidden auto}[data-theme=dark] .secondary-sidebar{background:var(--surface-dark);border-right:1px solid var(--border-subtle)}[data-theme=dark] .sec-title-compact{color:#ffffffb3}[data-theme=dark] .sec-header-compact{border-bottom-color:#ffffff1a}.secondary-sidebar::-webkit-scrollbar{width:6px}.secondary-sidebar::-webkit-scrollbar-track{background:transparent}.secondary-sidebar::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}.secondary-sidebar::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.sec-header{margin-bottom:var(--spacing-md)}.sec-header-compact{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-subtle)}.sec-title-compact{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.app-title-row{display:flex;align-items:center;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-md)}.app-icon-blue{width:32px;height:32px;background-color:var(--primary-blue);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.app-name{font-size:1.25rem;font-weight:600;flex:1 1 0%}.collapse-btn-small{width:24px;height:24px;border:1px solid var(--border-subtle);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;background:transparent;transition:all .2s}.collapse-btn-small:hover{background-color:var(--bg-page);color:var(--text-main)}.sec-actions{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.new-chat-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-main);font-size:.9rem;background:transparent;transition:background .2s;cursor:pointer;position:relative;z-index:10;pointer-events:auto}.new-chat-btn:hover{background-color:var(--bg-page)}[data-theme=dark] .new-chat-btn{border-color:#fff3;color:#ffffffe5}[data-theme=dark] .new-chat-btn:hover{background-color:#ffffff1a}.sec-search-input{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:var(--surface-white);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-muted)}.sec-search-input input{border:none;outline:none;background:transparent;width:100%;font-size:.9rem;color:var(--text-main)}.history-section{flex:1 1 0%;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-lg)}.history-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.history-title{font-size:.7rem;color:var(--text-muted);font-weight:600;letter-spacing:.5px;margin-bottom:var(--spacing-sm);padding-left:12px}.history-title-separator{font-size:.7rem;color:var(--text-muted);font-weight:500;padding:var(--spacing-xs) 12px;margin-bottom:var(--spacing-xs);position:relative}.history-list{display:flex;flex-direction:column;gap:2px}.history-item{font-size:.85rem;color:var(--text-secondary);padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:8px;position:relative}.history-item .drag-handle{opacity:0;transition:opacity .2s;flex-shrink:0}.history-item:hover .drag-handle{opacity:1}.history-item.dragging{background:var(--glass-accent-bg);border-color:var(--primary-blue);box-shadow:0 4px 12px #3b82f64d;transform:rotate(2deg)}.history-item span{flex:1 1 0%;min-width:0;overflow:hidden;text-overflow:ellipsis}.chat-options{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.option-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:all .2s}.option-btn:hover{background:var(--bg-page);color:var(--text-main)}.history-item:hover{background-color:var(--bg-page);color:var(--text-main)}.history-item.active{background-color:#f1f5f9;color:var(--text-main);font-weight:500}.archived-section{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border-subtle)}.archived-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;font-size:.85rem}.archived-header:hover{background-color:var(--bg-page)}.archived-left{display:flex;align-items:center;gap:8px;color:var(--text-secondary)}.archived-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-page);padding:2px 6px;border-radius:10px}.archived-list{padding-left:12px;margin-top:4px}.archived-item{opacity:.7}.pinned-section{margin-top:auto;padding-top:var(--spacing-md);border-top:1px solid var(--border-subtle)}.planner-pins-list{display:flex;flex-direction:column;gap:4px}.pinned-trip-folder{display:flex;flex-direction:column}.pinned-trip-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;font-size:.85rem}.pinned-trip-header:hover{background-color:var(--bg-page)}.pinned-trip-header.active{background-color:var(--primary-blue-light)}.pinned-trip-left{display:flex;align-items:center;gap:6px;flex:1 1 0%;min-width:0}.drag-handle{color:var(--text-muted);cursor:grab;flex-shrink:0}.drag-handle:active{cursor:grabbing}.pinned-trip-name{font-weight:500;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-trip-count{font-size:.75rem;color:var(--text-muted);background:var(--bg-page);padding:2px 6px;border-radius:10px;flex-shrink:0}.pinned-trip-sections{padding-left:20px;display:flex;flex-direction:column;gap:2px}.pinned-section-item{display:flex;flex-direction:column}.pinned-section-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .2s;font-size:.8rem}.pinned-section-header:hover{background-color:var(--bg-page)}.pinned-section-left{display:flex;align-items:center;gap:6px;flex:1 1 0%;min-width:0}.pinned-section-name{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-section-count{font-size:.7rem;color:var(--text-muted);background:var(--bg-page);padding:1px 5px;border-radius:8px;flex-shrink:0}.pinned-section-items{padding-left:16px;display:flex;flex-direction:column;gap:2px}.pinned-item{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--radius-sm);cursor:grab;transition:background .2s,opacity .2s;font-size:.75rem}.pinned-item:active{cursor:grabbing;opacity:.6}.pinned-item:hover{background-color:var(--bg-page)}.pinned-item-text{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 0%}.planner-section-compact{margin-top:auto;padding:.75rem;border-top:1px solid var(--border-subtle);background:var(--bg-secondary, #f8f9fa)}.planner-section-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.planner-section-header .trip-count{margin-left:auto;background:var(--border-subtle);color:var(--text-secondary);padding:1px 6px;border-radius:10px;font-size:.65rem;font-weight:600}.planner-trips-list{display:flex;flex-direction:column;gap:2px;margin-bottom:.5rem;max-height:120px;overflow-y:auto}.planner-trip-item{display:flex;align-items:center;gap:.4rem;padding:4px 8px;border-radius:var(--radius-sm, 4px);cursor:pointer;font-size:.8rem;color:var(--text-secondary);transition:all .15s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planner-trip-item:hover{background:var(--bg-page);color:var(--text-main)}.planner-trip-item.active{background:var(--primary-blue-light, rgb(59 130 246 / 10%));color:var(--primary-blue);font-weight:500}.planner-trip-item .pin-icon{color:var(--primary-blue);flex-shrink:0}.planner-trip-item .trip-name{flex:1;overflow:hidden;text-overflow:ellipsis}.more-trips-indicator{font-size:.7rem;color:var(--text-muted);text-align:center;padding:2px;font-style:italic}.new-trip-btn-compact{display:flex;align-items:center;justify-content:center;gap:.4rem;width:100%;padding:6px 10px;background:transparent;border:1px dashed var(--border-subtle);border-radius:var(--radius-sm, 4px);color:var(--text-muted);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s ease}.new-trip-btn-compact:hover{background:var(--bg-page);border-color:var(--primary-blue);color:var(--primary-blue)}.new-trip-btn-compact:active{transform:scale(.98)}[data-theme=dark] .planner-section-compact{background:var(--surface-dark, #1a1a1a)}[data-theme=dark] .planner-trip-item:hover{background:#ffffff0d}[data-theme=dark] .new-trip-btn-compact{border-color:#fff3;color:#ffffff7f}[data-theme=dark] .new-trip-btn-compact:hover{border-color:var(--primary-blue);color:var(--primary-blue);background:#ffffff0d}.secondary-sidebar-collapsed{width:50px;height:-webkit-fill-available;background-color:var(--surface-white);border-right:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.secondary-sidebar-collapsed:hover{background-color:var(--bg-page)}.itinerary-header{background:#fffffff2;padding:16px 32px 12px;box-shadow:0 2px 8px #0000000d;position:fixed;top:0;left:0;right:0;width:100%;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:12px}.header-text h1{font-size:1.25rem;font-weight:600;color:var(--text-main);margin:0 0 2px}.header-text p{color:var(--text-muted);font-size:.8rem;margin:0}.header-actions{display:flex;gap:12px}.create-blank-btn,.create-ai-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease}.create-blank-btn{background:#fff;color:var(--text-main);border:1px solid var(--border-subtle)}.create-blank-btn:hover{background:#f8f9fa;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.create-ai-btn{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.create-ai-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #007bff66}.filter-tabs{display:flex;gap:8px;margin:0;padding:0}.filter-tab{padding:6px 16px;border-radius:99px;font-size:.9rem;font-weight:500;background:transparent;color:var(--text-secondary);border:none;cursor:pointer;transition:var(--transition-fast)}.filter-tab:hover{color:var(--text-main);background:var(--glass-bg-subtle)}.filter-tab.active{background-color:var(--primary-blue);color:#fff}[data-theme=dark] .itinerary-header{background:#1a1f2ef2;box-shadow:0 2px 8px #0000004d}[data-theme=dark] .create-blank-btn{background:var(--surface-dark);color:var(--text-main);border-color:var(--border-subtle)}[data-theme=dark] .create-blank-btn:hover{background:var(--surface-hover)}.time-picker-trigger{display:flex;align-items:center;justify-content:flex-start;gap:8px;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:100%;box-sizing:border-box}.time-picker-trigger:hover{border-color:var(--primary-blue)}.time-picker-trigger svg{color:var(--text-tertiary);flex-shrink:0}.time-picker-trigger span{flex:1 1 0%;font-size:14px;color:var(--text-primary)}.time-picker-trigger span.placeholder{color:var(--text-tertiary)}.time-picker-dropdown{background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:0 8px 24px #0000001f;overflow:hidden;min-width:240px}.time-picker-dropdown--portal{z-index:var(--z-dropdown)}.time-picker-content{padding:16px}.time-columns{display:flex;gap:8px}.time-column{flex:1 1 0%;display:flex;flex-direction:column}.time-scroll{max-height:180px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:8px;background:var(--surface-subtle)}.time-scroll::-webkit-scrollbar{width:4px}.time-scroll::-webkit-scrollbar-track{background:transparent}.time-scroll::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}.time-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.time-option{padding:8px 12px;text-align:center;font-size:14px;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.time-option:hover{background:var(--surface-hover)}.time-option.selected{background:var(--primary-blue);color:#fff;font-weight:600}.time-picker-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.time-apply-btn{width:100%;padding:8px 16px;background:var(--primary-blue);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.time-apply-btn:hover{background:#0052cc;transform:translateY(-1px)}.time-apply-btn:active{transform:translateY(0)}[data-theme=dark] .time-picker-trigger,[data-theme=dark] .time-picker-dropdown{background:var(--surface-dark)}[data-theme=dark] .time-scroll{background:var(--surface-subtle-dark)}.duration-picker-trigger{display:flex;align-items:center;justify-content:flex-start;gap:8px;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:100%;box-sizing:border-box}.duration-picker-trigger:hover{border-color:var(--primary-blue)}.duration-picker-trigger svg{color:var(--text-tertiary);flex-shrink:0}.duration-picker-trigger span{flex:1 1 0%;font-size:14px;color:var(--text-primary)}.duration-picker-trigger span.placeholder{color:var(--text-tertiary)}.duration-picker-dropdown{background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:0 8px 24px #0000001f;overflow:hidden;min-width:200px}.duration-picker-dropdown--portal{z-index:var(--z-dropdown)}.duration-picker-content{padding:16px}.duration-columns{display:flex;gap:8px}.duration-column{flex:1 1 0%;display:flex;flex-direction:column}.column-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;text-align:center}.duration-scroll{max-height:180px;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:8px;background:var(--surface-subtle)}.duration-scroll::-webkit-scrollbar{width:4px}.duration-scroll::-webkit-scrollbar-track{background:transparent}.duration-scroll::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:4px}.duration-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.duration-option{padding:8px 12px;text-align:center;font-size:14px;color:var(--text-primary);cursor:pointer;transition:all .15s ease}.duration-option:hover{background:var(--surface-hover)}.duration-option.selected{background:var(--primary-blue);color:#fff;font-weight:600}.duration-picker-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.duration-apply-btn{width:100%;padding:8px 16px;background:var(--primary-blue);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.duration-apply-btn:hover{background:#0052cc;transform:translateY(-1px)}.duration-apply-btn:active{transform:translateY(0)}[data-theme=dark] .duration-picker-trigger,[data-theme=dark] .duration-picker-dropdown{background:var(--surface-dark)}[data-theme=dark] .duration-scroll{background:var(--surface-subtle-dark)}.activity-editor{background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:8px;padding:16px;margin-bottom:12px}.activity-editor-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.title-input-wrapper{flex:1 1 0%;display:flex;flex-direction:column;gap:4px}.activity-title-input{width:100%;padding:10px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);color:var(--text-primary);font-size:15px;font-weight:500;transition:border-color .2s ease}.activity-title-input:focus{outline:none;border-color:var(--primary-blue)}.activity-title-input::placeholder{color:var(--text-tertiary)}.activity-title-input.error{border-color:#ef4444}.remove-btn{padding:10px;background:transparent;border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.remove-btn:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}.activity-editor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}.input-group{display:flex;align-items:stretch;gap:8px;min-height:38px}.input-group:has(input){padding:8px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);transition:border-color .2s ease}.input-group:has(input):focus-within{border-color:var(--primary-blue)}.input-group:has(.time-picker-trigger),.input-group:has(.duration-picker-trigger){padding:0;border:none;background:transparent}.input-group .time-picker-trigger,.input-group .duration-picker-trigger{width:100%;min-height:38px}.input-group.location-autocomplete{padding:0;border:none;background:transparent}.input-group.location-autocomplete .location-autocomplete-wrapper{width:100%}.input-group.location-autocomplete .input-with-icon{border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);transition:border-color .2s ease;padding:8px 12px}.input-group.location-autocomplete .input-with-icon:focus-within{border-color:var(--primary-blue)}.input-group.location-autocomplete .location-input{border:none;background:transparent;padding:0 0 0 8px}.input-group svg{color:var(--text-tertiary);flex-shrink:0}.input-group input{flex:1 1 0%;border:none;background:transparent;color:var(--text-primary);font-size:14px;outline:none}.input-group input::placeholder{color:var(--text-tertiary)}.input-group.full-width{grid-column:1 / -1}.activity-notes textarea{width:100%;padding:10px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);color:var(--text-primary);font-family:inherit;font-size:14px;resize:vertical;transition:border-color .2s ease}.activity-notes textarea:focus{outline:none;border-color:var(--primary-blue)}.activity-notes textarea::placeholder{color:var(--text-tertiary)}[data-theme=dark] .activity-editor,[data-theme=dark] .activity-title-input,[data-theme=dark] .input-group,[data-theme=dark] .activity-notes textarea{background:var(--surface-dark)}[data-theme=dark] .remove-btn:hover{background:#ef44441a}.accommodation-editor{background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:8px;padding:16px;margin-bottom:12px}.accommodation-editor-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.name-input-wrapper{flex:1 1 0%;display:flex;flex-direction:column;gap:4px}.accommodation-name-input{width:100%;padding:10px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);color:var(--text-primary);font-size:15px;font-weight:500;transition:border-color .2s ease}.accommodation-name-input:focus{outline:none;border-color:var(--primary-blue)}.accommodation-name-input::placeholder{color:var(--text-tertiary)}.accommodation-name-input.error{border-color:#ef4444}.accommodation-editor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.time-input-wrapper{display:flex;flex-direction:column;gap:4px;flex:1 1 0%}.time-input-wrapper label{font-size:11px;color:var(--text-tertiary);font-weight:500}.time-input-wrapper input{border:none;background:transparent;color:var(--text-primary);font-size:14px;outline:none}[data-theme=dark] .accommodation-editor,[data-theme=dark] .accommodation-name-input,[data-theme=dark] .input-group{background:var(--surface-dark)}.transportation-editor{background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:8px;padding:16px;margin-bottom:12px}.transportation-editor-header{display:flex;gap:12px;margin-bottom:12px}.mode-selector{flex:1 1 0%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);transition:border-color .2s ease}.mode-selector:focus-within{border-color:var(--primary-blue)}.mode-selector svg{color:var(--text-tertiary);flex-shrink:0}.mode-selector select{flex:1 1 0%;border:none;background:transparent;color:var(--text-primary);font-size:15px;font-weight:500;outline:none;cursor:pointer}.transportation-editor-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.input-group{display:flex;align-items:flex-start;gap:8px}.input-with-error{flex:1 1 0%;display:flex;flex-direction:column;gap:4px}.input-group input{flex:1 1 0%;padding:10px 12px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-white);color:var(--text-primary);font-size:14px;transition:border-color .2s ease}.input-group input:focus{outline:none;border-color:var(--primary-blue)}.input-group input.error{border-color:#ef4444}.error-message{font-size:.75rem;color:#ef4444;margin-top:2px}[data-theme=dark] .transportation-editor,[data-theme=dark] .mode-selector,[data-theme=dark] .input-group{background:var(--surface-dark)}.day-editor{background:var(--surface-white);border-radius:12px;padding:20px;margin-bottom:16px;border:1px solid var(--border-subtle)}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}.day-title-section{display:flex;align-items:center;gap:12px}.day-title-section svg{color:var(--primary-blue)}.day-title-section h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.day-date{margin:4px 0 0;font-size:14px;color:var(--text-secondary)}.day-header-actions{display:flex;align-items:center;gap:12px}.day-budget{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.day-budget svg{color:var(--primary-blue)}.day-budget .spent{font-weight:600;color:var(--text-primary)}.delete-day-btn{display:flex;align-items:center;justify-content:center;padding:8px;background:transparent;border:1px solid var(--border-subtle);border-radius:6px;color:#ef4444;cursor:pointer;transition:all .2s ease}.delete-day-btn:hover{background:#fef2f2;border-color:#ef4444;transform:scale(1.05)}.delete-day-btn:active{transform:scale(.95)}.time-section{margin-bottom:12px}.section-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:8px;cursor:pointer;transition:all .2s ease}.section-header:hover{background:var(--surface-hover)}.section-title{display:flex;align-items:center;gap:10px;font-weight:500;color:var(--text-primary)}.activity-count{font-size:12px;color:var(--text-secondary);font-weight:400;margin-left:8px}.section-content{padding:12px 16px;overflow:hidden}.activity-actions{display:flex;gap:8px;margin-top:8px}.add-activity-btn,.ai-suggest-btn,.find-travelle-btn{flex:1 1 0%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:1px dashed var(--border-subtle);border-radius:6px;color:var(--primary-blue);font-size:14px;cursor:pointer;transition:all .2s ease}.add-activity-btn:hover{background:var(--surface-subtle);border-color:var(--primary-blue)}.find-travelle-btn{border-style:solid;background:linear-gradient(135deg,#10b9811a,#3b82f61a);border-color:#10b9814d;color:#10b981}.find-travelle-btn:hover{background:linear-gradient(135deg,#10b98133,#3b82f633);border-color:#10b981}.ai-suggest-btn{border-style:solid;background:linear-gradient(135deg,#8b5cf61a,#3b82f61a);border-color:#8b5cf64d;color:#8b5cf6}.ai-suggest-btn:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf633,#3b82f633);border-color:#8b5cf6}.ai-suggest-btn:disabled{opacity:.6;cursor:not-allowed}.day-notes-section{margin-top:16px}.day-notes-section label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.day-notes-section textarea{width:100%;padding:12px;border:1px solid var(--border-subtle);border-radius:8px;background:var(--surface-white);color:var(--text-primary);font-family:inherit;font-size:14px;resize:vertical;transition:border-color .2s ease}.day-notes-section textarea:focus{outline:none;border-color:var(--primary-blue)}.day-notes-section textarea::placeholder{color:var(--text-tertiary)}[data-theme=dark] .day-editor{background:var(--surface-dark)}[data-theme=dark] .section-header{background:var(--surface-subtle-dark)}[data-theme=dark] .section-header:hover{background:var(--surface-hover-dark)}[data-theme=dark] .day-notes-section textarea{background:var(--surface-dark)}.expanded-itinerary-card{overflow:hidden;border-top:1px solid var(--border-subtle);margin-top:16px;background:var(--surface-white);border-radius:12px}.expanded-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--surface-white);border-bottom:1px solid var(--border-subtle);border-radius:12px 12px 0 0}.expanded-header h3{font-size:1rem;font-weight:600;color:var(--text-main)}.header-actions{display:flex;align-items:center;gap:12px}.save-status{font-size:.75rem;font-weight:500;padding:4px 8px;border-radius:4px}.save-status.saving{color:var(--primary-blue);background:#1e3a8a1a}.save-status.saved{color:#10b981;background:#10b9811a}.save-status.error{color:#ef4444;background:#ef44441a}.close-expanded-btn{background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:6px;color:var(--text-secondary);transition:var(--transition-fast);display:flex;align-items:center;justify-content:center}.close-expanded-btn:hover{background:var(--surface-hover);color:var(--text-main)}.days-container{display:flex;flex-direction:column;gap:0;padding:20px 24px;background:var(--surface-white)}.loading-days,.no-days{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary)}.loading-days .spinner{animation:spin 1s linear infinite;color:var(--primary-blue);margin-bottom:16px}.no-days p{font-size:15px;color:var(--text-tertiary)}.add-day-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;max-width:200px;margin:20px auto;padding:12px 24px;background:linear-gradient(135deg,var(--primary-blue) 0%,#0056b3 100%);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #007bff33}.add-day-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #007bff4d}.add-day-btn:active{transform:translateY(0)}[data-theme=dark] .add-day-btn{background:linear-gradient(135deg,#3b82f6,#2563eb)}@media(max-width:767px){.expanded-header{padding:12px 16px}.expanded-header h3{font-size:.9rem}.days-container{padding:12px 16px}}.itinerary-builder-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:1000}.itinerary-builder-modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:600px;width:90%;max-height:90vh;display:flex;flex-direction:column}.builder-step{display:flex;flex-direction:column;max-height:90vh;overflow-y:auto}.builder-step.completion-step{overflow:visible;max-height:none}.builder-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid var(--border-subtle)}.builder-header h2{font-size:1.5rem;font-weight:700;color:var(--text-main)}.close-builder-btn{background:transparent;border:none;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);transition:var(--transition-fast)}.close-builder-btn:hover{background:#f1f5f9;color:var(--text-main)}.builder-content{padding:32px;display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.9rem;font-weight:600;color:var(--text-main)}.date-input-wrapper,.traveler-input-wrapper{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:#fff;cursor:pointer;transition:var(--transition-fast)}.date-input-wrapper:hover,.traveler-input-wrapper:hover{border-color:var(--primary-blue);box-shadow:0 0 0 3px #007bff1a}.date-input-wrapper span,.traveler-input-wrapper span{font-size:.9rem;color:var(--text-main)}.builder-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px 32px;border-top:1px solid var(--border-subtle)}.btn-primary{background:var(--primary-blue);color:#fff;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:8px;transition:var(--transition-fast);border:none}.btn-primary:hover:not(:disabled){background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-button-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#fff;border:1px solid var(--border-subtle);color:var(--text-secondary);padding:10px 20px;border-radius:var(--radius-sm);font-weight:500;font-size:.9rem;transition:var(--transition-fast)}.btn-secondary:hover{background:#f1f5f9;color:var(--text-main)}.building-step{min-height:500px;display:flex;align-items:center;justify-content:center}.building-animation{padding:48px 32px;text-align:center;width:100%}.building-animation h2{font-size:1.3rem;font-weight:600;color:var(--text-main);margin-bottom:24px}.progress-indicator{width:100%;height:4px;background:#e5e7eb;border-radius:99px;overflow:hidden;margin-bottom:32px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-blue),#667eea);transition:width .5s ease}.building-steps{display:flex;flex-direction:column;gap:12px;align-items:flex-start;max-width:400px;margin:0 auto}.building-step-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f5f7fa;border-radius:var(--radius-sm);width:100%}.step-icon{display:flex;align-items:center;justify-content:center}.building-step-item span{font-size:.9rem;color:var(--text-main);font-weight:500}.completion-step .builder-header{flex-direction:column;align-items:center;gap:16px;padding:32px}.success-icon{width:64px;height:64px;border-radius:50%;background:#dcfce7;color:#22c55e;display:flex;align-items:center;justify-content:center;animation:successPulse .5s ease-out}@keyframes successPulse{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.itinerary-preview{padding:32px;min-height:300px}.preview-image-wrapper{width:100%;height:200px;border-radius:var(--radius-md);overflow:hidden;margin-bottom:20px}.preview-image{width:100%;height:100%;object-fit:cover}.itinerary-preview h3{font-size:1.3rem;font-weight:700;color:var(--text-main);margin-bottom:16px}.preview-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.preview-meta span{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary);font-weight:500}.preview-summary{display:flex;flex-direction:column;gap:10px;padding:20px;background:#f0f9ff;border-radius:var(--radius-md);border-left:4px solid var(--primary-blue)}.preview-summary p{font-size:.9rem;color:var(--text-main);margin:0;font-weight:500}.preview-days{display:flex;flex-direction:column;gap:8px;padding:16px;background:#f5f7fa;border-radius:var(--radius-sm)}.preview-day{font-size:.9rem;color:var(--text-main)}.preview-day strong{color:var(--primary-blue)}.builder-footer.three-buttons{display:flex;gap:12px}.builder-footer.three-buttons .btn-secondary{flex:0 0 auto}.builder-footer.three-buttons .btn-outline,.builder-footer.three-buttons .btn-primary{flex:1 1 0%}.builder-footer.two-buttons{display:flex;gap:12px}.builder-footer.two-buttons .btn-secondary{flex:0 0 auto}.builder-footer.two-buttons .btn-primary{flex:1 1 0%}.btn-outline{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:2px solid var(--primary-blue);background:#fff;color:var(--primary-blue);border-radius:var(--radius-md);font-weight:600;font-size:.95rem;transition:var(--transition-fast)}.btn-outline:hover{background:#f0f9ff}.details-step{display:flex;flex-direction:column;max-height:90vh}.details-header{display:flex;align-items:center;gap:16px;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.details-header h2{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0}.back-btn{display:flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;padding:8px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.back-btn:hover{background:#f1f5f9;color:var(--text-main)}.details-content{flex:1 1 0%;overflow-y:auto;padding:20px 24px}.details-overview{display:flex;gap:20px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-subtle)}.details-hero-image{width:180px;height:120px;object-fit:cover;border-radius:var(--radius-md)}.details-info{display:flex;flex-direction:column;gap:12px;justify-content:center}.info-item{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-secondary);font-weight:500}.info-item svg{color:var(--primary-blue)}.details-days{display:flex;flex-direction:column;gap:16px}.details-day-card{background:#f8fafc;border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.day-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#fff;border-bottom:1px solid var(--border-subtle)}.day-card-header h4{font-size:.95rem;font-weight:700;color:var(--text-main);margin:0}.day-card-meta{display:flex;align-items:center;gap:12px}.weather-badge{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--text-secondary);font-weight:500}.cost-badge{font-size:.75rem;padding:4px 10px;border-radius:99px;background:#eff6ff;color:var(--primary-blue);font-weight:600}.day-activities-compact{padding:8px 0}.activity-row{display:flex;align-items:center;padding:10px 16px;gap:16px;border-bottom:1px solid #e8ebef}.activity-row:last-child{border-bottom:none}.activity-row .activity-time{font-size:.8rem;font-weight:600;color:var(--text-muted);min-width:70px}.activity-row .activity-title{flex:1 1 0%;font-size:.85rem;font-weight:500;color:var(--text-main)}.activity-row .activity-cost{font-size:.8rem;font-weight:600;color:var(--text-secondary);min-width:60px;text-align:right}@media(max-width:767px){.itinerary-builder-modal{width:100%;max-width:100%;max-height:-webkit-fill-available;border-radius:0;margin:0}.builder-header{padding:16px 20px}.builder-header h2{font-size:1.2rem}.builder-content{padding:20px;gap:20px}.form-group label{font-size:.85rem}.form-input,.form-textarea,.form-select{font-size:.9rem;padding:10px 12px}.builder-footer{padding:16px 20px;gap:10px}.builder-footer.three-buttons{flex-direction:column}.builder-footer.three-buttons .btn-outline,.builder-footer.three-buttons .btn-primary,.builder-footer.three-buttons .btn-secondary{width:100%}.builder-footer.two-buttons{flex-direction:column-reverse}.builder-footer.two-buttons .btn-secondary,.builder-footer.two-buttons .btn-primary{width:100%}.btn-primary,.btn-secondary,.btn-outline{padding:12px 20px;font-size:.9rem}.building-animation{padding:32px 20px}.building-animation h2{font-size:1.1rem}.building-steps{max-width:100%}.building-step-item{padding:10px 14px}.building-step-item span{font-size:.85rem}.completion-step .builder-header{padding:24px 20px}.success-icon{width:56px;height:56px}.day-card{margin-bottom:12px}.day-card-header{padding:12px 14px;flex-wrap:wrap;gap:8px}.day-card-header h4{font-size:.9rem;width:100%}.day-card-meta{gap:8px;width:100%}.weather-badge,.cost-badge{font-size:.75rem}.activity-row{padding:10px 14px;gap:10px}.activity-row .activity-icon{width:32px;height:32px}.activity-row .activity-title{font-size:.8rem}.activity-row .activity-cost{font-size:.75rem;min-width:50px}}.date-picker-overlay.in-modal{position:fixed;z-index:1100}.date-picker-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #00000040;padding:24px;width:360px;border:1px solid rgb(0 0 0 / 5%);font-family:Inter,sans-serif}.date-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:0 8px}.month-year-label{font-weight:600;font-size:1.05rem;color:#1e293b;font-family:Outfit,sans-serif;flex:1 1 0%;text-align:center}.nav-btn{background:transparent;border:none;color:#64748b;cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.nav-btn:hover{background:#f1f5f9;color:#1e3a8a}.days-header{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:12px;text-align:center}.days-header span{font-size:.85rem;font-weight:600;color:#94a3b8}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px 0}.calendar-day-wrapper{position:relative;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-bottom:2px}.calendar-day-wrapper.empty{cursor:default}.calendar-day-wrapper.disabled{cursor:not-allowed;opacity:.4}.day-number{position:relative;z-index:2;font-size:.95rem;font-weight:500;color:#334155;pointer-events:none;transition:color .2s}.day-number.disabled-text{color:#cbd5e1;text-decoration:line-through}.selected-text{color:#fff;font-weight:600}.selection-circle{position:absolute;top:4px;left:50%;transform:translate(-50%);width:36px;height:36px;background-color:#1e3a8a;border-radius:50%;z-index:1;box-shadow:0 4px 12px #1e3a8a4d}[data-theme=dark] .date-picker-card{background:var(--surface-white);border:1px solid var(--border-subtle);box-shadow:var(--shadow-xl)}[data-theme=dark] .month-year-label{color:var(--text-main)}[data-theme=dark] .nav-btn{color:var(--text-secondary)}[data-theme=dark] .nav-btn:hover{background:var(--button-bg-hover);color:var(--primary-blue)}[data-theme=dark] .days-header span{color:var(--text-secondary)}[data-theme=dark] .day-number{color:var(--text-main)}[data-theme=dark] .selected-text{color:#fff}[data-theme=dark] .selection-circle{background-color:var(--primary-blue);box-shadow:0 4px 12px var(--glow-blue)}.modal-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.edit-itinerary-modal{background:var(--surface-white);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.modal-close-btn{background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.modal-body{padding:20px;overflow:visible}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid var(--border-subtle, #e5e7eb);border-radius:8px;font-size:14px;background:var(--surface-white);color:var(--text-main);transition:all .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #4a9eff1a}.form-group input::placeholder{color:var(--text-muted)}.form-group input:-webkit-autofill,.form-group input:-webkit-autofill:hover,.form-group input:-webkit-autofill:focus{box-shadow:0 0 0 1000px var(--surface-white) inset;-webkit-text-fill-color:var(--text-main);border:1px solid var(--border-subtle, #e5e7eb)}.location-input-wrapper,.date-input-wrapper{position:relative}.date-input-wrapper input{cursor:pointer}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding-top:16px;border-top:1px solid var(--border-color);margin-top:16px}.btn-secondary,.btn-primary{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;border:none}.btn-secondary{background:var(--button-bg-hover, #f3f4f6);color:var(--text-secondary)}.btn-secondary:hover{background:var(--button-bg-active, #e5e7eb)}.btn-primary{background:var(--primary-blue);color:#fff}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.itinerary-list-container{min-height:-webkit-fill-available;overflow-y:auto;background:transparent;padding-top:var(--header-height, 120px);scrollbar-width:thin;scrollbar-color:transparent transparent}.itinerary-list-container::-webkit-scrollbar{width:6px}.itinerary-list-container::-webkit-scrollbar-track{background:transparent}.itinerary-list-container::-webkit-scrollbar-thumb{background:transparent;border-radius:10px;transition:background .3s ease}.itinerary-list-container:hover::-webkit-scrollbar-thumb{background:var(--primary-blue)}.itinerary-list-container::-webkit-scrollbar-thumb:hover{background:#1e3a8a}.itinerary-list-container:hover{scrollbar-color:var(--primary-blue) transparent}.itinerary-card-wrapper{background:transparent;border-radius:16px;overflow:visible;transition:all .3s ease;margin:0 auto 20px;max-width:1380px;width:calc(100% - 55px)}.itinerary-card-wrapper:first-of-type{margin-top:24px}.itinerary-card-wrapper:hover,.itinerary-card-wrapper.expanded,.itinerary-card-wrapper.expanded:hover{transform:none}.itinerary-card{display:flex;background:var(--surface-white);border:none;border-radius:16px;box-shadow:0 4px 20px #0000001a;overflow:hidden;height:180px;transition:all .3s ease}.itinerary-card:hover{transform:none;box-shadow:none}.itin-image-wrapper{width:240px;height:100%;flex-shrink:0;position:relative;cursor:pointer;overflow:hidden}.itin-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.itin-image-wrapper:hover .itin-image{transform:scale(1.05)}.image-overlay{position:absolute;inset:0;background:#0009;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff;opacity:0;transition:opacity .3s ease}.itin-image-wrapper:hover .image-overlay{opacity:1}.image-overlay span{font-size:.85rem;font-weight:500}.itin-content{flex:1 1 0%;padding:20px 24px;display:flex;flex-direction:column;position:relative}.itin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.itin-title{font-size:1.1rem;font-weight:700;color:var(--text-main);margin-bottom:8px;cursor:text;-webkit-user-select:text;user-select:text}.itin-title:hover{color:var(--primary-blue)}.itin-date{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem;margin-bottom:12px}.itin-date span{cursor:pointer;transition:color .2s}.itin-date span:hover{color:var(--primary-blue);text-decoration:underline}.itin-meta-row{display:flex;align-items:center;gap:16px}.itin-meta-item{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.85rem;font-weight:500}.itin-meta-item.clickable{cursor:pointer;transition:color .2s}.itin-meta-item.clickable:hover{color:var(--primary-blue)}.itin-header-right{display:flex;align-items:center;gap:12px}.status-dropdown-wrapper{position:relative}.status-badge{font-size:.7rem;padding:4px 10px 4px 12px;border-radius:99px;font-weight:600;text-transform:capitalize;display:flex;align-items:center;gap:4px;cursor:pointer;border:none;transition:all .2s ease}.status-badge:hover{transform:scale(1.05)}.status-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;overflow:hidden;z-index:10;min-width:120px}.status-option{display:block;width:100%;padding:8px 16px;border:none;background:#fff;color:var(--text-main);font-size:.85rem;text-align:left;cursor:pointer;transition:background .2s ease}.status-option:hover{background:#f8f9fa}.delete-itin-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .2s}.delete-itin-btn:hover{background:#ef44441a;color:#ef4444}.status-badge.upcoming{background-color:var(--glass-accent-bg);color:var(--primary-blue)}.status-badge.completed{background-color:var(--glass-bg-subtle);color:var(--text-secondary)}.status-badge.draft{background-color:var(--warning-bg, #fef9c3);color:var(--warning-text, #b45309)}.status-badge.booked{background-color:#dcfce7;color:#15803d}.status-badge.pending{background-color:#fef3c7;color:#d97706}.status-badge.bucket,.status-badge.bucket.list{background-color:var(--glass-accent-bg);color:var(--primary-blue)}.itin-footer{margin-top:auto;display:flex;justify-content:flex-end;align-items:center;gap:16px}.btn-link{background:none;border:none;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:color .2s}.btn-link:hover{color:var(--text-main)}.btn-link.primary{color:var(--primary-blue);display:flex;align-items:center;gap:4px}.btn-link.primary:hover{color:var(--primary-blue-hover);transform:translate(2px)}.btn-link.bucket{color:#e11d48;display:flex;align-items:center;gap:4px}.btn-link.bucket:hover{color:#be123c}.draft-actions{display:flex;align-items:center;gap:16px;width:100%}.draft-actions .btn-link{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-sm);transition:all .2s}.draft-actions .btn-link:hover{background:var(--glass-bg-subtle)}.draft-actions .btn-link.primary{background:var(--primary-blue);color:#fff;padding:8px 14px}.draft-actions .btn-link.primary:hover{background:var(--primary-blue-hover);transform:none}.draft-actions .btn-link.bucket:hover{background:var(--error-bg, #fef2f2)}@media(max-width:767px){.itinerary-list-container{padding:12px;padding-top:var(--header-height, 120px);padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 80px);height:100dvh}.itinerary-header{flex-direction:column;gap:12px;margin-bottom:20px}.header-left h1{font-size:1.3rem}.header-left p{font-size:.85rem}.header-buttons{width:100%;flex-direction:column;gap:8px}.new-itinerary-btn{width:100%;justify-content:center;min-height:var(--touch-target-min);padding:12px 16px}.filter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{white-space:nowrap;padding:6px 12px;font-size:.8rem;flex-shrink:0}.itinerary-card-wrapper{width:calc(100% - 20px);margin-bottom:12px}.itinerary-card{flex-direction:column;height:auto;border-radius:12px}.itin-image-wrapper{width:100%;height:180px}.itin-content{padding:14px}.itin-header{margin-bottom:6px}.itin-title{font-size:.95rem;margin-bottom:6px}.itin-date{font-size:.75rem;margin-bottom:8px}.itin-meta-row{flex-wrap:wrap;gap:8px}.itin-meta-item{font-size:.75rem}.status-badge{font-size:.7rem;padding:3px 8px}.itin-footer{flex-direction:column;gap:8px;margin-top:12px}.draft-actions{flex-direction:column;gap:8px}.draft-actions .btn-link,.btn-link{width:100%;justify-content:center;min-height:var(--touch-target-min);padding:10px 12px;font-size:.8rem}}@media(min-width:768px)and (max-width:1023px){.itinerary-list-container{padding:20px;padding-top:var(--header-height, 120px)}.itinerary-header{margin-bottom:24px}.header-left h1{font-size:1.6rem}.filter-tab{padding:7px 14px;font-size:.85rem}.itinerary-card-wrapper{width:calc(100% - 34px);margin-bottom:16px}.itin-image-wrapper{width:200px}.itin-content{padding:18px 20px}.itin-title{font-size:1.05rem}}@media(min-width:1024px)and (max-width:1279px){.itinerary-list-container{padding:var(--spacing-lg) 32px;padding-top:var(--header-height, 120px)}.itin-image-wrapper{width:220px}}@media(min-width:1280px){.itinerary-list-container{padding:var(--spacing-xl) 40px;padding-top:var(--header-height, 120px);max-width:1600px;margin:0 auto}.itin-image-wrapper{width:240px}.itin-content{padding:20px 24px}}@media(hover:none)and (pointer:coarse){.new-itinerary-btn,.filter-tab,.btn-link{min-height:var(--touch-target-min)}.itinerary-card:hover,.new-itinerary-btn:hover,.filter-tab:hover,.btn-link:hover{transform:none}.itinerary-card:active{opacity:.95}.filter-tab:active,.btn-link:active{opacity:.8}}@media(prefers-reduced-motion:reduce){.itinerary-card,.new-itinerary-btn,.filter-tab,.btn-link{transition:none}}.image-upload-modal{background:#fff;border-radius:16px;width:90%;max-width:500px;box-shadow:0 8px 32px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-subtle)}.modal-header h3{font-size:1.1rem;font-weight:600;color:var(--text-main);margin:0}.modal-header button{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:all .2s}.modal-header button:hover{background:#0000000d;color:var(--text-main)}.upload-tabs{display:flex;border-bottom:1px solid var(--border-subtle)}.upload-tabs button{flex:1 1 0%;padding:12px 16px;border:none;background:transparent;color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;border-bottom:2px solid transparent}.upload-tabs button:hover{background:#00000005;color:var(--text-main)}.upload-tabs button.active{color:#667eea;border-bottom-color:#667eea}.upload-content{padding:24px}.upload-area{border:2px dashed var(--border-subtle);border-radius:12px;padding:40px 20px;text-align:center;transition:all .2s}.upload-area:hover{border-color:#667eea;background:#667eea05}.upload-label{display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;color:var(--text-muted)}.upload-label p{font-size:.95rem;font-weight:500;color:var(--text-main);margin:0}.upload-label span{font-size:.8rem;color:var(--text-muted)}.url-input-area{display:flex;flex-direction:column;gap:16px}.url-input-area input{padding:12px 16px;border:1px solid var(--border-subtle);border-radius:8px;font-size:.9rem;transition:all .2s}.url-input-area input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.url-input-area button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.url-input-area button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.url-input-area button:disabled{opacity:.5;cursor:not-allowed}.planner-popup{position:fixed;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:0 8px 24px #0003;padding:8px;display:flex;flex-direction:column;gap:4px;z-index:9999;min-width:140px}.planner-popup button{padding:8px 12px;background:transparent;border:none;border-radius:6px;font-size:.85rem;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s ease;text-align:left}.planner-popup button:hover{background:var(--primary-blue);color:#fff}[data-theme=dark] .planner-popup{background:var(--surface-dark);border-color:#ffffff1a}[data-theme=dark] .itinerary-card{background:var(--surface-white);box-shadow:0 8px 20px #0000004d}[data-theme=dark] .itinerary-card:hover{box-shadow:0 8px 30px #0006}[data-theme=dark] .itinerary-list-container:hover::-webkit-scrollbar-thumb{background:#60a5fa}[data-theme=dark] .itinerary-list-container::-webkit-scrollbar-thumb:hover{background:#3b82f6}[data-theme=dark] .itinerary-list-container:hover{scrollbar-color:#60a5fa transparent}.empty-state{padding:60px 40px;text-align:center;background:var(--surface-white);border-radius:16px;box-shadow:0 4px 20px #0000001a;max-width:500px;margin:40px auto}.empty-state-icon{margin:0 auto 24px;opacity:.4;color:var(--primary-blue)}.empty-state-title{margin-bottom:12px;color:var(--text-main);font-size:1.5rem;font-weight:600}.empty-state-description{margin-bottom:32px;color:var(--text-secondary);font-size:1rem;line-height:1.5}.empty-state-buttons{display:flex;gap:16px;justify-content:center;align-items:center}.empty-state-buttons .new-itinerary-btn{flex:1 1 0%;max-width:200px;padding:12px 20px;border-radius:8px;font-size:.9rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;border:none;cursor:pointer}.empty-state-buttons .new-itinerary-btn:first-child{background:var(--surface-white);color:var(--text-main);border:1px solid var(--border-subtle)}.empty-state-buttons .new-itinerary-btn:first-child:hover{background:var(--bg-page);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.empty-state-buttons .new-itinerary-btn.ai-btn{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none}.empty-state-buttons .new-itinerary-btn.ai-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #007bff66}[data-theme=dark] .empty-state-buttons .new-itinerary-btn:first-child{background:var(--surface-white);border-color:var(--border-subtle)}[data-theme=dark] .empty-state-buttons .new-itinerary-btn:first-child:hover{background:#2d333b}[data-theme=dark] .empty-state{box-shadow:0 8px 20px #0000004d}.smart-itinerary-generator{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);max-width:800px;margin:0 auto}.generator-header{margin-bottom:var(--spacing-lg);text-align:center}.generator-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.generator-subtitle{color:var(--text-secondary);font-size:.9rem}.generator-form{display:grid;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:6px}.label-hint{font-size:.85rem;font-weight:400;color:var(--text-secondary);margin-left:8px}.form-hint{font-size:.85rem;color:var(--text-secondary);margin:4px 0 0}.form-label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select{padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.interests-selector{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.interest-tag{padding:4px 12px;border-radius:16px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;border:1px solid transparent;transition:all .2s}.interest-tag.selected{background:rgb(var(--primary-rgb),.1);color:var(--primary-color);border-color:rgb(var(--primary-rgb),.3)}.generate-btn{background:var(--primary-color);color:#fff;border:none;padding:12px;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;margin-top:var(--spacing-md);display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.generate-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.generate-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinning{animation:spin 1s linear infinite}.loading-tips{margin-top:var(--spacing-md);padding:var(--spacing-md);background:rgb(var(--primary-rgb),.05);border-radius:var(--radius-md);border-left:3px solid var(--primary-color)}.loading-tip{margin:8px 0;color:var(--text-secondary);font-size:.9rem;animation:fadeInOut 2s ease-in-out infinite}.loading-tip:nth-child(1){animation-delay:0s}.loading-tip:nth-child(2){animation-delay:.7s}.loading-tip:nth-child(3){animation-delay:1.4s}@keyframes fadeInOut{0%,to{opacity:.5}50%{opacity:1}}.error-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:#ef44441a;border:1px solid rgb(239 68 68 / 30%);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);color:#dc2626}.error-banner svg{flex-shrink:0}.error-content{flex:1 1 0%}.error-title{font-weight:600;margin:0 0 4px;font-size:.95rem}.error-message{margin:0;font-size:.9rem;opacity:.9}.retry-btn-inline{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid rgb(239 68 68 / 30%);border-radius:var(--radius-sm);color:#dc2626;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.retry-btn-inline:hover{background:#ef44440d;border-color:#ef44447f}.create-another-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.create-another-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgb(var(--primary-rgb),.3)}.itinerary-results{margin-top:var(--spacing-xl)}.day-card{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);border-left:4px solid var(--primary-color)}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-color)}.day-title{font-weight:600;font-size:1.1rem}.activity-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-sm) 0}.activity-time{font-weight:600;color:var(--text-secondary);font-size:.85rem;width:60px;flex-shrink:0}.activity-details{flex:1 1 0%}.activity-name{font-weight:600;margin-bottom:2px}.activity-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.action-buttons{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.save-btn{flex:1 1 0%;background:var(--success-color, #10b981);color:#fff;border:none;padding:12px;border-radius:var(--radius-md);font-weight:600;cursor:pointer}.loading-container{text-align:center;padding:var(--spacing-xl);color:var(--text-secondary)}.map-panel{width:340px;height:100%;display:flex;flex-direction:column;background:#fff;border-left:1px solid #e5e7eb;box-shadow:-4px 0 24px #0000000d;flex-shrink:0;overflow:hidden}.map-panel-fullwidth{width:100%;height:100%;display:flex;flex-direction:column;background:transparent;overflow:hidden}[data-theme=dark] .map-panel{background:#1a1f2e;border-left:1px solid #2d333b}.map-panel-collapsed{width:48px;height:100%;background:#ffffffe5;border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) var(--spacing-sm);gap:var(--spacing-sm);cursor:pointer;transition:all .2s ease}.map-panel-collapsed:hover{background:#fffffff2;box-shadow:-2px 0 12px #00000014}.collapsed-label{writing-mode:vertical-rl;text-orientation:mixed;font-size:.75rem;color:var(--text-muted);font-weight:500}.map-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:linear-gradient(135deg,#3b82f61a,#8b5cf60d);border-bottom:1px solid rgb(255 255 255 / 50%)}[data-theme=dark] .map-panel-header{background:linear-gradient(135deg,#3b82f626,#8b5cf61a);border-bottom:1px solid rgb(255 255 255 / 10%)}.map-header-left{display:flex;align-items:center;gap:var(--spacing-sm)}.map-icon{width:32px;height:32px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 8px #3b82f64d}.map-title{font-size:1rem;font-weight:600;color:var(--text-main)}.map-header-actions{display:flex;gap:var(--spacing-xs)}.map-action-btn{width:28px;height:28px;border:none;background:#fff9;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:all .2s}.map-action-btn:hover{background:#ffffffe5;color:var(--primary-blue);transform:translateY(-1px)}[data-theme=dark] .map-action-btn{background:#ffffff1a}[data-theme=dark] .map-action-btn:hover{background:#fff3}.map-container{flex:1 1 0%;position:relative;min-height:0;overflow:hidden}.google-map{width:100%;height:100%}.map-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0f2fe,#f0e7fe);gap:var(--spacing-md)}.map-loading-spinner{width:40px;height:40px;border:3px solid rgb(59 130 246 / 20%);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.map-glass-overlay{position:absolute;top:0;left:0;right:0;height:40px;background:linear-gradient(to bottom,rgb(255 255 255 / 30%),transparent);pointer-events:none}.map-quick-actions{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#fff9;border-top:1px solid rgb(255 255 255 / 50%);overflow-x:auto}.quick-action-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border-subtle);background:#fff;border-radius:20px;font-size:.75rem;font-weight:500;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all .2s}.quick-action-chip:hover{border-color:var(--primary-blue);color:var(--primary-blue)}.quick-action-chip.active{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:transparent;color:#fff}.modal-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:360px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.modal-header h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-main)}.modal-close{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.modal-close:hover{background:var(--bg-page);color:var(--text-main)}.modal-body{padding:30px 20px}.modal-options-grid{display:grid;grid-template-columns:repeat(2,132px);gap:16px;justify-content:center}.modal-option-btn{width:100%;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;background:#f8fafc;border:1px solid var(--border-subtle);border-radius:10px;cursor:pointer;transition:all .2s;text-align:center}.modal-option-btn:hover{background:#f1f5f9;border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 4px 12px #3b82f626}.modal-option-btn svg{color:var(--primary-blue);flex-shrink:0;width:20px;height:20px}.modal-option-btn>div{display:flex;flex-direction:column;gap:2px}.modal-option-btn strong{display:block;font-size:.875rem;font-weight:600;color:var(--text-main)}.modal-option-btn p{margin:0;font-size:.75rem;color:var(--text-secondary);line-height:1.3}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-main);margin-bottom:6px}.form-group input,.form-group textarea{width:100%;max-width:320px;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:4px;font-size:.9rem;box-sizing:border-box;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-blue)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;min-width:100%}.form-row .form-group{min-width:140px}.form-row .form-group input,.form-row .form-group textarea{max-width:100%}.modal-actions{display:flex;gap:8px;margin-top:20px}.modal-btn-primary,.modal-btn-secondary{flex:1 1 0%;padding:10px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.modal-btn-primary{background:var(--primary-blue);color:#fff}.modal-btn-primary:hover{background:#2563eb}.modal-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle)}.modal-btn-secondary:hover{background:var(--bg-page);color:var(--text-main)}.share-modal{max-width:500px;width:90%}.share-option{padding:20px;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px}.share-option-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.share-option-header h3{margin:0;font-size:16px;font-weight:600}.share-option p{margin:0 0 15px;color:#666;font-size:14px}.share-link-container{display:flex;gap:10px}.share-link-container input{flex:1 1 0%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px}.share-divider{text-align:center;color:#999;font-weight:600;margin:20px 0;position:relative}.share-divider:before,.share-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#e0e0e0}.share-divider:before{left:0}.share-divider:after{right:0}.members-panel{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;max-width:400px;width:100%}.members-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.members-panel-title{display:flex;align-items:center;gap:10px}.members-panel-title h3{margin:0;font-size:18px;font-weight:600;color:#1a1a1a}.close-btn{background:none;border:none;cursor:pointer;padding:4px;color:#666;transition:color .2s}.close-btn:hover{color:#1a1a1a}.members-error{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:16px;font-size:14px}.members-loading{text-align:center;padding:40px 20px;color:#666}.members-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.member-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f8f9fa;border-radius:8px;transition:background .2s}.member-item:hover{background:#f0f1f3}.member-info{display:flex;align-items:center;gap:12px;flex:1 1 0%}.member-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.member-details{display:flex;flex-direction:column;gap:4px}.member-name{font-weight:500;color:#1a1a1a;font-size:14px}.member-role{display:flex;align-items:center;gap:4px;font-size:12px;color:#666}.member-role svg{color:#f59e0b}.member-remove-btn{background:none;border:none;cursor:pointer;padding:6px;color:#999;transition:color .2s}.member-remove-btn:hover{color:#dc2626}.members-invite-section{border-top:1px solid #e5e7eb;padding-top:20px}.invite-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.invite-header h4{margin:0;font-size:16px;font-weight:600;color:#1a1a1a}.invite-code-container{display:flex;gap:8px;margin-bottom:8px}.invite-code-input{flex:1 1 0%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:13px;font-family:monospace;background:#f9fafb}.btn-icon{padding:10px 12px;display:flex;align-items:center;justify-content:center}.invite-hint{font-size:12px;color:#666;margin:8px 0 0}.advertising-column{display:flex;flex-direction:column;gap:12px;padding:12px;height:100%}.ad-spot{flex-shrink:0}.ad-placeholder{width:100%;height:250px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:1px dashed var(--border-subtle);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted)}.ad-placeholder span{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.ad-placeholder p{margin:4px 0 0;font-size:.7rem;opacity:.7}.ad-small{height:100px}.partner-cards-container{max-height:280px;overflow:hidden auto;display:flex;flex-direction:column;gap:8px;padding:2px;flex-shrink:0;scrollbar-width:none;-ms-overflow-style:none}.partner-cards-container::-webkit-scrollbar{display:none}.partner-card{display:flex;align-items:center;gap:10px;padding:10px;background:#fff;border:1px solid var(--border-subtle);border-radius:6px;text-decoration:none;transition:all .2s;cursor:pointer}.partner-card:hover{border-color:var(--primary-blue);box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.partner-icon{width:36px;height:36px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.partner-info{flex:1 1 0%;min-width:0}.partner-info h4{margin:0;font-size:.85rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.partner-info p{margin:2px 0 0;font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.partner-link-icon{color:var(--text-muted);flex-shrink:0;transition:color .2s}.partner-card:hover .partner-link-icon{color:var(--primary-blue)}@media(max-width:768px){.advertising-column{padding:8px;gap:8px}.ad-placeholder{height:150px}.ad-small{height:80px}.partner-cards-container{max-height:240px}.partner-card{padding:8px;gap:8px}.partner-icon{width:32px;height:32px}.partner-info h4{font-size:.8rem}.partner-info p{font-size:.7rem}}[data-theme=dark] .advertising-column{background:var(--surface-white);border-left-color:var(--border-subtle)}[data-theme=dark] .ad-placeholder{background:var(--bg-page);border-color:var(--border-subtle);color:var(--text-muted)}[data-theme=dark] .partner-card{background:var(--bg-page);border-color:var(--border-subtle)}[data-theme=dark] .partner-card:hover{border-color:var(--primary-blue)}[data-theme=dark] .partner-info h4{color:var(--text-main)}[data-theme=dark] .partner-info p{color:var(--text-secondary)}[data-theme=dark] .partner-link-icon{color:var(--text-muted)}[data-theme=dark] .partner-card:hover .partner-link-icon{color:var(--primary-blue)}.fixed-sidebar{position:fixed;right:0;top:var(--header-height, 80px);bottom:0;width:300px;background:transparent;border-left:none;overflow:hidden auto;z-index:50;transition:transform .3s ease;scrollbar-width:none;-ms-overflow-style:none}.fixed-sidebar::-webkit-scrollbar{display:none}.fixed-sidebar.full-height{top:0}.fixed-sidebar.closed{transform:translate(100%)}.fixed-sidebar.open{transform:translate(0)}.fixed-sidebar-toggle{display:flex;align-items:center;justify-content:center;position:fixed;right:0;top:50%;transform:translateY(-50%);width:28px;height:40px;background:#3b82f6f2;color:#fff;border:none;border-radius:12px 0 0 12px;cursor:pointer;z-index:1001;box-shadow:-2px 0 12px #3b82f64d;transition:all .25s cubic-bezier(.4,0,.2,1)}.fixed-sidebar-toggle:hover{background:#3b82f6;width:32px;box-shadow:-2px 0 16px #3b82f666}@media(max-width:1024px){.fixed-sidebar{top:0;width:300px;height:-webkit-fill-available;z-index:1000;background:var(--bg-page);border-left:1px solid var(--border-subtle);box-shadow:-4px 0 12px #00000026}}@media(max-width:768px){.fixed-sidebar{width:280px}}.planner-container{--header-height: 70px;height:-webkit-fill-available;display:flex;flex-direction:column;background-color:transparent;padding-bottom:24px}.planner-main-content{flex:1 1 0%;min-height:0;display:flex;overflow:hidden;padding-right:300px}.planner-views-container{flex:1 1 0%;min-height:0;overflow-y:auto}.planner-header{position:sticky;top:0;z-index:100;background:#fffffff2;border-bottom:1px solid rgb(255 255 255 / 30%);padding:8px 16px 6px;display:flex;flex-direction:column;gap:4px;box-shadow:0 2px 8px #0000000d}.planner-header-row-1{display:flex;align-items:center;justify-content:space-between;min-height:36px}.planner-header-row-2{display:flex;align-items:center;justify-content:space-between;min-height:32px;padding-top:2px;border-top:1px solid rgb(0 0 0 / 4%)}.planner-title-section{display:flex;align-items:center;gap:10px}.planner-breadcrumb{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem}.planner-trip-title{display:flex;align-items:center;gap:6px;font-size:1.05rem;font-weight:600}.planner-views{display:flex;gap:4px}.planner-controls{display:flex;gap:6px;align-items:center}.view-tab{display:flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.view-tab:hover{background-color:var(--bg-page);color:var(--text-main)}.view-tab.active{background-color:var(--primary-blue);color:#fff}.planner-actions{display:flex;gap:6px;align-items:center}.planner-btn{padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:#fff;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px}.planner-btn:hover{background-color:var(--bg-page)}.journii-ai-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-weight:600;display:flex;align-items:center;gap:6px;box-shadow:0 2px 8px #667eea4d}.journii-ai-btn:hover{background:linear-gradient(135deg,#5568d3,#653a8b);transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.planner-board{flex:1 1 0%;padding:10px;position:relative;overflow:hidden;background-color:transparent}.board-columns{display:flex;gap:8px;height:100%;padding-bottom:10px;flex-wrap:nowrap}.board-column{min-width:260px;width:100%;background:#f0f2f5;border-radius:8px;border:1px solid #e1e4e8;padding:12px;display:flex;flex-direction:column;max-height:calc(100dvh - 144px);flex-shrink:0}.column-header{padding:8px 10px;border-bottom:1px solid #e1e4e8;font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:space-between;gap:4px}.column-header span{flex:1 1 0%;cursor:pointer}.column-header span:hover{color:var(--primary-blue)}.board-column-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.board-column-header:hover .board-column-actions{opacity:1}.board-column-actions .icon-btn-small,.list-section-actions .icon-btn-small{position:static;top:auto;right:auto;width:auto;height:auto;background:transparent;border-radius:4px;color:#1f2937;transition:all .2s}.board-column-actions .icon-btn-small.delete-btn,.list-section-actions .icon-btn-small.delete-btn{opacity:inherit}.board-column-actions .icon-btn-small:hover,.list-section-actions .icon-btn-small:hover{background:#0000000d;color:#000}.board-column-actions .icon-btn-small.delete-btn:hover,.list-section-actions .icon-btn-small.delete-btn:hover{background:#ef44441a;color:#ef4444}[data-theme=dark] .board-column-actions .icon-btn-small,[data-theme=dark] .list-section-actions .icon-btn-small{color:#f9fafb}[data-theme=dark] .board-column-actions .icon-btn-small:hover,[data-theme=dark] .list-section-actions .icon-btn-small:hover{background:#ffffff1a;color:#fff}[data-theme=dark] .board-column-actions .icon-btn-small.delete-btn:hover,[data-theme=dark] .list-section-actions .icon-btn-small.delete-btn:hover{background:#ef444433;color:#fca5a5}.section-name-input,.trip-name-input{border:1px solid var(--primary-blue);border-radius:4px;padding:4px 8px;font-size:inherit;font-weight:inherit;font-family:inherit;outline:none;width:100%}.icon-btn,.icon-btn-small{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover,.icon-btn-small:hover{background-color:var(--bg-page);color:var(--text-main)}.icon-btn.active{color:var(--primary-blue);background-color:#eff6ff}.column-tasks{flex:1 1 0%;min-height:0;padding:6px 8px;display:flex;flex-direction:column;gap:4px;overflow:hidden auto}.column-tasks::-webkit-scrollbar{width:6px}.column-tasks::-webkit-scrollbar-track{background:transparent}.column-tasks::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.column-tasks::-webkit-scrollbar-thumb:hover{background:#94a3b8}.task-card{padding:8px;background:#f8f9fa;border:1px solid #e1e4e8;border-radius:4px;font-size:.8125rem;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;position:relative}.task-card:hover{background:#f1f3f5;border-color:#0078d4;box-shadow:0 1px 3px #00000014}.delete-item-btn{position:absolute;top:4px;right:4px;background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;opacity:0;transition:opacity .2s;padding:2px 6px;border-radius:4px;z-index:10}.task-card:hover .delete-item-btn,.item-content:hover .delete-item-btn,.schedule-item-content:hover .delete-item-btn,.grid-item-card:hover .delete-item-btn,.board-item-card:hover .delete-item-btn,.compact-item-content:hover .delete-item-btn{opacity:1}.delete-item-btn:hover{background:#ef44441a;color:#ef4444}.item-content{position:relative;min-height:30px}.item-content a{color:var(--primary-blue);text-decoration:none;word-break:break-all}.item-content a:hover{text-decoration:underline}.add-task-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;color:var(--primary-blue);background:transparent;border:none;font-size:.85rem;cursor:pointer;border-radius:var(--radius-sm);margin:4px 8px 8px;transition:background .2s;font-weight:500}.add-task-btn:hover{background:#eff6ff;transform:translate(2px)}.section-specific{display:flex;gap:8px;padding:4px 8px 8px}.section-specific .add-task-btn{flex:1 1 0%;margin:0;justify-content:center}.add-flight-btn,.add-hotel-btn{color:var(--primary-blue)}.add-experience-btn{color:#9333ea}.card-type-menu{background:#fff;border:1px solid #e1e4e8;border-radius:6px;padding:8px;margin:4px 0;box-shadow:0 2px 8px #0000001a}.card-type-header{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-bottom:1px solid #e1e4e8;margin-bottom:6px}.card-type-header span{font-size:.8125rem;font-weight:600;color:var(--text-main)}.close-menu-btn{background:transparent;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s ease}.close-menu-btn:hover{background:#f1f3f5;color:var(--text-main)}.card-type-options{display:flex;flex-direction:column;gap:4px}.card-type-option{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s ease;text-align:left}.card-type-option:hover{background:#f8f9fa;border-color:#e1e4e8}.card-type-option svg{color:#0078d4;flex-shrink:0}.card-type-info{display:flex;flex-direction:column;gap:2px}.card-type-name{font-size:.8125rem;font-weight:600;color:var(--text-main)}.card-type-desc{font-size:.75rem;color:var(--text-muted)}.add-section-container{display:flex;align-items:center;justify-content:center;min-height:80px;border:2px dashed #e1e4e8;background:transparent;padding:0}.add-section-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #e1e4e8;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:600;color:#0078d4;transition:all .15s ease}.add-section-btn:hover{background:#f8f9fa;border-color:#0078d4;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.add-section-btn svg{color:#0078d4}.section-type-menu{background:#fff;border:1px solid #e1e4e8;border-radius:6px;padding:8px;box-shadow:0 2px 8px #0000001a}.section-type-header{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-bottom:1px solid #e1e4e8;margin-bottom:6px}.section-type-header span{font-size:.8125rem;font-weight:600;color:var(--text-main)}.section-type-options{display:flex;flex-direction:column;gap:4px}.section-type-option{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s ease;text-align:left}.section-type-option:not(.custom-section):hover{background:#f8f9fa;border-color:#e1e4e8}.section-type-option svg{color:#0078d4;flex-shrink:0}.section-type-info{display:flex;flex-direction:column;gap:2px;flex:1 1 0%}.section-type-name{font-size:.8125rem;font-weight:600;color:var(--text-main)}.section-type-desc{font-size:.75rem;color:var(--text-muted)}.section-type-option.custom-section{cursor:default;padding:10px}.section-type-option.custom-section .section-type-info{flex-direction:row;gap:8px;align-items:center}.custom-section-input{flex:1 1 0%;border:1px solid #e1e4e8;border-radius:4px;padding:6px 8px;font-size:.8125rem;font-family:inherit;outline:none}.custom-section-input:focus{border-color:#0078d4}.add-custom-btn{padding:6px 12px;background:#0078d4;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.add-custom-btn:hover:not(:disabled){background:#005a9e}.add-custom-btn:disabled{opacity:.5;cursor:not-allowed}.item-input-container{padding:8px;position:relative}.item-input{width:100%;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:8px;font-size:.85rem;font-family:inherit;outline:none;margin-bottom:8px}.item-input:focus{border-color:var(--primary-blue)}.item-input-actions{display:flex;gap:6px;justify-content:flex-end}.btn-primary,.btn-secondary{padding:6px 12px;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:all .2s;border:1px solid var(--border-subtle);font-weight:500}.btn-primary{background:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.btn-primary:hover{background:var(--primary-blue-hover)}.btn-secondary{background:#fff;color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-page)}.add-column-btn{min-width:240px;width:240px;background:transparent;border:2px dashed var(--border-subtle);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.add-column-btn:hover{border-color:var(--primary-blue);background:#eff6ff}.add-column-content{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-muted)}.add-column-btn:hover .add-column-content{color:var(--primary-blue)}.board-column.dragging{opacity:.5}.column-tasks.drag-over{background-color:#eff6ff;border:2px dashed var(--primary-blue);border-radius:var(--radius-sm)}.task-card.dragging{opacity:.8;box-shadow:0 4px 12px #00000026}.board-column-items.drag-over{background-color:#dbeafe;border:2px dashed #3b82f6;border-radius:6px;padding:8px}.board-item-card.dragging{opacity:.8;box-shadow:0 4px 12px #00000026;transform:rotate(2deg)}.grid-section.dragging{opacity:.5}.grid-items.drag-over{background-color:#eff6ff;border:2px dashed var(--primary-blue);border-radius:var(--radius-sm);padding:8px}.grid-item-card.dragging{opacity:.8;box-shadow:0 4px 12px #00000026}.schedule-day.dragging{opacity:.5}.schedule-items.drag-over{background-color:#eff6ff;border:2px dashed var(--primary-blue);border-radius:var(--radius-sm)}.schedule-item.dragging{opacity:.8;box-shadow:0 4px 12px #00000026}.media-preview{width:100%;margin:8px 0 4px;border-radius:6px;overflow:hidden}.media-preview img{width:100%;height:auto;max-height:200px;object-fit:cover;display:block}.planner-board-view{flex:1 1 0%;min-height:0;padding:0;overflow:hidden auto;background-color:transparent}.board-columns-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;padding:16px;align-items:start;height:fit-content;max-height:calc(100dvh - 220px)}.board-column-header{display:flex;justify-content:space-between;align-items:center;padding:8px 4px;margin-bottom:4px}.board-column-header .drag-handle{display:flex;align-items:center;gap:8px;flex:1 1 0%;cursor:grab}.board-column-header .drag-handle:active{cursor:grabbing}.board-column-header h3{font-size:.9375rem;font-weight:600;color:#1f2937;margin:0;letter-spacing:-.01em}.board-column:hover .board-column-actions{opacity:1}.board-column-items{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1 1 0%;min-height:0;padding:4px 0}.board-item-card{background:#fff;border-radius:6px;border:1px solid #e5e7eb;padding:10px 12px;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.board-item-card:hover{box-shadow:0 2px 8px #0000001a;border-color:#d1d5db}.board-add-item{margin-top:4px}.compact-item-content{position:relative}.compact-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:6px}.compact-item-title{font-size:.875rem;font-weight:600;color:#111827;margin:0;line-height:1.4;flex:1 1 0%;overflow-wrap:break-word}.compact-item-details{margin:0;padding-left:16px;list-style-type:disc}.compact-item-details li{font-size:.75rem;color:#6b7280;line-height:1.5;margin-bottom:2px}.compact-item-details li:last-child{margin-bottom:0}.compact-item-title-row{display:flex;align-items:center;gap:6px;flex:1 1 0%;min-width:0;font-size:16px}.compact-item-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;line-height:1}.compact-item-badges{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.compact-badge{font-size:.6875rem;padding:2px 6px;border-radius:3px;font-weight:500;white-space:nowrap;line-height:1.4}.compact-badge-price{background:#dbeafe;color:#1e40af}.compact-badge-date{background:#fef3c7;color:#92400e}.compact-badge-category{background:#e0e7ff;color:#3730a3}.compact-badge-rating{background:#fef9c3;color:#854d0e}.compact-badge-duration{background:#f3e8ff;color:#6b21a8}.compact-badge-status{background:#d1fae5;color:#065f46}.compact-item-media{margin-top:8px}.compact-media-preview{width:100%;max-height:120px;object-fit:cover;border-radius:4px}.planner-grid-view{flex:1 1 0%;padding:12px 12px 40px;overflow-y:auto;background-color:transparent}.grid-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;max-width:1400px;margin:0 auto}.grid-section{background:#fff;border-radius:6px;border:1px solid #e1e4e8;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.grid-section-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:6px;border-bottom:1px solid #e1e4e8}.grid-section-header .drag-handle{display:flex;align-items:center;gap:8px;flex:1 1 0%;cursor:grab}.grid-section-header .drag-handle:active{cursor:grabbing}.grid-section-header h3{font-size:.875rem;font-weight:600;color:var(--text-main);margin:0}.schedule-day-header .drag-handle{display:flex;align-items:center;gap:12px;flex:1 1 0%;cursor:grab}.schedule-day-header .drag-handle:active{cursor:grabbing}.section-name-input{font-size:.875rem;font-weight:600;padding:4px 8px;border:1px solid var(--primary-blue);border-radius:4px;outline:none;background:#fff}.grid-items{display:flex;flex-direction:column;gap:4px}.grid-item-card{position:relative;padding:8px;background:#f8f9fa;border:1px solid #e1e4e8;border-radius:4px;font-size:.8125rem}.grid-add-item{margin-top:2px}.planner-schedule-view{flex:1 1 0%;padding:12px;overflow-y:auto;background-color:transparent}.schedule-timeline{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:12px}.schedule-day{background:#fff;border-radius:6px;border:1px solid #e1e4e8;padding:10px 12px}.schedule-day.add-section-container{padding:0}.schedule-day-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e1e4e8}.day-number{background:var(--primary-blue);color:#fff;padding:6px 10px;border-radius:6px;font-weight:600;font-size:.8125rem;display:flex;align-items:center;justify-content:center}.schedule-day-header h3{font-size:.9375rem;font-weight:600;color:var(--text-main)}.schedule-items{display:flex;flex-direction:column;gap:6px}.schedule-item{display:flex;gap:12px;align-items:flex-start}.schedule-time{min-width:55px;font-weight:600;color:var(--primary-blue);font-size:.8125rem;padding-top:6px}.schedule-item-content{position:relative;flex:1 1 0%;padding:8px;background:#f8f9fa;border:1px solid #e1e4e8;border-radius:4px}.schedule-add-item{margin-left:67px;margin-top:4px}.planner-charts-view{flex:1 1 0%;padding:24px;overflow-y:auto;background-color:var(--bg-page)}.charts-container{max-width:1200px;margin:0 auto}.chart-card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:24px;text-align:center}.chart-card h3{font-size:1.2rem;font-weight:600;color:var(--text-main);margin-bottom:12px}.chart-card p{color:var(--text-muted)}.media-preview video{width:100%;max-height:200px;display:block}.btn-icon{display:flex;align-items:center;justify-content:center;min-width:32px}.add-item-section{padding:4px 8px 8px}@media(max-width:1024px){.planner-main-content{padding-right:0}}@media(max-width:767px){.planner-container{padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 24px)}.planner-header{padding:8px 12px 6px;gap:6px}.planner-header-row-1{flex-direction:row;align-items:center;justify-content:space-between;gap:8px;width:100%;min-height:32px}.planner-trip-title,.planner-trip-title span{font-size:1.1rem;font-weight:600}.planner-title-section{flex:1 1 0%;min-width:0}.planner-actions{display:flex;gap:4px;align-items:center;flex-shrink:0}.planner-header-row-2{flex-direction:row;align-items:center;justify-content:space-between;gap:8px;width:100%}.planner-views{display:flex;gap:4px;flex:1 1 0%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.planner-views::-webkit-scrollbar{display:none}.view-tab{padding:4px 10px;font-size:.75rem;white-space:nowrap;flex-shrink:0}.planner-controls{display:flex;gap:4px;flex-shrink:0}.journii-ai-btn span,.planner-btn span{display:none}.planner-btn{padding:6px 8px;min-width:auto}.icon-btn{padding:4px}.planner-board-view{padding:0;overflow-y:auto}.board-columns-container{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;padding:12px}.board-column{width:100%}.board-column-header{position:sticky;top:0;background:#f0f2f5;z-index:1}.compact-item-title{font-size:.8125rem}.compact-item-details li{font-size:.6875rem}.board-view{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--spacing-md)}.board-columns{min-width:max-content}.grid-view{padding:var(--spacing-md)}.grid-columns{grid-template-columns:1fr;gap:var(--spacing-md)}.grid-column{min-height:auto}.schedule-view{padding:var(--spacing-md)}.schedule-header{flex-direction:column;gap:var(--spacing-sm)}.schedule-nav{width:100%;justify-content:space-between}.schedule-grid{overflow-x:auto;-webkit-overflow-scrolling:touch}.schedule-grid-inner{min-width:600px}.planner-board{padding:8px}.column-header{position:sticky;top:0;background:#fff;z-index:1}}@media(min-width:768px)and (max-width:1023px){.planner-header{padding:10px 16px}.planner-trip-title{font-size:1.05rem}.view-tab{padding:7px 14px;font-size:.8rem}.planner-board{padding:12px}.board-columns{gap:12px}.board-column{min-width:300px;width:300px}.grid-columns{grid-template-columns:repeat(2,1fr);gap:16px}.schedule-grid-inner{min-width:auto}}@media(min-width:1024px){.planner-board{padding:16px}.board-columns{gap:12px}.board-column{min-width:280px;width:280px}.grid-columns{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}}@media(min-width:1280px){.planner-board{padding:20px}.board-column{min-width:320px;width:320px}.grid-columns{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}}@media(hover:none)and (pointer:coarse){.view-tab,.planner-btn,.journii-ai-btn{min-height:var(--touch-target-min)}.view-tab:hover,.planner-btn:hover,.journii-ai-btn:hover{transform:none}.view-tab:active{opacity:.8}.planner-btn:active{background-color:var(--bg-page)}}@media(prefers-reduced-motion:reduce){.board-columns,.view-tab,.planner-btn,.journii-ai-btn{transition:none;scroll-behavior:auto}}.spinner{border:2px solid rgb(59 130 246 / 20%);border-top:2px solid #3b82f6;border-radius:50%;animation:spin .8s linear infinite}.sync-indicator{display:flex;align-items:center;gap:3px;padding:3px 7px;border-radius:10px;font-size:16px;font-weight:500;margin-left:6px;transition:all .3s ease}.sync-indicator.connected{background:#22c55e1a;color:#22c55e;border:1px solid rgb(34 197 94 / 20%)}.sync-indicator.disconnected{background:#ef44441a;color:#ef4444;border:1px solid rgb(239 68 68 / 20%)}.sync-indicator svg{width:12px;height:12px}.sync-indicator span{line-height:1}.upload-progress{display:flex;align-items:center;gap:12px;padding:12px;background:#3b82f60d;border:1px solid rgb(59 130 246 / 20%);border-radius:8px;color:#3b82f6;font-size:14px}.upload-error{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#ef44440d;border:1px solid rgb(239 68 68 / 20%);border-radius:8px;color:#ef4444;font-size:13px;margin-bottom:8px}.upload-error button{background:none;border:none;color:#ef4444;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.upload-error button:hover{background:#ef44441a}.media-preview img,.media-preview video{width:100%;height:auto;display:block}.item-input-container.dragging{border:2px dashed #3b82f6;background:#3b82f60d}.drop-overlay{position:absolute;inset:0;background:#3b82f61a;border:2px dashed #3b82f6;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#3b82f6;font-weight:500;z-index:10;pointer-events:none}.drop-overlay svg{opacity:.7}.undo-redo-group{display:flex;gap:2px;padding:2px;background:#00000005;border-radius:6px;border:1px solid rgb(0 0 0 / 6%)}.planner-btn-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:5px;cursor:pointer;color:#64748b;transition:all .2s}.planner-btn-icon:hover:not(:disabled){background:#3b82f61a;color:#3b82f6}.planner-btn-icon:active:not(:disabled){transform:scale(.95)}.planner-btn-icon:disabled{opacity:.3;cursor:not-allowed}.planner-btn-icon .spinner{border-color:#3b82f633;border-top-color:#3b82f6}.history-panel{position:absolute;top:100%;right:0;width:320px;max-height:500px;background:#fff;border:1px solid rgb(0 0 0 / 10%);border-radius:12px;box-shadow:0 8px 24px #0000001f;z-index:100;margin-top:8px;display:flex;flex-direction:column;overflow:hidden}.history-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgb(0 0 0 / 6%)}.history-header h3{margin:0;font-size:16px;font-weight:600;color:#1e293b}.history-header button{background:none;border:none;font-size:24px;color:#64748b;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.history-header button:hover{background:#0000000d;color:#1e293b}.history-content{flex:1 1 0%;overflow-y:auto;padding:8px}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:#94a3b8}.history-empty p{margin:12px 0 4px;font-size:15px;font-weight:500;color:#64748b}.history-empty span{font-size:13px}.history-list{display:flex;flex-direction:column;gap:4px}.history-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;transition:background .2s}.history-item:hover{background:#00000005}.history-item-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border-radius:8px;color:#3b82f6;flex-shrink:0}.history-item-content{flex:1 1 0%;min-width:0}.history-item-action{font-size:14px;font-weight:500;color:#1e293b;margin-bottom:4px}.history-item-time{font-size:12px;color:#94a3b8}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-section{animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-title{width:120px;height:20px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-count{width:40px;height:20px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-item{padding:12px;background:#fff;border-radius:8px;margin-bottom:8px}.skeleton-content{width:100%;height:80px;background:linear-gradient(90deg,#e2e8f0 25%,#f1f5f9,#e2e8f0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:6px}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.board-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;text-align:center;min-height:400px}.error-icon{font-size:64px;margin-bottom:16px;opacity:.5}.board-error h3{margin:0 0 8px;font-size:20px;font-weight:600;color:#1e293b}.board-error p{margin:0 0 24px;font-size:14px;color:#64748b;max-width:400px}.map-view-container{flex:1 1 0%;width:100%;min-height:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.map-state-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:20px}[data-theme=dark] .planner-header{background:#1a1f2ef2;border-bottom:1px solid var(--border-subtle);box-shadow:0 2px 8px #0000004d}[data-theme=dark] .planner-header-row-2{border-top:1px solid var(--border-subtle)}[data-theme=dark] .planner-breadcrumb{color:var(--text-muted)}[data-theme=dark] .planner-trip-title{color:var(--text-main)}[data-theme=dark] .view-tab{color:var(--text-secondary)}[data-theme=dark] .view-tab.active{background:var(--primary-blue-light);color:var(--primary-blue)}[data-theme=dark] .view-tab:hover:not(.active){background:var(--button-bg-hover);color:var(--text-main)}[data-theme=dark] .planner-btn{background:var(--button-bg-hover);color:var(--text-main);border:1px solid var(--border-subtle)}[data-theme=dark] .planner-btn:hover{background:var(--button-bg-active);border-color:var(--primary-blue)}[data-theme=dark] .planner-btn-primary{background:var(--primary-blue);color:#fff}[data-theme=dark] .planner-btn-primary:hover{background:var(--primary-blue-hover)}[data-theme=dark] .schedule-section{background:var(--surface-white);border:1px solid var(--border-subtle)}[data-theme=dark] .section-header{background:var(--glass-bg);border-bottom:1px solid var(--border-subtle)}[data-theme=dark] .section-title{color:var(--text-main)}[data-theme=dark] .section-number{background:var(--primary-blue-light);color:var(--primary-blue)}[data-theme=dark] .schedule-item{background:var(--surface-white);border:1px solid var(--border-subtle)}[data-theme=dark] .schedule-item:hover{border-color:var(--primary-blue);box-shadow:0 2px 8px #4a9eff33}[data-theme=dark] .item-card,[data-theme=dark] .item-card h4{color:var(--text-main)}[data-theme=dark] .item-card p{color:var(--text-secondary)}[data-theme=dark] .item-card a{color:var(--primary-blue)}[data-theme=dark] .item-card a:hover{color:var(--primary-blue-hover)}[data-theme=dark] .add-item-btn,[data-theme=dark] .add-section-btn{background:var(--button-bg-hover);color:var(--text-secondary);border:1px dashed var(--border-subtle)}[data-theme=dark] .add-item-btn:hover,[data-theme=dark] .add-section-btn:hover{background:var(--button-bg-active);color:var(--primary-blue);border-color:var(--primary-blue)}[data-theme=dark] .icon-btn-small{color:var(--text-secondary)}[data-theme=dark] .icon-btn-small:hover{color:var(--text-main);background:var(--button-bg-hover)}[data-theme=dark] .delete-btn:hover{color:var(--error-text);background:var(--error-bg)}[data-theme=dark] .fixed-advertising-column{background:var(--surface-white);border-left:1px solid var(--border-subtle)}[data-theme=dark] .ad-placeholder{background:var(--glass-bg);border:1px dashed var(--border-subtle);color:var(--text-muted)}[data-theme=dark] .section-name-input,[data-theme=dark] .trip-name-input,[data-theme=dark] .custom-section-input,[data-theme=dark] .item-input{background:var(--input-bg);border-color:var(--input-border);color:var(--text-main)}[data-theme=dark] .section-name-input:focus,[data-theme=dark] .trip-name-input:focus,[data-theme=dark] .custom-section-input:focus,[data-theme=dark] .item-input:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-shadow)}[data-theme=dark] .section-name-input::placeholder,[data-theme=dark] .trip-name-input::placeholder,[data-theme=dark] .custom-section-input::placeholder,[data-theme=dark] .item-input::placeholder{color:var(--text-muted)}[data-theme=dark] [contenteditable=true]{color:var(--text-main)}[data-theme=dark] [contenteditable=true]:focus{outline-color:var(--primary-blue)}[data-theme=dark] .card-type-menu,[data-theme=dark] .section-type-menu{background:var(--surface-white);border-color:var(--border-subtle);box-shadow:var(--shadow-lg)}[data-theme=dark] .card-type-option,[data-theme=dark] .section-type-option{color:var(--text-main)}[data-theme=dark] .card-type-option:hover,[data-theme=dark] .section-type-option:hover{background:var(--button-bg-hover)}[data-theme=dark] .close-menu-btn{color:var(--text-secondary)}[data-theme=dark] .close-menu-btn:hover{background:var(--button-bg-hover);color:var(--text-main)}[data-theme=dark] .btn-secondary{background:var(--surface-white);color:var(--text-main);border-color:var(--border-subtle)}[data-theme=dark] .btn-secondary:hover{background:var(--button-bg-hover)}[data-theme=dark] .btn-icon{color:var(--text-secondary)}[data-theme=dark] .btn-icon:hover{color:var(--text-main);background:var(--button-bg-hover)}[data-theme=dark] .history-header{background:var(--surface-white);border-bottom:1px solid var(--border-subtle)}[data-theme=dark] .history-header button{color:var(--text-secondary)}[data-theme=dark] .history-header button:hover{color:var(--text-main)}[data-theme=dark] .upload-error{background:var(--error-bg);border-color:var(--error-border)}[data-theme=dark] .upload-error button{color:var(--error-text)}[data-theme=dark] .card-type-header span,[data-theme=dark] .card-type-name{color:var(--text-main)}[data-theme=dark] .card-type-desc{color:var(--text-muted)}[data-theme=dark] .card-type-option svg{color:var(--primary-blue)}[data-theme=dark] .item-input-container.dragging{border-color:var(--primary-blue);background:#4a9eff1a}[data-theme=dark] .empty-state{color:var(--text-muted)}[data-theme=dark] .empty-state-icon{color:var(--text-disabled)}[data-theme=dark] .schedule-day,[data-theme=dark] .grid-section,[data-theme=dark] .board-column{background:var(--surface-white);border-color:var(--border-subtle)}[data-theme=dark] .schedule-day-header,[data-theme=dark] .grid-section-header,[data-theme=dark] .board-column-header{background:var(--surface-white);border-bottom-color:var(--border-subtle)}[data-theme=dark] .schedule-day-header h3,[data-theme=dark] .grid-section-header h3,[data-theme=dark] .board-column-header h3{color:var(--text-main)}[data-theme=dark] .schedule-item-content,[data-theme=dark] .grid-item-card,[data-theme=dark] .board-item-card{background:var(--bg-page);border-color:var(--border-subtle);color:var(--text-main)}[data-theme=dark] .item-content p,[data-theme=dark] .item-content a,[data-theme=dark] .compact-item-title{color:var(--text-main)}[data-theme=dark] .item-content a:hover{color:var(--primary-blue)}[data-theme=dark] .compact-item-details li{color:var(--text-secondary)}[data-theme=dark] .compact-badge-price{background:#1e3a8a;color:#bfdbfe}[data-theme=dark] .compact-badge-date{background:#78350f;color:#fef3c7}[data-theme=dark] .compact-badge-category{background:#312e81;color:#c7d2fe}[data-theme=dark] .compact-badge-rating{background:#713f12;color:#fef9c3}[data-theme=dark] .compact-badge-duration{background:#581c87;color:#f3e8ff}[data-theme=dark] .compact-badge-status{background:#064e3b;color:#d1fae5}[data-theme=dark] .planner-board-view{background-color:transparent}.planner-list-view{width:100%;height:100%;overflow:auto;background:var(--bg-page);padding:20px}.list-view-table-container{width:100%;overflow-x:auto;background:var(--bg-elevated);border-radius:8px;box-shadow:0 1px 3px #0000001a}.planner-table{width:100%;border-collapse:collapse;font-size:14px}.planner-table thead{background:var(--bg-page);border-bottom:2px solid var(--border-subtle);position:sticky;top:0;z-index:10}.planner-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.planner-table tbody tr{border-bottom:1px solid var(--border-subtle);transition:background-color .15s ease}.planner-table tbody tr:hover{background:var(--bg-page)}.section-header-row{background:var(--bg-page);border-bottom:2px solid var(--border-subtle)}.section-header-row:hover{background:var(--bg-page)}.section-header-cell{padding:8px 16px}.list-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.list-section-title{display:flex;align-items:center;gap:8px}.list-section-title h4{margin:0;font-size:14px;font-weight:600;color:var(--text-main)}.list-section-title .item-count{font-size:12px;color:var(--text-secondary);font-weight:400}.list-section-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s}.section-header-row:hover .list-section-actions,.list-section-actions .icon-btn-small{opacity:1}.planner-table td{padding:12px 16px;color:var(--text-main);vertical-align:middle}.col-section{width:150px;min-width:150px}.col-title{width:auto;min-width:200px}.col-type{width:120px;min-width:120px}.col-date{width:140px;min-width:140px}.col-location{width:180px;min-width:180px}.col-price{width:100px;min-width:100px}.col-actions{width:80px;min-width:80px;text-align:center}.editable-cell{cursor:pointer;position:relative;transition:background-color .2s}.editable-cell:hover{background-color:#3b82f60d}.inline-edit-input{width:100%;padding:6px 8px;border:2px solid var(--primary-blue);border-radius:4px;font-size:14px;font-family:inherit;color:var(--text-main);background-color:var(--bg-page);outline:none;box-shadow:0 0 0 3px #3b82f61a}.inline-edit-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #3b82f633}.empty-cell-placeholder{color:var(--text-muted);font-style:italic;opacity:.6}.editable-cell .empty-cell-placeholder{opacity:0;transition:opacity .2s}.editable-cell:hover .empty-cell-placeholder{opacity:.6}.planner-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.planner-table th.sortable:hover{background-color:#3b82f60d}.planner-table th.sortable:active{background-color:#3b82f61a}.sort-indicator{font-size:10px;color:var(--primary-blue);margin-left:4px}.section-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-page);border:1px solid var(--border-subtle);border-radius:4px;font-size:13px;font-weight:500;color:var(--text-main)}.section-badge svg{flex-shrink:0}.type-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap}.type-badge.type-flight{background:#dbeafe;color:#1e40af}.type-badge.type-hotel{background:#fef3c7;color:#92400e}.type-badge.type-experience{background:#ede9fe;color:#5b21b6}.type-badge.type-note{background:#f3f4f6;color:#374151}[data-theme=dark] .type-badge.type-flight{background:#1e3a8a;color:#bfdbfe}[data-theme=dark] .type-badge.type-hotel{background:#78350f;color:#fef3c7}[data-theme=dark] .type-badge.type-experience{background:#581c87;color:#f3e8ff}[data-theme=dark] .type-badge.type-note{background:#374151;color:#d1d5db}.table-action-btn{padding:6px;background:transparent;border:none;border-radius:4px;cursor:pointer;color:var(--text-secondary);transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center}.table-action-btn:hover{background:var(--bg-page);color:var(--text-main)}.table-action-btn.delete-btn:hover{background:#fee2e2;color:#dc2626}[data-theme=dark] .table-action-btn.delete-btn:hover{background:#7f1d1d;color:#fca5a5}.add-item-row{background:transparent;border-bottom:none}.add-item-row:hover{background:transparent}.add-item-row td{padding:2px 16px 8px;border-bottom:1px solid var(--border-subtle)}.add-item-row .item-input-container{margin:0;padding:0}.add-item-row .item-input{min-height:unset;padding:4px 8px;font-size:13px}.add-item-row .item-input-actions{gap:4px}.add-item-row .item-input-actions button,.add-item-row .item-input-actions a{padding:4px 8px;font-size:12px;min-height:unset}.list-view-add-section{margin-top:20px;padding:16px;background:var(--bg-elevated);border-radius:8px;border:2px dashed var(--border-subtle)}.list-view-add-section .add-section-btn{width:100%;padding:12px;background:transparent;border:none;border-radius:6px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s ease}.list-view-add-section .add-section-btn:hover{background:var(--bg-page);color:var(--primary-blue)}[data-theme=dark] .planner-list-view{background:var(--bg-page)}[data-theme=dark] .list-view-table-container{background:var(--bg-elevated)}[data-theme=dark] .planner-table thead,[data-theme=dark] .planner-table tbody tr:hover{background:var(--bg-page)}[data-theme=dark] .section-badge{background:var(--bg-page);border-color:var(--border-subtle)}[data-theme=dark] .add-item-row{background:transparent}[data-theme=dark] .add-item-row td{border-bottom-color:var(--border-subtle)}.planner-empty-state{padding:60px 40px;text-align:center;background:var(--surface-white);border-radius:16px;box-shadow:0 4px 20px #0000001a;max-width:500px;margin:40px auto}.planner-empty-state-icon{margin:0 auto 24px;opacity:.4;color:var(--primary-blue)}.planner-empty-state-title{margin-bottom:12px;color:var(--text-main);font-size:1.5rem;font-weight:600}.planner-empty-state-description{margin-bottom:32px;color:var(--text-secondary);font-size:1rem;line-height:1.5}.planner-empty-state-buttons{display:flex;gap:16px;justify-content:center;align-items:center}.planner-new-trip-btn{padding:12px 24px;border-radius:8px;font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:8px;transition:all .2s ease;border:none;cursor:pointer;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff}.planner-new-trip-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #007bff66}[data-theme=dark] .planner-empty-state{box-shadow:0 8px 20px #0000004d}.planner-secondary-sidebar{position:relative;width:280px;background-color:var(--surface-white);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;height:100%;padding:var(--spacing-md);padding-left:calc(var(--spacing-md) + 8px);flex-shrink:0;overflow:hidden auto}.planner-secondary-sidebar-collapsed{position:relative;width:8px;background-color:transparent;border-right:1px solid var(--border-subtle);display:flex;flex-shrink:0;height:100%}.planner-secondary-sidebar::-webkit-scrollbar{width:6px}.planner-secondary-sidebar::-webkit-scrollbar-track{background:transparent}.planner-secondary-sidebar::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}.planner-secondary-sidebar::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.planner-sec-nav{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--spacing-lg)}.planner-nav-heading{display:flex;align-items:center;gap:8px;padding:8px 12px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:default;-webkit-user-select:none;user-select:none}.planner-nav-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.9rem;cursor:pointer;transition:background .2s}.planner-nav-item:hover{background-color:var(--bg-page);color:var(--text-main)}.planner-nav-item.active{background-color:#f1f5f9;color:var(--text-main);font-weight:500}.planner-nav-item .coming-soon-text{display:block;font-size:.75rem;color:var(--text-muted);font-weight:400;margin-top:2px}.planner-secondary-sidebar .pinned-section{margin-bottom:var(--spacing-md);margin-top:0;padding-top:0;border-top:none}.planner-secondary-sidebar .pinned-header{font-size:.7rem;font-weight:600;color:var(--text-muted);letter-spacing:.5px;padding:0 12px;margin-top:12px;margin-bottom:8px}.planner-secondary-sidebar .pinned-trip{padding:6px 8px;border-radius:var(--radius-sm);background-color:#eff6ff;color:var(--primary-blue);font-size:.8rem;cursor:pointer;margin-bottom:3px;display:flex;align-items:center;gap:4px;transition:all .2s;position:relative;line-height:1.3}.planner-secondary-sidebar .pinned-trip:hover{background-color:#dbeafe}.planner-secondary-sidebar .pinned-trip.active{background-color:var(--primary-blue);color:#fff}.planner-secondary-sidebar .pinned-trip.unpinned{background-color:#f1f5f9;color:var(--text-secondary)}.planner-secondary-sidebar .pinned-trip.unpinned:hover{background-color:#e2e8f0}.planner-secondary-sidebar .pinned-trip span{flex:1 1 0%}.planner-secondary-sidebar .trip-actions{display:flex;align-items:center;gap:4px;transition:opacity .2s;flex-shrink:0;margin-left:auto;align-self:center}.planner-secondary-sidebar .trip-actions .delete-btn,.planner-secondary-sidebar .trip-actions .unpin-btn,.planner-secondary-sidebar .trip-actions .pin-btn{background:transparent;border:none;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0;position:static;opacity:.6;top:auto;right:auto}.planner-secondary-sidebar .trip-actions .delete-btn{color:#ef4444}.planner-secondary-sidebar .trip-actions .delete-btn svg{width:14px;height:14px}.planner-secondary-sidebar .trip-actions .unpin-btn,.planner-secondary-sidebar .trip-actions .pin-btn{color:currentcolor}.planner-secondary-sidebar .trip-actions .unpin-btn{font-size:1.2rem}.planner-secondary-sidebar .pinned-trip:hover .trip-actions .delete-btn,.planner-secondary-sidebar .pinned-trip:hover .trip-actions .unpin-btn,.planner-secondary-sidebar .pinned-trip:hover .trip-actions .pin-btn{opacity:1}.planner-secondary-sidebar .trip-actions .delete-btn:hover{background-color:#ef44444d;color:#dc2626}.planner-secondary-sidebar .trip-actions .unpin-btn:hover,.planner-secondary-sidebar .trip-actions .pin-btn:hover{background-color:#0000001a}.planner-secondary-sidebar .pinned-trip.active .trip-actions .delete-btn{color:#fca5a5}.planner-secondary-sidebar .pinned-trip.active .trip-actions .delete-btn:hover{color:#fff;background-color:#ef444466}.new-plan-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);background:transparent;font-size:.85rem;cursor:pointer;margin-top:auto;transition:all .2s}.new-plan-btn-top{margin-top:0;margin-bottom:var(--spacing-md);background-color:var(--primary-blue);color:#fff;border-color:var(--primary-blue)}.new-plan-btn-top:hover{background-color:#2563eb;border-color:#2563eb}.new-plan-btn:hover{background-color:var(--bg-page);color:var(--text-main)}.trip-name-input{flex:1 1 0%;background:#fff;border:1px solid var(--primary-blue);border-radius:4px;padding:4px 8px;font-size:.85rem;color:var(--text-main);outline:none}.trip-name-input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.trip-chevron{display:flex;align-items:center;justify-content:center;padding:0;margin-right:2px;color:var(--text-secondary);transition:color .2s;flex-shrink:0}.trip-chevron:hover{color:var(--text-main)}.trip-sections{margin-left:0;margin-top:2px;margin-bottom:2px}.planner-secondary-sidebar .section-item{margin-bottom:2px;display:flex;flex-direction:column;padding:0}.section-row{display:flex;align-items:center;gap:5px;padding:4px 8px;border-radius:4px;cursor:pointer;transition:background-color .2s;font-size:.8rem;color:var(--text-secondary);line-height:1.3}.section-row:hover{background-color:var(--bg-page);color:var(--text-main)}.section-chevron{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:14px}.section-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary);width:14px}.section-name{flex:1 1 0%;font-size:.8rem;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-items{display:flex;flex-direction:column;margin-left:20px;margin-top:2px;gap:1px}.item-row{display:flex;align-items:center;padding:4px 8px;border-radius:4px;cursor:pointer;transition:background-color .2s;font-size:.75rem;color:var(--text-secondary);line-height:1.3}.item-row:hover{background-color:var(--bg-page);color:var(--text-main)}.item-name{flex:1 1 0%;overflow-wrap:break-word;white-space:normal;max-width:100%}[data-theme=dark] .section-row:hover,[data-theme=dark] .item-row:hover{background-color:#ffffff0d}.compact-search-bar{background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000001a}[data-theme=dark] .compact-search-bar{background:#1e293b;border-bottom-color:#334155;box-shadow:0 1px 3px #0000004d}.compact-search-bar-main{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;gap:24px}.results-count-compact{font-size:14px;font-weight:600;color:#1f2937;white-space:nowrap;min-width:140px}[data-theme=dark] .results-count-compact{color:#f1f5f9}.inline-search-editor{display:flex;align-items:center;gap:12px;flex:1 1 0%;justify-content:center;max-width:700px}.search-field-group{display:flex;align-items:center;gap:8px}.dates-field-group{display:flex;align-items:center;gap:4px}.calendar-icon-btn{background:none;border:none;padding:6px;cursor:pointer;border-radius:6px;color:var(--primary-blue);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.calendar-icon-btn:hover{background:#3b82f61a;transform:scale(1.1)}.calendar-icon-btn:active{transform:scale(.95)}.search-field{display:flex;flex-direction:row;align-items:center;gap:0;padding:6px 12px;border-radius:6px;background:#f9fafb;border:1px solid transparent;transition:all .2s;font-size:14px;color:#1f2937;white-space:nowrap}[data-theme=dark] .search-field{background:#334155;color:#f1f5f9}.search-field.clickable{cursor:pointer}.search-field.clickable:hover{background:#f3f4f6;border-color:#d1d5db}[data-theme=dark] .search-field.clickable:hover{background:#475569;border-color:#64748b}.search-field .field-value{font-weight:500;display:inline-block}.search-field .field-icon-left{color:#6b7280;flex-shrink:0;margin-right:6px;display:inline-block;vertical-align:middle}[data-theme=dark] .search-field .field-icon-left{color:#94a3b8}.search-field .field-icon-right{color:#6b7280;flex-shrink:0;margin-left:6px;display:inline-block;vertical-align:middle}[data-theme=dark] .search-field .field-icon-right{color:#94a3b8}.search-field .cabin-class{text-transform:capitalize}.field-input{border:none;background:transparent;outline:none;font-size:14px;font-weight:500;color:#1f2937;width:60px}.plane-icon{color:#6b7280;flex-shrink:0}[data-theme=dark] .plane-icon{color:#94a3b8}.price-mode-toggle-compact{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:8px}[data-theme=dark] .price-mode-toggle-compact{background:#334155}.price-mode-toggle-compact .price-mode-btn{padding:6px 16px;border:none;background:transparent;border-radius:6px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s;white-space:nowrap}[data-theme=dark] .price-mode-toggle-compact .price-mode-btn{color:#94a3b8}.price-mode-toggle-compact .price-mode-btn:hover{background:#e5e7eb}[data-theme=dark] .price-mode-toggle-compact .price-mode-btn:hover{background:#475569}.price-mode-toggle-compact .price-mode-btn.active{background:#fff;color:#1f2937;box-shadow:0 1px 2px #0000000d}[data-theme=dark] .price-mode-toggle-compact .price-mode-btn.active{background:#1e293b;color:#f1f5f9;box-shadow:0 1px 2px #0000004d}.compact-search-tabs-floating{display:flex;gap:4px;padding:0 24px 8px;background:transparent;position:relative;z-index:99}.compact-tab{padding:6px 16px;border:none;background:#fff;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;border-top:2px solid transparent;transition:all .2s;border-radius:0 0 6px 6px;box-shadow:0 2px 4px #0000001a}[data-theme=dark] .compact-tab{background:#1e293b;color:#94a3b8;box-shadow:0 2px 4px #0000004d}.compact-tab:hover{color:#1f2937;background:#f9fafb}[data-theme=dark] .compact-tab:hover{color:#f1f5f9;background:#334155}.compact-tab.active{color:#2563eb;border-top-color:#2563eb;background:#fff}[data-theme=dark] .compact-tab.active{color:#60a5fa;border-top-color:#60a5fa;background:#1e293b}@media(max-width:1024px){.compact-search-bar-main{flex-wrap:wrap;gap:12px}.results-count-compact{order:1;width:100%}.inline-search-editor{order:3;width:100%;max-width:none}.price-mode-toggle-compact{order:2;margin-left:auto}}@media(max-width:768px){.inline-search-editor{flex-wrap:wrap;gap:8px}.search-field{font-size:13px;padding:5px 10px}}.price-calendar-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}[data-theme=dark] .price-calendar-overlay{background:#000000b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.price-calendar-modal{background:var(--surface-white, white);border-radius:16px;padding:24px;max-width:500px;width:95%;max-height:90vh;overflow:visible;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;border:1px solid var(--border-subtle, #e5e7eb);position:relative}[data-theme=dark] .price-calendar-modal{box-shadow:0 20px 60px #0009;background:var(--surface-white)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.close-btn{position:absolute;top:16px;right:16px;background:none;border:none;padding:8px;cursor:pointer;border-radius:8px;color:var(--text-subtle, #6b7280);transition:all .2s ease;display:flex;align-items:center;justify-content:center;z-index:10}.close-btn:hover{background:var(--bg-page, #f3f4f6);color:var(--text-main, #1f2937)}[data-theme=dark] .close-btn:hover{background:var(--bg-page)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;margin-top:40px;gap:16px}.calendar-title{font-size:1.125rem;font-weight:600;color:var(--text-main, #1f2937);flex:1 1 0%;text-align:center}.nav-btn{background:none;border:none;padding:8px;cursor:pointer;border-radius:8px;color:var(--text-main, #1f2937);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.nav-btn:hover{background:var(--bg-page, #f3f4f6)}[data-theme=dark] .nav-btn:hover{background:var(--bg-page)}.price-calendar-modal .calendar-grid{width:100%;max-width:100%;display:flex;justify-content:center}.price-calendar-modal .calendar-days{max-width:400px;display:grid;grid-template-columns:repeat(7,1fr);gap:4px;width:100%}.price-calendar-modal .calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;width:100%}.price-calendar-modal .weekday{text-align:center;font-size:.65rem;font-weight:600;color:var(--text-muted, #6b7280);padding:4px}.price-calendar-modal .calendar-day{aspect-ratio:1;border:1px solid var(--border-subtle, #e5e7eb);border-radius:6px;background:var(--surface-white, white);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 2px;transition:all .2s ease;font-size:.75rem}.price-calendar-modal .calendar-day.empty{border:none;cursor:default;background:transparent}.price-calendar-modal .calendar-day:not(.empty,.past):hover{border-color:var(--primary-blue, #3b82f6);box-shadow:0 2px 8px #3b82f626;transform:translateY(-2px)}[data-theme=dark] .price-calendar-modal .calendar-day:not(.empty,.past):hover{box-shadow:0 2px 8px #3b82f64d}.price-calendar-modal .calendar-day.past{opacity:.3;cursor:not-allowed;background:var(--bg-page, #f9fafb)}[data-theme=dark] .price-calendar-modal .calendar-day.past{background:var(--bg-page)}.price-calendar-modal .calendar-day.selected{background:var(--primary-blue, #3b82f6);border-color:var(--primary-blue, #3b82f6);color:#fff}.price-calendar-modal .calendar-day.selected .day-number,.price-calendar-modal .calendar-day.selected .day-price{color:#fff}.price-calendar-modal .day-number{font-size:.8rem;font-weight:500;margin-bottom:2px;color:var(--text-main, #1f2937)}.price-calendar-modal .day-price{font-size:.6rem;font-weight:600;line-height:1}.price-calendar-modal .calendar-day.price-low .day-price{color:#10b981}.price-calendar-modal .calendar-day.price-mid .day-price{color:#f59e0b}.price-calendar-modal .calendar-day.price-high .day-price{color:#ef4444}.price-calendar-modal .calendar-loading{text-align:center;padding:16px;color:var(--text-subtle, #6b7280);font-size:.875rem}.price-calendar-modal .calendar-info{text-align:center;padding:12px 16px;margin-top:12px;background:var(--bg-page, #f9fafb);border-radius:8px}[data-theme=dark] .price-calendar-modal .calendar-info{background:var(--bg-page)}.comparison-modal-overlay{position:fixed;inset:0;background:#0000007f;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.comparison-modal{background:#fff;border-radius:16px;max-width:1200px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.comparison-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e5e7eb}.comparison-modal-header h2{margin:0;font-size:24px;font-weight:600;color:#1f2937}.comparison-modal-close{background:none;border:none;cursor:pointer;color:#6b7280;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.comparison-modal-close:hover{background:#f3f4f6;color:#1f2937}.comparison-modal-content{flex:1 1 0%;overflow-y:auto;padding:24px}.comparison-table{display:flex;flex-direction:column;gap:1px;background:#e5e7eb;border-radius:8px;overflow:hidden}.comparison-row{display:grid;grid-template-columns:180px repeat(auto-fit,minmax(200px,1fr));background:#fff}.comparison-header-row,.comparison-actions-row{background:#f9fafb}.comparison-cell{padding:16px;display:flex;align-items:center;justify-content:center;text-align:center}.comparison-label-cell{background:#f9fafb;font-weight:600;color:#374151;justify-content:flex-start;text-align:left}.comparison-flight-header{flex-direction:column;gap:4px}.comparison-flight-number{font-size:12px;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.comparison-flight-airline{font-weight:600;color:#1f2937}.comparison-value-cell{color:#4b5563;flex-direction:column;gap:4px}.comparison-price{font-size:24px;color:#3b82f6}.comparison-trip-type{font-size:12px;color:#6b7280}.comparison-airport{display:flex;align-items:center;gap:6px;color:#059669}.comparison-airport.nearby{color:#f59e0b}.comparison-actions{display:flex;flex-direction:column;gap:8px;width:100%}.btn-comparison-add,.btn-comparison-book{padding:10px 16px;border-radius:8px;border:none;cursor:pointer;font-weight:500;transition:all .2s;width:100%}.btn-comparison-add{background:#f3f4f6;color:#374151}.btn-comparison-add:hover{background:#e5e7eb}.btn-comparison-book{background:#3b82f6;color:#fff}.btn-comparison-book:hover{background:#2563eb}.recent-search-card{position:relative;display:flex;align-items:center;padding:8px 10px;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:100%;box-sizing:border-box}.recent-search-card:hover{background:var(--surface-subtle);border-color:var(--primary-blue);transform:translateY(-1px);box-shadow:0 4px 12px #0000000d}.recent-search-card.compact{padding:6px 8px;background:transparent;border-color:transparent;border-radius:4px}.recent-search-card.compact:hover{background:var(--surface-subtle);border-color:var(--border-subtle);transform:none;box-shadow:none}.recent-search-card.expired{border-color:#ef4444;background:linear-gradient(135deg,#ef44440d,#ef444405);box-shadow:0 0 0 1px #ef44441a,0 0 12px #ef444426;cursor:not-allowed;opacity:.85}.recent-search-card.expired:hover{transform:none;border-color:#ef4444}.recent-search-card .delete-btn{position:absolute;top:50%;right:4px;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;opacity:0;transition:all .2s ease;z-index:2}.recent-search-card:hover .delete-btn{opacity:1}.recent-search-card .delete-btn:hover{background:#fee2e2;color:#ef4444;border-radius:4px}.expired-badge{position:absolute;top:4px;right:4px;padding:1px 4px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;border-radius:2px;text-transform:uppercase}.search-content{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0;padding-right:16px}.search-route{color:var(--text-main);font-size:13px;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact .search-route{font-size:12px;font-weight:500;color:var(--text-secondary)}.recent-search-card.compact:hover .search-route{color:var(--primary-blue)}.search-details{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.detail{color:var(--text-muted);font-size:11px;line-height:1.2}.compact .detail{font-size:10px}.search-class{display:inline-block;padding:1px 4px;background:var(--surface-subtle);border-radius:3px;color:var(--text-secondary);font-size:9px;font-weight:500}body.dark-mode .recent-search-card{background:var(--glass-bg-dark);border-color:var(--border-dark)}body.dark-mode .recent-search-card:hover{background:#ffffff0d}body.dark-mode .recent-search-card.expired{background:linear-gradient(135deg,#ef444414,#ef444408)}.recent-searches-section{padding:0;margin:0;border-bottom:none;position:relative;z-index:5;width:100%;max-width:100%;box-sizing:border-box}.recent-searches-header{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;font-weight:600;color:var(--text-main);margin:0 0 var(--spacing-sm) 0;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.recent-searches-header:hover{color:var(--primary-blue)}.header-content{display:flex;align-items:center;gap:8px}.recent-searches-list{display:flex;flex-direction:column;gap:var(--spacing-xs);overflow:hidden;transition:max-height .3s ease-in-out,opacity .3s ease-in-out;width:100%;max-width:100%;box-sizing:border-box}.recent-searches-list::-webkit-scrollbar{width:4px}.recent-searches-list::-webkit-scrollbar-track{background:transparent}.recent-searches-list::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}.recent-searches-list.expanded{max-height:300px;opacity:1;overflow-y:auto}.recent-searches-list.collapsed{max-height:70px;opacity:1}.recent-search-item{padding:var(--spacing-sm);background:var(--glass-bg-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;gap:4px}.recent-search-item:hover{background:var(--button-bg-hover);transform:translate(4px)}.search-label{font-size:.85rem;font-weight:500;color:var(--text-main)}.search-meta{font-size:.75rem;color:var(--text-muted)}.no-searches{font-size:.85rem;color:var(--text-muted);padding:var(--spacing-sm)}.flight-filters-sidebar{width:100%;height:100%;display:flex;flex-direction:column;background:var(--glass-bg)}.filters-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-subtle);position:relative;background:var(--glass-bg);z-index:10}.filters-header h3{font-size:.95rem;font-weight:600;color:var(--text-main);margin:0}.clear-all-btn{display:flex;align-items:center;gap:4px;padding:8px 14px;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .15s;min-height:36px}.clear-all-btn:hover{background:var(--bg-page);color:var(--text-main);border-color:var(--text-muted)}.filters-content{flex:1 1 0%;overflow-y:auto;padding:8px 12px}.filter-section{margin-bottom:12px;border-bottom:1px solid var(--border-subtle);padding-bottom:12px}.filter-section:last-child{border-bottom:none}.filter-section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:6px 8px;border-radius:var(--radius-sm);transition:background .15s;-webkit-user-select:none;user-select:none}.filter-section-header:hover{background:var(--bg-page)}.filter-section-header h4{font-size:.85rem;font-weight:600;color:var(--text-main);margin:0}.filter-section-content{padding:8px 8px 0;display:flex;flex-direction:column;gap:4px}.price-slider{width:100%;height:6px;border-radius:3px;background:var(--bg-page);outline:none;appearance:none}.price-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-blue);cursor:pointer;transition:all .2s}.price-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #3b82f633}.price-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-blue);cursor:pointer;border:none;transition:all .2s}.price-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 4px #3b82f633}.price-range-labels{display:flex;justify-content:space-between;margin-top:var(--spacing-xs);font-size:.85rem;color:var(--text-secondary)}.scrollable-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-xs);padding-right:var(--spacing-xs)}.scrollable-list::-webkit-scrollbar{width:6px}.scrollable-list::-webkit-scrollbar-track{background:var(--bg-page);border-radius:3px}.scrollable-list::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}.scrollable-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px),(hover:none)and (pointer:coarse){.clear-all-btn{min-height:44px;min-width:44px;padding:10px 16px}.filter-section-header{min-height:48px;padding:12px}.price-slider::-webkit-slider-thumb{width:24px;height:24px}.price-slider::-moz-range-thumb{width:24px;height:24px}}.amenities-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.amenity-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 8px;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;text-align:center;min-height:80px}.amenity-button:hover{background:var(--bg-hover);border-color:var(--text-muted)}.amenity-button.selected{background:rgb(var(--primary-blue-rgb),.08);border-color:var(--primary-blue)}.amenity-button svg{color:var(--text-secondary);transition:color .2s ease;flex-shrink:0}.amenity-button.selected svg{color:var(--primary-blue)}.amenity-label{font-size:.75rem;font-weight:400;color:var(--text-main);line-height:1.3}.amenity-button.selected .amenity-label{color:var(--primary-blue);font-weight:500}.flagpole-amenities{display:flex;flex-direction:column;gap:4px;padding:4px 0}.flagpole-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface-white);border-radius:var(--radius-sm);transition:all .2s ease}.flagpole-item:hover{background:var(--bg-hover)}.flagpole-label-group{display:flex;align-items:center;gap:12px}.flagpole-icon{color:var(--text-secondary)}.flagpole-text{font-size:.85rem;color:var(--text-main);font-weight:500}body.dark-mode .flagpole-item{background:#ffffff08}body.dark-mode .flagpole-item:hover{background:#ffffff0d}.dual-range-slider{position:relative;width:100%;padding:0 4px}.slider{position:relative;width:100%;height:5px;margin:20px 0 10px}.slider-track{position:absolute;width:100%;height:5px;background:var(--border-subtle);border-radius:3px;z-index:1}.slider-range{position:absolute;height:5px;background:var(--primary-blue);border-radius:3px;z-index:2}.thumb{position:absolute;top:4px;width:100%;height:5px;background:transparent;pointer-events:none;appearance:none;z-index:3}.thumb::-webkit-slider-thumb{appearance:none;width:18px;height:18px;background:var(--primary-blue);border:2px solid white;border-radius:50%;cursor:pointer;pointer-events:all;box-shadow:0 2px 6px #00000026;transition:all .2s ease}.thumb::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 3px 8px #0003}.thumb::-moz-range-thumb{width:18px;height:18px;background:var(--primary-blue);border:2px solid white;border-radius:50%;cursor:pointer;pointer-events:all;box-shadow:0 2px 6px #00000026;transition:all .2s ease}.thumb::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 3px 8px #0003}.thumb-left{z-index:4}.thumb-right{z-index:5}.slider-labels{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.slider-label-min,.slider-label-max{font-size:.85rem;font-weight:600;color:var(--text-main)}.price-histogram{width:100%;height:60px;margin-top:12px;padding:0 2px}.histogram-bars{display:flex;align-items:flex-end;justify-content:space-between;height:100%;gap:1px}.histogram-bar{flex:1 1 0%;background:var(--primary-blue);border-radius:2px 2px 0 0;transition:all .2s ease;min-height:4px}.histogram-bar.in-range{background:var(--primary-blue);opacity:1}.histogram-bar.out-range{background:var(--border-subtle);opacity:.3}.hotel-search-sidebar{width:280px;height:100%;background:var(--bg-primary, #fff);border-right:1px solid var(--border-color, #e5e7eb);display:flex;flex-direction:column;position:relative;overflow:hidden}.hotel-search-sidebar.collapsed{width:40px;min-width:40px}.hotel-search-sidebar .collapse-btn,.hotel-search-sidebar .expand-btn{position:absolute;right:-12px;top:50%;transform:translateY(-50%);z-index:20;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.hotel-search-sidebar.collapsed .expand-btn{right:8px}.hotel-search-sidebar .collapse-btn:hover,.hotel-search-sidebar .expand-btn:hover{background:var(--bg-secondary, #f9fafb);transform:translateY(-50%) scale(1.1)}.hotel-search-sidebar .sidebar-header{padding:16px;border-bottom:1px solid var(--border-color, #e5e7eb);display:flex;align-items:center;justify-content:space-between}.hotel-search-sidebar .sidebar-header h3{font-size:18px;font-weight:600;margin:0;color:var(--text-primary, #111827)}.hotel-search-sidebar .clear-all-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:transparent;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:12px;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .2s}.hotel-search-sidebar .clear-all-btn:hover{background:var(--bg-secondary, #f9fafb);border-color:var(--border-hover, #d1d5db)}.hotel-search-sidebar .sidebar-content{flex:1;overflow-y:auto;padding:8px 0}.hotel-search-sidebar .filter-section{border-bottom:1px solid var(--border-color, #e5e7eb)}.hotel-search-sidebar .section-header{width:100%;padding:12px 16px;background:transparent;border:none;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:background .2s;font-size:14px;font-weight:500;color:var(--text-primary, #111827)}.hotel-search-sidebar .section-header:hover{background:var(--bg-secondary, #f9fafb)}.hotel-search-sidebar .section-header .header-left{display:flex;align-items:center;gap:8px}.hotel-search-sidebar .section-content{padding:12px 16px}.hotel-search-sidebar .search-input{width:100%;padding:8px 12px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:14px;transition:all .2s}.hotel-search-sidebar .search-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}@media(max-width:768px){.hotel-search-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color, #e5e7eb)}.hotel-search-sidebar.collapsed{display:none}}.hotel-card-skeleton{background:#fff;border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;display:flex;flex-direction:column}.skeleton-hotel-image{width:100%;height:200px;flex-shrink:0}.skeleton-hotel-info{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1}.skeleton-hotel-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.skeleton-hotel-name{flex:1;height:20px;max-width:200px}.skeleton-hotel-rating{width:60px;height:20px;flex-shrink:0}.skeleton-hotel-location{width:150px;height:14px}.skeleton-hotel-amenities{display:flex;gap:8px;flex-wrap:wrap}.skeleton-amenity{width:70px;height:24px;border-radius:12px}.skeleton-hotel-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px;border-top:1px solid #e5e7eb}.skeleton-hotel-price{display:flex;flex-direction:column;gap:4px}.skeleton-price-label{width:60px;height:12px}.skeleton-price-value{width:80px;height:24px}.skeleton-hotel-button{width:100px;height:36px;border-radius:6px}.hotel-results-skeleton{padding:20px}.skeleton-sort{width:120px;height:36px;border-radius:6px}.skeleton-hotel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}@media(max-width:768px){.skeleton-hotel-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.skeleton-hotel-image{height:160px}}@media(max-width:480px){.skeleton-hotel-grid{grid-template-columns:1fr}.skeleton-header{flex-direction:column;gap:12px}.skeleton-title,.skeleton-sort{width:100%}}.comparison-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-toast);padding:20px}.comparison-modal-compact{background:#fff;border-radius:12px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.comparison-header-compact{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:10}.comparison-header-compact h2{margin:0;font-size:1.4rem;font-weight:600;color:#1f2937}.close-btn{background:none;border:none;cursor:pointer;color:#6b7280;padding:8px;border-radius:8px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#1f2937}.comparison-body{padding:24px}.hotel-headers{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.hotel-header-card{background:#f9fafb;border-radius:10px;overflow:hidden;border:1px solid #e5e7eb}.hotel-header-img{width:100%;height:140px;object-fit:cover}.hotel-header-info{padding:12px}.hotel-header-info h3{margin:0 0 6px;font-size:1rem;font-weight:600;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hotel-location{display:flex;align-items:center;gap:6px;color:#6b7280;font-size:.85rem}.hotel-location svg{flex-shrink:0}.hotel-location span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.comparison-section{margin-bottom:24px}.section-title{font-size:1rem;font-weight:600;color:#1f2937;margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid #e5e7eb}.comparison-table{display:flex;flex-direction:column;gap:0;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.comparison-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;align-items:center;border-bottom:1px solid #e5e7eb;min-height:44px}.comparison-row:last-child{border-bottom:none}.row-label{padding:10px 14px;font-size:.85rem;font-weight:500;color:#4b5563;background:#f9fafb;border-right:1px solid #e5e7eb}.row-value{padding:10px 14px;font-size:.85rem;color:#1f2937;text-align:center;transition:all .2s}.row-value.better{background:linear-gradient(135deg,#d1fae5,#a7f3d0);font-weight:600;color:#065f46}.stars-inline{display:flex;gap:2px;justify-content:center}.amenities-comparison{display:flex;flex-direction:column;gap:0;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.amenity-row{display:grid;grid-template-columns:1.5fr 1fr 1fr;align-items:center;border-bottom:1px solid #e5e7eb;min-height:40px}.amenity-row:last-child{border-bottom:none}.amenity-label{padding:10px 14px;font-size:.85rem;font-weight:500;color:#4b5563;background:#f9fafb;border-right:1px solid #e5e7eb}.amenity-check{display:flex;align-items:center;justify-content:center;padding:10px}.check-icon{color:#10b981}.x-icon{color:#ef4444;opacity:.5}.pricing-summary{margin-top:24px;padding-top:24px;border-top:2px solid #e5e7eb}.pricing-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}.pricing-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px}.pricing-hotel-name{font-size:.95rem;font-weight:600;color:#1f2937;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.pricing-breakdown{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.pricing-line{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#4b5563}.pricing-line.total{margin-top:8px;padding-top:12px;border-top:1px solid #e5e7eb;font-weight:600;color:#1f2937}.total-price{font-size:1.1rem;color:#059669;font-weight:700}.book-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.book-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}@media(max-width:768px){.comparison-modal-compact{max-width:100%;border-radius:12px 12px 0 0;max-height:95vh}.hotel-headers{grid-template-columns:1fr}.comparison-row,.amenity-row{grid-template-columns:1fr .8fr .8fr;font-size:.8rem}.row-label,.amenity-label{font-size:.8rem}.row-value{font-size:.8rem;padding:8px 10px}.pricing-cards{grid-template-columns:1fr}}.hotel-search-bar-fixed{position:fixed;top:0;left:0;right:0;z-index:500;background:var(--surface-white);border-bottom:1px solid var(--border-subtle);box-shadow:0 2px 8px #00000014}.hotel-search-bar-content{display:flex;align-items:center;height:56px;max-width:100%;margin:0;padding:0 16px;gap:8px}.search-field{display:flex;flex-direction:column;justify-content:center;padding:0 16px;height:100%;cursor:pointer;transition:background .15s ease;position:relative;flex:1 1 0%;min-width:0}.search-field:hover,.search-field.editing{background:var(--surface-subtle)}.field-label{font-size:16px;font-weight:600;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;margin-bottom:2px}.field-display{display:flex;align-items:center;justify-content:center;gap:6px;color:var(--text-main);white-space:nowrap;overflow:hidden;width:100%}.field-display svg{flex-shrink:0;color:var(--primary-blue)}.field-value{font-size:16px;font-weight:500;overflow:hidden;text-overflow:ellipsis}.field-subtext{font-size:12px;color:var(--text-secondary);margin-left:4px}.field-edit{position:absolute;top:100%;left:0;margin-top:8px;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:0 8px 24px #0000001f;padding:12px;min-width:280px;z-index:1001}.close-edit-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px;z-index:1002}.close-edit-btn:hover{background:var(--surface-subtle);color:var(--text-main)}.field-divider{width:1px;height:32px;background:var(--border-subtle);flex-shrink:0}.search-bar-btn{display:flex;align-items:center;gap:8px;padding:0 20px;height:40px;margin-left:12px;border:none;background:linear-gradient(135deg,var(--primary-blue) 0%,#2563eb 100%);color:#fff;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3b82f64d;flex-shrink:0}.search-bar-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.search-bar-btn:active{transform:translateY(0)}.search-bar-hint{display:flex;align-items:center;gap:12px;text-align:center;font-size:11px;color:var(--text-muted);padding:2px 0;background:var(--surface-subtle);border-top:1px solid var(--border-subtle)}@media(max-width:768px){.hotel-search-bar-content{height:48px;padding:0 12px}.search-field{padding:0 8px}.field-label,.field-value{font-size:16px}.field-subtext{display:none}.search-bar-btn{padding:0 12px;height:36px;margin-left:8px}.search-bar-btn span{display:none}.field-edit{left:-50px;min-width:240px}}.search-bar-bottom{display:flex;align-items:center;justify-content:space-between;padding:6px 16px;background:var(--surface-subtle);border-top:1px solid var(--border-subtle);gap:16px}.results-count-inline{font-size:12px;font-weight:600;color:var(--text-secondary)}.hint-text{font-size:11px;color:var(--text-muted)}.view-tabs{display:flex;gap:2px;background:var(--surface-white);border-radius:6px;padding:2px;border:1px solid var(--border-subtle)}.view-tab{padding:4px 12px;font-size:12px;font-weight:500;background:transparent;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.view-tab:hover{background:var(--surface-subtle);color:var(--text-main)}.view-tab.active{background:var(--primary-blue);color:#fff}[data-theme=dark] .hotel-search-bar-fixed{background:var(--surface-elevated);border-color:var(--border-subtle)}[data-theme=dark] .search-field:hover,[data-theme=dark] .search-field.editing{background:var(--surface-subtle)}[data-theme=dark] .field-edit{background:var(--surface-elevated);border-color:var(--border-subtle)}[data-theme=dark] .search-bar-bottom{background:var(--surface-subtle);border-color:var(--border-subtle)}[data-theme=dark] .view-tabs{background:var(--surface-elevated)}.hotel-results-container{height:100%;display:flex;flex-direction:column;background-color:transparent;position:relative;overflow:hidden}.hotel-results-container.with-fixed-bar{padding-top:0}.compare-button-container{position:fixed;bottom:30px;left:50%;transform:translate(-50%);z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.compare-button{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:14px 32px;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 8px 24px #3b82f666;transition:all .3s ease;display:flex;align-items:center;gap:8px}.compare-button:hover{transform:translateY(-2px);box-shadow:0 12px 32px #3b82f67f;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.compare-button:active{transform:translateY(0)}.view-toggle-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding:12px 16px;background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.results-count{font-size:.95rem;font-weight:500;color:var(--text-secondary)}.results-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.results-heading{font-size:1.5rem;font-weight:700;color:var(--text-main);margin:0}.results-subtext{font-size:.9rem;color:var(--text-muted);margin:4px 0 0}.view-toggles{display:flex;gap:var(--spacing-sm)}.view-btn{padding:8px 16px;border:1px solid var(--border-subtle);background:var(--surface-white);color:var(--text-main);border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.view-btn:hover{background-color:var(--button-bg-hover)}.view-btn.active{background-color:var(--primary-blue);border-color:var(--primary-blue);color:#fff;box-shadow:var(--shadow-sm),0 0 8px var(--glow-blue)}.hotel-results-grid{position:absolute;inset:104px 0 0;overflow:hidden auto;padding:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-auto-rows:minmax(min-content,max-content);gap:12px;align-items:start;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.hotel-map-view{width:100%;height:calc(100dvh - 200px);min-height:600px;border-radius:var(--radius-md);overflow:hidden}.hotel-split-view{display:flex;flex-direction:column;gap:var(--spacing-md);height:auto}.hotel-results-grid.split-grid{grid-template-columns:1fr;gap:8px;overflow-y:visible;padding-right:0}.split-map{flex:1 1 0%;border-radius:var(--radius-md);overflow:hidden;height:400px;min-height:400px}.split-map .map-panel-fullwidth,.split-map .map-panel{height:100%;width:100%}.split-map .map-container,.split-map .google-map{height:100%}@media(max-width:767px){.hotel-results-container{padding:12px;padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + 80px)}.hotel-results-container.with-fixed-bar{padding-top:72px}.results-controls-bar{padding:6px 0;margin-bottom:8px}.results-controls-bar .results-count{font-size:13px}.results-controls-bar .view-toggles.compact .view-btn{padding:4px 10px;font-size:12px}.results-top-bar{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px}.results-heading{font-size:1.2rem}.results-subtext{font-size:.8rem}.view-toggles{width:100%;justify-content:flex-start;gap:8px}.view-btn{padding:8px 14px;font-size:.75rem;min-height:var(--touch-target-min);flex:1 1 0%}.hotel-split-view{flex-direction:column;height:auto}.split-grid{max-height:400px}.split-map{height:400px;position:relative}.hotel-map-view{height:500px;min-height:400px}}@media(min-width:768px){.hotel-results-container{padding:16px}.results-top-bar{margin-bottom:20px}.results-heading{font-size:1.4rem}.view-btn{padding:7px 14px;font-size:.8rem}.hotel-results-grid{gap:10px}.hotel-split-view{flex-direction:row;height:calc(100dvh - 200px);min-height:600px}.hotel-results-grid.split-grid{grid-template-columns:1fr;gap:10px;overflow-y:auto;padding-right:var(--spacing-sm);flex:0 0 50%;max-width:50%}.split-map{height:100%;position:sticky;top:0;flex:0 0 50%;max-width:50%}}@media(min-width:1024px){.hotel-results-container{padding:var(--spacing-lg)}.hotel-results-grid{gap:12px}.hotel-results-grid.split-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media(min-width:1440px){.hotel-results-grid{gap:12px}}@media(hover:none)and (pointer:coarse){.view-btn{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}.view-btn:hover{background-color:var(--surface-white)}.view-btn.active:hover{background-color:var(--primary-blue)}.view-btn:active{opacity:.8}}@media(prefers-reduced-motion:reduce){.view-btn{transition:none}}.experiences-results-wrapper{display:flex;min-height:100%}.experiences-main-content{flex:1 1 0%;padding:var(--spacing-lg);transition:all .3s ease;min-width:0}.experiences-main-content.sidebar-collapsed{padding-left:80px}.results-header{margin-bottom:var(--spacing-lg)}.header-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.results-header h2{font-size:1.8rem;font-weight:700;color:var(--text-main);display:flex;align-items:center;gap:var(--spacing-sm);margin:0}.results-count{font-size:.9rem;color:var(--text-muted);display:flex;align-items:center;gap:var(--spacing-xs)}.filtered-badge{background:#dbeafe;color:#1e40af;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase}.nearby-badge{background:linear-gradient(135deg,#e0f2fe,#dbeafe);color:#1e40af;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;text-transform:uppercase;display:inline-flex;align-items:center;gap:4px;margin-left:8px}.nearby-info-banner{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#e0f2fe,#dbeafe);border:1px solid #bfdbfe;border-radius:12px;padding:14px 18px;margin-bottom:24px;color:#1e40af;font-size:.95rem;font-weight:500}.nearby-info-banner svg{flex-shrink:0;color:#3b82f6}.clear-filters-btn{margin-top:var(--spacing-md);padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease}.clear-filters-btn:hover{background:#2563eb}.favorite-icon{position:absolute;top:12px;right:12px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff;border:none;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000001a;transition:all .2s ease;z-index:10}.favorite-icon:hover{transform:scale(1.1);box-shadow:0 4px 8px #00000026}.favorite-icon.active{background:#fef2f2}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.spinner{width:48px;height:48px;border:4px solid var(--border-subtle);border-top:4px solid var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-md)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p{color:var(--text-muted);font-size:1rem}.experiences-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;margin-top:24px}.experience-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:all .2s ease;cursor:pointer;display:flex;flex-direction:column}.experience-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.experience-image{width:100%;height:180px;position:relative;flex-shrink:0;overflow:hidden;background-color:#f5f5f5}.experience-image img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--border-subtle);color:var(--text-muted);font-size:var(--font-size-sm)}.experience-badges{position:absolute;top:var(--spacing-sm);left:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs);z-index:2}.category-badge{position:absolute;top:12px;left:12px;background:#fff;padding:6px 12px;border-radius:4px;font-size:.75rem;font-weight:600;color:#1a1a1a;box-shadow:0 2px 4px #0000001a}.experience-content{padding:12px;display:flex;flex-direction:column;flex-grow:1}.experience-rating{display:flex;align-items:center;gap:6px;margin-bottom:8px}.rating-star{color:#00aa6c;font-size:14px}.rating-value{font-size:14px;font-weight:600;color:#1a1a1a}.rating-count{font-size:14px;color:#767676}.experience-content h3{font-size:14px;font-weight:600;color:#1a1a1a;margin-bottom:6px;line-height:1.3;display:-webkit-box;-webkit-line-height-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.experience-features{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.feature-item{display:flex;align-items:center;gap:4px;font-size:12px;color:#767676}.feature-item.duration-feature{font-weight:500;color:#4b5563}.feature-icon{width:14px;height:14px;color:#767676;flex-shrink:0}.duration{display:flex;align-items:center;gap:4px;font-size:.875rem;color:var(--text-secondary)}.duration-filter{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.duration-filter button{padding:6px 12px;border:1px solid var(--border-subtle, #e5e7eb);border-radius:20px;background:#fff;cursor:pointer;font-size:.875rem;color:#374151;transition:all .2s ease}.duration-filter button:hover,.duration-filter button.active{background:var(--primary-blue, #3b82f6);color:#fff;border-color:var(--primary-blue, #3b82f6)}[data-theme=dark] .duration-filter button{background:#252b3a;border-color:#4a5568;color:#e8eaed}[data-theme=dark] .duration-filter button:hover,[data-theme=dark] .duration-filter button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.experience-footer{margin-top:auto;padding-top:10px}.price{display:flex;align-items:baseline;gap:3px}.price-label{font-size:11px;color:#767676}.price-value{font-size:18px;font-weight:700;color:#1a1a1a}.price-currency{font-size:13px;font-weight:600;color:#1a1a1a}.error-state,.empty-state{text-align:center;padding:60px 20px}.error-message{font-size:16px;color:#dc2626;margin-bottom:16px}.retry-btn{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.retry-btn:hover{background:#2563eb}.empty-state p{font-size:16px;color:#767676;margin-bottom:8px}.empty-hint{font-size:14px;color:#9ca3af}@media(max-width:1200px){.experiences-grid{gap:18px}.experience-image{height:170px}}@media(max-width:768px){.experiences-results-container{padding:16px}.experiences-grid{gap:16px}.experience-image{height:160px}.results-header h2{font-size:1.5rem}}@media(max-width:480px){.experience-image{height:200px}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.experience-card-skeleton{background:#fff;border-radius:12px;overflow:hidden;border:1px solid #e5e7eb;display:flex;flex-direction:column}.skeleton-experience-image{width:100%;height:180px;flex-shrink:0}.skeleton-experience-info{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1}.skeleton-experience-title{width:100%;height:18px}.skeleton-experience-subtitle{width:70%;height:14px}.skeleton-experience-rating{display:flex;align-items:center;gap:8px}.skeleton-stars{width:80px;height:16px}.skeleton-reviews{width:60px;height:14px}.skeleton-experience-meta{display:flex;gap:12px}.skeleton-meta-item{width:90px;height:20px;border-radius:10px}.skeleton-experience-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:12px;border-top:1px solid #e5e7eb}.skeleton-experience-price{display:flex;flex-direction:column;gap:4px}.skeleton-price-label{width:50px;height:12px}.skeleton-price-value{width:70px;height:22px}.skeleton-experience-button{width:90px;height:36px;border-radius:6px}.experience-results-skeleton{padding:20px}.skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.skeleton-title{width:200px;height:20px}.skeleton-filter{width:100px;height:36px;border-radius:6px}.skeleton-experience-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}@media(max-width:768px){.skeleton-experience-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.skeleton-experience-image{height:150px}}@media(max-width:480px){.skeleton-experience-grid{grid-template-columns:1fr}.skeleton-header{flex-direction:column;gap:12px}.skeleton-title,.skeleton-filter{width:100%}}.recent-search-carousel{padding:0;margin:0;background:transparent;border-radius:var(--radius-lg)}.carousel-title{font-size:.9rem;font-weight:600;color:#1e3a8a;text-align:center;margin-bottom:var(--spacing-sm)}.carousel-container{position:relative;overflow:hidden;width:100%;max-width:1072px;margin:0 auto}.carousel-track{display:flex;gap:12px;padding:4px;-webkit-user-select:none;user-select:none}.recent-search-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);background:var(--surface-white);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 14px;flex-shrink:0;width:240px;min-width:240px;min-height:70px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.recent-search-card:hover{background:var(--surface-subtle);border-color:var(--primary-blue);transform:translateY(-2px)}.recent-search-carousel .delete-btn{position:absolute;top:4px;right:4px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);font-size:16px;line-height:1;cursor:pointer;opacity:0;transition:all .2s ease;z-index:2}.recent-search-carousel .recent-search-card:hover .delete-btn{opacity:1}.recent-search-carousel .delete-btn:hover{background:#fee2e2;color:#ef4444;border-radius:4px}.search-details{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:100%;text-align:center}.destination{font-size:.9rem;font-weight:600;color:var(--text-main);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.travelers{font-size:.75rem;color:var(--text-muted)}@media(max-width:767px){.recent-search-card{width:180px;min-width:180px;min-height:60px}.destination{font-size:.8rem}.travelers{font-size:.7rem}.delete-btn{opacity:1}}.search-only-view{width:100%;height:100dvh;display:flex;align-items:center;justify-content:center;background-color:transparent;padding:var(--spacing-xl);overflow:hidden;transition:transform .4s cubic-bezier(.4,0,.2,1),opacity .4s ease}.search-only-view.slide-off{transform:translateY(-30px) scale(.95);opacity:0;pointer-events:none}.search-only-container{width:100%;max-width:1000px;margin:0 auto;display:flex;flex-direction:column;gap:0;transition:transform .4s cubic-bezier(.4,0,.2,1)}.search-only-view.slide-off .search-only-container{transform:translateY(-20px)}.recent-searches-section{width:100%}@media(max-width:767px){.search-only-view{padding:var(--spacing-md);padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--spacing-md));align-items:flex-start;padding-top:var(--spacing-lg)}.search-only-container{gap:0}}.experiences-sidebar-toggle{position:fixed;left:16px;top:100px;z-index:100;display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;font-size:14px;font-weight:500;color:#374151;transition:all .2s ease}.experiences-sidebar-toggle:hover{background:#f9fafb;box-shadow:0 4px 12px #00000026}[data-theme=dark] .experiences-sidebar-toggle{background:#1a1f2e;border-color:#2d333b;color:#e8eaed}[data-theme=dark] .experiences-sidebar-toggle:hover{background:#252b3a}.filter-badge{background:#3b82f6;color:#fff;font-size:16px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.experiences-sidebar{background:#fff;border-right:1px solid #e5e7eb;height:100%;overflow:hidden;flex-shrink:0}[data-theme=dark] .experiences-sidebar{background:#1a1f2e;border-right-color:#2d333b}.experiences-sidebar-inner{height:100%;overflow-y:auto;padding:16px;background:#fff}[data-theme=dark] .experiences-sidebar-inner{background:#1a1f2e}.experiences-sidebar-inner::-webkit-scrollbar{width:6px}.experiences-sidebar-inner::-webkit-scrollbar-track{background:transparent}.experiences-sidebar-inner::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.experiences-sidebar-inner::-webkit-scrollbar-thumb:hover{background:#9ca3af}[data-theme=dark] .experiences-sidebar-inner::-webkit-scrollbar-thumb{background:#4a5568}[data-theme=dark] .experiences-sidebar-inner::-webkit-scrollbar-thumb:hover{background:#718096}.sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}[data-theme=dark] .sidebar-header{border-bottom-color:#2d333b}.sidebar-header h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#111827;margin:0}[data-theme=dark] .sidebar-header h3{color:#e8eaed}.header-badge{background:#3b82f6;color:#fff;font-size:16px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.collapse-btn{background:none;border:none;padding:6px;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s ease}.collapse-btn:hover{background:#f3f4f6;color:#374151}[data-theme=dark] .collapse-btn{color:#8a9199}[data-theme=dark] .collapse-btn:hover{background:#252b3a;color:#e8eaed}.results-count{display:flex;align-items:baseline;gap:6px;margin-bottom:16px;padding:8px 12px;background:#f3f4f6;border-radius:8px}[data-theme=dark] .results-count{background:#252b3a}.count-number{font-size:20px;font-weight:700;color:#111827}[data-theme=dark] .count-number{color:#e8eaed}.count-label{font-size:13px;color:#6b7280}[data-theme=dark] .count-label{color:#8a9199}.sidebar-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}[data-theme=dark] .sidebar-section{border-bottom-color:#2d333b}.sidebar-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.section-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}[data-theme=dark] .section-title{color:#b8bdc3}.price-icon{font-size:14px;font-weight:700}.count-badge{background:#ef4444;color:#fff;font-size:16px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;margin-left:auto}.recent-searches-list{display:flex;flex-direction:column;gap:6px}.recent-search-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.recent-search-item:hover{background:#f3f4f6;border-color:#d1d5db}[data-theme=dark] .recent-search-item{background:#252b3a;border-color:#2d333b}[data-theme=dark] .recent-search-item:hover{background:#2d333b;border-color:#4a5568}.search-info{display:flex;flex-direction:column;gap:2px}.search-destination{font-size:14px;font-weight:500;color:#111827}[data-theme=dark] .search-destination{color:#e8eaed}.search-date{font-size:12px;color:#6b7280}[data-theme=dark] .search-date{color:#8a9199}.search-arrow{color:#9ca3af;flex-shrink:0}[data-theme=dark] .search-arrow{color:#718096}.empty-favorites{display:flex;flex-direction:column;align-items:center;padding:24px 16px;text-align:center;color:#6b7280}[data-theme=dark] .empty-favorites{color:#8a9199}.empty-icon{color:#d1d5db;margin-bottom:12px}[data-theme=dark] .empty-icon{color:#4a5568}.empty-favorites p{font-weight:500;margin-bottom:4px}.empty-favorites span{font-size:12px;color:#9ca3af}[data-theme=dark] .empty-favorites span{color:#718096}.favorites-list{display:flex;flex-direction:column;gap:8px}.favorite-item{display:flex;align-items:center;gap:10px;padding:8px;background:#f9fafb;border-radius:8px;cursor:pointer;transition:all .2s ease}.favorite-item:hover{background:#f3f4f6}[data-theme=dark] .favorite-item{background:#252b3a}[data-theme=dark] .favorite-item:hover{background:#2d333b}.favorite-image{width:48px;height:48px;border-radius:6px;object-fit:cover;flex-shrink:0}.favorite-info{flex:1 1 0%;min-width:0;display:flex;flex-direction:column;gap:2px}.favorite-title{font-size:13px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-theme=dark] .favorite-title{color:#e8eaed}.favorite-price{font-size:12px;color:#3b82f6;font-weight:600}[data-theme=dark] .favorite-price{color:#60a5fa}.remove-favorite-btn{background:none;border:none;padding:4px;border-radius:4px;cursor:pointer;color:#9ca3af;opacity:0;transition:all .2s ease}.favorite-item:hover .remove-favorite-btn{opacity:1}.remove-favorite-btn:hover{background:#fee2e2;color:#ef4444}.view-all-favorites{background:none;border:none;padding:8px;font-size:12px;color:#3b82f6;cursor:pointer;text-align:center;transition:color .2s ease}.view-all-favorites:hover{color:#2563eb;text-decoration:underline}[data-theme=dark] .view-all-favorites{color:#60a5fa}[data-theme=dark] .view-all-favorites:hover{color:#93c5fd}.price-slider-container{padding:8px 0}.price-range-display{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:16px;font-size:14px;font-weight:500;color:#374151}[data-theme=dark] .price-range-display{color:#e8eaed}.price-separator{color:#9ca3af}[data-theme=dark] .price-separator{color:#718096}.dual-slider{position:relative;height:6px;background:#e5e7eb;border-radius:3px}[data-theme=dark] .dual-slider{background:#4a5568}.slider{position:absolute;width:100%;height:6px;background:none;pointer-events:none;appearance:none;z-index:2}.slider::-webkit-slider-thumb{pointer-events:auto;appearance:none;width:18px;height:18px;background:#fff;border:2px solid #3b82f6;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000001a;transition:all .2s ease}.slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #3b82f64d}.slider::-moz-range-thumb{pointer-events:auto;width:18px;height:18px;background:#fff;border:2px solid #3b82f6;border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000001a}.slider-track{position:absolute;height:6px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:3px;z-index:1}.duration-options{display:flex;flex-wrap:wrap;gap:8px}.duration-pill{display:flex;align-items:center;gap:4px;padding:8px 14px;background:#fff;border:1px solid #d1d5db;border-radius:20px;font-size:12px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s ease}.duration-pill:hover{border-color:#9ca3af;background:#f9fafb}.duration-pill.active{background:#3b82f6;border-color:#3b82f6;color:#fff}[data-theme=dark] .duration-pill{background:#252b3a;border-color:#4a5568;color:#e8eaed}[data-theme=dark] .duration-pill:hover{background:#2d333b;border-color:#718096}[data-theme=dark] .duration-pill.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.pill-icon{animation:sparkle 1.5s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.category-options{display:flex;flex-direction:column;gap:6px}.category-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;color:#374151;cursor:pointer;transition:all .2s ease;text-align:left}.category-chip:hover{border-color:#d1d5db;background:#f9fafb}.category-chip.active{background:#eff6ff;border-color:#3b82f6;color:#1e40af}[data-theme=dark] .category-chip{background:#252b3a;border-color:#2d333b;color:#e8eaed}[data-theme=dark] .category-chip:hover{background:#2d333b;border-color:#4a5568}[data-theme=dark] .category-chip.active{background:#3b82f633;border-color:#3b82f6;color:#93c5fd}.checkbox{width:18px;height:18px;border:2px solid #d1d5db;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;transition:all .2s ease;flex-shrink:0}[data-theme=dark] .checkbox{border-color:#4a5568}.category-chip.active .checkbox{background:#3b82f6;border-color:#3b82f6}.rating-options{display:flex;flex-direction:column;gap:8px}.rating-option{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease}.rating-option:hover{border-color:#d1d5db;background:#f9fafb}.rating-option.active{background:#fffbeb;border-color:#f59e0b}[data-theme=dark] .rating-option{background:#252b3a;border-color:#2d333b}[data-theme=dark] .rating-option:hover{background:#2d333b;border-color:#4a5568}[data-theme=dark] .rating-option.active{background:#f59e0b33;border-color:#f59e0b}.stars{color:#f59e0b;font-size:14px;letter-spacing:2px}.rating-label{font-size:13px;font-weight:500;color:#374151}[data-theme=dark] .rating-label{color:#e8eaed}.toggle-section{display:flex;flex-direction:column;gap:12px}.toggle-option{display:flex;align-items:center;justify-content:space-between;cursor:pointer}.toggle-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#374151}[data-theme=dark] .toggle-label{color:#e8eaed}.toggle-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:4px;font-size:12px}[data-theme=dark] .toggle-icon{background:#2d333b}.toggle-switch{width:44px;height:24px;background:#e5e7eb;border-radius:12px;position:relative;cursor:pointer;border:none;padding:0;transition:background .2s ease}[data-theme=dark] .toggle-switch{background:#4a5568}.toggle-switch.active{background:#3b82f6}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000001a;transition:transform .2s ease}.toggle-switch.active .toggle-thumb{transform:translate(20px)}.sidebar-footer{padding-top:8px}.reset-filters-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:#fff;border:1px dashed #d1d5db;border-radius:8px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease}.reset-filters-btn:hover{border-color:#9ca3af;color:#374151;background:#f9fafb}[data-theme=dark] .reset-filters-btn{background:#252b3a;border-color:#4a5568;color:#8a9199}[data-theme=dark] .reset-filters-btn:hover{border-color:#718096;color:#e8eaed;background:#2d333b}@media(max-width:768px){.experiences-sidebar{position:fixed;left:0;top:0;height:-webkit-fill-available;z-index:1000;box-shadow:4px 0 20px #00000026}.experiences-sidebar-toggle{left:12px;top:80px;padding:8px 12px;font-size:13px}.experiences-sidebar-inner{padding:12px}}
