/* VaciLatte production site - shared design system
   Brand language inherited from concept-13-architectural: cool-grey neutrals,
   hairline grid, thin lowercase display, wide-tracked micro-labels, numbered indices. */

:root {
	--grey: #e2e4e6;
	--grey-2: #d4d7d9;
	--off: #eef0f2;
	--char: #1a1c1e;
	--char-soft: #636363;
	--line: #c4c6c4;
	--line-strong: #b3b4b2;
	--sans: "Archivo", system-ui, -apple-system, sans-serif;
	--wrap: 1280px;
	--focus: #1a1c1e;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	font-family: var(--sans);
	font-weight: 400;
	background: var(--grey);
	color: var(--char);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

:focus-visible { outline: 2px solid var(--focus); outline-offset: 3px; }

.wrap { width: min(var(--wrap), 100% - 3rem); margin-inline: auto; }
.label { font-size: .66rem; letter-spacing: .26em; text-transform: uppercase; color: var(--char-soft); font-weight: 500; }

.skip {
	position: absolute; left: 50%; top: -3rem; transform: translateX(-50%);
	background: var(--char); color: var(--off); padding: .7rem 1.2rem;
	font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; z-index: 100;
	transition: top .2s;
}
.skip:focus { top: .6rem; }

/* Reveal on scroll */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
	.reveal { opacity: 1; transform: none; transition: none; }
	html { scroll-behavior: auto; }
}

