:root{
  --linen:#ECE5D3;
  --paper:#FBF8F0;
  --ink:#241F1B;
  --ink-soft:#5A5147;
  --brick:#AC3527;
  --brick-dark:#832619;
  --gold:#C08F33;
  --sage:#6C7C56;
  --line:#D8CBA9;
  --radius:4px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--linen);
  color:var(--ink);
  font-family:'Manrope',sans-serif;
  font-size:15.5px;
  line-height:1.55;
  padding-bottom:64px; /* space for mobile bottom nav */
}
h1,h2,h3,.serif{font-family:'PT Serif',serif;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{font-family:inherit;cursor:pointer;}
.wrap{max-width:1100px;margin:0 auto;padding:0 16px;}

/* ---------- stitch divider ---------- */
.stitch{
  height:14px;
  background-color:var(--ink);
  background-image:
    linear-gradient(45deg, var(--brick) 25%, transparent 25%, transparent 75%, var(--brick) 75%),
    linear-gradient(45deg, var(--brick) 25%, transparent 25%, transparent 75%, var(--brick) 75%);
  background-position:0 0, 7px 7px;
  background-size:14px 14px;
}
.stitch.gold{
  background-image:
    linear-gradient(45deg, var(--gold) 25%, transparent 25%, transparent 75%, var(--gold) 75%),
    linear-gradient(45deg, var(--gold) 25%, transparent 25%, transparent 75%, var(--gold) 75%);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:1.5px solid var(--ink);background:transparent;color:var(--ink);
  padding:11px 18px;border-radius:var(--radius);font-weight:700;font-size:14px;
}
.btn-primary{background:var(--brick);border-color:var(--brick);color:#fff;}
.btn-block{width:100%;}
.btn[disabled]{opacity:.45;pointer-events:none;}

/* ---------- header (mobile-first) ---------- */
header.site{
  position:sticky;top:0;z-index:40;background:var(--paper);border-bottom:1px solid var(--line);
}
.header-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;gap:10px;}
.logo{display:flex;align-items:center;gap:8px;}
.logo-mark{width:30px;height:30px;flex-shrink:0;}
.logo-text{line-height:1.1;}
.logo-text .b1{font-family:'PT Serif',serif;font-weight:700;font-size:16px;display:block;}
.logo-text .b2{font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-soft);display:block;}
.header-actions{display:flex;align-items:center;gap:6px;}
.icon-btn{background:none;border:none;color:var(--ink);padding:6px;position:relative;display:flex;}
.cart-count{
  position:absolute;top:0;right:0;background:var(--brick);color:#fff;border-radius:50%;
  width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;
}
nav.desktop-nav{display:none;}

/* ---------- bottom mobile nav ---------- */
nav.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;z-index:50;
  background:var(--paper);border-top:1px solid var(--line);
  display:flex;justify-content:space-around;padding:6px 0 8px;
}
nav.bottom-nav a{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  font-size:10.5px;color:var(--ink-soft);font-weight:600;padding:4px 8px;position:relative;
}
nav.bottom-nav a.active{color:var(--brick);}
nav.bottom-nav svg{width:21px;height:21px;}
.bn-badge{
  position:absolute;top:-2px;right:2px;background:var(--brick);color:#fff;border-radius:50%;
  width:15px;height:15px;font-size:9px;display:flex;align-items:center;justify-content:center;font-weight:700;
}

/* ---------- hero ---------- */
.hero{padding:32px 16px 28px;}
.eyebrow{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--brick);font-weight:700;margin:0 0 10px;}
.hero h1{font-size:30px;line-height:1.15;margin:0 0 14px;font-weight:700;}
.hero p{font-size:15.5px;color:var(--ink-soft);margin:0 0 20px;max-width:46ch;}
.hero-ctas{display:flex;gap:10px;flex-wrap:wrap;}
.hero-photo{border-radius:8px;overflow:hidden;margin-top:20px;aspect-ratio:16/10;}
.hero-photo img{width:100%;height:100%;object-fit:cover;}

