/* ===================================================================
   BBTM Park Day Planner — front-end (mobile-first, app mode)
   Scoped to #bbtm-pd-app and #bpd-* fixed elements.
   =================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@500;600;700&family=Nunito:wght@400;600;700;800;900&display=swap');

/* page background (only loads on the planner page) */
body.fcp-focused-body,
body.bpd-page{
  background:
    radial-gradient(800px 460px at 50% -12%, rgba(83,63,176,.4), transparent 62%),
    linear-gradient(180deg,#241a63,#180f44 55%,#120b34) !important;
  background-attachment:fixed !important;
}

#bbtm-pd-app{
  --ink:#efeaff; --muted:#a99fe0; --gold:#F0B429; --gold-lite:#ffd54a; --gold-soft:#ffe7a0;
  --accent:#534AB7; --plate1:#5b4fc4; --plate2:#3a2f93; --bg2:#180f44;
  --glass:rgba(255,255,255,.06); --line:rgba(255,255,255,.14);
  --disp:"Oswald","Arial Narrow",sans-serif; --body:"Nunito",system-ui,sans-serif;
  --bar:84px;
  font-family:var(--body); color:var(--ink); display:block;
  max-width:560px; margin:0 auto;
  padding:14px 14px calc(var(--bar) + env(safe-area-inset-bottom,0px) + 8px);
  -webkit-tap-highlight-color:transparent;
}
#bbtm-pd-app[data-loading]{text-align:center;color:#a99fe0;padding:60px 0;font-family:var(--body)}

/* ---- THEME-ROUNDING GUARD: neutralise the host theme's border-radius:50%
        on everything we own, then re-apply our own radii below. ---- */
#bbtm-pd-app *, #bpd-bar *, #bpd-sheet *, #bpd-bar, #bpd-sheet, #bpd-toast{ border-radius:0 !important; }

#bbtm-pd-app *{box-sizing:border-box}

/* header */
#bbtm-pd-app .bpd-back{display:inline-flex;align-items:center;gap:6px;margin:0 0 12px;
  font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;
  padding:9px 16px;border-radius:999px !important;border:1px solid var(--line);
  background:var(--glass);color:var(--gold-lite);text-decoration:none}
#bbtm-pd-app .bpd-back:hover{border-color:var(--gold);color:var(--gold-soft)}
#bbtm-pd-app .bpd-back:active{transform:scale(.97)}
#bbtm-pd-app .bpd-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
#bbtm-pd-app .bpd-brand h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;letter-spacing:.02em;font-size:1.45rem;margin:0;line-height:1;color:var(--ink)}
#bbtm-pd-app .bpd-brand .bpd-tag{font-family:var(--disp);font-weight:600;letter-spacing:.18em;font-size:.55rem;color:var(--gold-lite);text-transform:uppercase;margin-top:5px}
#bbtm-pd-app .bpd-hbtns{display:flex;gap:8px}
#bbtm-pd-app .bpd-icon{width:42px;height:42px;border-radius:12px !important;border:1px solid var(--line);background:var(--glass);color:var(--ink);
  font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;text-decoration:none}

/* horizontal scrollers */
#bbtm-pd-app .bpd-hscroll{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 8px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
#bbtm-pd-app .bpd-hscroll::-webkit-scrollbar{display:none}
#bbtm-pd-app .bpd-park{flex:0 0 auto;font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:.76rem;
  padding:10px 14px;border-radius:999px !important;border:1px solid var(--line);background:var(--glass);color:var(--ink);cursor:pointer;
  display:flex;align-items:center;gap:7px;white-space:nowrap}
#bbtm-pd-app .bpd-park.on{background:linear-gradient(180deg,var(--plate1),var(--plate2));border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset}
#bbtm-pd-app .bpd-park .e{font-size:1rem}
#bbtm-pd-app .bpd-daytab{flex:0 0 auto;font-weight:800;font-size:.78rem;padding:8px 13px;border-radius:11px !important;border:1px solid var(--line);
  background:var(--glass);color:var(--muted);cursor:pointer;white-space:nowrap}
#bbtm-pd-app .bpd-daytab.on{color:var(--ink);background:rgba(240,180,41,.16);border-color:rgba(240,180,41,.5)}
#bbtm-pd-app .bpd-addday{flex:0 0 auto;font-weight:900;color:var(--gold-lite);background:transparent;border:1px dashed rgba(240,180,41,.5);
  padding:8px 12px;border-radius:11px !important;cursor:pointer;font-size:.78rem;white-space:nowrap}
