/* ===== Café Arcadia — Menu (faithful slurpramen.dk look: light cream + terracotta,
   editorial. Scoped to #menuPage so it never touches the dark hero). ===== */
@font-face{font-family:"Murmure";src:url("../fonts/le-murmure.otf") format("opentype");
  font-weight:400;font-style:normal;font-display:swap;}

#menuPage{
  --cream:#f4eee2;
  --cream-2:#ece4d4;
  --red:#b23b2e;
  --red-soft:rgba(178,59,46,.42);
  --ink:#2a241d;
  --muted:rgba(42,36,29,.55);
  --line:rgba(42,36,29,.14);
  --margin:clamp(20px,3vw,48px);
  --sans:"Helvetica Neue","Inter",Arial,sans-serif;
  background:var(--cream);color:var(--ink);
  font-family:var(--sans);-webkit-font-smoothing:antialiased;
}
#menuPage *{box-sizing:border-box;}
#menuPage a{color:inherit;text-decoration:none;cursor:pointer;}
#menuPage sup{font-size:.62em;margin-left:2px;vertical-align:super;}

/* ---- nav ---- */
#menuPage .m-nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:24px;
  justify-content:space-between;padding:20px var(--margin);background:var(--cream);
  border-bottom:1px solid var(--line);}
/* original Café Arcadia wordmark, pre-tinted to the current terracotta (red PNG) */
#menuPage .m-logo{display:flex;align-items:center;flex:none;}
#menuPage .m-logo img{height:34px;width:auto;display:block;}
#menuPage .m-links{display:flex;gap:26px;font-size:13px;letter-spacing:.06em;color:var(--red);}
#menuPage .m-links a{opacity:.55;transition:opacity .2s;} #menuPage .m-links a:hover,#menuPage .m-links a.is-active{opacity:1;}
#menuPage .m-cart{appearance:none;background:none;border:none;cursor:pointer;color:var(--red);
  font-family:var(--sans);font-size:13px;letter-spacing:.06em;}

/* ---- subbar: Filters | Gallery/List ---- */
#menuPage .m-subbar{display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--margin);border-bottom:1px solid var(--line);position:sticky;top:61px;z-index:15;background:var(--cream);}
#menuPage .m-filters-label{color:var(--red);font-size:13px;letter-spacing:.06em;}
#menuPage .view-toggle{display:flex;gap:22px;}
#menuPage .view-toggle button{appearance:none;background:none;border:none;cursor:pointer;color:var(--red);
  font-family:var(--sans);font-size:13px;letter-spacing:.06em;opacity:.5;transition:opacity .2s;}
#menuPage .view-toggle button::before{content:"○";margin-right:7px;}
#menuPage .view-toggle button.is-active{opacity:1;} #menuPage .view-toggle button.is-active::before{content:"●";}

/* ---- layout ---- */
#menuPage .menu-layout{display:grid;grid-template-columns:200px 1fr;gap:clamp(24px,4vw,72px);
  padding:36px clamp(70px,7vw,120px) 160px var(--margin);align-items:start;}  /* extra right gutter for the rail */
#menuPage .menu-cats,#menuPage .menu-main{min-width:0;}   /* let grid cols shrink → no horizontal overflow on mobile */
#menuPage .menu-cats{position:sticky;top:118px;}
#menuPage .menu-cats-inner{display:flex;flex-direction:column;gap:7px;align-items:flex-start;}
#menuPage .cat-link{appearance:none;background:none;border:none;cursor:pointer;text-align:left;
  color:var(--red-soft);font-family:var(--sans);font-size:14px;letter-spacing:.02em;padding:2px 0;
  transition:color .2s;}
#menuPage .cat-link:hover{color:var(--red);}
#menuPage .cat-link.is-active{color:var(--red);}

/* ---- sections ---- */
#menuPage .menu-section{margin-bottom:clamp(56px,7vw,96px);scroll-margin-top:130px;}
#menuPage .sec-title{color:var(--red);font-size:14px;letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:30px;padding-bottom:12px;border-bottom:1px solid var(--line);font-weight:400;}

