/* ============================================================
   Awestruck — Location & Mood Filter
   awestruck-filter.css   (scoped under .aw-filter, no globals)

   Theme:  <div class="aw-filter" data-theme="light|dark">
   Fonts:  Inter (UI) — load it on the host page (see README).
   ============================================================ */
.aw-filter{
  --amber:#E89A12; --gold:#F2B61C; --indigo:#2B40E0; --indigo-2:#4258F2;
  --yellow:#FFE600; --pink:#FF2E92; --green:#2FE06B;
  --ink:#15151D; --muted:#6C7080; --line:#E7E7F1; --soft:#F3F3FB;
  --card:#FFFFFF; --bubble-soft:#EEEFFC;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
  position:relative;
}
.aw-filter[data-theme="dark"]{
  --ink:#F2F2F8; --muted:#9A9DB5; --line:rgba(255,255,255,.1); --soft:rgba(255,255,255,.06);
  --card:#1E1E29; --bubble-soft:rgba(66,88,242,.18);
}
.aw-filter *{box-sizing:border-box;margin:0;padding:0}

/* ---- shining section label ---- */
.aw-filter .barlbl{display:flex;align-items:center;gap:8px;font-size:10.5px;font-weight:800;letter-spacing:.14em;
  text-transform:uppercase;margin:0 2px 12px}
.aw-filter .barlbl .s{color:var(--pink);display:inline-block;animation:aw-twinkle 2.4s ease-in-out infinite}
@keyframes aw-twinkle{0%,100%{transform:scale(1) rotate(0);opacity:.8}50%{transform:scale(1.35) rotate(90deg);opacity:1}}
.aw-filter .barlbl .t{background:linear-gradient(100deg,var(--muted) 0%,var(--muted) 38%,var(--indigo) 50%,var(--pink) 56%,var(--muted) 66%,var(--muted) 100%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  animation:aw-shine 3.4s cubic-bezier(.6,0,.4,1) infinite}
@keyframes aw-shine{0%{background-position:160% 0}55%,100%{background-position:-160% 0}}

/* ============================================================
   The two trigger cells
   ============================================================ */
@property --iflt-ang{syntax:'<angle>';inherits:false;initial-value:0deg}
.iflt{position:relative;display:flex;gap:10px;z-index:10;margin-bottom:15px}
.iflt__cell{flex:1;min-width:0;display:flex;align-items:center;gap:10px;background:var(--card);border:1.5px solid var(--line);
  border-radius:15px;padding:7px 11px;cursor:pointer;position:relative;overflow:hidden;
  transition:border-color .22s,box-shadow .22s,transform .14s;-webkit-tap-highlight-color:transparent;
  animation:iflt-in .5s cubic-bezier(.2,.8,.25,1) both}
.iflt__cell:nth-child(1){animation-delay:.05s}.iflt__cell:nth-child(2){animation-delay:.13s}
@keyframes iflt-in{from{transform:translateY(10px)}to{transform:translateY(0)}}
.iflt__cell:active{transform:scale(.975)}
.iflt__cell.act{border-color:transparent;box-shadow:0 0 0 3px rgba(43,64,224,.10),0 10px 22px -14px rgba(43,64,224,.55)}
.iflt__cell.act::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.7px;pointer-events:none;z-index:3;
  background:conic-gradient(from var(--iflt-ang),var(--indigo),var(--pink),var(--yellow),var(--indigo-2),var(--indigo));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;animation:iflt-rot 2.6s linear infinite}
@keyframes iflt-rot{to{--iflt-ang:360deg}}
.iflt__bub{width:34px;height:34px;border-radius:11px;flex:none;display:grid;place-items:center;position:relative;
  background:var(--bubble-soft);color:var(--indigo);transition:background .26s,color .26s;box-shadow:inset 0 1px 0 rgba(255,255,255,.4)}
.iflt__bub svg{width:18px;height:18px;transition:transform .3s cubic-bezier(.3,1.4,.4,1)}
.iflt__cell.act .iflt__bub{background:linear-gradient(145deg,var(--indigo-2),var(--indigo));color:#fff;
  box-shadow:0 6px 14px -5px rgba(43,64,224,.8),inset 0 1px 0 rgba(255,255,255,.3)}