/* Art-directed placeholders, gallery-installation neutral */
.ph { position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; text-align: center; padding: 2.4rem; border: 1px solid rgba(26,28,30,.1); background: linear-gradient(115deg, rgba(255,255,255,.4), transparent 58%), linear-gradient(150deg, #ced3d7 0%, #b8bec3 100%); }
.ph::before { content: ""; position: absolute; inset: 0; pointer-events: none;
	background:
		linear-gradient(#9c9c9a,#9c9c9a) left 1.1rem top 1.1rem/16px 1px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) left 1.1rem top 1.1rem/1px 16px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) right 1.1rem top 1.1rem/16px 1px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) right 1.1rem top 1.1rem/1px 16px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) left 1.1rem bottom 1.1rem/16px 1px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) left 1.1rem bottom 1.1rem/1px 16px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) right 1.1rem bottom 1.1rem/16px 1px no-repeat,
		linear-gradient(#9c9c9a,#9c9c9a) right 1.1rem bottom 1.1rem/1px 16px no-repeat; }
.ph .ph-label { position: relative; z-index: 1; font-size: .58rem; letter-spacing: .22em; text-transform: uppercase; color: var(--char-soft); max-width: 24ch; line-height: 1.85; }
.ph img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.ph.has-img::before { display: none; }
.ph.has-img .ph-label { display: none; }

/* Header / nav */
header { position: sticky; top: 0; z-index: 50; background: rgba(226,228,230,.9); backdrop-filter: blur(8px); border-bottom: 1px solid var(--line); }
.nav { display: flex; align-items: center; justify-content: space-between; padding: 1.2rem 0; }
.brand img { height: 34px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 2.2rem; list-style: none; }
.nav-links a { font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--char-soft); transition: color .25s; font-weight: 500; padding: .4rem 0; position: relative; }
.nav-links a:hover { color: var(--char); }
.nav-links a[aria-current="page"] { color: var(--char); }
.nav-links a[aria-current="page"]:not(.nav-cta)::after { content: ""; position: absolute; left: 0; right: 0; bottom: -.1rem; height: 1px; background: var(--char); }
.nav-cta[aria-current="page"] { box-shadow: 0 1px 0 var(--char); }
.nav-cta { color: var(--char); }
.nav-cta::before { content: "["; margin-right: .25rem; color: var(--char-soft); }
.nav-cta::after { content: "]"; margin-left: .25rem; color: var(--char-soft); }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: .5rem; margin-right: -.5rem; }
.nav-toggle span { display: block; width: 24px; height: 1px; background: var(--char); margin: 6px 0; transition: transform .25s, opacity .25s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Buttons */
.actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.btn { font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; padding: .9rem 1.8rem; transition: background .25s, color .25s; display: inline-block; }
.btn-solid { background: var(--char); color: var(--off); }
.btn-solid:hover { background: #000; }
.btn-ghost { border: 1px solid var(--char); color: var(--char); }
.btn-ghost:hover { background: var(--char); color: var(--off); }

/* Section + numbered section head */
section { padding: clamp(3.5rem,8vw,6.5rem) 0; }
.sec-head { display: flex; align-items: baseline; flex-wrap: wrap; gap: .3rem 1.1rem; margin-bottom: clamp(1rem,2vw,1.5rem); }
.sec-head .ix { font-size: .95rem; color: var(--char-soft); font-variant-numeric: tabular-nums; font-weight: 500; }
.sec-head h2 { font-weight: 400; font-size: clamp(1.7rem,3.5vw,2.4rem); letter-spacing: -.01em; }
.sec-head .meta-r { align-self: center; margin-left: .5rem; font-size: .66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--char-soft); }

/* Page intro band (per-page hero for inner pages) */
.page-head { border-bottom: 1px solid var(--line); }
.page-head .wrap { padding: clamp(2rem,4.5vw,3.6rem) 0 clamp(2.2rem,4.5vw,3.4rem); }
.page-head .pager { font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--char-soft); font-variant-numeric: tabular-nums; display: block; margin-bottom: 1.6rem; }
.page-head h1 { font-weight: 300; font-size: clamp(2.4rem,6vw,4.4rem); line-height: 1.04; letter-spacing: -.02em; max-width: 18ch; }
.page-head .sub { color: var(--char-soft); max-width: 44ch; margin-top: 1.6rem; }

/* Footer */
footer { background: var(--char); color: var(--off); padding: clamp(3.5rem,8vw,6rem) 0 2.5rem; }
.foot-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; }
.foot-brand img { height: 30px; width: auto; margin-bottom: 1.2rem; }
.foot-brand p { color: #9a9a99; font-size: .88rem; max-width: 26ch; }
.foot-col h2 { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: #8c8c8a; margin-bottom: 1.1rem; font-weight: 500; }
.foot-col a, .foot-col span { display: block; padding: .35rem 0; font-size: .9rem; color: #d6d6d4; }
.foot-col a:hover { color: #fff; }
.foot-col a:focus-visible { outline-color: #fff; }
.foot-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin-top: clamp(2.5rem,6vw,4rem); padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.12); font-size: .68rem; letter-spacing: .06em; color: #8c8c8a; }

/* ============ Home ============ */
.hero { border-bottom: 1px solid var(--line); padding: clamp(1.4rem,2.5vw,2.2rem) 0 0; }
.hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; }
.hero-text { padding: 0 clamp(2rem,4vw,3.5rem) clamp(2rem,4vw,3.4rem) 0; display: flex; flex-direction: column; }
.hero-logo { height: clamp(52px,6.5vw,90px); width: auto; align-self: flex-start; margin-bottom: clamp(1.6rem,3vw,2.4rem); }
.hero-text .label { margin-bottom: 1rem; }
.hero h1 { font-weight: 300; font-size: clamp(2.6rem,5.5vw,4.8rem); line-height: 1.04; letter-spacing: -.025em; }
.hero .lede { color: var(--char-soft); max-width: 40ch; margin: 1.4rem 0 2rem; }
.hero .meta { display: flex; gap: 2.5rem; flex-wrap: wrap; margin-top: clamp(1.8rem,3.5vw,2.6rem); padding-top: 1.8rem; border-top: 1px solid var(--line); }
.hero .meta .k { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--char-soft); display: block; margin-bottom: .3rem; }
.hero .meta .v { font-size: .95rem; }
.hero-fig { border-left: 1px solid var(--line); }
.hero-fig .ph { height: 100%; min-height: 27rem; }

/* Shop band (online roaster, single path) */
.paths { border-bottom: 1px solid var(--line); padding: clamp(2.2rem,4vw,3.2rem) 0; }
.shopband { display: flex; flex-direction: column; align-items: flex-start; gap: 1.5rem; }
.shopband .no { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--char-soft); font-variant-numeric: tabular-nums; }
.shopband h2 { font-weight: 300; font-size: clamp(1.6rem,3.2vw,2.3rem); letter-spacing: -.01em; margin: 1rem 0 .8rem; }
.shopband p { color: var(--char-soft); font-size: .98rem; max-width: 54ch; }

/* Beans teaser + shop cards (shared grid) */
.shop-grid { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line); }
.prod { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: clamp(1.4rem,3vw,2.2rem); background: var(--grey); transition: background .3s; }
.prod:nth-child(3n) { border-right: 0; }
.prod:hover { background: var(--off); }
.prod .ph { aspect-ratio: 1/1; margin-bottom: 1.4rem; }
.prod .top { display: flex; justify-content: space-between; align-items: baseline; }
.prod .roast { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--char-soft); }
.prod .no { font-size: .62rem; color: var(--char-soft); font-variant-numeric: tabular-nums; }
.prod h3 { font-weight: 400; font-size: 1.35rem; margin: .8rem 0 .3rem; letter-spacing: -.01em; }
.prod p { color: var(--char-soft); font-size: .88rem; }
.prod .pf { display: flex; justify-content: space-between; align-items: baseline; margin-top: 1.4rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.prod .price { font-size: 1.05rem; font-variant-numeric: tabular-nums; }
.prod .price::before { content: "$"; color: var(--char-soft); font-size: .8em; margin-right: .1em; }
.add { font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; border-bottom: 1px solid var(--line-strong); transition: border-color .2s; }
.prod:hover .add { border-color: var(--char); }
.add::after { content: " +"; }

/* Story teaser / About split */
.story { background: var(--off); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem,6vw,5rem); align-items: center; }
.story h2 { font-weight: 300; font-size: clamp(1.8rem,4vw,2.8rem); line-height: 1.15; letter-spacing: -.01em; margin: 1rem 0 1.4rem; }
.story p { color: var(--char-soft); margin-bottom: 1rem; max-width: 46ch; }
.story .ph { height: clamp(20rem,30vw,26rem); }
.story .go { display: inline-block; margin-top: 1rem; font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; border-bottom: 1px solid var(--char); padding-bottom: .25rem; }
.story .go::after { content: " \2192"; }

/* ============ Shop feature ============ */
.menu-feature { margin: 0 0 clamp(3rem,7vw,5rem); }
.menu-feature .ph { aspect-ratio: 5/2; min-height: 16rem; }

/* ============ About ============ */
.lead-statement { font-weight: 300; font-size: clamp(1.6rem,4vw,2.8rem); line-height: 1.22; letter-spacing: -.01em; max-width: 24ch; }
.lead-statement em { font-style: italic; color: var(--char-soft); }
.prose { max-width: 60ch; }
.prose p { color: var(--char-soft); margin-bottom: 1.2rem; }
.principles { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line); }
.principle { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: clamp(1.6rem,3.5vw,2.4rem); }
.principle:nth-child(3n) { border-right: 0; }
.principle .no { font-size: .64rem; letter-spacing: .2em; text-transform: uppercase; color: var(--char-soft); font-variant-numeric: tabular-nums; display: block; margin-bottom: 1.2rem; }
.principle h3 { font-weight: 500; font-size: 1.15rem; margin-bottom: .6rem; }
.principle p { color: var(--char-soft); font-size: .9rem; }
.wide-fig { margin-top: clamp(3rem,7vw,5rem); }
.wide-fig .ph { aspect-ratio: 16/7; min-height: 16rem; }