/* GALLERY — airy image grid (editorial) */
#menuPage .view-gallery .items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(28px,3vw,56px);}
#menuPage .view-gallery .menu-item{display:flex;flex-direction:column;}
#menuPage .view-gallery .mi-thumb{aspect-ratio:4/5;width:100%;background:var(--cream-2);
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;}
#menuPage .view-gallery .mi-thumb span{color:var(--muted);font-size:11px;letter-spacing:.14em;text-transform:uppercase;}
#menuPage .view-gallery .mi-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
#menuPage .view-gallery .mi-body{padding-top:16px;display:flex;flex-direction:column;gap:7px;}
#menuPage .view-gallery .mi-head{display:flex;justify-content:space-between;align-items:baseline;gap:14px;}
#menuPage .view-gallery .mi-name{color:var(--red);font-size:17px;font-weight:400;letter-spacing:.01em;}
#menuPage .view-gallery .mi-price{color:var(--red);font-size:15px;white-space:nowrap;}
#menuPage .view-gallery .mi-desc{color:var(--muted);font-size:13.5px;line-height:1.5;}
#menuPage .view-gallery .mi-actions{margin-top:8px;}
#menuPage .view-gallery .items-grid{align-items:start;}
#menuPage .mi-desc:empty{display:none;}   /* collapse blank description lines (e.g. Bakery) */

/* MIXED GALLERY — items without a photo render as a full-width list row;
   sections with no photos at all (Drinks, Bakery) render as a tight list. */
/* list-only sections (Drinks, Bakery) flow into multiple columns to use the width */
#menuPage .view-gallery .items-grid.all-list{display:grid;
  grid-template-columns:repeat(auto-fill,minmax(340px,1fr));column-gap:clamp(40px,5vw,90px);row-gap:0;}
#menuPage .view-gallery .items-grid.all-list .menu-item.no-img{grid-column:auto;}
#menuPage .view-gallery .menu-item.no-img{grid-column:1 / -1;display:grid;grid-template-columns:1fr auto;
  gap:5px 24px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line);}
#menuPage .view-gallery .menu-item.no-img .mi-thumb{display:none;}
#menuPage .view-gallery .menu-item.no-img .mi-body{display:contents;}
#menuPage .view-gallery .menu-item.no-img .mi-head{grid-column:1;grid-row:1;display:flex;
  justify-content:flex-start;gap:14px;align-items:baseline;}
#menuPage .view-gallery .menu-item.no-img .mi-desc{grid-column:1;grid-row:2;max-width:62ch;}
#menuPage .view-gallery .menu-item.no-img .mi-actions{grid-column:2;grid-row:1 / span 2;justify-self:end;margin:0;}

/* LIST — minimal rows */
#menuPage .view-list .items-grid{display:flex;flex-direction:column;}
#menuPage .view-list .menu-item{display:grid;grid-template-columns:1fr auto;gap:5px 24px;align-items:center;
  padding:20px 0;border-bottom:1px solid var(--line);}
#menuPage .view-list .mi-thumb{display:none;}
#menuPage .view-list .mi-body{display:contents;}
#menuPage .view-list .mi-head{grid-column:1;grid-row:1;display:flex;gap:14px;align-items:baseline;}
#menuPage .view-list .mi-name{color:var(--red);font-size:17px;}
#menuPage .view-list .mi-price{color:var(--red);font-size:15px;white-space:nowrap;}
#menuPage .view-list .mi-desc{grid-column:1;grid-row:2;color:var(--muted);font-size:13.5px;line-height:1.5;max-width:62ch;}
#menuPage .view-list .mi-actions{grid-column:2;grid-row:1 / span 2;justify-self:end;}

/* add button + stepper (Add+ until in cart, then stepper) */
#menuPage .add-btn{appearance:none;cursor:pointer;background:none;border:1px solid var(--red-soft);color:var(--red);
  font-family:var(--sans);font-size:12px;letter-spacing:.06em;padding:8px 16px;border-radius:999px;transition:background .2s,border-color .2s;}
#menuPage .add-btn:hover{border-color:var(--red);background:rgba(178,59,46,.06);}
#menuPage .menu-item.in-cart .add-btn{display:none;}
#menuPage .stepper{display:none;align-items:center;border:1px solid var(--red-soft);border-radius:999px;overflow:hidden;}
#menuPage .menu-item.in-cart .stepper,
#menuPage .cart-line .stepper{display:inline-flex;}   /* cart lines always show the −/+ stepper */
#menuPage .stepper button{appearance:none;background:none;border:none;cursor:pointer;color:var(--red);
  width:32px;height:32px;font-size:17px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s;}
#menuPage .stepper button:hover{background:rgba(178,59,46,.08);}
#menuPage .stepper .qty{min-width:26px;text-align:center;font-size:14px;color:var(--red);}

/* ---- cart ---- */
#menuPage .cart-scrim{position:fixed;inset:0;background:rgba(42,36,29,.32);opacity:0;pointer-events:none;transition:opacity .35s;z-index:60;}
#menuPage .cart-scrim.open{opacity:1;pointer-events:auto;}
#menuPage .cart-drawer{position:fixed;top:0;right:0;height:100vh;width:380px;max-width:90vw;z-index:61;
  background:#fbf7ee;border-left:1px solid var(--line);transform:translateX(100%);
  transition:transform .4s cubic-bezier(.7,0,.2,1);display:flex;flex-direction:column;}