.iflt__cell.act .iflt__bub svg{transform:scale(1.12) rotate(-4deg)}
.iflt__cell.act .iflt__bub::after{content:"";position:absolute;inset:-4px;border-radius:14px;border:2px solid var(--indigo);
  opacity:0;animation:iflt-glow 2.2s ease-in-out infinite}
@keyframes iflt-glow{0%,100%{opacity:0;transform:scale(.9)}50%{opacity:.35;transform:scale(1.08)}}
.iflt__tx{min-width:0;flex:1;max-width:100%}
.iflt__tx .k{font-size:9px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:var(--muted);display:block;line-height:1.2;transition:color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.iflt__cell.act .iflt__tx .k{color:var(--indigo)}
.aw-filter[data-theme="dark"] .iflt__cell.act .iflt__tx .k{color:var(--indigo-2)}
.iflt__tx .v{position:relative;font-size:14.5px;font-weight:800;color:var(--ink);letter-spacing:-.01em;display:inline-flex;align-items:center;gap:6px;line-height:1.25;
  max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.iflt__tx .v::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--indigo),var(--pink));transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.3,.9,.3,1)}
.iflt__cell.act .iflt__tx .v::after{transform:scaleX(1)}
.iflt__cr{color:var(--muted);flex:none;transition:transform .26s cubic-bezier(.3,.9,.3,1)}
.iflt__cr svg{width:14px;height:14px;display:block}
.iflt__cell.act .iflt__cr{transform:rotate(180deg);color:var(--indigo)}

/* ============================================================
   Dropdown = pill cloud
   ============================================================ */
.iflt__dd{position:absolute;z-index:60;top:54px;background:var(--card);border:1px solid var(--line);border-radius:16px;
  box-shadow:0 26px 50px -20px rgba(20,20,50,.5);padding:11px 11px 12px;width:230px;
  opacity:0;transform:translateY(-8px) scale(.97);transform-origin:top;pointer-events:none;transition:.18s cubic-bezier(.2,.9,.3,1)}
.iflt__dd.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.iflt__dd[data-dd="mood"]{right:0}.iflt__dd[data-dd="location"]{left:0}
.iflt__hd{font-size:9.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 2px 9px;
  display:flex;align-items:center;justify-content:space-between}
.iflt__hd .clr{color:var(--indigo);font-weight:800;letter-spacing:0;text-transform:none;font-size:11px;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s}
.iflt__hd .clr.show{opacity:1;pointer-events:auto}
.cloud{display:flex;flex-wrap:wrap;gap:7px}
.pill{position:relative;height:33px;display:inline-flex;align-items:center;gap:7px;border-radius:999px;border:1.5px solid var(--line);
  background:var(--card);font-size:12.5px;font-weight:700;color:var(--ink);padding:0 13px;cursor:pointer;
  transition:border-color .15s,background .18s,color .18s,transform .14s;
  opacity:0;transform:translateY(6px) scale(.96)}
