/* ===========================================================
   Cafetaria Tavor — Theme styles
   Gebaseerd op de HTML/CSS mockup. Kleuren-tokens worden
   overschreven via wp_add_inline_style() in inc/enqueue.php
   (op basis van de Customizer-instellingen).
   =========================================================== */

:root{
  --wood-1:       #7a3618;
  --wood-2:       #4d1e09;
  --brand:        #a62219;
  --brand-dark:   #7a1510;
  --accent:       #ffd500;
  --accent-dark:  #e6c000;
  --cream:        #f5ede0;
  --cream-2:      #ebdfc8;
  --bg:           var(--wood-2);
  --surface:      var(--cream);
  --ink:          #2a140a;
  --ink-soft:     #6b4a38;
  --ink-muted:    #8a6d5a;
  --line:         #e4d8c1;
  --radius:       14px;
  --shadow:       0 10px 30px rgba(0,0,0,.22);
  --maxw:         1180px;
  --nav-height:   60px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top: calc(var(--nav-height) + 12px);}
body{
  margin:0;
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--cream); line-height:1.55;
  background:
    repeating-linear-gradient(90deg, rgba(0,0,0,.035) 0, rgba(0,0,0,.035) 1px, transparent 1px, transparent 7px),
    radial-gradient(900px 500px at 20% -10%, rgba(255, 210, 150, .18), transparent 60%),
    linear-gradient(180deg, var(--wood-1) 0%, var(--wood-2) 100%) fixed;
  background-attachment: fixed;
}
a{color:inherit}
img{max-width:100%; display:block; height:auto}