#menuPage .cart-drawer.open{transform:none;}
#menuPage .cart-head{display:flex;justify-content:space-between;align-items:center;padding:24px var(--margin);
  border-bottom:1px solid var(--line);color:var(--red);font-size:14px;letter-spacing:.06em;text-transform:uppercase;}
#menuPage .cart-close{appearance:none;background:none;border:none;cursor:pointer;color:var(--red);font-size:17px;}
#menuPage .cart-lines{flex:1;overflow-y:auto;padding:8px var(--margin);}
#menuPage .cart-empty{color:var(--muted);text-align:center;padding:48px 0;font-size:14px;}
#menuPage .cart-line{display:grid;grid-template-columns:1fr auto;gap:8px 14px;padding:18px 0;border-bottom:1px solid var(--line);}
#menuPage .cart-line .cl-name{font-size:15px;color:var(--ink);}
#menuPage .cart-line .cl-price{color:var(--red);text-align:right;}
#menuPage .cart-line .cl-controls{grid-column:1 / -1;}
#menuPage .cart-foot{padding:20px var(--margin) 26px;border-top:1px solid var(--line);}
#menuPage .cart-subtotal{display:flex;justify-content:space-between;font-size:15px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--red);margin-bottom:16px;}
#menuPage .checkout-btn{width:100%;appearance:none;border:none;cursor:pointer;background:var(--red);color:var(--cream);
  font-family:var(--sans);font-size:14px;letter-spacing:.08em;text-transform:uppercase;padding:15px;border-radius:8px;transition:opacity .2s;}
#menuPage .checkout-btn:hover{opacity:.9;}
#menuPage .cart-note{text-align:center;color:var(--muted);font-size:12px;margin-top:12px;}

/* ---- checkout modal (order review + notes) ---- */
#menuPage .checkout-scrim{position:fixed;inset:0;background:rgba(42,36,29,.45);opacity:0;pointer-events:none;transition:opacity .35s;z-index:70;}
#menuPage .checkout-scrim.open{opacity:1;pointer-events:auto;}
#menuPage .checkout-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-46%);
  width:460px;max-width:calc(100vw - 32px);max-height:calc(100vh - 48px);z-index:71;
  background:#fbf7ee;border:1px solid var(--line);border-radius:16px;box-shadow:0 30px 80px rgba(42,36,29,.3);
  display:flex;flex-direction:column;opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .35s,transform .35s,visibility .35s;}
#menuPage .checkout-modal.open{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,-50%);}
#menuPage .checkout-head{display:flex;justify-content:space-between;align-items:center;
  padding:22px 26px;border-bottom:1px solid var(--line);color:var(--red);font-size:15px;letter-spacing:.06em;text-transform:uppercase;}
#menuPage .checkout-close{appearance:none;background:none;border:none;cursor:pointer;color:var(--red);font-size:17px;}
#menuPage .checkout-body{padding:20px 26px;overflow-y:auto;}
#menuPage .checkout-items{display:flex;flex-direction:column;}
#menuPage .checkout-line{display:flex;align-items:baseline;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px;}
#menuPage .checkout-line .cl-q{color:var(--red);min-width:26px;}
#menuPage .checkout-line .cl-name{flex:1;color:var(--ink);}
#menuPage .checkout-line .cl-amt{color:var(--red);white-space:nowrap;}
#menuPage .checkout-summary{padding:14px 0 2px;}
#menuPage .checkout-row{display:flex;justify-content:space-between;color:var(--red);font-size:15px;letter-spacing:.04em;text-transform:uppercase;}
#menuPage .checkout-mode-wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:18px;}
#menuPage .checkout-mode-label{color:var(--ink);font-size:13px;letter-spacing:.04em;}
#menuPage .checkout-mode{display:inline-flex;border:1px solid var(--red-soft);border-radius:999px;overflow:hidden;}
#menuPage .cm-opt{appearance:none;cursor:pointer;background:none;border:none;color:var(--red);
  font-family:var(--sans);font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:9px 18px;transition:background .2s,color .2s;}
#menuPage .cm-opt.is-active{background:var(--red);color:var(--cream);}
#menuPage .checkout-notes-label{display:block;margin:18px 0 8px;color:var(--ink);font-size:13px;letter-spacing:.04em;}
#menuPage .checkout-notes{width:100%;resize:vertical;min-height:64px;background:#fff;border:1px solid var(--red-soft);border-radius:10px;
  padding:12px 14px;color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.5;transition:border-color .2s;}
