/* /css/styles.css */
:root{
	--espresso:#4B2E2A;
	--caramel:#C8772E;
	--mint:#3DBF9E;
	--paper:#FBF7F0;
	--ink:#241A17;

	--fraunces:"Fraunces", ui-serif, Georgia, serif;
	--nunito:"Nunito", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

	--hero: clamp(2.5rem, 6vw, 4.5rem);
	--h2: clamp(1.75rem, 3.5vw, 2.75rem);
	--h3: clamp(1.15rem, 1.6vw, 1.35rem);
	--body: 1.0625rem;

	--r-xs: 10px;
	--r-sm: 14px;
	--r-md: 18px;
	--r-lg: 26px;

	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 20px;
	--space-6: 24px;
	--space-7: 28px;
	--space-8: 32px;
	--space-9: 36px;
	--space-10: 40px;
	--space-11: 48px;
	--space-12: 56px;
	--space-13: 64px;
	--space-14: 72px;
	--space-15: 80px;
	--space-16: 96px;
	--space-17: 112px;

	--shadow-1: 0 10px 30px rgba(36,26,23,.08);
	--shadow-2: 0 18px 60px rgba(36,26,23,.12);
	--shadow-3: 0 26px 90px rgba(36,26,23,.14);

	--ease: cubic-bezier(.2,.8,.2,1);
	--dur: 320ms;

	--max: 1180px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
	margin:0;
	font-family:var(--nunito);
	font-size:var(--body);
	line-height:1.6;
	color:var(--ink);
	background:
		radial-gradient(1100px 700px at 15% 12%, rgba(200,119,46,.13), transparent 60%),
		radial-gradient(900px 600px at 80% 8%, rgba(61,191,158,.10), transparent 55%),
		linear-gradient(180deg, var(--paper), #fff 60%, var(--paper));
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
p{ margin:0; }
h1,h2,h3{ margin:0; font-family:var(--fraunces); letter-spacing:-0.02em; }
h2{ font-size:var(--h2); line-height:1.06; }
h3{ font-size:var(--h3); line-height:1.15; }
strong{ font-weight:800; }

.container{
	width: min(var(--max), calc(100% - 2 * var(--space-6)));
	margin-inline:auto;
}

.skip-link{
	position:absolute;
	left: -999px;
	top: var(--space-4);
	padding: var(--space-3) var(--space-4);
	background: #fff;
	border: 2px solid rgba(36,26,23,.22);
	border-radius: var(--r-sm);
	box-shadow: var(--shadow-1);
	z-index: 9999;
}
.skip-link:focus{ left: var(--space-6); }

.site-header{
	position: sticky;
	top: 0;
	z-index: 50;
	backdrop-filter: blur(14px);
	background: rgba(251,247,240,.78);
	border-bottom: 1px solid rgba(36,26,23,.10);
}
.header-inner{
	display:flex;
	align-items:center;
	justify-content:space-between;
	gap: var(--space-4);
	padding: var(--space-4) 0;
}

.brand{
	display:flex;
	align-items:center;
	gap: var(--space-3);
	min-width: 220px;
}
.brand-mark{
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background:
		radial-gradient(12px 12px at 30% 28%, rgba(255,255,255,.55), transparent 60%),
		linear-gradient(135deg, rgba(200,119,46,.45), rgba(75,46,42,.78));
	color: #fff;
	box-shadow: 0 10px 22px rgba(36,26,23,.16);
	display:grid;
	place-items:center;
}
.brand-mark svg{ width: 26px; height: 26px; }

.brand-name{
	display:block;
	font-family: var(--fraunces);
	font-weight: 600;
	letter-spacing: -0.03em;
}
.brand-tag{
	display:block;
	font-size: 0.9rem;
	color: rgba(36,26,23,.72);
	margin-top: 1px;
}

.nav{
	display:none;
	align-items:center;
	gap: var(--space-5);
}
.nav-link{
	position:relative;
	font-size: 0.98rem;
	color: rgba(36,26,23,.84);
	padding: var(--space-2) 0;
	transition: color var(--dur) var(--ease);
}
.nav-link::after{
	content:"";
	position:absolute;
	left: 0;
	right: 0;
	bottom: -2px;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--caramel), transparent);
	transform: scaleX(0);
	transform-origin: center;
	transition: transform var(--dur) var(--ease);
}
.nav-link:hover{ color: rgba(36,26,23,.98); }
.nav-link:hover::after{ transform: scaleX(1); }
.nav-link:focus-visible{
	outline: 2px solid rgba(61,191,158,.6);
	outline-offset: 6px;
	border-radius: 10px;
}

