/* FiLLi Select — scoped page system. Namespaced under .filli-select so it
   never touches the global site tokens. Palette + type per
   docs/.../FiLLi-Select_Design-Direction.md. Copper #C68442, Playfair Display + ARS Maquette. */

.filli-select{
  --fs-copper:#C68442; --fs-copper-deep:#9A6230; --fs-ink:#2E1B12; --fs-brown:#663333;
  --fs-cream:#FAF6EF; --fs-sand:#F3EBDD; --fs-line:#E5D8C3; --fs-saffron:#441A38; --fs-muted:#7A6450;
  --fs-serif:'Playfair Display',Georgia,serif;
  --fs-sans:'ARSMaquettePro','ARS Maquette Pro',-apple-system,'Segoe UI',sans-serif;
  background:var(--fs-cream); color:var(--fs-ink); font-family:var(--fs-sans);
  -webkit-font-smoothing:antialiased;
}
.filli-select .fs-wrap{max-width:1040px;margin:0 auto;padding:0 24px}
.filli-select .fs-serif{font-family:var(--fs-serif)}

/* hero banner styles live in the dedicated-chrome block at the bottom (.fs-herobanner) */

/* section */
.filli-select .fs-section{padding:clamp(44px,6vw,64px) 0}
.filli-select .fs-eyebrow{font-size:11px;letter-spacing:.26em;color:var(--fs-copper);font-weight:700;
  text-transform:uppercase;text-align:center;margin:0 0 6px}
.filli-select .fs-sectitle{font-family:var(--fs-serif);font-weight:500;font-size:clamp(24px,3.2vw,30px);
  text-align:center;margin:0 0 34px;color:var(--fs-ink)}
.filli-select .fs-sectitle em{font-style:italic;color:var(--fs-copper)}

/* signature grid */
.filli-select .fs-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.filli-select .fs-card{background:var(--fs-cream);border:1px solid var(--fs-line);border-radius:6px;overflow:hidden}
.filli-select .fs-card img{width:100%;height:auto;display:block;aspect-ratio:4/3;object-fit:cover}
.filli-select .fs-card .fs-body{padding:18px}
.filli-select .fs-card .fs-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.filli-select .fs-card .fs-nm{font-family:var(--fs-serif);font-size:21px}
.filli-select .fs-card .fs-price{font-size:15px;color:var(--fs-copper-deep)}
.filli-select .fs-card .fs-desc{font-size:13px;font-weight:300;font-style:italic;color:var(--fs-muted);margin:5px 0 0;line-height:1.55}
.filli-select .fs-zafran{width:6px;height:6px;border-radius:50%;background:var(--fs-saffron);display:inline-block;margin-left:7px;vertical-align:middle}