/* Split feature (text + portrait), reused on About */
.feat h2 { font-weight: 300; font-size: clamp(1.8rem,4vw,2.6rem); letter-spacing: -.01em; line-height: 1.15; margin: 1rem 0 1.4rem; }
.feat p { color: var(--char-soft); max-width: 46ch; margin-bottom: 1rem; }
.feat .go { display: inline-block; margin-top: .6rem; font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500; border-bottom: 1px solid var(--char); padding-bottom: .25rem; }
.feat .go::after { content: " \2192"; }
.feat .ph { height: clamp(16rem,24vw,21rem); }

/* ============ Contact ============ */
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2.5rem,6vw,5rem); align-items: start; }
.contact-detail { margin-bottom: 2.2rem; }
.contact-detail h2 { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--char-soft); font-weight: 500; margin-bottom: .8rem; }
.contact-detail p, .contact-detail a { font-size: 1.05rem; display: block; }
.contact-detail a { border-bottom: 1px solid var(--line-strong); width: fit-content; padding-bottom: .15rem; transition: border-color .2s; }
.contact-detail a:hover { border-color: var(--char); }
.contact-detail .muted { display: block; color: var(--char-soft); font-size: .9rem; margin-top: .4rem; max-width: 38ch; }
.contact-aside .ph { height: clamp(16rem,24vw,21rem); }
.contact-aside h2 { font-weight: 300; font-size: clamp(1.5rem,3vw,2.1rem); letter-spacing: -.01em; margin: 1.4rem 0 .8rem; }
.contact-aside p { color: var(--char-soft); max-width: 36ch; margin-bottom: 1.4rem; }
.contact-note { margin-top: 1.4rem; font-size: .78rem; color: var(--char-soft); letter-spacing: .02em; }