#menuPage .checkout-notes::placeholder{color:var(--muted);}
#menuPage .checkout-notes:focus{outline:none;border-color:var(--red);}
#menuPage .checkout-foot{display:flex;gap:12px;padding:18px 26px 24px;border-top:1px solid var(--line);}
#menuPage .checkout-back{appearance:none;cursor:pointer;background:none;border:1px solid var(--red-soft);color:var(--red);
  border-radius:10px;padding:14px 22px;font-family:var(--sans);font-size:13px;letter-spacing:.06em;text-transform:uppercase;transition:border-color .2s;}
#menuPage .checkout-back:hover{border-color:var(--red);}
#menuPage .checkout-place,#menuPage .checkout-done{flex:1;appearance:none;cursor:pointer;border:none;background:var(--red);color:var(--cream);
  border-radius:10px;padding:14px;font-family:var(--sans);font-size:14px;letter-spacing:.08em;text-transform:uppercase;transition:opacity .2s;}
#menuPage .checkout-place:hover,#menuPage .checkout-done:hover{opacity:.9;}
/* confirmation state */
#menuPage .checkout-confirm,#menuPage .checkout-done{display:none;}
#menuPage .checkout-confirm{text-align:center;padding:14px 4px 8px;}
#menuPage .checkout-confirm h4{color:var(--red);font-size:21px;font-weight:400;margin-bottom:12px;letter-spacing:.02em;}
#menuPage .checkout-confirm p{color:var(--muted);font-size:14px;line-height:1.6;}
#menuPage .checkout-modal.done .checkout-review,
#menuPage .checkout-modal.done .checkout-back,
#menuPage .checkout-modal.done .checkout-place{display:none;}
#menuPage .checkout-modal.done .checkout-confirm{display:block;}
#menuPage .checkout-modal.done .checkout-done{display:block;}
@media(max-width:560px){
  #menuPage .checkout-modal{width:100vw;max-width:100vw;height:100%;max-height:100%;border-radius:0;top:0;left:0;transform:none;}
  #menuPage .checkout-modal.open{transform:none;}
}

/* ---- sub-section headings (e.g. Sandwiches & Toast under Breakfast) ---- */
#menuPage .subsec-title{color:var(--red);opacity:.7;font-size:12px;letter-spacing:.12em;
  text-transform:uppercase;font-weight:400;margin:34px 0 18px;}
#menuPage .menu-section .subsec-title:first-of-type{margin-top:6px;}

/* ---- florporto-style right rail: tags current category while scrolling ---- */
#menuPage .menu-rail{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:18;
  display:flex;flex-direction:column;gap:15px;align-items:flex-end;}
#menuPage .rail-link{display:flex;flex-direction:row-reverse;align-items:center;gap:10px;
  background:none;border:none;cursor:pointer;color:var(--red);opacity:.45;transition:opacity .25s;
  font-family:var(--sans);padding:0;}
#menuPage .rail-link:hover{opacity:1;}
#menuPage .rail-dot{width:7px;height:7px;border-radius:50%;border:1px solid var(--red);
  background:transparent;flex:none;transition:background .25s,transform .25s;}
#menuPage .rail-name{font-size:12px;letter-spacing:.04em;white-space:nowrap;
  opacity:0;transform:translateX(8px);transition:opacity .25s,transform .25s;}
#menuPage .rail-link:hover .rail-name{opacity:1;transform:none;}
#menuPage .rail-link.is-active{opacity:1;}
#menuPage .rail-link.is-active .rail-dot{background:var(--red);transform:scale(1.3);}
#menuPage .rail-link.is-active .rail-name{opacity:1;transform:none;}

/* ---- responsive ---- */
@media (max-width:820px){
  #menuPage .menu-layout{grid-template-columns:1fr;padding-right:var(--margin);}
  #menuPage .menu-cats{position:sticky;top:108px;background:var(--cream);z-index:14;}
  #menuPage .menu-cats-inner{flex-direction:row;overflow-x:auto;gap:18px;padding:10px 0;scrollbar-width:none;}
  #menuPage .menu-cats-inner::-webkit-scrollbar{display:none;}
  #menuPage .cat-link{white-space:nowrap;}
  #menuPage .menu-rail{display:none;}
}
@media (max-width:560px){
  #menuPage .view-gallery .items-grid{grid-template-columns:1fr 1fr;gap:18px;}
  #menuPage .m-links{display:none;}
  #menuPage .m-nav{padding:16px var(--margin);}
  #menuPage .m-logo img{height:28px;}
  #menuPage .cart-drawer{width:100vw;max-width:100vw;}
}
@media (prefers-reduced-motion:reduce){ #menuPage *{transition-duration:.01ms!important;} }
