/* ════════════════════════════════════════════════════════════════
   /italydo — the activity directory + day planner. Inherits italyeat.css
   tokens & shell (.ie-*). Adds practical-data-forward activity cards, the
   filter toggles, and the DAY PLANNER (the signature feature).
   Zero external requests. Pairs with wishlist.css (hearts) + italydo.js.
   ════════════════════════════════════════════════════════════════ */

/* breathing room at the top of the sticky bar (matches /italysleep) */
.do .ie-filterbar-inner{padding-top:16px}

/* ── toggle row (Indoor/Outdoor) above the chips ──────────────── */
.is-toggles{display:flex;align-items:center;gap:16px;flex-wrap:wrap;width:100%;padding:2px 0 8px;margin-bottom:6px;border-bottom:1px dashed var(--ie-hair-soft)}
.is-tgroup{display:flex;align-items:center;gap:8px}
.is-tgroup-label{font-family:var(--ie-fu);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ie-ink-38)}
.is-tg{display:inline-flex;border:1px solid var(--ie-hair);border-radius:2px;overflow:hidden}
.is-tg button{font-family:var(--ie-fu);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ie-ink-60);background:none;border:none;padding:6px 11px;cursor:pointer;border-left:1px solid var(--ie-hair);transition:background .2s,color .2s}
.is-tg button:first-child{border-left:none}
.is-tg button.on{background:var(--ie-terra);color:var(--ie-paper)}
.do-positioning{color:var(--ie-terra)!important}

/* ── grid ─────────────────────────────────────────────────────── */
.do-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:1199px){.do-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:719px){.do-grid{grid-template-columns:1fr}}

/* ── activity card (class do-card so wishlist hearts hook in) ──── */
.do .do-card{position:relative;background:var(--ie-paper);border:1px solid var(--ie-hair-soft);border-radius:3px;padding:18px 18px 16px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;min-height:230px}
.do .do-card:hover{transform:translateY(-3px);box-shadow:0 8px 26px rgba(31,26,20,.10)}
.do .do-loc{display:flex;align-items:baseline;gap:8px;font-family:var(--ie-fu);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ie-terra);padding-right:34px}
.do .do-loc .cat{color:var(--ie-ink-38)}
.do .do-name{font-family:var(--ie-fd);font-weight:500;font-size:clamp(19px,1.5vw,22px);line-height:1.12;color:var(--ie-espresso)}
/* the practical strip — the loudest element after the name */
.do .do-strip{font-family:var(--ie-fu);font-size:13px;letter-spacing:.01em;color:var(--ie-terra);display:flex;flex-wrap:wrap;align-items:center;gap:4px 0;line-height:1.4}
.do .do-strip .tok{white-space:nowrap}
.do .do-strip .tok + .tok::before{content:"·";margin:0 9px;color:var(--ie-ink-38)}
.do .do-strip .eff{display:inline-flex;align-items:center;gap:5px}
.do .do-strip .eff .eff-word{font-weight:700;color:var(--ie-terra-deep);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.do .do-strip .book{color:var(--ie-ink-60)}
/* effort terrain mark — filled silhouette, terracotta */
.eff-mark{display:block;flex-shrink:0}
.eff-mark path{fill:var(--ie-terra)}
.do .do-season{font-family:var(--ie-fd);font-style:italic;font-size:12.5px;color:var(--ie-ink-60)}
.do .do-desc{font-family:var(--ie-fb);font-size:13.5px;line-height:1.55;color:var(--ie-ink-60);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.do .do-bestfor{display:flex;flex-wrap:wrap;gap:5px}
.do .do-bestfor .bf{font-family:var(--ie-fu);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ie-terra);border:1px solid rgba(178,82,56,.28);border-radius:2px;padding:3px 7px}
.do .do-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:10px;border-top:1px solid var(--ie-hair-soft)}
.do-addtrip{font-family:var(--ie-fu);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ie-terra);background:transparent;border:1px solid rgba(178,82,56,.4);border-radius:2px;padding:5px 10px;cursor:pointer;transition:background .2s,color .2s}
.do-addtrip:hover{background:var(--ie-wash)}
.do-addtrip.in{background:var(--ie-terra);border-color:var(--ie-terra);color:var(--ie-paper)}
.do .do-link{font-family:var(--ie-fu);font-size:10px;letter-spacing:.06em;color:var(--ie-terra);text-decoration:none}
.do .do-freewalk{font-family:var(--ie-fd);font-style:italic;font-size:11px;color:var(--ie-ink-38)}
/* tier hierarchy */
.do .do-card[data-tier-mark="hala-vetted"]{border-top:2px solid var(--ie-terra)}
.do .do-card[data-tier-mark="sofias-pick"]{border:1px solid var(--ie-terra);border-top:3px solid var(--ie-terra)}
.do-tiermark{display:inline-flex;align-items:center;gap:6px;font-family:var(--ie-fu);font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ie-terra)}
.do-tiermark .seal{width:14px;height:14px;border-radius:50%;background:var(--ie-terra);color:var(--ie-paper);display:inline-flex;align-items:center;justify-content:center;font-family:var(--ie-fd);font-size:9px;font-style:italic}

