/* ============================================ */
/* === INNER PAGES (Weddings / Conferences /  === */
/* === Banquets / Venue detail)              === */
/* ============================================ */

/* === Inner Hero (more compact than home hero) === */
.inner-hero {
  position: relative;
  min-height: 78vh;
  display: grid;
  align-items: end;
  overflow: hidden;
  isolation: isolate;
  color: var(--on-dark);
}
.inner-hero__media { position: absolute; inset: 0; z-index: -2; }
.inner-hero__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  animation: heroZoom 18s var(--ease-out) forwards;
}
.inner-hero__media::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(15,15,14,.55) 0%, rgba(15,15,14,.20) 30%, rgba(15,15,14,.55) 70%, rgba(15,15,14,.92) 100%),
    radial-gradient(ellipse 80% 60% at 25% 70%, rgba(15,15,14,.45) 0%, rgba(15,15,14,0) 70%);
  z-index: 1;
}
.inner-hero__inner {
  padding: 180px 0 80px;
  display: grid;
  grid-template-columns: 1.5fr auto;
  gap: 48px;
  align-items: end;
  width: 100%;
}
.inner-hero__title-wrap { display: flex; flex-direction: column; gap: 24px; max-width: 800px; }
.inner-hero__crumbs {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
.inner-hero__crumbs a { transition: color var(--dur-fast) var(--ease); }
.inner-hero__crumbs a:hover { color: var(--on-dark); }
.inner-hero__crumbs::before {
  content: '';
  width: 28px; height: 1px;
  background: currentColor;
  opacity: .6;
}
.inner-hero__title {
  font-size: clamp(48px, 8vw, 100px);
  font-weight: 200;
  line-height: 0.96;
  letter-spacing: -0.035em;
  color: var(--on-dark);
  text-shadow: 0 2px 24px rgba(0,0,0,.35);
}
.inner-hero__title em { font-style: italic; color: var(--on-dark-mute); font-weight: 200; }
.inner-hero__lead {
  max-width: 560px;
  font-size: var(--fs-lg);
  line-height: 1.55;
  color: rgba(244,240,232,.92);
  font-weight: 300;
  text-shadow: 0 1px 12px rgba(0,0,0,.45);
}
.inner-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 8px; }

.inner-hero__stats {
  display: flex;
  gap: 40px;
  align-items: end;
}
.inner-hero__stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.inner-hero__stat-label {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--on-dark-mute);
}
.inner-hero__stat-value {
  font-size: clamp(28px, 3vw, 48px);
  font-weight: 200;
  letter-spacing: var(--tracking-tight);
  color: var(--on-dark);
}

@media (max-width: 900px) {
  .inner-hero__inner { grid-template-columns: 1fr; padding: 140px 0 80px; }
  .inner-hero__stats { flex-wrap: wrap; gap: 28px; }
}