.btn{
	display:inline-flex;
	align-items:center;
	justify-content:center;
	gap: var(--space-2);
	padding: 12px 16px;
	border-radius: 999px;
	border: 1px solid rgba(36,26,23,.16);
	background: rgba(255,255,255,.65);
	color: rgba(36,26,23,.92);
	box-shadow: 0 16px 40px rgba(36,26,23,.10);
	transition:
		transform var(--dur) var(--ease),
		box-shadow var(--dur) var(--ease),
		background var(--dur) var(--ease),
		border-color var(--dur) var(--ease);
}
.btn:hover{
	transform: translateY(-1px);
	box-shadow: 0 22px 60px rgba(36,26,23,.14);
	border-color: rgba(36,26,23,.22);
}
.btn:active{ transform: translateY(0px); }
.btn:focus-visible{
	outline: 2px solid rgba(61,191,158,.7);
	outline-offset: 6px;
}
.btn-sm{ padding: 10px 14px; font-size: 0.95rem; }

.btn-accent{
	background: linear-gradient(135deg, rgba(61,191,158,.92), rgba(61,191,158,.76));
	border-color: rgba(61,191,158,.22);
	color: #072a22;
	box-shadow: 0 20px 55px rgba(61,191,158,.20);
}
.btn-accent:hover{ box-shadow: 0 28px 76px rgba(61,191,158,.26); }

.btn-ghost{
	background: rgba(255,255,255,0);
	border-color: rgba(36,26,23,.18);
	box-shadow: none;
}
.btn-ghost:hover{
	background: rgba(255,255,255,.55);
	box-shadow: 0 18px 45px rgba(36,26,23,.10);
}

.hero{
	position:relative;
	padding: var(--space-12) 0 var(--space-10);
	overflow:hidden;
}
.hero::before{
	content:"";
	position:absolute;
	inset: -120px;
	background:
		radial-gradient(800px 480px at 18% 18%, rgba(200,119,46,.20), transparent 62%),
		radial-gradient(980px 560px at 78% 10%, rgba(61,191,158,.14), transparent 60%),
		radial-gradient(880px 560px at 60% 70%, rgba(75,46,42,.12), transparent 60%);
	filter: blur(0px);
	pointer-events:none;
}

.hero-grid{
	position:relative;
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items:start;
}

/* Hero fitting guards (prevents overflow and weird compression) */
.hero-copy,
.hero-visual{ min-width: 0; }

.hero-copy{ max-width: 58ch; }

.eyebrow{
	display:inline-flex;
	align-items:center;
	gap: var(--space-2);
	font-weight: 600;
	color: rgba(36,26,23,.78);
}
.eyebrow::before{
	content:"";
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background:
		radial-gradient(circle at 30% 30%, #fff, rgba(255,255,255,0) 65%),
		linear-gradient(135deg, rgba(200,119,46,.95), rgba(75,46,42,.85));
	box-shadow: 0 10px 20px rgba(36,26,23,.14);
}

.hero-title{
	font-size: var(--hero);
	line-height: 0.96;
	margin-top: var(--space-4);
	color: rgba(36,26,23,.98);
}
.hero-lede{
	margin-top: var(--space-5);
	font-size: 1.18rem;
	color: rgba(36,26,23,.86);
}
.lede-soft{
	display:inline-block;
	margin-top: var(--space-2);
	color: rgba(36,26,23,.70);
}
.hero-ctas{
	margin-top: var(--space-6);
	display:flex;
	flex-wrap:wrap;
	gap: var(--space-3);
}

/* Mobile overflow fix: badges stack on small screens */
.hero-badges{
	list-style:none;
	padding:0;
	margin: var(--space-7) 0 0;
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-3);
}