/* offer + footer */
.filli-select .fs-offer{background:var(--fs-sand);border-radius:6px;padding:clamp(24px,4vw,32px);text-align:center;margin-bottom:8px}
.filli-select .fs-offer h2{font-family:var(--fs-serif);font-weight:500;font-size:clamp(20px,2.8vw,25px);margin:6px 0 4px;color:var(--fs-ink)}
.filli-select .fs-offer p{font-size:13px;font-weight:300;color:var(--fs-muted);margin:0}
.filli-select .fs-foot{background:var(--fs-brown);color:var(--fs-cream);padding:clamp(28px,4vw,36px) 24px;text-align:center}
.filli-select .fs-foot h3{font-family:var(--fs-serif);font-weight:500;font-size:clamp(20px,2.6vw,23px);margin:0 0 5px;color:var(--fs-cream)}
.filli-select .fs-foot p{font-size:12px;letter-spacing:.05em;color:#D9C3B5;font-weight:300;margin:0}

@media (max-width:680px){
  .filli-select .fs-grid{grid-template-columns:1fr}
}

/* ---- FiLLi Select complete-menu page. Reuses the .fm-* card component
   (menu-cards.css) but re-skins it copper + Playfair, scoped so the national
   /menu is untouched. Order button hidden (intent-only). ---- */
.filli-select-menu{--fm-orange:#C68442;--fm-brown:#663333;padding:0 16px 56px}
.filli-select-menu .fsm-head{text-align:center;padding:34px 0 6px}
.filli-select-menu .fsm-kicker{font-family:var(--fs-serif);font-style:italic;color:#C68442;font-size:15px;margin:0}
.filli-select-menu h1.fs-serif{font-size:34px;color:#2E1B12;margin:2px 0 4px}
.filli-select-menu .fsm-sub{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#66333399}
.filli-select-menu .fsm-jump{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:14px 0 6px}
.filli-select-menu .fsm-jump a{font-size:12px;color:#663333;border:.5px solid #C6844259;border-radius:20px;padding:5px 14px;text-decoration:none}
.filli-select-menu .fsm-jump a:hover{background:#F3EBDD}
.filli-select-menu .fsm-sec{max-width:980px;margin:0 auto;padding-top:26px}
.filli-select-menu .fsm-sec>h2.fs-serif{font-size:14px;letter-spacing:.3em;text-transform:uppercase;color:#663333;text-align:center;border-bottom:1px solid #C6844233;padding-bottom:8px;margin-bottom:6px}
.filli-select-menu .fsm-cat{color:#C68442;font-size:18px;margin:18px 0 8px}
.filli-select-menu .fm-card.expanded{border-color:#C68442;box-shadow:0 4px 20px rgba(198,132,66,.14)}
.filli-select-menu .fm-card-order{display:none}
.filli-select-menu .fm-badge-star{background:#fbf2e3;color:#C68442}
.filli-select-menu .fsm-empty{text-align:center;color:#66333399;padding:48px 0;font-style:italic}
/* Landing → menu deep-links (below the teaser grid) */
.filli-select .fs-menu-links{text-align:center;margin-top:22px;font-size:13px;letter-spacing:.04em;color:#7A6450}
.filli-select .fs-menu-links a{color:#C68442;text-decoration:none;border-bottom:1px solid #C6844259;padding-bottom:1px}

/* ============================================================================
   FiLLi Select — DEDICATED CHROME (header + footer)
   Used only on the Select pages (partials/select-header + select-footer, opted in
   via @section('site_header')/@section('site_footer') + body.filli-select).
   The bar/footer render OUTSIDE the .filli-select content wrapper, so everything
   here is scoped to body.filli-select and the tokens are re-declared at that level.
   ============================================================================ */
body.filli-select{
  --fs-copper:#C68442; --fs-copper-deep:#9A6230; --fs-ink:#2E1B12; --fs-brown:#663333;
  --fs-cream:#FAF6EF; --fs-sand:#F3EBDD; --fs-line:#E5D8C3; --fs-muted:#7A6450;
  --fs-foot-soft:#D9C3B5; /* muted cream for footer sub-text */
  --fs-serif:'Playfair Display',Georgia,serif;
  --fs-sans:'ARSMaquettePro','ARS Maquette Pro',-apple-system,'Segoe UI',sans-serif;
  --fs-nav-h:82px; /* match the main fillicafe.com nav height exactly */
}
/* Mirror the main nav's height at its breakpoints (68px ≤1199, 57px ≤575) */
@media (max-width:1199.98px){ body.filli-select{--fs-nav-h:68px} }
@media (max-width:575.98px){ body.filli-select{--fs-nav-h:57px} }
/* The Select bar is position:fixed (sticky breaks under the site's overflow-x
   ancestor). Reserve exactly its height on .body-wrapper, overriding the generic
   fixed-navbar offset (92/68/57px) so the hero isn't hidden and there's no gap. */
body.filli-select .body-wrapper{padding-top:var(--fs-nav-h) !important}
/* Floating global order button + its trigger are off-brand on the intent-only
   Select pages (no on-page ordering, decision 2026-06-11) — hide them here only. */
body.filli-select .open-btn{display:none !important}

/* ---- Header ---- */
body.filli-select .fs-nav{position:fixed;top:0;left:0;right:0;z-index:1020;font-family:var(--fs-sans);
  background:rgba(250,246,239,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--fs-line)}
body.filli-select .fs-nav__inner{max-width:1100px;margin:0 auto;min-height:calc(var(--fs-nav-h) - 1px);
  padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
body.filli-select .fs-nav__brand{display:inline-flex;align-items:center;line-height:0}
body.filli-select .fs-nav__brand img{height:38px;width:auto;display:block}
body.filli-select .fs-nav__links{display:flex;align-items:center;gap:26px}
/* Match the MAIN site nav typography (ARSMaquettePro 1rem/700, uppercase, no
   letter-spacing) but keep the Select COPPER colour (main site is black). */
body.filli-select .fs-nav__link{font-family:var(--fs-sans);font-size:1rem;font-weight:700;letter-spacing:0;
  text-transform:uppercase;color:var(--fs-copper-deep);
  text-decoration:none;transition:color .25s ease;white-space:nowrap}
body.filli-select .fs-nav__link:hover,body.filli-select .fs-nav__link:focus-visible{color:var(--fs-copper)}
body.filli-select .fs-nav__lang{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--fs-copper-deep);border:1px solid var(--fs-line);border-radius:4px;padding:6px 12px;
  text-decoration:none;white-space:nowrap;transition:border-color .25s ease,color .25s ease}
body.filli-select .fs-nav__lang:hover,body.filli-select .fs-nav__lang:focus-visible{border-color:var(--fs-copper);color:var(--fs-copper)}
body.filli-select .fs-nav :focus-visible{outline:2px solid var(--fs-copper);outline-offset:3px;border-radius:2px}
body.filli-select .fs-nav__mobile{display:none}

/* ---- Footer ---- */
body.filli-select .fs-sitefoot{background:var(--fs-brown);color:var(--fs-cream);font-family:var(--fs-sans);
  padding:clamp(36px,5vw,56px) 24px clamp(28px,4vw,40px)}
body.filli-select .fs-sitefoot__inner{max-width:1100px;margin:0 auto;display:grid;gap:38px;
  grid-template-columns:1.5fr 1fr 1.2fr;align-items:start}
body.filli-select .fs-sitefoot__brand img{height:50px;width:auto;display:block;margin-bottom:16px;
  filter:brightness(0) invert(1);opacity:.95}
body.filli-select .fs-sitefoot__loc{font-family:var(--fs-serif);font-size:20px;margin:0 0 4px;color:var(--fs-cream)}
body.filli-select .fs-sitefoot__hours{font-size:12.5px;color:var(--fs-foot-soft);margin:0 0 16px;line-height:1.6}
body.filli-select .fs-sitefoot__social{list-style:none;display:flex;gap:14px;padding:0;margin:0}
body.filli-select .fs-sitefoot__social a{color:var(--fs-cream);font-size:19px;line-height:1;opacity:.85;transition:opacity .25s ease,color .25s ease}
body.filli-select .fs-sitefoot__social a:hover{opacity:1;color:#E8C9A0}
body.filli-select .fs-sitefoot__h{font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:#E3C4A0;font-weight:500;margin:0 0 14px}
body.filli-select .fs-sitefoot__links ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
body.filli-select .fs-sitefoot__links a{color:var(--fs-cream);text-decoration:none;font-size:13.5px;opacity:.9;transition:opacity .25s ease,color .25s ease}
body.filli-select .fs-sitefoot__links a:hover{opacity:1;color:#E8C9A0}
body.filli-select .fs-sitefoot__apptext{font-size:13px;color:var(--fs-foot-soft);line-height:1.6;margin:0 0 16px;max-width:30ch}
body.filli-select .fs-sitefoot__appcta{display:inline-block;border:1px solid rgba(250,246,239,.5);color:var(--fs-cream);
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:11px 22px;border-radius:4px;
  text-decoration:none;transition:background .3s ease,color .3s ease,border-color .3s ease}
body.filli-select .fs-sitefoot__appcta:hover{background:var(--fs-cream);color:var(--fs-brown);border-color:var(--fs-cream)}
body.filli-select .fs-sitefoot :focus-visible{outline:2px solid #E8C9A0;outline-offset:3px;border-radius:2px}
/* Legal strip uses the SAME brown as the Select footer above it (one colour, no two-tone) */
body.filli-select .footer-bottom{background:var(--fs-brown)}
body.filli-select .footer-bottom,body.filli-select .footer-bottom a,body.filli-select .footer-bottom p{color:var(--fs-foot-soft)}
body.filli-select .footer-bottom a:hover{color:var(--fs-cream)}

/* ---- RTL (/ar/filli-select) ---- */
[dir="rtl"] body.filli-select .fs-nav__lang,[dir="rtl"] body.filli-select .fs-sitefoot__apptext{letter-spacing:0}
[dir="rtl"] body.filli-select .fs-nav__drawer{right:auto;left:0}

/* ---- Responsive ---- */
@media (max-width:860px){
  body.filli-select .fs-nav__links{display:none}
  body.filli-select .fs-nav__mobile{display:block;position:relative}
  body.filli-select .fs-nav__toggle{list-style:none;cursor:pointer;width:42px;height:42px;
    display:flex;align-items:center;justify-content:center;border:1px solid var(--fs-line);border-radius:6px}
  body.filli-select .fs-nav__toggle::-webkit-details-marker{display:none}
  body.filli-select .fs-nav__bars{display:inline-flex;flex-direction:column;gap:4px;width:18px}
  body.filli-select .fs-nav__bars span{height:2px;width:100%;background:var(--fs-ink);border-radius:2px;display:block;transition:transform .25s ease,opacity .25s ease}
  body.filli-select .fs-nav__mobile[open] .fs-nav__bars span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  body.filli-select .fs-nav__mobile[open] .fs-nav__bars span:nth-child(2){opacity:0}
  body.filli-select .fs-nav__mobile[open] .fs-nav__bars span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  body.filli-select .fs-nav__drawer{position:absolute;right:0;top:calc(100% + 12px);min-width:208px;z-index:30;
    background:var(--fs-cream);border:1px solid var(--fs-line);border-radius:10px;
    box-shadow:0 20px 44px -20px rgba(46,27,18,.45);display:flex;flex-direction:column;padding:8px}
  body.filli-select .fs-nav__drawer .fs-nav__link{padding:11px 13px;border-radius:6px}
  body.filli-select .fs-nav__drawer .fs-nav__link:hover{background:var(--fs-sand)}
  body.filli-select .fs-nav__drawer .fs-nav__lang{margin-top:6px;text-align:center}
}
@media (max-width:760px){
  body.filli-select .fs-sitefoot__inner{grid-template-columns:1fr;gap:30px;text-align:center}
  body.filli-select .fs-sitefoot__brand img{margin-left:auto;margin-right:auto}
  body.filli-select .fs-sitefoot__social{justify-content:center}
  body.filli-select .fs-sitefoot__links ul{align-items:center}
  body.filli-select .fs-sitefoot__apptext{margin-left:auto;margin-right:auto}
}
/* Nav links step down a touch below xl, mirroring the main site's nav breakpoint */
@media (max-width:1199.98px){
  body.filli-select .fs-nav__link{font-size:.9rem}
}

/* ============================================================================
   FiLLi Select — HERO BANNER (full-bleed image + overlaid text, FiLLi Cafe format)
   Replaces the old centred-logo hero. Sits below the fixed nav; image is the LCP.
   ============================================================================ */
body.filli-select .fs-herobanner{position:relative;display:flex;align-items:center;overflow:hidden;
  min-height:clamp(70vh,82vh,720px)}
body.filli-select .fs-herobanner__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
/* The cup is centred in the photo. On wide screens the image fills the width (only
   vertical crop), so object-position can't move it — zoom-pan from the left instead to
   push the cup RIGHT, clear of the left text. Narrower screens DO crop horizontally, so
   there we use object-position (no zoom). Mirrored for RTL below. */
body.filli-select .fs-herobanner__bg img{width:100%;height:100%;object-fit:cover;display:block;
  object-position:center;transform-origin:left center;transform:scale(1.22)}
/* Left-panel scrim: strong behind the text, fully clear by ~52% so the white cup stays
   vibrant (a wide diagonal washed it out). */
body.filli-select .fs-herobanner__scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(96deg,rgba(40,22,14,.92) 0%,rgba(40,22,14,.82) 26%,rgba(40,22,14,.4) 41%,transparent 52%)}
body.filli-select .fs-herobanner__inner{position:relative;z-index:2;width:100%;max-width:1100px;margin:0 auto;padding:0 32px}
body.filli-select .fs-herobanner__eyebrow{display:inline-flex;align-items:center;gap:10px;margin:0 0 16px;
  font-family:var(--fs-sans);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(250,246,239,.85);text-shadow:0 1px 8px rgba(0,0,0,.35)}
body.filli-select .fs-herobanner__eyebrow::before{content:"";display:block;width:26px;height:1.5px;background:var(--fs-copper)}
body.filli-select .fs-herobanner__title{font-family:var(--fs-serif);font-weight:500;color:var(--fs-cream);
  font-size:clamp(34px,5vw,56px);line-height:1.12;max-width:12ch;margin:0;text-shadow:0 2px 24px rgba(0,0,0,.5)}
body.filli-select .fs-herobanner__title em{font-style:italic;color:#E3A968} /* lifted copper for contrast on dark */
body.filli-select .fs-herobanner__sub{font-size:clamp(14px,1.4vw,16px);font-weight:300;color:rgba(250,246,239,.9);
  max-width:32ch;margin:20px 0 30px;line-height:1.7;text-shadow:0 1px 8px rgba(0,0,0,.4)}
body.filli-select .fs-herobanner__ctas{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
body.filli-select .fs-hb-btn{display:inline-block;font-family:var(--fs-sans);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;font-weight:600;padding:15px 32px;border-radius:4px;text-decoration:none;cursor:pointer;
  transition:background .3s ease,color .3s ease,border-color .3s ease,transform .3s ease,box-shadow .3s ease}
body.filli-select .fs-hb-btn--fill{background:var(--fs-copper);color:var(--fs-cream);border:1px solid var(--fs-copper)}
body.filli-select .fs-hb-btn--fill:hover,body.filli-select .fs-hb-btn--fill:focus-visible{background:var(--fs-copper-deep);border-color:var(--fs-copper-deep);transform:translateY(-2px);box-shadow:0 14px 32px -14px rgba(0,0,0,.55)}
body.filli-select .fs-hb-btn--ghost{background:transparent;color:var(--fs-cream);border:1px solid rgba(250,246,239,.6)}
body.filli-select .fs-hb-btn--ghost:hover,body.filli-select .fs-hb-btn--ghost:focus-visible{background:rgba(250,246,239,.12);border-color:var(--fs-cream);transform:translateY(-2px)}
body.filli-select .fs-herobanner :focus-visible{outline:2px solid var(--fs-cream);outline-offset:3px;border-radius:2px}
/* RTL — text on the right, so mirror the scrim and pan the cup LEFT (clear of text) */
[dir="rtl"] body.filli-select .fs-herobanner__bg img{transform-origin:right center}
[dir="rtl"] body.filli-select .fs-herobanner__scrim{background:linear-gradient(264deg,rgba(40,22,14,.92) 0%,rgba(40,22,14,.82) 26%,rgba(40,22,14,.4) 41%,transparent 52%)}
[dir="rtl"] body.filli-select .fs-herobanner__inner{text-align:right}
[dir="rtl"] body.filli-select .fs-herobanner__title,[dir="rtl"] body.filli-select .fs-herobanner__sub{margin-left:auto}
@media (max-width:860px){
  /* These widths crop the photo horizontally, so position with object-position (no zoom) */
  body.filli-select .fs-herobanner__bg img{transform:none;object-position:64% center}
  [dir="rtl"] body.filli-select .fs-herobanner__bg img{object-position:36% center}
}
@media (max-width:680px){
  body.filli-select .fs-herobanner{min-height:clamp(500px,76vh,620px)}
  body.filli-select .fs-herobanner__scrim{background:linear-gradient(180deg,rgba(40,22,14,.5) 0%,rgba(40,22,14,.32) 42%,rgba(40,22,14,.78) 100%)}
  [dir="rtl"] body.filli-select .fs-herobanner__scrim{background:linear-gradient(180deg,rgba(40,22,14,.5) 0%,rgba(40,22,14,.32) 42%,rgba(40,22,14,.78) 100%)}
  body.filli-select .fs-herobanner__inner{padding:0 22px}
  body.filli-select .fs-herobanner__sub{max-width:34ch}
}