/* === Filter row === */
.filter {
  background: var(--bg-elevated);
  border-radius: var(--r-xl);
  padding: 32px;
  display: grid;
  grid-template-columns: repeat(4, 1fr) auto;
  gap: 20px;
  align-items: end;
  border: 1px solid var(--line);
  margin-bottom: 64px;
}
.filter__field { display: flex; flex-direction: column; gap: 8px; }
.filter__label {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.filter__select,
.filter__input {
  width: 100%;
  padding: 12px 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  background: transparent;
  font-size: var(--fs-md);
  color: var(--ink);
  outline: none;
  font-family: inherit;
  transition: border-color var(--dur-fast) var(--ease);
}
.filter__select { appearance: none; -webkit-appearance: none; padding-right: 24px; cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='1.5'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
}
.filter__select:focus,
.filter__input:focus { border-color: var(--ink); }
.filter__submit {
  height: 48px;
  padding: 0 28px;
  border-radius: var(--r-pill);
  background: var(--ink);
  color: var(--bg);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  font-weight: 500;
  transition: background var(--dur-fast) var(--ease);
}
.filter__submit:hover { background: var(--accent); }

@media (max-width: 1100px) {
  .filter { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .filter { grid-template-columns: 1fr; padding: 24px; }
}

/* === Venue grid (more cards on inner pages) === */
.venue-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.venue-grid .venue {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  background: var(--bg-section);
  isolation: isolate;
  cursor: pointer;
  min-height: 460px;
}

@media (max-width: 1000px) {
  .venue-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .venue-grid { grid-template-columns: 1fr; }
}

/* === Packages === */
.packages {
  background: var(--bg-section);
}
.packages__head {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 56px;
  max-width: 720px;
}
.packages__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.package {
  background: var(--bg-elevated);
  border: 1px solid var(--line);
  border-radius: var(--r-xl);
  padding: 40px 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  position: relative;
  transition: border-color var(--dur-md) var(--ease), transform var(--dur-md) var(--ease), background var(--dur-md) var(--ease);
}
.package:hover { border-color: var(--accent); transform: translateY(-4px); }
.package--featured {
  background: var(--bg-dark);
  color: var(--on-dark);
  border-color: var(--bg-dark);
}
.package--featured:hover { background: var(--ink); }

.package__badge {
  position: absolute;
  top: 24px; right: 24px;
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: var(--accent);
  color: var(--accent-ink);
  font-weight: 500;
}

.package__head { display: flex; flex-direction: column; gap: 8px; }
.package__num {
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.package--featured .package__num { color: var(--on-dark-mute); }
.package__name {
  font-size: clamp(28px, 2.6vw, 36px);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: var(--tracking-tight);
}
.package--featured .package__name { color: var(--on-dark); }
.package__price {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding-block: 16px;
  border-block: 1px solid var(--line);
}
.package--featured .package__price { border-color: rgba(255,255,255,.15); }
.package__price-num {
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 200;
  letter-spacing: -0.02em;
}
.package__price-unit {
  font-size: var(--fs-sm);
  color: var(--ink-mute);
}
.package--featured .package__price-unit { color: var(--on-dark-mute); }

.package__list { display: flex; flex-direction: column; gap: 12px; flex: 1; }
.package__list li {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 14px;
  align-items: baseline;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: 1.5;
}
.package--featured .package__list li { color: rgba(244,240,232,.85); }
.package__list li::before {
  content: '';
  width: 12px; height: 1px;
  background: var(--accent);
  align-self: center;
}
.package--featured .package__list li::before { background: var(--on-dark); }

.package__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 14px 24px;
  border-radius: var(--r-pill);
  background: var(--ink);
  color: var(--bg);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  font-weight: 500;
  align-self: flex-start;
  transition: gap var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.package__cta:hover { gap: 18px; background: var(--accent); color: var(--accent-ink); }
.package--featured .package__cta { background: var(--bg); color: var(--ink); }
.package--featured .package__cta:hover { background: var(--accent); color: var(--accent-ink); }

@media (max-width: 900px) {
  .packages__grid { grid-template-columns: 1fr; }
}

/* === Outdoor registration / Special block === */
.special {
  position: relative;
  border-radius: var(--r-xl);
  overflow: hidden;
  isolation: isolate;
  padding: 80px;
  min-height: 480px;
  display: flex;
  align-items: end;
  color: var(--on-dark);
}
.special__bg { position: absolute; inset: 0; z-index: -2; }
.special__bg img { width: 100%; height: 100%; object-fit: cover; }
.special::after {
  content: '';
  position: absolute; inset: 0;
  z-index: -1;
  background: linear-gradient(135deg, rgba(15,15,14,.85) 0%, rgba(15,15,14,.45) 50%, rgba(15,15,14,.7) 100%);
}
.special__inner { display: flex; flex-direction: column; gap: 24px; max-width: 640px; }
.special__title {
  font-size: clamp(32px, 4vw, 56px);
  font-weight: 200;
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--on-dark);
}
.special__title em { font-style: italic; color: rgba(244,240,232,.7); }
.special__lead { font-size: var(--fs-md); line-height: 1.6; color: rgba(244,240,232,.85); max-width: 480px; }
.special__list { display: flex; flex-wrap: wrap; gap: 14px; }
.special__list li {
  padding: 8px 14px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(255,255,255,.25);
  font-size: var(--fs-sm);
  color: rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background: rgba(255,255,255,.06);
}

@media (max-width: 700px) {
  .special { padding: 48px 28px; min-height: 380px; }
}

/* === Menu (wedding-specific) === */
.menu-section { background: var(--bg); }
.menu-section__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.menu-section__visual {
  border-radius: var(--r-xl);
  overflow: hidden;
  aspect-ratio: 4 / 5;
}
.menu-section__visual img { width: 100%; height: 100%; object-fit: cover; }
.menu-section__text { display: flex; flex-direction: column; gap: 24px; }
.menu-section__categories { display: flex; flex-direction: column; gap: 16px; }
.menu-cat {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.menu-cat__name { font-size: var(--fs-lg); font-weight: 400; letter-spacing: var(--tracking-tight); }
.menu-cat__price { font-size: var(--fs-md); color: var(--ink-mute); white-space: nowrap; }

@media (max-width: 900px) {
  .menu-section__inner { grid-template-columns: 1fr; gap: 32px; }
}

/* === Gallery (portfolio) === */
.gallery { background: var(--bg-dark); color: var(--on-dark); }
.gallery .t-eyebrow { color: var(--on-dark-mute); }
.gallery__head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 32px;
  margin-bottom: 56px;
}
.gallery__title {
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 200;
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--on-dark);
  display: flex; flex-direction: column; gap: 16px;
}
.gallery__title em { font-style: italic; color: var(--on-dark-mute); }

.gallery__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 220px;
  gap: 12px;
}
.gallery__item {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  isolation: isolate;
}
.gallery__item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease), filter var(--dur-md) var(--ease);
  filter: saturate(0.9) brightness(0.95);
}
.gallery__item:hover img { transform: scale(1.05); filter: saturate(1) brightness(1); }
.gallery__item--lg { grid-column: span 3; grid-row: span 2; }
.gallery__item--md { grid-column: span 2; grid-row: span 2; }
.gallery__item--sm { grid-column: span 2; grid-row: span 1; }
.gallery__item--w3 { grid-column: span 3; }
.gallery__item--w4 { grid-column: span 4; }