.iflt__dd.open .pill{animation:pill-in .32s cubic-bezier(.2,.9,.3,1) forwards}
.iflt__dd.open .pill:nth-child(1){animation-delay:.02s}
.iflt__dd.open .pill:nth-child(2){animation-delay:.05s}
.iflt__dd.open .pill:nth-child(3){animation-delay:.08s}
.iflt__dd.open .pill:nth-child(4){animation-delay:.11s}
.iflt__dd.open .pill:nth-child(5){animation-delay:.14s}
.iflt__dd.open .pill:nth-child(6){animation-delay:.17s}
.iflt__dd.open .pill:nth-child(7){animation-delay:.20s}
@keyframes pill-in{to{opacity:1;transform:translateY(0) scale(1)}}
.pill:hover{border-color:#C4C8EC}
.pill:active{transform:scale(.94)}
/* mood emoji — force full-colour emoji presentation, 3D lift */
.pill .em{font-size:16px;line-height:1;font-family:'Apple Color Emoji','Segoe UI Emoji','Noto Color Emoji',sans-serif;
  filter:drop-shadow(0 2px 2px rgba(0,0,0,.22));transition:transform .26s cubic-bezier(.3,1.4,.4,1)}
.pill.mood:hover .em{transform:scale(1.14) rotate(-6deg)}
/* location count badge — neutral, calm */
.pill .ct{font-size:10.5px;font-weight:800;color:var(--muted);background:var(--soft);border-radius:999px;padding:1px 7px;transition:.18s}
/* selected — shared gradient treatment (synergy across both filters) */
.pill.sel{border-color:transparent;color:#fff;background:linear-gradient(135deg,var(--indigo-2),var(--indigo));box-shadow:0 9px 20px -8px rgba(43,64,224,.75)}
.pill.sel .ct{background:rgba(255,255,255,.24);color:#fff!important}
.pill.mood.sel{background:linear-gradient(135deg,var(--pink),var(--indigo));box-shadow:0 9px 20px -8px rgba(255,46,146,.6)}
.pill.mood.sel .em{filter:drop-shadow(0 2px 3px rgba(0,0,0,.3))}
.pill.pop{animation:pill-pop .42s cubic-bezier(.3,1.4,.4,1)}
@keyframes pill-pop{0%{transform:scale(.86)}45%{transform:scale(1.12)}70%{transform:scale(.97)}100%{transform:scale(1)}}
.pill.sel::after{content:"";position:absolute;inset:-3px;border-radius:999px;border:2px solid var(--indigo);opacity:0;animation:pill-ring .9s ease-out}
.pill.mood.sel::after{border-color:var(--pink)}
@keyframes pill-ring{0%{opacity:.55;transform:scale(.92)}100%{opacity:0;transform:scale(1.18)}}
/* location panel — wider + scrollable (gradient-yellow scrollbar) */
.iflt__dd[data-dd="location"]{width:256px}
.cloud--scroll{max-height:196px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--gold) transparent;margin:0 -3px -2px;padding:2px 3px}
.cloud--scroll::-webkit-scrollbar{width:6px}
.cloud--scroll::-webkit-scrollbar-track{background:transparent}
.cloud--scroll::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--yellow),var(--gold));border-radius:99px}
/* coming-soon footer note */
.cloud .soon{flex:0 0 100%;display:flex;align-items:center;justify-content:center;gap:6px;margin-top:5px;padding:7px 10px;
  font-size:11px;font-weight:700;color:var(--muted);background:var(--soft);border:1.5px dashed var(--line);border-radius:12px;letter-spacing:.01em}
.cloud .soon .sp{animation:aw-twinkle 2.4s ease-in-out infinite;color:var(--gold)}

@media(prefers-reduced-motion:reduce){
  .aw-filter *{animation:none!important}
  .pill{opacity:1!important;transform:none!important}
}
.aw-active-filters{display:flex;flex-wrap:wrap;gap:8px;margin:10px 2px 18px}
.aw-active-filters:empty{display:none;margin:0}
.aw-af-chip{display:inline-flex;align-items:center;gap:6px;background:#EEEFFC;color:#2B40E0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;font-size:12.5px;font-weight:700;
  padding:6px 8px 6px 12px;border-radius:999px;border:1.5px solid rgba(43,64,224,.16)}
