/* ============================================================
   UitEten — restaurantgids front-end
   Per-stad themeable via CSS-variabelen (--ue-*), default = UitGroningen-groen.
   De stad-/home-plugin overschrijft ze inline (zie class-templates.php).
   ============================================================ */
.uiteten-archive,
.uiteten-single {
	--ue-accent: #14533A; --ue-accent-deep: #0E3A28; --ue-gold: #E0A53A;
	--ue-ink: #1B2A22; --ue-cream: #F6F3EC; --ue-line: #E4DDCF;
	--ue-fa: #14533A; --ue-fb: #0E3A28; --ue-grey: #5E6A60;
	--ue-radius: 16px; --ue-shadow: 0 2px 14px rgba(16,16,16,.07);
	--ue-shadow-h: 0 16px 38px rgba(16,16,16,.16);
	max-width: 1180px; margin: 0 auto; padding: 1.75rem 1.1rem 3.5rem;
	color: var(--ue-ink);
}
.uiteten-archive *, .uiteten-single * { box-sizing: border-box; }

/* ── Kop / intro ── */
.uiteten-archive__header h1,
.uiteten-hero__intro h1 { margin: 0 0 .3rem; line-height: 1.1; letter-spacing: -.01em; font-size: clamp(1.7rem, 3vw, 2.5rem); }
.uiteten-intro { max-width: 70ch; color: var(--ue-grey); margin: .25rem 0 1.5rem; font-size: 1.05rem; }

/* ── Breadcrumb ── */
.uiteten-breadcrumb { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; font-size: .85rem; color: var(--ue-grey); margin: 0 0 1.2rem; }
.uiteten-breadcrumb a { color: var(--ue-accent); text-decoration: none; }
.uiteten-breadcrumb a:hover { text-decoration: underline; }

/* ── Filterbalk ── */
.uiteten-filters {
	display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
	padding: 1rem; margin-bottom: 1rem;
	background: var(--ue-cream); border: 1px solid var(--ue-line); border-radius: var(--ue-radius);
}
.uiteten-filters input[type="search"],
.uiteten-filters select {
	padding: .55rem .7rem; border: 1px solid var(--ue-line); border-radius: 10px;
	font: inherit; background: #fff; color: var(--ue-ink);
}
.uiteten-filters input[type="search"]:focus,
.uiteten-filters select:focus { outline: none; border-color: var(--ue-accent); box-shadow: 0 0 0 3px rgba(0,0,0,.06); }
.uiteten-search { flex: 1 1 220px; min-width: 180px; }
.uiteten-check { display: inline-flex; align-items: center; gap: .35rem; font-size: .9rem; color: var(--ue-ink); }
.uiteten-count { font-size: .9rem; color: var(--ue-grey); margin: .25rem 0 1.25rem; }