@media (max-width: 1000px) {
  .gallery__grid { grid-template-columns: repeat(4, 1fr); }
  .gallery__item--lg { grid-column: span 4; grid-row: span 1; }
  .gallery__item--md, .gallery__item--sm { grid-column: span 2; }
}
@media (max-width: 600px) {
  .gallery__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
  .gallery__item, .gallery__item--lg, .gallery__item--md, .gallery__item--sm { grid-column: span 2; grid-row: span 1; }
}

/* === Inner CTA banner === */
.inner-cta {
  background: var(--bg-dark);
  color: var(--on-dark);
  padding: 80px;
  border-radius: var(--r-xl);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  align-items: center;
}
.inner-cta__title {
  font-size: clamp(32px, 4vw, 56px);
  font-weight: 200;
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}
.inner-cta__title em { font-style: italic; color: var(--on-dark-mute); }
.inner-cta__lead { font-size: var(--fs-md); line-height: 1.6; color: var(--on-dark-mute); margin-top: 20px; max-width: 520px; }
.inner-cta__actions { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }

@media (max-width: 900px) {
  .inner-cta { grid-template-columns: 1fr; padding: 48px 28px; }
}

/* === Venue detail page === */
.venue-hero {
  position: relative;
  min-height: 70vh;
  overflow: hidden;
  isolation: isolate;
  color: var(--on-dark);
  display: grid;
  align-items: end;
}
.venue-hero__media { position: absolute; inset: 0; z-index: -2; }
.venue-hero__media img { width: 100%; height: 100%; object-fit: cover; animation: heroZoom 18s var(--ease-out) forwards; }
.venue-hero__media::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(15,15,14,.45) 0%, rgba(15,15,14,.20) 30%, rgba(15,15,14,.85) 100%);
  z-index: 1;
}
.venue-hero__inner {
  padding: 160px 0 64px;
  display: grid;
  grid-template-columns: 1.4fr auto;
  gap: 32px;
  align-items: end;
}
.venue-hero__title-wrap { display: flex; flex-direction: column; gap: 18px; max-width: 720px; }
.venue-hero__city {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--r-pill);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  align-self: flex-start;
}
.venue-hero__city::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 3px rgba(61,79,63,.3); }
.venue-hero__title {
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 200;
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--on-dark);
  text-shadow: 0 2px 24px rgba(0,0,0,.35);
}
.venue-hero__lead { font-size: var(--fs-lg); line-height: 1.55; color: rgba(244,240,232,.92); max-width: 560px; }

