﻿:root {
  --ink: #2a211b;
  --muted: #65584f;
  --soft: #fffaf4;
  --cream: #f8ecda;
  --surface: #fffdf8;
  --cocoa: #5b3528;
  --cocoa-deep: #342018;
  --rose: #bd5c71;
  --rose-deep: #7d3344;
  --gold: #b98237;
  --gold-soft: #ead1a7;
  --aqua: #2f9aa0;
  --violet: #7563b8;
  --leaf: #5f8c61;
  --line: rgba(91, 53, 40, 0.16);
  --glass: rgba(255, 253, 248, 0.78);
  --glass-strong: rgba(255, 253, 248, 0.92);
  --shadow: 0 24px 72px rgba(55, 34, 24, 0.15);
  --shadow-soft: 0 14px 42px rgba(55, 34, 24, 0.10);
  --radius: 8px;
  --max: 1180px;
  --header-height: 82px;
}

/* Phase 8I final UI corrections: hero rails, icons, catalogue, gallery, and contact polish */
:root {
  --icon-whatsapp: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M12.04 2.2a9.72 9.72 0 0 0-8.39 14.62L2.6 21.8l5.1-1.34a9.72 9.72 0 1 0 4.34-18.26Zm0 1.84a7.88 7.88 0 0 1 6.67 12.08 7.88 7.88 0 0 1-9.8 2.69l-.37-.2-3.04.8.81-2.95-.23-.39A7.88 7.88 0 0 1 12.04 4.04Zm-3.22 3.9c-.18 0-.48.07-.73.36-.25.29-.96.94-.96 2.29 0 1.34.98 2.64 1.12 2.82.14.19 1.9 3.04 4.66 4.13 2.3.9 2.77.72 3.28.68.5-.05 1.62-.66 1.85-1.31.23-.64.23-1.2.16-1.31-.07-.12-.26-.19-.54-.33l-1.6-.78c-.28-.14-.48-.21-.68.08-.2.3-.78.98-.96 1.18-.18.2-.35.22-.65.08-.3-.15-1.24-.46-2.36-1.45-.88-.78-1.47-1.75-1.64-2.04-.17-.3-.02-.46.13-.61.13-.13.29-.35.44-.52.15-.18.2-.3.3-.5.1-.2.05-.37-.03-.52L9.9 8.56c-.2-.47-.4-.61-.7-.62h-.38Z'/%3E%3C/svg%3E");
  --icon-call: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.9v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.2 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.12.9.32 1.77.6 2.61a2 2 0 0 1-.45 2.11L8 9.71A16 16 0 0 0 14.29 16l1.27-1.27a2 2 0 0 1 2.11-.45c.84.28 1.71.48 2.61.6A2 2 0 0 1 22 16.9Z'/%3E%3C/svg%3E");
  --icon-instagram: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3.4' y='3.4' width='17.2' height='17.2' rx='5.1'/%3E%3Ccircle cx='12' cy='12' r='4'/%3E%3Ccircle cx='17.4' cy='6.6' r='1.1' fill='white' stroke='none'/%3E%3C/svg%3E");
  --icon-facebook: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M15.1 8.1h2.35V4.28C17.05 4.22 15.75 4 14.35 4c-2.9 0-4.86 1.8-4.86 5.08v2.76H6.24v4.23h3.25V24h4.24v-7.93h3.26l.5-4.23h-3.76V9.5c0-1.03.28-1.4 1.37-1.4Z'/%3E%3C/svg%3E");
  --icon-youtube: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9.6 8.2v7.6l6.55-3.8L9.6 8.2Z'/%3E%3C/svg%3E");
}

.hero.hero-motion {
  min-height: 790px !important;
  padding: 118px 0 96px !important;
}

.hero-motion-bg {
  inset: 110px 0 100px !important;
  display: flex !important;
  flex-direction: column;
  justify-content: space-between;
  align-content: normal !important;
  gap: clamp(230px, 31vh, 330px) !important;
  opacity: 0.74 !important;
}

.hero-motion-row,
.hero-motion-row.is-reverse {
  transform: none !important;
}

.hero-motion-track {
  gap: clamp(18px, 2vw, 34px) !important;
}

.hero-motion-row.is-rectangles .hero-motion-item {
  width: clamp(250px, 23vw, 390px) !important;
  height: clamp(150px, 13vw, 222px) !important;
  min-height: 0 !important;
  aspect-ratio: 16 / 9;
}

.hero-motion-row.is-squares .hero-motion-item {
  width: clamp(145px, 15vw, 235px) !important;
  height: clamp(145px, 15vw, 235px) !important;
  min-height: 0 !important;
  aspect-ratio: 1 / 1;
}

.hero-motion-item {
  padding: 8px !important;
  border-radius: 16px !important;
  background: rgba(255, 253, 248, 0.82) !important;
}

.hero-motion-item img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  border-radius: 11px !important;
}

.hero-motion .hero-content {
  width: min(930px, calc(100% - 32px)) !important;
  padding: 0 18px !important;
}

.hero-motion h1 {
  max-width: 860px !important;
  font-size: clamp(54px, 6.2vw, 94px) !important;
  line-height: 0.94 !important;
}

.hero-motion p {
  max-width: 760px !important;
  font-size: clamp(18px, 1.55vw, 23px) !important;
}

.hero-motion .hero-actions {
  margin-top: 22px !important;
}

.hero-motion .trust-row {
  margin-top: 28px !important;
}

.trust-item strong,
.trust-item .stat-number {
  display: inline !important;
  font-family: var(--font-display) !important;
  font-size: clamp(30px, 3vw, 44px) !important;
  font-weight: 800;
  line-height: 1;
}

.sweet-marquee {
  display: none !important;
}

.product-card {
  grid-template-rows: 230px 1fr !important;
}

.product-card .product-media {
  height: 230px !important;
  min-height: 230px !important;
  padding: 10px !important;
}

.product-card .product-media img,
.product-card img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
}

.product-card .image-card-body {
  min-height: 168px !important;
}

.gallery-mosaic-uniform {
  align-items: stretch !important;
}

.gallery-mosaic-uniform figure {
  height: 100%;
}

.gallery-mosaic-uniform .media-zoom {
  height: 270px !important;
  padding: 10px !important;
  display: grid !important;
  place-items: center;
}

.gallery-mosaic-uniform img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
}

.info-strip .info-card {
  min-height: 96px;
  padding: 18px 20px;
}

.info-card strong {
  font-family: var(--font-body) !important;
  font-size: clamp(17px, 1.35vw, 22px) !important;
  font-weight: 900;
  letter-spacing: 0.01em;
}

.info-card p {
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.social-icon {
  position: relative;
}

.social-icon .icon {
  display: none !important;
}

.social-icon::before,
.btn-accent[href*="wa.me"]::before,
.quick-view-btn::before,
.floating-actions .icon-btn::after {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.social-instagram::before {
  background-image: var(--icon-instagram);
}

.social-facebook::before {
  background-image: var(--icon-facebook);
}

.social-youtube::before {
  background-image: var(--icon-youtube);
}

.social-threads::before {
  content: "@";
  width: auto;
  height: auto;
  color: #fff;
  background-image: none;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 28px;
  font-weight: 900;
  line-height: 1;
}

.btn-accent[href*="wa.me"] .brand-icon,
.quick-view-btn .brand-icon,
.floating-actions .icon-btn .icon {
  display: none !important;
}

.btn-accent[href*="wa.me"]::before,
.quick-view-btn::before {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  background-image: var(--icon-whatsapp);
}

.quick-view-btn::before {
  width: 15px;
  height: 15px;
  filter: drop-shadow(0 0 0 #128c7e);
}

.floating-actions .icon-btn {
  border-radius: 50% !important;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  background: #25d366 !important;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"]::after {
  width: 31px;
  height: 31px;
  background-image: var(--icon-whatsapp);
}

.floating-actions .icon-btn[aria-label*="call"]::after,
.floating-actions .icon-btn[aria-label*="Call"]::after {
  width: 28px;
  height: 28px;
  background-image: var(--icon-call);
}

@media (max-width: 960px) {
  .hero.hero-motion {
    min-height: 760px !important;
  }

  .hero-motion-bg {
    inset: 100px 0 96px !important;
    gap: 260px !important;
  }

  .hero-motion-row.is-rectangles .hero-motion-item {
    width: 230px !important;
    height: 136px !important;
  }

  .hero-motion-row.is-squares .hero-motion-item {
    width: 148px !important;
    height: 148px !important;
  }
}

@media (max-width: 680px) {
  .hero.hero-motion {
    min-height: 780px !important;
    padding: 68px 0 54px !important;
  }

  .hero-motion-bg {
    inset: 92px 0 76px !important;
    gap: 330px !important;
    opacity: 0.58 !important;
  }

  .hero-motion h1 {
    font-size: clamp(34px, 10vw, 46px) !important;
  }

  .hero-motion p br {
    display: none;
  }

  .product-card {
    grid-template-rows: 215px 1fr !important;
  }

  .product-card .product-media {
    height: 215px !important;
    min-height: 215px !important;
  }

  .gallery-mosaic-uniform .media-zoom {
    height: 238px !important;
  }
}

.info-strip {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
}

.info-card strong {
  overflow-wrap: anywhere !important;
  word-break: normal;
}

/* Phase 8R homepage signature image frame correction */
body.home-redesign .home-signature-section .center-story {
  align-items: center !important;
}

body.home-redesign .home-signature-section .content-block {
  max-width: 520px;
}

body.home-redesign .home-signature-section .story-media {
  display: block !important;
  width: min(620px, 100%) !important;
  padding: 0 !important;
  aspect-ratio: 3 / 2;
  overflow: hidden !important;
  border: 1px solid rgba(185, 130, 55, 0.26) !important;
  border-radius: 28px !important;
  outline: 10px solid rgba(255, 253, 248, 0.9);
  background: rgba(255, 253, 248, 0.9) !important;
  box-shadow: 0 26px 78px rgba(72, 49, 33, 0.13);
}

body.home-redesign .home-signature-section .story-media img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  aspect-ratio: auto !important;
  border-radius: inherit !important;
  object-fit: cover !important;
}

@media (max-width: 1080px) {
  body.home-redesign .home-signature-section .content-block,
  body.home-redesign .home-signature-section .story-media {
    max-width: 720px;
    margin-inline: auto;
  }
}

@media (max-width: 680px) {
  body.home-redesign .home-signature-section .story-media {
    border-radius: 22px !important;
    outline-width: 7px;
  }
}

/* Phase 8P homepage reference-inspired finish */
body.home-redesign {
  background:
    radial-gradient(circle at 8% 4%, rgba(255, 220, 152, 0.26), transparent 26%),
    radial-gradient(circle at 92% 8%, rgba(47, 154, 160, 0.10), transparent 28%),
    linear-gradient(180deg, #fffaf2 0%, #f8efe2 44%, #fffaf4 100%);
}

body.home-redesign .site-header {
  background: rgba(255, 250, 242, 0.86);
  border-bottom-color: rgba(176, 121, 52, 0.18);
  box-shadow: 0 16px 44px rgba(72, 49, 33, 0.08);
  backdrop-filter: blur(18px);
}

body.home-redesign .home-atelier {
  min-height: auto !important;
  padding: clamp(62px, 7vw, 92px) 0 clamp(56px, 7vw, 88px) !important;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 20%, rgba(246, 202, 111, 0.24), transparent 26%),
    radial-gradient(circle at 84% 22%, rgba(95, 140, 97, 0.13), transparent 26%),
    linear-gradient(135deg, #fffdf8 0%, #fbf1df 54%, #fff8ed 100%);
}

body.home-redesign .home-atelier::before,
body.home-redesign .home-atelier::after {
  content: "";
  position: absolute;
  pointer-events: none;
  border-radius: 999px;
}

body.home-redesign .home-atelier::before {
  width: 520px;
  height: 520px;
  right: -170px;
  top: 90px;
  background: radial-gradient(circle, rgba(185, 130, 55, 0.18), transparent 68%);
}

body.home-redesign .home-atelier::after {
  width: 420px;
  height: 420px;
  left: -190px;
  bottom: -160px;
  background: radial-gradient(circle, rgba(47, 154, 160, 0.12), transparent 67%);
}

body.home-redesign .home-atelier .hero-motion-bg {
  display: none !important;
}

body.home-redesign .home-atelier .hero-layout {
  position: relative;
  z-index: 1;
  display: grid !important;
  grid-template-columns: minmax(0, 0.92fr) minmax(360px, 1.08fr);
  align-items: center;
  gap: clamp(34px, 5vw, 78px);
}

body.home-redesign .home-atelier .hero-content {
  width: auto !important;
  max-width: 640px !important;
  padding: clamp(28px, 4vw, 46px) !important;
  text-align: left !important;
  border: 1px solid rgba(185, 130, 55, 0.18);
  border-radius: 28px;
  background: rgba(255, 253, 248, 0.72);
  box-shadow: 0 30px 90px rgba(72, 49, 33, 0.10);
  backdrop-filter: blur(18px);
}

body.home-redesign .home-atelier .kicker {
  width: max-content;
  margin: 0 0 18px !important;
  padding: 9px 16px;
  border: 1px solid rgba(185, 130, 55, 0.22);
  border-radius: 999px;
  background: rgba(255, 250, 242, 0.92);
}

body.home-redesign .home-atelier h1.hero-brand-title {
  max-width: 620px !important;
  margin: 0 !important;
  font-size: clamp(50px, 5.3vw, 82px) !important;
  line-height: 0.93 !important;
  color: #43281f;
}

body.home-redesign .home-atelier .hero-title-prefix {
  font-size: 0.74em !important;
  letter-spacing: 0.03em;
}

body.home-redesign .home-atelier .hero-title-main {
  margin-top: 7px;
}

body.home-redesign .home-atelier p {
  max-width: 560px !important;
  margin: 24px 0 0 !important;
  color: rgba(64, 48, 39, 0.84);
  font-size: clamp(17px, 1.35vw, 21px) !important;
  line-height: 1.72 !important;
}

body.home-redesign .home-atelier .hero-actions {
  justify-content: flex-start !important;
  margin-top: 26px !important;
}

body.home-redesign .home-atelier .hero-actions .btn {
  min-height: 52px;
  border-radius: 999px;
}

body.home-redesign .home-atelier .trust-row {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px !important;
  margin-top: 30px !important;
}

body.home-redesign .home-atelier .trust-item {
  min-height: 116px;
  padding: 18px 18px 16px !important;
  border: 1px solid rgba(185, 130, 55, 0.17);
  border-radius: 20px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(246, 232, 205, 0.42));
  box-shadow: 0 16px 40px rgba(72, 49, 33, 0.08);
}

body.home-redesign .home-atelier .trust-item span:last-child {
  color: rgba(80, 63, 52, 0.78);
  font-size: 13px;
  line-height: 1.4;
}

.home-hero-showcase {
  position: relative;
  min-height: clamp(520px, 56vw, 680px);
  isolation: isolate;
}

.home-showcase-card {
  position: absolute;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(185, 130, 55, 0.24);
  border-radius: 28px;
  background: rgba(255, 253, 248, 0.86);
  box-shadow: 0 28px 80px rgba(72, 49, 33, 0.16);
  outline: 10px solid rgba(255, 253, 248, 0.88);
}

.home-showcase-card img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
  background: rgba(255, 250, 242, 0.94);
}

.home-showcase-main {
  top: clamp(72px, 8vw, 104px);
  right: clamp(16px, 2.5vw, 34px);
  width: clamp(440px, 43vw, 610px);
  aspect-ratio: 3 / 2;
  z-index: 2;
}

.home-showcase-small {
  z-index: 3;
}

.home-showcase-small.is-top {
  top: clamp(8px, 1.2vw, 18px);
  right: 0;
  width: clamp(178px, 18vw, 250px);
  aspect-ratio: 4 / 3;
}

.home-showcase-small.is-bottom {
  left: clamp(6px, 1vw, 18px);
  bottom: clamp(72px, 8vw, 118px);
  width: clamp(180px, 20vw, 270px);
  aspect-ratio: 3 / 2;
}

.home-showcase-note {
  position: absolute;
  z-index: 4;
  right: clamp(20px, 4vw, 54px);
  bottom: clamp(26px, 4vw, 62px);
  max-width: 255px;
  padding: 18px 20px;
  border: 1px solid rgba(185, 130, 55, 0.22);
  border-radius: 22px;
  background: rgba(255, 253, 248, 0.9);
  box-shadow: 0 24px 70px rgba(72, 49, 33, 0.14);
  backdrop-filter: blur(12px);
}

.home-showcase-note strong {
  display: block;
  color: var(--cocoa);
  font-family: var(--font-display);
  font-size: 25px;
  line-height: 1.04;
}

.home-showcase-note span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-weight: 700;
}