/* ── SEASONAL MODULE (between hero and grid) ──────────────────── */
.do-seasonal{border-top:1px solid var(--ie-hair);border-bottom:1px solid var(--ie-hair);padding:clamp(22px,3vw,34px) 0;background:var(--ie-paper-soft)}
.do-seasonal-k{font-family:var(--ie-fu);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ie-terra);margin-bottom:10px;display:block}
.do-seasonal h2{font-family:var(--ie-fd);font-weight:400;font-size:clamp(22px,2.6vw,32px);line-height:1.15;color:var(--ie-espresso);max-width:30ch;margin-bottom:18px}
.do-seasonal-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:14px}
.do-seasonal-card{border-left:2px solid var(--ie-terra);padding:2px 0 2px 12px}
.do-seasonal-card .t{font-family:var(--ie-fd);font-size:16px;color:var(--ie-espresso);line-height:1.2}
.do-seasonal-card .w{font-family:var(--ie-fu);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ie-terra);margin:4px 0}
.do-seasonal-card .d{font-family:var(--ie-fb);font-size:13px;color:var(--ie-ink-60);line-height:1.45}
.do-seasonal-all{font-family:var(--ie-fu);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ie-terra);text-decoration:none;cursor:pointer}

/* ── MODAL cross-references ───────────────────────────────────── */
.do-xref{margin-top:16px;border-top:1px solid var(--ie-hair);padding-top:14px}
.do-xref h4{font-family:var(--ie-fu);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ie-terra);margin-bottom:8px}
.do-xref-row{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.do-xref-item{display:flex;align-items:baseline;gap:8px;font-family:var(--ie-fb);font-size:14px;color:var(--ie-ink);cursor:pointer;padding:4px 0}
.do-xref-item:hover .nm{text-decoration:underline;text-decoration-color:var(--ie-terra)}
.do-xref-item .nm{color:var(--ie-espresso);font-family:var(--ie-fd);font-size:16px}
.do-xref-item .mt{font-family:var(--ie-fu);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ie-ink-38)}
.ie-modal .do-modal-strip{font-family:var(--ie-fu);font-size:13px;color:var(--ie-terra);margin:8px 0 14px}
.ie-modal .do-modal-strip .eff{display:inline-flex;align-items:center;gap:6px;vertical-align:middle}
.ie-modal .do-modal-strip .eff .eff-word{font-weight:700;color:var(--ie-terra-deep);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
/* effort filter dropdown — 40px mark + word; mark fades until the row is selected */
.ie-opt .eff-opt{display:inline-flex;align-items:center;gap:11px}
.ie-opt .eff-opt .eff-word{font-family:var(--ie-fu);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ie-ink-60)}
.ie-opt .eff-opt .eff-mark{opacity:.42;transition:opacity .15s}
.ie-opt.sel .eff-opt .eff-mark{opacity:1}
.ie-opt.sel .eff-opt .eff-word{color:var(--ie-terra-deep)}

