/* =========================================================================
   Case — La Vela
   Italian restaurant. Terracotta, candlelight, sage.
   Type: DM Serif Display + DM Sans + Allura
   ========================================================================= */

.case--lavela {
	background: #1A0E07;
	color: #F2E4CF;
	font-family: 'DM Sans', sans-serif;
}

.lv-eyebrow {
	font-family: 'Allura', cursive;
	font-size: 1.6rem; line-height: 1;
	color: #D96C36;
	margin: 0 0 .4em;
	display: inline-block;
}
.lv-eyebrow--sage { color: #8FA76B; }

.lv-h2 {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	font-size: clamp(2rem, 4.4vw, 3.4rem);
	line-height: 1.05;
	letter-spacing: -.01em;
	margin: 0 0 .6em;
	color: #F2E4CF;
}
.lv-h2 em { font-style: italic; color: #D96C36; }

.lv-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 14px 26px;
	font-family: 'DM Sans', sans-serif; font-weight: 600;
	font-size: .96rem;
	border-radius: 999px; text-decoration: none;
	transition: transform .25s var(--ac-ease-out), background .25s, box-shadow .25s;
}
.lv-btn--pri {
	background: #D96C36; color: #1A0E07;
	box-shadow: 0 8px 24px -8px rgba(217,108,54,.5);
}
.lv-btn--pri:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -10px rgba(217,108,54,.7); }
.lv-btn--ghost {
	background: transparent; color: #F2E4CF;
	border: 1px solid rgba(242,228,207,.3);
}
.lv-btn--ghost:hover { border-color: #F2E4CF; transform: translateY(-2px); }

/* ---------- HERO ---------- */
.lv-hero {
	position: relative;
	padding: clamp(70px, 11vw, 150px) 0 clamp(60px, 9vw, 100px);
	overflow: hidden;
	background:
		radial-gradient(40% 60% at 70% 50%, rgba(217,108,54,.18), transparent 60%),
		radial-gradient(40% 60% at 30% 100%, rgba(242,199,126,.10), transparent 60%);
}
.lv-hero__warm {
	position: absolute; inset: 0;
	background:
		radial-gradient(circle at 50% 50%, rgba(242,199,126,.06), transparent 50%);
	pointer-events: none;
	animation: lv-flicker 5s ease-in-out infinite;
}
@keyframes lv-flicker { 0%,100%{ opacity: .85; } 50% { opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .lv-hero__warm { animation: none; } }

.lv-hero__inner {
	position: relative; z-index: 2;
	display: grid; grid-template-columns: 1.3fr 1fr;
	gap: 60px; align-items: center;
}
@media (max-width: 980px) { .lv-hero__inner { grid-template-columns: 1fr; } }

.lv-title {
	margin: 0 0 .4em;
	line-height: .85;
	display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap;
}
.lv-title__script {
	font-family: 'Allura', cursive;
	font-size: clamp(3rem, 8vw, 6rem);
	color: #D96C36;
	line-height: 1;
}
.lv-title__main {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	font-size: clamp(3.6rem, 11vw, 7.5rem);
	letter-spacing: -.02em;
	color: #F2E4CF;
}
.lv-tagline {
	max-width: 56ch;
	font-size: clamp(1rem, 1.4vw, 1.12rem);
	color: #C8B89C;
	line-height: 1.6;
	margin: 0 0 32px;
}
.lv-tagline em { font-style: italic; color: #F2C77E; }
.lv-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; }

/* ---------- Candle scene ---------- */
.lv-scene {
	position: relative;
	display: flex; align-items: flex-end; justify-content: center;
	gap: 30px;
	min-height: 380px;
}
.lv-bottle {
	position: relative;
	width: 90px;
	display: flex; flex-direction: column; align-items: center;
}
.lv-bottle__neck {
	width: 30px; height: 80px;
	background: linear-gradient(180deg, #2A1810 0%, #3A2114 100%);
	border-radius: 6px 6px 0 0;
	box-shadow: inset -4px 0 8px rgba(0,0,0,.4), inset 4px 0 8px rgba(255,255,255,.05);
}
.lv-bottle__body {
	width: 90px; height: 220px;
	background:
		linear-gradient(180deg, #3A2114 0%, #2A1810 30%, #1F0D08 100%);
	border-radius: 12px 12px 6px 6px;
	box-shadow:
		inset -8px 0 16px rgba(0,0,0,.4),
		inset 8px 0 16px rgba(255,255,255,.05),
		0 12px 30px -12px rgba(0,0,0,.6);
	position: relative;
	display: flex; align-items: center; justify-content: center;
}
.lv-bottle__label {
	width: 70px; padding: 20px 6px;
	background: linear-gradient(180deg, #F2E4CF 0%, #C8B89C 100%);
	border-radius: 2px;
	text-align: center;
	color: #1A0E07;
	box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.lv-bottle__label small {
	display: block;
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: .65rem;
	color: #8A5A2A;
	letter-spacing: .1em;
}
.lv-bottle__label strong {
	display: block;
	font-family: 'DM Serif Display', serif;
	font-size: 1.4rem;
	margin-top: 6px;
}

.lv-candle {
	position: relative;
	width: 50px;
	display: flex; flex-direction: column; align-items: center;
	margin-bottom: 12px;
}
.lv-candle__stick {
	width: 38px; height: 180px;
	background: linear-gradient(180deg, #F2E4CF 0%, #D9C9A8 100%);
	border-radius: 4px 4px 2px 2px;
	box-shadow:
		inset -4px 0 8px rgba(0,0,0,.1),
		inset 4px 0 8px rgba(255,255,255,.4);
	position: relative;
}
.lv-candle__stick::after {
	content: ''; position: absolute; top: 0; left: 5px; right: 5px; height: 6px;
	background: radial-gradient(ellipse, rgba(0,0,0,.2) 0%, transparent 70%);
}
.lv-candle__wick {
	position: absolute; top: -8px; left: 50%; transform: translateX(-50%);
	width: 2px; height: 10px;
	background: #1A0E07;
	z-index: 2;
}
.lv-candle__flame {
	position: absolute; top: -34px; left: 50%; transform: translateX(-50%);
	width: 16px; height: 26px;
	background: radial-gradient(ellipse at 50% 65%, #FFE680 0%, #F2C77E 35%, #D96C36 70%, transparent 100%);
	border-radius: 50% 50% 35% 35% / 60% 60% 40% 40%;
	filter: blur(.5px);
	animation: lv-flame 1.2s ease-in-out infinite;
	transform-origin: 50% 100%;
	z-index: 3;
}
@keyframes lv-flame {
	0%, 100% { transform: translateX(-50%) scale(1,1) skewX(0deg); }
	25%      { transform: translateX(-50%) scale(.95,1.05) skewX(2deg); }
	50%      { transform: translateX(-50%) scale(1.05,.95) skewX(-3deg); }
	75%      { transform: translateX(-50%) scale(.92,1.08) skewX(1deg); }
}
@media (prefers-reduced-motion: reduce) { .lv-candle__flame { animation: none; } }

.lv-candle__glow {
	position: absolute; top: -60px; left: 50%; transform: translateX(-50%);
	width: 200px; height: 200px;
	background: radial-gradient(circle, rgba(242,199,126,.4) 0%, rgba(217,108,54,.2) 30%, transparent 60%);
	border-radius: 50%;
	filter: blur(20px);
	animation: lv-glow 1.6s ease-in-out infinite;
	pointer-events: none;
	z-index: 1;
}
@keyframes lv-glow { 0%,100%{ opacity: .8; transform: translateX(-50%) scale(1); } 50% { opacity: 1; transform: translateX(-50%) scale(1.1); } }
@media (prefers-reduced-motion: reduce) { .lv-candle__glow { animation: none; } }

/* ---------- SECTIONS ---------- */
.lv-section {
	padding: clamp(70px, 10vw, 130px) 0;
	border-top: 1px solid rgba(217,108,54,.1);
}
.lv-split { display: grid; grid-template-columns: 1fr 1.3fr; gap: 60px; align-items: start; }
@media (max-width: 880px) { .lv-split { grid-template-columns: 1fr; gap: 24px; } }
.lv-split p {
	color: #C8B89C; margin: 0 0 1.2em; line-height: 1.65;
	max-width: 56ch; font-size: 1.05rem;
}
.lv-split p:last-child { margin-bottom: 0; }
.lv-split em { color: #F2C77E; font-style: italic; }

/* ---------- MENU ---------- */
.lv-section--menu {
	background:
		radial-gradient(80% 60% at 50% 0%, rgba(217,108,54,.10), transparent 60%),
		#100804;
}
.lv-menu {
	max-width: 900px; margin: 0 auto;
	background:
		linear-gradient(180deg, #F2E4CF 0%, #E8D8BC 100%);
	color: #1A0E07;
	padding: clamp(40px, 6vw, 70px) clamp(30px, 5vw, 60px);
	border-radius: 4px;
	box-shadow:
		0 30px 80px -30px rgba(0,0,0,.6),
		inset 0 0 0 1px rgba(0,0,0,.05);
	background-image:
		radial-gradient(circle at 20% 30%, rgba(217,108,54,.06) 0%, transparent 40%),
		radial-gradient(circle at 80% 70%, rgba(143,167,107,.04) 0%, transparent 40%);
}
.lv-menu__head { text-align: center; margin-bottom: 40px; }
.lv-menu__head small {
	font-family: 'Allura', cursive;
	font-size: 1.4rem; color: #D96C36;
	display: block; margin-bottom: 4px;
}
.lv-menu__head h3 {
	font-family: 'DM Serif Display', serif;
	font-weight: 400;
	font-size: clamp(1.6rem, 3.4vw, 2.6rem);
	margin: 0 0 18px;
	color: #1A0E07;
}
.lv-menu__rule {
	width: 80px; height: 1px;
	background: #1A0E07; margin: 0 auto;
	position: relative;
}
.lv-menu__rule::before, .lv-menu__rule::after {
	content: ''; position: absolute; top: 50%; transform: translateY(-50%);
	width: 4px; height: 4px; border-radius: 50%; background: #1A0E07;
}
.lv-menu__rule::before { left: -2px; } .lv-menu__rule::after { right: -2px; }

.lv-menu__cols {
	display: grid; grid-template-columns: 1fr 1fr; gap: 50px;
}
@media (max-width: 720px) { .lv-menu__cols { grid-template-columns: 1fr; gap: 30px; } }
.lv-menu__col h4 {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-weight: 400;
	font-size: 1.5rem;
	color: #D96C36;
	margin: 30px 0 16px;
	padding-bottom: 8px;
	border-bottom: 1px dotted rgba(217,108,54,.4);
}
.lv-menu__col h4:first-child { margin-top: 0; }
.lv-menu__col ul {
	list-style: none; padding: 0; margin: 0;
}
.lv-menu__col li {
	display: flex; align-items: baseline; gap: 12px;
	padding: 8px 0;
	font-family: 'DM Serif Display', serif;
}
.lv-menu__col li span {
	font-style: italic;
	flex: 1;
	font-size: 1.05rem;
	color: #1A0E07;
}
.lv-menu__col li em {
	font-style: normal;
	font-family: 'DM Sans', sans-serif;
	font-weight: 500;
	color: #6A4A2A;
	font-size: .95rem;
}
.lv-menu__col li::before {
	content: '';
	flex: 0 0 auto;
	width: 6px; height: 6px;
	background: #D96C36;
	border-radius: 50%;
	margin-right: 4px;
}
.lv-menu__foot {
	margin-top: 40px;
	text-align: center;
	padding-top: 24px;
	border-top: 1px solid rgba(26,14,7,.15);
}
.lv-menu__foot small {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 1rem;
	color: #6A4A2A;
}

/* ---------- POLAROIDS ---------- */
.lv-polaroids {
	display: flex; gap: 24px; justify-content: center; flex-wrap: wrap;
	margin-top: 50px;
}
.lv-pola {
	width: 180px;
	background: #F2E4CF;
	padding: 12px 12px 36px;
	margin: 0;
	box-shadow: 0 10px 24px -6px rgba(0,0,0,.4);
	transform: rotate(var(--rot, 0deg));
	transition: transform .4s var(--ac-ease-out);
}
.lv-pola:hover { transform: rotate(0deg) scale(1.06); z-index: 5; }
.lv-pola__photo {
	width: 100%; aspect-ratio: 1;
	background:
		radial-gradient(circle at 30% 30%, var(--b, #D96C36) 0%, var(--a, #3A2114) 60%);
}
.lv-pola figcaption {
	font-family: 'Allura', cursive;
	font-size: 1.4rem;
	color: #1A0E07;
	text-align: center;
	margin-top: 10px;
}

/* ---------- RESERVE ---------- */
.lv-section--reserve {
	background:
		radial-gradient(60% 50% at 50% 50%, rgba(143,167,107,.05), transparent 60%),
		#100804;
}
.lv-reserve {
	display: grid; grid-template-columns: 1.4fr 1fr; gap: 60px; align-items: start;
}
@media (max-width: 880px) { .lv-reserve { grid-template-columns: 1fr; gap: 40px; } }

.lv-book h2 { margin-bottom: 30px; }
.lv-form {
	display: grid; grid-template-columns: repeat(3, 1fr) auto; gap: 14px;
	background: rgba(242,228,207,.05);
	border: 1px solid rgba(217,108,54,.2);
	padding: 20px;
	border-radius: 8px;
	margin-bottom: 12px;
}
@media (max-width: 720px) { .lv-form { grid-template-columns: 1fr; } }
.lv-form label { display: flex; flex-direction: column; gap: 6px; }
.lv-form small {
	font-family: 'Allura', cursive;
	font-size: 1.2rem;
	color: #D96C36;
}
.lv-form input {
	background: transparent;
	border: 0;
	border-bottom: 1px solid rgba(242,228,207,.3);
	color: #F2E4CF;
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 1.05rem;
	padding: 6px 0;
	outline: none;
	pointer-events: none;
}
.lv-form__submit { align-self: end; }
.lv-form__note {
	font-family: 'DM Sans', sans-serif;
	font-size: .82rem;
	color: #8A7A60;
	display: block;
}

.lv-hours {
	background: rgba(143,167,107,.05);
	border: 1px solid rgba(143,167,107,.2);
	padding: 30px;
	border-radius: 8px;
}
.lv-hours h3 {
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 1.6rem;
	margin: 12px 0 16px;
	color: #8FA76B;
}
.lv-hours table {
	width: 100%; border-collapse: collapse;
	font-family: 'DM Sans', sans-serif;
}
.lv-hours td {
	padding: 8px 0;
	border-bottom: 1px dotted rgba(242,228,207,.15);
	font-size: .96rem;
	color: #F2E4CF;
}
.lv-hours td:last-child { text-align: right; color: #C8B89C; }
.lv-hours td em { font-style: italic; color: #D96C36; }
.lv-addr {
	margin-top: 24px;
	padding-top: 24px;
	border-top: 1px dotted rgba(242,228,207,.15);
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: 1.05rem;
	line-height: 1.6;
	color: #C8B89C;
}
.lv-addr strong { color: #F2E4CF; font-weight: 400; }
.lv-addr span { font-family: 'DM Sans', sans-serif; font-style: normal; color: #8FA76B; }

/* ---------- QUOTE ---------- */
.lv-section--quote {
	background: linear-gradient(180deg, #100804 0%, #1A0E07 100%);
	text-align: center;
	padding: clamp(80px, 12vw, 140px) 0;
}
.lv-quote {
	max-width: 800px; margin: 0 auto;
	font-family: 'DM Serif Display', serif;
	font-style: italic;
	font-size: clamp(1.4rem, 3vw, 2.2rem);
	line-height: 1.4;
	color: #F2E4CF;
}
.lv-quote p {
	margin: 0 0 24px;
	position: relative;
}
.lv-quote p em { font-style: italic; }
.lv-quote p::before {
	content: '"'; position: absolute; top: -.5em; left: -.4em;
	font-size: 5em; color: #D96C36; opacity: .2;
}
.lv-quote cite {
	display: block;
	font-family: 'Allura', cursive;
	font-style: normal;
	font-size: 1.4rem;
	color: #D96C36;
}

/* ---------- STACK ---------- */
.lv-section--stack { background: #100804; }
.lv-stack {
	display: grid; grid-template-columns: max-content 1fr;
	gap: 16px 32px; margin: 0;
	background: rgba(242,228,207,.03);
	border: 1px solid rgba(217,108,54,.15);
	padding: 30px;
	border-radius: 8px;
}
@media (max-width: 600px) { .lv-stack { grid-template-columns: 1fr; gap: 4px 0; } }
.lv-stack dt {
	font-family: 'Allura', cursive;
	font-size: 1.3rem;
	color: #D96C36;
	padding-top: 2px;
}
.lv-stack dd {
	margin: 0;
	font-family: 'DM Sans', sans-serif;
	font-size: .98rem;
	color: #F2E4CF;
	line-height: 1.5;
}
@media (max-width: 600px) {
	.lv-stack dd { padding-bottom: 14px; border-bottom: 1px dashed rgba(217,108,54,.1); margin-bottom: 8px; }
}
