/* ─── TASK LIST ─── */
.tlist{
  max-width:680px;margin:0 auto;
  padding:0 14px;display:flex;flex-direction:column;gap:3px;
  transition:opacity .1s ease;
}
.tlist.fading{opacity:0;pointer-events:none}
.sec-lbl{
  padding:14px 4px 5px;font-size:11px;font-weight:600;color:var(--t2);
  letter-spacing:.06em;text-transform:uppercase;
  user-select:none;-webkit-user-select:none;
}
.tcard{
  background:var(--bg);border:.5px solid var(--bor);border-radius:var(--r);
  padding:10px 13px;display:flex;align-items:flex-start;gap:11px;
  transition:background .1s,opacity .17s,transform .17s ease;
  opacity:.88;
}
@keyframes cardIn{
  from{opacity:0;transform:translateY(16px) scale(.97)}
  to{opacity:1;transform:none}
}
@media(hover:hover){.tcard:hover{background:var(--hov)}}
.tcard.done .tc-title{text-decoration:line-through;color:var(--t2)}
.tcard.highlight{
  background:var(--blue-bg)!important;
  box-shadow:0 0 0 2px var(--blue)!important;
  transition:background .25s,box-shadow .25s!important;
}
.tc-chk{
  width:20px;height:20px;flex-shrink:0;margin-top:2px;
  border:1.5px solid var(--bor);border-radius:6px;cursor:pointer;touch-action:manipulation;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;color:transparent;
  transition:background .16s,border-color .16s,color .16s,transform .22s cubic-bezier(0.34,1.6,0.64,1);
}
@media(hover:hover){.tc-chk:hover{border-color:var(--green);color:rgba(13,122,102,.45)}}
.tc-chk:active{transform:scale(0.75)}
.tcard.done .tc-chk{background:var(--green);border-color:var(--green);color:#fff}
.tc-body{flex:1;min-width:0}
.tc-title{font-size:13.5px;font-weight:420;word-break:break-word;user-select:none;-webkit-user-select:none;color:var(--t1)}
.tc-meta{display:flex;align-items:center;flex-wrap:wrap;gap:5px;margin-top:5px}
.tc-date{font-size:12px;color:var(--t2)}
.tc-time{font-size:12px;color:var(--t2);display:flex;align-items:center;gap:3px}
.tc-kind{
  font-size:11px;font-weight:800;padding:2px 7px;border-radius:100px;
  background:var(--green-bg);color:var(--green);letter-spacing:.02em;
}
.tc-location{
  max-width:100%;font-size:12px;color:var(--t2);
  display:inline-flex;align-items:center;gap:3px;min-width:0;
}
.tc-location svg{flex-shrink:0;color:var(--t3)}
.tc-date-sep{font-size:12px;color:var(--t3)}
.tc-files{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.tc-file{
  display:inline-flex;align-items:center;gap:5px;min-width:0;max-width:100%;
  padding:4px 8px;border:1px solid var(--bor);border-radius:100px;background:var(--sur);
  color:var(--t2);font-size:12px;font-family:inherit;cursor:pointer;touch-action:manipulation;
}
.tc-file span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media(hover:hover){.tc-file:hover{background:var(--hov);color:var(--t1)}}
.plan-route-outer{
  position:relative;margin-top:9px;
}
.plan-route-outer.collapsed{max-height:200px;overflow:hidden}
.plan-route-outer.collapsed::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:62px;
  background:linear-gradient(to bottom,transparent,var(--bg));
  pointer-events:none;z-index:2;
}
.plan-route-outer.has-top-blur::before{
  content:"";position:absolute;top:0;left:0;right:0;height:50px;
  background:linear-gradient(to bottom,var(--bg),transparent);
  pointer-events:none;z-index:2;
}
.plan-route-outer .plan-route{margin-top:0}
.plan-route-outer.collapsed .plan-route{padding-bottom:100px}
.plan-route-more{
  display:block;width:100%;border:none;
  border:1px solid var(--bor);border-top:none;
  border-radius:0 0 var(--rs) var(--rs);
  background:var(--sur);color:var(--t2);
  font-size:12px;font-weight:800;font-family:inherit;
  padding:8px 0;text-align:center;cursor:pointer;
  touch-action:manipulation;
}
@media(hover:hover){.plan-route-more:hover{color:var(--t1);background:var(--hov)}}
.plan-route-more:active{opacity:.6}
.plan-route{
  margin-top:9px;border:1px solid var(--bor);border-radius:var(--rs);
  background:var(--sur);overflow:hidden;
}
.plan-route-stop{
  display:grid;grid-template-columns:20px 1fr;gap:7px;
  padding:7px 10px;border-bottom:1px solid var(--bor);
}
.plan-route-stop:last-child{border-bottom:none}
.prs-num{
  width:20px;height:20px;border-radius:50%;background:var(--sur);border:1px solid var(--bor);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:700;color:var(--t3);
}
.prs-body{min-width:0;display:flex;flex-direction:column;gap:1px}
.prs-body strong{
  font-size:12.5px;font-weight:620;color:var(--t1);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.prs-body span{
  font-size:11.5px;color:var(--t2);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.prs-body > p,
.prs-desc{
  margin-top:3px;font-size:12px;color:var(--t2);line-height:1.45;
}
.prs-desc-wrap{
  position:relative;margin-top:3px;padding-bottom:18px;
}
.prs-desc-wrap .prs-desc{margin:0}
.prs-desc-wrap.collapsed .short{
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;max-height:34px;
}
.prs-desc-wrap.collapsed::after{
  content:"";position:absolute;left:0;right:0;bottom:18px;height:18px;
  background:linear-gradient(to bottom, rgba(245,244,242,0), var(--sur));
  pointer-events:none;
}
.plan-route-stop.active .prs-desc-wrap.collapsed::after{
  background:linear-gradient(to bottom, rgba(227,247,239,0), var(--green-bg));
}
.plan-desc-more{
  position:absolute;left:0;bottom:0;
  border:none;background:transparent;color:var(--t1);
  padding:0;font-size:11px;font-weight:800;font-family:inherit;
  cursor:pointer;touch-action:manipulation;
}
.plan-desc-more:active{opacity:.55}
.plan-route-stop.active{
  background:var(--green-bg);
}
.plan-route-stop.active .prs-num{
  background:var(--green);border-color:var(--green);color:#fff;
}
.plan-route-stop.has-loc{cursor:pointer;transition:background .14s}
@media(hover:hover){.plan-route-stop.has-loc:hover{background:var(--hov)}}
.plan-route-stop.place-expanded{background:var(--bg)}
.place-detail-slot{display:none;grid-column:1/-1}
.place-detail-slot.open{
  display:block;
  animation:placeDetailOpen .28s cubic-bezier(0.18,1.18,0.3,1) both;
  transform-origin:top center;
}
/* When a place detail is open inside a collapsed plan route, allow it to expand */
.plan-route-outer.collapsed:has(.place-detail-slot.open){
  max-height:none;overflow:visible;
}
.plan-route-outer.collapsed:has(.place-detail-slot.open)::after{display:none}
@keyframes placeDetailOpen{
  from{opacity:0;transform:translateY(-8px) scale(.985);max-height:0}
  to{opacity:1;transform:none;max-height:860px}
}
.place-detail-card{
  margin-top:7px;border:1px solid rgba(0,0,0,.08);border-radius:14px;
  overflow:hidden;background:#2e2d2b;color:#fff;
  box-shadow:none;
}
.place-detail-card.ready{
  animation:placeDetailReady .32s cubic-bezier(0.18,1.18,0.3,1) both;
}
@keyframes placeDetailReady{
  from{opacity:.52;filter:blur(3px);transform:translateY(6px)}
  to{opacity:1;filter:none;transform:none}
}
.place-detail-card.loading{
  min-height:206px;position:relative;padding:18px;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.place-detail-shimmer{
  position:absolute;inset:0;
  background:linear-gradient(110deg,#30302d 0%,#44443f 42%,#30302d 76%);
  background-size:220% 100%;
  animation:placeShimmer 1s ease-in-out infinite;
}
@keyframes placeShimmer{
  from{background-position:110% 0}
  to{background-position:-110% 0}
}
.place-detail-top{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  min-height:44px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.07);
  background:none;
}
.place-detail-head{align-items:flex-start;padding:14px 15px 13px}
.place-detail-title{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;
}
.place-detail-eyebrow{
  width:max-content;max-width:100%;padding:3px 7px;border-radius:100px;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.72);
  font-size:10px;font-weight:900;line-height:1.15;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.place-detail-top strong{
  min-width:0;color:#fff;font-size:16px;font-weight:900;line-height:1.22;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.place-detail-title > span:not(.place-detail-eyebrow){
  color:rgba(255,255,255,.68);font-size:11px;line-height:1.35;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.place-detail-chips{
  display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:6px;
}
.place-chip{
  max-width:100%;padding:4px 7px;border-radius:100px;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.78);
  font-size:10px;font-weight:900;line-height:1.15;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.place-chip.status.open{background:rgba(53,208,127,.18);color:#93f0bf}
.place-chip.status.closed{background:rgba(240,85,51,.16);color:#ffb4a3}
.place-chip.rating{background:rgba(255,205,92,.15);color:#ffe1a3}
.place-chip.price{background:rgba(255,255,255,.14)}
.place-detail-close{
  width:28px;height:28px;border:none;border-radius:50%;
  display:grid;place-items:center;flex:0 0 auto;
  background:transparent;color:rgba(255,255,255,.7);
  font-size:22px;line-height:1;font-family:inherit;cursor:pointer;
}
@media(hover:hover){.place-detail-close:hover{background:rgba(255,255,255,.1);color:#fff}}
.place-gallery{
  --place-gallery-w:min(100%,650px);
  position:relative;padding:22px 68px 16px;
  background:linear-gradient(180deg,#343431,#2b2b29);
}
.place-gallery.fallback-map{padding:18px;background:#2b2b29}
.place-gallery.fallback-map .place-main-photo{box-shadow:none}
.place-main-photo{
  width:var(--place-gallery-w);height:clamp(176px,32vw,260px);margin:0 auto;
  border-radius:14px;overflow:hidden;background:#242423;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
.place-main-photo img{
  width:100%;height:100%;display:block;object-fit:cover;
}
.place-gallery-arrow{
  position:absolute;top:calc(24px + clamp(176px,32vw,260px) / 2 - 17px);z-index:2;width:34px;height:34px;
  border:1px solid rgba(255,255,255,.14);border-radius:50%;
  background:rgba(26,25,23,.78);color:#fff;font-size:25px;line-height:1;
  display:grid;place-items:center;cursor:pointer;
}
.place-gallery-arrow.prev{left:28px}
.place-gallery-arrow.next{right:28px}
@media(hover:hover){.place-gallery-arrow:hover{background:rgba(255,255,255,.16)}}
.place-thumb-rail{
  width:var(--place-gallery-w);margin:14px auto 0;padding:0 2px 3px;
  display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x proximity;
  scrollbar-width:none;justify-content:center;
}
.place-thumb-rail::-webkit-scrollbar{display:none}
.place-thumb{
  position:relative;flex:0 0 58px;width:58px;height:48px;padding:0;
  border:1px solid rgba(255,255,255,.18);border-radius:8px;overflow:hidden;
  background:#242423;cursor:pointer;scroll-snap-align:center;
}
.place-thumb img{width:100%;height:100%;display:block;object-fit:cover}
.place-thumb.active{border-color:rgba(255,255,255,.88);box-shadow:0 0 0 2px rgba(255,255,255,.16)}
.place-thumb.failed{display:none}
.place-thumb.active::after{
  content:"";position:absolute;left:16px;right:16px;bottom:-1px;height:2px;
  background:#fff;border-radius:2px;
}
.place-photo-empty{
  height:160px;display:grid;place-items:center;
  background:linear-gradient(135deg,#242423,#4d4b47);
}
.place-photo-empty span{
  width:48px;height:48px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.12);color:#fff;font-size:22px;font-weight:900;
}
.place-detail-copy{
  position:relative;z-index:1;padding:13px 14px 14px;
  display:flex;flex-direction:column;gap:8px;min-width:0;
}
.place-detail-copy strong{
  font-size:14px;font-weight:850;color:var(--t1);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.place-detail-copy > span,
.place-detail-copy p{
  margin:0;font-size:12px;line-height:1.45;color:var(--t2);
}
.place-detail-card.loading .place-detail-copy strong{color:#fff}
.place-detail-card.loading .place-detail-copy > span{color:rgba(255,255,255,.7)}
.place-detail-card.loading .place-detail-copy{
  align-items:center;gap:10px;width:min(100%,520px);max-width:100%;
}
.place-detail-card.loading .place-detail-copy strong{
  display:block;width:100%;max-width:100%;
}
.place-detail-card.loading .place-detail-copy > span{
  max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.place-detail-section{
  padding:14px 18px;border-top:1px solid rgba(255,255,255,.06);
  background:none;
}
.place-detail-section h4{
  margin:0 0 8px;color:#fff;font-size:13px;font-weight:800;
}
.place-overview{
  margin:0;color:rgba(255,255,255,.78);font-size:12px;line-height:1.58;
  white-space:pre-line;
}
.place-overview.collapsed{
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;white-space:normal;
}
.place-overview-toggle{
  margin-top:8px;border:none;background:transparent;color:#fff;
  font-size:12px;font-weight:900;font-family:inherit;padding:0;cursor:pointer;
}
@media(hover:hover){.place-overview-toggle:hover{text-decoration:underline}}
@media(max-width:520px){
  .place-gallery{padding-left:48px;padding-right:48px}
  .place-gallery-arrow.prev{left:14px}
  .place-gallery-arrow.next{right:14px}
  .place-thumb-rail{justify-content:flex-start}
}
.place-info-list{display:flex;flex-direction:column;gap:11px}
.place-info-row{
  display:grid;grid-template-columns:86px minmax(0,1fr);gap:12px;align-items:start;
}
.place-info-row span{
  color:rgba(255,255,255,.62);font-size:11px;font-weight:850;
}
.place-info-row p{
  margin:0;color:rgba(255,255,255,.78);font-size:11px;line-height:1.45;
  word-break:break-word;
}
.place-info-row a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.28)}
.place-detail-actions{
  display:flex;align-items:center;gap:7px;flex-wrap:wrap;
  padding:12px 18px 16px;background:rgba(255,255,255,.03);
}
.place-map-open,.place-link{
  border:none;border-radius:100px;background:rgba(255,255,255,.14);color:#fff;
  text-decoration:none;font-size:11px;font-weight:800;font-family:inherit;
  padding:7px 12px;white-space:nowrap;cursor:pointer;
}
.place-map-open{background:rgba(255,255,255,.2)}
.place-directions{background:#35d07f!important;color:#173326!important}
.place-directions:disabled{background:rgba(255,255,255,.18)!important;color:rgba(255,255,255,.55)!important;cursor:default}
@media(hover:hover){
  .place-map-open:hover,.place-link:hover{background:rgba(255,255,255,.28)}
  .place-directions:hover{background:#48e090!important}
}
.plan-travel{
  padding:0 10px 0 38px;border-bottom:1px solid var(--bor);
  background:var(--sur);position:relative;
}
.pt-inner{display:flex;align-items:flex-start;gap:10px;padding:10px 0}
.pt-vline{
  width:2px;flex-shrink:0;align-self:stretch;min-height:18px;
  background:var(--bor);border-radius:2px;margin-top:2px;
}
.pt-info{display:flex;flex-wrap:wrap;align-items:center;gap:6px;flex:1;min-width:0}
.pt-loading{font-size:11px;color:var(--t3)}
.pt-time-btn{
  border:none;border-radius:var(--rs);background:var(--sur2);
  color:var(--t1);font-size:12px;font-weight:800;font-family:inherit;
  padding:4px 9px;cursor:pointer;touch-action:manipulation;
  transition:background .13s,color .13s;flex-shrink:0;
}
@media(hover:hover){.pt-time-btn:hover{background:var(--soft-ink);color:#fff}}
.pt-time-btn:active{transform:scale(.94)}
.pt-chips{display:flex;gap:5px;flex-wrap:wrap}
.pt-chip{
  min-height:18px;font-size:9px;font-weight:800;padding:1px 6px;border-radius:100px;
  color:#fff;letter-spacing:.02em;white-space:nowrap;display:inline-flex;align-items:center;gap:3px;
}
.pt-chip.walk{background:var(--t3);color:#fff}
.pt-chip.drive{background:var(--sur2);color:var(--t1)}
.pt-chip.drive svg{width:12px;height:12px;stroke-width:2;flex-shrink:0}
.pt-meta{font-size:11px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pt-warn{
  font-size:10px;font-weight:800;color:#d97706;
  background:#fef3c7;border-radius:100px;padding:2px 7px;white-space:nowrap;
}
.pt-fallback-btn{
  border:none;border-radius:var(--rs);background:var(--sur2);
  color:var(--t3);font-size:12px;font-weight:600;font-family:inherit;
  padding:4px 9px;cursor:pointer;touch-action:manipulation;
  border:1px dashed var(--bor);
  transition:background .13s,color .13s,border-color .13s;flex-shrink:0;
}
@media(hover:hover){.pt-fallback-btn:hover{background:var(--hov);color:var(--t1);border-color:var(--t3)}}
.pt-fallback-btn:active{transform:scale(.94);opacity:.7}
.pt-fallback-btn:disabled{opacity:.5;cursor:default}
@keyframes routeMarkerIn{
  from{opacity:0;transform:scale(0) translateY(6px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.route-user-marker{
  width:18px;height:18px;border-radius:50%;
  background:#2a7fff;border:3px solid #fff;
  box-shadow:0 2px 10px rgba(0,0,0,.32),0 0 0 7px rgba(42,127,255,.2);
  position:relative;
}
.route-user-marker::after{
  content:"";position:absolute;inset:-8px;border-radius:50%;
  border:1px solid rgba(42,127,255,.26);
}
.route-locate-control button{
  width:29px;height:29px;
  display:flex;align-items:center;justify-content:center;
  color:#333;
  touch-action:manipulation;
}
.route-locate-control button svg{
  width:17px;height:17px;
}
.route-locate-control button.locating svg{
  color:#2a7fff;
  animation:routeLocatePulse .72s ease-in-out infinite alternate;
}
.route-locate-control button:disabled{
  opacity:.72;cursor:default;
}
@keyframes routeLocatePulse{
  from{transform:scale(.9)}
  to{transform:scale(1.08)}
}

/* Transit route map modal */
.transit-modal{
  position:fixed;inset:0;z-index:1400;background:rgba(0,0,0,.0);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  animation:routeModalBgIn .28s ease forwards;
}
@keyframes routeModalBgIn{
  to{background:rgba(0,0,0,.58)}
}
.transit-modal-sheet{
  position:relative;width:min(860px,100%);height:min(580px,82dvh);
  border-radius:20px;overflow:hidden;background:#2f2d2a;
  box-shadow:0 10px 36px rgba(0,0,0,.22);
  animation:routeSheetIn .32s cubic-bezier(0.34,1.12,0.64,1) both;
}
@keyframes routeSheetIn{
  from{opacity:0;transform:scale(.94) translateY(16px)}
  to{opacity:1;transform:none}
}
.transit-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);
}
.transit-modal-info{
  position:absolute;left:16px;top:16px;z-index:3;max-width:min(400px,72%);
  display:flex;flex-direction:column;gap:4px;
  padding:11px 14px;border-radius:16px;
  background:rgba(26,25,23,.92);color:#fff;
  border:1px solid rgba(255,255,255,.08);
}
.tmi-route{font-size:14px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tmi-chips{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}
.tmi-chip{font-size:10px;font-weight:850;padding:2px 7px;border-radius:100px;color:#fff}
.tmi-meta{font-size:11px;color:rgba(255,255,255,.65)}
.transit-modal-canvas{position:absolute;inset:0}
.task-map-panel{
  margin-top:10px;border:1px solid var(--bor);border-radius:var(--r);
  overflow:hidden;background:var(--bg);box-shadow:var(--sh1);
  animation:taskMapIn .22s cubic-bezier(0.34,1.08,0.64,1) both;
}
.task-map-panel.closing{animation:taskMapOut .18s ease forwards}
@keyframes taskMapIn{from{opacity:0;transform:translateY(-6px);max-height:0}to{opacity:1;transform:none;max-height:680px}}
@keyframes taskMapOut{to{opacity:0;transform:translateY(-4px);max-height:0}}
.task-map-head{
  padding:10px 12px;border-bottom:1px solid var(--bor);
  display:flex;flex-direction:column;gap:2px;
}
.task-map-head strong{font-size:13px;font-weight:800;color:var(--t1)}
.task-map-head span{font-size:12px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.task-map-canvas{height:220px;background:#242423}
.task-map-panel .mapboxgl-ctrl-bottom-left,
.task-map-panel .mapboxgl-ctrl-bottom-right{display:none}
.dd{font-size:11px;font-weight:600;padding:2px 8px;border-radius:100px;letter-spacing:.02em}
.dd-d0{background:var(--red-bg);color:var(--red)}
.dd-hot{background:var(--red-bg);color:var(--red)}
.dd-warm{background:var(--amber-bg);color:var(--amber)}
.dd-cool{background:var(--sur2);color:var(--t2)}
.dd-past{background:var(--red-bg);color:var(--red);opacity:.6}
.tc-desc{font-size:13px;color:var(--t2);margin-top:5px;word-break:break-word;line-height:1.6}
.desc-more{
  display:inline;background:none;border:none;padding:0 0 0 4px;
  font-size:12px;font-weight:600;color:var(--t1);cursor:pointer;
  font-family:inherit;transition:opacity .12s;user-select:none;touch-action:manipulation;
}
.desc-more:active{opacity:.5}
.tc-acts{display:flex;gap:2px;flex-shrink:0;opacity:0;transition:opacity .12s}
.tcard:hover .tc-acts,.tcard:focus-within .tc-acts{opacity:1}
.ta{
  width:32px;height:32px;border:none;background:none;border-radius:var(--rs);
  display:flex;align-items:center;justify-content:center;
  color:var(--t2);font-size:14px;touch-action:manipulation;
  transition:background .1s,color .12s,transform .2s cubic-bezier(0.34,1.6,0.64,1);
}
@media(hover:hover){
  .ta:hover{background:var(--hov)}
  .ta.tdel:hover{color:var(--red);background:var(--red-bg)}
  .ta.tres:hover{color:var(--green);background:var(--green-bg)}
}
.ta:active{transform:scale(0.8)}

/* ─── INLINE EDIT FORM ─── */
.tc-edit{display:none;flex-direction:column;gap:0;flex:1;min-width:0}
.tc-edit.open{display:flex;animation:editIn .2s cubic-bezier(0.34,1.08,0.64,1) both}
@keyframes editIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.tc-body.hide,.tc-chk.hide{display:none}
.e-title-row{display:flex;align-items:center;border-bottom:1px solid var(--bor);padding-bottom:10px}
.e-notify-toggle{
  width:30px;height:30px;border-radius:50%;border:1px solid var(--bor);
  background:var(--sur);color:var(--t3);
  display:flex;align-items:center;justify-content:center;
  padding:0;line-height:1;flex-shrink:0;
  transition:background .14s,color .14s,border-color .14s;
}
.e-notify-toggle.on{background:var(--t1);color:#fff;border-color:var(--t1)}
.e-notify-toggle svg{display:block;flex-shrink:0}
.tc-edit .e-t{
  border:none;
  padding:0;
  font-size:15px;font-weight:500;font-family:inherit;color:var(--t1);
  background:transparent;outline:none;width:100%;flex:1;min-width:0;
}
.tc-edit .e-d{
  border:none;border-bottom:1px solid var(--bor);
  padding:10px 0;
  font-size:13px;font-family:inherit;color:var(--t2);
  background:transparent;outline:none;resize:none;min-height:52px;
}
.e-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:10px;gap:8px;flex-wrap:wrap;
}
.e-date-wrap{
  display:inline-flex;align-items:center;gap:5px;cursor:pointer;
  padding:5px 8px;border-radius:var(--rs);margin-left:-8px;
  transition:background .12s;touch-action:manipulation;flex-shrink:0;
}
@media(hover:hover){.e-date-wrap:hover{background:var(--hov)}}
.e-date-wrap svg{color:var(--t3);flex-shrink:0}
.tc-edit .e-due,.tc-edit .e-end,.tc-edit .e-time{
  border:none;outline:none;background:transparent;
  font-size:13px;font-family:inherit;color:var(--t2);cursor:pointer;
}
.tc-edit .file-field{padding:10px 0;background:transparent}
.tc-edit-acts{display:flex;gap:6px;flex-shrink:0}

/* ─── e-controls (edit form date row) ─── */
.e-controls{
  margin-left:-8px;
}
.e-pill-wrap{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 8px;border-radius:var(--rs);
  cursor:pointer;touch-action:manipulation;flex-shrink:0;
  transition:background .12s;
}
@media(hover:hover){.e-pill-wrap:hover{background:var(--hov)}}
.e-pill-wrap svg{color:var(--t3);flex-shrink:0}
.e-pill-wrap input[type=date],
.e-pill-wrap input[type=time]{
  border:none;outline:none;background:transparent;
  font-size:13px;font-family:inherit;color:var(--t2);
  cursor:pointer;min-width:0;max-width:110px;
}
.e-extra-btn{
  display:inline-flex;align-items:center;gap:4px;
  padding:5px 8px;border-radius:var(--rs);
  border:1.5px dashed var(--bor);background:none;
  color:var(--t3);font-size:12px;font-weight:500;
  cursor:pointer;font-family:inherit;touch-action:manipulation;
  transition:border-color .12s,color .12s;
  white-space:nowrap;flex-shrink:0;
}
@media(hover:hover){.e-extra-btn:hover{border-color:var(--t2);color:var(--t2)}}
.e-extra-btn svg{color:currentColor;flex-shrink:0}
.e-pill-x{
  border:none;background:none;color:var(--t3);
  font-size:15px;line-height:1;cursor:pointer;
  padding:0 0 0 1px;font-family:inherit;
  touch-action:manipulation;flex-shrink:0;transition:color .1s;
}
@media(hover:hover){.e-pill-x:hover{color:var(--red)}}

.empty{text-align:center;padding:72px 24px;animation:cardIn .28s ease both}
.empty-ic{font-size:42px;margin-bottom:14px;opacity:.38}
.empty-tx{font-size:14px;color:var(--t2);line-height:1.6}
.loading{text-align:center;padding:56px;color:var(--t2);font-size:13px}