body.home-redesign .section {
  position: relative;
}

body.home-redesign .home-signature-section {
  background:
    linear-gradient(180deg, rgba(255, 250, 242, 0.92), rgba(255, 253, 248, 0.96));
}

body.home-redesign .center-story {
  grid-template-columns: minmax(0, 0.88fr) minmax(360px, 1.12fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: center;
}

body.home-redesign .center-story .content-block {
  padding: clamp(26px, 4vw, 42px);
  border: 1px solid rgba(185, 130, 55, 0.18);
  border-radius: 28px;
  background: rgba(255, 253, 248, 0.78);
  box-shadow: 0 22px 62px rgba(72, 49, 33, 0.09);
}

body.home-redesign .story-media {
  position: relative;
  border-radius: 30px;
  background: linear-gradient(145deg, rgba(255, 253, 248, 0.94), rgba(246, 232, 205, 0.58));
}

body.home-redesign .story-media img {
  border-radius: 22px;
  object-fit: cover;
  aspect-ratio: 4 / 3;
}

body.home-redesign .home-collection-section,
body.home-redesign .home-contact-section {
  background:
    radial-gradient(circle at 85% 15%, rgba(47, 154, 160, 0.08), transparent 28%),
    linear-gradient(180deg, #fff9ef, #f6ead8);
}

body.home-redesign .section-header-centered {
  max-width: 780px;
  margin-inline: auto;
  text-align: center;
}

body.home-redesign .section-header-centered .section-lead {
  margin-inline: auto;
}

body.home-redesign .home-collection-section .grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
}

body.home-redesign .home-collection-section .product-card {
  border-radius: 24px;
  background: rgba(255, 253, 248, 0.92);
  box-shadow: 0 22px 62px rgba(72, 49, 33, 0.10);
  transition: transform 220ms ease, box-shadow 220ms ease;
}

body.home-redesign .home-collection-section .product-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 34px 82px rgba(72, 49, 33, 0.16);
}

body.home-redesign .home-collection-section .product-media {
  border-radius: 20px 20px 0 0;
  background: #fffdf8;
}

body.home-redesign .home-path-section .grid-3 {
  align-items: stretch;
}

body.home-redesign .home-path-section .image-card {
  border-radius: 26px;
  box-shadow: 0 22px 64px rgba(72, 49, 33, 0.10);
}

body.home-redesign .home-path-section .image-card > img {
  aspect-ratio: 1.14 / 1;
  object-fit: cover;
}

body.home-redesign .contact-route-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.home-redesign .contact-route-card {
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(255, 253, 248, 0.94), rgba(246, 232, 205, 0.52));
  box-shadow: 0 18px 52px rgba(72, 49, 33, 0.09);
}

body.home-redesign .home-map-section .map-card {
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 26px 78px rgba(72, 49, 33, 0.12);
}

body.home-redesign .home-map-section .map-card iframe {
  min-height: 390px;
}

@media (max-width: 1080px) {
  body.home-redesign .home-atelier .hero-layout,
  body.home-redesign .center-story {
    grid-template-columns: 1fr;
  }

  body.home-redesign .home-atelier .hero-content {
    max-width: none !important;
    text-align: center !important;
  }

  body.home-redesign .home-atelier .kicker,
  body.home-redesign .home-atelier .hero-actions {
    margin-inline: auto !important;
    justify-content: center !important;
  }

  .home-hero-showcase {
    min-height: 520px;
  }

  .home-showcase-main {
    top: 74px;
    right: 44px;
    width: min(620px, calc(100% - 88px));
    aspect-ratio: 3 / 2;
  }

  .home-showcase-small.is-top {
    width: min(250px, 36vw);
  }

  .home-showcase-small.is-bottom {
    width: min(270px, 38vw);
    bottom: 52px;
  }

  body.home-redesign .home-collection-section .grid-4,
  body.home-redesign .contact-route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  body.home-redesign .home-atelier {
    padding-top: 76px !important;
  }

  body.home-redesign .home-atelier .hero-content {
    padding: 24px 18px !important;
    border-radius: 22px;
  }

  body.home-redesign .home-atelier h1.hero-brand-title {
    font-size: clamp(46px, 13vw, 64px) !important;
  }

  body.home-redesign .home-atelier p {
    font-size: 16px !important;
  }

  body.home-redesign .home-collection-section .grid-4,
  body.home-redesign .contact-route-grid {
    grid-template-columns: 1fr;
  }

  body.home-redesign .home-atelier .trust-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  body.home-redesign .home-atelier .trust-item {
    min-height: 92px;
    padding: 12px !important;
    border-radius: 16px;
  }

  body.home-redesign .home-atelier .trust-item strong,
  body.home-redesign .home-atelier .trust-item .stat-number {
    font-size: 28px !important;
  }

  body.home-redesign .home-atelier .trust-item span:last-child {
    font-size: 11px;
    line-height: 1.3;
  }

  .home-hero-showcase {
    min-height: 480px;
  }

  .home-showcase-main {
    top: 76px;
    right: 20px;
    width: calc(100% - 40px);
    aspect-ratio: 3 / 2;
  }

  .home-showcase-small.is-top {
    width: 144px;
    aspect-ratio: 4 / 3;
  }

  .home-showcase-small.is-bottom {
    width: 152px;
    aspect-ratio: 3 / 2;
  }

  .home-showcase-small.is-bottom {
    bottom: 82px;
  }

  .home-showcase-note {
    left: 24px;
    right: 24px;
    bottom: 22px;
    max-width: none;
  }

  body.home-redesign .center-story .content-block {
    padding: 24px 18px;
  }
}

.info-card strong {
  overflow-wrap: anywhere;
}

.pr-report-section {
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 184, 77, 0.18), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(248, 242, 231, 0.78));
}

.pr-report-section .section-lead {
  margin-inline: auto;
  text-align: center;
}

.publication-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.publication-card {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  grid-template-areas:
    "logo title"
    "logo label"
    "logo url";
  align-items: start;
  gap: 4px 13px;
  padding: 18px;
  color: var(--ink);
  text-decoration: none;
  min-height: 132px;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.publication-card:hover {
  transform: translateY(-4px);
  border-color: rgba(165, 102, 43, 0.42);
  box-shadow: 0 22px 52px rgba(72, 49, 33, 0.14);
}

.publication-logo {
  grid-area: logo;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  padding: 8px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(165, 102, 43, 0.22);
  box-shadow: 0 10px 24px rgba(72, 49, 33, 0.1);
  object-fit: contain;
}

.publication-card strong {
  grid-area: title;
  font-family: var(--font-display);
  font-size: 20px;
  line-height: 1.12;
}

.publication-card small {
  grid-area: label;
  color: var(--muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.publication-card em {
  grid-area: url;
  display: block;
  max-width: 100%;
  overflow: hidden;
  color: rgba(96, 81, 67, 0.86);
  font-style: normal;
  font-weight: 650;
  font-size: 12px;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 980px) {
  .publication-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

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

/* Phase 8L: awards gallery, exact-aspect WebP frames */
.section-awards {
  background:
    radial-gradient(circle at 14% 8%, rgba(197, 138, 60, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 253, 248, 0.94), rgba(252, 246, 236, 0.84));
}

.awards-gallery {
  column-count: 3;
  column-gap: 24px;
  margin-top: 38px;
}

.award-photo {
  break-inside: avoid;
  display: block;
  margin: 0 0 24px;
}

.award-photo-frame {
  appearance: none;
  background: #fffaf2;
  border: 1px solid rgba(176, 119, 54, 0.38);
  border-radius: 16px;
  box-shadow: 0 18px 44px rgba(62, 39, 28, 0.12);
  cursor: zoom-in;
  display: block;
  overflow: hidden;
  padding: 0;
  transition: box-shadow 180ms ease, transform 180ms ease, border-color 180ms ease;
  width: 100%;
}

.award-photo-frame:hover,
.award-photo-frame:focus-visible {
  border-color: rgba(176, 119, 54, 0.72);
  box-shadow: 0 24px 58px rgba(62, 39, 28, 0.18);
  outline: none;
  transform: translateY(-3px);
}

.award-photo-frame:focus-visible {
  box-shadow: 0 0 0 4px rgba(37, 211, 102, 0.18), 0 24px 58px rgba(62, 39, 28, 0.18);
}

.award-photo-frame img {
  border: 0;
  display: block;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  width: 100% !important;
}

.award-photo figcaption {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.05em;
  margin-top: 9px;
  text-align: center;
  text-transform: uppercase;
}

@media (max-width: 1024px) {
  .awards-gallery {
    column-count: 2;
  }
}

@media (max-width: 680px) {
  .awards-gallery {
    column-count: 1;
    column-gap: 0;
  }

  .award-photo {
    margin-bottom: 20px;
  }
}

/* Phase 8M: Jolbhora story image and long-form origin copy */
.jolbhora-page-hero .page-hero-layout {
  grid-template-columns: minmax(0, 860px) !important;
  justify-content: center;
}

.jolbhora-page-hero .page-hero-content {
  margin-inline: auto;
  text-align: center;
}

.jolbhora-page-hero {
  padding-bottom: 30px;
}

.jolbhora-page-hero + .section {
  padding-top: 28px;
}

.jolbhora-story-feature {
  display: grid;
  gap: 34px;
  justify-items: center;
}

.jolbhora-main-visual {
  width: min(1180px, 100%);
  margin: 0;
  padding: 12px;
  border: 1px solid rgba(176, 119, 54, 0.34);
  border-radius: 18px;
  background: rgba(255, 253, 248, 0.9);
  box-shadow: 0 26px 80px rgba(62, 39, 28, 0.18);
}

.jolbhora-main-visual img {
  display: block;
  width: 100%;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  border-radius: 12px;
}

.jolbhora-story-copy {
  width: min(960px, 100%);
  padding: clamp(26px, 4vw, 46px);
  border: 1px solid rgba(176, 119, 54, 0.24);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.96), rgba(250, 241, 227, 0.82)),
    radial-gradient(circle at 100% 0, rgba(197, 138, 60, 0.12), transparent 34%);
  box-shadow: 0 20px 62px rgba(62, 39, 28, 0.12);
  text-align: center;
}

.jolbhora-story-copy .section-title {
  margin-inline: auto;
}

.story-prose {
  display: grid;
  gap: 16px;
  margin-top: 22px;
  text-align: left;
}

.story-prose p,
.story-note p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.15vw, 19px);
  line-height: 1.85;
}

.story-note {
  margin-top: 26px;
  padding: 22px;
  border: 1px solid rgba(185, 130, 55, 0.24);
  border-radius: 16px;
  background: rgba(255, 248, 235, 0.72);
  text-align: left;
}

.story-note strong {
  display: block;
  margin-bottom: 8px;
  color: var(--cocoa);
  font-family: var(--font-display);
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1.15;
}

@media (max-width: 680px) {
  .jolbhora-main-visual {
    padding: 8px;
    border-radius: 14px;
  }

  .jolbhora-main-visual img {
    border-radius: 10px;
  }

  .jolbhora-story-copy {
    padding: 24px 18px;
  }
}

/* Phase 8I visual safety patch: keep gallery/product thumbnails contained. */
.gallery-mosaic-uniform figure,
.gallery-mosaic-uniform .media-zoom,
.product-card .product-media {
  overflow: hidden !important;
}

.gallery-mosaic-uniform img,
.product-card .product-media img {
  display: block !important;
}

/* Phase 8J homepage title correction. */
.hero-motion h1.hero-brand-title {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  gap: 0.02em;
  text-align: center;
}

.hero-motion h1.hero-brand-title .hero-title-prefix {
  display: block;
  font-size: 0.86em;
  line-height: 0.84;
}

.hero-motion h1.hero-brand-title .hero-title-main {
  display: block;
  line-height: 0.9;
  white-space: nowrap;
}

@media (max-width: 680px) {
  .hero-motion h1.hero-brand-title .hero-title-main {
    white-space: normal;
  }
}

/* Phase 8E visual brand correction */
:root {
  --font-body: "Inter", "Segoe UI", Arial, sans-serif;
  --font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --premium-bg: #fffaf4;
  --premium-mint: #eef9f4;
  --premium-blush: #fff2ef;
  --premium-sky: #f0fbff;
}

body {
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 226, 219, 0.65), transparent 28%),
    radial-gradient(circle at 86% 16%, rgba(225, 247, 241, 0.72), transparent 32%),
    linear-gradient(135deg, #fffdf8 0%, #fff3e7 48%, #f4fbf8 100%);
  font-family: var(--font-body);
}

.brand-title,
.hero h1,
.page-hero h1,
.section h2,
.card h2,
.section-title,
.content-block h3,
.collection-feature-body h3,
.timeline-item strong,
.quote-panel p,
.footer-title,
.modal-content h2 {
  font-family: var(--font-display);
  letter-spacing: 0;
}

.hero h1,
.page-hero h1,
.brand-title {
  max-width: 100%;
  overflow-wrap: break-word;
}

.brand-title {
  font-size: 20px;
}

.kicker {
  gap: 0;
  margin-bottom: 14px;
  color: #7b4832;
  letter-spacing: 0.04em;
}

.kicker::before {
  content: none;
}

.hero.hero-motion {
  min-height: 720px;
  display: grid;
  align-items: center;
  padding: 92px 0 82px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255, 252, 247, 0.6), rgba(255, 244, 232, 0.52)),
    linear-gradient(110deg, #fffaf4, #f4fbf7);
}

.hero-motion::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.92), rgba(255, 253, 248, 0.66) 22%, rgba(255, 253, 248, 0.66) 78%, rgba(255, 253, 248, 0.92)),
    linear-gradient(180deg, rgba(255, 253, 248, 0.14), rgba(255, 253, 248, 0.58));
  pointer-events: none;
}

.hero-motion-bg {
  position: absolute;
  inset: 92px 0 70px;
  z-index: 0;
  display: grid;
  align-content: center;
  gap: 26px;
  opacity: 0.62;
  filter: saturate(0.92) contrast(0.96) brightness(1.06);
}

.hero-motion-row {
  overflow: hidden;
  transform: rotate(-1deg);
}

.hero-motion-row.is-reverse {
  transform: rotate(1deg);
}

.hero-motion-track {
  display: flex;
  align-items: center;
  width: max-content;
  gap: 22px;
  animation: heroSweetRail 54s linear infinite;
}

.hero-motion-row.is-reverse .hero-motion-track {
  animation-name: heroSweetRailReverse;
  animation-duration: 62s;
}