@media (min-width: 520px){
	.hero-badges{
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.badge{
	border-radius: var(--r-md);
	padding: var(--space-4);
	background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.52));
	border: 1px solid rgba(36,26,23,.10);
	box-shadow: var(--shadow-1);
	min-width: 0;
}
.badge-kicker{
	display:block;
	font-size: 0.92rem;
	color: rgba(36,26,23,.72);
}
.badge-value{
	display:block;
	font-family: var(--fraunces);
	font-weight: 600;
	letter-spacing: -0.02em;
	margin-top: 2px;
	overflow-wrap: anywhere;
	word-break: break-word;
	hyphens: auto;
}

.hero-visual{ position:relative; }

.hero-card{
	border-radius: calc(var(--r-lg) + 8px);
	background: linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.52));
	border: 1px solid rgba(36,26,23,.12);
	box-shadow: var(--shadow-3);
	padding: var(--space-4);
	position:relative;
	max-width: 100%;
}

.image-slot{
	position:relative;
	width: 100%;
	max-width: 100%;
	border-radius: var(--r-lg);
	overflow:hidden;
	background: linear-gradient(135deg, rgba(200,119,46,.18), rgba(75,46,42,.10) 50%, rgba(61,191,158,.16));
	border: 1px solid rgba(36,26,23,.12);
	isolation:isolate;
}
.image-slot img{
	position:absolute;
	inset:0;
	width:100%;
	height:100%;
	object-fit:cover;
	z-index:2;
	transition: transform 900ms var(--ease), filter var(--dur) var(--ease);
}
.image-slot:hover img{ transform: scale(1.02); }

.image-placeholder{
	position:absolute;
	inset:0;
	display:flex;
	flex-direction:column;
	justify-content:space-between;
	padding: var(--space-5);
	z-index:1;
	color: rgba(36,26,23,.78);
	background:
		radial-gradient(300px 180px at 22% 18%, rgba(255,255,255,.35), transparent 64%),
		linear-gradient(135deg, rgba(200,119,46,.18), rgba(75,46,42,.12) 55%, rgba(61,191,158,.16));
}
.ph-top{
	display:flex;
	gap: var(--space-2);
	flex-wrap:wrap;
}
.ph-chip{
	font-size: 0.88rem;
	font-weight: 700;
	padding: 8px 10px;
	border-radius: 999px;
	background: rgba(251,247,240,.85);
	border: 1px solid rgba(36,26,23,.14);
	box-shadow: 0 16px 35px rgba(36,26,23,.12);
}
.ph-path{
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
	font-size: 0.95rem;
	line-height:1.25;
	background: rgba(255,255,255,.55);
	border: 1px solid rgba(36,26,23,.12);
	border-radius: var(--r-md);
	padding: var(--space-3) var(--space-4);
	box-shadow: 0 18px 45px rgba(36,26,23,.12);
}
.is-missing{ opacity:0; }

.image-slot-hero{ aspect-ratio: 4 / 5; }

.steam{
	position:absolute;
	right: -22px;
	top: -34px;
	width: 180px;
	height: auto;
	color: rgba(200,119,46,.92);
	z-index:3;
	filter: drop-shadow(0 20px 40px rgba(36,26,23,.18));
	pointer-events:none;
}

.hero-note{
	margin-top: var(--space-4);
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
	padding: var(--space-4) var(--space-5);
	border-radius: var(--r-lg);
	background:
		radial-gradient(220px 140px at 30% 35%, rgba(61,191,158,.10), transparent 70%),
		linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.50));
	border: 1px solid rgba(36,26,23,.10);
}
.hero-note-title{
	font-family: var(--fraunces);
	font-weight: 600;
	letter-spacing: -0.02em;
}
.hero-note-body{ color: rgba(36,26,23,.76); }

.hero-ribbon{
	margin-top: var(--space-6);
	border-radius: var(--r-lg);
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.62);
	box-shadow: var(--shadow-2);
	padding: var(--space-3) var(--space-4);
	overflow:hidden;
}
.ribbon-hint{
	margin-top: var(--space-2);
	font-size: 0.92rem;
	color: rgba(36,26,23,.64);
}

