:root{--c-brand-50: #eef2ff;--c-brand-100: #e0e7ff;--c-brand-200: #c7d2fe;--c-brand-400: #818cf8;--c-brand-500: #6366f1;--c-brand-600: #4f46e5;--c-brand-700: #4338ca;--c-amber-50: #fffbeb;--c-amber-100: #fef3c7;--c-amber-200: #fde68a;--c-amber-400: #fbbf24;--c-amber-500: #f59e0b;--c-amber-600: #d97706;--c-amber-900: #78350f;--c-green-50: #f0fdf4;--c-green-100: #dcfce7;--c-green-600: #16a34a;--c-green-700: #15803d;--c-zinc-50: #fafafa;--c-zinc-100: #f4f4f5;--c-zinc-200: #e4e4e7;--c-zinc-300: #d4d4d8;--c-zinc-400: #a1a1aa;--c-zinc-500: #71717a;--c-zinc-600: #52525b;--c-zinc-700: #3f3f46;--c-zinc-800: #27272a;--c-zinc-900: #18181b;--bg-page: var(--c-zinc-50);--bg-surface: #ffffff;--bg-subtle: var(--c-zinc-100);--bg-hover: var(--c-brand-50);--bg-soft-row: #fffdf5;--border: var(--c-zinc-200);--border-strong: var(--c-zinc-300);--text-primary: var(--c-zinc-900);--text-secondary: var(--c-zinc-600);--text-muted: var(--c-zinc-400);--text-inverse: #ffffff;--text-link: var(--c-brand-600);--interactive: var(--c-brand-600);--interactive-hover: var(--c-brand-700);--interactive-focus: var(--c-brand-400);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: ui-monospace, "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-5: 1.25rem;--sp-6: 1.5rem;--sp-8: 2rem;--sp-10: 2.5rem;--sp-12: 3rem;--r-sm: 4px;--r-md: 6px;--r-lg: 10px;--r-xl: 16px;--r-full: 9999px;--shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 20px 40px rgb(0 0 0 / .15);--ease: cubic-bezier(.4, 0, .2, 1);--dur-fast: .1s;--dur-normal: .2s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-page);line-height:var(--leading-normal);min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{position:sticky;top:0;z-index:20;background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0 var(--sp-5);height:48px;display:flex;align-items:center;gap:var(--sp-3);box-shadow:var(--shadow-xs)}.logo{font-size:var(--text-base);font-weight:var(--font-bold);letter-spacing:-.02em;color:var(--text-primary);flex-shrink:0}.logo .i-host{position:relative;display:inline-block;color:inherit}.logo .i-host .spider{position:absolute;left:50%;top:-.14em;transform:translate(-50%);width:1.05em;height:.59em;pointer-events:none;overflow:visible;color:var(--interactive)}.logo span{color:var(--interactive)}.city-context{display:flex;align-items:center;gap:var(--sp-2);padding:3px var(--sp-3);background:var(--bg-subtle);border-radius:var(--r-md);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);flex-shrink:0}.city-dot{width:6px;height:6px;background:var(--interactive);border-radius:50%}.header-right{margin-left:auto;display:flex;align-items:center;gap:var(--sp-4)}.live-badge{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-xs);color:var(--text-muted)}.live-dot{width:6px;height:6px;background:var(--c-green-600);border-radius:50%}.settings-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;color:var(--text-secondary);font-size:14px;transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease);font-family:var(--font-sans)}.settings-btn:hover{background:var(--bg-subtle);color:var(--text-primary)}.filter-bar{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:var(--sp-2) var(--sp-5);display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.search-wrap{position:relative;flex-shrink:0}.search-icon{position:absolute;left:var(--sp-3);top:50%;transform:translateY(-50%);font-size:12px;color:var(--text-muted);pointer-events:none}.search-input{padding:var(--sp-2) var(--sp-3) var(--sp-2) var(--sp-8);border:1px solid var(--border-strong);border-radius:var(--r-md);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-surface);box-shadow:var(--shadow-xs);outline:none;width:200px;transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}.search-input:focus{border-color:var(--interactive-focus);box-shadow:0 0 0 3px var(--c-brand-100)}.search-input::placeholder{color:var(--text-muted)}.filter-group{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.filter-group-label{font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--font-medium);white-space:nowrap}.filter-input{width:68px;padding:var(--sp-1) var(--sp-2);border:1px solid var(--border-strong);border-radius:var(--r-md);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-surface);box-shadow:var(--shadow-xs);outline:none;transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease);-moz-appearance:textfield}.filter-input::-webkit-outer-spin-button,.filter-input::-webkit-inner-spin-button{-webkit-appearance:none}.filter-input:focus{border-color:var(--interactive-focus);box-shadow:0 0 0 3px var(--c-brand-100)}.filter-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.ambient-stats{margin-left:auto;display:flex;align-items:center;gap:var(--sp-4);font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0}.ambient-stats strong{color:var(--text-secondary);font-weight:var(--font-semibold)}.tbl-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;margin:var(--sp-4) var(--sp-5);box-shadow:var(--shadow-sm)}.tbl{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.tbl thead th{padding:var(--sp-2) var(--sp-3);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-subtle);border-bottom:1px solid var(--border);white-space:nowrap;user-select:none}.tbl thead th.sortable{cursor:pointer}.tbl thead th.sortable:hover{color:var(--text-secondary);background:var(--c-zinc-200)}.sort-icon{font-size:9px;margin-left:3px;color:var(--interactive)}.tbl tbody td{padding:var(--sp-3);border-bottom:1px solid var(--c-zinc-100);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:var(--bg-hover)}.row-expander{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:10px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);transition:color var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease);padding:0;font-family:var(--font-sans)}.row-expander:hover{color:var(--interactive);background:var(--c-brand-100)}.row-expander.open{color:var(--interactive)}.listing-link{color:var(--text-link);font-weight:var(--font-medium);text-decoration:none}.listing-link:hover{text-decoration:underline}.listing-link-read{color:var(--text-muted);font-weight:var(--font-normal)}.badge-new{display:inline-flex;align-items:center;padding:1px 6px;border-radius:var(--r-full);font-size:10px;font-weight:var(--font-semibold);letter-spacing:.04em;background:var(--interactive);color:var(--text-inverse);margin-right:var(--sp-2);vertical-align:middle;line-height:1.6}.listing-addr{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.price{font-weight:var(--font-semibold)}.price-good{color:var(--c-green-700)}.badge{display:inline-flex;align-items:center;padding:2px var(--sp-2);border-radius:var(--r-full);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1.5;white-space:nowrap}.badge-brand{background:var(--c-brand-100);color:var(--c-brand-700)}.badge-green{background:var(--c-green-100);color:var(--c-green-700)}.badge-amber{background:var(--c-amber-100);color:var(--c-amber-600)}.badge-neutral{background:var(--c-zinc-100);color:var(--c-zinc-600)}.tbl tbody tr.row-soft td{background:var(--bg-soft-row)}.tbl tbody tr.row-soft:hover td{background:var(--c-amber-50)}.tbl tbody tr.row-soft .listing-link,.tbl tbody tr.row-soft .price,.tbl tbody tr.row-soft .listing-addr{opacity:.65}.soft-separator td{padding:var(--sp-2) var(--sp-3)!important;background:var(--c-amber-50)!important;border-top:1px dashed var(--c-amber-200)!important;border-bottom:1px dashed var(--c-amber-200)!important;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--c-amber-600)}.soft-separator:hover td{background:var(--c-amber-50)!important}.tbl tbody tr.row-expanded td{background:var(--bg-hover)}.detail-cell{padding:0 var(--sp-3) var(--sp-3) 44px!important;background:var(--c-brand-50)!important}.detail-panel{background:var(--bg-surface);border:1px solid var(--c-brand-200);border-left:3px solid var(--interactive);border-radius:var(--r-lg);padding:var(--sp-4) var(--sp-5);font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.detail-panel a:not(.btn){color:var(--text-link)}.detail-panel table{border:none;width:auto;font-size:var(--text-xs)}.detail-panel th,.detail-panel td{border:none;padding:2px var(--sp-3) 2px 0;text-align:left;font-weight:var(--font-normal)}.detail-summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--sp-3) var(--sp-5);margin-bottom:var(--sp-4)}.detail-field{display:flex;flex-direction:column;gap:2px}.detail-label{font-size:10px;font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.detail-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:var(--font-medium)}.detail-no-desc{font-size:var(--text-xs);color:var(--text-muted);font-style:italic;margin-bottom:var(--sp-4)}.detail-unstructured{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--border);font-size:var(--text-xs);color:var(--text-secondary);line-height:var(--leading-relaxed)}.detail-unstructured strong{color:var(--text-primary)}.detail-actions{display:flex;justify-content:flex-start;padding-top:var(--sp-3);border-top:1px solid var(--border);margin-top:var(--sp-4)}a.btn{text-decoration:none}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-4);border-top:1px solid var(--border);background:var(--bg-subtle);font-size:var(--text-xs);color:var(--text-secondary);flex-wrap:wrap;gap:var(--sp-3)}.page-btns{display:flex;gap:var(--sp-1)}.page-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);border:1px solid transparent;background:none;font-size:var(--text-xs);cursor:pointer;color:var(--text-secondary);font-family:var(--font-sans);transition:all var(--dur-fast) var(--ease)}.page-btn:hover:not(:disabled){background:var(--bg-surface);border-color:var(--border)}.page-btn.current{background:var(--interactive);color:var(--text-inverse);border-color:var(--interactive)}.page-btn:disabled{opacity:.3;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:rgb(0 0 0 / .45);z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--sp-4)}.modal{background:var(--bg-surface);border-radius:var(--r-xl);padding:var(--sp-8);width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.modal-eyebrow{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.1em;color:var(--interactive);margin-bottom:var(--sp-2)}.modal-title{font-size:var(--text-xl);font-weight:var(--font-bold);letter-spacing:-.02em;margin-bottom:var(--sp-2)}.modal-sub{font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin-bottom:var(--sp-6)}.modal-section{margin-bottom:var(--sp-5)}.modal-label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:var(--sp-3);display:block}.city-cards{display:flex;gap:var(--sp-3)}.city-card{flex:1;padding:var(--sp-4) var(--sp-3);border:2px solid var(--border);border-radius:var(--r-lg);cursor:pointer;text-align:center;transition:all var(--dur-fast) var(--ease);background:none;font-family:var(--font-sans)}.city-card:hover{border-color:var(--c-brand-200);background:var(--bg-hover)}.city-card.selected{border-color:var(--interactive);background:var(--c-brand-50)}.city-card-icon{font-size:var(--text-2xl);display:block;margin-bottom:var(--sp-2)}.city-card-name{font-size:var(--text-sm);font-weight:var(--font-semibold);display:block;color:var(--text-primary)}.city-card-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px;display:block}.wbs-row{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--r-lg)}.wbs-title{font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:2px}.wbs-desc{font-size:var(--text-xs);color:var(--text-muted);line-height:1.4;max-width:220px}.toggle-wrap{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0;margin-left:var(--sp-4)}.toggle{position:relative;width:36px;height:20px;background:var(--c-zinc-300);border-radius:var(--r-full);cursor:pointer;transition:background var(--dur-fast) var(--ease);border:none;padding:0;flex-shrink:0}.toggle.on{background:var(--interactive)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:white;border-radius:50%;transition:transform var(--dur-normal) var(--ease);box-shadow:var(--shadow-xs)}.toggle.on:after{transform:translate(16px)}.destination-input{width:100%;padding:var(--sp-2) var(--sp-3);border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:var(--text-sm);color:var(--text-primary);background:var(--bg-card);box-sizing:border-box;transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}.destination-input:focus{outline:none;border-color:var(--interactive-focus);box-shadow:0 0 0 3px var(--c-brand-100)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-3);margin-top:var(--sp-6);padding-top:var(--sp-5);border-top:1px solid var(--border)}.btn{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);border-radius:var(--r-md);font-size:var(--text-sm);font-weight:var(--font-medium);font-family:var(--font-sans);cursor:pointer;border:1px solid transparent;transition:all var(--dur-fast) var(--ease);line-height:1}.btn-primary{background:var(--interactive);color:var(--text-inverse);border-color:var(--interactive)}.btn-primary:hover{background:var(--interactive-hover);border-color:var(--interactive-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border-strong)}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text-primary)}.empty-state{padding:var(--sp-12) var(--sp-8);text-align:center;color:var(--text-muted)}.empty-icon{font-size:2.5rem;margin-bottom:var(--sp-4)}.empty-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-secondary);margin-bottom:var(--sp-2)}.empty-desc{font-size:var(--text-sm);max-width:320px;margin:0 auto;line-height:var(--leading-relaxed)}.profile-switcher{position:relative}.profile-btn{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3);background:transparent;border:1px solid var(--border);border-radius:var(--r-full);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-primary);transition:background var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease)}.profile-btn:hover,.profile-btn.open{background:var(--bg-hover);border-color:var(--interactive-focus)}.profile-btn-name{font-weight:var(--font-semibold);color:var(--text-primary)}.profile-btn-city{font-size:var(--text-xs);color:var(--text-secondary);padding:1px var(--sp-2);background:var(--bg-subtle);border-radius:var(--r-full)}.profile-btn-caret{font-size:10px;color:var(--text-muted);margin-left:var(--sp-1)}.profile-dropdown{position:absolute;top:calc(100% + var(--sp-2));left:50%;transform:translate(-50%);min-width:220px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;padding:var(--sp-2) 0}.profile-item{display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-2) var(--sp-1) var(--sp-3);transition:background var(--dur-fast) var(--ease)}.profile-item:hover{background:var(--bg-subtle)}.profile-item.active{background:var(--bg-hover)}.profile-item-btn{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:1px;background:none;border:none;padding:var(--sp-1) 0;cursor:pointer;font-family:var(--font-sans);text-align:left;min-width:0}.profile-item-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.profile-item-city{font-size:var(--text-xs);color:var(--text-muted)}.profile-item-actions{display:flex;gap:2px;flex-shrink:0}.profile-action-btn{width:24px;height:24px;border:none;background:none;border-radius:var(--r-sm);cursor:pointer;font-size:var(--text-sm);color:var(--text-muted);display:flex;align-items:center;justify-content:center;transition:background var(--dur-fast) var(--ease),color var(--dur-fast) var(--ease)}.profile-action-btn:hover{background:var(--bg-subtle);color:var(--text-primary)}.profile-action-delete:hover{background:#fee2e2;color:#dc2626}.profile-edit-input{flex:1;border:1px solid var(--interactive-focus);border-radius:var(--r-sm);padding:2px var(--sp-2);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-surface);outline:none}.profile-new-btn{display:block;width:100%;padding:var(--sp-2) var(--sp-3);background:none;border:none;border-top:1px solid var(--border);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--interactive);text-align:left;transition:background var(--dur-fast) var(--ease);margin-top:var(--sp-1)}.profile-new-btn:hover{background:var(--bg-hover)}.soft-toggle-btn{background:none;border:none;cursor:pointer;font-family:var(--font-sans);font-size:var(--text-xs);color:var(--c-amber-600);font-weight:var(--font-medium);padding:var(--sp-1) var(--sp-2);border-radius:var(--r-sm);transition:background var(--dur-fast) var(--ease);letter-spacing:.01em}.soft-toggle-btn:hover{background:var(--c-amber-50)}