/* ── Grid + kaarten ── */
.uiteten-grid { display: grid; gap: 1.4rem; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.uiteten-card {
	display: flex; flex-direction: column;
	border: 1px solid var(--ue-line); border-radius: var(--ue-radius); overflow: hidden;
	background: #fff; box-shadow: var(--ue-shadow); transition: transform .2s ease, box-shadow .2s ease;
}
.uiteten-card:hover { transform: translateY(-5px); box-shadow: var(--ue-shadow-h); }
.uiteten-card.is-featured { border-color: var(--ue-gold); box-shadow: 0 0 0 1px var(--ue-gold), var(--ue-shadow); }
.uiteten-card__link { text-decoration: none; color: inherit; display: flex; flex-direction: column; flex: 1; }
.uiteten-card__media { position: relative; aspect-ratio: 16/10; background: var(--ue-cream); overflow: hidden; }
.uiteten-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.uiteten-card:hover .uiteten-card__media img { transform: scale(1.05); }
.uiteten-card__body { padding: .9rem 1.05rem 1rem; display: flex; flex-direction: column; gap: .4rem; flex: 1; }
.uiteten-card__top { display: flex; align-items: flex-start; justify-content: space-between; gap: .5rem; }
.uiteten-card__top h3 { margin: 0; font-size: 1.16rem; line-height: 1.25; color: var(--ue-ink); }
.uiteten-card:hover .uiteten-card__top h3 { color: var(--ue-accent); }
.uiteten-card__excerpt { font-size: .92rem; color: var(--ue-grey); margin: 0; line-height: 1.5;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.uiteten-card__loc { font-size: .86rem; color: var(--ue-grey); margin: 0; }
.uiteten-card__loc .ico-pin { filter: grayscale(.2); }

/* Actie-rij onder de kaart */
.uiteten-card__actions { display: flex; align-items: center; justify-content: space-between; gap: .5rem;
	padding: .65rem 1.05rem; border-top: 1px solid var(--ue-line); }
.uiteten-link-detail { font-weight: 700; font-size: .9rem; color: var(--ue-accent); text-decoration: none; }
.uiteten-link-detail:hover { text-decoration: underline; }
.uiteten-card__contact { display: inline-flex; align-items: center; gap: .4rem; }

/* Rating / prijs / open-badge */
.uiteten-rating { flex: none; font-size: .85rem; font-weight: 700; color: var(--ue-accent-deep); white-space: nowrap; }
.uiteten-price { position: absolute; bottom: .5rem; right: .5rem; background: rgba(255,255,255,.92); color: var(--ue-ink);
	font-weight: 800; font-size: .8rem; padding: .15rem .5rem; border-radius: 6px; }
.uiteten-open { position: absolute; bottom: .5rem; left: .5rem; font-size: .72rem; font-weight: 800; text-transform: uppercase;
	letter-spacing: .03em; padding: .2rem .55rem; border-radius: 50px; }
.uiteten-open--yes { background: #1a8a2e; color: #fff; }
.uiteten-open--no { background: #6b6b6b; color: #fff; }

/* Chips */
.uiteten-chips { list-style: none; display: flex; flex-wrap: wrap; gap: .4rem; padding: 0; margin: 0; }
.uiteten-chips li { background: var(--ue-cream); border: 1px solid var(--ue-line); color: var(--ue-accent-deep);
	font-size: .74rem; font-weight: 600; padding: .2rem .6rem; border-radius: 50px; }
.uiteten-chips--lg li { font-size: .82rem; padding: .3rem .8rem; }

/* Foto-fallback */
.uiteten-fallback { position: absolute; inset: 0; display: grid; place-items: center;
	background: linear-gradient(135deg, var(--ue-fa), var(--ue-fb)); color: #fff; }
.uiteten-fallback span { font-size: 2.6rem; font-weight: 800; opacity: .85; }

/* Badge */
.uiteten-badge { position: absolute; top: .55rem; left: .55rem; z-index: 2;
	background: var(--ue-gold); color: var(--ue-ink); font-size: .68rem; font-weight: 800;
	text-transform: uppercase; letter-spacing: .05em; padding: .22rem .55rem; border-radius: 6px; }

/* Knoppen */
.uiteten-btn { display: inline-block; padding: .62rem 1.15rem; border-radius: 10px; border: 1px solid var(--ue-line);
	background: #fff; text-decoration: none; color: var(--ue-ink); font-weight: 700; font-size: .92rem; cursor: pointer;
	transition: all .18s ease; }
.uiteten-btn:hover { border-color: var(--ue-accent); color: var(--ue-accent); }
.uiteten-btn--primary { background: var(--ue-accent); border-color: var(--ue-accent); color: #fff; }
.uiteten-btn--primary:hover { background: var(--ue-accent-deep); border-color: var(--ue-accent-deep); color: #fff; }
.uiteten-btn--sm { padding: .42rem .8rem; font-size: .82rem; border-radius: 8px; }
.uiteten-btn--block { display: block; text-align: center; margin-top: 1rem; }
.uiteten-ico { display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 50%;
	border: 1px solid var(--ue-line); color: var(--ue-accent); text-decoration: none; font-size: 1rem; }
.uiteten-ico:hover { background: var(--ue-accent); color: #fff; border-color: var(--ue-accent); }

.uiteten-empty, .uiteten-error { padding: 1.5rem; text-align: center; color: var(--ue-grey); }
.uiteten-error { color: #b00020; }
.uiteten-more { display: block; margin: 1.75rem auto 0; padding: .7rem 1.6rem; border: 1px solid var(--ue-accent);
	border-radius: 50px; background: #fff; color: var(--ue-accent); font: inherit; font-weight: 700; cursor: pointer; }
.uiteten-more:hover { background: var(--ue-accent); color: #fff; }

/* ── Detailpagina: hero ── */
.uiteten-hero { display: grid; grid-template-columns: 1.1fr 1fr; gap: 2rem; align-items: stretch; margin-bottom: 2rem; }
.uiteten-hero__media { position: relative; border-radius: var(--ue-radius); overflow: hidden; min-height: 320px; background: var(--ue-cream); }
.uiteten-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.uiteten-hero__intro { display: flex; flex-direction: column; justify-content: center; }
.uiteten-meta { color: var(--ue-grey); margin: 0 0 .6rem; }
.uiteten-openstate { font-weight: 700; font-size: .92rem; margin: 0 0 .8rem; }
.uiteten-openstate--yes { color: #1a8a2e; }
.uiteten-openstate--no { color: #6b6b6b; }
.uiteten-openstate span { color: var(--ue-grey); font-weight: 500; }
.uiteten-lead { font-size: 1.08rem; line-height: 1.6; color: var(--ue-ink); margin: 0 0 1rem; }
.uiteten-cta { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: .4rem; }

/* ── Detailpagina: body + contact ── */
.uiteten-single__grid { display: grid; grid-template-columns: 1fr 320px; gap: 2.5rem; align-items: start; }
.uiteten-single__body { font-size: 1.02rem; line-height: 1.7; }
.uiteten-single__body p { margin: 0 0 1rem; }
.uiteten-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: .6rem; margin: 1.5rem 0; }
.uiteten-gallery__item { border-radius: 12px; overflow: hidden; aspect-ratio: 1; display: block; }
.uiteten-gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.uiteten-gallery__item:hover img { transform: scale(1.06); }

.uiteten-contact { background: #fff; border: 1px solid var(--ue-line); border-radius: var(--ue-radius);
	padding: 1.25rem 1.4rem; box-shadow: var(--ue-shadow); position: sticky; top: 1rem; }
.uiteten-contact h2 { margin: 0 0 .8rem; font-size: 1.25rem; }
.uiteten-contact h3 { margin: 1.2rem 0 .5rem; font-size: 1.05rem; }
.uiteten-facts { display: grid; grid-template-columns: max-content 1fr; gap: .4rem 1rem; margin: 0; }
.uiteten-facts dt { font-weight: 700; color: var(--ue-grey); }
.uiteten-facts dd { margin: 0; }
.uiteten-facts a { color: var(--ue-accent); }
.uiteten-hours { list-style: none; padding: 0; margin: .25rem 0 0; font-size: .92rem; color: var(--ue-ink); }
.uiteten-hours li { padding: .2rem 0; border-bottom: 1px dashed var(--ue-line); }

.uiteten-related { margin-top: 3rem; }
.uiteten-related h2 { margin: 0 0 1.2rem; font-size: 1.5rem; }
.uiteten-back { margin-top: 2.5rem; }
.uiteten-back a { color: var(--ue-accent); font-weight: 700; text-decoration: none; }

/* ── Responsive ── */
@media (max-width: 880px) {
	.uiteten-hero { grid-template-columns: 1fr; }
	.uiteten-hero__media { min-height: 220px; aspect-ratio: 16/9; }
	.uiteten-single__grid { grid-template-columns: 1fr; }
	.uiteten-contact { position: static; }
}
@media (max-width: 480px) {
	.uiteten-filters { padding: .8rem; }
	.uiteten-search { flex-basis: 100%; }
	.uiteten-grid { grid-template-columns: 1fr; }
}
