/*
=========================================================
VENUES PAGE STYLESHEET - Joshua Dalton Media
=========================================================

Purpose
-------
Page-specific styles for the /venues/ Auckland wedding
venues guide page. Uses vn- BEM prefix. Relies on design
tokens and shared utilities from global.css.

What belongs in this file
-------------------------
- Venue page hero and trust badge
- Filter tabs
- Venue card grid with featured variant
- Venue card body/links
- Editorial insights section
- Scroll reveal states
- Responsive rules

Asset path usage
----------------
This stylesheet is intended to be referenced from pages with:

<link rel="stylesheet" href="/assets/css/auckland-wedding-venues.css">

Relationship to page files
--------------------------
Page files should:
1. Load this stylesheet after global.css
2. Use this stylesheet only on the /venues/ page
3. Keep shared styling in global.css

Maintenance rule
----------------
If any styles become reusable beyond the venues page,
move them to a shared stylesheet.
*/

/* ================= HERO ================= */
.vn-hero{padding:clamp(18px,5vw,30px) 0 clamp(18px,5vw,28px);border-bottom:1px solid var(--line)}
.vn-hero__inner{display:grid;gap:12px}
.vn-hero__title{margin:0;font-size:1.1rem;line-height:1.02;letter-spacing:-.03em}
.vn-hero__lead{margin:0;font-size:.86rem;line-height:1.5;color:var(--muted);max-width:62ch}
.vn-trust{display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:var(--ink);text-decoration:none;font-size:13px;line-height:1;transition:border-color .2s}
.vn-trust:hover{border-color:rgba(255,255,255,.18);text-decoration:none}
.vn-trust__stars{color:#facc15;font-size:14px;letter-spacing:1px}
.vn-trust__copy{display:flex;align-items:baseline;gap:6px}
.vn-trust__score{font-weight:800;font-size:14px}
.vn-trust__source{font-size:11px;color:var(--muted)}
.vn-trust__arrow{font-size:13px;color:var(--muted)}

/* ================= FILTERS ================= */
.vn-filters{display:flex;flex-wrap:wrap;gap:8px;padding:14px 0 8px}
.vn-filter{display:inline-flex;align-items:center;min-height:34px;padding:7px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04);color:var(--muted);font-size:13px;font-weight:700;line-height:1;cursor:pointer;transition:background .2s, color .2s, border-color .2s}
.vn-filter:hover{background:rgba(255,255,255,.08);color:var(--ink)}
.vn-filter.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ================= VENUE GRID ================= */
.vn-grid{display:grid;gap:var(--grid-gap);grid-template-columns:1fr;grid-auto-flow:dense;padding:8px 0 0}
.vn-card{position:relative;display:grid;grid-template-rows:auto 1fr auto;border-radius:var(--radius);overflow:hidden;background:var(--panel);border:1px solid var(--line);transition:transform .3s ease, box-shadow .3s ease}
.vn-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.vn-card--featured{border-color:rgba(255,77,77,.22)}
.vn-card__image{position:relative;aspect-ratio:4/3;overflow:hidden}
.vn-card--featured .vn-card__image{aspect-ratio:16/9}
.vn-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.vn-card:hover .vn-card__image img{transform:scale(1.03)}
.vn-card__style{position:absolute;top:10px;left:10px;display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-size:11px;font-weight:700;color:#fff;letter-spacing:.02em;line-height:1}
.vn-card__body{display:grid;gap:8px;padding:14px}
.vn-card__region{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--muted);line-height:1.2}
.vn-card__name{margin:0;font-size:16px;line-height:1.25;color:var(--ink);font-weight:700}
.vn-card__desc{margin:0;font-size:13px;line-height:1.5;color:var(--muted)}
.vn-card__links{display:flex;flex-wrap:wrap;gap:8px;padding:0 14px 14px}
.vn-card__link{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;line-height:1;text-decoration:none;transition:background .2s}
.vn-card__link--blog{background:var(--accent);color:#fff;border:1px solid var(--accent)}
.vn-card__link--blog:hover{filter:brightness(1.1);text-decoration:none}
.vn-card__link--site{background:rgba(255,255,255,.05);color:var(--muted);border:1px solid rgba(255,255,255,.1)}
.vn-card__link--site:hover{color:var(--ink);border-color:rgba(255,255,255,.2);text-decoration:none}

/* ================= INSIGHTS (EDITORIAL) ================= */
.vn-insights{display:grid;gap:var(--grid-gap);grid-template-columns:1fr;padding:4px 0 0}
.vn-insight{display:grid;grid-template-columns:auto 1fr;gap:14px;padding:18px;border-radius:var(--radius);background:var(--panel);border:1px solid var(--line)}
.vn-insight__num{width:36px;height:36px;border-radius:999px;background:var(--accent);color:#fff;font-weight:800;font-size:.85rem;line-height:1;display:grid;place-items:center;flex-shrink:0}
.vn-insight__body{display:grid;gap:6px}
.vn-insight__title{margin:0;font-size:15px;line-height:1.25;color:var(--ink);font-weight:700}
.vn-insight__text{margin:0;font-size:13px;line-height:1.55;color:var(--muted)}

/* ================= SCROLL REVEAL ================= */
.vn-reveal--pending{opacity:0;transform:translateY(20px);transition:opacity .5s ease, transform .5s ease}
.vn-reveal--pending.is-visible{opacity:1;transform:translateY(0)}

/* ================= HIDDEN UTILITY ================= */
.vn-card.is-hidden{display:none}

/* ================= RESPONSIVE BREAKPOINTS ================= */

@media(min-width:360px){
	/* ================= VENUE GRID ================= */
	.vn-card__body{padding:16px}
	.vn-card__links{padding:0 16px 16px}
}

@media(min-width:700px){
	/* ================= HERO ================= */
	.vn-hero__title{font-size:1.8rem}
	.vn-hero__lead{font-size:1rem}
	/* ================= VENUE GRID ================= */
	.vn-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
	.vn-card--featured{grid-column:span 2}
	.vn-card--featured .vn-card__image{aspect-ratio:21/9}
	.vn-card__name{font-size:18px}
	.vn-card__desc{font-size:14px}
	/* ================= INSIGHTS (EDITORIAL) ================= */
	.vn-insights{grid-template-columns:repeat(2, minmax(0, 1fr))}
	.vn-insight{padding:20px}
	.vn-insight__title{font-size:16px}
	.vn-insight__text{font-size:14px}
}

@media(min-width:1024px){
	/* ================= HERO ================= */
	.vn-hero__title{font-size:2.5rem}
	/* ================= VENUE GRID ================= */
	.vn-grid{display:block;columns:3;column-gap:var(--grid-gap)}
	.vn-card{break-inside:avoid;margin-bottom:var(--grid-gap)}
	.vn-card:last-child{margin-bottom:0}
	.vn-card--featured{grid-column:auto}
	.vn-card--featured .vn-card__image{aspect-ratio:4/3}
}

@media(prefers-reduced-motion:reduce){
	/* ================= SCROLL REVEAL ================= */
	.vn-reveal--pending{opacity:1;transform:none;transition:none}
	/* ================= VENUE GRID ================= */
	.vn-card__image img{transition:none}
	.vn-card{transition:none}
}
