*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1a1a2e;--ink2:#4a4a6a;--ink3:#8888aa;
  --paper:#fafaf7;--surface:#fff;--surface2:#f4f4f0;
  --accent:#c4622d;--accent2:#e8956d;--accentbg:#fdf0e8;
  --teal:#1d7a6e;--tealbg:#e8f5f3;--blue:#2563a8;--bluebg:#e8f0fb;
  --red:#cc3333;--redbg:#ffeaea;--gold:#b45309;--goldbg:#fffbeb;
  --border:#e4e4dc;--border2:#d0d0c4;
  --radius:12px;--radius-sm:8px;
  --font-display:'Playfair Display',serif;--font-body:'DM Sans',sans-serif;
  --shadow:0 2px 12px rgba(0,0,0,0.08);--shadow-lg:0 8px 32px rgba(0,0,0,0.14);
}
body{font-family:var(--font-body);background:var(--paper);color:var(--ink);min-height:100vh;font-size:14px;line-height:1.5}
.app{display:grid;grid-template-columns:280px 1fr;grid-template-rows:auto 1fr;min-height:100vh}
.topbar{grid-column:1/-1;background:var(--surface);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:100;overflow:visible;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.brand-bar{display:flex;align-items:center;padding:0 24px;height:48px;gap:12px;border-bottom:1px solid var(--border)}
.brand-spacer{flex:1}
.save-chip{display:flex;align-items:center;gap:5px}
.trip-bar{display:flex;align-items:center;padding:0 24px;height:62px;gap:16px;border-bottom:1px solid var(--border)}
.trip-identity{flex:1;min-width:0}
.trip-title-wrap{display:flex;align-items:center;gap:8px}.trip-title-wrap:hover .edit-hint{opacity:1}
.trip-name-input{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--ink);border:none;background:transparent;outline:none;width:100%;cursor:pointer;padding:0;line-height:1.2}
.trip-name-input:focus{cursor:text;border-bottom:2px solid var(--accent);padding-bottom:2px}
.trip-name-input::placeholder{color:var(--ink3)}
.edit-hint{font-size:15px;color:var(--ink3);opacity:0;transition:opacity .15s;flex-shrink:0;cursor:default;margin-top:2px}
.trip-meta{display:flex;align-items:center;flex-wrap:wrap;margin-top:5px}
.trip-meta-item{font-size:12px;color:var(--ink3)}
.trip-meta-dot{font-size:12px;color:var(--border2);margin:0 8px}
.currency-pill-select{font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:12px;padding:4px 8px;background:var(--surface2);cursor:pointer;color:var(--ink2);outline:none;font-family:var(--font-body);flex-shrink:0}
.currency-pill-select:focus{border-color:var(--accent)}
.feature-nav{display:flex;align-items:stretch;padding:0 16px;height:44px;gap:2px}
.fnav-btn{display:inline-flex;align-items:center;gap:6px;padding:0 14px;border:none;background:transparent;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;color:var(--ink2);transition:all .15s;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;text-decoration:none}
.fnav-btn:hover{color:var(--ink);background:var(--surface2)}
.fnav-icon{font-size:15px}
.fnav-sep{width:1px;background:var(--border);margin:10px 6px;flex-shrink:0}
.fnav-right{margin-left:auto;display:flex;align-items:stretch}
.fnav-share:hover{color:var(--blue);background:var(--bluebg)}
.fnav-export:hover{color:var(--teal);background:var(--tealbg)}
.fnav-split:hover{color:var(--gold);background:var(--goldbg)}
.sidebar{background:var(--surface);border-right:1px solid var(--border);overflow-y:auto;padding:16px}
.main{overflow-y:auto;padding:20px}
.logo{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--accent);white-space:nowrap}
.save-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0;transition:background .3s}
.save-dot.saving{background:#f59e0b;animation:pulse .8s infinite}
.save-label{font-size:11px;color:var(--ink3);white-space:nowrap}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.btn{padding:6px 12px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border2);background:var(--surface);color:var(--ink);transition:all .15s;white-space:nowrap}
.btn:hover{background:var(--surface2)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:#b5561f}
.btn-blue{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-blue:hover{background:#1d4f8a}
.btn-teal{background:var(--teal);color:#fff;border-color:var(--teal)}.btn-teal:hover{background:#166057}
.btn-danger{background:var(--redbg);color:var(--red);border-color:#ffcccc}.btn-danger:hover{background:#ffdddd}
.btn-sm{padding:4px 9px;font-size:11px}
.sidebar-section{margin-bottom:20px}
.sidebar-label{font-size:10px;font-weight:500;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.city-list{display:flex;flex-direction:column;gap:4px}
.city-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;border:1px solid transparent}
.city-item:hover{background:var(--surface2)}.city-item:hover .city-actions{opacity:1}.city-item.active{background:var(--accentbg);border-color:var(--accent2)}
.city-actions{display:flex;gap:3px;opacity:0;transition:opacity .15s;margin-left:auto;flex-shrink:0}
.city-action-btn{width:22px;height:22px;border-radius:4px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--ink3);transition:all .15s}
.city-action-btn:hover{background:var(--surface2);color:var(--ink)}.city-action-btn.del:hover{background:var(--redbg);color:var(--red)}
.city-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.city-name{font-size:14px;font-weight:500;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.city-dates{font-size:12px;color:var(--ink3)}
.city-connector{width:1px;height:12px;background:var(--border2);margin-left:16px}
.add-city-btn{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--ink3);border:1px dashed var(--border2);background:transparent;width:100%;transition:all .15s;margin-top:8px}
.add-city-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accentbg)}
.plus-icon{width:16px;height:16px;border-radius:50%;background:var(--border2);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--ink3);line-height:1;flex-shrink:0;transition:all .15s}
.add-city-btn:hover .plus-icon{background:var(--accent);color:#fff}
.summary-card{background:var(--surface2);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px}
.summary-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.summary-row:last-child{margin-bottom:0}
.summary-key{font-size:12px;color:var(--ink3)}.summary-val{font-size:12px;font-weight:500;color:var(--ink)}
.progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:8px}
.traveler-opt-in-btn{display:block;width:100%;margin-top:8px;padding:0;border:none;background:transparent;font-family:var(--font-body);font-size:11px;color:var(--ink3);cursor:pointer;text-align:left;transition:color .15s}
.traveler-opt-in-btn:hover{color:var(--accent)}
.traveler-names-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.traveler-clear-btn{border:none;background:transparent;font-size:11px;color:var(--ink3);cursor:pointer;padding:0;font-family:var(--font-body);transition:color .15s}
.traveler-clear-btn:hover{color:var(--red)}
.traveler-names-list{display:flex;flex-direction:column;gap:5px;margin-bottom:6px}
.traveler-name-row{display:flex;align-items:center;gap:5px}
.traveler-name-input{flex:1;padding:5px 8px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:12px;color:var(--ink);background:var(--paper);outline:none;transition:border-color .15s}
.traveler-name-input:focus{border-color:var(--accent)}
.traveler-remove-btn{width:22px;height:22px;border-radius:4px;border:1px solid var(--border);background:transparent;cursor:pointer;color:var(--ink3);font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s}
.traveler-remove-btn:hover:not(:disabled){background:var(--redbg);border-color:#ffaaaa;color:var(--red)}
.traveler-remove-btn:disabled{opacity:0.3;cursor:not-allowed}
.traveler-add-btn{border:none;background:transparent;font-family:var(--font-body);font-size:11px;color:var(--ink3);cursor:pointer;padding:0;transition:color .15s}
.traveler-add-btn:hover{color:var(--accent)}
.payer-chip{display:inline-flex;align-items:center;gap:4px;margin-top:5px;padding:2px 8px;border-radius:10px;background:var(--goldbg);color:var(--gold);font-size:11px;font-weight:500;border:1px solid #fde68a}
.split-total-note{font-size:12px;color:var(--ink3);margin-bottom:14px;padding:10px 12px;background:var(--surface2);border-radius:var(--radius-sm);text-align:center}
.split-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink3);margin-bottom:8px}
.split-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:4px}
.split-th{text-align:left;font-size:11px;font-weight:500;color:var(--ink3);padding:0 0 8px;border-bottom:1px solid var(--border)}
.split-th-num{text-align:right}
.split-name{padding:10px 12px 10px 0;font-weight:500;color:var(--ink);font-size:13px}
.split-cell{padding:10px 0 10px 8px;color:var(--ink2);text-align:right;font-size:13px}
.split-net-pos{color:var(--teal);font-weight:600}
.split-net-neg{color:var(--red);font-weight:600}
.split-divider{height:1px;background:var(--border);margin:16px 0}
.split-empty{padding:14px 16px;background:var(--surface2);border-radius:var(--radius-sm);font-size:13px;color:var(--ink3);line-height:1.5}
.split-even{padding:12px 16px;background:var(--tealbg);border-radius:var(--radius-sm);font-size:13px;color:var(--teal);font-weight:500}
.split-settle-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface2);border-radius:var(--radius-sm);margin-bottom:6px}
.split-settle-from,.split-settle-to{font-size:13px;font-weight:600;color:var(--ink)}
.split-settle-arrow{font-size:11px;color:var(--ink3)}
.split-settle-amount{margin-left:auto;font-size:15px;font-weight:700;color:var(--accent)}
.split-help{font-size:11px;color:var(--ink3);margin-top:12px;margin-bottom:8px;line-height:1.5}
/* ── Import preview modal ──────────────────────────────────────────────────── */
.imp-modal{max-width:660px;width:96vw;max-height:88vh;display:flex;flex-direction:column}
.imp-stats-bar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0}
.imp-modal-body{flex:1;overflow-y:auto;padding:16px 20px 8px}
.imp-stat{display:inline-flex;align-items:center;gap:4px;font-size:12px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:3px 10px;color:var(--ink2)}
.imp-stat-dest{color:var(--ink)}
.imp-stat-flight{color:var(--blue);background:var(--bluebg);border-color:#d0deff}
.imp-stat-train{color:var(--teal);background:var(--tealbg);border-color:#b8e0d8}
.imp-stat-hotel{color:var(--accent);background:#f0eeff;border-color:#d4c9ff}
.imp-stat-sight{color:#16a34a;background:#f0fdf4;border-color:#bbf7d0}
.imp-stat-review{color:#b45309;background:#fffbeb;border-color:#fde68a}
.imp-stat-warn{color:#92400e;background:#fef3c7;border-color:#fde68a}
/* Parse-error warnings */
.imp-warnings{background:#fef9ee;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:16px}
.imp-warn-title{font-size:12px;font-weight:600;color:#92400e;margin-bottom:4px}
.imp-warn-row{font-size:12px;color:#92400e;padding:3px 0;border-top:1px solid #fde68a;margin-top:3px}
/* Uncertain items section */
.imp-uncertain-section{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:20px;overflow:hidden}
.imp-uncertain-hdr{padding:12px 14px 8px;border-bottom:1px solid var(--border)}
.imp-uncertain-title{font-size:13px;font-weight:600;color:var(--ink);display:block}
.imp-uncertain-sub{font-size:12px;color:var(--ink3);margin-top:2px;display:block}
.imp-uncertain-card{padding:12px 14px;border-bottom:1px solid var(--border)}
.imp-uncertain-card:last-child{border-bottom:none}
.imp-uncertain-raw{margin-bottom:10px}
.imp-uncertain-source{font-size:11px;color:var(--ink3);display:block;margin-bottom:6px}
.imp-uncertain-vals{display:flex;flex-wrap:wrap;gap:5px}
.imp-uncertain-val{font-size:12px;background:var(--paper);border:1px solid var(--border);border-radius:4px;padding:2px 8px;color:var(--ink)}
.imp-uncertain-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
/* Per-item wrapper */
.imp-item-wrap{position:relative;margin-bottom:4px}
.imp-item-medium{border-left:3px solid #f59e0b;padding-left:6px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:8px}
.imp-item-editing{border-left:3px solid var(--accent);padding-left:6px;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
/* Confirm banner for medium-confidence */
.imp-review-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm) var(--radius-sm) 0 0;padding:7px 12px;font-size:12px}
.imp-review-label{color:#92400e;flex:1;min-width:140px}
.imp-review-yes{padding:3px 10px;background:#f59e0b;color:#fff;border:none;border-radius:12px;font-size:12px;cursor:pointer;font-family:var(--font-body)}
.imp-review-yes:hover{background:#d97706}
.imp-review-sep{color:var(--ink3);font-size:11px}
.imp-review-retype{font-size:12px;padding:3px 6px;border:1px solid var(--border);border-radius:6px;background:var(--surface2);color:var(--ink);font-family:var(--font-body);cursor:pointer}
/* Action bar */
.imp-item-bar{display:flex;gap:8px;padding:4px 2px 6px;opacity:0;transition:opacity .15s}
.imp-item-wrap:hover .imp-item-bar,.imp-item-editing .imp-item-bar{opacity:1}
.imp-action-btn{font-size:11px;color:var(--ink3);background:none;border:1px solid var(--border);border-radius:6px;padding:2px 9px;cursor:pointer;font-family:var(--font-body);transition:background .12s,color .12s}
.imp-action-btn:hover{background:var(--surface2);color:var(--ink)}
.imp-action-remove:hover{background:#fee2e2;color:var(--red);border-color:#fca5a5}
/* Inline edit form */
.imp-edit-form{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin:4px 0 8px}
.imp-ef-row{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.imp-ef-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:100px}
.imp-ef-group label{font-size:11px;font-weight:500;color:var(--ink3)}
.imp-ef-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}
.imp-empty-city{padding:8px 4px;color:var(--ink3);font-size:13px}
.split-alloc-tabs{display:flex;gap:4px;margin-top:6px}
.split-alloc-tab{padding:4px 12px;border-radius:16px;border:1px solid var(--border);background:var(--surface2);color:var(--ink2);font-size:12px;cursor:pointer;font-family:var(--font-body);transition:background .12s,color .12s}
.split-alloc-tab:hover{background:var(--surface3);color:var(--ink)}
.split-alloc-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.split-some-panel{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:8px}
.split-some-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);cursor:pointer}
.split-pct-panel{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.split-pct-row{display:flex;align-items:center;gap:8px}
.split-pct-name{flex:1;font-size:13px;color:var(--ink)}
.split-pct-input{width:64px!important;text-align:right}
.split-pct-sym{font-size:13px;color:var(--ink2);width:14px}
.split-pct-total{font-size:12px;color:var(--ink3);text-align:right;margin-top:2px}
.map-modal{max-width:860px;width:96vw}
.map-modal-body{display:flex;gap:0;height:460px;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.map-container{flex:1;min-width:0;background:var(--surface2)}
.map-loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:13px;color:var(--ink3)}
.map-empty{display:flex;align-items:center;justify-content:center;height:100%;font-size:13px;color:var(--ink3);text-align:center;padding:24px}
.map-unconfigured{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:28px;text-align:center}
.map-unconf-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:8px}
.map-unconf-body{font-size:12px;color:var(--ink3);line-height:1.6;max-width:340px}
.map-unconf-body code{background:var(--surface2);padding:1px 5px;border-radius:4px;font-size:11px}
.map-city-sidebar{width:220px;flex-shrink:0;border-left:1px solid var(--border);overflow-y:auto;background:var(--surface)}
.map-city-row{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s}
.map-city-row:hover{background:var(--surface2)}
.map-city-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.map-city-info{flex:1;min-width:0}
.map-city-name{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-city-sub{font-size:11px;color:var(--ink3);margin-top:1px}
.map-city-no-coords{font-size:10px;color:var(--ink3);font-style:italic}
.map-city-link{font-size:12px;color:var(--ink3);text-decoration:none;flex-shrink:0;padding:2px 4px;border-radius:4px;transition:color .12s}
.map-city-link:hover{color:var(--blue)}
.search-links-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.search-link-tile{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);text-decoration:none;color:var(--ink);background:var(--surface);transition:all .12s}
.search-link-tile:hover{background:var(--surface2);border-color:var(--border2);transform:translateY(-1px)}
.search-link-icon{font-size:20px;flex-shrink:0;width:26px;text-align:center}
.search-link-name{font-size:13px;font-weight:500;color:var(--ink)}
.search-link-desc{font-size:11px;color:var(--ink3);margin-top:1px}
.google-places-search{margin-bottom:4px}
.search-map-wrap{position:relative;margin-bottom:10px}
.search-map-container{width:100%;height:210px;border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden}
.search-area-btn{position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:10;background:#fff;border:1px solid var(--border2);border-radius:20px;padding:5px 14px;font-size:12px;font-weight:500;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.18);font-family:var(--font-body);color:var(--ink);white-space:nowrap;transition:all .12s}
.search-area-btn:hover{background:var(--surface2);box-shadow:0 3px 10px rgba(0,0,0,.22)}
.google-search-status{font-size:12px;color:var(--ink3);padding:10px 0;text-align:center}
.google-search-err{color:var(--red)}
.google-results-list{display:flex;flex-direction:column;gap:6px;margin-top:6px;max-height:200px;overflow-y:auto;padding-right:2px}
.google-result-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);transition:border-color .12s,background .12s}
.google-result-card.google-result-highlighted{border-color:var(--accent);background:var(--accentbg)}
.google-result-num{width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.google-result-info{flex:1;min-width:0}
.google-result-name{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.google-result-addr{font-size:11px;color:var(--ink3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.google-result-meta{font-size:11px;color:var(--gold);margin-top:2px}
.progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s}
.tabs{display:flex;gap:2px;background:var(--surface2);padding:4px;border-radius:var(--radius-sm);margin-bottom:22px;width:fit-content;flex-wrap:wrap}
.tab{padding:6px 14px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;color:var(--ink3);transition:all .15s;border:none;background:transparent;font-family:var(--font-body)}
.tab.active{background:var(--surface);color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.city-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;gap:12px}
.action-ribbon{display:flex;align-items:center;gap:6px;padding:10px 0 14px;border-bottom:1px solid var(--border);margin-bottom:18px}
.ribbon-group{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.ribbon-sep{width:1px;height:20px;background:var(--border2);margin:0 4px;flex-shrink:0}
.ribbon-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:20px;border:1.5px solid var(--border2);background:var(--surface);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;color:var(--ink2);transition:all .15s;white-space:nowrap}
.ribbon-btn:hover{background:var(--surface2)}
.rb-icon{font-size:13px;line-height:1}
.rb-flight:hover{border-color:var(--blue);color:var(--blue);background:var(--bluebg)}
.rb-train:hover{border-color:var(--teal);color:var(--teal);background:var(--tealbg)}
.rb-hotel:hover{border-color:var(--accent);color:var(--accent);background:var(--accentbg)}
.rb-sight:hover{border-color:#7a6550;color:#7a6550;background:#f5f0ea}
.rb-import{margin-left:auto;color:var(--ink3)}.rb-import:hover{border-color:var(--accent);color:var(--accent);background:var(--accentbg)}
.city-title{font-family:var(--font-display);font-size:26px;font-weight:500;color:var(--ink)}
.city-subtitle{font-size:13px;color:var(--ink3);margin-top:2px}
.city-header-actions{display:flex;gap:8px;flex-shrink:0;margin-top:4px}
.section{margin-bottom:24px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.section-title{font-size:14px;font-weight:500;color:var(--ink);display:flex;align-items:center;gap:8px}
.section-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:13px}
.icon-flight{background:var(--bluebg);color:var(--blue)}.icon-train{background:var(--tealbg);color:var(--teal)}
.icon-hotel{background:var(--accentbg);color:var(--accent)}.icon-sight{background:#f0ede8;color:#7a6550}
.item-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;margin-bottom:8px;transition:all .15s}
.item-card:hover{border-color:var(--border2);box-shadow:var(--shadow)}.item-card:hover .item-actions{opacity:1}
.item-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.item-name{font-size:13px;font-weight:500;color:var(--ink)}
.item-sub{font-size:12px;color:var(--ink3);margin-top:2px}
.item-datetime{font-size:11px;color:var(--ink3);margin-top:3px;display:flex;gap:10px;flex-wrap:wrap}
.item-datetime span{display:flex;align-items:center;gap:3px}
.item-meta{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.badge{padding:3px 8px;border-radius:20px;font-size:11px;font-weight:500}
.badge-blue{background:var(--bluebg);color:var(--blue)}.badge-teal{background:var(--tealbg);color:var(--teal)}
.badge-accent{background:var(--accentbg);color:var(--accent)}.badge-gray{background:var(--surface2);color:var(--ink3)}
.item-price{font-family:var(--font-display);font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap}
.converted-price{font-size:11px;color:var(--ink3);white-space:nowrap}
.item-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}
.icon-btn{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .15s}
.icon-btn.edit:hover{background:var(--bluebg);border-color:var(--blue);color:var(--blue)}
.icon-btn.delete:hover{background:var(--redbg);border-color:#ffaaaa;color:var(--red)}
.empty-state{text-align:center;padding:40px 20px;color:var(--ink3)}
.empty-state-title{font-size:14px;font-weight:500;color:var(--ink2);margin-bottom:6px}
.empty-state-sub{font-size:12px;margin-bottom:16px}
.modal-overlay{position:fixed;inset:0;background:rgba(26,26,46,.5);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding:50px 20px;backdrop-filter:blur(2px)}
.modal{background:var(--surface);border-radius:16px;width:100%;max-width:680px;box-shadow:var(--shadow-lg);overflow:hidden;max-height:90vh;display:flex;flex-direction:column}
.modal-header{padding:18px 20px 0;flex-shrink:0}
.modal-title{font-family:var(--font-display);font-size:17px;font-weight:500;margin-bottom:4px}
.modal-sub{font-size:12px;color:var(--ink3);margin-bottom:12px}
.modal-body{overflow-y:auto;padding:0 20px 20px;flex:1}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;flex-shrink:0}
.stype-tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.stype-tab{padding:4px 11px;border-radius:20px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--ink3);transition:all .15s}
.stype-tab.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.form-group{margin-bottom:12px}
.form-label{font-size:12px;font-weight:500;color:var(--ink2);margin-bottom:4px;display:block}
.form-input{width:100%;padding:8px 11px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none;background:var(--paper);transition:border-color .15s}
.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,98,45,.1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.divider-label{font-size:11px;font-weight:500;color:var(--ink3);text-transform:uppercase;letter-spacing:.8px;margin:12px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.datetime-picker-wrap{position:relative;display:flex;gap:6px;align-items:center}
.datetime-picker-wrap input[type=text]{flex:1;cursor:pointer}
.cal-icon-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface2);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;font-size:14px;transition:all .15s}
.cal-icon-btn:hover{background:var(--accentbg);border-color:var(--accent)}
.calendar-popup{position:absolute;top:calc(100% + 6px);left:0;z-index:500;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:12px;min-width:300px;user-select:none}
.calendar-popup.right{left:auto;right:0}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-nav{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s}
.cal-nav:hover{background:var(--surface2)}
.cal-month-year{font-size:13px;font-weight:600;color:var(--ink)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:10px}
.cal-dow{font-size:10px;font-weight:600;color:var(--ink3);text-align:center;padding:4px 0;text-transform:uppercase;letter-spacing:.5px}
.cal-day{font-size:12px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;color:var(--ink)}
.cal-day:hover:not(.cal-empty):not(.cal-disabled){background:var(--accentbg);color:var(--accent)}
.cal-day.cal-today{font-weight:700;color:var(--accent)}
.cal-day.cal-selected{background:var(--accent);color:#fff;font-weight:600}
.cal-day.cal-selected:hover{background:#b5561f}
.cal-day.cal-in-range{background:var(--accentbg)}
.cal-day.cal-disabled{color:var(--border2);cursor:default}
.cal-day.cal-empty{cursor:default}
.cal-time-row{display:flex;gap:8px;align-items:center;padding-top:10px;border-top:1px solid var(--border)}
.cal-time-label{font-size:11px;color:var(--ink3);white-space:nowrap}
.cal-time-input{flex:1;padding:5px 8px;border:1px solid var(--border2);border-radius:6px;font-size:12px;font-family:var(--font-body);outline:none;color:var(--ink);background:var(--paper)}
.cal-time-input:focus{border-color:var(--accent)}
.cal-footer{display:flex;gap:6px;margin-top:10px;justify-content:flex-end}
.cal-footer .btn{font-size:11px;padding:4px 10px}
.search-links{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px}
.search-link-card{display:flex;align-items:center;gap:10px;padding:10px 13px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;text-decoration:none;color:var(--ink);background:var(--surface)}
.search-link-card:hover{border-color:var(--border2);background:var(--surface2);box-shadow:var(--shadow)}
.sl-icon{font-size:17px;flex-shrink:0}.sl-name{font-size:12px;font-weight:500}.sl-desc{font-size:11px;color:var(--ink3)}.sl-arr{margin-left:auto;color:var(--ink3);font-size:11px}
.import-panel{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;margin-bottom:12px}
.import-panel-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px}
.import-help{font-size:12px;color:var(--ink3);margin-bottom:10px;line-height:1.5}
.import-results{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.import-empty{font-size:12px;color:var(--ink3);background:var(--surface);border:1px dashed var(--border2);border-radius:var(--radius-sm);padding:12px;line-height:1.45}
.import-mode-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:14px}
.import-mode-tab{flex:1;padding:10px 8px;text-align:center;font-size:13px;font-weight:500;cursor:pointer;color:var(--ink3);background:none;border:none;border-bottom:2px solid transparent;transition:all .15s;font-family:var(--font-body)}
.import-mode-tab:hover{color:var(--ink)}.import-mode-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.import-result-card{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px}
.import-result-img{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--surface2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:20px}
.import-result-main{flex:1;min-width:0}
.import-result-title{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.import-result-sub{font-size:11px;color:var(--ink3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bulk-import-textarea{min-height:90px;resize:vertical;font-family:ui-monospace,monospace;font-size:11px}
.manual-summary{cursor:pointer;font-size:12px;font-weight:500;color:var(--ink3);padding:6px 0;user-select:none}
details.manual-add-section>summary{list-style:none}
.color-picker-row{display:flex;gap:8px;margin-top:4px}
.color-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s;flex-shrink:0}
.color-swatch.active{border-color:var(--ink);transform:scale(1.15)}
.timeline-day{margin-bottom:24px}
.day-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.day-badge{width:34px;height:34px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;flex-shrink:0}
.day-title{font-size:14px;font-weight:500;color:var(--ink)}.day-sub{font-size:12px;color:var(--ink3)}
.timeline-items{padding-left:17px;border-left:2px solid var(--border);margin-left:17px;display:flex;flex-direction:column;gap:8px}
.timeline-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;margin-left:14px;position:relative}
.timeline-dot{position:absolute;left:-21px;top:11px;width:8px;height:8px;border-radius:50%;border:2px solid var(--surface);background:var(--accent)}
.timeline-dot.blue{background:var(--blue)}.timeline-dot.teal{background:var(--teal)}.timeline-dot.gray{background:var(--ink3)}
.timeline-time{font-size:11px;color:var(--ink3);margin-bottom:2px}.timeline-title{font-size:13px;font-weight:500;color:var(--ink)}.timeline-sub{font-size:11px;color:var(--ink3);margin-top:2px}
.confirm-overlay{position:fixed;inset:0;background:rgba(26,26,46,.6);z-index:300;display:flex;align-items:center;justify-content:center;padding:20px}
.confirm-box{background:var(--surface);border-radius:var(--radius);padding:24px;max-width:360px;width:100%;box-shadow:var(--shadow-lg)}
.confirm-title{font-size:15px;font-weight:500;color:var(--ink);margin-bottom:8px}
.confirm-sub{font-size:13px;color:var(--ink3);margin-bottom:18px;line-height:1.5}
.confirm-actions{display:flex;gap:8px;justify-content:flex-end}
.currency-select{padding:4px 8px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:11px;font-family:var(--font-body);background:var(--surface2);color:var(--ink);cursor:pointer;outline:none}
.rates-note{font-size:10px;color:var(--ink3);line-height:1.4}
.rates-note{font-size:10px;color:var(--ink3);margin-top:4px}
.storage-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;margin-top:10px;font-size:12px;color:var(--ink2)}
.share-option{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-bottom:10px}
.share-option-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:4px}
.share-option-desc{font-size:12px;color:var(--ink3);line-height:1.5;margin-bottom:10px}
.big-btn{width:100%;padding:9px 14px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:6px}
.data-preview{font-family:monospace;font-size:10px;color:var(--ink3);background:var(--paper);border:1px solid var(--border);border-radius:6px;padding:8px;max-height:55px;overflow:hidden;word-break:break-all;margin-bottom:8px}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.hidden{display:none!important}
.packing-category{margin-bottom:14px}
.packing-cat-header{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--ink3);margin-bottom:5px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.packing-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--radius-sm);margin-bottom:1px;transition:background .1s}
.packing-item:hover{background:var(--surface2)}
.packing-item.checked .packing-label{text-decoration:line-through;color:var(--ink3)}
.packing-label{font-size:13px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.city-autocomplete-drop{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:600;max-height:220px;overflow-y:auto}
.city-suggest-item{display:flex;align-items:baseline;gap:8px;padding:8px 11px;cursor:pointer;transition:background .1s}
.city-suggest-item:hover{background:var(--surface2)}
.city-suggest-name{font-size:13px;font-weight:500;color:var(--ink)}
.city-suggest-sub{font-size:11px;color:var(--ink3)}
.prepare-card{background:var(--tealbg);border:1px solid #b8e0d8;border-radius:var(--radius-sm);padding:11px;margin-bottom:8px;cursor:pointer;transition:all .15s}
.prepare-card:hover{border-color:var(--teal);box-shadow:var(--shadow)}
.prepare-card-title{font-size:12px;font-weight:600;color:var(--teal);margin-bottom:6px;display:flex;align-items:center;gap:5px}
.prepare-card-note{font-size:11px;color:var(--ink2);margin-top:5px}
.prep-section{margin-bottom:18px;padding-bottom:16px;border-bottom:1px solid var(--border)}
.prep-section:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
.prep-section-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:10px}
.weather-city{margin-bottom:14px}
.weather-city-name{font-size:12px;font-weight:600;color:var(--ink);margin-bottom:6px}
.weather-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}
.weather-day{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:42px;background:var(--surface2);border-radius:var(--radius-sm);padding:7px 4px}
.weather-dow{font-size:10px;font-weight:600;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px}
.weather-icon{font-size:18px;line-height:1}
.weather-hi{font-size:11px;font-weight:600;color:var(--ink)}
.weather-lo{font-size:10px;color:var(--ink3)}
.weather-loading{font-size:11px;color:var(--ink3)}
.app-toast{position:fixed;bottom:20px;right:20px;background:var(--ink);color:#fff;padding:9px 16px;border-radius:8px;font-size:13px;font-weight:500;z-index:9999;transition:opacity .3s;box-shadow:0 4px 16px rgba(0,0,0,.2);pointer-events:none}
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(26,26,46,.4);z-index:154}
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);z-index:150;padding:4px 0 env(safe-area-inset-bottom,4px)}
.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;background:none;border:none;cursor:pointer;font-size:10px;color:var(--ink3);font-family:var(--font-body);transition:color .15s}
.mobile-nav-btn:active,.mobile-nav-btn.mactive{color:var(--accent)}
.mobile-nav-icon{font-size:20px;line-height:1.2;display:block}
@media(max-width:700px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed!important;display:block!important;left:-290px;top:56px;bottom:0;width:280px;z-index:155;transition:left .25s ease;border-right:1px solid var(--border);overflow-y:auto}
  .sidebar.mobile-open{left:0;box-shadow:var(--shadow-lg)}
  .mobile-overlay.open{display:block}
  .mobile-nav{display:flex}
  .main{padding-bottom:72px}
  .search-links{grid-template-columns:1fr}
  .form-row,.form-row-3{grid-template-columns:1fr}
  #shareBtn,#myTripsBtn,#searchTopBtn{display:none!important}
  .app-toast{bottom:80px;right:12px}
}
.auth-modal-overlay{position:fixed;inset:0;background:rgba(26,26,46,.65);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px)}
.auth-modal{background:var(--surface);border-radius:16px;width:100%;max-width:380px;box-shadow:var(--shadow-lg);overflow:hidden}
.auth-tabs{display:flex;border-bottom:1px solid var(--border)}
.auth-tab{flex:1;padding:11px;text-align:center;font-size:13px;font-weight:500;cursor:pointer;color:var(--ink3);transition:all .15s;background:transparent;border:none;border-bottom:2px solid transparent;font-family:var(--font-body)}
.auth-tab:hover{color:var(--ink)}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.auth-body{padding:18px 20px 12px}
.auth-footer{padding:0 20px 16px;text-align:center;font-size:12px;color:var(--ink3)}
.share-banner{padding:8px 20px;display:flex;align-items:center;gap:10px;font-size:12px;border-bottom:1px solid var(--border);flex-wrap:wrap;grid-column:1/-1}
.share-banner.edit-mode{background:var(--goldbg);border-bottom-color:var(--gold)}
.share-banner.view-mode{background:var(--surface2)}
.presence-avatar{width:24px;height:24px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-left:-6px;border:2px solid var(--surface);cursor:default;transition:transform .15s}
.presence-avatar:first-child{margin-left:0}
.presence-avatar:hover{transform:translateY(-2px);z-index:1}
.user-menu-wrap{position:relative}
.user-menu-btn{display:flex;align-items:center;gap:5px;padding:4px 9px;border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface);cursor:pointer;font-size:12px;color:var(--ink);transition:all .15s;font-family:var(--font-body)}
.user-menu-btn:hover{background:var(--surface2)}
.user-avatar{width:20px;height:20px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.user-dropdown{position:fixed;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:9999;min-width:180px;padding:6px;display:flex;flex-direction:column;gap:2px}
.user-dropdown-email{padding:7px 10px;font-size:11px;color:var(--ink3);border-bottom:1px solid var(--border);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis}
.trip-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px;cursor:pointer;transition:all .15s}
.trip-list-item:hover{border-color:var(--border2);background:var(--surface2)}
.trip-list-item.active-trip{border-color:var(--accent2);background:var(--accentbg)}
.trip-item-title{font-size:13px;font-weight:500;color:var(--ink);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trip-item-meta{font-size:11px;color:var(--ink3)}
.share-link-row{display:flex;gap:6px;margin-top:6px;align-items:center}
.share-link-input{flex:1;padding:7px 10px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:11px;color:var(--ink);background:var(--surface2);font-family:ui-monospace,monospace;outline:none;min-width:0}
.collab-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--surface2);border-radius:var(--radius-sm);margin-bottom:5px;font-size:12px}
.collab-name{font-weight:500;flex:1;overflow:hidden;text-overflow:ellipsis}
.collab-role{font-size:11px;color:var(--ink3)}
.purchase-link{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--blue);text-decoration:none;padding:2px 7px;border-radius:4px;background:var(--bluebg);border:1px solid #d0deff;margin-top:5px}
.purchase-link:hover{background:#dce8ff}
.incoming-badge{font-size:10px;color:var(--teal);background:var(--tealbg);border:1px solid #b8e0d8;padding:2px 8px;border-radius:10px;margin-bottom:6px;display:inline-block}
.fulltrip-city-section{margin-bottom:28px}
.fulltrip-city-header{display:flex;align-items:center;gap:10px;padding:11px 15px;background:var(--surface2);border-radius:var(--radius-sm);margin-bottom:10px;border:1px solid var(--border)}
.fulltrip-city-name{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--ink)}
.fulltrip-city-dates{font-size:12px;color:var(--ink3);margin-top:1px}
.fulltrip-items{padding-left:4px}
.ft-filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.ft-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;border:1px solid var(--border);background:var(--surface2);color:var(--ink2);font-size:13px;font-family:var(--font-body);cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.ft-filter-btn:hover{background:var(--surface3);color:var(--ink)}
.ft-filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.landing-page{position:fixed;inset:0;background:var(--paper);z-index:500;overflow-y:auto;transition:opacity .35s,transform .35s}
.landing-page.hiding{opacity:0;transform:translateY(-14px);pointer-events:none}
.landing-nav{position:sticky;top:0;background:rgba(250,250,247,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:0 40px;height:58px;display:flex;align-items:center;justify-content:space-between;z-index:10}
.landing-hero{max-width:820px;margin:0 auto;padding:96px 40px 72px;text-align:center}
.landing-eyebrow{font-size:11px;font-weight:500;letter-spacing:1.8px;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.landing-h1{font-family:var(--font-display);font-size:52px;font-weight:600;color:var(--ink);line-height:1.08;margin-bottom:22px}
.landing-sub{font-size:17px;color:var(--ink2);line-height:1.65;max-width:500px;margin:0 auto 36px}
.landing-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.landing-btn{padding:11px 26px;font-size:14px;border-radius:10px}
.landing-pills{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:0 40px 56px;max-width:860px;margin:0 auto}
.landing-pill{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;background:var(--surface);border:1px solid var(--border2);color:var(--ink2)}
.landing-features{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:64px 40px}
.landing-section-title{font-family:var(--font-display);font-size:28px;font-weight:500;color:var(--ink);text-align:center;margin-bottom:44px}
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;max-width:900px;margin:0 auto}
.feature-card{background:var(--paper);border:1px solid var(--border);border-radius:var(--radius);padding:22px 22px 20px}
.feature-icon-wrap{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.feature-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:7px}
.feature-desc{font-size:13px;color:var(--ink2);line-height:1.58}
.landing-cta-strip{text-align:center;padding:64px 40px}
.landing-cta-strip h2{font-family:var(--font-display);font-size:26px;font-weight:500;color:var(--ink);margin-bottom:10px}
.landing-cta-strip p{font-size:14px;color:var(--ink2);margin-bottom:28px}
.landing-footer{padding:22px 40px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--ink3);flex-wrap:wrap;gap:10px}
.landing-footer a{color:var(--accent);text-decoration:none}
@media(max-width:600px){
  .landing-nav{padding:0 20px}
  .landing-hero{padding:60px 20px 48px}
  .landing-h1{font-size:36px}
  .landing-sub{font-size:15px}
  .landing-pills{padding:0 20px 40px}
  .landing-features{padding:44px 20px}
  .landing-cta-strip{padding:44px 20px}
  .landing-footer{padding:18px 20px}
}