.marquee{
	position:relative;
	overflow:hidden;
	border-radius: 999px;
	background: linear-gradient(90deg, rgba(75,46,42,.08), rgba(200,119,46,.10), rgba(61,191,158,.10));
	border: 1px solid rgba(36,26,23,.10);
}
.marquee::before,
.marquee::after{
	content:"";
	position:absolute;
	top:0;
	bottom:0;
	width: 72px;
	pointer-events:none;
	z-index: 3;
}
.marquee::before{
	left:0;
	background: linear-gradient(90deg, rgba(251,247,240,.96), rgba(251,247,240,0));
}
.marquee::after{
	right:0;
	background: linear-gradient(270deg, rgba(251,247,240,.96), rgba(251,247,240,0));
}
.marquee-track{
	display:flex;
	gap: var(--space-4);
	white-space:nowrap;
	padding: 12px 14px;
	animation: marquee 22s linear infinite;
	will-change: transform;
	color: rgba(36,26,23,.86);
	font-weight: 700;
}
.marquee:hover .marquee-track{ animation-duration: 14s; }

.sep{ color: rgba(200,119,46,.85); }

@keyframes marquee{
	from{ transform: translateX(0); }
	to{ transform: translateX(-50%); }
}

.hero-bottom{ margin-top: var(--space-10); }
.hero-bottom-inner{
	display:flex;
	flex-direction:column;
	gap: var(--space-4);
	align-items:flex-start;
}
.microcopy{
	display:flex;
	align-items:flex-start;
	gap: var(--space-3);
	color: rgba(36,26,23,.74);
	max-width: 72ch;
}
.icon{ width: 22px; height: 22px; color: var(--caramel); margin-top: 3px; }

.signal{
	display:flex;
	flex-wrap:wrap;
	gap: var(--space-3);
}
.signal-item{
	padding: var(--space-3) var(--space-4);
	border-radius: 999px;
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.60);
	box-shadow: 0 14px 34px rgba(36,26,23,.10);
}
.signal-num{
	font-weight: 800;
	letter-spacing: -0.02em;
}
.signal-label{
	display:block;
	font-size: 0.92rem;
	color: rgba(36,26,23,.66);
	margin-top: 1px;
}

.section{ padding: var(--space-16) 0; }
.section-head{ max-width: 70ch; }

.kicker{
	display:inline-block;
	font-weight: 800;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	font-size: 0.82rem;
	color: rgba(36,26,23,.72);
	padding: 8px 12px;
	border-radius: 999px;
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.55);
	box-shadow: 0 14px 34px rgba(36,26,23,.10);
}
.section-head h2{ margin-top: var(--space-4); }
.subhead{
	margin-top: var(--space-4);
	color: rgba(36,26,23,.76);
	font-size: 1.12rem;
}

.section-menu{ position:relative; }
.menu-grid{
	margin-top: var(--space-10);
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}
.menu-card{
	border-radius: calc(var(--r-lg) + 6px);
	padding: var(--space-6);
	border: 1px solid rgba(36,26,23,.12);
	background:
		radial-gradient(400px 240px at 18% 10%, rgba(200,119,46,.10), transparent 70%),
		linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.52));
	box-shadow: var(--shadow-2);
}
.menu-card-head{
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
}
.menu-card-note{ color: rgba(36,26,23,.70); }

.menu-list{
	list-style:none;
	padding:0;
	margin: var(--space-6) 0 0;
	display:flex;
	flex-direction:column;
	gap: var(--space-4);
}
.menu-item{
	padding-top: var(--space-4);
	border-top: 1px dashed rgba(36,26,23,.18);
}
.menu-item-top{
	display:flex;
	align-items:baseline;
	justify-content:space-between;
	gap: var(--space-3);
}
.menu-name{ font-weight: 800; letter-spacing: -0.01em; }
.menu-price{
	font-family: var(--fraunces);
	font-weight: 600;
	color: rgba(36,26,23,.82);
	font-variant-numeric: oldstyle-nums;
}
.menu-desc{ margin-top: var(--space-2); color: rgba(36,26,23,.74); }

.menu-foot{ margin-top: var(--space-8); }
.menu-foot-line{
	display:flex;
	flex-direction:column;
	gap: var(--space-3);
	align-items:flex-start;
	padding: var(--space-6);
	border-radius: calc(var(--r-lg) + 6px);
	border: 1px solid rgba(36,26,23,.12);
	background: linear-gradient(135deg, rgba(61,191,158,.12), rgba(255,255,255,.60) 55%, rgba(200,119,46,.12));
	box-shadow: var(--shadow-2);
}
.menu-foot-copy{ color: rgba(36,26,23,.76); }