.venue-hero__specs {
  display: flex; flex-direction: column; gap: 18px;
  text-align: right;
}
.venue-hero__spec { display: flex; flex-direction: column; gap: 4px; }
.venue-hero__spec-label { font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--on-dark-mute); }
.venue-hero__spec-value { font-size: var(--fs-2xl); font-weight: 200; color: var(--on-dark); }

@media (max-width: 900px) {
  .venue-hero__inner { grid-template-columns: 1fr; padding: 130px 0 60px; }
  .venue-hero__specs { text-align: left; flex-direction: row; flex-wrap: wrap; gap: 28px; }
}

/* === Venue detail body grid === */
.venue-body {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 48px;
}
.venue-body__main { display: flex; flex-direction: column; gap: 64px; }
.venue-body__side { position: sticky; top: 100px; align-self: start; display: flex; flex-direction: column; gap: 24px; }

.spec-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  padding: 32px 0;
  border-block: 1px solid var(--line);
}
.spec-item { display: flex; flex-direction: column; gap: 6px; }
.spec-item__label { font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--ink-mute); }
.spec-item__value { font-size: var(--fs-xl); font-weight: 300; }

.feature-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.feature-list li {
  display: grid; grid-template-columns: 32px 1fr; gap: 12px; align-items: center;
  font-size: var(--fs-md);
}
.feature-list li::before {
  content: '';
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%233D4F3F' stroke-width='2'><polyline points='20 6 9 17 4 12'/></svg>") no-repeat center / 12px;
}

.layout-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.layout-card {
  background: var(--bg-elevated);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  text-align: center;
}
.layout-card svg { color: var(--ink-mute); }
.layout-card__name { font-size: var(--fs-sm); font-weight: 500; }
.layout-card__cap { font-size: var(--fs-xs); color: var(--ink-mute); letter-spacing: var(--tracking-wider); text-transform: uppercase; }

.side-card {
  background: var(--bg-elevated);
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.side-card__price { display: flex; align-items: baseline; gap: 8px; }
.side-card__price-num { font-size: clamp(28px, 3vw, 36px); font-weight: 200; letter-spacing: var(--tracking-tight); }
.side-card__price-unit { font-size: var(--fs-sm); color: var(--ink-mute); }
.side-card__cta { width: 100%; justify-content: center; }
.side-card__divider { height: 1px; background: var(--line); }
.side-card__contact { display: flex; flex-direction: column; gap: 6px; }
.side-card__contact-label { font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--ink-mute); }
.side-card__contact-value { font-size: var(--fs-md); }

@media (max-width: 900px) {
  .venue-body { grid-template-columns: 1fr; }
  .venue-body__side { position: static; }
  .spec-grid { grid-template-columns: repeat(2, 1fr); }
  .feature-list { grid-template-columns: 1fr; }
  .layout-grid { grid-template-columns: repeat(2, 1fr); }
}

/* === Page intro: simple eyebrow + title block on inner pages === */
.section-intro {
  margin-bottom: 56px;
  display: flex; flex-direction: column; gap: 16px;
  max-width: 720px;
}
.section-intro__title {
  font-size: clamp(32px, 4.5vw, 56px);
  font-weight: 200;
  line-height: 1.05;
  letter-spacing: var(--tracking-tight);
}
.section-intro__title em { font-style: italic; color: var(--ink-mute); font-weight: 200; }
.section-intro__lead {
  font-size: var(--fs-md);
  line-height: 1.7;
  color: var(--ink-soft);
  max-width: 640px;
}

/* === Adv-style blocks for inner pages (advantages summary) === */
.summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.summary__card {
  padding: 32px 28px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--bg-elevated);
  display: flex; flex-direction: column; gap: 14px;
  min-height: 220px;
  transition: border-color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), transform var(--dur-fast) var(--ease);
}
.summary__card:hover { border-color: var(--accent); transform: translateY(-2px); }
.summary__num {
  font-size: var(--fs-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--accent); font-weight: 500;
}
.summary__title {
  font-size: var(--fs-lg); font-weight: 400; letter-spacing: var(--tracking-tight); line-height: 1.3;
}
.summary__hint { font-size: var(--fs-sm); color: var(--ink-mute); line-height: 1.5; margin-top: auto; }

@media (max-width: 1000px) { .summary { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .summary { grid-template-columns: 1fr; } }