.hero-motion-item {
  display: grid;
  place-items: center;
  width: clamp(160px, 18vw, 330px);
  min-height: 154px;
  margin: 0;
  padding: 10px;
  border: 1px solid rgba(185, 130, 55, 0.16);
  border-radius: 14px;
  background: rgba(255, 253, 248, 0.86);
  box-shadow: 0 18px 54px rgba(55, 34, 24, 0.12);
}

.hero-motion-item img {
  width: auto;
  max-width: 100%;
  max-height: 230px;
  height: auto;
  object-fit: contain;
  border-radius: 10px;
}

.hero-motion .hero-layout {
  z-index: 2;
  display: block;
}

.hero-motion .hero-content {
  width: min(850px, 100%);
  margin-inline: auto;
  text-align: center;
  padding: clamp(28px, 5vw, 58px);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.88), rgba(255, 248, 239, 0.78)),
    linear-gradient(90deg, rgba(47, 154, 160, 0.08), rgba(185, 130, 55, 0.12), rgba(189, 92, 113, 0.08));
  border-color: rgba(185, 130, 55, 0.22);
  box-shadow: 0 34px 100px rgba(52, 32, 24, 0.18);
}

.hero-motion .hero h1,
.hero-motion h1 {
  margin-inline: auto;
  font-size: clamp(44px, 7vw, 82px);
}

.hero-motion p {
  margin-inline: auto;
}

.hero-motion .hero-actions,
.hero-motion .trust-row {
  justify-content: center;
}

.hero-motion .trust-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.btn {
  border-radius: 999px;
  letter-spacing: 0;
}

.btn .icon,
.quick-view-btn .icon {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
}

.btn-accent {
  background: linear-gradient(135deg, #075e54, #128c7e 45%, #25d366);
}

.btn-primary {
  background: linear-gradient(135deg, #6c3c2c, #a76833 54%, #c7964b);
}

.btn-secondary {
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.92), rgba(246, 252, 249, 0.88));
}

.page-hero-layout,
.split-panel,
.collection-grid,
.contact-panel {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
}

.page-hero-content,
.content-block,
.form-intro,
.legal-content {
  margin-inline: auto;
  text-align: center;
}

.page-hero.has-media .page-hero-media,
.split-media,
.story-media {
  width: min(860px, 100%);
  margin-inline: auto;
}

.split-panel.reverse .split-media {
  order: 0;
}

.center-story {
  display: grid;
  justify-items: center;
  gap: 28px;
  text-align: center;
}

.story-media {
  overflow: visible;
  padding: 12px;
  border: 1px solid rgba(185, 130, 55, 0.2);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: var(--shadow);
}

.story-media img {
  width: auto;
  max-width: 100%;
  height: auto;
  margin-inline: auto;
  object-fit: contain;
}

.section-header {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
  gap: 14px;
}

.section-lead {
  margin: 0 auto;
}

.product-card,
.image-card,
.gallery-mosaic figure,
.archive-card,
.legacy-sequence .image-card {
  overflow: visible;
}

.product-card img,
.image-card img,
.gallery-mosaic img,
.archive-card img,
.media-zoom img,
.legacy-sequence img {
  width: auto;
  max-width: 100%;
  height: auto;
  margin-inline: auto;
  object-fit: contain;
}

.product-media {
  display: grid;
  place-items: center;
  min-height: 210px;
  overflow: visible;
}

.product-card .image-card-body,
.image-card .image-card-body {
  text-align: left;
}

.product-card .image-card-body {
  text-align: center;
}

.quick-view-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border-radius: 999px;
}

.sweet-marquee {
  border-radius: 999px;
}

.sweet-marquee-item {
  display: grid;
  place-items: center;
  grid-template-columns: 1fr;
  min-width: 132px;
  padding: 8px;
  border-radius: 999px;
}

.sweet-marquee-item img {
  width: auto;
  max-width: 110px;
  max-height: 86px;
}

.legacy-sequence {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: start;
  gap: 18px;
}

.legacy-sequence .image-card {
  padding: 14px;
}

.legacy-sequence .image-card img {
  max-height: 360px;
}

.archive-grid {
  display: block;
  columns: 4 220px;
  column-gap: 18px;
}

.archive-card {
  display: inline-block;
  width: 100%;
  margin: 0 0 18px;
  break-inside: avoid;
}

.archive-card .media-zoom {
  display: grid;
  place-items: center;
  min-height: 0;
  background: #fff;
}

.archive-card-body {
  text-align: left;
}

.map-card {
  width: min(1060px, 100%);
  margin-inline: auto;
  overflow: hidden;
  border: 1px solid rgba(91, 53, 40, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: var(--shadow);
}

.map-card iframe {
  width: 100%;
  min-height: 360px;
  border: 0;
  display: block;
  filter: saturate(0.9) contrast(0.98);
}

.map-card-body {
  padding: clamp(22px, 4vw, 38px);
  text-align: center;
}

.map-card-body h3 {
  margin: 0;
  color: var(--cocoa);
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.04;
}

.map-card-body p {
  max-width: 700px;
  margin: 12px auto 0;
}

.social-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
}

.social-icon {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 14px 30px rgba(55, 34, 24, 0.16);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.social-icon:hover,
.social-icon:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 18px 38px rgba(55, 34, 24, 0.22);
}

.social-icon span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.social-icon .icon {
  width: 23px;
  height: 23px;
  stroke-width: 1.8;
}

.social-instagram {
  background: radial-gradient(circle at 30% 105%, #fdf497 0 16%, #fd5949 42%, #d6249f 65%, #285aeb 100%);
}

.social-facebook {
  background: #1877f2;
}

.social-threads {
  background: #111;
}

.social-youtube {
  background: #ff0000;
}

.contact-socials {
  justify-content: center;
}

.footer-bottom a {
  color: inherit;
  text-decoration: none;
}

.footer-bottom a:hover,
.footer-bottom a:focus-visible {
  color: var(--cocoa);
  text-decoration: underline;
}

.legal-content {
  width: min(900px, 100%);
  padding: clamp(24px, 5vw, 54px);
  border: 1px solid rgba(91, 53, 40, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: var(--shadow-soft);
}

.legal-content h2,
.legal-content h3 {
  color: var(--cocoa);
  font-family: var(--font-display);
}

.legal-content h2 {
  margin: 0 0 18px;
  font-size: clamp(34px, 5vw, 56px);
  line-height: 1.05;
}

.legal-content h3 {
  margin: 28px 0 8px;
  font-size: 28px;
}

.legal-content p {
  margin: 0 auto 12px;
  max-width: 760px;
}

.floating-actions .icon-btn {
  border-radius: 50%;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  background: #25d366;
}

.floating-actions .icon-btn[aria-label*="call"] {
  background: #a76833;
}

@keyframes heroSweetRail {
  from {
    transform: translateX(-50%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes heroSweetRailReverse {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-motion-track {
    animation: none !important;
  }
}

@media (max-width: 960px) {
  .hero.hero-motion {
    min-height: 680px;
  }

  .hero-motion .trust-row,
  .legacy-sequence {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .archive-grid {
    columns: 2 220px;
  }
}

@media (max-width: 680px) {
  .hero.hero-motion {
    min-height: 640px;
    padding: 58px 0;
  }

  .hero-motion-bg {
    inset: 84px 0 42px;
    gap: 18px;
    opacity: 0.5;
  }

  .hero-motion-item {
    width: 170px;
    min-height: 122px;
  }

  .hero-motion-item img {
    max-height: 132px;
  }

  .hero-motion .trust-row,
  .legacy-sequence {
    grid-template-columns: 1fr;
  }

  .archive-grid {
    columns: 1;
  }

  .floating-actions .icon-btn {
    border-radius: 50%;
  }

  .social-icons {
    justify-content: center;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--ink);
  background:
    linear-gradient(135deg, #fffaf4 0%, #f8ecda 44%, #f5fbf7 100%);
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

::selection {
  color: #ffffff;
  background: var(--cocoa);
}

body.nav-open,
body.modal-open {
  overflow: hidden;
}

img,
svg {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

button,
input,
textarea,
select {
  font: inherit;
}

button {
  cursor: pointer;
}

.skip-link {
  position: absolute;
  top: -48px;
  left: 16px;
  z-index: 1000;
  padding: 10px 14px;
  border-radius: var(--radius);
  color: #ffffff;
  background: var(--cocoa);
  transition: top 0.2s ease;
}

.skip-link:focus {
  top: 16px;
}

.site-shell {
  width: min(var(--max), calc(100% - 32px));
  margin-inline: auto;
}

.site-shell > *,
.grid > *,
.split-panel > *,
.collection-grid > *,
.contact-panel > *,
.info-strip > *,
.archive-grid > *,
.gallery-mosaic > * {
  min-width: 0;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255, 253, 248, 0.82);
  border-bottom: 1px solid transparent;
  backdrop-filter: blur(8px);
  transition: box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.site-header.is-scrolled {
  border-color: var(--line);
  background: rgba(255, 253, 248, 0.94);
  box-shadow: 0 10px 35px rgba(55, 34, 24, 0.09);
}

.header-inner {
  min-height: var(--header-height);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.header-inner.site-shell {
  width: min(1360px, calc(100% - 32px));
}

.brand-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--ink);
  text-decoration: none;
  flex: 0 0 auto;
}

.brand-mark {
  width: 54px;
  height: 54px;
  border-radius: var(--radius);
  box-shadow: 0 10px 28px rgba(55, 34, 24, 0.12);
}

.brand-title {
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.1;
}

.brand-subtitle {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
}

.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
}

.nav-toggle span,
.nav-toggle::before,
.nav-toggle::after {
  content: "";
  display: block;
  width: 20px;
  height: 2px;
  margin: 5px auto;
  background: var(--cocoa);
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.nav-toggle.is-active::before {
  transform: translateY(7px) rotate(45deg);
}

.nav-toggle.is-active span {
  opacity: 0;
}

.nav-toggle.is-active::after {
  transform: translateY(-7px) rotate(-45deg);
}

.site-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  flex: 1 1 auto;
  min-width: 0;
}

.site-nav a {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  padding: 10px 9px;
  border-radius: var(--radius);
  color: var(--muted);
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.2s ease, background 0.2s ease;
}

.site-nav a:hover,
.site-nav a[aria-current="page"] {
  color: var(--cocoa);
  background: linear-gradient(135deg, rgba(234, 209, 167, 0.42), rgba(255, 253, 248, 0.74));
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.btn,
.icon-btn,
.text-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  border-radius: var(--radius);
  font-weight: 800;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.btn {
  padding: 12px 18px;
  border: 1px solid transparent;
}

.btn-primary {
  color: #ffffff;
  background: linear-gradient(135deg, var(--cocoa), #8b5730 52%, var(--gold));
  box-shadow: 0 14px 34px rgba(91, 53, 40, 0.24);
}

.btn-secondary {
  color: var(--cocoa);
  background: rgba(255, 253, 248, 0.86);
  border-color: var(--line);
}

.btn-accent {
  color: #fff;
  background: linear-gradient(135deg, #128c7e, #25d366);
  box-shadow: 0 14px 34px rgba(18, 140, 126, 0.22);
}

.btn:hover,
.icon-btn:hover,
.text-link:hover {
  transform: translateY(-2px);
}

.btn:focus-visible,
.icon-btn:focus-visible,
.text-link:focus-visible,
.site-nav a:focus-visible {
  outline: 3px solid rgba(185, 130, 55, 0.34);
  outline-offset: 3px;
}

.icon-btn {
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  color: var(--cocoa);
  background: rgba(255, 253, 248, 0.84);
}

.icon {
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hero {
  position: relative;
  overflow: visible;
  padding: 76px 0 70px;
  background:
    linear-gradient(135deg, rgba(255, 250, 244, 0.98), rgba(248, 236, 218, 0.86)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.09), rgba(95, 140, 97, 0.08));
}

.hero::before,
.page-hero::before,
.section-soft::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: linear-gradient(120deg, rgba(91, 53, 40, 0.035) 0 1px, transparent 1px 100%);
  background-size: 34px 34px;
  opacity: 0.42;
}

.breadcrumb-nav {
  border-bottom: 1px solid rgba(91, 53, 40, 0.08);
  background: rgba(255, 253, 248, 0.72);
}

.breadcrumb-nav ol {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 14px 0;
  list-style: none;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.breadcrumb-nav li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.breadcrumb-nav li + li::before {
  content: "/";
  color: rgba(91, 53, 40, 0.38);
}

.breadcrumb-nav a {
  color: var(--cocoa);
  text-decoration: none;
}

.breadcrumb-nav a:hover,
.breadcrumb-nav a:focus-visible {
  text-decoration: underline;
}

.hero-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(320px, 1.08fr);
  align-items: center;
  gap: 40px;
}

.hero-media {
  position: relative;
  z-index: 1;
  overflow: visible;
  padding: 12px;
  border: 1px solid rgba(185, 130, 55, 0.24);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: var(--shadow);
}

.hero-media,
.page-hero.has-media .page-hero-media,
.split-media,
.feature-media,
.collection-feature,
.gallery-mosaic figure,
.image-card,
.archive-card {
  outline: 1px solid rgba(255, 253, 248, 0.72);
  outline-offset: -7px;
}

.hero-media img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 6px);
}

.hero-media::after {
  content: none;
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 100%;
  overflow-wrap: break-word;
  padding: 26px;
  border: 1px solid rgba(185, 130, 55, 0.20);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.88), rgba(250, 241, 227, 0.72)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.08), rgba(95, 140, 97, 0.06));
  box-shadow: 0 22px 80px rgba(55, 34, 24, 0.16);
  backdrop-filter: blur(4px);
}

.kicker {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  color: var(--cocoa);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.kicker::before {
  content: "";
  width: 42px;
  height: 3px;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--gold), var(--leaf), var(--aqua));
}

.hero h1,
.page-hero h1 {
  margin: 0;
  max-width: 820px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 68px;
  line-height: 1.02;
  color: var(--cocoa);
  text-shadow: 0 2px 22px rgba(255, 255, 255, 0.78);
}

.hero p,
.page-hero p,
.section-lead {
  max-width: 720px;
  color: var(--muted);
  font-size: 19px;
}

.hero-actions,
.section-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.trust-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 38px;
}

.hero .trust-row {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.trust-item {
  min-height: 112px;
  padding: 18px;
  border: 1px solid rgba(185, 130, 55, 0.20);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.84);
  backdrop-filter: blur(6px);
  box-shadow: var(--shadow-soft);
}

.trust-item strong {
  display: block;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 30px;
  line-height: 1.05;
  color: var(--cocoa);
  overflow-wrap: anywhere;
}

.trust-item span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.section {
  padding: 86px 0;
  position: relative;
}

.section-soft {
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.74), rgba(248, 236, 218, 0.58)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.07), rgba(95, 140, 97, 0.07));
  border-block: 1px solid rgba(91, 53, 40, 0.09);
}

.section-header {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(260px, 0.28fr);
  gap: 36px;
  align-items: end;
  margin-bottom: 36px;
}

.section h2,
.card h2,
.section-title {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 43px;
  line-height: 1.08;
  color: var(--cocoa);
}

.section p {
  color: var(--muted);
}

.grid {
  display: grid;
  gap: 18px;
}

.grid-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.grid-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.card,
.glass-panel,
.form-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--glass);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(6px);
}

.card {
  position: relative;
  padding: 24px;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  border-radius: var(--radius) var(--radius) 0 0;
  background: linear-gradient(90deg, rgba(185, 130, 55, 0.64), rgba(95, 140, 97, 0.44), rgba(47, 154, 160, 0.36));
  opacity: 0;
  transition: opacity 0.2s ease;
}

.card:hover::before {
  opacity: 1;
}

