/* ─── PLAN TRIGGER ─── */
:root{
  --soft-ink:#3d3b37;
  --soft-ink-2:#4a4843;
}
.add-form.open{margin-top:12px}
.add-trigger-row{
  display:flex;align-items:stretch;gap:8px;
}
.add-trigger-row .add-trig{
  flex:1;min-width:0;background:transparent;
}
.plan-trig{
  min-width:76px;border:1.5px solid var(--bor);border-radius:var(--r);
  background:var(--bg);color:var(--t2);
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:0 13px;font-size:13px;font-weight:700;
  touch-action:manipulation;user-select:none;-webkit-user-select:none;
  box-shadow:var(--sh0);
  transition:background .15s,color .15s,border-color .15s,transform .2s cubic-bezier(0.34,1.5,0.64,1),box-shadow .15s;
}
.plan-trig svg{flex-shrink:0}
@media(hover:hover){
  .plan-trig:hover{border-color:var(--t1);color:var(--t1);background:var(--hov)}
}
.plan-trig:active{transform:scale(.94)}
.add-trigger-row.task-open .add-trig,
.add-trigger-row.plan-open .add-trig,
.add-trigger-row.plan-open .plan-trig{
  border-color:var(--soft-ink-2);background:var(--soft-ink);color:#fff;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 2px 10px rgba(0,0,0,.14);
}
.add-trigger-row.task-open .add-plus,
.add-trigger-row.plan-open .add-plus{
  background:rgba(255,255,255,.18);color:#fff;
}
.add-form.mode-plan .single-only{display:none!important}
.add-form.mode-plan .af-footer{justify-content:flex-end;padding-top:12px}