.section-roast .split{
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items:start;
}
.body{
	margin-top: var(--space-4);
	color: rgba(36,26,23,.78);
	max-width: 70ch;
}

.pillars{
	margin-top: var(--space-7);
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}
.pillar{
	padding: var(--space-5);
	border-radius: var(--r-lg);
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.56);
	box-shadow: var(--shadow-1);
}
.pillar p{ margin-top: var(--space-2); color: rgba(36,26,23,.74); }

.split-media{
	position:relative;
	display:grid;
	gap: var(--space-4);
}
.image-slot-story{ aspect-ratio: 4 / 3; }

.story-card{
	border-radius: var(--r-lg);
	border: 1px solid rgba(36,26,23,.12);
	background:
		radial-gradient(320px 220px at 15% 35%, rgba(200,119,46,.12), transparent 70%),
		linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.52));
	box-shadow: var(--shadow-2);
	padding: var(--space-6);
}
.story-card-title{
	font-family: var(--fraunces);
	font-weight: 600;
	letter-spacing: -0.02em;
}
.story-card-body{ margin-top: var(--space-3); color: rgba(36,26,23,.76); }
.story-card-tags{
	margin-top: var(--space-4);
	display:flex;
	flex-wrap:wrap;
	gap: var(--space-2);
}
.tag{
	font-size: 0.92rem;
	font-weight: 800;
	color: rgba(36,26,23,.78);
	padding: 8px 10px;
	border-radius: 999px;
	border: 1px solid rgba(36,26,23,.14);
	background: rgba(251,247,240,.85);
}

.steam-divider{
	margin-top: var(--space-12);
	color: rgba(75,46,42,.55);
}

.section-visit .visit-grid{
	margin-top: var(--space-10);
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
	align-items:start;
}
.visit-card{
	border-radius: calc(var(--r-lg) + 6px);
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.62);
	box-shadow: var(--shadow-2);
	padding: var(--space-6);
}

.hours{
	list-style:none;
	padding:0;
	margin: var(--space-5) 0 0;
	display:flex;
	flex-direction:column;
	gap: var(--space-3);
}
.hours li{
	display:flex;
	justify-content:space-between;
	gap: var(--space-3);
	padding: 10px 12px;
	border-radius: var(--r-sm);
	border: 1px solid rgba(36,26,23,.10);
	background: rgba(251,247,240,.70);
}
.hours span:first-child{ font-weight: 800; }
.hours span:last-child{ font-family: var(--fraunces); font-weight: 600; }

.visit-meta{
	margin-top: var(--space-5);
	display:grid;
	gap: var(--space-4);
	color: rgba(36,26,23,.74);
}
.muted{ color: rgba(36,26,23,.62); }

.visit-map .map-frame{
	position:relative;
	border-radius: calc(var(--r-lg) + 6px);
	border: 1px solid rgba(36,26,23,.12);
	overflow:hidden;
	background: linear-gradient(135deg, rgba(200,119,46,.14), rgba(75,46,42,.10), rgba(61,191,158,.12));
	box-shadow: var(--shadow-2);
	aspect-ratio: 16 / 10;
}
.visit-map iframe{
	position:absolute;
	inset:0;
	width:100%;
	height:100%;
	border:0;
	filter: saturate(1.05) contrast(1.02);
}
.map-overlay{
	position:absolute;
	inset:0;
	pointer-events:none;
	display:flex;
	align-items:flex-end;
	justify-content:flex-start;
	padding: var(--space-4);
	background: linear-gradient(180deg, rgba(251,247,240,0), rgba(251,247,240,.72));
}
.map-label{
	padding: var(--space-3) var(--space-4);
	border-radius: var(--r-md);
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.72);
	box-shadow: 0 20px 55px rgba(36,26,23,.14);
}
.map-title{ font-weight: 900; letter-spacing:-0.01em; }
.map-sub{ font-size: 0.95rem; color: rgba(36,26,23,.68); margin-top: 2px; }
.map-note{ margin-top: var(--space-3); color: rgba(36,26,23,.70); }