.card:hover {
  transform: translateY(-3px);
  border-color: rgba(185, 130, 55, 0.28);
  background: var(--glass-strong);
  box-shadow: var(--shadow);
}

.card h3 {
  margin: 0;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.2;
}

.card p {
  margin: 12px 0 0;
}

.mini-copy {
  max-width: 760px;
  color: var(--muted);
}

.content-block {
  display: grid;
  gap: 18px;
  max-width: 100%;
  min-width: 0;
}

.content-block h3 {
  margin: 0;
  color: var(--cocoa);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 30px;
  line-height: 1.12;
}

.content-block p {
  margin: 0;
  max-width: 100%;
  overflow-wrap: break-word;
}

.split-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 34px;
  align-items: center;
}

.split-panel.reverse .split-media {
  order: 2;
}

.split-media {
  overflow: visible;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  background: rgba(255, 253, 248, 0.86);
  padding: 12px;
}

.split-media img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 6px);
}

.quote-panel {
  padding: 30px;
  border: 1px solid rgba(217, 155, 50, 0.28);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.86), rgba(246, 232, 205, 0.72)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.08), rgba(95, 140, 97, 0.06));
  box-shadow: var(--shadow-soft);
}

.quote-panel p {
  margin: 0;
  color: var(--cocoa);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 25px;
  line-height: 1.35;
}

.list-check {
  display: grid;
  gap: 12px;
  padding: 0;
  margin: 18px 0 0;
  list-style: none;
  max-width: 100%;
  min-width: 0;
}

.list-check li {
  position: relative;
  padding-left: 30px;
  color: var(--muted);
  min-width: 0;
  overflow-wrap: break-word;
}

.list-check li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold), var(--leaf));
  box-shadow: 0 0 0 4px rgba(185, 130, 55, 0.12);
}

.product-card {
  overflow: visible;
}

.product-media {
  position: relative;
  overflow: hidden;
  border-radius: calc(var(--radius) - 2px);
  background:
    radial-gradient(circle at 24% 18%, rgba(234, 209, 167, 0.28), transparent 30%),
    linear-gradient(135deg, rgba(255, 253, 248, 0.94), rgba(248, 236, 218, 0.48));
}

.product-media::after {
  content: "";
  position: absolute;
  inset: auto 12px 12px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(185, 130, 55, 0.36), transparent);
}

.product-card img {
  width: 100%;
  height: auto;
  object-fit: contain;
  background: rgba(255, 253, 248, 0.76);
  transition: transform 0.35s ease, filter 0.35s ease;
}

.product-card:hover img {
  transform: scale(1.018);
  filter: saturate(1.04) contrast(1.02);
}

.product-card .image-card-body,
.image-card .image-card-body {
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(250, 241, 227, 0.62));
}

.product-card .tag {
  margin-bottom: 12px;
}

.quick-view-btn {
  margin-top: 18px;
  width: 100%;
  min-height: 42px;
  border: 1px solid rgba(185, 130, 55, 0.28);
  border-radius: var(--radius);
  color: var(--cocoa);
  background: linear-gradient(135deg, rgba(255, 253, 248, 0.94), rgba(234, 209, 167, 0.26));
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.quick-view-btn:hover,
.quick-view-btn:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(91, 53, 40, 0.34);
  color: #ffffff;
  background: linear-gradient(135deg, var(--cocoa), var(--gold));
}

.sweet-marquee {
  overflow: hidden;
  margin-top: 28px;
  border: 1px solid rgba(185, 130, 55, 0.18);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.82), rgba(250, 241, 227, 0.48)),
    linear-gradient(90deg, rgba(47, 154, 160, 0.07), rgba(185, 130, 55, 0.08));
  box-shadow: var(--shadow-soft);
}

.sweet-marquee-track {
  display: flex;
  width: max-content;
  gap: 14px;
  padding: 14px;
  animation: sweetRail 34s linear infinite;
}

.sweet-marquee:hover .sweet-marquee-track {
  animation-play-state: paused;
}

.sweet-marquee-item {
  display: grid;
  grid-template-columns: 76px 190px;
  align-items: center;
  gap: 12px;
  min-width: 292px;
  padding: 10px;
  border: 1px solid rgba(91, 53, 40, 0.12);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.86);
}

.sweet-marquee-item img {
  width: 76px;
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 3px);
  background: rgba(255, 253, 248, 0.92);
}

.sweet-marquee-item span,
.modal-kicker {
  display: block;
  color: var(--gold);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.sweet-marquee-item strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  line-height: 1.15;
}

.collection-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 18px;
}

.collection-feature {
  min-height: 0;
  position: relative;
  overflow: visible;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  background: rgba(255, 253, 248, 0.86);
  padding: 12px;
}

.collection-feature img {
  width: 100%;
  height: auto;
  object-fit: contain;
  position: static;
  border-radius: calc(var(--radius) - 6px);
}

.collection-feature::after {
  content: none;
}

.collection-feature-body {
  position: static;
  padding: 22px 10px 10px;
  color: var(--ink);
}

.collection-feature-body h3 {
  margin: 0;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 34px;
  line-height: 1.1;
}

.collection-feature-body p {
  color: var(--muted);
}

.press-card img {
  object-fit: contain;
  background: #fff;
}

.archive-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.archive-card {
  overflow: visible;
  padding: 14px;
  align-self: start;
}

.archive-card img,
.media-zoom img {
  width: 100%;
  height: auto;
  aspect-ratio: auto;
  object-fit: contain;
  padding: 0;
  background: rgba(255, 253, 248, 0.78);
}

.archive-card-body {
  padding: 18px 4px 4px;
}

.gallery-mosaic {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
  gap: 18px;
}

.gallery-mosaic figure {
  margin: 0;
  position: relative;
  overflow: visible;
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255, 253, 248, 0.84);
  box-shadow: var(--shadow-soft);
}

.gallery-mosaic figure:first-child {
  grid-row: span 1;
}

.gallery-mosaic img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 6px);
}

.media-zoom {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  border-radius: calc(var(--radius) - 6px);
  color: inherit;
  background: transparent;
  text-align: left;
}

.media-zoom img {
  transition: transform 0.35s ease, filter 0.35s ease;
}

.media-zoom span {
  position: absolute;
  right: 10px;
  bottom: 10px;
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border: 1px solid rgba(255, 253, 248, 0.66);
  border-radius: var(--radius);
  color: #ffffff;
  background: rgba(91, 53, 40, 0.76);
  box-shadow: 0 10px 24px rgba(55, 34, 24, 0.2);
  font-size: 12px;
  font-weight: 900;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.media-zoom:hover img,
.media-zoom:focus-visible img {
  transform: scale(1.012);
  filter: saturate(1.04) contrast(1.02);
}

.media-zoom:hover span,
.media-zoom:focus-visible span {
  opacity: 1;
  transform: translateY(0);
}

.gallery-mosaic figcaption {
  position: static;
  display: inline-flex;
  margin-top: 10px;
  padding: 8px 10px;
  border-radius: var(--radius);
  color: var(--ink);
  background: rgba(255, 253, 248, 0.92);
  font-size: 13px;
  font-weight: 800;
  backdrop-filter: none;
}

.process-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  counter-reset: steps;
}

.faq-section {
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.74), rgba(248, 236, 218, 0.42)),
    linear-gradient(90deg, rgba(47, 154, 160, 0.05), rgba(185, 130, 55, 0.07));
}

.faq-list {
  display: grid;
  gap: 12px;
}

.faq-item {
  border: 1px solid rgba(91, 53, 40, 0.14);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: var(--shadow-soft);
}

.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 58px;
  padding: 16px 18px;
  color: var(--cocoa);
  font-weight: 900;
  cursor: pointer;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "+";
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  color: #ffffff;
  background: linear-gradient(135deg, var(--cocoa), var(--gold));
  font-size: 18px;
  line-height: 1;
}

.faq-item[open] summary::after {
  content: "-";
}

.faq-item p {
  margin: 0;
  padding: 0 18px 18px;
  color: var(--muted);
}

.faq-item summary:focus-visible {
  outline: 3px solid rgba(47, 154, 160, 0.28);
  outline-offset: 3px;
}

.process-card {
  position: relative;
  padding-top: 54px;
}

.process-card::before {
  counter-increment: steps;
  content: counter(steps, decimal-leading-zero);
  position: absolute;
  top: 20px;
  left: 24px;
  color: var(--gold);
  font-weight: 900;
  font-size: 22px;
}

.info-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 18px;
}

.info-card strong {
  display: block;
  color: var(--cocoa);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(20px, 1.8vw, 25px);
  line-height: 1.12;
  overflow-wrap: normal;
}

.info-card p {
  margin: 6px 0 0;
}

.faq-list {
  display: grid;
  gap: 12px;
}

.faq-item {
  padding: 20px;
}

.faq-item h3 {
  font-size: 19px;
}

.contact-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 18px;
}

.social-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.social-row a {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  color: var(--cocoa);
  background: rgba(255, 253, 248, 0.80);
  font-weight: 800;
  text-decoration: none;
}

.social-row a[href*="instagram"] {
  border-color: rgba(221, 42, 123, 0.20);
  color: #8a2d5f;
}

.social-row a[href*="facebook"] {
  border-color: rgba(24, 119, 242, 0.20);
  color: #1f5f9f;
}

.social-row a[href*="threads"] {
  border-color: rgba(42, 33, 27, 0.18);
  color: var(--cocoa-deep);
}

.social-row a[aria-disabled="true"],
.footer-links a[aria-disabled="true"] {
  opacity: 0.72;
}

.map-placeholder {
  min-height: 320px;
  display: grid;
  place-items: center;
  padding: 24px;
  text-align: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.82), rgba(248, 236, 218, 0.68)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.08), rgba(47, 154, 160, 0.08));
  box-shadow: var(--shadow-soft);
}

.image-card {
  overflow: visible;
  padding: 0;
  align-self: start;
}

.image-card img {
  width: 100%;
  height: auto;
  object-fit: contain;
  background: rgba(255, 253, 248, 0.76);
}

.image-card-body {
  padding: 20px;
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tag {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border: 1px solid rgba(185, 130, 55, 0.22);
  border-radius: var(--radius);
  color: var(--cocoa);
  background: rgba(255, 248, 235, 0.76);
  font-size: 12px;
  font-weight: 800;
}

.feature-band {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 28px;
  align-items: center;
}

.feature-media {
  overflow: visible;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 12px;
  background: rgba(255, 253, 248, 0.86);
}

.feature-media img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 6px);
}

.timeline {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--glass);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.timeline-item {
  padding: 26px;
  border-right: 1px solid var(--line);
}

.timeline-item:last-child {
  border-right: 0;
}

.timeline-item strong {
  display: block;
  color: var(--gold);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 32px;
  line-height: 1;
  margin-bottom: 12px;
}

.page-hero {
  position: relative;
  overflow: visible;
  min-height: 0;
  display: block;
  padding: 70px 0 56px;
  background:
    linear-gradient(135deg, rgba(255, 250, 244, 0.96), rgba(255, 253, 248, 0.82)),
    var(--cream);
}

.page-hero-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(300px, 0.98fr);
  align-items: center;
  gap: 38px;
}

.page-hero.has-media .page-hero-media {
  position: relative;
  inset: auto;
  z-index: 1;
  overflow: visible;
  padding: 12px;
  border: 1px solid rgba(185, 130, 55, 0.24);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.88);
  box-shadow: var(--shadow);
}

.page-hero.has-media .page-hero-media img {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 6px);
}

.page-hero.has-media .page-hero-media::after {
  content: none;
}

.page-hero-content {
  position: relative;
  z-index: 1;
  max-width: 820px;
  overflow-wrap: break-word;
  padding: 26px;
  border: 1px solid rgba(185, 130, 55, 0.20);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.88), rgba(250, 241, 227, 0.72)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.08), rgba(95, 140, 97, 0.06));
  box-shadow: 0 22px 80px rgba(55, 34, 24, 0.15);
  backdrop-filter: blur(4px);
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.field {
  display: grid;
  gap: 8px;
}

.field.full {
  grid-column: 1 / -1;
}

.field label {
  color: var(--ink);
  font-weight: 800;
  font-size: 14px;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--ink);
  background: rgba(255, 253, 248, 0.88);
}

.field textarea {
  min-height: 130px;
  resize: vertical;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: 3px solid rgba(185, 130, 55, 0.22);
  border-color: rgba(185, 130, 55, 0.62);
}

.inquiry-panel {
  padding: clamp(24px, 4vw, 44px);
  display: grid;
  gap: 28px;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.88), rgba(248, 236, 218, 0.76)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.08), rgba(47, 154, 160, 0.08));
}

.form-intro {
  display: grid;
  gap: 12px;
  max-width: 860px;
}

.form-intro p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}

.inquiry-form {
  display: grid;
  gap: 18px;
}

.honeypot {
  position: absolute;
  left: -100vw;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.field-error {
  min-height: 18px;
  margin: 0;
  color: #ad243c;
  font-size: 12px;
  font-weight: 800;
}

.field.has-error input,
.field.has-error select,
.field.has-error textarea {
  border-color: rgba(173, 36, 60, 0.65);
  background: rgba(255, 246, 248, 0.92);
}

.consent-field {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.78);
  color: var(--muted);
  font-weight: 700;
}

.consent-field input {
  flex: 0 0 auto;
  margin-top: 5px;
  accent-color: var(--cocoa);
}

.consent-field span {
  flex: 1;
  text-align: left;
}

.consent-field.has-error {
  border-color: rgba(173, 36, 60, 0.65);
}

.form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.form-status {
  min-height: 24px;
  padding: 0;
  color: var(--muted);
  font-weight: 800;
}

.form-status.is-success,
.form-status.is-warning,
.form-status.is-error {
  padding: 14px 16px;
  border-radius: var(--radius);
}

.form-status.is-success {
  color: #17624f;
  background: rgba(28, 178, 128, 0.12);
  border: 1px solid rgba(28, 178, 128, 0.25);
}

.form-status.is-warning {
  color: #856017;
  background: rgba(246, 190, 74, 0.15);
  border: 1px solid rgba(246, 190, 74, 0.28);
}

.form-status.is-error {
  color: #ad243c;
  background: rgba(173, 36, 60, 0.10);
  border: 1px solid rgba(173, 36, 60, 0.22);
}

.site-footer {
  padding: 64px 0 30px;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.92), rgba(248, 236, 218, 0.82)),
    linear-gradient(90deg, rgba(185, 130, 55, 0.10), rgba(95, 140, 97, 0.08));
  border-top: 1px solid var(--line);
}

.site-footer h3 {
  margin-top: 0;
  color: var(--cocoa);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr 0.8fr;
  gap: 28px;
}

.footer-title {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 28px;
  color: var(--cocoa);
  margin: 0;
}

.footer-links {
  display: grid;
  gap: 10px;
}

.footer-links a {
  color: var(--muted);
  text-decoration: none;
}

.footer-links a:hover {
  color: var(--cocoa);
}

.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
  margin-top: 38px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 14px;
}

.interaction-modal {
  position: fixed;
  inset: 0;
  z-index: 180;
  display: grid;
  place-items: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s ease;
}

.interaction-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.modal-backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(234, 209, 167, 0.22), transparent 34%),
    rgba(42, 33, 27, 0.42);
  backdrop-filter: blur(10px);
}

.modal-card {
  position: relative;
  z-index: 1;
  width: min(980px, 100%);
  max-height: min(86vh, 820px);
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(300px, 0.75fr);
  gap: 22px;
  overflow: auto;
  padding: 18px;
  border: 1px solid rgba(255, 253, 248, 0.66);
  border-radius: var(--radius);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(248, 236, 218, 0.88)),
    linear-gradient(90deg, rgba(47, 154, 160, 0.08), rgba(185, 130, 55, 0.10));
  box-shadow: 0 34px 110px rgba(26, 17, 12, 0.35);
  transform: translateY(14px) scale(0.98);
  transition: transform 0.22s ease;
}

