:root{
  /* coffee / brown + dark-orange theme. --green is the primary (coffee) brand colour;
     --terra is the dark-orange accent. Variable names kept for compatibility. */
  --cream:#FBF5ED; --card:#ffffff; --ink:#241A12; --muted:#8A7561;
  --green:#4A3424; --green-soft:#EEE4D8; --terra:#C25E1E; --terra-soft:#F7E4D3;
  --purple:#9C6B3F; --line:#E6DAC9; --radius:18px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--cream);color:var(--ink);font-family:'Outfit',system-ui,sans-serif;font-size:15px;line-height:1.45;overflow-x:hidden}
h1,h2,h3,.disp{font-family:'Oswald','Fraunces',Georgia,sans-serif;margin:0;letter-spacing:.3px}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.muted{color:var(--muted)}
.small{font-size:13px}
.tiny{font-size:11px}

/* ---------- shell ---------- */
.app{max-width:1100px;margin:0 auto;display:flex;min-height:100vh}
.topbanner{position:sticky;top:0;z-index:50;height:56px;display:flex;align-items:center;
  justify-content:space-between;padding:0 18px;background:var(--green);
  box-shadow:0 2px 8px rgba(0,0,0,.18)}
.auth-cta{display:flex;gap:8px;align-items:center}
.preview-banner{background:#fff4e0;border-bottom:1px solid #f0d49a;color:#7a5a18;
  padding:9px 18px;font-size:13px;line-height:1.45;text-align:center}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;line-height:1;min-width:0}