.visit-photos{
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-4);
}
.image-slot-interior{ aspect-ratio: 3 / 2; }
.image-slot-pastry{ aspect-ratio: 4 / 3; }

.section-beans .beans-grid{
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items:start;
}
.cta-row{
	margin-top: var(--space-6);
	display:flex;
	flex-wrap:wrap;
	gap: var(--space-3);
}
.fineprint{
	margin-top: var(--space-4);
	color: rgba(36,26,23,.62);
	font-size: 0.95rem;
}

.beans-media{
	display:grid;
	gap: var(--space-4);
}
.image-slot-bag{ aspect-ratio: 4 / 5; }

.beans-spec{
	display:grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-3);
}
.spec{
	padding: var(--space-4);
	border-radius: var(--r-md);
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(255,255,255,.58);
	box-shadow: var(--shadow-1);
}
.spec-k{
	display:block;
	font-size: 0.9rem;
	color: rgba(36,26,23,.66);
}
.spec-v{
	display:block;
	font-weight: 900;
	letter-spacing:-0.01em;
	margin-top: 2px;
}

.insta-strip{ margin-top: var(--space-14); }
.insta-head{
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
}
.insta-grid{
	margin-top: var(--space-6);
	display:grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-3);
}
.image-slot-insta{
	border-radius: var(--r-md);
	aspect-ratio: 1 / 1;
}
.insta-foot{
	margin-top: var(--space-6);
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
}

.link-accent{
	display:inline-flex;
	align-items:center;
	gap: var(--space-2);
	font-weight: 900;
	color: rgba(36,26,23,.90);
	position:relative;
	width: fit-content;
}
.link-accent::after{
	content:"";
	position:absolute;
	left:0;
	right:0;
	bottom:-4px;
	height: 2px;
	background: linear-gradient(90deg, var(--mint), var(--caramel));
	transform: scaleX(0);
	transform-origin:left;
	transition: transform var(--dur) var(--ease);
}
.link-accent:hover::after{ transform: scaleX(1); }
.link-arrow{ color: var(--mint); }

.section-contact .contact-card{
	border-radius: calc(var(--r-lg) + 10px);
	border: 1px solid rgba(36,26,23,.12);
	background:
		radial-gradient(520px 320px at 20% 20%, rgba(61,191,158,.12), transparent 70%),
		radial-gradient(520px 320px at 80% 70%, rgba(200,119,46,.14), transparent 72%),
		linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.52));
	box-shadow: var(--shadow-3);
	padding: var(--space-8);
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-8);
}
.contact-item{
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
	padding: var(--space-4);
	border-radius: var(--r-md);
	border: 1px solid rgba(36,26,23,.12);
	background: rgba(251,247,240,.62);
}
.contact-k{
	font-size: 0.9rem;
	color: rgba(36,26,23,.66);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.03em;
}
.contact-v{ font-weight: 900; letter-spacing: -0.01em; }
.contact-actions{
	margin-top: var(--space-4);
	display:flex;
	flex-wrap:wrap;
	gap: var(--space-3);
}

.site-footer{
	padding: var(--space-14) 0 var(--space-8);
	background:
		radial-gradient(1000px 700px at 20% -10%, rgba(200,119,46,.12), transparent 60%),
		linear-gradient(180deg, rgba(75,46,42,.98), rgba(36,26,23,.98));
	color: rgba(251,247,240,.92);
}
.footer-inner{
	display:grid;
	grid-template-columns: 1fr;
	gap: var(--space-10);
	align-items:start;
}
.footer-note{
	margin-top: var(--space-5);
	color: rgba(251,247,240,.76);
	max-width: 60ch;
}