/* ── TRIP PILL (persistent, bottom-right) ─────────────────────── */
.do-trippill{position:fixed;right:20px;bottom:20px;z-index:9400;display:none;align-items:center;gap:12px;background:var(--ie-espresso);color:var(--ie-paper);border-radius:3px;padding:11px 15px;box-shadow:0 12px 36px rgba(31,26,20,.32)}
.do-trippill.show{display:flex}
.do-trippill .lbl{font-family:var(--ie-fu);font-size:11px;letter-spacing:.06em;text-transform:uppercase;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.do-trippill .lbl b{color:var(--ie-ochre)}
.do-trippill .open{font-family:var(--ie-fu);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ie-paper);background:var(--ie-terra);border:none;border-radius:2px;padding:8px 13px;cursor:pointer}
.do-trippill .switch{font-family:var(--ie-fu);font-size:14px;color:rgba(245,233,213,.7);background:none;border:none;cursor:pointer;padding:0 4px}
.do-tripmenu{position:fixed;right:20px;bottom:74px;z-index:9410;background:var(--ie-paper);border:1px solid var(--ie-hair);border-radius:3px;box-shadow:0 10px 30px rgba(31,26,20,.2);padding:8px;display:none;min-width:240px}
.do-tripmenu.show{display:block}
.do-tripmenu .mi{font-family:var(--ie-fb);font-size:13px;color:var(--ie-ink);padding:8px 10px;border-radius:2px;cursor:pointer;display:flex;justify-content:space-between;gap:10px}
.do-tripmenu .mi:hover{background:var(--ie-paper-soft)}
.do-tripmenu .mi.on{color:var(--ie-terra)}
.do-tripmenu .new{border-top:1px solid var(--ie-hair-soft);margin-top:6px;padding-top:10px;color:var(--ie-terra);font-family:var(--ie-fu);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
@media(max-width:560px){.do-trippill{left:12px;right:12px;bottom:12px;justify-content:space-between}.do-tripmenu{left:12px;right:12px;bottom:70px}}

/* ── small modal (create trip) ────────────────────────────────── */
.do-mini-bd{position:fixed;inset:0;z-index:9800;background:rgba(31,26,20,.4);opacity:0;pointer-events:none;transition:opacity .25s}
.do-mini-bd.open{opacity:1;pointer-events:auto}
.do-mini{position:fixed;z-index:9810;top:50%;left:50%;transform:translate(-50%,-46%);width:420px;max-width:calc(100vw - 28px);background:var(--ie-paper);border:1px solid var(--ie-hair);border-radius:4px;box-shadow:0 18px 60px rgba(31,26,20,.28);padding:26px 26px 24px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.do-mini.open{opacity:1;pointer-events:auto;transform:translate(-50%,-50%)}
.do-mini h3{font-family:var(--ie-fd);font-weight:400;font-size:26px;color:var(--ie-espresso);margin-bottom:4px}
.do-mini p{font-family:var(--ie-fb);font-size:13px;color:var(--ie-ink-60);margin-bottom:16px}
.do-field{margin-bottom:14px}
.do-field label{display:block;font-family:var(--ie-fu);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ie-ink-38);margin-bottom:5px}
.do-field input,.do-field select{width:100%;font-family:var(--ie-fb);font-size:14px;color:var(--ie-ink);background:var(--ie-paper-soft);border:1px solid var(--ie-hair);border-radius:2px;padding:9px 11px}
.do-field .row{display:flex;gap:10px}
.do-mini-acts{display:flex;justify-content:flex-end;gap:12px;margin-top:18px}
.do-mini-acts button{font-family:var(--ie-fb);font-size:14px;padding:11px 20px;border-radius:2px;cursor:pointer;border:1px solid var(--ie-terra)}
.do-mini-acts .go{background:var(--ie-terra);color:var(--ie-paper)}
.do-mini-acts .cancel{background:transparent;color:var(--ie-ink-60);border-color:var(--ie-hair)}

/* ── DAY PLANNER (full-screen) ────────────────────────────────── */
.do-plan-bd{position:fixed;inset:0;z-index:9700;background:rgba(31,26,20,.4);opacity:0;pointer-events:none;transition:opacity .3s}
.do-plan-bd.open{opacity:1;pointer-events:auto}
.do-plan{position:fixed;inset:0;z-index:9750;background:var(--ie-paper);transform:translateY(2%);opacity:0;pointer-events:none;transition:opacity .35s,transform .35s;display:flex;flex-direction:column;overflow:hidden}
.do-plan.open{opacity:1;pointer-events:auto;transform:none}
.do-plan-head{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px var(--ie-g);border-bottom:1px solid var(--ie-hair);background:var(--ie-paper-soft);flex-wrap:wrap}
.do-plan-title input{font-family:var(--ie-fd);font-weight:400;font-size:clamp(20px,2.4vw,28px);color:var(--ie-espresso);background:none;border:none;border-bottom:1px dashed transparent;outline:none;width:auto;min-width:120px}
.do-plan-title input:focus{border-bottom-color:var(--ie-terra)}
.do-plan-title .meta{font-family:var(--ie-fu);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ie-ink-38);margin-top:2px;display:flex;gap:8px;align-items:center}
.do-plan-title .meta input{font-family:var(--ie-fu);font-size:10px;color:var(--ie-terra);border:none;background:none;letter-spacing:.1em}
.do-plan-acts{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.do-plan-acts button,.do-plan-acts a{font-family:var(--ie-fu);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:1px solid var(--ie-hair);background:transparent;color:var(--ie-ink-60);border-radius:2px;padding:8px 12px;text-decoration:none}
.do-plan-acts .send{background:var(--ie-terra);border-color:var(--ie-terra);color:var(--ie-paper)}
.do-plan-acts .close{font-family:var(--ie-fd);font-size:24px;border:none;padding:0 6px;color:var(--ie-terra)}
.do-plan-acts .danger{color:var(--ie-terra-deep);border-color:rgba(142,63,42,.3)}

.do-daysbar{flex-shrink:0;display:flex;gap:6px;align-items:center;padding:12px var(--ie-g);border-bottom:1px solid var(--ie-hair-soft);overflow-x:auto}
.do-daytab{font-family:var(--ie-fu);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ie-ink-60);background:var(--ie-paper-soft);border:1px solid var(--ie-hair);border-radius:2px;padding:8px 14px;cursor:pointer;white-space:nowrap}
.do-daytab.on{background:var(--ie-terra);border-color:var(--ie-terra);color:var(--ie-paper)}
.do-daytab .rm{margin-left:8px;opacity:.6}
.do-addday{font-family:var(--ie-fu);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ie-terra);background:none;border:1px dashed rgba(178,82,56,.4);border-radius:2px;padding:8px 12px;cursor:pointer}