.aw-af-chip button{all:unset;cursor:pointer;width:16px;height:16px;display:grid;place-items:center;
  border-radius:50%;background:rgba(43,64,224,.12);color:#2B40E0;font-size:12px;line-height:1}
.aw-af-chip button:hover{background:rgba(43,64,224,.22)}
[data-bs-theme="dark"] .aw-af-chip{background:rgba(66,88,242,.18);color:#AAB0FF;border-color:rgba(255,255,255,.12)}
[data-bs-theme="dark"] .aw-af-chip button{background:rgba(255,255,255,.12);color:#AAB0FF}
[data-bs-theme="dark"] .aw-af-chip button:hover{background:rgba(255,255,255,.2)}
.aw-active-filters:not(:empty) + #experience-skeleton,
.aw-active-filters:not(:empty) + #experiences {
  margin-top: 8px !important;
}

/* ============================================================
   Responsive — Location & Mood trigger cells + dropdowns
   This widget only ever renders on mobile/tablet (d-lg-none,
   i.e. < 992px), so we scale it down through every phone/tablet
   width instead of assuming one fixed size. Font-size on the
   value text (.iflt__tx .v) is the main lever that keeps the
   location/mood name on a single line — it steps down at each
   breakpoint, plus a nowrap/ellipsis safety net (set above)
   catches any name still too long for the space available.
   ============================================================ */

/* Tablets / small laptops just under the 992px cutoff */
@media (max-width:991px){
  .iflt{gap:9px;margin-bottom:14px}
  .iflt__cell{padding:7px 10px;gap:9px;border-radius:14px}
  .iflt__bub{width:32px;height:32px;border-radius:10px}
  .iflt__bub svg{width:17px;height:17px}
  .iflt__tx .k{font-size:8.5px}
  .iflt__tx .v{font-size:13.5px;gap:5px}
  .iflt__cr svg{width:13px;height:13px}
  .iflt__dd{width:220px;max-width:calc(100vw - 28px)}
  .iflt__dd[data-dd="location"]{width:246px;max-width:calc(100vw - 28px)}
}

/* Standard phones (most Android + iPhone 12–16 class devices) */
@media (max-width:575px){
  .iflt{gap:8px;margin-bottom:12px}
  .iflt__cell{padding:6px 9px;gap:8px;border-radius:13px}
  .iflt__bub{width:30px;height:30px;border-radius:10px}
  .iflt__bub svg{width:16px;height:16px}
  .iflt__tx .k{font-size:8px;letter-spacing:.07em}
  .iflt__tx .v{font-size:12.5px;gap:4px}
  .iflt__cr svg{width:12px;height:12px}
  .iflt__dd{top:50px;width:200px;padding:10px 10px 11px;max-width:calc(100vw - 24px)}
  .iflt__dd[data-dd="location"]{width:224px;max-width:calc(100vw - 24px)}
  .iflt__hd{font-size:9px}
  .pill{height:31px;font-size:12px;padding:0 12px;gap:6px}
  .pill .em{font-size:15px}
  .pill .ct{font-size:10px;padding:1px 6px}
  .aw-af-chip{font-size:12px;padding:5px 7px 5px 11px}
}

/* Compact phones (iPhone SE/mini, small Android, ~390–430px) */
@media (max-width:430px){
  .iflt__cell{padding:6px 8px;gap:7px}
  .iflt__bub{width:28px;height:28px;border-radius:9px}
  .iflt__bub svg{width:15px;height:15px}
  .iflt__tx .k{font-size:7.5px}
  .iflt__tx .v{font-size:11.5px;gap:4px;letter-spacing:0}
  .iflt__dd{width:190px}
  .iflt__dd[data-dd="location"]{width:210px}
}

/* Small/narrow phones (~360–390px, e.g. Galaxy S, Pixel compact) */
@media (max-width:390px){
  .iflt{gap:7px}
  .iflt__cell{padding:5px 8px;gap:7px;border-radius:12px}
  .iflt__bub{width:27px;height:27px;border-radius:9px}
  .iflt__bub svg{width:14px;height:14px}
  .iflt__tx .k{font-size:7.2px}
  .iflt__tx .v{font-size:11px;gap:3px}
  .iflt__cr svg{width:11px;height:11px}
  .iflt__dd{width:182px;padding:9px 9px 10px}
  .iflt__dd[data-dd="location"]{width:200px}
  .pill{height:29px;font-size:11.5px;padding:0 11px}
}

/* Extra-small phones (~320–359px, iPhone SE 1st gen, Galaxy Fold cover) */
@media (max-width:359px){
  .iflt{gap:6px}
  .iflt__cell{padding:5px 7px;gap:6px;border-radius:11px}
  .iflt__bub{width:25px;height:25px;border-radius:8px}
  .iflt__bub svg{width:13px;height:13px}
  .iflt__tx .k{font-size:6.8px;letter-spacing:.05em}
  .iflt__tx .v{font-size:10px;gap:3px}
  .iflt__cr svg{width:10px;height:10px}
  .iflt__dd{width:168px;padding:8px 8px 9px}
  .iflt__dd[data-dd="location"]{width:186px}
  .pill{height:27px;font-size:11px;padding:0 10px;gap:5px}
  .pill .em{font-size:14px}
  .pill .ct{font-size:9.5px;padding:1px 5px}
}

/* Sticky filter bar */
#aw-pill-filter.aw-sticky{
  position:-webkit-sticky;
  position:sticky;
  top:0px;
  z-index:500;
  background:var(--bs-body-bg,#fff);
  padding:10px 0 8px;
  transition:box-shadow .25s ease;
}
[data-bs-theme="dark"] #aw-pill-filter.aw-sticky{
  background:var(--bs-body-bg,#0d0d12);
}
#aw-pill-filter.aw-sticky.is-stuck{
  box-shadow:0 10px 22px -18px rgba(20,20,50,.45);
}