/* =====================================================================
   Curry Shashwat — Theme Styles
   ===================================================================== */

:root {
	--gold: #c79a3a;
	--gold-bright: #d9a43a;
	--gold-soft: #e6b94a;
	--ink: #111;
	--ink-2: #1a1a1a;
	--text: #f5f5f5;
	--muted: rgba(255,255,255,0.78);
	--card-bg: #ffffff;
	--card-text: #2b2b2b;
	--border-soft: rgba(255,255,255,0.25);
	--maxw: 1200px;
	--font-serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
	--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

/* ---------- Reset-ish ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

html, body { overflow-x: hidden; }
body {
	margin: 0;
	background: var(--ink);
	color: var(--text);
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	max-width: 100%;
}

img { max-width: 100%; height: auto; display: block; }

a { color: inherit; text-decoration: none; transition: opacity .2s ease, color .2s ease; }
a:hover { opacity: .85; }

h1, h2, h3, h4 { font-family: var(--font-serif); font-weight: 500; line-height: 1.2; margin: 0 0 .5em; }

p { margin: 0 0 1em; }

.container {
	max-width: var(--maxw);
	margin: 0 auto;
	padding: 0 24px;
}

.screen-reader-text {
	border: 0; clip: rect(1px, 1px, 1px, 1px); -webkit-clip-path: inset(50%); clip-path: inset(50%);
	height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; word-wrap: normal !important;
}
.skip-link {
	position: absolute; top: -100px; left: 8px; background: var(--gold); color: #000; padding: 8px 16px; z-index: 9999;
}
.skip-link:focus { top: 8px; }

/* ---------- Buttons ---------- */
.btn {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: 15px;
	font-weight: 600;
	letter-spacing: .02em;
	color: #fff;
	background: transparent;
	border: 2px solid #fff;
	padding: 14px 28px;
	cursor: pointer;
	transition: background .25s ease, color .25s ease, transform .15s ease;
	text-align: center;
	min-width: 140px;
}
.btn:hover { background: #fff; color: #111; opacity: 1; }
.btn:active { transform: translateY(1px); }
.btn--lg { padding: 16px 36px; font-size: 16px; min-width: 180px; }
.btn--ghost { border-color: #fff; }
.btn--primary {
	background: var(--gold);
	border-color: var(--gold);
	color: #1a1a1a;
	box-shadow: 0 6px 18px rgba(199,154,58,0.28);
}
.btn--primary:hover {
	background: var(--gold-bright);
	border-color: var(--gold-bright);
	color: #111;
	transform: translateY(-1px);
	box-shadow: 0 10px 24px rgba(217,164,58,0.36);
}
.btn__icon {
	display: inline-block;
	vertical-align: -3px;
	margin-right: 6px;
}

/* =====================================================================
   Hero (front-page)
   ===================================================================== */
.hero {
	position: relative;
	min-height: 100vh;
	background-color: var(--ink);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	padding: 32px 0 80px;
	overflow: hidden;
}
.hero__overlay {
	position: absolute; inset: 0;
	background: #000;
	z-index: 1;
}
.hero > .container,
.hero__top,
.hero__body { position: relative; z-index: 2; }

.hero__top { padding-top: 8px; }

.hero__brand-row {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-bottom: 36px;
}
.hero__logo {
	display: inline-flex;
	align-items: center;
	max-width: 240px;
}
.hero__logo img,
.hero__logo .custom-logo,
.hero__logo .custom-logo-link img {
	width: auto !important;
	max-height: 90px !important;
	max-width: 240px !important;
	height: auto !important;
	display: block;
}
.hero__brand {
	font-family: var(--font-serif);
	font-weight: 400;
	color: var(--gold);
	font-size: clamp(40px, 6vw, 78px);
	margin: 0;
	letter-spacing: .01em;
	line-height: 1;
}

.hero__buttons {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 14px;
	margin: 60px auto 0;
}

.hero__body {
	margin-top: 90px;
	text-align: center;
}
.hero__tagline {
	font-family: var(--font-serif);
	font-weight: 400;
	font-size: clamp(28px, 4vw, 48px);
	color: #fff;
	margin: 0 0 .25em;
	line-height: 1.1;
}
.hero__tagline-line { display: block; }
.hero__tagline-accent {
	display: block;
	color: var(--gold);
	font-style: italic;
	margin-top: .05em;
}
.hero__subline {
	font-family: var(--font-serif);
	font-size: clamp(20px, 2.6vw, 30px);
	color: #fff;
	font-weight: 300;
	margin: 0 0 28px;
}
.hero__divider {
	height: 1px;
	background: rgba(255,255,255,0.5);
	margin: 18px auto;
	width: 100%;
	max-width: var(--maxw);
}
.hero__divider--gold { background: var(--gold); }

.hero__bio {
	color: #fff;
	font-size: 16px;
	line-height: 1.65;
	max-width: 100%;
	margin: 16px 0;
}
.hero__highlight {
	color: var(--gold);
	font-weight: 700;
	font-size: clamp(18px, 2vw, 22px);
	margin: 18px 0;
}
.hero__about { margin-top: 28px; }

/* Credentials row — three icon badges */
.creds {
	list-style: none;
	margin: 28px 0 8px;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}
.cred {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	text-align: center;
}
.cred__icon {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	border: 1.5px solid var(--gold);
	color: var(--gold);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(199,154,58,0.06);
	transition: transform .25s ease, background .25s ease;
}
.cred:hover .cred__icon {
	background: rgba(199,154,58,0.18);
	transform: translateY(-2px);
}
.cred__label {
	font-size: 14px;
	color: rgba(255,255,255,0.92);
	font-weight: 500;
	max-width: 180px;
	line-height: 1.35;
}

/* =====================================================================
   Reviews
   ===================================================================== */
.reviews {
	position: relative;
	background-color: var(--ink);
	background-size: cover;
	background-position: center;
	padding: 60px 0 90px;
}
.reviews__overlay {
	position: absolute; inset: 0;
	background: #000;
	z-index: 1;
}
.reviews__inner { position: relative; z-index: 2; }

.reviews__about-btn {
	text-align: center;
	margin-bottom: 50px;
}

.reviews__row {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 40px;
	align-items: center;
}
.reviews__row--shortcode {
	grid-template-columns: 1fr;
	gap: 0;
}

.reviews__rating { text-align: center; }
.reviews__rating-label {
	font-weight: 700;
	letter-spacing: .12em;
	font-size: 18px;
	color: #ffffff;
	margin-bottom: 8px;
}
.reviews__stars {
	display: flex;
	justify-content: center;
	gap: 4px;
	margin-bottom: 8px;
}
.star { color: rgba(255,255,255,.25); font-size: 28px; line-height: 1; }
.star--full { color: #f5b90c; }

.reviews__count {
	color: #ffffff;
	font-size: 14px;
	margin-bottom: 14px;
}
.reviews__count strong { color: #ffffff; font-weight: 700; }
.reviews__google {
	font-family: "Product Sans", "Arial", sans-serif;
	font-weight: 700;
	font-size: 32px;
	letter-spacing: -1px;
	user-select: none;
}
.g--blue { color: #4285F4; }
.g--red  { color: #EA4335; }
.g--yellow { color: #FBBC05; }
.g--green { color: #34A853; }

/* Plugin shortcode container (Trustindex / Elfsight / Brevio etc.) */
.reviews__plugin {
	min-width: 0;
	width: 100%;
}
.reviews__plugin > * { max-width: 100%; }

/* Trustindex rating header — force white text on dark hero photo */
.reviews__plugin .ti-rating,
.reviews__plugin .ti-rating-text,
.reviews__plugin .ti-rating-text strong,
.reviews__plugin .ti-rating-text .nowrap,
.reviews__plugin .ti-rating-text .nowrap strong,
.reviews__plugin .ti-fade-container .ti-rating-text,
.reviews__plugin .ti-fade-container .ti-rating-text * {
	color: #ffffff !important;
}

/* Carousel */
.reviews__carousel {
	position: relative;
	overflow: hidden;
}
.reviews__track {
	display: flex;
	align-items: stretch;
	gap: 22px;
	transition: transform .45s cubic-bezier(.4,0,.2,1);
	will-change: transform;
}
.review-card {
	flex: 0 0 calc((100% - 44px) / 3);
	background: var(--card-bg);
	color: var(--card-text);
	border-radius: 16px;
	padding: 26px 26px 24px;
	box-shadow: 0 10px 30px rgba(0,0,0,0.22), 0 2px 6px rgba(0,0,0,0.08);
	display: flex;
	flex-direction: column;
}
.review-card__text { flex: 1 1 auto; }
.review-card__head {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 14px;
}
.review-card__avatar {
	width: 48px; height: 48px; border-radius: 50%;
	background: #777; color: #fff;
	display: flex; align-items: center; justify-content: center;
	font-weight: 600; font-size: 22px;
	flex: 0 0 auto;
	text-transform: lowercase;
	letter-spacing: 0;
	line-height: 1;
}
.review-card__meta { flex: 1; min-width: 0; }
.review-card__name {
	font-weight: 600;
	color: #1f1f1f;
	font-size: 16px;
	line-height: 1.2;
	margin-bottom: 3px;
}
.review-card__when {
	color: #6b6b6b;
	font-size: 13px;
	line-height: 1.2;
}
.review-card__src {
	display: flex;
	align-items: center;
	flex: 0 0 auto;
}
.review-card__stars-row {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 12px;
}
.review-card__stars { display: flex; gap: 2px; }
.review-card__stars .star { font-size: 18px; line-height: 1; }
.review-card__verified {
	display: inline-flex;
	align-items: center;
}
.review-card__text {
	color: #2b2b2b;
	font-size: 15px;
	line-height: 1.55;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 5;
	-webkit-box-orient: vertical;
	overflow: hidden;
	word-wrap: break-word;
}
.review-card.is-expanded .review-card__text {
	-webkit-line-clamp: unset;
	display: block;
	overflow: visible;
}
.review-card__more {
	background: none;
	border: 0;
	color: #6b6b6b;
	font-size: 14px;
	font-weight: 500;
	padding: 8px 0 0;
	margin: 4px 0 0;
	cursor: pointer;
	text-align: left;
	font-family: inherit;
}
.review-card__more:hover { color: #1a73e8; }
.review-card.is-expanded .review-card__more { display: none; }

.reviews__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(0,0,0,0.4);
	color: #fff;
	border: 0;
	width: 38px; height: 38px;
	border-radius: 50%;
	font-size: 26px;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	z-index: 3;
	transition: background .2s;
}
.reviews__nav:hover { background: rgba(0,0,0,0.7); }
.reviews__nav--prev { left: -8px; }
.reviews__nav--next { right: -8px; }

/* =====================================================================
   Footer — warm dark with gold accents
   ===================================================================== */
.site-footer {
	background: #1a1310;
	background: linear-gradient(180deg, #1f1612 0%, #14100d 100%);
	color: rgba(255,255,255,0.85);
	padding: 70px 0 26px;
	border-top: 1px solid rgba(199,154,58,0.18);
	position: relative;
}
.site-footer::before {
	content: "";
	position: absolute;
	top: -1px; left: 50%;
	transform: translateX(-50%);
	width: 80px;
	height: 2px;
	background: var(--gold);
	opacity: .85;
}

.site-footer__brand {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin-bottom: 50px;
	text-align: center;
}
.site-footer__logo {
	display: inline-flex;
	align-items: center;
	max-width: 180px;
}
.site-footer__logo img,
.site-footer__logo .custom-logo,
.site-footer__logo .custom-logo-link img,
.site-footer__brand .site-footer__logo img {
	width: auto !important;
	max-height: 50px !important;
	max-width: 180px !important;
	height: auto !important;
	display: block;
}
.site-footer__mark {
	display: inline-flex;
	width: 44px; height: 44px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1.5px solid var(--gold);
	color: var(--gold);
	background: rgba(199,154,58,0.06);
}
.site-footer__brandname {
	font-family: var(--font-serif);
	font-size: 28px;
	color: var(--gold);
	letter-spacing: .01em;
	font-weight: 400;
}
.site-footer__brandname:hover { color: var(--gold-bright); opacity: 1; }

.site-footer__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
	text-align: center;
}
.site-footer__col {
	padding: 0 8px;
}
.site-footer__icon {
	display: inline-flex;
	width: 56px; height: 56px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1.5px solid rgba(199,154,58,0.45);
	background: rgba(199,154,58,0.08);
	color: var(--gold);
	margin: 0 auto 16px;
	transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.site-footer__col:hover .site-footer__icon {
	background: rgba(199,154,58,0.18);
	border-color: var(--gold);
	transform: translateY(-2px);
}

.site-footer__heading {
	font-family: var(--font-serif);
	font-size: 22px;
	font-weight: 500;
	color: #fff;
	margin: 0 0 12px;
	letter-spacing: .01em;
}
.site-footer__text {
	color: rgba(255,255,255,0.78);
	font-size: 15px;
	line-height: 1.65;
	margin: 0;
}
.site-footer__text a {
	color: rgba(255,255,255,0.92);
	border-bottom: 1px solid transparent;
	transition: color .2s ease, border-color .2s ease;
}
.site-footer__text a:hover {
	color: var(--gold);
	border-bottom-color: var(--gold);
	opacity: 1;
}

/* Social row */
.site-footer__socials {
	display: flex;
	justify-content: center;
	gap: 12px;
	margin-top: 44px;
}
.site-footer__social {
	display: inline-flex;
	width: 40px; height: 40px;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,0.25);
	color: rgba(255,255,255,0.85);
	transition: background .2s, border-color .2s, color .2s, transform .15s;
}
.site-footer__social:hover {
	background: var(--gold);
	border-color: var(--gold);
	color: #1a1310;
	transform: translateY(-2px);
	opacity: 1;
}

.site-footer__credit {
	margin-top: 36px;
	padding-top: 22px;
	border-top: 1px solid rgba(255,255,255,0.08);
	text-align: center;
	font-size: 13px;
	letter-spacing: .03em;
	color: rgba(255,255,255,0.55);
}

/* =====================================================================
   Inner page header (about, etc.)
   ===================================================================== */
.site-header.inner-header {
	background: #6f5b51;
	padding: 16px 0;
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
}
.site-branding { display: flex; align-items: center; gap: 12px; }
.site-logo {
	display: inline-flex;
	align-items: center;
	max-width: 180px;
}
.site-logo img,
.site-logo .custom-logo,
.site-logo .custom-logo-link img {
	width: auto !important;
	max-height: 56px !important;
	max-width: 180px !important;
	height: auto !important;
	display: block;
}
.site-title {
	font-family: var(--font-serif);
	font-size: 22px;
	color: #fff;
	font-weight: 400;
}
.site-nav .primary-menu {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0; padding: 0;
}
.site-nav .primary-menu a {
	display: inline-block;
	padding: 9px 18px;
	border: 1px solid rgba(255,255,255,0.6);
	color: #fff;
	font-size: 13.5px;
	font-weight: 500;
	letter-spacing: .02em;
	border-radius: 4px;
	transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.site-nav .primary-menu a:hover {
	background: var(--gold);
	border-color: var(--gold);
	color: #1a1310;
	opacity: 1;
}
.site-nav .primary-menu a.is-current,
.site-nav .primary-menu .is-current > a {
	background: var(--gold);
	border-color: var(--gold);
	color: #1a1310;
}
/* Order Online sits to the right as the primary call-to-action */
.site-nav .primary-menu a.is-cta {
	background: linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 100%);
	border-color: var(--gold);
	color: #1a1310;
	font-weight: 600;
	box-shadow: 0 4px 12px rgba(199,154,58,0.28);
}
.site-nav .primary-menu a.is-cta:hover {
	background: var(--gold-bright);
	color: #0d0805;
	transform: translateY(-1px);
	box-shadow: 0 6px 16px rgba(217,164,58,0.36);
}

/* =====================================================================
   About page — editorial layout v3
   Centered hero (eyebrow / title / ornament / subtitle / quote card)
   over two-column body (bio paragraphs + sticky image).
   ===================================================================== */
.about-page {
	background:
		radial-gradient(circle at 20% 0%, rgba(199,154,58,0.08) 0%, transparent 55%),
		radial-gradient(circle at 90% 100%, rgba(199,154,58,0.06) 0%, transparent 50%),
		linear-gradient(180deg, #5e4a40 0%, #4a3a32 100%);
	min-height: 100vh;
	padding: 90px 0 100px;
	position: relative;
}
.about-page__inner { max-width: 1180px; margin: 0 auto; padding: 0 28px; }

/* ----- Centered hero ----- */
.about-page__hero {
	text-align: center;
	margin: 0 auto 70px;
	max-width: 820px;
}
.about-page__eyebrow {
	display: inline-block;
	font-family: var(--font-sans);
	font-size: 12px;
	letter-spacing: .35em;
	color: var(--gold);
	text-transform: uppercase;
	font-weight: 600;
	margin-bottom: 14px;
}
.about-page__title {
	font-family: var(--font-serif);
	color: #fff8e7;
	font-weight: 400;
	font-size: clamp(34px, 4.5vw, 52px);
	margin: 0;
	line-height: 1.05;
	letter-spacing: .005em;
}
.about-page__ornament {
	display: inline-block;
	color: var(--gold);
	margin-top: 16px;
	opacity: .85;
}
.about-page__chef-subtitle {
	font-family: var(--font-serif);
	font-style: italic;
	color: var(--gold-soft);
	font-size: 22px;
	margin: 26px 0 0;
	letter-spacing: .01em;
}

/* Featured quote card */
.about-page__chef-quote {
	position: relative;
	max-width: 720px;
	margin: 36px auto 0;
	padding: 32px 36px 28px;
	background: rgba(199,154,58,0.06);
	border: 1px solid rgba(199,154,58,0.28);
	border-radius: 10px;
	text-align: center;
}
.about-page__quote-mark {
	position: absolute;
	top: -22px;
	left: 50%;
	transform: translateX(-50%);
	width: 44px;
	height: 44px;
	padding: 8px;
	background: #5a4640;
	border: 1px solid rgba(199,154,58,0.28);
	border-radius: 50%;
	color: var(--gold);
	box-sizing: content-box;
}
.about-page__quote-text {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 20px;
	color: #fff8e7;
	line-height: 1.55;
	margin: 0;
}

/* ----- Two-column body ----- */
.about-page__body {
	display: flex;
	gap: 60px;
	align-items: flex-start;
}
.about-page__body--right { flex-direction: row-reverse; }
.about-page__body--no-image .about-page__copy {
	max-width: 760px;
	margin: 0 auto;
}

.about-page__media {
	flex: 0 0 40%;
	max-width: 40%;
	margin: 0;
	position: sticky;
	top: 32px;
	align-self: flex-start;
}
.about-page__media-frame {
	position: relative;
	padding: 14px;
}
.about-page__media-frame::before,
.about-page__media-frame::after {
	content: "";
	position: absolute;
	width: 28px;
	height: 28px;
	border: 2px solid var(--gold);
	z-index: 0;
}
.about-page__media-frame::before {
	top: 0; left: 0;
	border-right: 0;
	border-bottom: 0;
}
.about-page__media-frame::after {
	bottom: 0; right: 0;
	border-left: 0;
	border-top: 0;
}
.about-page__image {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 4px;
	box-shadow: 0 30px 70px rgba(0,0,0,0.5), 0 8px 20px rgba(0,0,0,0.3);
	position: relative;
	z-index: 1;
	/* Cap height ~20% shorter than the natural portrait crop. */
	aspect-ratio: 4 / 5;
	object-fit: cover;
	object-position: center 28%;
}

/* About-page slider — used when 2+ images are uploaded */
.about-slider {
	position: relative;
	width: 100%;
	border-radius: 4px;
	overflow: hidden;
	box-shadow: 0 30px 70px rgba(0,0,0,0.5), 0 8px 20px rgba(0,0,0,0.3);
}
.about-slider__track {
	position: relative;
	width: 100%;
	aspect-ratio: 4 / 5;
	background: #1a1310;
}
.about-slider__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity .65s ease;
	pointer-events: none;
}
.about-slider__slide.is-active {
	opacity: 1;
	pointer-events: auto;
	z-index: 1;
}
/* Inside the slider the per-slide image fills the slide; override the
   single-image rules so we don't double up shadows or radius. */
.about-slider__slide .about-page__image {
	width: 100%;
	height: 100%;
	aspect-ratio: auto;
	border-radius: 0;
	box-shadow: none;
	object-fit: cover;
	object-position: center 28%;
}

/* Arrow nav — appears on hover/focus */
.about-slider__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 38px;
	height: 38px;
	border: 0;
	border-radius: 50%;
	background: rgba(0,0,0,0.45);
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 3;
	opacity: 0;
	transition: opacity .25s, background .2s, transform .15s;
}
.about-slider__nav--prev { left: 14px; }
.about-slider__nav--next { right: 14px; }
.about-slider:hover .about-slider__nav,
.about-slider:focus-within .about-slider__nav { opacity: 1; }
.about-slider__nav:hover { background: var(--gold); color: #1a1310; }
.about-slider__nav:active { transform: translateY(-50%) scale(0.94); }

/* Dots */
.about-slider__dots {
	position: absolute;
	left: 50%;
	bottom: 14px;
	transform: translateX(-50%);
	display: flex;
	gap: 8px;
	z-index: 3;
	background: rgba(0,0,0,0.36);
	padding: 7px 12px;
	border-radius: 999px;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}
.about-slider__dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	border: 0;
	background: rgba(255,255,255,0.45);
	padding: 0;
	cursor: pointer;
	transition: background .2s, width .3s, border-radius .3s;
}
.about-slider__dot:hover { background: rgba(255,255,255,0.8); }
.about-slider__dot.is-active {
	background: var(--gold);
	width: 22px;
	border-radius: 6px;
}

@media (max-width: 600px) {
	.about-slider__nav { opacity: 1; width: 32px; height: 32px; }
	.about-slider__nav--prev { left: 8px; }
	.about-slider__nav--next { right: 8px; }
}

.about-page__copy { flex: 1 1 auto; min-width: 0; }

.about-page__content {
	color: rgba(255,248,231,0.9);
	font-size: 16px;
	line-height: 1.75;
}
.about-page__content p,
.about-page__content h2,
.about-page__content h3,
.about-page__content h4 {
	margin: 0 0 1.05em;
}
.about-page__content h2 {
	font-family: var(--font-serif);
	font-size: 22px;
	font-weight: 500;
	color: var(--gold-soft);
	font-style: italic;
	letter-spacing: .01em;
}
.about-page__content h3 {
	font-family: var(--font-serif);
	font-size: 19px;
	font-weight: 500;
	color: var(--gold-soft);
}
.about-page__content p:last-of-type { margin-bottom: 0; }

.about-page__signature {
	font-family: var(--font-serif);
	font-style: italic;
	color: var(--gold-soft);
	font-size: 17px;
	margin-top: 1.8em !important;
	letter-spacing: .02em;
}

/* Hide WordPress.com / Jetpack sharing & like widgets so we can render our
   own unified Share + Follow row instead. */
.about-page .sharedaddy,
.about-page .sd-sharing-enabled,
.about-page .sharing,
.about-page .jp-likes-widget-wrapper,
.about-page .post-likes-widget-placeholder,
.about-page #jp-relatedposts {
	display: none !important;
}

/* Combined Share + Follow row */
.about-page__share-follow {
	display: flex;
	flex-wrap: wrap;
	gap: 32px;
	align-items: center;
	margin-top: 36px;
	padding-top: 24px;
	border-top: 1px solid rgba(255,255,255,0.16);
}
.about-page__group {
	display: flex;
	align-items: center;
	gap: 14px;
}
.about-page__group-label {
	font-family: var(--font-serif);
	font-style: italic;
	font-size: 16px;
	color: var(--gold-soft);
	letter-spacing: .02em;
}
.about-page__group-row {
	display: inline-flex;
	gap: 8px;
}
.about-page__action {
	display: inline-flex;
	width: 38px;
	height: 38px;
	border-radius: 50%;
	border: 1px solid rgba(255,255,255,0.32);
	color: rgba(255,255,255,0.85);
	background: transparent;
	font: inherit;
	cursor: pointer;
	align-items: center;
	justify-content: center;
	transition: background .2s, color .2s, border-color .2s, transform .15s;
	position: relative;
}
.about-page__action:hover {
	background: var(--gold);
	color: #1a1310;
	border-color: var(--gold);
	transform: translateY(-1px);
	opacity: 1;
}
.about-page__action--copy .about-page__action-check {
	position: absolute;
	inset: 0;
	margin: auto;
	opacity: 0;
	transform: scale(.6);
	transition: opacity .2s, transform .2s;
}
.about-page__action--copy.is-copied {
	background: var(--gold);
	color: #1a1310;
	border-color: var(--gold);
}
.about-page__action--copy.is-copied .about-page__action-icon {
	opacity: 0;
	transform: scale(.5);
	transition: opacity .15s, transform .15s;
}
.about-page__action--copy.is-copied .about-page__action-check {
	opacity: 1;
	transform: scale(1);
}

/* Toast — used by share-via-clipboard and any other small confirmations */
.cs-toast {
	position: fixed;
	bottom: 28px;
	left: 50%;
	z-index: 100000;
	transform: translateX(-50%) translateY(16px);
	min-width: 220px;
	max-width: calc(100vw - 40px);
	padding: 12px 18px;
	background: #1a1310;
	color: #fff;
	border: 1px solid rgba(199,154,58,0.5);
	border-radius: 10px;
	font-size: 14px;
	line-height: 1.4;
	text-align: center;
	box-shadow: 0 14px 40px rgba(0,0,0,0.55);
	opacity: 0;
	transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .25s ease;
	pointer-events: none;
}
.cs-toast--show {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}
.about-page__group--share + .about-page__group--follow {
	position: relative;
}
.about-page__group--share + .about-page__group--follow::before {
	content: "";
	position: absolute;
	left: -16px;
	top: 8px; bottom: 8px;
	width: 1px;
	background: rgba(255,255,255,0.18);
}

@media (max-width: 900px) {
	.about-page { padding: 60px 0 80px; }
	.about-page__hero { margin-bottom: 50px; }
	.about-page__title { font-size: clamp(28px, 6vw, 36px); }
	.about-page__chef-subtitle { font-size: 19px; }
	.about-page__chef-quote { padding: 28px 22px 22px; }
	.about-page__quote-text { font-size: 17px; }
	.about-page__body,
	.about-page__body--right {
		flex-direction: column;
		gap: 36px;
	}
	.about-page__media {
		flex: 0 0 auto;
		max-width: 100%;
		width: 100%;
		position: static;  /* sticky off on mobile — would block scroll */
		top: auto;
	}
	.about-page__content { font-size: 15.5px; }
}

/* Generic single page */
.single-page {
	background: #1a1a1a;
	min-height: 60vh;
	padding: 80px 0;
}
.single-page__inner { max-width: 800px; }
.single-page__title { color: var(--gold); }
.single-page__content { color: #eee; line-height: 1.7; }

/* Archive */
.archive { padding: 60px 0; }
.archive__title { color: var(--gold); margin-bottom: 30px; }
.post-list {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 30px;
}
.post-card { background: var(--ink-2); padding: 20px; border-radius: 8px; }
.post-card__thumb { display: block; margin-bottom: 14px; }
.post-card__title a { color: var(--gold); }
.post-card__meta { color: #888; font-size: 13px; margin-bottom: 8px; }
.post-card__excerpt { color: #ccc; font-size: 15px; }

/* 404 */
.error-404 { padding: 120px 0; text-align: center; }
.error-404__inner { max-width: 600px; margin: 0 auto; padding: 0 24px; }
.error-404__title {
	font-size: clamp(80px, 14vw, 160px);
	color: var(--gold);
	font-family: var(--font-serif);
	margin: 0 0 16px;
}
.error-404__text { color: #ccc; margin-bottom: 30px; font-size: 18px; }

/* =====================================================================
   Responsive
   ===================================================================== */
@media (max-width: 1000px) {
	.reviews__row {
		grid-template-columns: 1fr;
		gap: 30px;
	}
	.review-card {
		flex: 0 0 calc((100% - 22px) / 2);
	}
}

@media (max-width: 768px) {
	.container { padding: 0 12px; }   /* ≈ 95% content width on phones */

	.hero { padding: 24px 0 60px; min-height: auto; }
	.hero__brand-row {
		flex-direction: column;
		gap: 8px;
		align-items: center;
		text-align: center;
		margin-bottom: 24px;
	}
	.hero__brand { font-size: 48px; line-height: 1.1; }
	/* Bump logo sizes on phones — they were a bit too small. */
	.hero__logo,
	.hero__logo img,
	.hero__logo .custom-logo,
	.hero__logo .custom-logo-link img {
		max-width: 280px !important;
		max-height: 130px !important;
	}
	.site-logo,
	.site-logo img,
	.site-logo .custom-logo,
	.site-logo .custom-logo-link img {
		max-width: 220px !important;
		max-height: 80px !important;
	}
	.site-footer__logo,
	.site-footer__logo img,
	.site-footer__logo .custom-logo,
	.site-footer__logo .custom-logo-link img {
		max-width: 220px !important;
		max-height: 70px !important;
	}
	.hero__buttons {
		gap: 10px;
		margin: 30px auto 0;
	}
	.hero__body { margin-top: 50px; }
	.hero__tagline { font-size: 28px; }
	.hero__subline { font-size: 18px; margin-bottom: 18px; }
	.hero__bio { font-size: 15px; }
	.hero__highlight { font-size: 17px; }
	.btn { padding: 12px 22px; min-width: 110px; font-size: 14px; }
	.btn--lg { padding: 14px 26px; font-size: 15px; min-width: 150px; }

	.reviews { padding: 40px 0 60px; }
	.reviews__about-btn { margin-bottom: 30px; }
	.review-card { flex: 0 0 100%; min-height: auto; }
	.reviews__track { gap: 16px; }
	.reviews__nav { width: 32px; height: 32px; font-size: 22px; }
	.reviews__nav--prev { left: 0; }
	.reviews__nav--next { right: 0; }

	.site-footer { padding: 50px 0 22px; }
	.site-footer__brand { margin-bottom: 32px; }
	.site-footer__brandname { font-size: 24px; }
	.site-footer__grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}
	.site-footer__heading { font-size: 20px; margin-bottom: 8px; }
	.site-footer__icon { width: 48px; height: 48px; margin-bottom: 12px; }
	.site-footer__socials { margin-top: 32px; }
	.site-footer__credit { margin-top: 30px; }

	.site-header.inner-header { padding: 12px 0; }
	.site-header__inner { flex-direction: column; gap: 12px; }
	.about-page { padding: 40px 0; }
	.about-page__title { font-size: 28px; }
	.about-page__content { font-size: 16px; }

}

@media (max-width: 600px) {
	.creds {
		grid-template-columns: 1fr;
		gap: 18px;
		max-width: 320px;
	}
	.cred { flex-direction: row; gap: 14px; text-align: left; }
	.cred__label { max-width: none; }
}

@media (max-width: 480px) {
	.hero__brand { font-size: 38px; }
	.hero__tagline { font-size: 24px; }
	.hero__buttons { flex-direction: column; align-items: stretch; }
	.hero__buttons .btn { width: 100%; }
	.review-card { padding: 18px; }
	.reviews__rating-label { font-size: 16px; }
	.star { font-size: 24px; }
}

/* =====================================================================
   Menu Page — 3D flipbook
   ===================================================================== */
.menu-page {
	background: linear-gradient(180deg, #1a1310 0%, #221915 100%);
	min-height: 60vh; /* enough to feel substantial, not so much it leaves big gaps when filtering */
	padding: 70px 0 100px;
	color: var(--text);
}
.menu-page__head {
	text-align: center;
	max-width: 720px;
	margin: 0 auto 50px;
}
.menu-page__title {
	font-family: var(--font-serif);
	color: var(--gold);
	font-weight: 400;
	font-size: clamp(34px, 5vw, 52px);
	margin: 0 0 14px;
	letter-spacing: .01em;
}
.menu-page__intro {
	color: rgba(255,255,255,0.78);
	font-size: 17px;
	line-height: 1.65;
	margin: 0;
}
.menu-page__cta {
	text-align: center;
	margin-top: 40px;
}
.menu-page__empty {
	text-align: center;
	color: rgba(255,255,255,0.6);
	padding: 60px 0;
}
.menu-page__empty a { color: var(--gold); text-decoration: underline; }

/* Flipbook */
.flipbook {
	max-width: 720px;
	margin: 0 auto;
	user-select: none;
}
.flipbook__stage {
	position: relative;
	perspective: 2400px;
	perspective-origin: 50% 50%;
	aspect-ratio: 3 / 4.2;
	margin: 0 auto;
	max-width: 620px;
}
.flipbook__sheet {
	position: absolute;
	inset: 0;
	transform-style: preserve-3d;
	-webkit-transform-style: preserve-3d;
	transform-origin: left center;
	transition: transform 1.05s cubic-bezier(0.645, 0.045, 0.355, 1);
	will-change: transform;
}
.flipbook__sheet.is-flipped {
	transform: rotateY(-180deg);
}
.flipbook__face {
	position: absolute;
	inset: 0;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	background: #fff;
	border-radius: 6px 14px 14px 6px;
	overflow: hidden;
	box-shadow:
		-2px 0 0 rgba(0,0,0,0.12) inset,
		0 14px 30px rgba(0,0,0,0.45),
		0 4px 10px rgba(0,0,0,0.25);
}
.flipbook__face img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	cursor: zoom-in;
	background: #fff;
}
.flipbook__shine {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background: linear-gradient(90deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0) 8%, rgba(0,0,0,0) 92%, rgba(0,0,0,0.10) 100%);
	border-radius: 6px 14px 14px 6px;
	mix-blend-mode: multiply;
}

.flipbook__controls {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 22px;
	margin-top: 40px;
}
.flipbook__btn {
	width: 52px;
	height: 52px;
	border-radius: 50%;
	border: 1.5px solid var(--gold);
	background: transparent;
	color: var(--gold);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background .25s ease, color .25s ease, transform .15s ease;
}
.flipbook__btn:hover {
	background: var(--gold);
	color: #1a1310;
	transform: translateY(-2px);
}
.flipbook__btn:active { transform: translateY(0); }
.flipbook__btn:disabled,
.flipbook__btn[aria-disabled="true"] {
	opacity: 0.35;
	cursor: not-allowed;
	transform: none;
}
.flipbook__counter {
	font-family: var(--font-serif);
	font-size: 22px;
	color: var(--gold);
	min-width: 64px;
	text-align: center;
	letter-spacing: .04em;
}
.flipbook__counter-sep { opacity: .5; margin: 0 4px; }
.flipbook__hint {
	text-align: center;
	margin-top: 18px;
	color: rgba(255,255,255,0.4);
	font-size: 13px;
	letter-spacing: .04em;
}

/* =====================================================================
   Dishes grid (Menu page — below flipbook)
   ===================================================================== */
.dishes {
	background: linear-gradient(180deg, #15100c 0%, #1f1612 100%);
	padding: 80px 0 100px;
	color: var(--text);
}
.dishes__head {
	text-align: center;
	max-width: 700px;
	margin: 0 auto 50px;
}
.dishes__title {
	font-family: var(--font-serif);
	color: var(--gold);
	font-weight: 400;
	font-size: clamp(30px, 4vw, 42px);
	margin: 0 0 12px;
	letter-spacing: .01em;
}
.dishes__intro {
	color: rgba(255,255,255,0.72);
	font-size: 16px;
	line-height: 1.6;
	margin: 0;
}

/* Filter tabs */
.dishes__tabs {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin: 0 auto 38px;
	max-width: 920px;
	padding: 0 8px;
}
.dishes__tab {
	background: transparent;
	border: 1px solid rgba(199,154,58,0.4);
	color: rgba(255,255,255,0.85);
	padding: 9px 18px;
	border-radius: 999px;
	cursor: pointer;
	font: inherit;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: .01em;
	transition: background .2s, color .2s, border-color .2s, transform .15s;
	white-space: nowrap;
}
.dishes__tab:hover {
	background: rgba(199,154,58,0.12);
	border-color: var(--gold);
	color: #fff;
}
.dishes__tab.is-active {
	background: var(--gold);
	color: #1a1310;
	border-color: var(--gold);
}
.dishes__tab:active { transform: translateY(1px); }

/* Pinned tab — Customer Choices, with star icon */
.dishes__tab--pinned {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.dishes__tab-icon {
	color: var(--gold);
	flex: 0 0 auto;
}
.dishes__tab--pinned.is-active .dishes__tab-icon {
	color: #1a1310;
}

.dishes__empty {
	text-align: center;
	color: rgba(255,255,255,0.55);
	font-style: italic;
	padding: 40px 0;
	margin: 0;
}

.dishes__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 28px;
}
.dish-card {
	transition: opacity .25s ease, transform .25s ease;
	position: relative;
}
.dish-card.is-hidden {
	opacity: 0;
	transform: scale(0.96);
	pointer-events: none;
}


.dish-card {
	background: rgba(255,255,255,0.03);
	border: 1px solid rgba(199,154,58,0.18);
	border-radius: 14px;
	overflow: hidden;
	transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
	display: flex;
	flex-direction: column;
}
.dish-card:hover {
	transform: translateY(-4px);
	border-color: rgba(199,154,58,0.55);
	box-shadow: 0 20px 40px rgba(0,0,0,0.5);
}
.dish-card__media {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	position: relative;
	background: #221915;
}
.dish-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .5s ease;
}
.dish-card:hover .dish-card__media img {
	transform: scale(1.06);
}
.dish-card__media--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(199,154,58,0.45);
}
.dish-card__body {
	padding: 18px 20px 22px;
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
}
.dish-card__title {
	font-family: var(--font-serif);
	font-size: 20px;
	font-weight: 500;
	color: #fff;
	margin: 0 0 8px;
	line-height: 1.25;
}
.dish-card__desc {
	color: rgba(255,255,255,0.72);
	font-size: 14px;
	line-height: 1.55;
	margin: 0;
	flex: 1 1 auto;
}

@media (max-width: 600px) {
	.dishes { padding: 60px 0 80px; }
	.dishes__grid { grid-template-columns: 1fr; gap: 20px; }
	.dish-card__title { font-size: 18px; }
}

/* Lightbox (click image to enlarge) */
.lightbox {
	position: fixed;
	inset: 0;
	background: rgba(10,7,5,0.95);
	z-index: 10000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 30px;
	opacity: 0;
	transition: opacity .3s ease;
}
.lightbox.is-open {
	opacity: 1;
}
.lightbox[hidden] { display: none; }
.lightbox__image {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
	border-radius: 4px;
	box-shadow: 0 20px 60px rgba(0,0,0,0.6);
}
.lightbox__close {
	position: absolute;
	top: 22px; right: 22px;
	width: 44px; height: 44px;
	border-radius: 50%;
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.25);
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background .2s, transform .15s;
}
.lightbox__close:hover {
	background: var(--gold);
	border-color: var(--gold);
	color: #1a1310;
	transform: rotate(90deg);
}

@media (max-width: 768px) {
	.menu-page { padding: 50px 0 80px; }
	.flipbook__stage { max-width: 90vw; }
	.flipbook__btn { width: 44px; height: 44px; }
	.flipbook__counter { font-size: 18px; min-width: 54px; }
	.lightbox__close { top: 12px; right: 12px; width: 38px; height: 38px; }
}

/* =====================================================================
   Built-in FAQ Chat Bot
   ===================================================================== */
.cs-chat-launcher {
	position: fixed;
	right: 22px;
	bottom: 22px;
	z-index: 9998;
	display: flex;
	align-items: center;
	gap: 10px;
	background: transparent;
	border: 0;
	padding: 0;
	cursor: pointer;
	font: inherit;
	color: inherit;
}
.cs-chat-launcher__label {
	background: #fdf9f1;
	color: #1a1310;
	border: 1px solid rgba(199,154,58,0.55);
	padding: 9px 14px;
	border-radius: 10px;
	font-size: 13px;
	font-weight: 500;
	box-shadow: 0 6px 18px rgba(0,0,0,0.35);
	white-space: nowrap;
	transition: transform .2s, opacity .2s;
}
.cs-chat-launcher__bubble {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 100%);
	color: #1a1310;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 10px 24px rgba(0,0,0,0.35), 0 4px 10px rgba(199,154,58,0.4);
	transition: transform .2s ease;
}
.cs-chat-launcher:hover .cs-chat-launcher__bubble {
	transform: translateY(-2px) scale(1.04);
}
.cs-chat-launcher.is-active .cs-chat-launcher__bubble { transform: scale(0.92); }
.cs-chat-launcher.is-active .cs-chat-launcher__label { opacity: 0; transform: translateX(8px); }

/* Chat panel — light cream palette so it stands out against the dark site bg */
.cs-chat {
	position: fixed;
	right: 22px;
	bottom: 100px;
	z-index: 9999;
	width: 380px;
	max-width: calc(100vw - 24px);
	height: 540px;
	max-height: calc(100vh - 130px);
	background: #fdf9f1;
	background: linear-gradient(180deg, #fdf9f1 0%, #f5ecdb 100%);
	color: #2b1f15;
	border-radius: 18px;
	box-shadow: 0 30px 80px rgba(0,0,0,0.55), 0 8px 24px rgba(0,0,0,0.3);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	border: 1px solid rgba(199,154,58,0.4);
	transform: translateY(20px) scale(0.96);
	opacity: 0;
	transform-origin: bottom right;
	transition: transform .3s cubic-bezier(.34,1.56,.64,1), opacity .25s ease;
}
.cs-chat.is-open {
	transform: translateY(0) scale(1);
	opacity: 1;
}
.cs-chat[hidden] { display: none; }

.cs-chat__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 16px 16px 14px;
	background: linear-gradient(180deg, rgba(199,154,58,0.18) 0%, rgba(199,154,58,0.08) 100%);
	border-bottom: 1px solid rgba(199,154,58,0.3);
}
.cs-chat__id { display: flex; align-items: center; gap: 12px; }
.cs-chat__avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #fff;
	border: 1.5px solid var(--gold);
	color: var(--gold);
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.cs-chat__name {
	color: #1a1310;
	font-family: var(--font-serif);
	font-size: 17px;
	line-height: 1.1;
}
.cs-chat__status {
	color: rgba(0,0,0,0.55);
	font-size: 12px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: 3px;
}
.cs-chat__status-dot {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: #34c759;
	box-shadow: 0 0 0 2px rgba(52,199,89,0.18);
}
.cs-chat__close {
	background: none;
	border: 0;
	color: rgba(0,0,0,0.55);
	cursor: pointer;
	width: 32px; height: 32px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background .2s, color .2s;
}
.cs-chat__close:hover { background: rgba(0,0,0,0.06); color: #1a1310; }

.cs-chat__body {
	flex: 1 1 auto;
	overflow-y: auto;
	padding: 18px 16px 16px;
	display: flex;
	flex-direction: column;
	gap: 12px;
	scroll-behavior: smooth;
}
.cs-chat__body::-webkit-scrollbar { width: 6px; }
.cs-chat__body::-webkit-scrollbar-thumb { background: rgba(199,154,58,0.45); border-radius: 3px; }

/* Messages */
.cs-chat__msg {
	max-width: 85%;
	padding: 10px 14px;
	border-radius: 14px;
	font-size: 14.5px;
	line-height: 1.5;
	word-wrap: break-word;
	animation: csChatIn .25s ease;
}
.cs-chat__msg--bot {
	background: #ffffff;
	color: #2b1f15;
	border: 1px solid rgba(199,154,58,0.22);
	align-self: flex-start;
	border-bottom-left-radius: 4px;
	box-shadow: 0 2px 6px rgba(0,0,0,0.04);
}
.cs-chat__msg--user {
	background: linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 100%);
	color: #1a1310;
	align-self: flex-end;
	border-bottom-right-radius: 4px;
	font-weight: 500;
	box-shadow: 0 2px 8px rgba(199,154,58,0.3);
}
@keyframes csChatIn {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Typing indicator */
.cs-chat__typing {
	background: #ffffff;
	border: 1px solid rgba(199,154,58,0.22);
	border-radius: 14px;
	border-bottom-left-radius: 4px;
	padding: 14px 16px;
	align-self: flex-start;
	display: inline-flex;
	gap: 4px;
}
.cs-chat__typing span {
	width: 7px; height: 7px;
	border-radius: 50%;
	background: rgba(0,0,0,0.35);
	animation: csChatBounce 1s infinite;
}
.cs-chat__typing span:nth-child(2) { animation-delay: 0.15s; }
.cs-chat__typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes csChatBounce {
	0%, 60%, 100% { transform: translateY(0); opacity: 0.5; }
	30% { transform: translateY(-4px); opacity: 1; }
}

/* Suggestion chips */
.cs-chat__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 4px;
	animation: csChatIn .3s ease;
}
.cs-chat__chip {
	background: #ffffff;
	border: 1px solid rgba(199,154,58,0.6);
	color: #6b5333;
	font-size: 13px;
	padding: 8px 14px;
	border-radius: 999px;
	cursor: pointer;
	font-family: inherit;
	transition: background .2s, color .2s, border-color .2s, transform .15s;
	line-height: 1.3;
	text-align: left;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.cs-chat__chip:hover {
	background: var(--gold);
	color: #1a1310;
	border-color: var(--gold);
}
.cs-chat__chip:active { transform: scale(0.97); }

/* Input form (AI mode) */
.cs-chat__input-form {
	display: flex;
	gap: 8px;
	padding: 10px 12px;
	border-top: 1px solid rgba(199,154,58,0.3);
	background: rgba(199,154,58,0.1);
}
.cs-chat__input {
	flex: 1;
	background: #ffffff;
	border: 1px solid rgba(199,154,58,0.4);
	color: #2b1f15;
	border-radius: 999px;
	padding: 10px 16px;
	font: inherit;
	font-size: 14.5px;
	min-width: 0;
	transition: border-color .2s, background .2s, box-shadow .2s;
}
.cs-chat__input::placeholder { color: rgba(0,0,0,0.4); }
.cs-chat__input:focus {
	outline: none;
	border-color: var(--gold);
	background: #ffffff;
	box-shadow: 0 0 0 3px rgba(199,154,58,0.18);
}
.cs-chat__input:disabled { opacity: 0.6; }
.cs-chat__send {
	width: 40px; height: 40px;
	border-radius: 50%;
	border: 0;
	background: linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 100%);
	color: #1a1310;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
	transition: transform .15s, opacity .15s;
}
.cs-chat__send:hover { transform: translateY(-1px); }
.cs-chat__send:active { transform: scale(0.95); }
.cs-chat__send:disabled { opacity: 0.5; cursor: not-allowed; }

/* Footer actions */
.cs-chat__foot {
	display: flex;
	gap: 10px;
	padding: 12px 14px;
	border-top: 1px solid rgba(199,154,58,0.3);
	background: rgba(199,154,58,0.08);
}
.cs-chat__action {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 9px 12px;
	background: #ffffff;
	border: 1px solid rgba(199,154,58,0.6);
	border-radius: 10px;
	color: #6b5333;
	text-decoration: none;
	font-size: 13px;
	font-weight: 500;
	transition: background .2s, color .2s, border-color .2s;
}
.cs-chat__action:hover {
	background: var(--gold);
	color: #1a1310;
	border-color: var(--gold);
	opacity: 1;
}

/* Mobile */
@media (max-width: 600px) {
	.cs-chat-launcher { right: 14px; bottom: 14px; gap: 8px; }
	.cs-chat-launcher__label {
		font-size: 12px;
		padding: 7px 11px;
		max-width: 160px;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.cs-chat-launcher__bubble { width: 52px; height: 52px; }
	.cs-chat {
		right: 12px;
		left: 12px;
		width: auto;
		max-width: none;
		bottom: 80px;
		height: auto;                          /* size to content (4 chips don't need a full screen) */
		max-height: calc(100vh - 100px);       /* but never exceed viewport */
	}
}

/* Customizer adjustments */
.customize-partial-edit-shortcut { z-index: 5; }