#bbtm-pd-app .bpd-rmday{flex:0 0 auto;font-weight:900;color:#e2627a;background:transparent;border:1px dashed rgba(226,98,122,.55);
  padding:8px 12px;border-radius:11px !important;cursor:pointer;font-size:.78rem;white-space:nowrap}

#bbtm-pd-app .bpd-rule{height:2px;border-radius:2px !important;opacity:.65;margin:8px 2px 14px;
  background:linear-gradient(90deg,transparent,var(--gold) 20%,var(--gold-lite) 50%,var(--gold) 80%,transparent)}

#bbtm-pd-app .bpd-dayhead{display:flex;align-items:baseline;justify-content:space-between;margin:0 2px 4px}
#bbtm-pd-app .bpd-dayhead .t{font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:1rem}
#bbtm-pd-app .bpd-dayhead .c{font-weight:900;font-size:.72rem;color:#2a2150;background:linear-gradient(180deg,var(--gold-soft),var(--gold));border-radius:999px !important;padding:2px 9px}
#bbtm-pd-app .bpd-hint{color:var(--muted);font-size:.74rem;font-weight:700;margin:0 2px 12px}
#bbtm-pd-app .bpd-hint b{color:var(--gold-lite)}

/* day list */
#bbtm-pd-app .bpd-day{list-style:none;margin:0;padding:0;position:relative}
#bbtm-pd-app .bpd-day.empty{text-align:center;color:var(--muted);font-weight:700;padding:48px 24px;line-height:1.5;
  border:1px dashed var(--line);border-radius:18px !important;background:var(--glass)}
#bbtm-pd-app .bpd-day.empty b{color:var(--gold-lite)}
#bbtm-pd-app .bpd-day:not(.empty)::before{content:"";position:absolute;left:13px;top:14px;bottom:14px;width:2px;border-radius:2px;
  background:linear-gradient(180deg,transparent,rgba(240,180,41,.55) 8%,rgba(240,180,41,.55) 92%,transparent)}
#bbtm-pd-app .bpd-parkhead{list-style:none;display:flex;align-items:center;gap:9px;position:relative;z-index:1;
  margin:16px 0 11px;padding:9px 14px;border-radius:12px !important;
  font-family:var(--disp);font-weight:600;text-transform:uppercase;letter-spacing:.07em;font-size:.74rem;color:var(--ink);
  background:linear-gradient(180deg,var(--plate1),var(--plate2));border:1px solid var(--gold);box-shadow:0 0 0 1px var(--gold) inset}
#bbtm-pd-app .bpd-parkhead:first-child{margin-top:2px}
#bbtm-pd-app .bpd-parkhead .e{font-size:1.05rem}
#bbtm-pd-app .bpd-parkhead .nm{color:var(--gold-lite);font-weight:800;letter-spacing:.05em}
#bbtm-pd-app .bpd-slot{position:relative;display:flex;gap:10px;margin:0 0 11px;padding-left:30px}
#bbtm-pd-app .bpd-dot{position:absolute;left:5px;top:16px;width:18px;height:18px;border-radius:50% !important;
  background:radial-gradient(circle at 35% 30%,var(--gold-soft),var(--gold));box-shadow:0 0 0 4px var(--bg2),0 0 10px -2px var(--gold)}
#bbtm-pd-app .bpd-it{flex:1;background:linear-gradient(150deg,rgba(91,79,196,.34),rgba(58,47,147,.34));border:1px solid var(--line);
  border-radius:15px !important;padding:11px;min-width:0}
#bbtm-pd-app .bpd-row1{display:flex;align-items:center;gap:9px}
#bbtm-pd-app .bpd-it .e{font-size:1.3rem;flex:0 0 auto}
#bbtm-pd-app .bpd-it .nm{font-weight:800;font-size:.95rem;line-height:1.18;flex:1;min-width:0}
#bbtm-pd-app .bpd-it .time{flex:0 0 auto;font-family:var(--disp);font-weight:600;font-size:.74rem;color:#2a2150;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));border-radius:8px !important;padding:5px 9px;cursor:text;outline:none;min-width:50px;text-align:center}
#bbtm-pd-app .bpd-it .time:empty::before{content:"\FF0B time";font-size:.68rem}
#bbtm-pd-app .bpd-it .note{font-size:.77rem;color:var(--muted);font-weight:700;margin-top:7px;cursor:text;outline:none;padding:2px 0}
#bbtm-pd-app .bpd-it .note:empty::before{content:"\FF0B add note — Lightning Lane, ADR, must-do…";color:rgba(169,159,224,.55)}
#bbtm-pd-app .bpd-ctrls{display:flex;gap:6px;margin-top:9px;justify-content:flex-end}
#bbtm-pd-app .bpd-ctrls button{height:34px;min-width:42px;border-radius:9px !important;border:1px solid var(--line);background:rgba(255,255,255,.06);
  color:var(--ink);font-size:1rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center}