.interaction-modal.is-open .modal-card {
  transform: translateY(0) scale(1);
}

.modal-media {
  display: grid;
  place-items: center;
  min-height: 220px;
  padding: 12px;
  border: 1px solid rgba(185, 130, 55, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 253, 248, 0.72);
}

.modal-media img {
  width: auto;
  max-width: 100%;
  max-height: min(68vh, 680px);
  height: auto;
  object-fit: contain;
  border-radius: calc(var(--radius) - 5px);
}

.modal-content {
  display: grid;
  align-content: center;
  gap: 14px;
  padding: 16px;
}

.modal-content h2 {
  margin: 0;
  color: var(--cocoa);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 34px;
  line-height: 1.08;
}

.modal-content p {
  margin: 0;
  color: var(--muted);
}

.modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 6px;
}

.modal-close,
.modal-nav {
  border: 1px solid rgba(91, 53, 40, 0.16);
  border-radius: var(--radius);
  color: var(--cocoa);
  background: rgba(255, 253, 248, 0.9);
  box-shadow: 0 10px 28px rgba(55, 34, 24, 0.12);
}

.modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
  width: 42px;
  height: 42px;
  font-size: 24px;
  line-height: 1;
}

.modal-nav {
  position: absolute;
  top: 50%;
  z-index: 3;
  width: 42px;
  height: 42px;
  transform: translateY(-50%);
  font-size: 24px;
}

.modal-nav[data-modal-prev] {
  left: 12px;
}

.modal-nav[data-modal-next] {
  right: 62px;
}

.modal-nav[hidden] {
  display: none;
}

.floating-actions {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 90;
  display: grid;
  gap: 10px;
}

.floating-actions .icon-btn {
  position: relative;
  width: 54px;
  height: 54px;
  border-color: rgba(156, 50, 68, 0.18);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 12px 30px rgba(80, 49, 34, 0.16);
  overflow: visible;
}

.floating-actions .icon-btn::before {
  content: "";
  position: absolute;
  inset: -6px;
  border: 2px solid currentColor;
  border-radius: inherit;
  opacity: 0.34;
  animation: contactRing 2.4s ease-out infinite;
  pointer-events: none;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  color: #ffffff;
  border-color: rgba(37, 211, 102, 0.36);
  background: linear-gradient(135deg, #128c7e, #25d366);
}

.floating-actions .icon-btn[aria-label*="call"] {
  color: #ffffff;
  border-color: rgba(91, 53, 40, 0.24);
  background: linear-gradient(135deg, var(--cocoa), var(--gold));
}

.call-panel {
  position: fixed;
  right: 18px;
  bottom: 86px;
  z-index: 91;
  width: min(330px, calc(100% - 36px));
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  transform: translateY(12px);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.call-panel.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.call-panel h3 {
  margin: 0 0 12px;
  color: var(--cocoa);
}

.call-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  color: var(--ink);
  text-decoration: none;
  border-top: 1px solid var(--line);
}

.call-option span {
  display: block;
  color: var(--muted);
  font-size: 13px;
}

.reveal {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
  transition: transform 0.7s ease, opacity 0.7s ease, filter 0.7s ease;
}

body.js-ready .reveal {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

body.js-ready .reveal.is-visible {
  transform: translateY(0);
  opacity: 1;
  filter: blur(0);
}

@keyframes sweetRail {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@keyframes contactRing {
  0% {
    transform: scale(0.82);
    opacity: 0.34;
  }

  72%,
  100% {
    transform: scale(1.35);
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
  }

  .reveal {
    transform: none;
    opacity: 1;
    filter: none;
  }

  .sweet-marquee-track,
  .floating-actions .icon-btn::before {
    animation: none !important;
  }
}

@media (max-width: 1280px) {
  .header-inner {
    gap: 14px;
  }

  .brand-link {
    gap: 10px;
  }

  .brand-title {
    font-size: 18px;
  }

  .site-nav a {
    padding-inline: 7px;
    font-size: 13px;
  }

  .header-actions {
    gap: 8px;
  }

  .header-actions .btn {
    padding-inline: 14px;
  }
}

@media (max-width: 1120px) {
  .site-nav {
    position: fixed;
    inset: var(--header-height) 14px auto;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
  }

  .site-nav.is-open {
    display: flex;
  }

  .site-nav a {
    justify-content: space-between;
  }

  .nav-toggle {
    display: block;
  }

  .header-actions .btn-secondary {
    display: none;
  }
}

@media (max-width: 960px) {
  .hero h1,
  .page-hero h1 {
    font-size: 52px;
  }

  .trust-row,
  .grid-4,
  .timeline,
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grid-3,
  .section-header,
  .feature-band,
  .hero-layout,
  .page-hero-layout,
  .split-panel,
  .collection-grid,
  .contact-panel,
  .modal-card {
    grid-template-columns: 1fr;
  }

  .split-panel.reverse .split-media {
    order: 0;
  }

  .archive-grid,
  .process-list,
  .info-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .gallery-mosaic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .modal-card {
    width: min(760px, 100%);
  }

  .timeline-item:nth-child(2) {
    border-right: 0;
  }

  .timeline-item {
    border-bottom: 1px solid var(--line);
  }

  .timeline-item:nth-last-child(-n+2) {
    border-bottom: 0;
  }
}

@media (max-width: 680px) {
  :root {
    --header-height: 74px;
  }

  .site-shell {
    width: min(var(--max), calc(100% - 24px));
  }

  .header-inner.site-shell {
    width: min(1280px, calc(100% - 24px));
    gap: 10px;
  }

  .brand-link {
    min-width: 0;
    gap: 8px;
  }

  .brand-link > span {
    min-width: 0;
  }

  .brand-mark {
    width: 48px;
    height: 48px;
    flex: 0 0 48px;
  }

  .brand-title {
    font-size: 16px;
    max-width: 235px;
    overflow-wrap: break-word;
  }

  .brand-subtitle {
    display: none;
  }

  .nav-toggle {
    flex: 0 0 44px;
  }

  .hero,
  .page-hero {
    min-height: 0;
    padding: 48px 0 42px;
  }

  .header-actions {
    display: none;
  }

  .hero h1,
  .page-hero h1 {
    font-size: 32px;
    line-height: 1.08;
    max-width: 100%;
  }

  .hero-content,
  .page-hero-content {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
    padding: 22px;
  }

  .hero p,
  .page-hero p,
  .section-lead {
    font-size: 16px;
    max-width: 100%;
  }

  .section {
    padding: 62px 0;
  }

  .section h2,
  .section-title {
    font-size: 29px;
    line-height: 1.12;
    overflow-wrap: break-word;
  }

  .content-block h3 {
    font-size: 25px;
    line-height: 1.15;
    overflow-wrap: break-word;
  }

  .trust-row,
  .grid-2,
  .grid-3,
  .grid-4,
  .timeline,
  .footer-grid,
  .form-grid,
  .archive-grid,
  .process-list,
  .info-strip,
  .gallery-mosaic {
    grid-template-columns: 1fr;
  }

  .gallery-mosaic {
    grid-auto-rows: auto;
  }

  .gallery-mosaic figure:first-child {
    grid-row: span 1;
  }

  .timeline-item,
  .timeline-item:nth-child(2),
  .timeline-item:nth-last-child(-n+2) {
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }

  .timeline-item:last-child {
    border-bottom: 0;
  }

  .hero-actions,
  .section-actions,
  .form-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .btn {
    width: 100%;
  }

  .floating-actions {
    right: 8px;
    bottom: 8px;
    gap: 8px;
  }

  .floating-actions .icon-btn {
    width: 44px;
    height: 44px;
    border-radius: 12px;
  }

  .floating-actions .icon-btn svg {
    width: 18px;
    height: 18px;
  }

  body.form-page .floating-actions,
  body.form-page .call-panel {
    display: none;
  }

  .interaction-modal {
    padding: 12px;
  }

  .modal-card {
    max-height: 90vh;
    padding: 12px;
    gap: 12px;
  }

  .modal-content {
    padding: 8px 4px 4px;
  }

  .modal-content h2 {
    font-size: 28px;
  }

  .modal-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .modal-close {
    top: 8px;
    right: 8px;
  }

  .modal-nav {
    top: auto;
    bottom: 10px;
    transform: none;
  }

  .modal-nav[data-modal-prev] {
    left: 10px;
  }

  .modal-nav[data-modal-next] {
    right: 58px;
  }

  .sweet-marquee-item {
    grid-template-columns: 62px 150px;
    min-width: 240px;
  }

  .sweet-marquee-item img {
    width: 62px;
  }
}

/* Phase 8F final visual correction: premium typography, no-crop media, real CTA feel */
:root {
  --font-body: "Inter", "Segoe UI", Arial, sans-serif;
  --font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ink: #2a211b;
  --muted: #67594f;
  --surface: rgba(255, 253, 248, 0.9);
  --surface-solid: #fffdf8;
  --cocoa: #553226;
  --gold: #b98237;
  --aqua: #218f98;
  --rose: #b95973;
  --leaf: #5f8c61;
  --line: rgba(85, 50, 38, 0.14);
  --radius: 8px;
}

body {
  color: var(--ink);
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.96), rgba(255, 247, 238, 0.88) 42%, rgba(241, 252, 247, 0.94)),
    radial-gradient(circle at 15% 0%, rgba(255, 231, 225, 0.48), transparent 28%),
    radial-gradient(circle at 92% 16%, rgba(220, 247, 242, 0.58), transparent 30%);
  font-family: var(--font-body);
}

.brand-title,
.hero h1,
.page-hero h1,
.section h2,
.section-title,
.content-block h3,
.collection-feature-body h3,
.timeline-item strong,
.quote-panel p,
.footer-title,
.modal-content h2,
.legal-content h2,
.legal-content h3 {
  font-family: var(--font-display);
  letter-spacing: 0;
}

.site-header {
  background: rgba(255, 253, 248, 0.9);
  backdrop-filter: blur(16px);
}

.site-nav a,
.btn,
.quick-view-btn,
.footer-links a,
.social-row a {
  letter-spacing: 0;
}

.kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin: 0 auto 14px;
  padding: 7px 14px;
  border: 1px solid rgba(185, 130, 55, 0.22);
  border-radius: 999px;
  color: #72402f;
  background: linear-gradient(135deg, rgba(255, 253, 248, 0.82), rgba(239, 249, 246, 0.72));
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.kicker::before {
  content: none !important;
}

.section,
.page-hero,
.hero {
  background: transparent;
}

.section-soft {
  background: linear-gradient(135deg, rgba(255, 248, 239, 0.72), rgba(239, 249, 246, 0.76));
}

.hero.hero-motion {
  min-height: min(760px, calc(100vh - var(--header-height)));
  display: grid;
  align-items: center;
  padding: clamp(72px, 8vw, 120px) 0;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.98), rgba(255, 253, 248, 0.72) 25%, rgba(255, 253, 248, 0.62) 74%, rgba(255, 253, 248, 0.96)),
    linear-gradient(135deg, #fffdf8, #eef9f4);
}

.hero-motion::before,
.hero-motion::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero-motion::before {
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(255, 253, 248, 0.16), rgba(255, 253, 248, 0.72)),
    radial-gradient(circle at 50% 44%, rgba(255, 253, 248, 0.42), transparent 34%);
}

.hero-motion::after {
  z-index: 0;
  background: none;
}

.hero-motion-bg {
  position: absolute;
  inset: 84px 0 54px;
  z-index: 0;
  display: grid;
  align-content: center;
  gap: clamp(18px, 3vw, 34px);
  opacity: 0.74;
  filter: saturate(0.84) contrast(0.95) brightness(1.06);
}

.hero-motion-row {
  overflow: hidden;
  transform: rotate(-1.2deg);
}

.hero-motion-row.is-reverse {
  transform: rotate(1.2deg);
}

.hero-motion-track {
  width: max-content;
  display: flex;
  align-items: center;
  gap: clamp(16px, 2vw, 28px);
  animation: heroSweetRail 58s linear infinite;
}

.hero-motion-row.is-reverse .hero-motion-track {
  animation-name: heroSweetRailReverse;
  animation-duration: 66s;
}

.hero-motion-item {
  width: clamp(160px, 19vw, 330px);
  min-height: clamp(130px, 15vw, 230px);
  display: grid;
  place-items: center;
  margin: 0;
  padding: clamp(8px, 1.2vw, 14px);
  border: 1px solid rgba(185, 130, 55, 0.16);
  border-radius: 16px;
  background: rgba(255, 253, 248, 0.88);
  box-shadow: 0 18px 54px rgba(55, 34, 24, 0.11);
}

.hero-motion-item img {
  width: auto;
  max-width: 100%;
  max-height: clamp(120px, 15vw, 230px);
  height: auto;
  object-fit: contain;
  border-radius: 10px;
}

.hero-motion .hero-layout {
  position: relative;
  z-index: 2;
  display: block;
}

.hero-motion .hero-content {
  width: min(900px, 100%);
  margin: 0 auto;
  padding: 0;
  border: 0;
  box-shadow: none;
  background: transparent;
  text-align: center;
}

.hero-motion h1 {
  margin-inline: auto;
  color: #42261d;
  font-size: clamp(48px, 7vw, 92px);
  line-height: 0.95;
  text-shadow: 0 2px 22px rgba(255, 253, 248, 0.9);
}

.hero-motion p {
  max-width: 720px;
  margin-inline: auto;
  color: #4d4038;
  text-shadow: 0 1px 16px rgba(255, 253, 248, 0.86);
}

.hero-motion .hero-actions,
.hero-motion .trust-row {
  justify-content: center;
}

.hero-motion .trust-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  max-width: 780px;
  margin-inline: auto;
}

.btn,
.quick-view-btn,
.icon-btn,
.social-icon {
  border-radius: 999px;
}

.btn .icon,
.quick-view-btn .icon,
.icon-btn .icon,
.social-icon .icon {
  flex: 0 0 auto;
}