.do-plan-scroll{flex:1;overflow:auto}
.do-day{max-width:var(--ie-max);margin:0 auto;padding:20px var(--ie-g) 60px;display:grid;grid-template-columns:1fr 320px;gap:28px;align-items:start}
@media(max-width:860px){.do-day{grid-template-columns:1fr}}
.do-slots{display:flex;flex-direction:column;gap:12px}
.do-slot{display:grid;grid-template-columns:120px 1fr;gap:14px;align-items:start}
.do-slot-label{font-family:var(--ie-fu);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ie-terra);padding-top:12px}
.do-slot-label span{display:block;color:var(--ie-ink-38);font-size:9px;margin-top:2px}
.do-slot-zone{min-height:64px;border:1px dashed var(--ie-hair);border-radius:3px;padding:8px;display:flex;flex-direction:column;gap:8px;transition:background .15s,border-color .15s}
.do-slot-zone.dragover{background:var(--ie-wash);border-color:var(--ie-terra)}
.do-slot-zone .ph{font-family:var(--ie-fd);font-style:italic;font-size:13px;color:var(--ie-ink-38);padding:6px 4px}

.do-item{display:flex;align-items:center;gap:10px;background:var(--ie-paper);border:1px solid var(--ie-hair-soft);border-radius:3px;padding:8px 10px;cursor:grab}
.do-item.dragging{opacity:.45}
.do-item .glyph{width:42px;height:42px;border-radius:2px;background:var(--ie-paper-deep);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--ie-fu);font-size:8px;letter-spacing:.06em;text-transform:uppercase;color:var(--ie-terra);text-align:center;line-height:1.1;padding:2px}
.do-item .info{flex:1;min-width:0}
.do-item .nm{font-family:var(--ie-fd);font-size:16px;color:var(--ie-espresso);line-height:1.1;cursor:pointer}
.do-item .nm:hover{text-decoration:underline;text-decoration-color:var(--ie-terra)}
.do-item .st{font-family:var(--ie-fu);font-size:10px;color:var(--ie-terra);margin-top:3px}
.do-item .rm{font-family:var(--ie-fu);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--ie-ink-38);background:none;border:none;cursor:pointer;flex-shrink:0}
.do-item .rm:hover{color:var(--ie-terra)}
.do-item .move{font-family:var(--ie-fu);font-size:9px;color:var(--ie-terra);background:var(--ie-paper-soft);border:1px solid var(--ie-hair);border-radius:2px;padding:3px 6px;cursor:pointer;display:none}
@media(max-width:860px){.do-item{cursor:default}.do-item .move{display:inline-block}}