#bbtm-pd-app .bpd-ctrls .grip{cursor:grab;color:var(--muted);flex:1;letter-spacing:3px}
#bbtm-pd-app .bpd-ctrls .del{color:#ffd2dc;background:rgba(255,93,143,.16);border-color:transparent}
#bbtm-pd-app .bpd-ctrls button:disabled{opacity:.3}
#bbtm-pd-app .sortable-ghost{opacity:.4}
#bbtm-pd-app .sortable-chosen .bpd-it{box-shadow:0 0 0 2px var(--gold),0 12px 26px -10px #000}

#bbtm-pd-app .bpd-note{font-size:.66rem;color:var(--muted);text-align:center;margin:18px auto 4px;max-width:520px;line-height:1.5;opacity:.85}
#bbtm-pd-app .bpd-note b{color:var(--gold-lite)}

/* ---- bottom action bar (appended to body) ---- */
#bpd-bar{position:fixed;left:0;right:0;bottom:0;z-index:30;
  padding:12px 14px calc(12px + env(safe-area-inset-bottom,0px));
  background:linear-gradient(180deg,rgba(18,11,52,0),rgba(18,11,52,.94) 36%);
  display:flex;gap:10px;max-width:560px;margin:0 auto;
  font-family:"Nunito",system-ui,sans-serif}
#bpd-bar .add{flex:1;font-weight:900;font-size:1rem;border:0;cursor:pointer;border-radius:14px !important;padding:15px;
  color:#2a2150;background:linear-gradient(180deg,#ffe7a0,#F0B429);box-shadow:0 10px 24px -8px #F0B429}
#bpd-bar .save{font-weight:900;font-size:.9rem;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);color:#efeaff;
  border-radius:14px !important;padding:15px 16px;cursor:pointer}

/* ---- bottom sheet (appended to body) ---- */
#bpd-scrim{position:fixed;inset:0;z-index:40;background:rgba(8,5,24,.6);opacity:0;pointer-events:none;transition:.2s}
#bpd-scrim.on{opacity:1;pointer-events:auto}
#bpd-sheet{position:fixed;left:0;right:0;bottom:0;z-index:41;max-width:560px;margin:0 auto;
  background:linear-gradient(180deg,#221752,#180f44);border:1px solid rgba(255,255,255,.14);border-bottom:0;
  border-radius:22px 22px 0 0 !important;transform:translateY(102%);transition:transform .26s cubic-bezier(.2,.8,.2,1);
  max-height:86vh;display:flex;flex-direction:column;box-shadow:0 -20px 50px -20px #000;
  font-family:"Nunito",system-ui,sans-serif;color:#efeaff}
#bpd-sheet.on{transform:translateY(0)}
#bpd-sheet .grab{width:42px;height:5px;border-radius:3px !important;background:rgba(255,255,255,.25);margin:10px auto 6px}
#bpd-sheet h3{font-family:"Oswald","Arial Narrow",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:1rem;
  margin:2px 16px 8px;display:flex;justify-content:space-between;align-items:center;color:#efeaff}
#bpd-sheet h3 .done{font-family:"Nunito",sans-serif;font-weight:900;font-size:.8rem;color:#2a2150;background:linear-gradient(180deg,#ffe7a0,#F0B429);
  border:0;border-radius:10px !important;padding:8px 14px;cursor:pointer}
#bpd-sheet .bpd-pickpark{margin:0 16px 6px;font-family:"Nunito",system-ui,sans-serif;font-weight:800;font-size:.74rem;color:#a99fe0}
#bpd-sheet #bpd-parks{display:flex;gap:8px;overflow-x:auto;padding:2px 16px 8px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
#bpd-sheet #bpd-parks::-webkit-scrollbar{display:none}
#bpd-sheet .bpd-park{flex:0 0 auto;display:flex;align-items:center;gap:6px;white-space:nowrap;cursor:pointer;
  font-family:"Oswald","Arial Narrow",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:.76rem;
  padding:9px 13px;border-radius:999px !important;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:#efeaff}