/* TOP BAR */
.topbar{
  background:#2a140a; color:#f5ede0; font-size:.85rem;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.topbar .wrap{
  max-width:var(--maxw); margin:0 auto; padding:8px 20px;
  display:flex; gap:22px; align-items:center; justify-content:space-between; flex-wrap:wrap;
}
.topbar a{color:#fff; text-decoration:none; display:inline-flex; align-items:center; gap:6px}
.topbar a:hover{color:var(--accent)}
.topbar span{display:inline-flex; align-items:center; gap:6px}

/* HERO */
.hero{
  position:relative; color:#fff; overflow:hidden;
  background:
    radial-gradient(1000px 400px at 80% -20%, rgba(255,213,0,.15), transparent 60%),
    linear-gradient(135deg, rgba(166,34,25,.55) 0%, rgba(77,30,9,.85) 100%),
    repeating-linear-gradient(90deg, rgba(0,0,0,.04) 0, rgba(0,0,0,.04) 1px, transparent 1px, transparent 8px),
    linear-gradient(180deg, #7a3618 0%, #4d1e09 100%);
  min-height: 320px;
  border-bottom:4px solid var(--accent);
}
.hero .wrap{
  max-width:var(--maxw); margin:0 auto; padding:38px 20px 42px;
  display:grid; grid-template-columns: 1.4fr 1fr; gap:28px; align-items:center;
}
.hero__brand{display:flex; align-items:center; gap:16px; margin-bottom:10px}
.hero__logo{
  width:78px; height:78px; border-radius:50%;
  background:var(--accent); color:var(--ink);
  display:grid; place-items:center; font-weight:800; font-size:30px;
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
  border: 3px solid #fff;
  overflow:hidden;
}
.hero__logo img{width:100%; height:100%; object-fit:cover; border-radius:50%}
.hero h1{
  font-family:'Roboto Slab', Georgia, serif;
  font-size:clamp(2rem, 3.4vw, 3rem); margin:.2rem 0 .4rem;
  letter-spacing:-.01em; font-weight:800; line-height:1.1;
  text-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.hero p.lead{font-size:1.05rem; opacity:.92; max-width:520px}
.hero .meta{display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:14px; font-size:.95rem;}
.chip{
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22);
  padding:6px 12px; border-radius:999px; display:inline-flex; gap:8px; align-items:center;
}
.hero__cta{display:flex; gap:10px; margin-top:18px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 18px; border-radius:999px; font-weight:600; text-decoration:none;
  transition: transform .08s ease, background .15s ease;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent); color:var(--ink); box-shadow: 0 4px 12px rgba(0,0,0,.2);}
.btn-primary:hover{background:#ffde33}
.btn-ghost{background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}

.hero__card{
  background:var(--cream); color:var(--ink); border-radius:var(--radius);
  padding:18px 20px; box-shadow: var(--shadow);
  border:1px solid rgba(0,0,0,.04);
}
.hero__card h3{margin:0 0 10px; font-size:1.05rem}
.hours{display:grid; grid-template-columns: 1fr auto; gap:4px 14px; font-size:.95rem}
.hours .day{color:var(--ink-soft)}
.status-dot{width:10px; height:10px; border-radius:50%; background:#2ea84a; display:inline-block; margin-right:6px;}
.status-dot.closed{background:#b03a2e}

@media (max-width: 860px){ .hero .wrap{grid-template-columns:1fr} }

/* STICKY CATEGORY NAV */
.catnav{
  position:sticky; top:0; z-index:50;
  background:var(--cream);
  border-bottom:1px solid var(--line);
  box-shadow: 0 4px 12px rgba(0,0,0,.18);
  display: flex;
  align-items: center;
}
.catnav-btn {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.5rem;
  line-height: 1;
  padding: 0 10px;
  color: var(--ink-soft);
  transition: color .15s ease;
}
.catnav-btn:hover { color: var(--ink); }
.catnav-btn[hidden] { display: none; }

.catnav-inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  align-items: center;
  width: 100%;
}

.catnav .wrap {
  flex: 1;              /* vul de ruimte tussen de twee buttons */
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 10px 0;      /* zijpadding zit nu op catnav-inner */
  scrollbar-width: none;
}
.catnav .wrap::-webkit-scrollbar{display:none}
.catnav a{
  white-space:nowrap; text-decoration:none; color:var(--ink-soft);
  font-weight:600; padding:10px 16px; border-radius:999px;
  transition: background .15s ease, color .15s ease;
}
.catnav a:hover{color:var(--ink); background:var(--cream-2)}
.catnav a.active{background:var(--brand); color:#fff; box-shadow: 0 2px 8px rgba(166,34,25,.35)}

/* LAYOUT */
.layout{
  max-width:var(--maxw); margin:0 auto; padding:30px 20px 60px;
  display:grid; grid-template-columns: 1fr 320px; gap:34px;
}
@media (max-width: 960px){
  .layout{
    grid-template-columns:1fr
  }
  .aside{
    order:-1;position:relative !important;
    top:auto !important;
  }
  #openingHours{
    display:none;
  }
}

/* CATEGORIES */
.cat{
  margin: 0 0 22px;
  background: var(--cream);
  color: var(--ink);
  border-radius: var(--radius);
  padding: 24px 28px 18px;
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,.04);
  position: relative;
}
.cat h2{
  font-family:'Roboto Slab', Georgia, serif;
  font-size:1.6rem; margin:0 0 4px; letter-spacing:.01em;
  color:var(--brand-dark); font-weight:800; text-transform:uppercase;
  display:flex; align-items:center; gap:12px;
}
.cat h2::before{
  content:""; width:8px; height:26px; background:var(--accent);
  border-radius:3px; display:inline-block; box-shadow: 0 1px 2px rgba(0,0,0,.1);
}
.cat .sub{color:var(--ink-soft); margin:0 0 14px; font-size:.95rem}

.items{display:grid; grid-template-columns: 1fr; gap:0}
.item{
  display:grid; grid-template-columns: 1fr auto; gap:8px 16px;
  padding:16px 0; border-bottom:1px dashed var(--line);
  align-items:center;
}
.item:last-child{border-bottom:none}
.item__name{font-weight:600; font-size:1rem; margin:0; color:var(--ink)}
.item__desc{color:var(--ink-soft); font-size:.92rem; margin:4px 0 0}
.item__price{
  font-weight:800; white-space:nowrap; color:var(--ink);
  background:var(--accent);
  padding:8px 14px; border-radius:999px;
  border:none; align-self:start;
  box-shadow: 0 3px 0 var(--accent-dark);
  font-size:.95rem;
}

/* Aanbieding */
.price-offer{display:inline-flex; align-items:center; gap:8px; align-self:start;}
.price-offer .old{text-decoration:line-through; color:var(--ink-muted); font-weight:600; font-size:.9rem;}
.price-offer .new{
  font-weight:800; color:#fff; white-space:nowrap;
  background:var(--brand);
  padding:8px 14px; border-radius:999px;
  box-shadow: 0 3px 0 var(--brand-dark);
  font-size:.95rem;
}
.item.on-sale{
  position:relative;
  background: linear-gradient(90deg, rgba(255,213,0,.18), transparent 60%);
  margin: 0 -12px; padding-left:12px; padding-right:12px; border-radius:10px;
}
.ribbon{
  display:inline-block; background:var(--brand); color:#fff;
  font-size:.68rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase;
  padding:3px 10px; border-radius:4px; margin-left:8px; vertical-align:middle;
  box-shadow: 0 2px 0 var(--brand-dark);
}

/* Tags */
.tag{
  display:inline-block; font-size:.68rem; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; padding:3px 8px; border-radius:6px; margin-left:6px;
  vertical-align:middle;
  background:var(--accent); color:var(--ink); border:1px solid var(--accent-dark);
}
.tag.hot{background:var(--brand); color:#fff; border-color:var(--brand-dark)}
.tag.veg{background:#2ea84a; color:#fff; border-color:#1f7a36}

/* ASIDE */
.aside{
  align-self:start;
  background:var(--cream); color:var(--ink);
  border:1px solid rgba(0,0,0,.04); border-radius:var(--radius);
  padding:22px; box-shadow:var(--shadow);
  position: sticky;
  top:110px;
}

.aside h3{margin:0 0 4px; font-size:1.1rem; color:var(--brand-dark); text-transform:uppercase; letter-spacing:.02em; font-weight:800}
.aside .row{display:flex; align-items:flex-start; gap:12px; padding:12px 0; border-top:1px dashed var(--line)}
.aside .row:first-of-type{border-top:none}
.aside .row svg{flex:0 0 auto; margin-top:2px}
.aside .row strong{display:block; color:var(--ink)}
.aside .row span{color:var(--ink-soft); font-size:.92rem}
.aside .row a{color:var(--brand-dark); text-decoration:none; font-weight:600}
.aside .row a:hover{text-decoration:underline}
.aside .btn{width:100%; justify-content:center; margin-top:10px}

/* FOOTER */
.site-footer{
  background:#2a140a; color:#e4d4c0;
  padding:36px 20px 20px;
  border-top:4px solid var(--accent);
}
.site-footer .wrap{max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:24px}
.site-footer h4{color:#fff; margin:0 0 10px; font-size:1rem; text-transform:uppercase; letter-spacing:.03em}
.site-footer a{color:#e4d4c0; text-decoration:none}
.site-footer a:hover{color:var(--accent)}
.site-footer .bottom{max-width:var(--maxw); margin:24px auto 0; padding-top:14px; border-top:1px solid rgba(255,255,255,.08); font-size:.85rem; color:#9a8471}
@media (max-width: 760px){ .site-footer .wrap{grid-template-columns:1fr} }

/* UTIL */
.visually-hidden{position:absolute; width:1px; height:1px; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0}

/* WordPress admin bar fix */
.admin-bar .catnav{top:32px;}
@media (max-width: 782px){ .admin-bar .catnav{top:46px;} }