/* ─── PLAN BUILDER ─── */
.plan-builder{
  background:var(--sur);border-top:1px solid var(--bor);
  padding:14px;display:flex;flex-direction:column;gap:12px;
}
.plan-builder-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.plan-builder-head div{display:flex;flex-direction:column;gap:2px;min-width:0}
.plan-builder-kicker{font-size:11px;font-weight:800;color:var(--green);letter-spacing:.04em}
.plan-builder-head strong{font-size:14px;font-weight:750;color:var(--t1)}
.plan-stop-add{
  flex-shrink:0;border:none;border-radius:100px;background:var(--t1);color:#fff;
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 12px;font-size:12px;font-weight:800;font-family:inherit;
  transition:opacity .14s,transform .2s cubic-bezier(0.34,1.5,0.64,1);
}
.plan-stop-add span{
  width:16px;height:16px;border-radius:50%;background:rgba(255,255,255,.16);
  display:flex;align-items:center;justify-content:center;line-height:1;
}
@media(hover:hover){.plan-stop-add:hover{opacity:.84}}
.plan-stop-add:active{transform:scale(.94)}
.plan-stops{display:flex;flex-direction:column;gap:10px}
.plan-stop{
  display:grid;grid-template-columns:26px 1fr;gap:9px;
}
.plan-stop-rail{
  position:relative;display:flex;justify-content:center;padding-top:10px;
}
.plan-stop-rail::after{
  content:"";position:absolute;top:34px;bottom:-12px;width:2px;
  background:var(--bor);border-radius:2px;
}
.plan-stop:last-child .plan-stop-rail::after{display:none}
.plan-stop-rail span{
  width:24px;height:24px;border-radius:50%;background:var(--soft-ink);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;z-index:1;
}
.ps-add-below{
  position:absolute;bottom:-13px;left:50%;transform:translateX(-50%);
  width:20px;height:20px;border-radius:50%;z-index:3;
  border:1.5px solid var(--bor);background:var(--bg);color:var(--t3);
  font-size:14px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;touch-action:manipulation;
  transition:background .12s,color .12s,border-color .12s,transform .18s cubic-bezier(.34,1.5,.64,1);
}
@media(hover:hover){
  .ps-add-below:hover{background:var(--soft-ink);color:#fff;border-color:var(--soft-ink)}
}
.ps-add-below:active{transform:translateX(-50%) scale(.86)}
.plan-stop-main{
  background:var(--bg);border:1px solid var(--bor);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--sh0);
}
.plan-stop-top{
  display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--bor);
  padding:12px 12px 10px;
}
.plan-stop-top input{
  flex:1;min-width:0;border:none;background:transparent;
  font-size:15px;font-weight:700;font-family:inherit;color:var(--t1);
}
.plan-stop-top input::placeholder{color:var(--t3)}
.plan-stop-remove{
  width:28px;height:28px;border:none;border-radius:50%;
  color:var(--t3);background:transparent;font-size:18px;line-height:1;
}
@media(hover:hover){.plan-stop-remove:hover{background:var(--red-bg);color:var(--red)}}
.ps-desc{
  width:100%;border:none;border-bottom:1px solid var(--bor);
  background:transparent;resize:none;min-height:48px;
  padding:10px 12px;font-size:13px;font-family:inherit;color:var(--t2);
}
.ps-desc::placeholder{color:var(--t3)}
.ps-controls{
  display:flex;align-items:center;gap:6px;flex-wrap:wrap;
  padding:10px 12px;background:var(--sur);
}
.ps-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 9px;border-radius:var(--rs);
  background:var(--bg);border:1px solid var(--bor);
  color:var(--t2);font-size:12px;font-weight:700;
}
.ps-pill svg{color:var(--t3);flex-shrink:0}
.ps-auto-end{
  display:inline-flex;align-items:center;gap:4px;
  padding:6px 9px;border-radius:var(--rs);
  background:var(--bg);border:1px solid var(--bor);
  color:var(--t3);font-size:11px;font-weight:800;font-family:inherit;
  cursor:pointer;touch-action:manipulation;
  transition:background .13s,color .13s,border-color .13s;
}
.ps-auto-end.hidden{display:none}
.ps-auto-end.active{background:var(--soft-ink);color:#fff;border-color:var(--soft-ink)}
@media(hover:hover){.ps-auto-end:not(.active):hover{color:var(--t1);border-color:var(--t1)}}
.ps-pill input{
  border:none;outline:none;background:transparent;
  font-size:12px;font-family:inherit;color:var(--t1);max-width:118px;
}
.ps-pill span{font-size:11px;color:var(--t3)}
.plan-stop-location{
  border-top:1px solid var(--bor);background:var(--bg);
}
.plan-stop-location .location-summary{padding:8px 10px}
.plan-stop-location .loc-picker{margin:0 10px 10px}
.plan-stop-location .loc-map-wrap{height:188px}

/* ─── LOCATION PICKER ─── */
.location-field{
  border-top:1px solid var(--bor);background:var(--sur);
}
.location-summary{
  display:flex;align-items:center;justify-content:space-between;
  gap:8px;padding:10px 14px;
}
.loc-open-btn{
  min-width:0;display:inline-flex;align-items:center;gap:7px;
  border:none;background:transparent;color:var(--t2);
  font-size:13px;font-weight:600;font-family:inherit;
  padding:7px 10px;border-radius:var(--rs);
  touch-action:manipulation;transition:background .14s,color .14s;
}
.loc-open-btn span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.loc-open-btn svg{color:var(--t3);flex-shrink:0}
@media(hover:hover){.loc-open-btn:hover{background:var(--hov);color:var(--t1)}}
.loc-clear-btn{
  width:28px;height:28px;border:none;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--t3);background:transparent;font-size:18px;line-height:1;
  transition:background .12s,color .12s,transform .18s cubic-bezier(0.34,1.5,0.64,1);
}
@media(hover:hover){.loc-clear-btn:hover{background:var(--red-bg);color:var(--red)}}
.loc-clear-btn:active{transform:scale(.9)}
.loc-picker{
  margin:0 14px 14px;background:var(--bg);border:1px solid var(--bor);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1);
  animation:formIn .2s cubic-bezier(0.34,1.08,0.64,1) both;
}
.loc-search-row{
  display:flex;gap:8px;padding:12px;border-bottom:1px solid var(--bor);
}
.loc-search-row input{
  flex:1;min-width:0;border:none;background:var(--sur);
  border-radius:var(--rs);padding:10px 12px;font-size:14px;
  font-family:inherit;color:var(--t1);
}
.loc-search-row button{
  border:none;border-radius:var(--rs);padding:0 14px;
  background:var(--soft-ink);color:#fff;font-size:13px;font-weight:700;
}
.loc-search-row .loc-current-btn{
  background:var(--bg);color:var(--t2);border:1px solid var(--bor);
  padding:0 10px;white-space:nowrap;
}
.loc-results{
  display:flex;flex-direction:column;max-height:156px;overflow:auto;
}
.loc-result{
  border:none;background:var(--bg);text-align:left;
  padding:11px 13px;border-bottom:1px solid var(--bor);
  display:flex;flex-direction:column;gap:2px;font-family:inherit;
  transition:background .12s;
}
.loc-result:last-child{border-bottom:none}
@media(hover:hover){.loc-result:hover{background:var(--hov)}}
.loc-result strong{
  font-size:13px;font-weight:700;color:var(--t1);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.loc-result span{
  font-size:12px;color:var(--t2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.loc-muted{pointer-events:none}
.loc-map-wrap{position:relative;height:230px;background:#181817}
.loc-map{position:absolute;inset:0}
.loc-map-toolbar{
  position:absolute;top:10px;right:10px;z-index:2;
  display:flex;gap:4px;padding:4px;border-radius:100px;
  background:rgba(252,251,249,.96);
  border:1px solid rgba(0,0,0,.08);box-shadow:var(--sh1);
}
.loc-map-toolbar button{
  border:none;border-radius:100px;background:transparent;color:var(--t2);
  padding:6px 9px;font-size:11px;font-weight:800;font-family:inherit;
}
.loc-map-toolbar button.active{background:var(--soft-ink);color:#fff}
.mapboxgl-ctrl-logo{opacity:.6}

/* ─── LIVE ACTIVITY ─── */
#live-activity-root{
  max-width:680px;margin:14px auto 0;padding:0 14px;
}
#live-activity-root:empty{display:none}
.live-activity{
  width:100%;min-height:192px;border-radius:26px;
  background:rgba(58,56,52,.94);color:#fff;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 12px 36px rgba(0,0,0,.22),0 2px 6px rgba(0,0,0,.1),
             inset 0 1px 0 rgba(255,255,255,.12);
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  overflow:hidden;
  animation:liveWidgetIn .54s cubic-bezier(0.22,1,0.36,1) both;
}
@keyframes liveIn{from{opacity:0;transform:translateY(-10px) scale(.97)}to{opacity:1;transform:none}}
@keyframes liveWidgetIn{
  0%  { opacity:0; transform:translateY(-28px) scale(.86); }
  65% { opacity:1; }
  82% { transform:translateY(3px) scale(1.012); }
  100%{ opacity:1; transform:none; }
}
@keyframes liveItemIn{
  from{ opacity:0; transform:translateY(9px); }
  to  { opacity:1; transform:none; }
}
@keyframes liveDotAppear{
  0%  { opacity:0; transform:scale(0) rotate(-90deg); }
  70% { transform:scale(1.35) rotate(8deg); }
  100%{ opacity:1; transform:scale(1) rotate(0); }
}
.live-inner{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;
  align-items:center;padding:14px 18px 14px 18px;
}
.live-inner.no-map{grid-template-columns:1fr}
.live-copy{min-width:0;padding-left:2px}
.live-kicker{display:flex;align-items:center;gap:6px;margin-bottom:6px;min-width:0}
.live-dot{
  width:6px;height:6px;border-radius:50%;background:#35d07f;
  box-shadow:0 0 0 3px rgba(53,208,127,.18);
  flex-shrink:0;
}
.live-state{
  min-width:0;max-width:100%;
  font-size:10px;font-weight:850;color:rgba(255,255,255,.62);
  letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.live-action{
  font-size:22px;font-weight:900;line-height:1.1;color:#fff;
  letter-spacing:-.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:5px;
  transition:color .3s ease;
}
.live-action.urgent{color:#ff6b6b}
.live-action.warning{color:#ffc34d}
.live-title{
  font-size:13px;font-weight:850;color:rgba(255,255,255,.78);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.live-desc{
  margin-top:2px;font-size:11px;color:rgba(255,255,255,.38);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4;
}
.live-meta{
  margin-top:6px;font-size:12px;font-weight:800;color:rgba(255,255,255,.66);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.live-progress{
  height:4px;margin-top:12px;border-radius:100px;overflow:hidden;
  background:rgba(255,255,255,.14);
}
.live-progress span{
  display:block;height:100%;width:0;border-radius:inherit;background:#35d07f;
  transition:width .6s ease;
}
.live-map{
  width:clamp(164px,30vw,192px);height:clamp(164px,30vw,192px);
  aspect-ratio:1/1;border-radius:22px;overflow:hidden;background:#242423;
  border:1px solid rgba(255,255,255,.14);box-shadow:0 4px 18px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.08);
  cursor:zoom-in;transform:translateX(2px);flex-shrink:0;
}
.live-map .mapboxgl-ctrl-bottom-left,
.live-map .mapboxgl-ctrl-bottom-right{display:none}
.live-marker{
  width:26px;height:26px;border-radius:50%;
  background:#8b7cf6;border:2.5px solid rgba(255,255,255,.9);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:850;font-family:inherit;
  font-variant-numeric:tabular-nums;color:#fff;
  box-shadow:0 2px 10px rgba(0,0,0,.38);
  pointer-events:none;
}
.live-marker.active{background:#35d07f;color:#173326;border-color:#fff}

.map-modal{
  position:fixed;inset:0;z-index:1400;background:rgba(0,0,0,.58);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:liveIn .2s ease both;
}
.map-modal-sheet{
  position:relative;width:min(860px,100%);height:min(620px,82dvh);
  border-radius:24px;overflow:hidden;background:#2f2d2a;
  box-shadow:0 22px 70px rgba(0,0,0,.32);
}
.map-modal-close{
  position:absolute;top:14px;right:14px;z-index:4;
  width:36px;height:36px;border:none;border-radius:50%;
  background:rgba(255,255,255,.88);color:var(--t1);font-size:22px;line-height:1;
  box-shadow:var(--sh1);
}
.map-modal-style{
  position:absolute;right:58px;top:14px;z-index:4;
  display:flex;gap:4px;padding:4px;border-radius:100px;
  background:rgba(252,251,249,.96);
  border:1px solid rgba(0,0,0,.08);box-shadow:var(--sh1);
}
.map-modal-style button{
  border:none;border-radius:100px;background:transparent;color:var(--t2);
  padding:7px 10px;font-size:11px;font-weight:850;font-family:inherit;
}
.map-modal-style button.active{background:var(--soft-ink);color:#fff}
.map-modal-copy{
  position:absolute;left:16px;top:16px;z-index:3;max-width:min(420px,72%);
  display:flex;flex-direction:column;gap:3px;
  padding:10px 13px;border-radius:16px;
  background:rgba(26,25,23,.92);color:#fff;
  border:1px solid rgba(255,255,255,.08);
}
.map-modal-copy strong{font-size:15px;font-weight:800}
.map-modal-copy span{font-size:12px;color:rgba(255,255,255,.7);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-modal-copy em{font-style:normal;font-size:11px;font-weight:800;color:rgba(255,255,255,.82)}
.map-modal-canvas{position:absolute;inset:0}

.live-plan-detail{
  margin-top:8px;border-radius:22px;padding:12px;
  background:#302f2c;color:#fff;
  border:1px solid rgba(255,255,255,.1);
  animation:livePlanDrop .32s cubic-bezier(0.18,1.35,0.3,1) backwards;
  transform-origin:top center;
}
@keyframes livePlanDrop{
  from{opacity:0;transform:translateY(-16px) scale(.96)}
  to{opacity:1;transform:none}
}
.live-activity.expanded{box-shadow:0 12px 30px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.14)}
.live-activity.live-summary{min-height:auto;opacity:.82}
.live-state{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.live-plan-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:3px 4px 11px;border-bottom:1px solid rgba(255,255,255,.1);
}
.live-plan-head > div:first-child{min-width:0;display:flex;flex-direction:column;gap:2px}
.live-plan-head span{
  max-width:100%;font-size:10px;font-weight:850;color:rgba(255,255,255,.68);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.live-plan-head strong{font-size:14px;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-plan-head-right{
  flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;gap:6px;
  min-width:auto;
}
.live-plan-head-right em{
  font-style:normal;border-radius:100px;padding:5px 9px;
  background:rgba(255,255,255,.1);font-size:11px;font-weight:850;color:rgba(255,255,255,.76);
  border:1px solid rgba(255,255,255,.08);white-space:nowrap;
}
.live-plan-switch{
  border:1px solid rgba(255,255,255,.18);border-radius:100px;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.82);
  font-size:11px;font-weight:850;font-family:inherit;padding:5px 9px;
  touch-action:manipulation;transition:background .13s,color .13s;
  white-space:nowrap;
}
@media(hover:hover){.live-plan-switch:hover{background:rgba(255,255,255,.2);color:#fff}}
.live-plan-switcher{
  border-bottom:1px solid rgba(255,255,255,.1);padding:8px 0;
  display:flex;flex-direction:column;gap:2px;
  max-height:180px;overflow-y:auto;scrollbar-width:none;
}
.live-plan-switcher::-webkit-scrollbar{display:none}
.live-plan-switcher.hidden{display:none}
.lps-hint{font-size:10px;font-weight:750;color:rgba(255,255,255,.38);padding:2px 4px 4px;letter-spacing:.02em}
.lps-item{
  width:100%;border:none;border-radius:8px;background:transparent;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:7px 8px;text-align:left;font-family:inherit;
  transition:background .12s;touch-action:manipulation;
}
@media(hover:hover){.lps-item:hover{background:rgba(255,255,255,.08)}}
.lps-item.current{background:rgba(53,208,127,.14)}
.lps-name{flex:1;min-width:0;font-size:13px;font-weight:750;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lps-item.current .lps-name{color:#35d07f}
.lps-badge{flex-shrink:0;font-size:10px;font-weight:850;color:#35d07f;border:1px solid rgba(53,208,127,.4);border-radius:100px;padding:2px 7px}
.live-plan-route{padding-top:8px;position:relative}
.live-plan-route:not(.collapsed){
  max-height:58dvh;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;
}
.live-plan-route:not(.collapsed)::-webkit-scrollbar{display:none}
.live-plan-route-inner{display:flex;flex-direction:column}
.live-plan-route.collapsed .live-plan-route-inner{
  padding-bottom:86px;max-height:172px;
  overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;
}
.live-plan-route.collapsed .live-plan-route-inner::-webkit-scrollbar{display:none}
.live-plan-route.collapsed{overflow:hidden}
/* Expand collapsed route when a place detail is open */
.live-plan-route.collapsed:has(.place-detail-slot.open){overflow:visible}
.live-plan-route.collapsed:has(.place-detail-slot.open) .live-plan-route-inner{
  max-height:none;overflow:visible;
}
.live-plan-route.collapsed:has(.place-detail-slot.open)::after{display:none}
.live-plan-route.collapsed::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:60px;
  background:linear-gradient(to bottom,transparent,rgba(74,72,67,.96));
  pointer-events:none;z-index:1;
}
.live-plan-route.has-top-blur::before{
  content:"";position:absolute;top:0;left:0;right:0;height:48px;
  background:linear-gradient(to bottom,rgba(74,72,67,.96),transparent);
  pointer-events:none;z-index:1;
}
.live-plan-stop{
  display:grid;grid-template-columns:26px 1fr;gap:8px;position:relative;
  padding:9px 4px;
}
/* connecting line now drawn by .live-plan-travel::before */
.live-plan-stop:not(:last-of-type)::after{
  content:"";position:absolute;left:16px;top:35px;bottom:-9px;width:2px;
  background:rgba(255,255,255,.16);border-radius:2px;
}
/* suppress the stop connector line when a travel row follows (travel row draws its own) */
.live-plan-stop:has(+ .live-plan-travel)::after{display:none}
.live-plan-stop i{
  width:26px;height:26px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.12);font-style:normal;font-size:11px;font-weight:900;color:#fff;
  z-index:1;
}
.live-plan-stop.current i{background:#35d07f;color:#173326}
.live-plan-stop div{min-width:0}
.live-plan-stop strong{
  display:block;font-size:13px;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.live-plan-stop span{
  display:block;margin-top:3px;font-size:11px;color:rgba(255,255,255,.62);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.live-plan-stop p{
  margin:5px 0 0;font-size:11px;line-height:1.5;color:rgba(255,255,255,.72);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.live-plan-more{
  width:100%;border:none;border-top:1px solid rgba(255,255,255,.1);
  background:transparent;color:rgba(255,255,255,.6);
  font-size:12px;font-weight:850;font-family:inherit;
  padding:10px 0 2px;text-align:center;letter-spacing:.02em;
  touch-action:manipulation;
}
@media(hover:hover){.live-plan-more:hover{color:#fff}}
.live-plan-stop.has-loc{cursor:pointer}
@media(hover:hover){
  .live-plan-stop.has-loc:hover{background:rgba(255,255,255,.06);border-radius:10px}
}
.live-plan-stop.place-expanded{
  background:rgba(255,255,255,.08);border-radius:12px;
}
.live-plan-stop .place-detail-slot{grid-column:1/-1}
.live-plan-stop .place-detail-card{
  border-color:rgba(255,255,255,.14);
  background:#30302d;
  box-shadow:0 12px 30px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.08);
}
.live-plan-stop .place-detail-head{padding:12px 13px}
.live-plan-stop .place-detail-top strong{font-size:14px}
.live-plan-stop .place-detail-title > span:not(.place-detail-eyebrow){font-size:10px}
.live-plan-stop .place-chip{font-size:9px;padding:3px 6px}
.live-plan-stop .place-detail-card.loading{
  background:#30302d;
}
.live-plan-stop .place-detail-shimmer{
  background:linear-gradient(110deg,rgba(255,255,255,.06) 0%,rgba(255,255,255,.16) 44%,rgba(255,255,255,.06) 78%);
  background-size:220% 100%;
}
.live-plan-stop .place-gallery{
  --place-gallery-w:min(100%,520px);
  padding:20px 52px 14px;
}
.live-plan-stop .place-main-photo{height:clamp(150px,30vw,220px)}
.live-plan-stop .place-gallery-arrow{top:calc(20px + clamp(150px,30vw,220px) / 2 - 17px)}
.live-plan-stop .place-gallery-arrow.prev{left:16px}
.live-plan-stop .place-gallery-arrow.next{right:16px}
.live-plan-stop .place-thumb{flex-basis:54px;width:54px;height:44px}
.live-plan-stop .place-photo-empty{
  height:108px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.18));
}
.live-plan-stop .place-detail-section{padding-left:12px;padding-right:12px;padding-top:9px;padding-bottom:9px}
.live-plan-stop .place-overview{
  margin:0;color:rgba(255,255,255,.72);font-size:11px;line-height:1.55;
  display:block;-webkit-line-clamp:unset;-webkit-box-orient:initial;
  overflow:visible;white-space:pre-line;
}
.live-plan-stop .place-overview.collapsed{
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;white-space:normal;
}
.live-plan-stop .place-info-row{grid-template-columns:60px minmax(0,1fr);gap:8px}
.live-plan-stop .place-detail-actions{padding-left:12px;padding-right:12px;padding-bottom:12px;padding-top:8px}

/* ── Live widget travel time rows ── */
.live-plan-travel{
  padding:2px 2px 2px 34px;position:relative;
}
.live-plan-travel::before{
  content:"";position:absolute;left:14px;top:0;bottom:0;width:2px;
  background:rgba(255,255,255,.16);border-radius:2px;
}
.lpt-loading{font-size:11px;color:rgba(255,255,255,.35)}
.lpt-btn{
  border:1px solid rgba(255,255,255,.08);border-radius:100px;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);
  font-size:10px;font-weight:800;font-family:inherit;
  padding:3px 8px;cursor:pointer;touch-action:manipulation;
  transition:background .15s,color .15s,box-shadow .15s;
}
@media(hover:hover){.lpt-btn:hover{background:rgba(255,255,255,.22)}}
.lpt-btn.lpt-active{
  background:#4a90e2;color:#fff;
  box-shadow:0 0 0 3px rgba(74,144,226,.35);
}
.lpt-btn.lpt-estimate{
  color:rgba(255,255,255,.68);
  background:rgba(255,255,255,.08);
  border:1px dashed rgba(255,255,255,.18);
}

/* ── Active route info banner (inside live plan detail) ── */
.lpt-route-banner{
  display:flex;align-items:center;gap:6px;
  margin:6px 0 0;padding:7px 10px;border-radius:10px;
  background:rgba(74,144,226,.18);border:1px solid rgba(74,144,226,.32);
  animation:liveIn .2s cubic-bezier(0.34,1.15,0.64,1) both;
}
.lpt-rb-arrow{
  font-size:13px;flex-shrink:0;color:#4a90e2;
}
.lpt-rb-text{
  flex:1;min-width:0;font-size:11px;font-weight:800;color:rgba(255,255,255,.9);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.lpt-rb-time{
  flex-shrink:0;font-size:11px;font-weight:800;color:#4a90e2;white-space:nowrap;
}
.lpt-rb-close{
  flex-shrink:0;border:none;background:none;color:rgba(255,255,255,.45);
  font-size:13px;line-height:1;padding:0 0 0 2px;cursor:pointer;
  font-family:inherit;touch-action:manipulation;
  transition:color .12s;
}
@media(hover:hover){.lpt-rb-close:hover{color:rgba(255,255,255,.9)}}

@media(max-width:600px){
  .add-trigger-row{gap:7px}
  .plan-trig{min-width:68px;padding:0 10px;font-size:12px}
  .loc-map-wrap{height:210px}
  .plan-builder{padding:12px 10px}
  .plan-builder-head{align-items:flex-start}
  .plan-stop{grid-template-columns:24px 1fr;gap:7px}
  .ps-controls{gap:5px}
  .ps-pill{padding:6px 8px}
  .loc-search-row{flex-wrap:wrap}
  .loc-search-row input{flex-basis:100%}
  #live-activity-root{padding:0 10px}
  .live-activity{min-height:146px;border-radius:22px}
  .live-inner{grid-template-columns:minmax(0,1fr) auto;padding:10px 12px;gap:8px}
  .live-map{width:122px;height:122px;border-radius:18px;transform:translateX(1px)}
  .live-title{font-size:13px;-webkit-line-clamp:2}
  .live-meta{font-size:11px}
  .map-modal-style{right:56px;top:14px}
  .map-modal-style button{padding:7px 9px}
}