/* ---------- category chips ---------- */
.chip-row{display:flex;gap:8px;overflow-x:auto;padding:4px 16px 4px;-webkit-overflow-scrolling:touch;}
.chip-row::-webkit-scrollbar{display:none;}
.chip{
  flex-shrink:0;background:var(--paper);border:1px solid var(--line);border-radius:20px;
  padding:8px 15px;font-size:13px;font-weight:600;color:var(--ink-soft);white-space:nowrap;
}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}

/* ---------- sections ---------- */
.section{padding:32px 16px;}
.section-head{margin-bottom:18px;}
.section-head h2{font-size:22px;margin:0 0 4px;font-weight:700;}
.section-head p{margin:0;color:var(--ink-soft);font-size:13.5px;}

/* ---------- product grid & card ---------- */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.card{background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;}
.card-photo{aspect-ratio:4/3;background:var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.card-photo img{width:100%;height:100%;object-fit:cover;}
.card-photo svg{width:34px;height:34px;opacity:.8;}
.card-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:5px;flex:1;}
.card-cat{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:700;}
.card-name{font-family:'PT Serif',serif;font-size:14px;font-weight:700;line-height:1.3;margin:0;}
.card-name a{color:inherit;}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:6px;}
.price{font-weight:800;font-size:15px;}
.add-btn{background:var(--brick);color:#fff;border:none;border-radius:var(--radius);width:32px;height:32px;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;}

/* ---------- category tiles (home) ---------- */
.cat-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.cat-tile{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:14px 6px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;}
.cat-tile svg{width:26px;height:26px;color:var(--brick);}
.cat-tile span{font-size:11.5px;font-weight:700;line-height:1.2;}

/* ---------- why ---------- */
.why{display:flex;flex-direction:column;gap:18px;}
.why-item .num{font-family:'PT Serif',serif;font-weight:700;color:var(--brick);font-size:19px;display:block;margin-bottom:4px;}
.why-item h3{margin:0 0 4px;font-size:15px;}
.why-item p{margin:0;color:var(--ink-soft);font-size:13.5px;}

/* ---------- product detail ---------- */
.pd-photo{border-radius:8px;overflow:hidden;aspect-ratio:4/3;background:var(--line);display:flex;align-items:center;justify-content:center;}
.pd-photo img{width:100%;height:100%;object-fit:cover;}
.pd-photo svg{width:60px;height:60px;opacity:.8;}
.pd-cat{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--brick);font-weight:700;margin:16px 0 6px;}
.pd-name{font-size:22px;margin:0 0 10px;font-weight:700;}
.pd-price{font-size:24px;font-weight:800;margin:0 0 16px;}
.pd-desc{color:var(--ink-soft);font-size:14.5px;margin:0 0 20px;}
.pd-qty{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.pd-qty button{width:34px;height:34px;border:1px solid var(--line);background:#fff;border-radius:6px;font-weight:700;font-size:16px;}
.pd-qty span{font-size:16px;font-weight:700;min-width:20px;text-align:center;}
.pd-note{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-size:13px;color:var(--ink-soft);margin-top:20px;}

/* ---------- cart page ---------- */
.cart-row{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line);}
.cart-thumb{width:64px;height:64px;border-radius:6px;flex-shrink:0;background:var(--line);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.cart-thumb img{width:100%;height:100%;object-fit:cover;}
.cart-info{flex:1;min-width:0;}
.cart-info .n{font-weight:700;font-size:13.5px;margin:0 0 4px;}
.cart-info .p{font-size:13px;color:var(--ink-soft);margin:0;}
.qty{display:flex;align-items:center;gap:8px;margin-top:8px;}
.qty button{width:26px;height:26px;border:1px solid var(--line);background:#fff;border-radius:4px;font-weight:700;}
.qty span{min-width:18px;text-align:center;font-size:13px;}
.cart-remove{background:none;border:none;color:var(--brick);font-size:12px;text-decoration:underline;margin-top:6px;padding:0;}
.empty-msg{color:var(--ink-soft);font-size:14px;padding:36px 0;text-align:center;}
.total-row{display:flex;justify-content:space-between;font-weight:800;font-size:18px;margin:16px 0;}

/* ---------- forms ---------- */
.field{margin-bottom:14px;}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px;}
.field input, .field textarea{
  width:100%;border:1px solid var(--line);border-radius:4px;padding:11px 12px;
  font-family:inherit;font-size:14.5px;background:#fff;color:var(--ink);
}
.field textarea{resize:vertical;min-height:64px;}
.pay-opt{display:flex;align-items:flex-start;gap:10px;border:1px solid var(--line);border-radius:6px;padding:12px;margin-bottom:8px;}
.pay-opt input{margin-top:3px;}
.pay-opt .t{font-weight:700;font-size:13.5px;}
.pay-opt .d{font-size:12px;color:var(--ink-soft);margin-top:2px;}
.order-summary{background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:12px 14px;font-size:13.5px;margin-bottom:16px;}
.order-summary div{display:flex;justify-content:space-between;padding:3px 0;}
.success-box{text-align:center;padding:30px 0;}
.success-box .ok{width:48px;height:48px;border-radius:50%;background:var(--sage);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:24px;}

/* ---------- info pages ---------- */
.info-block{margin-bottom:26px;}
.info-block h2{font-size:19px;margin:0 0 8px;}
.info-block p{color:var(--ink-soft);font-size:14.5px;margin:0 0 8px;}
.hours-table{width:100%;border-collapse:collapse;font-size:14px;}
.hours-table td{padding:7px 0;border-bottom:1px solid var(--line);}
.hours-table td:last-child{text-align:right;font-weight:700;}
.contact-list a{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:14.5px;}
.contact-list svg{width:18px;height:18px;color:var(--brick);flex-shrink:0;}

/* ---------- footer ---------- */
footer.site{background:var(--ink);color:#EEE7D6;padding:32px 16px 90px;margin-top:20px;}
footer.site h4{font-family:'PT Serif',serif;font-size:15px;margin:0 0 10px;}
footer.site p, footer.site a{color:#C9C0A8;font-size:13.5px;display:block;margin-bottom:6px;}
.foot-block{margin-bottom:22px;}
.foot-bottom{border-top:1px solid #3a352e;padding-top:14px;font-size:12px;color:#9d947e;}

/* ---------- badge ---------- */
.badge-demo{display:inline-block;background:var(--gold);color:#241F1B;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:20px;margin-bottom:10px;}

/* ---------- admin ---------- */
.admin-order{border:1px solid var(--line);border-radius:6px;padding:12px 14px;margin-bottom:10px;font-size:13.5px;background:var(--paper);}
.admin-order .top{display:flex;justify-content:space-between;font-weight:700;margin-bottom:4px;}
.admin-order .tag{font-size:10.5px;padding:2px 8px;border-radius:20px;background:var(--sage);color:#fff;}
.admin-order .tag.new{background:var(--brick);}
.admin-order .items{color:var(--ink-soft);margin:6px 0;}

/* ---------- modal (used on cart page for admin) ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(36,31,27,.55);z-index:200;display:none;align-items:center;justify-content:center;padding:16px;}
.modal-overlay.show{display:flex;}
.modal{background:var(--paper);border-radius:8px;max-width:460px;width:100%;max-height:85vh;overflow-y:auto;padding:22px;}

/* ================= DESKTOP ================= */
@media(min-width:860px){
  body{padding-bottom:0;font-size:16px;}
  nav.bottom-nav{display:none;}
  nav.desktop-nav{display:flex;gap:4px;padding:0 16px 14px;max-width:1100px;margin:0 auto;}
  nav.desktop-nav a{padding:7px 14px;font-size:13.5px;color:var(--ink-soft);font-weight:600;border-radius:20px;}
  nav.desktop-nav a.active,nav.desktop-nav a:hover{background:var(--ink);color:var(--paper);}
  .hero{padding:56px 16px 44px;}
  .hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:44px;align-items:center;}
  .hero h1{font-size:42px;}
  .hero p{font-size:17px;}
  .hero-photo{margin-top:0;}
  .grid{grid-template-columns:repeat(4,1fr);gap:20px;}
  .cat-tiles{grid-template-columns:repeat(7,1fr);}
  .why{flex-direction:row;gap:28px;}
  .why-item{flex:1;}
  .section{padding:52px 16px;}
  .foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:32px;}
  footer.site{padding:44px 16px 24px;}
  .pd-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start;}
}
