  /* ===== Trip · trim-to-budget builder (.tb-*) ===== */
  .tb-page { background:#FAF8F4; }
  .tb-wrap { max-width:1240px; margin:0 auto; padding:34px 40px 90px; }
  .tb-grid { display:grid; grid-template-columns:396px minmax(0,1fr); gap:30px; align-items:start; }
  .tb-reckon { position:sticky; top:88px; display:flex; flex-direction:column; gap:16px; }
  .tb-card { background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); border-radius:22px; padding:28px; box-shadow:0 1px 2px rgba(8,12,28,.04); }
  .tb-total { font-family:'Hanken Grotesk',sans-serif; font-weight:700; letter-spacing:-0.03em; font-size:54px; line-height:.95; margin-top:14px; transition:color .4s ease; }
  .tb-total-sub { display:inline-block; margin-left:12px; font-size:14px; font-weight:400; letter-spacing:0; color:color-mix(in oklab,#0F1B3D 56%, white); vertical-align:baseline; }
  .tb-meter { position:relative; margin-top:30px; }
  .tb-meter-track { position:relative; width:100%; height:18px; border-radius:999px; background:#F4F1EA; overflow:hidden; }
  .tb-meter-green { position:absolute; left:0; top:0; bottom:0; border-radius:999px; transition:width .55s cubic-bezier(.4,0,.1,1), background .4s ease; }
  .tb-meter-red { position:absolute; top:0; bottom:0; background:#D6453B; background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.16) 0 6px,transparent 6px 12px); transition:width .55s cubic-bezier(.4,0,.1,1), left .55s cubic-bezier(.4,0,.1,1); }
  .tb-tick { position:absolute; top:-5px; bottom:-5px; width:2px; background:#0F1B3D; border-radius:2px; transition:left .55s cubic-bezier(.4,0,.1,1); }
  .tb-tick span { position:absolute; top:-20px; left:50%; transform:translateX(-50%); font:700 10.5px/1 'Hanken Grotesk',sans-serif; letter-spacing:.04em; color:#0F1B3D; white-space:nowrap; }
  .tb-pill-row { margin-top:22px; }
  .tb-pill { display:inline-flex; align-items:center; gap:6px; padding:7px 13px; border-radius:999px; font:700 14px/1 'Hanken Grotesk',sans-serif; }
  .tb-trim { margin-top:22px; padding-top:20px; border-top:1px solid color-mix(in oklab,#0F1B3D 9%, white); }
  .tb-trim-head { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:6px; font-size:13px; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-trim-head strong { color:#0F1B3D; font-weight:700; font-size:13.5px; }
  .tb-trim-track { height:7px; border-radius:999px; background:#F4F1EA; overflow:hidden; }
  .tb-trim-fill { height:100%; background:#FF6B57; border-radius:999px; transition:width .5s cubic-bezier(.4,0,.1,1); }
  .tb-fits { margin-top:22px; padding-top:20px; border-top:1px solid color-mix(in oklab,#0F1B3D 9%, white); display:flex; align-items:center; gap:12px; }
  .tb-fits-ic { flex:none; width:38px; height:38px; border-radius:999px; background:#1C8C5B; color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; }
  .tb-fits strong { display:block; font:700 15px/1.3 'Hanken Grotesk',sans-serif; color:#1C8C5B; }
  .tb-fits span { font-size:12.5px; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-action { width:100%; height:52px; margin-top:18px; border-radius:15px; border:none; cursor:pointer; background:#0F1B3D; color:#fff; font:700 15.5px/1 'Hanken Grotesk',sans-serif; display:flex; align-items:center; justify-content:center; gap:9px; box-shadow:0 10px 22px color-mix(in oklab,#0F1B3D 26%, transparent); }
  .tb-action.ghost { background:#fff; color:#0F1B3D; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); box-shadow:none; }
  .tb-fields { margin-top:22px; padding-top:20px; border-top:1px solid color-mix(in oklab,#0F1B3D 9%, white); display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; }
  .tb-fields-budget { grid-template-columns:1fr; }
  .tb-trip-meta { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:12px; font-size:13.5px; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-trip-meta strong { color:#0F1B3D; font-weight:700; }
  .tb-editlink { appearance:none; border:none; background:none; cursor:pointer; padding:4px 2px; font:700 13px/1 'Hanken Grotesk',sans-serif; color:#FF6B57; }
  .tb-editlink:hover { text-decoration:underline; }
  .tb-field { display:flex; flex-direction:column; gap:6px; }
  .tb-field > span { font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:.04em; text-transform:uppercase; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-input { display:flex; align-items:center; gap:4px; height:40px; padding:0 10px; border-radius:11px; background:#FAF8F4; border:1px solid color-mix(in oklab,#0F1B3D 10%, white); font:700 14px/1 'Hanken Grotesk',sans-serif; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-input input { width:100%; min-width:0; border:none; outline:none; background:none; font:700 14px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .tb-input input::-webkit-outer-spin-button, .tb-input input::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
  .tb-note { margin:0; padding:0 6px; font-size:12.5px; line-height:1.5; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-list-head { display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
  .tb-head-right { display:flex; align-items:center; gap:14px; }
  .tb-h2 { margin:0; font-family:'Hanken Grotesk',sans-serif; font-weight:700; letter-spacing:-0.03em; font-size:26px; color:#0F1B3D; }
  .tb-count { font-size:13.5px; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-list-sub { margin:8px 0 20px; font-size:14.5px; line-height:1.5; color:color-mix(in oklab,#0F1B3D 56%, white); max-width:620px; }
  .tb-list { display:flex; flex-direction:column; gap:10px; }
  .tb-row { display:flex; align-items:center; gap:14px; padding:14px 16px; border-radius:16px; background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); transition:opacity .25s ease; }
  .tb-row.off { opacity:.55; background:transparent; }
  .tb-row.off .tb-rowname { text-decoration:line-through; }
  .tb-thumb { flex:none; width:52px; height:52px; border-radius:13px; background-size:cover; background-position:center; background-color:#eceae4; }
  .tb-thumb.glyph { display:flex; align-items:center; justify-content:center; }
  .tb-rowmid { flex:1; min-width:0; }
  .tb-rowname { font:700 15.5px/1.2 'Hanken Grotesk',sans-serif; letter-spacing:-0.015em; color:#0F1B3D; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .tb-basis { margin-top:3px; font-size:12.5px; color:color-mix(in oklab,#0F1B3D 56%, white); display:flex; align-items:center; gap:5px; }
  .tb-unit { width:52px; border:1px solid color-mix(in oklab,#0F1B3D 12%, white); border-radius:8px; padding:3px 6px; font:700 12.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; background:#FAF8F4; outline:none; }
  .tb-unit::-webkit-outer-spin-button, .tb-unit::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
  .tb-rowright { display:flex; align-items:center; gap:16px; flex-shrink:0; }
  .tb-cost { min-width:60px; text-align:right; font:700 15.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .tb-row.off .tb-cost { color:color-mix(in oklab,#0F1B3D 56%, white); text-decoration:line-through; }
  .tb-core { width:46px; text-align:center; font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:.04em; text-transform:uppercase; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .tb-toggle { width:46px; height:27px; border-radius:999px; border:none; cursor:pointer; background:color-mix(in oklab,#0F1B3D 12%, white); position:relative; padding:0; transition:background .2s ease; flex-shrink:0; }
  .tb-toggle.on { background:#FF6B57; }
  .tb-knob { position:absolute; top:3px; left:3px; width:21px; height:21px; border-radius:999px; background:#fff; box-shadow:0 1px 3px rgba(8,12,28,.25); transition:left .2s cubic-bezier(.4,0,.1,1); }
  .tb-toggle.on .tb-knob { left:22px; }
  @media (max-width:900px) {
    .tb-wrap { padding:22px 16px 96px; }
    .tb-grid { grid-template-columns:1fr; gap:22px; }
    .tb-reckon { position:static; }
  }

  /* ===== Trip · tabbed shell + day-by-day Itinerary (.it-*), v127 ===== */
  .it-page { background:#FAF8F4; }
  .it-wrap { max-width:1240px; margin:0 auto; padding:30px 40px 96px; }
  .it-summary { display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:18px; }
  .it-title { margin:0; font-family:'Hanken Grotesk',sans-serif; font-weight:700; letter-spacing:-0.03em; font-size:30px; color:#0F1B3D; }
  .it-meta { display:flex; align-items:center; gap:9px; margin-top:7px; font-size:14px; color:color-mix(in oklab,#0F1B3D 58%, white); }
  .it-meta i { opacity:.5; font-style:normal; }
  .it-pace { border:1px solid color-mix(in oklab,#0F1B3D 14%, white); background:#fff; border-radius:999px; padding:4px 12px; font:600 13px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; cursor:pointer; }
  .it-pace:hover { border-color:#FF6B57; color:#FF6B57; }
  .it-edit { appearance:none; border:none; background:none; padding:0; margin:0; cursor:pointer; font:inherit; color:inherit; border-bottom:1px dashed color-mix(in oklab,#0F1B3D 32%, white); }
  .it-edit:hover { color:#FF6B57; border-bottom-color:#FF6B57; }
  .it-sum-budget { text-align:right; }
  .it-sum-label { display:block; font:700 10.5px/1 'Hanken Grotesk',sans-serif; letter-spacing:.06em; text-transform:uppercase; color:color-mix(in oklab,#0F1B3D 50%, white); margin-bottom:4px; }
  .it-sum-amt { font:700 20px/1 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; color:#1F8A5B; }
  .it-sum-amt i { font-style:normal; font-weight:400; color:color-mix(in oklab,#0F1B3D 50%, white); }
  .it-sum-budget.over .it-sum-amt { color:#D6453B; }
  .it-tabs { display:flex; gap:4px; border-bottom:1px solid color-mix(in oklab,#0F1B3D 10%, white); margin-bottom:24px; }
  .it-tab { appearance:none; border:none; background:none; cursor:pointer; padding:11px 16px; font:600 14.5px/1 'Hanken Grotesk',sans-serif; color:color-mix(in oklab,#0F1B3D 56%, white); border-bottom:2px solid transparent; margin-bottom:-1px; white-space:nowrap; }
  .it-tab:hover { color:#0F1B3D; }
  .it-tab.on { color:#0F1B3D; border-bottom-color:#FF6B57; }
  .it-grid { display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:28px; align-items:start; }
  .it-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:6px; }
  .it-h2 { margin:0; font-family:'Hanken Grotesk',sans-serif; font-weight:700; letter-spacing:-0.03em; font-size:22px; color:#0F1B3D; }
  .it-sub { margin:4px 0 0; font-size:13.5px; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .it-modes { display:flex; align-items:center; gap:6px; }
  .it-mode { appearance:none; cursor:pointer; border:1px solid color-mix(in oklab,#0F1B3D 12%, white); background:#fff; border-radius:999px; padding:8px 14px; font:600 13px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .it-mode.on { background:#0F1B3D; color:#fff; border-color:#0F1B3D; }
  .it-reset { appearance:none; cursor:pointer; border:none; background:none; font:600 13px/1 'Hanken Grotesk',sans-serif; color:color-mix(in oklab,#0F1B3D 56%, white); padding:8px 6px; }
  .it-reset:hover { color:#FF6B57; }
  .it-explain { margin:10px 0 18px; font-size:13.5px; line-height:1.5; color:color-mix(in oklab,#0F1B3D 56%, white); max-width:640px; }
  .it-explain b { color:#0F1B3D; font-weight:700; }
  .it-days { display:flex; flex-direction:column; gap:14px; }
  .it-day { background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); border-radius:18px; padding:16px 18px; box-shadow:0 1px 2px rgba(8,12,28,.04); }
  .it-day-head { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
  .it-day-num { font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:.08em; color:#FF6B57; }
  .it-day-region { font:700 14px/1 'Hanken Grotesk',sans-serif; letter-spacing:-0.01em; color:#0F1B3D; }
  .it-day-date { margin-left:auto; font-size:12px; color:color-mix(in oklab,#0F1B3D 50%, white); }
  .it-day-items { display:flex; flex-direction:column; gap:8px; }
  .it-day-empty { font-size:13px; color:color-mix(in oklab,#0F1B3D 45%, white); padding:6px 2px; }
  .it-item { display:flex; align-items:center; gap:12px; padding:9px 10px; border-radius:13px; background:#FAF8F4; }
  .it-item.it-act { background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 8%, white); }
  .it-item-l { flex:none; }
  .it-ico { width:36px; height:36px; border-radius:10px; background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 8%, white); display:flex; align-items:center; justify-content:center; }
  .it-ico svg { width:20px; height:20px; }
  .it-transit { background:color-mix(in oklab,#2A6FDB 7%, white); }
  .it-thumb { width:42px; height:42px; border-radius:10px; background-size:cover; background-position:center; background-color:#eceae4; flex:none; }
  .it-thumb.glyph { display:flex; align-items:center; justify-content:center; }
  .it-thumb.sm { width:38px; height:38px; }
  .it-item-mid { flex:1; min-width:0; }
  .it-item-title { font:600 14px/1.25 'Hanken Grotesk',sans-serif; color:#0F1B3D; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .it-item-sub { display:flex; align-items:center; gap:8px; margin-top:2px; font-size:12px; color:color-mix(in oklab,#0F1B3D 54%, white); }
  .it-item-right { flex:none; display:flex; align-items:center; }
  .it-tag { font:700 10px/1 'Hanken Grotesk',sans-serif; letter-spacing:.03em; text-transform:uppercase; color:color-mix(in oklab,#0F1B3D 60%, white); background:color-mix(in oklab,#0F1B3D 8%, white); border-radius:999px; padding:3px 7px; }
  .it-cost { font:700 14px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .it-cost.free { color:#1F8A5B; }
  .it-pill { font:700 10.5px/1 'Hanken Grotesk',sans-serif; letter-spacing:.02em; border-radius:999px; padding:5px 9px; white-space:nowrap; }
  .it-pill.booked { color:#1F8A5B; background:color-mix(in oklab,#1F8A5B 12%, white); }
  .it-pill.tobook { color:#C2722E; background:color-mix(in oklab,#C2722E 13%, white); }
  .it-unsched { margin-top:16px; background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); border-radius:16px; padding:14px 16px; }
  .it-unsched-head { font:700 13px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; margin-bottom:10px; }
  .it-unsched-row { display:flex; align-items:center; gap:11px; padding:7px 0; }
  .it-add { display:flex; align-items:center; gap:6px; flex:none; }
  .it-day-sel { height:32px; border-radius:9px; border:1px solid color-mix(in oklab,#0F1B3D 14%, white); background:#FAF8F4; font:600 12.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; padding:0 6px; }
  .it-add-btn { height:32px; padding:0 13px; border-radius:9px; border:none; cursor:pointer; background:#FF6B57; color:#fff; font:700 12.5px/1 'Hanken Grotesk',sans-serif; }
  .it-add-btn:hover { background:#f0563f; }
  .it-rail { position:sticky; top:88px; display:flex; flex-direction:column; gap:14px; }
  .it-ts-card { background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); border-radius:18px; padding:18px; box-shadow:0 1px 2px rgba(8,12,28,.04); }
  .it-ts-title { margin:0; font:700 16px/1.2 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; color:#0F1B3D; }
  .it-ts-sub { margin:6px 0 14px; font-size:12.5px; line-height:1.5; color:color-mix(in oklab,#0F1B3D 54%, white); }
  .it-ts-list { display:flex; flex-direction:column; gap:10px; }
  .it-ts-row { display:flex; align-items:center; gap:11px; }
  .it-ts-add { width:100%; margin-top:14px; height:42px; border-radius:12px; border:1px dashed color-mix(in oklab,#0F1B3D 22%, white); background:none; cursor:pointer; font:700 13.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .it-ts-add:hover { border-color:#FF6B57; color:#FF6B57; }
  .it-ts-import { width:100%; margin-top:8px; height:42px; border-radius:12px; border:none; cursor:pointer; background:color-mix(in oklab,#0F1B3D 6%, white); color:#0F1B3D; font:700 13.5px/1 'Hanken Grotesk',sans-serif; display:flex; align-items:center; justify-content:center; gap:7px; }
  .it-ts-import svg { width:16px; height:16px; }
  .it-ts-import:hover { background:color-mix(in oklab,#0F1B3D 11%, white); }
  /* Gmail import / review (.gm-*) */
  .gm-card { max-width:560px; }
  .gm-privacy { margin:0 0 16px; font-size:12.5px; line-height:1.55; color:color-mix(in oklab,#0F1B3D 60%, white); background:#FAF8F4; border-radius:12px; padding:13px 14px; }
  .gm-privacy b { color:#0F1B3D; font-weight:700; }
  .gm-err { margin:0 0 12px; font-size:13px; color:#D6453B; }
  .gm-ok { margin:0 0 12px; font-size:13px; color:#1F8A5B; }
  .gm-mini { text-align:center; margin-top:12px; }
  .gm-link { border:none; background:none; cursor:pointer; font:600 13px/1 'Hanken Grotesk',sans-serif; color:color-mix(in oklab,#0F1B3D 55%, white); padding:6px; }
  .gm-link:hover { color:#FF6B57; }
  .gm-spin { width:30px; height:30px; margin:22px auto 4px; border:3px solid color-mix(in oklab,#0F1B3D 12%, white); border-top-color:#FF6B57; border-radius:999px; animation:gmspin 0.9s linear infinite; }
  @keyframes gmspin { to { transform:rotate(360deg); } }
  .gm-list { display:flex; flex-direction:column; gap:12px; max-height:52vh; overflow:auto; margin-bottom:4px; }
  .gm-card-row { border:1px solid color-mix(in oklab,#0F1B3D 10%, white); border-radius:14px; padding:13px 14px; background:#fff; }
  .gm-card-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
  .gm-approve { display:inline-flex; align-items:center; gap:7px; font:700 12.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; cursor:pointer; }
  .gm-approve input { accent-color:#FF6B57; width:16px; height:16px; }
  .gm-del { width:26px; height:26px; border-radius:999px; border:none; background:#F4F1EA; color:#0F1B3D; cursor:pointer; font-size:12px; line-height:26px; padding:0; }
  .gm-del:hover { background:color-mix(in oklab,#D6453B 16%, white); color:#D6453B; }
  .gm-grid { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
  .gm-f { display:flex; flex-direction:column; gap:4px; min-width:0; }
  .gm-f span { font:700 10px/1 'Hanken Grotesk',sans-serif; letter-spacing:.04em; text-transform:uppercase; color:color-mix(in oklab,#0F1B3D 50%, white); }
  .gm-f input { width:100%; box-sizing:border-box; height:36px; padding:0 10px; border-radius:9px; border:1px solid color-mix(in oklab,#0F1B3D 13%, white); background:#FAF8F4; font:600 13px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; outline:none; }
  .gm-f input:focus { border-color:#FF6B57; }
  @media (max-width:560px) { .gm-grid { grid-template-columns:1fr; } }
  .it-ts-statuscard { padding:14px 18px; }
  .it-ts-status { font:700 13.5px/1.3 'Hanken Grotesk',sans-serif; }
  .it-ts-status.ok { color:#1F8A5B; }
  .it-ts-status.warn { color:#C2722E; }
  .it-itinonly { max-width:860px; }
  .it-stays { display:flex; flex-direction:column; gap:14px; max-width:680px; }
  .it-stays > .it-head { margin-bottom:2px; }
  .it-ts-sechead { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:14px; }
  .it-ts-sechead > div { min-width:0; }
  .it-ts-count { display:block; margin-top:4px; font:600 12.5px/1 'Hanken Grotesk',sans-serif; color:color-mix(in oklab,#0F1B3D 54%, white); }
  .it-ts-addsm { flex:none; height:34px; padding:0 14px; border-radius:10px; border:1px dashed color-mix(in oklab,#0F1B3D 22%, white); background:none; cursor:pointer; font:700 12.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; white-space:nowrap; }
  .it-ts-addsm:hover { border-color:#FF6B57; color:#FF6B57; }
  .it-ts-right { display:flex; flex-direction:column; align-items:flex-end; gap:5px; margin-left:auto; flex:none; }
  .it-ts-cost { font:700 13.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .it-ts-edithint { font:600 11px/1 'Hanken Grotesk',sans-serif; color:#9a9488; }
  .it-ts-summary .it-ts-statusbig { margin:8px 0 12px; font:800 20px/1 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; color:#0F1B3D; }
  .it-ts-breakdown { display:flex; gap:18px; flex-wrap:wrap; padding-bottom:12px; border-bottom:1px solid color-mix(in oklab,#0F1B3D 9%, white); }
  .it-ts-breakdown span { font:600 13px/1 'Hanken Grotesk',sans-serif; color:color-mix(in oklab,#0F1B3D 62%, white); }
  .it-ts-total { margin:12px 0 0; font:600 14px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .it-ts-total strong { font-weight:800; }
  .it-stub { background:#fff; border:1px solid color-mix(in oklab,#0F1B3D 9%, white); border-radius:18px; padding:48px 40px; text-align:center; max-width:520px; margin:30px auto; }
  .it-stub-ic { width:56px; height:56px; margin:0 auto 16px; border-radius:16px; background:#FAF8F4; display:flex; align-items:center; justify-content:center; }
  .it-stub-ic svg { width:28px; height:28px; }
  .it-stub .it-sub { margin-top:10px; font-size:14.5px; line-height:1.55; }
  @media (max-width:900px) {
    .it-wrap { padding:20px 16px 96px; }
    .it-summary { gap:10px; }
    .it-sum-budget { text-align:left; }
    .it-tabs { overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
    .it-tabs::-webkit-scrollbar { display:none; }
    .it-grid { grid-template-columns:1fr; gap:20px; }
    .it-rail { position:static; order:2; }
  }

  /* ===== Save-to-Collection modal (.nc-*) + save snackbar (.snk) — v128 ===== */
  .nc-overlay { position:fixed; inset:0; z-index:1400; display:flex; align-items:center; justify-content:center; padding:20px; background:rgba(15,27,61,.5); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); opacity:0; pointer-events:none; transition:opacity .2s ease; }
  .nc-overlay.open { opacity:1; pointer-events:auto; }
  .nc-card { width:100%; max-width:460px; background:#fff; border-radius:24px; padding:26px; box-shadow:0 24px 60px rgba(8,12,28,.32); position:relative; transform:translateY(8px); transition:transform .2s ease; max-height:90vh; overflow:auto; }
  .nc-overlay.open .nc-card { transform:none; }
  .nc-close { position:absolute; top:16px; right:16px; width:32px; height:32px; border-radius:999px; border:none; background:#F4F1EA; color:#0F1B3D; font-size:14px; cursor:pointer; line-height:32px; padding:0; }
  .nc-head { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
  .nc-thumb { width:48px; height:48px; border-radius:13px; background-size:cover; background-position:center; background-color:#eceae4; flex:none; }
  .nc-thumb.glyph { display:flex; align-items:center; justify-content:center; }
  .nc-eyebrow { font:700 10.5px/1 'Hanken Grotesk',sans-serif; letter-spacing:.08em; text-transform:uppercase; color:#FF6B57; margin-bottom:4px; }
  .nc-place { font:700 15px/1.2 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .nc-h1 { margin:0 0 8px; font-family:'Hanken Grotesk',sans-serif; font-weight:700; letter-spacing:-0.02em; font-size:22px; line-height:1.2; color:#0F1B3D; }
  .nc-sub { margin:0 0 16px; font-size:13.5px; line-height:1.5; color:color-mix(in oklab,#0F1B3D 56%, white); }
  .nc-input { width:100%; box-sizing:border-box; height:48px; padding:0 15px; border-radius:13px; border:1px solid color-mix(in oklab,#0F1B3D 14%, white); background:#FAF8F4; font:600 15.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; outline:none; }
  .nc-input:focus { border-color:#FF6B57; }
  .nc-chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
  .nc-chip { border:1px solid color-mix(in oklab,#0F1B3D 14%, white); background:#fff; border-radius:999px; padding:7px 13px; font:600 13px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; cursor:pointer; }
  .nc-chip:hover { border-color:#FF6B57; color:#FF6B57; }
  .nc-cta { width:100%; height:52px; margin-top:20px; border-radius:15px; border:none; cursor:pointer; background:#FF6B57; color:#fff; font:700 15.5px/1 'Hanken Grotesk',sans-serif; box-shadow:0 10px 22px color-mix(in oklab,#FF6B57 30%, transparent); }
  .nc-cta:hover { background:#f0563f; }
  .nc-cta:disabled { opacity:.45; cursor:default; box-shadow:none; }
  .nc-picklist { display:flex; flex-direction:column; gap:8px; margin-bottom:12px; max-height:240px; overflow:auto; }
  .nc-pick { display:flex; align-items:center; gap:11px; padding:12px 14px; border:1px solid color-mix(in oklab,#0F1B3D 10%, white); border-radius:13px; cursor:pointer; }
  .nc-pick input { accent-color:#FF6B57; }
  .nc-pick-name { flex:1; font:600 14.5px/1.2 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .nc-pick-count { font-size:12px; color:color-mix(in oklab,#0F1B3D 50%, white); }
  .nc-newtoggle { width:100%; height:44px; border-radius:12px; border:1px dashed color-mix(in oklab,#0F1B3D 22%, white); background:none; cursor:pointer; font:700 13.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .nc-newtoggle:hover { border-color:#FF6B57; color:#FF6B57; }
  .nc-newwrap { margin-top:10px; }
  .td-field { display:block; margin-top:14px; }
  .td-label { display:block; font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:.04em; text-transform:uppercase; color:color-mix(in oklab,#0F1B3D 56%, white); margin-bottom:6px; }
  .td-who { margin-top:18px; }
  .td-row2 { display:flex; gap:12px; }
  .td-row2 .td-field { flex:1; min-width:0; }
  .td-card .nc-input[type="date"] { font-family:'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .td-steppers { display:flex; flex-direction:column; }
  .td-step { display:flex; align-items:center; justify-content:space-between; padding:9px 2px; border-top:1px solid color-mix(in oklab,#0F1B3D 8%, white); }
  .td-step:first-child { border-top:none; }
  .td-step-label { font:600 14.5px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .td-step-ctrl { display:flex; align-items:center; gap:14px; }
  .td-step-btn { width:32px; height:32px; border-radius:999px; border:1px solid color-mix(in oklab,#0F1B3D 16%, white); background:#fff; color:#0F1B3D; font-size:18px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; }
  .td-step-btn:hover { border-color:#FF6B57; color:#FF6B57; }
  .td-step-val { min-width:22px; text-align:center; font:700 15px/1 'Hanken Grotesk',sans-serif; color:#0F1B3D; }
  .td-hint { margin:12px 0 0; font-size:12.5px; color:#D6453B; }
  .snk { position:fixed; left:50%; bottom:84px; transform:translate(-50%, 20px); z-index:1300; display:flex; align-items:center; gap:14px; background:#0F1B3D; color:#fff; border-radius:14px; padding:12px 14px 12px 18px; box-shadow:0 12px 30px rgba(8,12,28,.34); opacity:0; pointer-events:none; transition:opacity .2s ease, transform .2s ease; max-width:calc(100vw - 32px); }
  .snk.show { opacity:1; pointer-events:auto; transform:translate(-50%, 0); }
  .snk-text { font:600 14px/1.2 'Hanken Grotesk',sans-serif; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .snk-action { flex:none; border:none; background:none; cursor:pointer; color:#FF8E7E; font:700 14px/1 'Hanken Grotesk',sans-serif; padding:6px 8px; }
  .snk-action:hover { color:#fff; }

  /* Profile (shell) */
  .pf-head { display:flex; align-items:center; gap:16px; margin-bottom:28px; }
  .pf-avatar { flex:none; width:64px; height:64px; border-radius:999px; background:#0F1B3D; color:#fff; font:700 26px/1 'Hanken Grotesk',sans-serif; display:flex; align-items:center; justify-content:center; }
  .pf-name { color:#0F1B3D; font:700 24px/1.1 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; }
  .pf-email { color:#6D778F; font:400 14.5px/1 'Hanken Grotesk',sans-serif; margin-top:4px; }
  .pf-list { display:flex; flex-direction:column; gap:10px; }
  .pf-row { display:flex; align-items:center; gap:12px; background:#fff; border:1px solid #ECE6DC; border-radius:16px; padding:16px 18px; cursor:pointer; color:#0F1B3D; font:600 15.5px/1 'Hanken Grotesk',sans-serif; text-align:left; }
  .pf-row svg { width:21px; height:21px; flex:none; }
  .pf-row:hover { border-color:#0F1B3D; }
  .pf-row.danger { color:#c0656a; }
  .pf-chev { margin-left:auto; color:#9aa3b2; font:400 20px/1 'Hanken Grotesk',sans-serif; }
  .pf-foot { color:#9aa3b2; font:400 12.5px/1 'Hanken Grotesk',sans-serif; text-align:center; margin-top:28px; }
  /* Profile (rich, design 17) + My guides (design 18) */
  .pf2-wrap { max-width:880px; margin:0 auto; }
  .pf2-card { background:#fff; border:1px solid #ECE6DC; border-radius:24px; padding:26px 28px; }
  .pf2-head { display:flex; align-items:flex-start; gap:18px; }
  .pf2-av { position:relative; flex:none; width:84px; height:84px; border-radius:999px; background:#0F1B3D center/cover no-repeat; color:#fff; font:700 32px/1 'Hanken Grotesk',sans-serif; display:flex; align-items:center; justify-content:center; border:none; cursor:pointer; }
  .pf2-av-cam { position:absolute; right:-2px; bottom:-2px; width:28px; height:28px; border-radius:999px; background:#FF6B57; color:#fff; display:flex; align-items:center; justify-content:center; border:2px solid #fff; }
  .pf2-av-cam svg { width:14px; height:14px; }
  .pf2-id { flex:1; min-width:0; padding-top:6px; }
  .pf2-name { color:#0F1B3D; font:700 26px/1.1 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; }
  .pf2-loc { color:#6D778F; font:500 14.5px/1 'Hanken Grotesk',sans-serif; margin-top:7px; display:flex; align-items:center; gap:6px; }
  .pf2-loc svg { width:15px; height:15px; flex:none; }
  .pf2-edit { flex:none; display:inline-flex; align-items:center; gap:7px; background:#fff; border:1px solid #E6E8EC; border-radius:999px; padding:10px 16px; cursor:pointer; color:#0F1B3D; font:700 13.5px/1 'Hanken Grotesk',sans-serif; }
  .pf2-edit:hover { border-color:#0F1B3D; }
  .pf2-edit svg { width:14px; height:14px; }
  .pf2-stats { display:flex; gap:32px; margin-top:22px; padding-top:20px; border-top:1px solid #F0ECE3; }
  .pf2-stat-n { color:#0F1B3D; font:700 22px/1 'Hanken Grotesk',sans-serif; }
  .pf2-stat-l { color:#6D778F; font:500 13px/1 'Hanken Grotesk',sans-serif; margin-top:5px; }
  .pf2-chips { display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
  .pf2-chip { display:inline-flex; align-items:center; gap:7px; background:#F7F4EE; border-radius:999px; padding:8px 14px; color:#0F1B3D; font:600 13px/1 'Hanken Grotesk',sans-serif; }
  .pf2-chip svg { width:15px; height:15px; flex:none; }
  .pf2-bio { color:#414b60; font:400 15px/1.55 'Hanken Grotesk',sans-serif; margin:18px 0 0; }
  .pf2-bio.empty { color:#9aa3b2; font-style:italic; }
  .pf2-promo { position:relative; overflow:hidden; background:#0F1B3D; border-radius:24px; padding:30px; margin-top:18px; }
  .pf2-promo-lbl { display:inline-flex; align-items:center; gap:7px; color:#FFC9C0; font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:0.12em; text-transform:uppercase; }
  .pf2-promo-lbl svg { width:14px; height:14px; }
  .pf2-promo-h { color:#fff; font:700 23px/1.2 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; margin:14px 0 8px; max-width:460px; }
  .pf2-promo-p { color:rgba(255,255,255,.78); font:400 14.5px/1.5 'Hanken Grotesk',sans-serif; margin:0 0 20px; max-width:490px; }
  .pf2-promo-actions { display:flex; gap:12px; flex-wrap:wrap; }
  .pf2-promo-btn { display:inline-flex; align-items:center; gap:8px; background:#FF6B57; color:#fff; border:none; border-radius:999px; padding:13px 22px; cursor:pointer; font:700 15px/1 'Hanken Grotesk',sans-serif; }
  .pf2-promo-btn svg { width:17px; height:17px; }
  .pf2-promo-ghost { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.24); border-radius:999px; padding:13px 22px; cursor:pointer; font:700 15px/1 'Hanken Grotesk',sans-serif; }
  .pf2-sec { margin-top:36px; }
  .pf2-sec-h { color:#0F1B3D; font:700 19px/1 'Hanken Grotesk',sans-serif; letter-spacing:-0.01em; margin:0 0 16px; }
  .pf2-trips { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
  .pf2-trip { text-align:left; border:none; padding:0; cursor:pointer; background:none; }
  .pf2-trip-img { aspect-ratio:4/3; border-radius:16px; background:#eceae4 center/cover no-repeat; }
  .pf2-trip-name { color:#0F1B3D; font:700 15px/1.2 'Hanken Grotesk',sans-serif; margin-top:9px; }
  .pf2-trip-meta { color:#6D778F; font:400 12.5px/1.3 'Hanken Grotesk',sans-serif; margin-top:3px; }
  .pf2-ints { display:flex; flex-wrap:wrap; gap:10px; }
  .pf2-int { display:inline-flex; align-items:center; gap:8px; background:#fff; border:1px solid #ECE6DC; border-radius:999px; padding:10px 16px; color:#0F1B3D; font:600 14px/1 'Hanken Grotesk',sans-serif; }
  .pf2-int svg { width:16px; height:16px; flex:none; color:#FF6B57; }
  .pf2-emptyline { color:#9aa3b2; font:500 14px/1.4 'Hanken Grotesk',sans-serif; }
  .pf2-settings { margin-top:36px; }
  /* My guides (design 18) */
  .mg-tabs { display:inline-flex; background:#F1ECE2; border-radius:999px; padding:5px; gap:4px; margin:22px 0 26px; }
  .mg-tab { border:none; background:none; cursor:pointer; border-radius:999px; padding:10px 22px; color:#6D778F; font:700 14.5px/1 'Hanken Grotesk',sans-serif; }
  .mg-tab.on { background:#fff; color:#0F1B3D; box-shadow:0 2px 8px rgba(8,12,28,.08); }
  .mg-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
  .mg-card { background:#fff; border:1px solid #ECE6DC; border-radius:22px; overflow:hidden; display:flex; flex-direction:column; }
  .mg-cover { position:relative; aspect-ratio:16/10; background:#0F1B3D center/cover no-repeat; }
  .mg-badge { position:absolute; top:12px; left:12px; display:inline-flex; align-items:center; gap:5px; background:rgba(255,255,255,.94); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); border-radius:999px; padding:6px 11px; color:#1F8A5B; font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:0.03em; }
  .mg-badge svg { width:13px; height:13px; }
  .mg-badge.draft { color:#B07A1E; }
  .mg-body { padding:16px 18px 18px; display:flex; flex-direction:column; flex:1; }
  .mg-title { color:#0F1B3D; font:700 17px/1.2 'Hanken Grotesk',sans-serif; letter-spacing:-0.01em; }
  .mg-meta { color:#6D778F; font:400 13px/1.4 'Hanken Grotesk',sans-serif; margin-top:5px; flex:1; }
  .mg-actions { display:flex; gap:9px; margin-top:14px; }
  .mg-open { flex:1; display:inline-flex; align-items:center; justify-content:center; gap:7px; background:#FF6B57; color:#fff; border:none; border-radius:999px; padding:11px 14px; cursor:pointer; font:700 14px/1 'Hanken Grotesk',sans-serif; }
  .mg-open svg { width:15px; height:15px; }
  .mg-add { flex:none; display:inline-flex; align-items:center; justify-content:center; background:#fff; border:1px solid #E6E8EC; border-radius:999px; padding:11px 16px; cursor:pointer; color:#0F1B3D; font:700 14px/1 'Hanken Grotesk',sans-serif; }
  .mg-add:hover { border-color:#0F1B3D; }
  .mg-empty { grid-column:1/-1; background:#fff; border:1px dashed #d8d2c6; border-radius:22px; padding:48px 32px; text-align:center; }
  .mg-empty strong { display:block; color:#0F1B3D; font:700 18px/1.3 'Hanken Grotesk',sans-serif; margin-bottom:8px; }
  .mg-empty p { color:#6D778F; font:400 14.5px/1.5 'Hanken Grotesk',sans-serif; margin:0 auto 18px; max-width:380px; }
  /* Edit-profile modal */
  .pfedit { position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center; padding:20px; background:rgba(8,12,28,.5); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px); }
  .pfedit.open { display:flex; }
  .pfedit-card { width:100%; max-width:460px; max-height:88vh; overflow:auto; background:#FAF8F4; border-radius:24px; padding:26px; }
  .pfedit-h { color:#0F1B3D; font:700 22px/1.1 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; margin:0 0 4px; }
  .pfedit-l { display:block; color:#0F1B3D; font:700 12px/1 'Hanken Grotesk',sans-serif; letter-spacing:0.05em; text-transform:uppercase; margin:18px 0 8px; }
  .pfedit-in, .pfedit-ta { width:100%; box-sizing:border-box; background:#fff; border:1px solid #E6E8EC; border-radius:14px; padding:13px 15px; color:#0F1B3D; font:500 15px/1.4 'Hanken Grotesk',sans-serif; }
  .pfedit-ta { min-height:92px; resize:vertical; }
  .pfedit-in:focus, .pfedit-ta:focus { outline:none; border-color:#0F1B3D; }
  .pfedit-ints { display:flex; flex-wrap:wrap; gap:8px; }
  .pfedit-pill { border:1px solid #E6E8EC; background:#fff; border-radius:999px; padding:9px 14px; cursor:pointer; color:#6D778F; font:600 13.5px/1 'Hanken Grotesk',sans-serif; }
  .pfedit-pill.on { background:#0F1B3D; color:#fff; border-color:#0F1B3D; }
  .pfedit-actions { display:flex; gap:10px; margin-top:24px; }
  .pfedit-save { flex:1; background:#FF6B57; color:#fff; border:none; border-radius:999px; padding:14px; cursor:pointer; font:700 15px/1 'Hanken Grotesk',sans-serif; }
  .pfedit-cancel { flex:none; background:none; border:1px solid #E6E8EC; border-radius:999px; padding:14px 22px; cursor:pointer; color:#0F1B3D; font:700 15px/1 'Hanken Grotesk',sans-serif; }
  @media (max-width:760px) {
    .pf2-card { padding:20px; border-radius:20px; }
    .pf2-name { font-size:22px; }
    .pf2-av { width:72px; height:72px; font-size:28px; }
    .pf2-promo { padding:24px 22px; }
    .pf2-stats { gap:24px; }
    .pf2-trips, .mg-grid { grid-template-columns:1fr 1fr; }
  }
  @media (max-width:480px) {
    .pf2-trips, .mg-grid { grid-template-columns:1fr; }
    .pf2-head { flex-wrap:wrap; }
    .pf2-edit { order:3; }
  }
  /* Redesign cleanup: the new shell nav replaces the old sidebar + mobile tab bar everywhere. */
  .app { grid-template-columns:1fr !important; }
  .sidebar { display:none !important; }
  #mobileTabbar { display:none !important; }
  /* Create a profile to unlock (purchase gate) */
  .cp-overlay { position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:20px; background:rgba(8,12,28,.62); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); }
  .cp-overlay.open { display:flex; }
  .cp-card { position:relative; width:100%; max-width:420px; max-height:92vh; overflow:auto; background:#FAF8F4; border-radius:28px; padding:34px 30px 26px; text-align:center; box-shadow:0 30px 80px rgba(8,12,28,.45); }
  .cp-close { position:absolute; top:16px; right:16px; width:34px; height:34px; border-radius:999px; background:#fff; border:1px solid #E6E8EC; cursor:pointer; color:#6D778F; display:flex; align-items:center; justify-content:center; }
  .cp-close:hover { color:#0F1B3D; border-color:#0F1B3D; }
  .cp-close svg { width:16px; height:16px; }
  .cp-mark { display:flex; justify-content:center; margin-bottom:18px; }
  .cp-mark img { height:30px; }
  .cp-ready { display:inline-flex; align-items:center; gap:8px; background:#EAF6EF; color:#1F8A5B; border-radius:999px; padding:7px 14px; font:700 12px/1 'Hanken Grotesk',sans-serif; margin-bottom:18px; }
  .cp-ready-dot { width:7px; height:7px; border-radius:999px; background:#1F8A5B; flex:none; }
  .cp-h1 { color:#0F1B3D; font:700 25px/1.15 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; margin:0 0 10px; }
  .cp-sub { color:#6D778F; font:400 15px/1.5 'Hanken Grotesk',sans-serif; margin:0 0 22px; }
  .cp-err { background:#fdecea; color:#b3261e; border-radius:12px; padding:11px 14px; font:600 13px/1.4 'Hanken Grotesk',sans-serif; margin-bottom:14px; text-align:left; }
  .cp-oauth { width:100%; box-sizing:border-box; display:inline-flex; align-items:center; justify-content:center; gap:10px; border-radius:14px; padding:14px; cursor:pointer; font:700 15px/1 'Hanken Grotesk',sans-serif; margin-bottom:10px; }
  .cp-oauth svg { width:19px; height:19px; flex:none; }
  .cp-apple { background:#0F1B3D; color:#fff; border:none; }
  .cp-apple:hover { background:#16224a; }
  .cp-google { background:#fff; color:#0F1B3D; border:1px solid #E0E0E0; }
  .cp-google:hover { border-color:#bfc4cc; }
  .cp-or { display:flex; align-items:center; gap:12px; color:#9aa3b2; font:600 12px/1 'Hanken Grotesk',sans-serif; margin:14px 0; text-transform:uppercase; letter-spacing:0.08em; }
  .cp-or::before, .cp-or::after { content:""; flex:1; height:1px; background:#E6E8EC; }
  .cp-email { width:100%; box-sizing:border-box; background:#FF6B57; color:#fff; border:none; border-radius:14px; padding:14px; cursor:pointer; font:700 15px/1 'Hanken Grotesk',sans-serif; box-shadow:0 10px 24px rgba(255,107,87,.3); }
  .cp-login { color:#6D778F; font:500 14px/1 'Hanken Grotesk',sans-serif; margin-top:20px; }
  .cp-login button { background:none; border:none; cursor:pointer; color:#FF6B57; font:700 14px/1 'Hanken Grotesk',sans-serif; padding:0; }
  .cp-terms { color:#9aa3b2; font:400 12px/1.5 'Hanken Grotesk',sans-serif; margin:18px 0 0; }
  .cp-terms b { color:#6D778F; font-weight:600; }
  /* Guide preview / storefront (12) */
  .gp-left { padding:28px 40px 48px; max-width:600px; }
  .gp-head { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin:14px 0 20px; }
  .gp-pill { display:inline-flex; align-items:center; gap:5px; background:#0F1B3D; color:#fff; border-radius:999px; padding:7px 14px; font:600 12px/1 'Hanken Grotesk',sans-serif; }
  .gp-pill b { font-weight:800; }
  .gp-row { display:flex; align-items:center; gap:13px; background:#fff; border:1px solid #ECE6DC; border-radius:20px; padding:10px 12px; margin-bottom:10px; }
  .gp-row[data-open-detail] { cursor:pointer; }
  .gp-thumb { position:relative; flex:none; width:64px; height:64px; border-radius:14px; background:#eceae4 center/cover no-repeat; overflow:hidden; }
  .gp-lock { position:absolute; inset:0; background:rgba(15,27,61,.92); display:flex; align-items:center; justify-content:center; color:#fff; }
  .gp-lock svg { width:22px; height:22px; }
  .gp-name { color:#0F1B3D; font:700 15.5px/1.2 'Hanken Grotesk',sans-serif; letter-spacing:-0.01em; }
  .gp-meta { color:#6D778F; font:400 12.5px/1.3 'Hanken Grotesk',sans-serif; margin-top:3px; }
  .gp-unlock { display:flex; align-items:center; gap:16px; background:#0F1B3D; border-radius:20px; padding:18px 20px; margin-top:18px; }
  .gp-unlock-t { color:#fff; font:700 17px/1.2 'Hanken Grotesk',sans-serif; }
  .gp-unlock-sub { color:rgba(255,255,255,.7); font:400 12.5px/1.3 'Hanken Grotesk',sans-serif; margin-top:4px; }
  .gp-unlock > div:first-child { flex:1; min-width:0; }
  .gp-unlock-btn { flex:none; background:#FF6B57; color:#fff; border:none; border-radius:999px; padding:13px 26px; font:700 15.5px/1 'Hanken Grotesk',sans-serif; cursor:pointer; }
  .gp-unlock-btn:disabled { background:#1F8A5B; cursor:default; }
  @media (max-width:900px) { .gp-left { padding:18px 18px 28px; max-width:none; } }
  /* How it works (02) — logged-out marketing */
  body.hw-view .app { grid-template-columns:1fr !important; }
  body.hw-view #main { padding:0 !important; }
  body.hw-view { background:#0F1B3D; }
  .hw-page, .hw-page * { font-family:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,system-ui,sans-serif; box-sizing:border-box; }
  .hw-page { background:#0F1B3D; color:#fff; min-height:100vh; }
  .hw-nav { display:flex; align-items:center; gap:24px; padding:22px 40px; max-width:1160px; margin:0 auto; }
  .hw-nav-logo { background:none; border:none; cursor:pointer; padding:0; display:flex; }
  .hw-nav-logo img { height:24px; }
  .hw-nav-links { margin-left:auto; display:flex; align-items:center; gap:24px; }
  .hw-nav-links a { color:rgba(255,255,255,.82); font:600 14.5px/1 'Hanken Grotesk',sans-serif; cursor:pointer; }
  .hw-nav-links a.on { color:#FF6B57; font-weight:700; }
  .hw-nav-cta { background:#FF6B57; color:#fff; border:none; border-radius:999px; padding:11px 20px; font:700 15px/1 'Hanken Grotesk',sans-serif; cursor:pointer; }
  .hiw-hero { max-width:880px; margin:0 auto; padding:50px 40px 30px; background:transparent; }
  .hw-eyebrow { color:#FF6B57; font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:0.14em; text-transform:uppercase; margin:0; }
  .hw-h1 { font:700 clamp(38px,6vw,64px)/1.04 'Hanken Grotesk',sans-serif; letter-spacing:-0.03em; margin:16px 0 0; }
  .hw-lead { color:rgba(255,255,255,.78); font:400 19px/1.55 'Hanken Grotesk',sans-serif; margin:20px 0 0; max-width:640px; }
  .hw-steps { max-width:1000px; margin:0 auto; padding:24px 40px; display:flex; flex-direction:column; gap:54px; }
  .hw-step { display:flex; gap:40px; align-items:center; }
  .hw-step.rev { flex-direction:row-reverse; }
  .hw-step-visual { flex:1; min-width:0; aspect-ratio:4/3; border-radius:26px; background:#16244d center/cover no-repeat; position:relative; }
  .hw-step-num { position:absolute; right:-12px; bottom:-12px; width:60px; height:60px; border-radius:999px; background:#FF6B57; color:#fff; font:700 32px/1 'Hanken Grotesk',sans-serif; display:flex; align-items:center; justify-content:center; box-shadow:0 12px 30px rgba(255,107,87,.4); }
  .hw-step-body { flex:1; min-width:0; }
  .hw-step-lbl { color:#FF6B57; font:700 11px/1 'Hanken Grotesk',sans-serif; letter-spacing:0.12em; text-transform:uppercase; }
  .hw-step-h2 { font:700 clamp(26px,3.4vw,42px)/1.08 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; margin:10px 0 0; }
  .hw-step-p { color:rgba(255,255,255,.78); font:400 17px/1.6 'Hanken Grotesk',sans-serif; margin:14px 0 0; }
  .hw-bullets { margin:18px 0 0; display:flex; flex-direction:column; gap:11px; }
  .hw-bullet { display:flex; align-items:center; gap:12px; color:rgba(255,255,255,.9); font:500 15px/1.3 'Hanken Grotesk',sans-serif; }
  .hw-bullet-dot { flex:none; width:22px; height:22px; border-radius:999px; background:rgba(255,107,87,.22); color:#FF6B57; display:flex; align-items:center; justify-content:center; }
  .hw-bullet-dot svg { width:12px; height:12px; }
  .hw-final { max-width:1000px; margin:24px auto 60px; padding:0 40px; }
  .hw-final-card { background:#16244d; border-radius:30px; padding:46px; display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap; }
  .hw-final-h { font:700 clamp(26px,3.4vw,40px)/1.1 'Hanken Grotesk',sans-serif; letter-spacing:-0.02em; max-width:520px; margin:0; }
  .hw-final-actions { display:flex; gap:12px; flex-wrap:wrap; }
  .hw-btn-coral { background:#FF6B57; color:#fff; border:none; border-radius:999px; padding:14px 24px; font:700 15.5px/1 'Hanken Grotesk',sans-serif; cursor:pointer; }
  .hw-btn-ghost { background:transparent; color:#fff; border:1px solid rgba(255,255,255,.3); border-radius:999px; padding:14px 24px; font:700 15.5px/1 'Hanken Grotesk',sans-serif; cursor:pointer; }
  @media (max-width:800px) {
    .hw-step, .hw-step.rev { flex-direction:column; gap:24px; }
    .hw-nav { padding:18px 18px; } .hw-nav-links { gap:16px; } .hw-nav-links a:not(.is-login) { display:none; }
    .hiw-hero { padding:30px 18px 20px; } .hw-steps { padding:14px 18px; } .hw-final { padding:0 18px; } .hw-final-card { padding:30px; }
  }
  /* Responsive: mobile uses the bottom tab bar, hides the top nav, stacks the grid */
  .wh-page .exp-tabbar { display:none; }
  @media (max-width:820px) {
    .wh-nav { display:none; }
    .wh-page .exp-tabbar { display:flex; }
    .wh-content { padding:20px 18px calc(86px + env(safe-area-inset-bottom,0px)); }
    .wh-coll-grid { grid-template-columns:1fr; gap:16px; }
    .wh-h1 { font-size:32px; }
    .ed-hero { height:220px; }
    .ed-hero-inner { padding:0 18px 22px; }
    .ed-grid { grid-template-columns:1fr 1fr; gap:13px; }
    .ed-card-name { font-size:14.5px; }
  }