.btn-accent {
  color: #fff;
  background: linear-gradient(135deg, #075e54, #128c7e 45%, #25d366);
  box-shadow: 0 14px 34px rgba(18, 140, 126, 0.22);
}

.btn-primary {
  color: #fff;
  background: linear-gradient(135deg, #5d3427, #a76833 56%, #c9974c);
}

.btn-secondary {
  color: var(--cocoa);
  background: rgba(255, 253, 248, 0.92);
  border-color: rgba(85, 50, 38, 0.18);
}

.page-hero-layout,
.split-panel,
.split-panel.reverse,
.collection-grid,
.contact-panel {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
}

.page-hero-content,
.content-block,
.form-intro,
.legal-content,
.section-header {
  margin-inline: auto;
  text-align: center;
}

.split-panel.reverse .split-media,
.split-panel .split-media {
  order: 0;
}

.page-hero-media,
.split-media,
.story-media,
.collection-feature,
.map-card {
  width: min(920px, 100%);
  margin-inline: auto;
}

.hero-media,
.page-hero-media,
.split-media,
.story-media,
.collection-feature,
.image-card,
.product-card,
.archive-card,
.gallery-mosaic figure,
.media-zoom {
  overflow: visible;
}

.hero-media img,
.page-hero-media img,
.split-media img,
.story-media img,
.collection-feature img,
.image-card img,
.product-card img,
.product-media img,
.archive-card img,
.gallery-mosaic img,
.media-zoom img,
.legacy-sequence img,
.modal-media img,
.sweet-marquee-item img {
  width: auto;
  max-width: 100%;
  height: auto;
  object-fit: contain !important;
}

.page-hero-media,
.split-media,
.story-media,
.product-media,
.media-zoom {
  display: grid;
  place-items: center;
  padding: clamp(10px, 1.5vw, 16px);
  background: rgba(255, 253, 248, 0.9);
  border: 1px solid rgba(185, 130, 55, 0.16);
  border-radius: 14px;
}

.product-media {
  min-height: 0;
}

.product-media img {
  max-height: 300px;
}

.image-card img {
  max-height: 380px;
  margin-inline: auto;
}

.image-card-body,
.product-card .image-card-body {
  text-align: center;
  background: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(248, 243, 234, 0.7));
}

.product-card .tag,
.product-card h3 {
  display: none;
}

.product-card p {
  margin-top: 0;
}

.sweet-marquee {
  border-radius: 18px;
  background: rgba(255, 253, 248, 0.68);
}

.sweet-marquee-item {
  display: grid;
  place-items: center;
  min-width: 150px;
  padding: 8px;
  border-radius: 14px;
  background: rgba(255, 253, 248, 0.82);
}

.sweet-marquee-item div {
  display: none;
}

.sweet-marquee-item img {
  max-height: 92px;
}

.legacy-sequence {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: start;
  gap: 18px;
}

.legacy-sequence .image-card {
  padding: 12px;
}

.legacy-sequence .image-card img {
  max-height: 390px;
}

.archive-grid {
  display: block;
  columns: 3 270px;
  column-gap: 22px;
}

.archive-card {
  display: inline-block;
  width: 100%;
  margin: 0 0 22px;
  break-inside: avoid;
  background: rgba(255, 253, 248, 0.94);
}

.archive-card .media-zoom {
  min-height: 0;
  padding: 12px;
  background: #fff;
}

.archive-card img {
  max-height: none;
  border-radius: 6px;
}

.gallery-mosaic {
  display: block;
  columns: 3 260px;
  column-gap: 22px;
}

.gallery-mosaic figure,
.gallery-mosaic figure:first-child {
  display: inline-block;
  width: 100%;
  margin: 0 0 22px;
  break-inside: avoid;
}

.gallery-mosaic img {
  max-height: none;
}

.social-icons,
.social-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.social-row a {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 50%;
  color: #fff;
  font-size: 0;
  border: 0;
  box-shadow: 0 14px 30px rgba(55, 34, 24, 0.16);
}

.social-row a[href*="instagram"] {
  background: radial-gradient(circle at 30% 105%, #fdf497 0 16%, #fd5949 42%, #d6249f 65%, #285aeb 100%);
}

.social-row a[href*="facebook"] {
  background: #1877f2;
}

.social-row a[href*="threads"] {
  background: #111;
}

.social-row a[href*="youtube"] {
  background: #ff0000;
}

.social-icons {
  justify-content: center;
}

.social-icon {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  color: #fff;
}

.social-icon span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.social-icon .icon,
.btn .brand-icon,
.quick-view-btn .brand-icon {
  fill: currentColor;
  stroke: none;
}

.floating-actions {
  right: 22px;
  bottom: 22px;
}

.floating-actions .icon-btn {
  width: 58px;
  height: 58px;
  border: 0;
  color: #fff;
  box-shadow: 0 18px 40px rgba(55, 34, 24, 0.2);
}

.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  background: #25d366;
}

.floating-actions .icon-btn[aria-label*="call"],
.floating-actions .icon-btn[aria-label*="Call"] {
  background: #a76833;
}

.footer-bottom a {
  color: inherit;
  text-decoration: none;
}

.footer-bottom a:hover,
.footer-bottom a:focus-visible {
  color: var(--cocoa);
  text-decoration: underline;
}

.map-card iframe {
  min-height: 390px;
}

@media (prefers-reduced-motion: reduce) {
  .hero-motion-track {
    animation: none !important;
  }
}

@media (max-width: 960px) {
  .hero-motion .trust-row,
  .legacy-sequence {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .archive-grid,
  .gallery-mosaic {
    columns: 2 240px;
  }
}

@media (max-width: 680px) {
  .header-inner {
    gap: 8px;
  }

  .brand-link {
    min-width: 0;
    flex: 1 1 auto;
  }

  .brand-link > span {
    min-width: 0;
  }

  .brand-title {
    font-size: 15px;
    line-height: 1.12;
  }

  .brand-subtitle {
    font-size: 10px;
  }

  .nav-toggle {
    display: block;
    position: fixed;
    top: 17px;
    right: 14px;
    z-index: 220;
    flex: 0 0 42px;
    background: rgba(255, 253, 248, 0.94);
    box-shadow: 0 12px 30px rgba(55, 34, 24, 0.12);
  }

  .header-actions {
    display: none;
  }

  .hero.hero-motion {
    min-height: 660px;
    padding: 58px 0;
  }

  .hero-motion-bg {
    inset: 78px 0 38px;
    opacity: 0.48;
  }

  .hero-motion h1 {
    width: min(100%, 340px);
    max-width: calc(100vw - 32px);
    margin-inline: auto;
    font-size: clamp(31px, 9vw, 38px);
    line-height: 1.02;
    overflow-wrap: anywhere;
    word-break: normal;
    text-wrap: balance;
  }

  .hero-motion p {
    width: min(100%, 270px);
    max-width: calc(100vw - 32px);
    margin-inline: auto;
    font-size: 16px;
    overflow-wrap: anywhere;
  }

  .hero-motion .hero-actions {
    width: min(100%, 270px);
    max-width: calc(100vw - 32px);
    margin-inline: auto;
  }

  .hero-motion .hero-actions .btn {
    width: 100%;
  }

  .hero-motion .trust-row,
  .legacy-sequence {
    grid-template-columns: 1fr;
  }

  .archive-grid,
  .gallery-mosaic {
    columns: 1;
  }

  .floating-actions .icon-btn {
    width: 52px;
    height: 52px;
  }
}

/* Phase 8F clarity correction: no intentional blur on visible content */
.reveal,
.js-ready .reveal,
.js-ready .reveal.is-visible {
  opacity: 1 !important;
  transform: none !important;
  filter: none !important;
}

/* Phase 8G final brand, spacing, and image-integrity refinements */
.brand-mark {
  width: 74px !important;
  height: 54px !important;
  object-fit: contain !important;
  padding: 5px;
  border-radius: 12px;
  background: rgba(255, 253, 248, 0.96);
  box-shadow: 0 12px 28px rgba(55, 34, 24, 0.08);
}

.site-footer .brand-mark {
  width: 96px !important;
  height: 64px !important;
}

.hero-motion::before {
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.56), rgba(255, 253, 248, 0.16) 26%, rgba(255, 253, 248, 0.12) 74%, rgba(255, 253, 248, 0.52)),
    linear-gradient(180deg, rgba(255, 253, 248, 0.18), rgba(255, 253, 248, 0.32)) !important;
}

.hero-motion-bg {
  opacity: 0.86 !important;
  filter: saturate(0.9) contrast(0.98) brightness(1.04) !important;
}

.hero-motion .hero-content {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.hero-motion h1 {
  text-shadow:
    0 3px 2px rgba(255, 253, 248, 0.88),
    0 16px 42px rgba(255, 253, 248, 0.72) !important;
}

.hero-motion p,
.hero-motion .kicker {
  text-shadow: 0 2px 18px rgba(255, 253, 248, 0.92) !important;
}

.hero-motion .trust-row {
  max-width: 940px !important;
}

.trust-item {
  min-height: 124px;
  display: grid;
  align-content: center;
  gap: 7px;
}

.trust-item strong {
  line-height: 1;
}

.section-header-centered {
  max-width: 880px !important;
  grid-template-columns: 1fr !important;
  justify-items: center;
  text-align: center;
  gap: 12px;
}

.section-header-centered .section-lead {
  max-width: 720px;
}

.grid-4 {
  align-items: stretch;
}

.product-card {
  height: 100%;
  display: grid !important;
  grid-template-rows: 220px 1fr;
}

.product-card .product-media {
  height: 220px;
  min-height: 220px;
  padding: 12px;
}

.product-card .product-media img,
.product-card img {
  max-height: 196px !important;
  max-width: 100% !important;
  object-fit: contain !important;
}

.product-card .image-card-body {
  min-height: 188px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
}

.quick-view-btn {
  min-height: 42px;
  width: 100%;
  justify-content: center;
  color: #5b3528;
  background: linear-gradient(135deg, rgba(255, 253, 248, 0.96), rgba(255, 246, 234, 0.95));
  border: 1px solid rgba(185, 130, 55, 0.34);
}

.quick-view-btn .brand-icon {
  color: #128c7e;
}

.sweet-marquee {
  width: min(760px, 100%);
  margin: 30px auto 0;
  overflow: hidden;
}

.sweet-marquee-track {
  gap: 12px;
}

.sweet-marquee-item {
  min-width: 126px;
  height: 78px;
}

.sweet-marquee-item img {
  max-height: 62px !important;
}

.image-card {
  height: 100%;
  display: grid !important;
  grid-template-rows: 260px 1fr;
}

.image-card > img {
  width: 100% !important;
  height: 260px !important;
  max-height: 260px !important;
  object-fit: contain !important;
  padding: 12px;
  background: rgba(255, 253, 248, 0.92);
}

.legacy-sequence .image-card {
  grid-template-rows: 340px 1fr;
}

.legacy-sequence .image-card > img {
  height: 340px !important;
  max-height: 340px !important;
}

.contact-route-grid,
.archive-route-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.archive-route-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.contact-route-card,
.archive-route-card {
  min-height: 170px;
  padding: 22px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 10px;
  text-align: center;
  color: var(--cocoa);
  text-decoration: none;
  border: 1px solid rgba(185, 130, 55, 0.2);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.96), rgba(246, 252, 249, 0.86));
  box-shadow: var(--shadow-soft);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.contact-route-card:hover,
.contact-route-card:focus-visible,
.archive-route-card:hover,
.archive-route-card:focus-visible {
  transform: translateY(-4px);
  border-color: rgba(18, 140, 126, 0.34);
  box-shadow: 0 22px 50px rgba(55, 34, 24, 0.16);
}

.contact-route-card .icon,
.archive-route-card .icon {
  width: 28px;
  height: 28px;
  color: #128c7e;
  fill: none;
}

.contact-route-card .brand-icon {
  fill: currentColor;
  stroke: none;
}

.contact-route-card strong,
.archive-route-card strong {
  font-size: 18px;
}

.contact-route-card span,
.archive-route-card span {
  color: var(--muted);
  line-height: 1.55;
}

.center-actions {
  justify-content: center;
  margin-top: 28px;
}

.lifestyle-panel .split-media img {
  max-height: 520px !important;
}

.certificate-media img {
  max-height: 720px !important;
}

.gallery-mosaic-uniform {
  columns: initial !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}

.gallery-mosaic-uniform figure,
.gallery-mosaic-uniform figure:first-child {
  display: grid !important;
  margin: 0 !important;
  break-inside: auto;
}

.gallery-mosaic-uniform .media-zoom {
  height: 240px;
}

.gallery-mosaic-uniform img {
  max-height: 212px !important;
  object-fit: contain !important;
}

.social-icon {
  width: 48px;
  height: 48px;
  box-shadow: 0 14px 30px rgba(55, 34, 24, 0.16);
}

.social-icon .icon {
  width: 24px;
  height: 24px;
}

