/* BarfNow shared design layer — Momentum Design System (Webex), theme lightBronze.
   Colors come from @momentum-design/tokens (.mds-theme-stable-lightBronzeWebex);
   we map them to local names with safe fallbacks. */
:root{
  --bg:        var(--mds-color-mobile-bronze-light-primary, #f5efe4);
  --bg-soft:   var(--mds-color-mobile-bronze-light-secondary, #fcfaf4);
  --surface:   var(--mds-color-theme-background-solid-primary-normal, #ffffff);
  --text:      var(--mds-color-theme-text-primary-normal, #15120e);
  --text2:     var(--mds-color-theme-text-secondary-normal, #5f5b54);
  --accent:    var(--mds-color-theme-text-accent-normal, #0353a8);
  --accent-bg: var(--mds-color-theme-background-accent-normal, #1170cf);
  --border:    var(--mds-color-theme-background-secondary-normal, rgba(0,0,0,.10));
  --border-strong: var(--mds-color-theme-outline-primary-normal, rgba(0,0,0,.30));
  --btn:       var(--mds-color-theme-button-primary-normal, #15120e);
  --btn-hover: var(--mds-color-theme-button-primary-hover, #000000);
  --ok:        var(--mds-color-theme-button-join-normal, #1d805f);
  --err:       var(--mds-color-theme-button-cancel-normal, #db1f2e);
  --radius: 14px; --radius-sm: 9px; --pill: 999px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.06);
  --shadow: 0 2px 6px rgba(0,0,0,.06), 0 12px 28px rgba(0,0,0,.07);
  --maxw: 1180px;
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
img{ max-width:100%; } /* never let an image force horizontal scroll on phones */
body{
  font-family:var(--font, "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif);
  background-color:var(--bg);
  background-image:linear-gradient(180deg, var(--bg-soft) 0%, var(--bg) 42%);
  background-attachment:fixed;
  color:var(--text); font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3{ line-height:1.2; margin:0 0 .6rem; font-weight:700; letter-spacing:-.01em; }
h1{ font-size:clamp(1.6rem,3vw,2.4rem); }
h2{ font-size:1.3rem; margin-top:1.6rem; }
h3{ font-size:1.05rem; }
p{ margin:.2rem 0 .8rem; }
.muted{ color:var(--text2); }
.center{ text-align:center; }
.spacer{ flex:1 1 auto; }
.hidden{ display:none !important; }
.container{ max-width:var(--maxw); margin:0 auto; padding:0 clamp(1.25rem, 4vw, 2.75rem); }

/* Buttons — real Momentum <mdc-button> + on-theme fallback if the bundle is missing */
mdc-button{ cursor:pointer; }
mdc-button:not(:defined){
  display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
  padding:.6rem 1.1rem; border-radius:var(--pill); font:inherit; font-weight:600;
  line-height:1; background:var(--btn); color:#fff; border:1px solid transparent;
}
mdc-button[variant="secondary"]:not(:defined),
mdc-button[variant="tertiary"]:not(:defined){
  background:transparent; color:var(--text); border-color:var(--border-strong);
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
  padding:.6rem 1.15rem; border-radius:var(--pill); font:inherit; font-weight:600;
  cursor:pointer; border:1px solid transparent; background:var(--btn); color:#fff;
  text-decoration:none; transition:background .15s, transform .05s, box-shadow .15s;
}
.btn:hover{ background:var(--btn-hover); text-decoration:none; }
.btn:active{ transform:translateY(1px); }
.btn--accent{ background:var(--accent-bg); }
.btn--accent:hover{ background:color-mix(in srgb, var(--accent-bg) 86%, #000); }
.btn--secondary{ background:transparent; color:var(--text); border-color:var(--border-strong); }
.btn--secondary:hover{ background:rgba(0,0,0,.04); }
.btn--lg{ padding:.8rem 1.5rem; font-size:1.02rem; }
.btn--sm{ padding:.34rem .8rem; font-size:.85rem; }
.btn--block{ width:100%; }

/* Surfaces */
.card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:1.2rem 1.3rem; box-shadow:var(--shadow-sm); }
.grid{ display:grid; gap:1.1rem; }
.cols-2{ grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.cols-3{ grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); }

/* Tables */
table{ width:100%; border-collapse:collapse; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); }
th,td{ text-align:left; padding:.6rem .8rem; border-bottom:1px solid var(--border); vertical-align:top; font-size:.92rem; }
th{ background:color-mix(in srgb, var(--bg) 60%, var(--surface)); font-weight:600; }
tr:last-child td{ border-bottom:none; }
tbody tr:hover td{ background:rgba(0,0,0,.025); }
/* Wide data tables on phones: .table-wrap = horizontal scroll; .table-cards = stack each row into a card */
.table-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; }
@media (max-width:560px){
  table.table-cards{ border:none; box-shadow:none; background:transparent; }
  table.table-cards thead{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
  table.table-cards tr{ display:block; background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); box-shadow:var(--shadow-sm); margin-bottom:.7rem; overflow:hidden; }
  table.table-cards td{ display:flex; justify-content:space-between; align-items:center; gap:1rem;
    border-bottom:1px solid var(--border); padding:.5rem .85rem; font-size:.9rem; }
  table.table-cards tr td:last-child{ border-bottom:none; }
  table.table-cards td::before{ content:attr(data-label); color:var(--text2); font-weight:600; font-size:.82rem; }
  table.table-cards td[data-label=""]::before{ content:none; }
}

/* Pills / badges */
.pill,.badge{ display:inline-block; padding:.14rem .6rem; border-radius:var(--pill); font-size:.78rem; font-weight:600; }
.pill.on{ background:color-mix(in srgb, var(--ok) 15%, transparent); color:var(--ok); }
.pill.off{ background:color-mix(in srgb, var(--err) 15%, transparent); color:var(--err); }
.pill.fc{ background:color-mix(in srgb, var(--accent-bg) 14%, transparent); color:var(--accent); }
.badge{ background:color-mix(in srgb, var(--accent-bg) 12%, transparent); color:var(--accent); }

/* Forms */
.field{ margin-bottom:1.05rem; }
.field>label{ display:block; font-weight:600; margin-bottom:.32rem; font-size:.9rem; }
.field .help{ color:var(--text2); font-size:.8rem; margin-top:.25rem; }
.field .err{ color:var(--err); font-size:.82rem; margin-top:.25rem; }
input[type=text],input[type=email],input[type=password],input[type=number],input:not([type]),
select,textarea{ width:100%; max-width:520px; padding:.55rem .7rem; border:1px solid var(--border-strong);
  border-radius:var(--radius-sm); font:inherit; background:var(--surface); color:var(--text); }
input:focus,select:focus,textarea:focus{ outline:2px solid color-mix(in srgb,var(--accent-bg) 45%,transparent); outline-offset:1px; border-color:var(--accent-bg); }
textarea{ min-height:5rem; }
select[multiple]{ min-height:8.5rem; }
input[type=checkbox]{ width:auto; transform:scale(1.15); }

/* Toolbars */
.toolbar{ display:flex; align-items:center; gap:.7rem; margin-bottom:1rem; flex-wrap:wrap; }
code,.code{ font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace; }
pre.code{ background:#0d1117; color:#e6edf3; padding:.95rem 1.05rem; border-radius:var(--radius-sm);
  overflow:auto; font-size:.82rem; line-height:1.45; }

/* Marketing */
.hero{ padding-top:3.6rem; padding-bottom:2.8rem; }
.hero h1{ max-width:18ch; }
.hero .lead{ font-size:1.15rem; color:var(--text2); max-width:54ch; }
.hero .cta{ display:flex; gap:.7rem; flex-wrap:wrap; margin-top:1.4rem; }
.section{ padding-top:2.4rem; padding-bottom:2.4rem; }
.section-title{ margin-bottom:1.2rem; }
.feature{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius);
  padding:1.2rem; box-shadow:var(--shadow-sm); }
.feature .ic{ font-size:1.6rem; }
.feature h3{ margin:.5rem 0 .3rem; }
.steps{ counter-reset:step; display:grid; gap:1rem; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); }
.step{ background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:1.1rem; position:relative; box-shadow:var(--shadow-sm); }
.step .num{ display:inline-flex; align-items:center; justify-content:center; width:1.9rem; height:1.9rem;
  border-radius:var(--pill); background:var(--accent-bg); color:#fff; font-weight:700; margin-bottom:.5rem; }

/* Tabs (audience switch) */
.tabs{ display:inline-flex; gap:.3rem; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--pill); padding:.28rem; box-shadow:var(--shadow-sm); }
.tab{ border:none; background:transparent; color:var(--text2); font:inherit; font-weight:600;
  padding:.5rem 1.1rem; border-radius:var(--pill); cursor:pointer; }
.tab.active{ background:var(--btn); color:#fff; }

/* ---- Shop product grid (responsive cards) ---- */
.shop-grid{ display:grid; gap:1.1rem; grid-template-columns:repeat(auto-fill, minmax(230px, 1fr)); margin-top:1.3rem; }
.pcard{ display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:box-shadow .15s, transform .05s; }
.pcard:hover{ box-shadow:var(--shadow); }
.pcard .thumb{ aspect-ratio:1/1; background:var(--bg-soft); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.pcard .thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.pcard .thumb .ph{ color:var(--text2); opacity:.5; font-size:2.4rem; }
.pcard .body{ padding:.85rem .95rem 1rem; display:flex; flex-direction:column; gap:.15rem; flex:1; }
.pcard .pname{ font-weight:700; line-height:1.25; }
.pcard .pprice{ font-size:1.15rem; font-weight:800; letter-spacing:-.01em; }
.pcard .pavail{ color:var(--text2); font-size:.82rem; }
.pcard .pavail.out{ color:var(--err); font-weight:600; }
.pcard .pdesc{ color:var(--text2); font-size:.82rem; margin-top:.15rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.pcard .pactions{ margin-top:auto; padding-top:.8rem; }
/* quantity stepper */
.stepper{ display:inline-flex; align-items:stretch; border:1px solid var(--border-strong); border-radius:var(--pill); overflow:hidden; background:var(--surface); }
.stepper button{ width:2.4rem; border:none; background:transparent; color:var(--text); font-size:1.2rem; font-weight:700; cursor:pointer; line-height:1; }
.stepper button:hover{ background:var(--bg); }
.stepper button:disabled{ opacity:.35; cursor:not-allowed; }
.stepper input{ width:2.8rem; max-width:2.8rem; text-align:center; border:none; border-left:1px solid var(--border); border-right:1px solid var(--border);
  font:inherit; font-weight:600; padding:.45rem 0; background:var(--surface); color:var(--text); -moz-appearance:textfield; }
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.pcard .addrow{ display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.pcard .addrow .btn{ flex:1; min-width:7rem; justify-content:center; }
.cart-fab{ display:inline-flex; align-items:center; gap:.45rem; }
.cart-badge{ display:inline-flex; align-items:center; justify-content:center; min-width:1.3rem; height:1.3rem;
  padding:0 .35rem; border-radius:999px; background:var(--accent-bg); color:#fff; font-size:.78rem; font-weight:700; }
@media (max-width:560px){ .shop-grid{ grid-template-columns:1fr; } }

/* ---- Cart rows (no-think quantity steppers) ---- */
.cart-list{ display:flex; flex-direction:column; gap:.7rem; margin-top:1.2rem; }
.cart-row{ display:flex; align-items:center; gap:.9rem; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius); padding:.7rem .9rem; box-shadow:var(--shadow-sm); }
.cart-thumb{ width:56px; height:56px; flex:none; border-radius:var(--radius-sm); overflow:hidden;
  background:var(--bg-soft); display:flex; align-items:center; justify-content:center; }
.cart-thumb img{ width:100%; height:100%; object-fit:cover; }
.cart-thumb .ph{ opacity:.5; }
.cart-info{ flex:1; min-width:0; }
.cart-name{ font-weight:700; line-height:1.25; }
.cart-sum{ font-weight:800; min-width:5rem; text-align:right; }
.stepper--lg button{ width:3rem; font-size:1.5rem; padding:.35rem 0; }
.stepper--lg .qval{ min-width:3rem; text-align:center; font-weight:700; font-size:1.05rem;
  border-left:1px solid var(--border); border-right:1px solid var(--border); padding:.45rem .2rem; align-self:stretch; display:flex; align-items:center; justify-content:center; }
.iconbtn{ border:1px solid var(--border-strong); background:var(--surface); color:var(--text2);
  width:2.6rem; height:2.6rem; border-radius:var(--radius-sm); cursor:pointer; font-size:1.1rem; line-height:1; }
.iconbtn:hover{ background:var(--bg); color:var(--err); border-color:color-mix(in srgb,var(--err) 45%,transparent); }
.cart-remove{ margin:0; flex:none; }
@media (max-width:560px){
  /* Predictable 2-row layout via grid (flex-wrap was keying off the product-name length):
     row 1 = thumb · name/price · remove ;  row 2 = stepper · line total (right). */
  .cart-row{ display:grid; align-items:center; gap:.5rem .7rem;
    grid-template-columns:auto 1fr auto; grid-template-areas:"thumb info remove" "stepper stepper sum"; }
  .cart-thumb{ grid-area:thumb; width:48px; height:48px; }
  .cart-info{ grid-area:info; min-width:0; }
  .cart-remove{ grid-area:remove; }
  .cart-row .stepper--lg{ grid-area:stepper; justify-self:start; }
  .cart-sum{ grid-area:sum; justify-self:end; min-width:auto; }
}

/* ---- Brand logo (public header) ---- */
.brand-logo{ height:34px; width:auto; display:block; vertical-align:middle; }
@media (max-width:560px){
  .brand-logo{ height:28px; }
  .hero{ padding-top:2.4rem; padding-bottom:2rem; }
  .section{ padding-top:1.8rem; padding-bottom:1.8rem; }
}