.do-add-activity{font-family:var(--ie-fu);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ie-terra);background:none;border:1px dashed rgba(178,82,56,.4);border-radius:2px;padding:11px;cursor:pointer;margin-top:6px}
.do-copy-day{font-family:var(--ie-fu);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ie-ink-38);background:none;border:none;cursor:pointer;margin-top:4px;align-self:flex-start}

/* day summary */
.do-summary{position:sticky;top:0;background:var(--ie-paper-soft);border-top:3px solid var(--ie-terra);border-radius:3px;padding:18px 20px}
.do-summary h4{font-family:var(--ie-fu);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ie-terra);margin-bottom:14px}
.do-sumrow{display:flex;justify-content:space-between;gap:10px;font-family:var(--ie-fb);font-size:14px;color:var(--ie-ink);padding:6px 0;border-bottom:1px solid var(--ie-hair-soft)}
.do-sumrow .k{color:var(--ie-ink-60)}
.do-sumrow .v{font-family:var(--ie-fu);font-size:12px;color:var(--ie-espresso)}
.do-warnings{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.do-warn{font-family:var(--ie-fd);font-style:italic;font-size:13.5px;line-height:1.4;color:var(--ie-terra-deep);padding-left:14px;position:relative}
.do-warn::before{content:"!";position:absolute;left:0;font-style:normal;font-family:var(--ie-fu);font-weight:700;color:var(--ie-terra)}
.do-mapnote{margin-top:14px;border:1px solid var(--ie-hair);border-radius:3px;background:linear-gradient(145deg,var(--ie-paper),var(--ie-paper-deep));padding:18px;text-align:center;font-family:var(--ie-fd);font-style:italic;font-size:13px;color:var(--ie-ink-60)}
.do-plan-empty{max-width:var(--ie-max);margin:0 auto;padding:60px var(--ie-g);text-align:center;font-family:var(--ie-fd);font-style:italic;font-size:18px;color:var(--ie-ink-60)}

@media(prefers-reduced-motion:reduce){
  .do .do-card:hover{transform:none}
  .do-plan,.do-plan-bd,.do-mini,.do-mini-bd{transition:none!important}
}
@media print{
  body>*:not(.do-plan){display:none!important}
  .do-plan{position:static;opacity:1;transform:none;height:auto}
  .do-plan-bd,.do-plan-acts,.do-daysbar,.do-summary,.do-add-activity,.do-copy-day,.do-slot-zone .ph,.do-item .rm,.do-item .move{display:none!important}
  .do-plan-scroll{overflow:visible}
  .do-day{display:block}
}