.social-instagram {
  background: radial-gradient(circle at 30% 105%, #fdf497 0 16%, #fd5949 42%, #d6249f 65%, #285aeb 100%) !important;
}

.social-facebook {
  background: #1877f2 !important;
}

.social-threads {
  background: #101010 !important;
}

.social-youtube {
  background: #ff0000 !important;
}

.floating-actions {
  gap: 13px;
}

.floating-actions .icon-btn {
  width: 64px !important;
  height: 64px !important;
}

.floating-actions .icon-btn .icon {
  width: 27px;
  height: 27px;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  background: linear-gradient(135deg, #128c7e, #25d366) !important;
}

.floating-actions .icon-btn[aria-label*="call"],
.floating-actions .icon-btn[aria-label*="Call"] {
  background: linear-gradient(135deg, #7a442f, #c58a3c) !important;
}

@media (max-width: 1024px) {
  .contact-route-grid,
  .archive-route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .gallery-mosaic-uniform {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .brand-mark {
    width: 58px !important;
    height: 44px !important;
  }

  .hero-motion::before {
    background: linear-gradient(180deg, rgba(255, 253, 248, 0.32), rgba(255, 253, 248, 0.48)) !important;
  }

  .hero-motion .trust-row,
  .contact-route-grid,
  .archive-route-grid,
  .gallery-mosaic-uniform {
    grid-template-columns: 1fr !important;
  }

  .product-card {
    grid-template-rows: 210px 1fr;
  }

  .image-card,
  .legacy-sequence .image-card {
    grid-template-rows: 280px 1fr;
  }

  .image-card > img,
  .legacy-sequence .image-card > img {
    height: 280px !important;
    max-height: 280px !important;
  }

  .floating-actions .icon-btn {
    width: 56px !important;
    height: 56px !important;
  }
}

/* Phase 8H targeted correction: original logo, certificate, and name-neutral product cards */
.brand-mark {
  width: 82px !important;
  height: 58px !important;
  padding: 4px !important;
  object-fit: contain !important;
  object-position: center !important;
}

.site-footer .brand-mark {
  width: 116px !important;
  height: 76px !important;
}

.page-hero-media img[src*="skm-logo-cropped"],
.split-media img[src*="skm-logo-cropped"] {
  width: auto !important;
  max-width: min(100%, 560px) !important;
  height: auto !important;
  max-height: 380px !important;
  object-fit: contain !important;
  margin-inline: auto;
}

.hero-motion .hero-content {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.product-card .image-card-body h3 {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  clip-path: inset(50%);
}

.product-card .image-card-body {
  justify-content: end;
}

.certificate-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(280px, 0.58fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
}

.certificate-frame {
  margin: 0;
  display: grid;
  place-items: center;
  padding: clamp(12px, 2vw, 22px);
  border: 1px solid rgba(185, 130, 55, 0.22);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255, 253, 248, 0.98), rgba(255, 246, 235, 0.88));
  box-shadow: 0 24px 70px rgba(55, 34, 24, 0.14);
}

.certificate-frame img {
  width: auto !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: min(76vh, 760px) !important;
  object-fit: contain !important;
  border-radius: 12px;
  box-shadow: 0 16px 44px rgba(55, 34, 24, 0.12);
}

@media (max-width: 900px) {
  .certificate-layout {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .certificate-layout .content-block {
    max-width: 720px;
    margin-inline: auto;
  }
}

@media (max-width: 680px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .site-shell,
  .page-hero-layout,
  .hero-layout,
  .split-panel,
  .center-story {
    width: min(calc(100vw - 24px), 366px) !important;
    max-width: calc(100vw - 24px) !important;
    min-width: 0 !important;
    margin-left: 12px !important;
    margin-right: 12px !important;
  }

  .page-hero {
    padding-inline: 0 !important;
    overflow: hidden !important;
  }

  .page-hero-layout,
  .split-panel,
  .center-story {
    grid-template-columns: 1fr !important;
  }

  .page-hero-content,
  .hero-content,
  .content-block {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding-inline: 20px !important;
    overflow-wrap: anywhere;
    overflow: hidden;
  }

  .page-hero h1,
  .section h2,
  .section-title {
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(32px, 10vw, 44px) !important;
    line-height: 1.08 !important;
    text-align: center;
    overflow-wrap: anywhere;
    word-break: normal;
    hyphens: auto;
  }

  .page-hero p,
  .section-lead,
  .content-block p {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-wrap: anywhere;
  }

  .hero-actions,
  .section-actions {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }

  .hero-actions .btn,
  .section-actions .btn {
    width: 100%;
    min-width: 0;
    justify-content: center;
    white-space: normal;
  }

  .grid,
  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr !important;
  }

  .card,
  .image-card,
  .product-card,
  .archive-card {
    max-width: 100%;
    min-width: 0;
  }

  .product-card .product-media,
  .image-card > img,
  .media-zoom {
    width: 100% !important;
    max-width: 100% !important;
  }

  .brand-mark {
    width: 66px !important;
    height: 48px !important;
  }

  .site-footer .brand-mark {
    width: 94px !important;
    height: 64px !important;
  }

  .certificate-frame img {
    max-height: 68vh !important;
  }
}

/* Phase 8I final override layer: keep this block last */
.hero.hero-motion {
  min-height: 790px !important;
  padding: 118px 0 96px !important;
}

.hero-motion-bg {
  inset: 110px 0 100px !important;
  display: flex !important;
  flex-direction: column;
  justify-content: space-between;
  align-content: normal !important;
  gap: clamp(230px, 31vh, 330px) !important;
  opacity: 0.74 !important;
}

.hero-motion-row,
.hero-motion-row.is-reverse {
  transform: none !important;
}

.hero-motion-track {
  gap: clamp(18px, 2vw, 34px) !important;
}

.hero-motion-row.is-rectangles .hero-motion-item {
  width: clamp(250px, 23vw, 390px) !important;
  height: clamp(150px, 13vw, 222px) !important;
  min-height: 0 !important;
  aspect-ratio: 16 / 9;
}

.hero-motion-row.is-squares .hero-motion-item {
  width: clamp(145px, 15vw, 235px) !important;
  height: clamp(145px, 15vw, 235px) !important;
  min-height: 0 !important;
  aspect-ratio: 1 / 1;
}

.hero-motion-item {
  padding: 8px !important;
  border-radius: 16px !important;
  background: rgba(255, 253, 248, 0.82) !important;
}

.hero-motion-item img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
  border-radius: 11px !important;
}

.hero-motion .hero-content {
  width: min(930px, calc(100% - 32px)) !important;
  padding: 0 18px !important;
}

.hero-motion h1 {
  max-width: 860px !important;
  font-size: clamp(54px, 6.2vw, 94px) !important;
  line-height: 0.94 !important;
}

.hero-motion p {
  max-width: 760px !important;
  font-size: clamp(18px, 1.55vw, 23px) !important;
}

.hero-motion .hero-actions {
  margin-top: 22px !important;
}

.hero-motion .trust-row {
  margin-top: 28px !important;
}

.trust-item strong,
.trust-item .stat-number {
  display: inline !important;
  font-family: var(--font-display) !important;
  font-size: clamp(30px, 3vw, 44px) !important;
  font-weight: 800;
  line-height: 1;
}

.sweet-marquee {
  display: none !important;
}

.product-card {
  grid-template-rows: 230px 1fr !important;
}

.product-card .product-media {
  height: 230px !important;
  min-height: 230px !important;
  padding: 10px !important;
}

.product-card .product-media img,
.product-card img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
}

.product-card .image-card-body {
  min-height: 168px !important;
}

.gallery-mosaic-uniform {
  align-items: stretch !important;
}

.gallery-mosaic-uniform figure {
  height: 100%;
}

.gallery-mosaic-uniform .media-zoom {
  height: 270px !important;
  padding: 10px !important;
  display: grid !important;
  place-items: center;
}

.gallery-mosaic-uniform img {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: cover !important;
}

.info-strip .info-card {
  min-height: 96px;
  padding: 18px 20px;
}

.info-card strong {
  font-family: var(--font-body) !important;
  font-size: clamp(17px, 1.35vw, 22px) !important;
  font-weight: 900;
  letter-spacing: 0.01em;
}

.info-card p {
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.social-icon {
  position: relative;
}

.social-icon .icon {
  display: none !important;
}

.social-icon::before,
.btn-accent[href*="wa.me"]::before,
.quick-view-btn::before,
.floating-actions .icon-btn::after {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.social-instagram::before {
  background-image: var(--icon-instagram);
}

.social-facebook::before {
  background-image: var(--icon-facebook);
}

.social-youtube::before {
  background-image: var(--icon-youtube);
}

.social-threads::before {
  content: "@";
  width: auto;
  height: auto;
  color: #fff;
  background-image: none;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 28px;
  font-weight: 900;
  line-height: 1;
}

.btn-accent[href*="wa.me"] .brand-icon,
.quick-view-btn .brand-icon,
.floating-actions .icon-btn .icon {
  display: none !important;
}

.btn-accent[href*="wa.me"]::before,
.quick-view-btn::before {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  background-image: var(--icon-whatsapp);
}

.quick-view-btn::before {
  width: 15px;
  height: 15px;
  background-color: #128c7e;
  background-image: none !important;
  -webkit-mask: var(--icon-whatsapp) center / contain no-repeat;
  mask: var(--icon-whatsapp) center / contain no-repeat;
}

.floating-actions .icon-btn {
  border-radius: 50% !important;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  background: #25d366 !important;
}

.floating-actions .icon-btn[aria-label*="WhatsApp"]::after {
  width: 31px;
  height: 31px;
  background-image: var(--icon-whatsapp);
}

.floating-actions .icon-btn[aria-label*="call"]::after,
.floating-actions .icon-btn[aria-label*="Call"]::after {
  width: 28px;
  height: 28px;
  background-image: var(--icon-call);
}

@media (max-width: 960px) {
  .hero.hero-motion {
    min-height: 760px !important;
  }

  .hero-motion-bg {
    inset: 100px 0 96px !important;
    gap: 260px !important;
  }

  .hero-motion-row.is-rectangles .hero-motion-item {
    width: 230px !important;
    height: 136px !important;
  }

  .hero-motion-row.is-squares .hero-motion-item {
    width: 148px !important;
    height: 148px !important;
  }
}

@media (max-width: 680px) {
  .hero.hero-motion {
    min-height: 780px !important;
    padding: 68px 0 54px !important;
  }

  .hero-motion-bg {
    inset: 92px 0 76px !important;
    gap: 330px !important;
    opacity: 0.58 !important;
  }

  .hero-motion h1 {
    font-size: clamp(34px, 10vw, 46px) !important;
  }

  .hero-motion p br {
    display: none;
  }

  .product-card {
    grid-template-rows: 215px 1fr !important;
  }

  .product-card .product-media {
    height: 215px !important;
    min-height: 215px !important;
  }

  .gallery-mosaic-uniform .media-zoom {
    height: 238px !important;
  }
}


.pr-report-contact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px 18px;
  margin: 0 0 24px;
  padding: 16px 20px;
  text-align: center;
}

.pr-report-contact strong {
  font-family: var(--font-display);
  color: var(--cocoa);
  font-size: 21px;
}

.pr-report-contact a {
  color: var(--ink);
  font-weight: 850;
  text-decoration: none;
}

.pr-report-contact a:hover {
  color: var(--cocoa);
}
/* Phase 8N contact and PR report final overrides */
.info-strip {
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)) !important;
}

.info-card strong {
  overflow-wrap: anywhere !important;
  word-break: normal;
}

/* Phase 8S official rectangular logo update */
.brand-mark {
  width: 118px !important;
  height: 50px !important;
  padding: 3px 5px !important;
  object-fit: contain !important;
  object-position: center !important;
  border-radius: 12px !important;
  background: rgba(255, 253, 248, 0.98) !important;
}

.site-footer .brand-mark {
  width: 142px !important;
  height: 58px !important;
}

@media (max-width: 680px) {
  .brand-mark {
    width: 96px !important;
    height: 42px !important;
  }

  .site-footer .brand-mark {
    width: 118px !important;
    height: 50px !important;
  }
}

/* Phase 8T brand-system polish: larger logo, heritage palette, nav/footer icons */
:root {
  --ink: #142d25;
  --muted: #5e675d;
  --soft: #fffaf1;
  --cream: #fff0d8;
  --surface: #fffdf8;
  --cocoa: #16382d;
  --cocoa-deep: #0b241c;
  --gold: #d39a2d;
  --gold-soft: #f3d58a;
  --rose: #d41422;
  --rose-deep: #a70f1b;
  --leaf: #0f6f54;
  --line: rgba(20, 56, 45, 0.16);
  --shadow: 0 28px 82px rgba(15, 48, 38, 0.14);
  --shadow-soft: 0 16px 44px rgba(15, 48, 38, 0.10);
  --max: 1320px;
  --nav-icon-home: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.35' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m3 11 9-8 9 8'/%3E%3Cpath d='M5 10v10h14V10'/%3E%3Cpath d='M10 20v-6h4v6'/%3E%3C/svg%3E");
  --nav-icon-legacy: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v18'/%3E%3Cpath d='M5 8c5 0 7-2 7-5 0 3 2 5 7 5'/%3E%3Cpath d='M6 15h12'/%3E%3Cpath d='M8 21h8'/%3E%3C/svg%3E");
  --nav-icon-jolbhora: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='7.5'/%3E%3Cpath d='M8.2 12.2c2.1 1.7 5.5 1.7 7.6 0'/%3E%3Cpath d='M12 4.5c1.5 2 1.5 4.1 0 6.2'/%3E%3C/svg%3E");
  --nav-icon-sweets: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 11c2.5-4 13.5-4 16 0'/%3E%3Cpath d='M5 11h14l-1.6 7H6.6L5 11Z'/%3E%3Cpath d='M9 8V5'/%3E%3Cpath d='M15 8V5'/%3E%3C/svg%3E");
  --nav-icon-franchise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 20V8l8-4 8 4v12'/%3E%3Cpath d='M9 20v-6h6v6'/%3E%3Cpath d='M8 10h.01M12 10h.01M16 10h.01'/%3E%3C/svg%3E");
  --nav-icon-press: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 4h12a2 2 0 0 1 2 2v14H7a2 2 0 0 1-2-2V4Z'/%3E%3Cpath d='M19 8h1.5v10a2 2 0 0 1-2 2'/%3E%3Cpath d='M8 8h7M8 12h7M8 16h4'/%3E%3C/svg%3E");
  --nav-icon-gallery: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='5' width='16' height='14' rx='2'/%3E%3Ccircle cx='9' cy='10' r='1.5'/%3E%3Cpath d='m7 17 4-4 3 3 2-2 3 3'/%3E%3C/svg%3E");
  --nav-icon-contact: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.9v3a2 2 0 0 1-2.2 2A19.8 19.8 0 0 1 3.1 5.2 2 2 0 0 1 5.1 3h3a2 2 0 0 1 2 1.7c.1.9.3 1.8.6 2.6a2 2 0 0 1-.5 2.1L9 10.7a16 16 0 0 0 6.3 6.3l1.3-1.3a2 2 0 0 1 2.1-.5c.8.3 1.7.5 2.6.6a2 2 0 0 1 1.7 2Z'/%3E%3C/svg%3E");
  --nav-icon-bulk: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 8h16v12H4z'/%3E%3Cpath d='m4 8 3-4h10l3 4'/%3E%3Cpath d='M9 12h6'/%3E%3C/svg%3E");
  --nav-icon-mail: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='6' width='16' height='12' rx='2'/%3E%3Cpath d='m4 7 8 6 8-6'/%3E%3C/svg%3E");
  --nav-icon-map: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21s7-5.1 7-12a7 7 0 0 0-14 0c0 6.9 7 12 7 12Z'/%3E%3Ccircle cx='12' cy='9' r='2.4'/%3E%3C/svg%3E");
  --nav-icon-clock: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='8'/%3E%3Cpath d='M12 8v5l3 2'/%3E%3C/svg%3E");
  --nav-icon-youtube: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M21.4 7.4a3 3 0 0 0-2.1-2.1C17.45 4.8 12 4.8 12 4.8s-5.45 0-7.3.5a3 3 0 0 0-2.1 2.1A31.5 31.5 0 0 0 2.1 12c0 1.6.17 3.2.5 4.6a3 3 0 0 0 2.1 2.1c1.85.5 7.3.5 7.3.5s5.45 0 7.3-.5a3 3 0 0 0 2.1-2.1c.33-1.4.5-3 .5-4.6s-.17-3.2-.5-4.6ZM10 15.2V8.8l5.5 3.2-5.5 3.2Z'/%3E%3C/svg%3E");
}

body {
  background: linear-gradient(135deg, #fffaf1 0%, #fff7ea 46%, #f7fbf5 100%) !important;
}

.site-shell {
  width: min(var(--max), calc(100% - clamp(24px, 4vw, 64px))) !important;
}

.header-inner.site-shell {
  width: min(1480px, calc(100% - clamp(24px, 4vw, 64px))) !important;
}

.site-header {
  background: rgba(255, 253, 248, 0.9) !important;
  border-bottom-color: rgba(20, 56, 45, 0.12) !important;
}

.brand-mark {
  width: 168px !important;
  height: 58px !important;
  padding: 2px 4px !important;
  flex: 0 0 168px !important;
  border: 1px solid rgba(211, 154, 45, 0.24) !important;
  box-shadow: 0 14px 34px rgba(15, 48, 38, 0.10) !important;
}

.site-footer .brand-mark {
  width: 260px !important;
  height: 90px !important;
  margin-inline: auto !important;
  display: block !important;
  flex: 0 0 auto !important;
}

.footer-title {
  text-align: center !important;
  color: var(--cocoa-deep) !important;
}

.footer-grid > div:first-child {
  text-align: center !important;
}

.brand-title,
.footer-title,
.section-title,
.hero h1,
.page-hero h1 {
  color: var(--cocoa-deep) !important;
}

.site-nav {
  gap: 4px !important;
}

.site-nav a {
  min-height: 64px !important;
  min-width: 72px;
  flex-direction: column !important;
  justify-content: center !important;
  gap: 4px !important;
  padding: 8px 9px !important;
  color: #2f4138 !important;
  font-size: 13px !important;
  line-height: 1.05 !important;
  text-align: center !important;
}

.site-nav a::before,
.footer-links a::before,
.footer-links span::before {
  content: "";
  display: inline-block;
  width: 23px;
  height: 23px;
  flex: 0 0 23px;
  background: currentColor;
  -webkit-mask: var(--nav-icon-home) center / contain no-repeat;
  mask: var(--nav-icon-home) center / contain no-repeat;
}

.site-nav a:hover,
.site-nav a[aria-current="page"] {
  color: var(--cocoa-deep) !important;
  background: linear-gradient(135deg, rgba(243, 213, 138, 0.40), rgba(255, 253, 248, 0.82)) !important;
  box-shadow: inset 0 -2px 0 rgba(211, 154, 45, 0.38);
}

.site-nav a[href="/"]::before,
.footer-links a[href="/"]::before { -webkit-mask-image: var(--nav-icon-home); mask-image: var(--nav-icon-home); }
.site-nav a[href="/legacy"]::before,
.footer-links a[href="/legacy"]::before { -webkit-mask-image: var(--nav-icon-legacy); mask-image: var(--nav-icon-legacy); }
.site-nav a[href="/jolbhora-story"]::before,
.footer-links a[href="/jolbhora-story"]::before { -webkit-mask-image: var(--nav-icon-jolbhora); mask-image: var(--nav-icon-jolbhora); }
.site-nav a[href="/products"]::before,
.footer-links a[href="/products"]::before { -webkit-mask-image: var(--nav-icon-sweets); mask-image: var(--nav-icon-sweets); }
.site-nav a[href="/business-enquiry"]::before,
.footer-links a[href^="/business-enquiry"]::before { -webkit-mask-image: var(--nav-icon-franchise); mask-image: var(--nav-icon-franchise); }
.site-nav a[href="/press-media"]::before,
.footer-links a[href="/press-media"]::before { -webkit-mask-image: var(--nav-icon-press); mask-image: var(--nav-icon-press); }
.site-nav a[href="/gallery"]::before,
.footer-links a[href="/gallery"]::before { -webkit-mask-image: var(--nav-icon-gallery); mask-image: var(--nav-icon-gallery); }
.site-nav a[href="/contact"]::before { -webkit-mask-image: var(--nav-icon-contact); mask-image: var(--nav-icon-contact); }
.footer-links a[href^="/bulk-orders"]::before { -webkit-mask-image: var(--nav-icon-bulk); mask-image: var(--nav-icon-bulk); }
.footer-links a[href^="tel:"]::before { -webkit-mask-image: var(--nav-icon-contact); mask-image: var(--nav-icon-contact); }
.footer-links a[href^="mailto:"]::before { -webkit-mask-image: var(--nav-icon-mail); mask-image: var(--nav-icon-mail); }
.footer-links a[href*="share.google"]::before { -webkit-mask-image: var(--nav-icon-map); mask-image: var(--nav-icon-map); }
.footer-links a[href*="youtube"]::before { -webkit-mask-image: var(--nav-icon-youtube); mask-image: var(--nav-icon-youtube); }
.footer-links span::before { -webkit-mask-image: var(--nav-icon-clock); mask-image: var(--nav-icon-clock); }

.site-footer {
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.94), rgba(255, 240, 216, 0.78)),
    linear-gradient(90deg, rgba(15, 111, 84, 0.10), rgba(211, 154, 45, 0.16), rgba(212, 20, 34, 0.04)) !important;
  border-top-color: rgba(20, 56, 45, 0.16) !important;
}