.brand-stack{display:inline-flex;flex-direction:column;align-items:stretch;min-width:0}
.brand-logo{width:42px;height:42px;flex:none;border-radius:10px;object-fit:cover;background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.3)}
.brand-logo-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:24px}
.brand-name{font-family:'Oswald','Fraunces',Georgia,sans-serif;font-weight:700;font-size:24px;letter-spacing:5px;
  color:#fff;line-height:1;white-space:nowrap;text-align:center;text-indent:5px;
  text-shadow:1px 1px 0 #2E2013,2px 2px 0 #1B120A,2px 2px 5px rgba(0,0,0,.4)}
.brand-tagline{margin-top:3px;padding-top:3px;border-top:1px solid rgba(255,255,255,.55);
  font-family:'Comic Sans MS','Comic Sans',cursive;font-style:italic;font-weight:600;
  font-size:11px;letter-spacing:.2px;color:#FBE7CF;line-height:1.1;white-space:nowrap;text-align:center;
  text-shadow:1px 1px 1px rgba(0,0,0,.3)}
.sidebar{position:sticky;top:56px;align-self:flex-start;width:230px;flex:0 0 230px;background:#fffcf8;border-right:1px solid var(--line);
  padding:14px;display:flex;flex-direction:column;gap:6px}
.sidebar-logo{display:block;width:100%;aspect-ratio:1/1;margin:6px auto 16px;border-radius:20px;
  border:7px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.16);overflow:hidden;background:#fff}
.sidebar-logo img{width:100%;height:100%;object-fit:cover;display:block}
.navlink{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:12px;font-weight:500;color:var(--ink)}
.navlink:hover{background:#f6f3ec}
.navlink.active{background:var(--green-soft);color:var(--green)}
.navlink .badge{margin-left:auto;background:var(--terra);color:#fff;border-radius:999px;font-size:11px;padding:1px 7px}
.navlink.sub{padding:8px 12px 8px 20px;font-size:13px}
.navlink.sub2{padding:7px 12px 7px 32px;font-size:12px;color:var(--muted)}
.navlink.sub2.active{color:var(--green)}
.navgroup>summary{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:12px;
  font-weight:500;color:var(--ink);list-style:none;cursor:pointer;user-select:none}
.navgroup>summary::-webkit-details-marker{display:none}
.navgroup>summary::after{content:'›';margin-left:auto;font-size:16px;line-height:1;
  display:inline-block;transition:transform .15s}
.navgroup[open]>summary::after{transform:rotate(90deg)}
.navgroup>summary:hover{background:#f6f3ec}
.navgroup>summary.active{background:var(--green-soft);color:var(--green)}
.navgroup-items>.navgroup>summary{padding:8px 12px 8px 20px;font-size:13px}
.navgroup-items{display:flex;flex-direction:column;gap:1px;padding-top:2px}
.content{flex:1;min-width:0;padding-bottom:90px}
.profile-menu{position:relative;z-index:30}
.profile-menu>summary{display:flex;align-items:center;gap:8px;cursor:pointer;list-style:none;
  padding:4px 12px 4px 4px;background:#fff;border:1px solid var(--line);border-radius:999px;
  box-shadow:0 1px 3px rgba(0,0,0,.12)}
.profile-menu>summary::-webkit-details-marker{display:none}
.profile-dropdown{position:absolute;right:0;top:calc(100% + 6px);background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:0 4px 16px rgba(0,0,0,.08);
  min-width:150px;z-index:50;overflow:hidden}
.profile-dropdown a{display:block;padding:10px 14px;font-size:14px;font-weight:500}
.profile-dropdown a:hover{background:#f6f3ec}
.topnav{display:flex;align-items:center;gap:6px;margin-left:auto;margin-right:14px}
.topnav-link{color:rgba(255,255,255,.85);font-size:14px;font-weight:600;padding:7px 12px;border-radius:999px;white-space:nowrap}
.topnav-link:hover{background:rgba(255,255,255,.14);color:#fff}
.topnav-link.active{background:#fff;color:var(--green)}
.pill{display:inline-flex;align-items:center;gap:6px;background:#fff;border-radius:999px;padding:7px 12px;font-size:13px;
  font-weight:500;box-shadow:0 1px 2px rgba(0,0,0,.05);border:1px solid var(--line)}
.page{padding:18px 20px}

.bottomnav{display:none}

/* ---------- components ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;cursor:pointer;
  border-radius:999px;padding:10px 16px;font-size:14px;font-weight:600;font-family:inherit;text-decoration:none}
.btn:active{transform:scale(.98)}
.btn.primary{background:var(--green);color:#fff}
.btn.terra{background:var(--terra);color:#fff}
.btn.soft{background:var(--green-soft);color:var(--green)}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.lg{padding:13px 22px;font-size:15px}
.btn.sm{padding:7px 13px;font-size:13px}
.btn.block{width:100%}
.btn[disabled]{opacity:.45;cursor:not-allowed}

.chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:7px;
  padding:6px 12px;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;white-space:nowrap}
.chip.active{background:var(--green);color:#fff;border-color:var(--green)}
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.sep{width:1px;background:var(--line);margin:0 4px;flex:0 0 1px}

/* category quick-filter chips: squarer, tighter and wrapping (no horizontal scroll) */
.catchips{display:flex;flex-wrap:wrap;gap:5px}
.catchip{display:inline-flex;align-items:center;background:var(--terra-soft);border:1px solid #EBD3BD;
  border-radius:7px;padding:4px 9px;font-size:12px;font-weight:500;color:var(--terra);cursor:pointer;white-space:nowrap}
.catchip.active{background:var(--terra);color:#fff;border-color:var(--terra)}

.card{background:var(--card);border-radius:var(--radius);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.pad{padding:18px}

.tag{display:inline-flex;align-items:center;gap:5px;background:#f1ede4;border-radius:999px;padding:3px 9px;font-size:12px}
.tag.green{background:var(--green-soft);color:var(--green)}
.tag.terra{background:var(--terra-soft);color:var(--terra)}

.avatar{flex:0 0 auto;border-radius:50%;background:var(--terra);color:#fff;display:grid;place-items:center;font-weight:600}

.field{display:block;margin-bottom:14px}
.field>span{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.field .hint{font-weight:400;color:var(--muted);font-size:12px;margin-top:4px;display:block}
input[type=text],input[type=number],input[type=email],textarea,select{
  width:100%;border:1px solid var(--line);border-radius:12px;padding:10px 13px;font-size:14px;font-family:inherit;
  background:#fff;outline:none}
input:focus,textarea:focus,select:focus{border-color:#b9b09b}

.price{font-family:'Fraunces',serif;font-weight:600;color:var(--green)}
.h1{font-size:30px}.h2{font-size:22px}

/* feed grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.lcard{overflow:hidden}
.lcard .ph{aspect-ratio:4/3;width:100%;object-fit:cover;background:linear-gradient(135deg,var(--green),#8A5A36)}
.lcard .ph.b{background:linear-gradient(135deg,#7c4a2d,var(--terra))}
.lcard .body{padding:12px}
.soldout{position:relative}
.soldout::after{content:"Sold out today";position:absolute;inset:0;display:grid;place-items:center;
  background:rgba(0,0,0,.45);color:#fff;font-weight:600;font-size:14px}

.flash{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:10px 18px;border-radius:999px;font-size:14px;z-index:60;box-shadow:0 6px 20px rgba(0,0,0,.2)}

.row{display:flex;align-items:center;gap:12px}
.between{display:flex;align-items:center;justify-content:space-between}
.stack>*+*{margin-top:12px}
.bubble{max-width:75%;padding:9px 13px;border-radius:16px;background:#fff;font-size:14px}
.bubble.me{background:var(--green);color:#fff;margin-left:auto}
/* automated order/system notice: centred neutral pill, distinct from typed bubbles */
.chat-system{max-width:88%;margin:0 auto;padding:8px 14px;border-radius:12px;text-align:center;
  background:var(--terra-soft);color:var(--green);border:1px solid #EBD3BD;font-size:13px}

/* ---------- responsive ---------- */
@media (max-width:760px){
  .sidebar{display:none}
  .brand-name{font-size:20px;letter-spacing:3.5px;text-indent:3.5px}
  .brand-tagline{font-size:10px;margin-top:2px;padding-top:2px;overflow:hidden;text-overflow:ellipsis}
  .brand-logo{width:34px;height:34px}
  .brand-logo-fallback{font-size:20px}
  .h1{font-size:22px}.h2{font-size:18px}
  h1{font-size:24px}h2{font-size:19px}h3{font-size:17px}
  .profile-name{display:none}
  .topnav{margin-right:8px;gap:4px}
  .topnav-link{font-size:12px;padding:6px 9px}
  .profile-menu>summary{padding:4px}
  .content{padding-bottom:80px}
  .page{padding:14px}
  .grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .detail-grid{grid-template-columns:1fr !important}
  .bottomnav{display:flex;position:fixed;left:0;right:0;bottom:0;background:#fff;
    border-top:1px solid var(--line);box-shadow:0 -2px 14px rgba(0,0,0,.07);
    justify-content:space-around;padding:8px 0;
    padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));z-index:40}
  .bottomnav a{display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;color:#9ca3af;font-size:10px;font-weight:600;flex:1;
    padding:6px 4px;min-height:52px;-webkit-tap-highlight-color:transparent}
  .bottomnav a.active{color:var(--green)}
  .bottomnav a svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.75;
    fill:none;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
  .bnav-icon-wrap{position:relative;display:inline-flex}
  .bnav-badge{position:absolute;top:-5px;right:-9px;background:var(--terra);color:#fff;
    border-radius:999px;font-size:9px;padding:0 4px;font-weight:700;
    min-width:15px;height:15px;display:flex;align-items:center;justify-content:center}
}

/* Scrollable Terms & Conditions accept gate (onboarding + seller registration) */
.terms-accept{margin-top:6px}
.terms-box{max-height:220px;overflow-y:auto;border:1px solid var(--line);border-radius:12px;
  padding:12px 14px;background:#fffcf8;font-size:13px;line-height:1.55;color:var(--ink)}
.terms-box:focus{border-color:#b9b09b;outline:none}
.terms-accept input[type=checkbox]:disabled+span{opacity:.5}

/* Rich (HTML) terms content — used in the scroll-to-accept box and the /terms page */
.terms-content h3{font-size:14px;font-weight:700;margin:16px 0 6px;color:var(--ink)}
.terms-content h3:first-child{margin-top:0}
.terms-content p{margin:0 0 8px}
.terms-content ul{margin:0 0 10px;padding-left:20px}
.terms-content li{margin:3px 0}
.terms-content .terms-meta{opacity:.7;font-size:12px;margin-bottom:12px}
.terms-box.terms-content h3{font-size:13px;margin-top:14px}