#bpd-sheet .bpd-park.on{background:linear-gradient(180deg,#5b4fc4,#3a2f93);border-color:#F0B429;box-shadow:0 0 0 1px #F0B429 inset}
#bpd-sheet .bpd-park .e{font-size:1rem}
#bpd-sheet .bpd-search{margin:0 16px 6px}
#bpd-sheet .bpd-search input{width:100%;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.14);border-radius:12px !important;color:#efeaff;
  font-family:inherit;font-size:1rem;padding:12px 14px;outline:none}
#bpd-sheet .bpd-search input::placeholder{color:#a99fe0}
#bpd-sheet .bpd-cats{display:flex;gap:7px;overflow-x:auto;padding:6px 16px 8px;scrollbar-width:none}
#bpd-sheet .bpd-cats::-webkit-scrollbar{display:none}
#bpd-sheet .bpd-cat{flex:0 0 auto;font-size:.75rem;font-weight:800;padding:8px 13px;border-radius:999px !important;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);color:#a99fe0;cursor:pointer;white-space:nowrap}
#bpd-sheet .bpd-cat.on{color:#efeaff;background:rgba(83,74,183,.55);border-color:#534AB7}
/* Keep every header row at its natural height; only the list scrolls.
   Without this, iOS shrinks these rows to fit max-height and the
   horizontal category strip clips its pills at the top. */
#bpd-sheet > .grab,
#bpd-sheet > h3,
#bpd-sheet > .bpd-pickpark,
#bpd-sheet > #bpd-parks,
#bpd-sheet > .bpd-search,
#bpd-sheet > .bpd-cats,
#bpd-sheet > .bpd-addown{flex:0 0 auto}
#bpd-sheet > .bpd-lib{flex:1 1 auto;min-height:0}
#bpd-sheet .bpd-lib{list-style:none;margin:0;padding:4px 12px 16px;overflow:auto;-webkit-overflow-scrolling:touch}
#bpd-sheet .bpd-lib li{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);
  border-radius:14px !important;padding:13px;margin-bottom:9px;cursor:pointer;transition:.12s}
#bpd-sheet .bpd-lib li:active{transform:scale(.985);background:rgba(240,180,41,.12)}
#bpd-sheet .bpd-lib li.added{border-color:rgba(240,180,41,.6);background:rgba(240,180,41,.14)}
#bpd-sheet .bpd-lib .e{font-size:1.4rem;width:28px;text-align:center;flex:0 0 auto}
#bpd-sheet .bpd-lib .nm{font-weight:800;font-size:.95rem;line-height:1.15;flex:1}
#bpd-sheet .bpd-lib .ct{font-size:.63rem;color:#a99fe0;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
#bpd-sheet .bpd-lib .plus{flex:0 0 auto;width:34px;height:34px;border-radius:10px !important;border:0;color:#2a2150;font-weight:900;font-size:1.2rem;
  background:linear-gradient(180deg,#ffe7a0,#F0B429);display:flex;align-items:center;justify-content:center}
#bpd-sheet .bpd-addown{display:flex;gap:8px;padding:0 16px 16px}
#bpd-sheet .bpd-addown input{flex:1;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.14);border-radius:12px !important;color:#efeaff;
  font-family:inherit;font-size:.95rem;padding:11px 13px;outline:none}
#bpd-sheet .bpd-addown input::placeholder{color:#a99fe0}
#bpd-sheet .bpd-addown button{border:0;border-radius:12px !important;padding:0 16px;font-weight:900;cursor:pointer;color:#2a2150;
  background:linear-gradient(180deg,#ffe7a0,#F0B429)}

/* ---- toast ---- */
#bpd-toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%) translateY(14px);opacity:0;z-index:60;
  background:#1b1448;border:1px solid #F0B429;color:#efeaff;font-weight:800;font-size:.86rem;padding:10px 16px;border-radius:12px !important;
  transition:.22s;box-shadow:0 12px 30px -10px #000;pointer-events:none;font-family:"Nunito",sans-serif}
#bpd-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* gate */
.bpd-gate{max-width:520px;margin:40px auto;padding:24px;text-align:center;border-radius:18px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);color:#efeaff;font-family:"Nunito",sans-serif;font-weight:700}