.site-footer h3 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--gold);
  color: var(--cocoa-deep) !important;
}

.footer-links a,
.footer-links span {
  display: flex !important;
  align-items: center;
  gap: 9px;
  color: #415248 !important;
  line-height: 1.35;
}

.footer-links a:hover {
  color: var(--cocoa-deep) !important;
}

.footer-bottom {
  padding-right: 112px !important;
}

.footer-links a::before,
.footer-links span::before {
  width: 19px;
  height: 19px;
  flex-basis: 19px;
  color: var(--gold);
}

.card,
.info-card,
.trust-item,
.process-list .card,
.quick-card,
.pr-link-card {
  text-align: center !important;
}

.card .tag,
.info-card .tag,
.kicker {
  margin-inline: auto;
}

.info-card,
.trust-item {
  display: grid !important;
  place-items: center !important;
}

.btn-primary {
  background: linear-gradient(135deg, var(--cocoa-deep), #0f6f54 54%, var(--gold)) !important;
  box-shadow: 0 16px 36px rgba(15, 111, 84, 0.22) !important;
}

.btn-secondary[href*="share.google"],
.btn-secondary[href*="maps"] {
  color: var(--cocoa-deep) !important;
  border-color: rgba(211, 154, 45, 0.35) !important;
}

.btn-accent,
.floating-actions .icon-btn[aria-label*="WhatsApp"] {
  background: linear-gradient(135deg, #075e54, #128c7e 48%, #25d366) !important;
}

.floating-actions .icon-btn[aria-label*="call"],
.call-option {
  background: linear-gradient(135deg, var(--cocoa-deep), var(--gold)) !important;
}

@media (max-width: 1280px) {
  .brand-mark {
    width: 144px !important;
    height: 52px !important;
    flex-basis: 144px !important;
  }

  .site-nav a {
    min-width: 64px;
    font-size: 12px !important;
    padding-inline: 6px !important;
  }
}

@media (max-width: 1120px) {
  .site-nav a {
    min-height: 52px !important;
    flex-direction: row !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    text-align: left !important;
  }
}

@media (max-width: 680px) {
  .site-shell,
  .header-inner.site-shell {
    width: min(var(--max), calc(100% - 24px)) !important;
  }

  .brand-mark {
    width: 112px !important;
    height: 42px !important;
    flex: 0 0 112px !important;
  }

  .site-footer .brand-mark {
    width: 210px !important;
    height: 74px !important;
  }

  .footer-grid > div,
  .footer-links a,
  .footer-links span {
    justify-content: center !important;
    text-align: center !important;
  }

  .footer-bottom {
    padding-right: 0 !important;
    text-align: center;
    justify-content: center !important;
  }
}

/* Phase 8U: keep the updated Suvendu Kumar Modak portrait uncropped on the Legacy page. */
.split-media img.legacy-suvendu-photo,
.legacy-sequence .image-card > img.legacy-suvendu-photo {
  object-fit: contain !important;
  object-position: center !important;
  background: rgba(255, 253, 248, 0.94);
}

.split-media img.legacy-suvendu-photo {
  width: min(100%, 620px) !important;
  height: auto !important;
  max-height: min(72vh, 620px) !important;
  aspect-ratio: 1 / 1 !important;
  margin-inline: auto;
}

/* Phase 8V: focused Legacy page additions. */
.split-media.legacy-suvendu-frame {
  width: fit-content !important;
  max-width: min(100%, 656px) !important;
  padding: 14px !important;
  margin-inline: auto !important;
}

.timeline-item {
  display: grid;
  gap: 9px;
}

.timeline-icon {
  width: 46px;
  height: 46px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: #113528;
  background:
    radial-gradient(circle at 35% 28%, rgba(255, 255, 255, 0.95), rgba(211, 154, 45, 0.18) 58%, rgba(15, 111, 84, 0.14)),
    rgba(255, 253, 248, 0.96);
  border: 1px solid rgba(211, 154, 45, 0.32);
  box-shadow: 0 12px 28px rgba(15, 48, 38, 0.10);
}

.timeline-icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.shailendra-story {
  display: grid;
  justify-items: center;
  gap: 28px;
  text-align: center;
}

.legacy-profile-frame {
  width: fit-content;
  max-width: min(100%, 560px);
  margin: 0 auto;
  padding: 12px;
  border: 1px solid rgba(211, 154, 45, 0.28);
  border-radius: 22px;
  background: rgba(255, 253, 248, 0.92);
  box-shadow: 0 22px 58px rgba(55, 34, 24, 0.12);
}

.legacy-profile-frame img {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: min(76vh, 680px);
  height: auto;
  object-fit: contain;
  border-radius: 14px;
}

.shailendra-story .content-block {
  max-width: 980px;
  margin-inline: auto;
}

.shailendra-story .content-block p {
  max-width: 920px;
  margin-inline: auto;
}

@media (max-width: 680px) {
  .timeline-item {
    justify-items: center;
    text-align: center;
  }

  .timeline-icon {
    width: 42px;
    height: 42px;
  }

  .legacy-profile-frame {
    padding: 9px;
    border-radius: 18px;
  }

  .split-media.legacy-suvendu-frame {
    padding: 10px !important;
  }
}

/* Phase 8W: international heritage polish and focused certificate refinement. */
:root {
  --max: 1280px;
  --heritage-green: #12382d;
  --heritage-green-soft: #eaf3ed;
  --heritage-red: #c91423;
  --heritage-gold: #d19a2d;
  --heritage-ivory: #fffaf0;
  --heritage-porcelain: #fffffb;
  --heritage-shadow: 0 26px 74px rgba(38, 33, 24, 0.12);
  --heritage-shadow-soft: 0 14px 42px rgba(38, 33, 24, 0.08);
}

html {
  background: #fffaf0;
}

body {
  color: #26211b;
  background:
    radial-gradient(circle at 7% 8%, rgba(201, 20, 35, 0.045), transparent 30%),
    radial-gradient(circle at 92% 16%, rgba(18, 56, 45, 0.07), transparent 32%),
    linear-gradient(135deg, #fffdf8 0%, #fff7e8 42%, #f5fbf7 100%) !important;
}

.site-shell {
  width: min(var(--max), calc(100% - 36px)) !important;
}

.site-header {
  border-bottom: 1px solid rgba(18, 56, 45, 0.10) !important;
  background:
    linear-gradient(90deg, rgba(255, 253, 248, 0.96), rgba(255, 249, 238, 0.94), rgba(248, 255, 251, 0.94)) !important;
  box-shadow: 0 12px 32px rgba(48, 35, 24, 0.07) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.brand-title,
.footer-title {
  color: #1b322a !important;
}

.brand-subtitle {
  color: rgba(54, 45, 37, 0.72) !important;
}

.site-nav a {
  color: rgba(39, 34, 29, 0.78) !important;
  border-radius: 16px !important;
}

.site-nav a:hover,
.site-nav a[aria-current="page"] {
  color: #172f27 !important;
  background: linear-gradient(180deg, rgba(250, 242, 226, 0.98), rgba(232, 244, 236, 0.74)) !important;
  box-shadow: inset 0 -2px 0 rgba(209, 154, 45, 0.35) !important;
}

.page-hero,
.section {
  position: relative;
}

.page-hero::after,
.section::after {
  content: "";
  position: absolute;
  inset-inline: max(18px, calc((100vw - var(--max)) / 2));
  bottom: 0;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(209, 154, 45, 0.22), rgba(18, 56, 45, 0.12), transparent);
}

.page-hero h1,
.hero-brand-title,
.section-title,
.section-header h2,
.content-block h2 {
  color: #3f241d !important;
  font-family: "Cormorant Garamond", Georgia, serif !important;
  font-weight: 700 !important;
  text-wrap: balance;
}

.page-hero h1,
.section-header h2,
.section-title {
  letter-spacing: 0 !important;
}

.page-hero p,
.section-lead,
.content-block p,
.card p {
  color: rgba(47, 41, 35, 0.76) !important;
}

.kicker {
  color: #7e2a22 !important;
  border-color: rgba(209, 154, 45, 0.32) !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(249, 238, 217, 0.78), rgba(232, 244, 236, 0.68)) !important;
  box-shadow: 0 10px 26px rgba(55, 34, 24, 0.06) !important;
}

.card,
.image-card,
.archive-card,
.quick-card,
.contact-route-card,
.archive-route-card,
.info-card,
.process-card,
.publication-card,
.map-card,
.content-block,
.page-hero-content {
  border-color: rgba(18, 56, 45, 0.10) !important;
  background:
    linear-gradient(145deg, rgba(255, 255, 252, 0.96), rgba(255, 248, 235, 0.78) 54%, rgba(242, 250, 245, 0.72)) !important;
  box-shadow: var(--heritage-shadow-soft) !important;
}

.card:hover,
.image-card:hover,
.archive-card:hover,
.publication-card:hover,
.contact-route-card:hover,
.archive-route-card:hover {
  border-color: rgba(209, 154, 45, 0.34) !important;
  box-shadow: 0 28px 76px rgba(38, 33, 24, 0.14) !important;
  transform: translateY(-4px);
}

.btn {
  border-radius: 999px !important;
  box-shadow: 0 14px 32px rgba(38, 33, 24, 0.10) !important;
}

.btn-primary {
  background: linear-gradient(135deg, #7b4026, #b6782e 52%, var(--heritage-gold)) !important;
}

.btn-accent {
  background: linear-gradient(135deg, #0a6c55, #0e9f7e 52%, #23cf74) !important;
}

.btn-secondary {
  background: rgba(255, 255, 250, 0.92) !important;
  border-color: rgba(91, 53, 40, 0.16) !important;
}

.page-hero.has-media .page-hero-media,
.split-media,
.story-media,
.certificate-frame,
.legacy-profile-frame {
  border-color: rgba(209, 154, 45, 0.26) !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 252, 0.98), rgba(255, 247, 232, 0.86)) !important;
  box-shadow: var(--heritage-shadow) !important;
}

.page-hero.has-media .page-hero-media img,
.split-media img,
.story-media img,
.image-card > img,
.archive-card img {
  filter: saturate(1.04) contrast(1.02);
}

body.home-redesign .home-atelier {
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 255, 255, 0.78), transparent 36%),
    linear-gradient(135deg, #fffaf0 0%, #fffdf9 48%, #f4fbf7 100%) !important;
}

body.home-redesign .home-atelier .hero-content {
  filter: drop-shadow(0 18px 35px rgba(255, 250, 242, 0.74));
}

body.home-redesign .home-showcase-main {
  border-color: rgba(209, 154, 45, 0.38) !important;
  box-shadow:
    0 34px 92px rgba(44, 33, 24, 0.18),
    0 0 0 1px rgba(255, 255, 255, 0.72) inset !important;
}

body.home-redesign .home-showcase-main img {
  object-fit: cover !important;
  object-position: center !important;
}

body.home-redesign .home-showcase-note {
  border-color: rgba(209, 154, 45, 0.30) !important;
  background: rgba(255, 253, 248, 0.94) !important;
}

body.home-redesign .home-showcase-note strong {
  color: #4a271f !important;
}

.trust-item strong {
  color: #4a271f !important;
}

.trust-item span:last-child {
  color: rgba(31, 53, 45, 0.74) !important;
}

.press-certificate-showcase .press-certificate-layout {
  grid-template-columns: minmax(280px, auto) minmax(320px, 520px) !important;
  justify-content: center !important;
  align-items: center !important;
  gap: clamp(30px, 4vw, 58px) !important;
  max-width: 1120px !important;
}

.press-certificate-frame {
  width: fit-content !important;
  max-width: min(100%, 500px) !important;
  justify-self: center !important;
  padding: 12px !important;
  border-radius: 18px !important;
}

.press-certificate-frame img {
  display: block !important;
  width: auto !important;
  max-width: min(100%, 440px) !important;
  height: auto !important;
  max-height: min(82vh, 760px) !important;
  object-fit: contain !important;
  object-position: center !important;
}

.press-certificate-showcase .content-block {
  max-width: 520px !important;
}

.publication-card {
  background:
    linear-gradient(135deg, rgba(255, 255, 252, 0.98), rgba(249, 241, 224, 0.76)) !important;
}

.publication-logo,
.timeline-icon {
  box-shadow: 0 10px 24px rgba(18, 56, 45, 0.12) !important;
}

.site-footer {
  background:
    linear-gradient(135deg, rgba(255, 250, 241, 0.98), rgba(243, 251, 246, 0.95)),
    radial-gradient(circle at 0 0, rgba(201, 20, 35, 0.06), transparent 36%) !important;
  border-top: 1px solid rgba(18, 56, 45, 0.10) !important;
}

.footer-grid {
  gap: clamp(28px, 5vw, 74px) !important;
}

.footer-links a,
.footer-links span {
  color: rgba(30, 49, 42, 0.82) !important;
}

@media (min-width: 1024px) {
  .section {
    padding-top: clamp(74px, 7vw, 118px) !important;
    padding-bottom: clamp(74px, 7vw, 118px) !important;
  }

  .page-hero-layout,
  .split-panel,
  .center-story {
    gap: clamp(42px, 6vw, 96px) !important;
  }
}

@media (max-width: 900px) {
  .press-certificate-showcase .press-certificate-layout {
    grid-template-columns: 1fr !important;
    text-align: center !important;
  }

  .press-certificate-showcase .content-block {
    margin-inline: auto !important;
  }
}

@media (max-width: 680px) {
  .site-shell {
    width: min(calc(100% - 24px), 390px) !important;
  }

  .press-certificate-frame {
    max-width: 100% !important;
    padding: 8px !important;
  }

  .press-certificate-frame img {
    max-width: 100% !important;
    max-height: 70vh !important;
  }
}

/* Phase 8X: business enquiry label stability. */
.site-nav a[href="/business-enquiry"] {
  min-width: 98px !important;
  text-align: center !important;
}

@media (max-width: 1180px) {
  .site-nav a[href="/business-enquiry"] {
    min-width: 86px !important;
  }
}