.badge-logo{
	width: 220px;
	height: 220px;
	position:relative;
}
.badge-ring{
	position:absolute;
	inset:0;
	border-radius: 50%;
	background: conic-gradient(from 210deg, rgba(61,191,158,.75), rgba(200,119,46,.92), rgba(61,191,158,.75));
	filter: blur(0px);
	opacity: 0.85;
}
.badge-center{
	position:absolute;
	inset: 10px;
	border-radius: 50%;
	background:
		radial-gradient(120px 120px at 35% 30%, rgba(255,255,255,.10), transparent 60%),
		linear-gradient(180deg, rgba(36,26,23,.96), rgba(75,46,42,.96));
	border: 1px solid rgba(251,247,240,.16);
	display:grid;
	place-items:center;
	text-align:center;
	padding: var(--space-5);
}
.badge-cup svg{ width: 46px; height: 46px; color: rgba(251,247,240,.95); }
.badge-text{
	margin-top: var(--space-3);
	display:flex;
	flex-direction:column;
	gap: 6px;
	font-family: var(--fraunces);
	letter-spacing: -0.02em;
}
.badge-top{ font-weight: 600; }
.badge-mid{ font-size: 0.98rem; opacity: 0.92; }
.badge-bot{ font-size: 0.98rem; opacity: 0.88; }

.footer-links{
	display:grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--space-8);
}
.footer-col{
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
}
.footer-title{
	font-family: var(--fraunces);
	font-weight: 600;
	letter-spacing: -0.02em;
	margin-bottom: var(--space-2);
}
.footer-col a{
	color: rgba(251,247,240,.78);
	padding: 6px 0;
	transition: color var(--dur) var(--ease);
}
.footer-col a:hover{ color: rgba(251,247,240,.96); }
.footer-col a:focus-visible{
	outline: 2px solid rgba(61,191,158,.70);
	outline-offset: 6px;
	border-radius: 10px;
}

.footer-bottom{
	margin-top: var(--space-10);
	padding-top: var(--space-6);
	border-top: 1px solid rgba(251,247,240,.16);
	display:flex;
	flex-direction:column;
	gap: var(--space-2);
	color: rgba(251,247,240,.72);
}
.credit{ color: rgba(251,247,240,.62); }

.reveal{ will-change: transform, opacity; }

/* Visibility safety: content is visible by default */
.js .reveal{
	opacity:0;
	transform: translateY(14px);
}
.js .reveal.is-visible{
	opacity:1;
	transform: translateY(0);
	transition: opacity 700ms var(--ease), transform 700ms var(--ease);
}

@media (prefers-reduced-motion: reduce){
	html{ scroll-behavior:auto; }
	.js .reveal{ opacity:1; transform:none; }
	.marquee-track{ animation: none; }
	.image-slot img{ transition:none; }
}

/* Desktop layout upgrades */
@media (min-width: 900px){
	.nav{ display:flex; }
	.hero{ padding: var(--space-14) 0 var(--space-12); }

	.hero-grid{
		grid-template-columns: 1.1fr .9fr;
		gap: var(--space-12);
		align-items:start;
	}

	.hero-bottom-inner{
		flex-direction:row;
		align-items:center;
		justify-content:space-between;
		gap: var(--space-8);
	}

	.menu-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }

	.menu-foot-line{
		flex-direction:row;
		align-items:center;
		justify-content:space-between;
	}

	.section-roast .split{
		grid-template-columns: 1.05fr .95fr;
		align-items:start;
	}

	.section-visit .visit-grid{
		grid-template-columns: 0.9fr 1.1fr;
		grid-template-areas:
			"card map"
			"photos map";
	}
	.visit-card{ grid-area: card; }
	.visit-map{ grid-area: map; }
	.visit-photos{ grid-area: photos; grid-template-columns: 1fr 1fr; }

	.section-beans .beans-grid{
		grid-template-columns: 0.95fr 1.05fr;
		align-items:center;
	}

	.insta-grid{ grid-template-columns: repeat(6, minmax(0, 1fr)); }

	.footer-inner{ grid-template-columns: 0.95fr 1.05fr; }
	.footer-links{ grid-template-columns: repeat(3, minmax(0, 1fr)); }

	.footer-bottom{
		flex-direction:row;
		align-items:center;
		justify-content:space-between;
	}
}

/* Large screens */
@media (min-width: 1280px){
	.hero-card{ padding: var(--space-5); }
	.hero-note{ padding: var(--space-5) var(--space-6); }
}

/* Slightly condensed header when scrolling */
.site-header.is-compact .header-inner{ padding: var(--space-3) 0; }
.site-header.is-compact .brand-tag{ display:none; }

/* Optional tilt polish for pointer devices */
@media (hover:hover) and (pointer:fine){
	[data-tilt]{ transform-style: preserve-3d; }
}