/* ============ 404 ============ */
.nf { min-height: 60vh; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; }
.nf .label { margin-bottom: 1.4rem; }
.nf h1 { font-weight: 300; font-size: clamp(2.4rem,6vw,4rem); letter-spacing: -.02em; margin-bottom: 1.4rem; }
.nf p { color: var(--char-soft); max-width: 40ch; margin-bottom: 2rem; }

/* ============ Responsive ============ */
@media (max-width: 880px) {
	.nav-links {
		position: absolute; top: 100%; left: 1.5rem; right: 1.5rem; background: var(--grey);
		border: 1px solid var(--line); border-top: 0; flex-direction: column; align-items: stretch;
		gap: 0; padding: .5rem 1.4rem; display: none;
	}
	.nav-links.open { display: flex; }
	.nav-links a { padding: 1rem 0; width: 100%; border-bottom: 1px solid var(--line); }
	.nav-links li:last-child a { border-bottom: 0; }
	.nav-links a[aria-current="page"]::after { display: none; }
	.nav-toggle { display: block; }

	.hero-grid { grid-template-columns: 1fr; min-height: 0; }
	.hero-text { padding-right: 0; padding-top: clamp(2rem,5vw,3rem); justify-content: flex-start; }
	.hero-fig { border-left: 0; border-top: 1px solid var(--line); }
	.hero-fig .ph { min-height: 20rem; }


	.shop-grid { grid-template-columns: 1fr; }
	.story-grid { grid-template-columns: 1fr; }
	.principles { grid-template-columns: 1fr; }
	.prod, .principle { border-right: 0; }
	.contact-grid { grid-template-columns: 1fr; }
	.foot-top { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
	.sec-head .meta-r { display: none; }
}

@media (max-width: 460px) {
	.hero .meta { gap: 1.4rem 2rem; }
	.foot-top { grid-template-columns: 1fr; gap: 2rem; }
	.btn { width: 100%; text-align: center; }
	.actions { gap: .8rem; }
}
