:root {
  --ink: #27130c;
  --muted: #766156;
  --paper: #fffaf1;
  --cream: #fff2c2;
  --sun: #ffb000;
  --orange: #f46a00;
  --red: #e53212;
  --green: #19a66a;
  --blue: #1977c9;
  --line: rgba(39, 19, 12, .14);
  --shadow: 0 22px 70px rgba(67, 29, 11, .16);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.55;
  overflow-x: hidden;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
.skip {
  position: absolute;
  left: -999px;
  top: 0;
  padding: 10px 14px;
  background: #fff;
  z-index: 1000;
}
.skip:focus { left: 12px; top: 12px; }

.topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  padding: 12px 18px;
  background: linear-gradient(180deg, rgba(255,250,241,.96), rgba(255,250,241,.58));
  backdrop-filter: blur(14px);
}
.topbar__inner {
  width: min(1180px, 100%);
  min-height: 66px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 8px 14px;
  background: rgba(255, 255, 255, .78);
  border: 1px solid rgba(39, 19, 12, .12);
  border-radius: 8px;
  box-shadow: 0 18px 60px rgba(67, 29, 11, .12);
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-weight: 900;
  color: var(--red);
  letter-spacing: 0;
}
.brand img { width: 46px; height: 46px; object-fit: contain; }
.nav {
  display: flex;
  flex: 1;
  justify-content: flex-end;
}
.nav__list,
.nav__submenu {
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav__list {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  width: 100%;
}
.nav__item {
  position: relative;
}
.nav__item > a {
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 38px;
  transition: color .2s ease, background .2s ease, transform .2s ease;
}
.nav a {
  text-decoration: none;
  font-size: 13px;
  font-weight: 800;
  padding: 8px 10px;
  border-radius: 8px;
  color: rgba(39, 19, 12, .78);
}
.nav a:hover,
.nav__item.is-active > a {
  color: var(--red);
  background: rgba(255, 176, 0, .16);
  transform: translateY(-1px);
}
.nav__submenu {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 80;
  min-width: 260px;
  max-width: 360px;
  padding: 8px;
  background: rgba(255, 255, 255, .96);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
}
.nav__submenu .nav__item > a {
  justify-content: space-between;
  width: 100%;
  white-space: normal;
  line-height: 1.25;
}
.nav__submenu .nav__submenu {
  top: -8px;
  left: calc(100% + 8px);
}
.nav__item:hover > .nav__submenu,
.nav__item:focus-within > .nav__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.nav__list > .nav__item:nth-last-child(-n+3) > .nav__submenu {
  left: auto;
  right: 0;
}
.menu-toggle { display: none; }

.hero {
  position: relative;
  min-height: calc(100svh - 74px);
  display: grid;
  align-items: center;
  overflow: hidden;
  background: radial-gradient(circle at 15% 20%, rgba(255, 176, 0, .34), transparent 28%),
              linear-gradient(135deg, #fff8df 0%, #ffe4a6 42%, #fffaf1 100%);
}
.hero::before,
.hero::after {
  content: "";
  position: absolute;
  inset: auto -8% 8% -8%;
  height: 36%;
  background:
    repeating-linear-gradient(115deg, rgba(229, 50, 18, .18) 0 12px, transparent 12px 34px),
    repeating-linear-gradient(65deg, rgba(25, 166, 106, .16) 0 10px, transparent 10px 32px);
  transform: rotate(-2deg);
  opacity: .7;
  animation: surfaceDrift 16s linear infinite;
}
.hero::after {
  inset: 8% -10% auto -10%;
  height: 20%;
  opacity: .24;
  transform: rotate(4deg);
  animation-duration: 24s;
  animation-direction: reverse;
}
#granuleCanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.hero__inner {
  position: relative;
  width: min(880px, calc(100% - 36px));
  margin: 0 auto;
  text-align: center;
  padding: 72px 0 96px;
}
.kicker {
  margin: 0 0 12px;
  color: var(--red);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}
h1, h2, h3 { line-height: 1.02; letter-spacing: 0; }
h1 {
  margin: 0;
  font-size: clamp(46px, 9vw, 118px);
  font-weight: 950;
}
.hero h1 { text-shadow: 0 10px 34px rgba(229, 50, 18, .16); }
h2 { font-size: clamp(30px, 4vw, 58px); margin: 0 0 20px; }
h3 { font-size: 24px; margin: 24px 0 10px; }
.hero p:not(.kicker), .page-head p, .split p, .content p, .content li {
  font-size: clamp(17px, 2vw, 21px);
  color: var(--muted);
}
.hero__actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border-radius: 8px;
  border: 1px solid var(--line);
  text-decoration: none;
  font-weight: 900;
  transition: transform .22s ease, box-shadow .22s ease;
}
.btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 42px rgba(67, 29, 11, .18);
}
.btn--primary {
  background: linear-gradient(135deg, var(--sun), var(--red));
  color: #fff;
  border: 0;
  box-shadow: var(--shadow);
}
.btn--ghost { background: rgba(255, 255, 255, .62); }
.btn--small { min-height: 38px; padding: 8px 12px; font-size: 14px; }

.band, .split, .content, .page-head, .gallery, .gallery-nav, .pdf-grid {
  width: min(1180px, calc(100% - 36px));
  margin-left: auto;
  margin-right: auto;
}
.stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: -46px;
  position: relative;
  z-index: 3;
  overflow: hidden;
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.stats article {
  background: #fff;
  padding: 24px;
  min-height: 116px;
  transition: transform .25s ease, background .25s ease;
}
.stats article:hover {
  background: #fff7dd;
  transform: translateY(-4px);
}
.stats strong { display: block; font-size: 34px; color: var(--red); }
.stats span { color: var(--muted); font-weight: 800; }

.split {
  display: grid;
  grid-template-columns: 1fr .9fr;
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
  padding: 96px 0 50px;
}
.feature-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.feature-grid a {
  min-height: 150px;
  display: flex;
  align-items: end;
  padding: 18px;
  color: #fff;
  text-decoration: none;
  font-size: 22px;
  font-weight: 950;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--orange), var(--red));
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition: transform .25s ease, box-shadow .25s ease;
}
.feature-grid a::before {
  content: "";
  position: absolute;
  inset: -40%;
  background: repeating-linear-gradient(45deg, rgba(255,255,255,.24) 0 8px, transparent 8px 24px);
  transform: translateX(-35%) rotate(8deg);
  transition: transform .45s ease;
  z-index: -1;
}
.feature-grid a:hover {
  transform: translateY(-6px) rotate(-.5deg);
  box-shadow: 0 26px 70px rgba(67, 29, 11, .22);
}
.feature-grid a:hover::before { transform: translateX(22%) rotate(8deg); }
.feature-grid a:nth-child(2) { background: linear-gradient(135deg, var(--blue), var(--green)); }
.feature-grid a:nth-child(3) { background: linear-gradient(135deg, var(--sun), var(--orange)); }
.feature-grid a:nth-child(4) { background: linear-gradient(135deg, var(--green), #0b7f55); }

.page-head {
  padding: 72px 0 28px;
  position: relative;
  isolation: isolate;
}
.page-head::before {
  content: "";
  position: absolute;
  inset: 32px 0 8px;
  z-index: -1;
  min-height: 210px;
  border-radius: 8px;
  background:
    linear-gradient(120deg, rgba(229,50,18,.12), transparent 36%),
    linear-gradient(300deg, rgba(25,166,106,.12), transparent 40%),
    repeating-linear-gradient(105deg, rgba(255,176,0,.26) 0 10px, transparent 10px 38px),
    rgba(255,255,255,.42);
  border: 1px solid rgba(39, 19, 12, .08);
  box-shadow: 0 22px 64px rgba(67,29,11,.08);
  animation: headerSheen 12s ease-in-out infinite alternate;
}
.page-head h1 { font-size: clamp(40px, 6vw, 82px); }
.content {
  padding: 10px 0 70px;
}
.content h2 {
  margin-top: 40px;
  display: inline-block;
  padding-bottom: 8px;
  background: linear-gradient(90deg, var(--red), var(--sun), var(--green)) left bottom / 100% 4px no-repeat;
}
.content ul {
  padding-left: 20px;
}
.section-title {
  width: min(1180px, calc(100% - 36px));
  margin: 56px auto 18px;
  font-size: clamp(26px, 3vw, 42px);
}
.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  padding-bottom: 38px;
}
.gallery__item {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 8px;
  background: #f4d99a;
  box-shadow: 0 12px 36px rgba(39, 19, 12, .12);
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.gallery__item:hover img { transform: scale(1.07); }
.gallery__item:hover {
  transform: translateY(-5px);
  box-shadow: 0 22px 54px rgba(39, 19, 12, .2);
}
.gallery__item::after {
  content: "Ver";
  position: absolute;
  right: 10px;
  bottom: 10px;
  padding: 7px 10px;
  border-radius: 8px;
  background: rgba(255, 250, 241, .9);
  color: var(--red);
  font-size: 12px;
  font-weight: 950;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .2s ease, transform .2s ease;
}
.gallery__item:hover::after {
  opacity: 1;
  transform: translateY(0);
}
.gallery[data-gallery="parceiros"] {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}
.gallery[data-gallery="parceiros"] .gallery__item {
  aspect-ratio: 3 / 2;
  padding: 20px;
  background: #fff;
}
.gallery[data-gallery="parceiros"] .gallery__item img {
  object-fit: contain;
}
.gallery[data-gallery="parceiros"] .gallery__item:hover img {
  transform: scale(1.03);
}
.gallery-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.gallery-nav a {
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  text-decoration: none;
  font-weight: 850;
}
.pdf-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  padding: 12px 0 80px;
}
.pdf-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 18px;
  box-shadow: 0 12px 38px rgba(39, 19, 12, .08);
}
.pdf-card h2 {
  font-size: 21px;
  margin-bottom: 20px;
}
.review-link {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  color: #fff;
  text-decoration: none;
  font-size: 24px;
  font-weight: 950;
}
.review-link span { font-size: 14px; }
.footer {
  padding: 54px clamp(18px, 4vw, 56px);
  background: linear-gradient(180deg, #35170c, #201007);
  color: #fff7df;
}
.footer__main {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.25fr 1fr .72fr .85fr;
  gap: clamp(22px, 4vw, 56px);
  align-items: center;
}
.footer a { color: #fff7df; text-decoration: none; }
.footer__contacts a { display: inline-block; margin: 4px 0; }
.footer h2 { font-size: 18px; margin: 0 0 14px; }
.footer__logo { width: 86px; filter: drop-shadow(0 8px 20px rgba(0,0,0,.25)); }
.footer__brand p,
.footer__contacts p {
  color: rgba(255, 247, 223, .78);
}
.footer__guarantee img {
  width: min(150px, 100%);
  margin: 0 auto;
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.26));
}
.footer__rating {
  justify-self: end;
  text-align: right;
}
.footer__legal {
  width: min(1180px, 100%);
  margin-left: auto;
  margin-right: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 38px;
  padding-top: 20px;
  border-top: 1px solid rgba(255, 247, 223, .18);
  color: rgba(255, 247, 223, .72);
  font-size: 13px;
}
.footer__legal nav {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.footer__legal p {
  margin: 0;
  text-align: right;
}
.call-note { font-size: 13px; opacity: .78; }
.cookiebar {
  position: fixed;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 60;
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  max-width: 860px;
  margin: auto;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.cookiebar.is-visible { display: flex; }
.cookiebar p { margin: 0; color: var(--muted); }
.cookiebar button {
  border: 0;
  border-radius: 8px;
  padding: 10px 14px;
  background: var(--red);
  color: #fff;
  font-weight: 900;
}

.lightbox {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 70px 76px;
  background: rgba(22, 10, 5, .88);
  backdrop-filter: blur(10px);
}
.lightbox.is-open { display: flex; }
.lightbox img {
  max-width: min(1120px, 100%);
  max-height: 82vh;
  border-radius: 8px;
  box-shadow: 0 26px 90px rgba(0,0,0,.46);
}
.lightbox button {
  position: absolute;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 8px;
  background: rgba(255,255,255,.12);
  color: #fff;
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
}
.lightbox__close { top: 22px; right: 22px; }
.lightbox__prev { left: 22px; top: 50%; transform: translateY(-50%); }
.lightbox__next { right: 22px; top: 50%; transform: translateY(-50%); }

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@keyframes granuleShift {
  from { background-position: 0 0, 0 0, 0 0, 0 0; }
  to { background-position: 116px 58px, -72px 72px, 64px -64px, 0 0; }
}

@keyframes surfaceDrift {
  from { background-position: 0 0, 0 0; }
  to { background-position: 360px 0, -360px 0; }
}

@keyframes headerSheen {
  from { background-position: 0 0, 0 0, 0 0, 0 0; }
  to { background-position: 0 0, 0 0, 180px 0, 0 0; }
}

@media (max-width: 900px) {
  .topbar { align-items: flex-start; }
  .topbar__inner {
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .menu-toggle {
    display: inline-flex;
    margin-left: auto;
    border: 1px solid var(--line);
    background: #fff;
    border-radius: 8px;
    padding: 10px 12px;
    font-weight: 900;
  }
  .nav {
    display: none;
    width: 100%;
    flex-basis: 100%;
    justify-content: flex-start;
  }
  .nav.is-open { display: flex; }
  .nav__list {
    align-items: stretch;
    flex-direction: column;
  }
  .nav__item > a {
    justify-content: space-between;
  }
  .nav__submenu,
  .nav__submenu .nav__submenu {
    position: static;
    display: block;
    min-width: 0;
    max-width: none;
    margin: 4px 0 8px 12px;
    padding: 4px;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    background: rgba(255, 176, 0, .08);
  }
  .stats, .split, .footer__main { grid-template-columns: 1fr; }
  .footer__rating {
    justify-self: start;
    text-align: left;
  }
  .footer__guarantee img {
    margin: 0;
  }
  .footer__legal {
    align-items: flex-start;
    flex-direction: column;
  }
  .footer__legal p {
    text-align: left;
  }
  .feature-grid, .gallery { grid-template-columns: repeat(2, 1fr); }
  .lightbox {
    padding: 64px 16px;
  }
  .lightbox__prev { left: 10px; }
  .lightbox__next { right: 10px; }
}

@media (max-width: 560px) {
  .hero__inner { text-align: left; }
  .hero__actions { justify-content: flex-start; }
  .feature-grid, .gallery { grid-template-columns: 1fr; }
  .cookiebar { align-items: stretch; flex-direction: column; }
}

/* Premium visual refresh */
body {
  background:
    linear-gradient(180deg, #fffaf1 0%, #fff5dc 22%, #fffaf1 52%, #ffffff 100%);
}

.topbar {
  padding-top: 16px;
}

.topbar__inner {
  min-height: 72px;
  padding: 10px 16px;
  background: rgba(255, 255, 255, .72);
  border-color: rgba(255, 176, 0, .22);
  box-shadow: 0 18px 80px rgba(39, 19, 12, .14);
}

.brand {
  font-size: 18px;
  letter-spacing: 0;
}

.brand img {
  width: 52px;
  height: 52px;
  filter: drop-shadow(0 12px 18px rgba(229, 50, 18, .18));
}

.nav a {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0;
}

.nav__list > .nav__item > a {
  padding: 10px 12px;
}

.nav__submenu {
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,248,224,.96));
  border-color: rgba(255, 176, 0, .22);
  box-shadow: 0 26px 80px rgba(39, 19, 12, .18);
}

.hero {
  min-height: calc(100svh - 88px);
  background:
    radial-gradient(circle at 50% 22%, rgba(255, 176, 0, .38), transparent 26%),
    radial-gradient(circle at 12% 72%, rgba(25, 166, 106, .24), transparent 27%),
    radial-gradient(circle at 86% 66%, rgba(25, 119, 201, .20), transparent 24%),
    linear-gradient(145deg, #2b130a 0%, #6a210f 42%, #f46a00 82%, #ffcf52 100%);
}

.hero::before {
  inset: auto -12% 0 -12%;
  height: 42%;
  opacity: .46;
  mix-blend-mode: screen;
}

.hero::after {
  display: none;
}

.hero__photo-field {
  position: absolute;
  inset: 0;
  overflow: hidden;
  opacity: .76;
}

.hero__photo {
  position: absolute;
  width: clamp(150px, 18vw, 300px);
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 1px solid rgba(255,255,255,.34);
  border-radius: 8px;
  box-shadow: 0 26px 70px rgba(0,0,0,.22);
  filter: saturate(1.12) contrast(1.04);
  animation: photoFloat 11s ease-in-out infinite;
}

.hero__photo--1 { left: 4%; top: 16%; transform: rotate(-9deg); animation-delay: -.6s; }
.hero__photo--2 { right: 7%; top: 12%; transform: rotate(8deg); animation-delay: -1.8s; }
.hero__photo--3 { left: 12%; bottom: 8%; transform: rotate(5deg); animation-delay: -3s; }
.hero__photo--4 { right: 15%; bottom: 10%; transform: rotate(-6deg); animation-delay: -4.2s; }
.hero__photo--5 { left: 40%; top: 4%; transform: rotate(3deg); animation-delay: -5.4s; }
.hero__photo--6 { right: -2%; top: 43%; transform: rotate(-12deg); animation-delay: -2.4s; }
.hero__photo--7 { left: -2%; top: 44%; transform: rotate(12deg); animation-delay: -6.6s; }
.hero__photo--8 { left: 31%; bottom: -4%; transform: rotate(-4deg); animation-delay: -7.8s; }
.hero__photo--9 { right: 36%; bottom: 3%; transform: rotate(7deg); animation-delay: -9s; }

.hero__inner {
  width: min(920px, calc(100% - 36px));
  min-height: calc(100svh - 120px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 78px 0 118px;
  color: #fff;
  text-shadow: 0 10px 34px rgba(0,0,0,.22);
}

.hero__inner::before {
  content: "";
  position: absolute;
  inset: 12% 2%;
  z-index: -1;
  border-radius: 8px;
  background: rgba(43, 19, 10, .38);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 32px 100px rgba(0,0,0,.24);
  backdrop-filter: blur(14px);
}

.hero .kicker {
  color: #ffe89a;
}

.hero h1 {
  max-width: 900px;
  font-size: clamp(54px, 10vw, 132px);
  color: #fff;
  text-shadow: 0 18px 50px rgba(0,0,0,.28);
}

.hero p:not(.kicker) {
  max-width: 760px;
  color: rgba(255,255,255,.88);
}

.hero__chips {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.hero__chips span {
  padding: 8px 11px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 8px;
  background: rgba(255,255,255,.12);
  color: #fff7df;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.stats {
  margin-top: -74px;
  border: 1px solid rgba(255,255,255,.5);
}

.stats article {
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(14px);
}

.split {
  padding-top: 120px;
}

.feature-grid a {
  min-height: 190px;
  font-size: 26px;
}

.page-head {
  padding-top: 82px;
  padding-bottom: 54px;
}

.page-head::before {
  inset: 34px 0 18px;
  background:
    linear-gradient(120deg, rgba(229,50,18,.16), transparent 32%),
    linear-gradient(300deg, rgba(25,119,201,.13), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.84), rgba(255,242,194,.48));
}

.page-head h1 {
  max-width: 980px;
}

.content {
  max-width: 980px;
}

.content p,
.content li {
  color: #5c463a;
}

.content h2 {
  font-size: clamp(28px, 3vw, 44px);
}

.gallery {
  gap: 16px;
}

.gallery__item {
  border: 1px solid rgba(255,255,255,.62);
  box-shadow: 0 18px 54px rgba(67,29,11,.12);
}

.gallery__item::after {
  content: "Abrir";
}

.footer {
  background:
    radial-gradient(circle at 12% 20%, rgba(255,176,0,.18), transparent 26%),
    radial-gradient(circle at 88% 70%, rgba(229,50,18,.22), transparent 24%),
    linear-gradient(180deg, #35170c, #170a05);
}

@keyframes photoFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -18px; }
}

@media (max-width: 900px) {
  .hero__photo {
    opacity: .46;
  }
  .hero__photo--5,
  .hero__photo--8,
  .hero__photo--9 {
    display: none;
  }
  .hero__inner::before {
    inset: 9% 0;
  }
}

/* Final playground-surface direction */
.topbar {
  padding: 14px 18px 8px;
  background:
    linear-gradient(90deg, #e53212 0 18%, #ffb000 18% 38%, #19a66a 38% 58%, #1977c9 58% 76%, #f46a00 76% 100%) top / 100% 5px no-repeat,
    rgba(255, 250, 241, .94);
}

.topbar__inner {
  min-height: 78px;
  padding: 10px 12px 10px 18px;
  background: #fffdf7;
  border: 1px solid rgba(39,19,12,.10);
  border-radius: 8px;
  box-shadow: 0 14px 42px rgba(39,19,12,.10);
}

.brand {
  min-width: 168px;
  gap: 12px;
  color: var(--ink);
}

.brand img {
  width: 64px;
  height: 64px;
  padding: 5px;
  border-radius: 50%;
  background: linear-gradient(145deg, #fff4bd, #fff);
  box-shadow: 0 12px 28px rgba(229,50,18,.16);
}

.brand span {
  display: inline-flex;
  flex-direction: column;
  font-size: 24px;
  line-height: 1;
  font-weight: 950;
  color: var(--red);
}

.brand span::after {
  content: "Pavimento IN-SITU";
  margin-top: 4px;
  color: var(--muted);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.nav__list {
  gap: 2px;
}

.nav__list > .nav__item > a {
  min-height: 44px;
  padding: 10px 12px;
  color: #4b3428;
  border: 1px solid transparent;
}

.nav__list > .nav__item > a:hover,
.nav__list > .nav__item.is-active > a {
  color: var(--ink);
  background: #fff5d2;
  border-color: rgba(255,176,0,.36);
  transform: none;
}

.nav__list > .nav__item > a::before {
  content: "";
  flex: 0 0 auto;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--sun);
  box-shadow: 10px 0 0 var(--red), 20px 0 0 var(--green);
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .18s ease, transform .18s ease;
  margin-right: 20px;
}

.nav__list > .nav__item > a:hover::before,
.nav__list > .nav__item.is-active > a::before {
  opacity: 1;
  transform: translateX(0);
}

.nav__submenu {
  top: calc(100% + 12px);
  padding: 10px;
  background: #fffdf7;
  border-color: rgba(39,19,12,.10);
  box-shadow: 0 22px 54px rgba(39,19,12,.16);
}

.nav__submenu a {
  border-radius: 6px;
}

.hero {
  min-height: calc(100svh - 100px);
  background:
    linear-gradient(120deg, rgba(229,50,18,.92), rgba(244,106,0,.72) 38%, rgba(255,176,0,.78) 68%, rgba(25,166,106,.78)),
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.34), transparent 25%),
    #f46a00;
}

.hero::before {
  inset: auto -10% 0 -10%;
  height: 48%;
  opacity: .32;
  mix-blend-mode: normal;
}

.hero__photo-field::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(43,19,10,.82), rgba(43,19,10,.26) 46%, rgba(43,19,10,.72)),
    radial-gradient(circle at 50% 50%, transparent 0 28%, rgba(43,19,10,.42) 74%);
}

.hero__photo {
  width: clamp(170px, 20vw, 330px);
  border: 3px solid rgba(255,255,255,.72);
  box-shadow: 0 24px 74px rgba(43,19,10,.36);
}

.hero__inner {
  width: min(960px, calc(100% - 36px));
}

.hero__inner::before {
  inset: 10% 0;
  background: linear-gradient(180deg, rgba(43,19,10,.56), rgba(43,19,10,.34));
  border-color: rgba(255,255,255,.24);
}

.hero h1 {
  letter-spacing: 0;
}

.hero__chips span {
  background: rgba(255,255,255,.18);
}

.split {
  grid-template-columns: minmax(0, 860px);
  justify-content: center;
  text-align: center;
  padding-top: 92px;
}

.split .kicker {
  color: var(--red);
}

.page-head {
  width: min(1180px, calc(100% - 36px));
  padding: 74px 0 44px;
  overflow: hidden;
}

.page-head::before {
  inset: 26px 0 14px;
  background:
    linear-gradient(90deg, #fffdf7, #fff4c6);
  border-left: 8px solid var(--red);
  animation: none;
}

.page-head::after {
  content: "";
  position: absolute;
  right: 28px;
  bottom: 28px;
  z-index: -1;
  width: min(280px, 36vw);
  height: 64px;
  border-radius: 999px;
  background:
    linear-gradient(90deg, var(--red) 0 18%, var(--sun) 18% 42%, var(--green) 42% 66%, var(--blue) 66% 100%);
  opacity: .18;
}

.page-head .kicker {
  color: #9b2b13;
}

.page-head h1 {
  font-size: clamp(40px, 5vw, 76px);
}

.stats {
  border-radius: 8px;
}

.stats article {
  text-align: center;
}

.gallery__item {
  border-radius: 8px;
  background: #fff7dd;
}

.gallery[data-gallery="experiencias"] {
  grid-template-columns: 1fr;
  max-width: 980px;
}

.gallery[data-gallery="experiencias"] .gallery__item {
  aspect-ratio: auto;
  padding: 14px;
  background: #fff;
}

.gallery[data-gallery="experiencias"] .gallery__item img {
  height: auto;
  object-fit: contain;
}

.partners-content {
  max-width: 1180px;
}

.partner-group {
  display: grid;
  grid-template-columns: minmax(260px, .85fr) 1.15fr;
  gap: clamp(22px, 4vw, 54px);
  align-items: center;
  margin: 0 0 28px;
  padding: clamp(18px, 3vw, 34px);
  border: 1px solid rgba(39,19,12,.10);
  border-radius: 8px;
  background: linear-gradient(135deg, #fff, #fff5d9);
  box-shadow: 0 18px 54px rgba(67,29,11,.08);
}

.partner-group h2 {
  margin-top: 0;
}

.partner-logos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 14px;
}

.partner-logos img {
  width: 100%;
  height: 112px;
  object-fit: contain;
  padding: 18px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(39,19,12,.08);
  box-shadow: 0 10px 28px rgba(67,29,11,.07);
}

.partner-group--single .partner-logos {
  max-width: 260px;
}

@media (max-width: 760px) {
  .partner-group {
    grid-template-columns: 1fr;
  }
}

/* Footer final layout */
.footer {
  padding: 56px 18px 28px;
  background: #fffaf1;
  color: var(--sje-ink);
  border-top: 1px solid rgba(39,19,12,.08);
}

.footer__main {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.12fr 1fr 1fr .96fr;
  gap: clamp(24px, 4vw, 52px);
  align-items: start;
  padding: 30px 0 0;
  border: 0;
  border-top: 6px solid transparent;
  border-image: linear-gradient(90deg, var(--sje-red), var(--sje-yellow), var(--sje-green), var(--sje-blue)) 1;
  background: transparent;
  border-radius: 0;
}

.footer__legal {
  width: min(1180px, 100%);
  margin: 34px auto 0;
  padding: 18px 0 0;
  background: transparent;
  border: 0;
  border-top: 1px solid rgba(39,19,12,.10);
  border-radius: 0;
  color: #6f5548;
}

.footer__logo {
  width: 108px;
  filter: none;
}

.footer a {
  color: var(--sje-ink);
}

.footer__brand p,
.footer__address p,
.footer__contacts p {
  color: #6f5548;
}

.footer h2 {
  color: var(--sje-ink);
}

.footer__trust {
  display: grid;
  gap: 12px;
}

.footer__guarantee-img {
  width: 118px;
  height: auto;
  margin: 0 0 4px;
}

.footer-link,
.footer-action {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
  text-decoration: none;
}

.footer-action {
  padding: 10px;
  border: 1px solid rgba(39,19,12,.10);
  border-radius: 8px;
  background: #fff;
}

.footer-icon {
  flex: 0 0 34px;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #fff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange));
  box-shadow: 0 10px 22px rgba(229, 50, 18, .16);
}

.footer-icon--mail { background: linear-gradient(135deg, var(--sje-blue), var(--sje-green)); }
.footer-icon--phone { background: linear-gradient(135deg, var(--sje-orange), var(--sje-yellow)); }
.footer-icon--facebook { background: #1877f2; font-family: Arial, sans-serif; font-size: 22px; }
.footer-icon--star { background: linear-gradient(135deg, var(--sje-yellow), var(--sje-red)); }

.footer-action span:last-child {
  display: grid;
  gap: 2px;
  font-weight: 950;
}

.footer-action small {
  color: #6f5548;
  font-size: 12px;
  font-weight: 800;
}

.footer-action--google {
  color: var(--sje-red);
}

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

/* Footer and internal headers refinement */
.footer {
  background:
    radial-gradient(circle at 10% 16%, rgba(255,176,0,.13), transparent 24%),
    radial-gradient(circle at 92% 72%, rgba(229,50,18,.16), transparent 24%),
    #211008;
  color: #fff7df;
}

.footer__main {
  grid-template-columns: 1.05fr 1fr 1.15fr 1fr;
  gap: clamp(26px, 4vw, 58px);
  align-items: stretch;
  border-top: 0;
  padding-top: 0;
}

.footer__main > div {
  min-height: 230px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.footer__brand,
.footer__address,
.footer__contacts,
.footer__trust {
  padding-top: 14px;
  border-top: 4px solid rgba(255,255,255,.14);
}

.footer__brand { border-color: var(--sje-red); }
.footer__address { border-color: var(--sje-yellow); }
.footer__contacts { border-color: var(--sje-green); }
.footer__trust { border-color: var(--sje-blue); }

.footer a,
.footer h2 {
  color: #fff7df;
}

.footer__brand p,
.footer__address p,
.footer__contacts p,
.footer__legal {
  color: rgba(255,247,223,.76);
}

.footer__logo {
  width: 118px;
  margin-bottom: 12px;
}

.footer__contacts {
  display: grid;
  grid-template-rows: auto 1fr;
}

.footer-link {
  min-height: 34px;
  margin: 8px 0;
  color: rgba(255,247,223,.92);
}

.footer-icon {
  flex-basis: 28px;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(255,247,223,.30);
  background: transparent !important;
  box-shadow: none;
  color: #fff7df;
  font-size: 12px;
}

.footer__trust {
  align-content: start;
}

.footer__guarantee-img {
  width: 128px;
  margin: 0 0 12px;
  filter: drop-shadow(0 16px 28px rgba(0,0,0,.24));
}

.footer-action {
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,247,223,.16);
  color: #fff7df;
}

.footer-action--google {
  color: #ffd64d;
  background: rgba(255,176,0,.12);
}

.footer-action small {
  color: rgba(255,247,223,.70);
}

.footer__legal {
  color: rgba(255,247,223,.70);
  border-top: 1px solid rgba(255,247,223,.16);
}

.footer__legal a {
  color: rgba(255,247,223,.86);
}

.page-head {
  padding: 46px 0 30px;
}

.page-head::before {
  inset: 18px 0 10px;
  background:
    radial-gradient(circle at 30px 30px, var(--sje-red) 0 5px, transparent 6px),
    radial-gradient(circle at 70px 58px, var(--sje-yellow) 0 6px, transparent 7px),
    radial-gradient(circle at 118px 32px, var(--sje-green) 0 5px, transparent 6px),
    radial-gradient(circle at 164px 62px, var(--sje-blue) 0 5px, transparent 6px),
    linear-gradient(90deg, #fffdf7, #fff3c9);
  background-size: 210px 92px, 210px 92px, 210px 92px, 210px 92px, auto;
  border: 1px solid rgba(39,19,12,.08);
  box-shadow: 0 14px 34px rgba(39,19,12,.06);
}

.page-head::after {
  display: none;
}

.page-head h1 {
  font-size: clamp(34px, 4.4vw, 58px);
}

.page-head p {
  font-size: clamp(16px, 1.6vw, 20px);
}

@media (max-width: 900px) {
  .footer__main > div {
    min-height: 0;
  }
}

/* Clean brand redesign */
.topbar {
  padding: 0;
  background: #fffaf1;
  border-bottom: 1px solid rgba(39,19,12,.10);
}

.topbar::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0 0 auto;
  height: 6px;
  background: linear-gradient(90deg, var(--red), var(--orange), var(--sun), var(--green), var(--blue));
}

.topbar__inner {
  width: min(1240px, calc(100% - 28px));
  min-height: 86px;
  padding: 13px 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.brand {
  min-width: 190px;
  gap: 14px;
}

.brand img {
  width: 70px;
  height: 70px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  object-fit: contain;
}

.brand span {
  font-size: 25px;
  color: var(--ink);
}

.brand span::after {
  color: var(--red);
}

.nav__list {
  gap: 8px;
}

.nav__list > .nav__item > a {
  min-height: 42px;
  padding: 10px 9px;
  color: #543b2e;
  background: transparent;
  border: 0;
  border-radius: 0;
  position: relative;
}

.nav__list > .nav__item > a::before {
  display: none;
}

.nav__list > .nav__item > a::after {
  content: "";
  position: absolute;
  left: 9px;
  right: 9px;
  bottom: 2px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--red), var(--sun));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .22s ease;
}

.nav__list > .nav__item > a:hover,
.nav__list > .nav__item.is-active > a {
  color: var(--red);
  background: transparent;
  transform: none;
}

.nav__list > .nav__item > a:hover::after,
.nav__list > .nav__item.is-active > a::after {
  transform: scaleX(1);
}

.nav__submenu {
  top: calc(100% + 16px);
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(39,19,12,.10);
  box-shadow: 0 26px 70px rgba(39,19,12,.16);
}

.hero {
  min-height: calc(100svh - 86px);
  background:
    linear-gradient(90deg, rgba(43,19,10,.76), rgba(43,19,10,.34) 48%, rgba(43,19,10,.68)),
    linear-gradient(135deg, #f46a00, #ffb000 48%, #19a66a);
}

.hero__inner {
  min-height: calc(100svh - 112px);
  width: min(1040px, calc(100% - 36px));
  text-align: left;
  align-items: flex-start;
}

.hero__inner::before {
  display: none;
}

.hero-logo {
  width: clamp(120px, 16vw, 210px);
  height: auto;
  margin-bottom: 22px;
  filter: drop-shadow(0 24px 42px rgba(0,0,0,.28));
  animation: logoLift 5.2s ease-in-out infinite;
}

.hero h1 {
  max-width: 940px;
  text-align: left;
  color: #fff;
}

.hero p:not(.kicker) {
  max-width: 720px;
  text-align: left;
}

.hero__chips,
.hero__actions {
  justify-content: flex-start;
}

.hero__photo-field {
  opacity: .58;
}

.hero__photo-field::after {
  background: linear-gradient(90deg, rgba(43,19,10,.76), rgba(43,19,10,.18) 48%, rgba(43,19,10,.42));
}

.page-head {
  padding: 58px 0 34px;
  overflow: visible;
}

.page-head::before {
  inset: 24px 0 12px;
  border-left: 0;
  background:
    linear-gradient(90deg, rgba(255,176,0,.26), transparent 54%),
    #fffdf7;
  border-top: 5px solid var(--sun);
  box-shadow: 0 16px 42px rgba(67,29,11,.06);
}

.page-head::after {
  display: none;
}

.page-head h1 {
  max-width: 1000px;
  font-size: clamp(38px, 5vw, 68px);
}

.page-head p {
  max-width: 760px;
}

.split {
  text-align: left;
  justify-content: start;
  grid-template-columns: minmax(0, 820px);
}

.footer {
  background: #241008;
}

.footer__main,
.footer__legal {
  background: transparent;
  border: 0;
  border-radius: 0;
  padding-left: 0;
  padding-right: 0;
}

.footer__main {
  border-top: 6px solid transparent;
  border-image: linear-gradient(90deg, var(--red), var(--sun), var(--green), var(--blue)) 1;
  padding-top: 34px;
}

@keyframes logoLift {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50% { transform: translateY(-10px) rotate(1deg); }
}

@media (max-width: 900px) {
  .topbar__inner {
    width: min(100% - 24px, 1240px);
  }
  .hero__inner {
    text-align: left;
    align-items: flex-start;
  }
  .hero__photo-field {
    opacity: .35;
  }
}

/* SJE complete redesign */
:root {
  --sje-ink: #22110a;
  --sje-coffee: #3a1a0d;
  --sje-paper: #fff9ea;
  --sje-card: #ffffff;
  --sje-red: #e53212;
  --sje-orange: #f46a00;
  --sje-yellow: #ffb000;
  --sje-green: #16a66a;
  --sje-blue: #1977c9;
  --sje-soft: rgba(34, 17, 10, .68);
  --sje-line: rgba(34, 17, 10, .10);
  --sje-shadow: 0 28px 80px rgba(34, 17, 10, .16);
}

body {
  color: var(--sje-ink);
  background:
    radial-gradient(circle at 16% 8%, rgba(255, 176, 0, .20), transparent 28%),
    radial-gradient(circle at 88% 28%, rgba(25, 119, 201, .10), transparent 28%),
    linear-gradient(180deg, #fffaf0 0%, #fff5de 38%, #fffdf8 100%);
}

.topbar {
  padding: 16px;
  background: transparent;
  border: 0;
}

.topbar::before {
  display: none;
}

.topbar__inner {
  width: min(1240px, 100%);
  min-height: 76px;
  padding: 10px 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, .82);
  border: 1px solid rgba(255, 255, 255, .82);
  box-shadow: 0 18px 70px rgba(34, 17, 10, .14);
  backdrop-filter: blur(18px);
}

.brand {
  min-width: 176px;
  gap: 12px;
}

.brand img {
  width: 58px;
  height: 58px;
  padding: 4px;
  border-radius: 8px;
  background:
    linear-gradient(#fff, #fff) padding-box,
    linear-gradient(135deg, var(--sje-yellow), var(--sje-red)) border-box;
  border: 2px solid transparent;
  filter: drop-shadow(0 12px 20px rgba(229, 50, 18, .18));
}

.brand span {
  font-size: 23px;
  color: var(--sje-red);
}

.brand span::after {
  content: "Safety surfacing";
  color: var(--sje-soft);
  letter-spacing: 0;
}

.nav__list {
  gap: 4px;
}

.nav__list > .nav__item > a {
  min-height: 42px;
  padding: 10px 12px;
  border-radius: 8px;
  color: #4c3428;
  font-size: 12px;
  letter-spacing: 0;
  background: transparent;
}

.nav__list > .nav__item > a::after {
  display: none;
}

.nav__list > .nav__item > a:hover,
.nav__list > .nav__item.is-active > a {
  color: #fff;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange));
  box-shadow: 0 12px 26px rgba(229, 50, 18, .20);
}

.nav__submenu {
  min-width: 286px;
  padding: 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, .96);
  border: 1px solid rgba(34, 17, 10, .08);
  box-shadow: 0 28px 80px rgba(34, 17, 10, .18);
}

.nav__submenu .nav__item > a {
  color: #51382b;
  background: transparent;
}

.nav__submenu .nav__item > a:hover,
.nav__submenu .nav__item.is-active > a {
  color: var(--sje-red);
  background: #fff2c8;
  box-shadow: none;
}

.hero {
  min-height: calc(100svh - 96px);
  display: block;
  isolation: isolate;
  background:
    linear-gradient(90deg, rgba(34,17,10,.88), rgba(34,17,10,.60) 44%, rgba(34,17,10,.18)),
    radial-gradient(circle at 82% 24%, rgba(255,176,0,.30), transparent 24%),
    linear-gradient(135deg, #ee3a16 0%, #f46a00 42%, #ffb000 100%);
}

.hero::before {
  inset: auto 0 0;
  height: 32%;
  opacity: .22;
  transform: none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.24) 0 10px, transparent 10px 32px);
  animation: surfaceDrift 24s linear infinite;
}

#granuleCanvas {
  opacity: .38;
  mix-blend-mode: screen;
}

.hero__photo-field {
  position: absolute;
  inset: 0;
  opacity: 1;
  pointer-events: none;
}

.hero__photo-field::after {
  background:
    linear-gradient(90deg, rgba(34,17,10,.92), rgba(34,17,10,.58) 36%, rgba(34,17,10,.12) 68%, rgba(34,17,10,.44)),
    linear-gradient(180deg, transparent 0%, rgba(34,17,10,.34) 100%);
}

.hero__photo {
  width: clamp(170px, 19vw, 320px);
  border-radius: 8px;
  border: 4px solid rgba(255, 255, 255, .76);
  box-shadow: 0 30px 86px rgba(0,0,0,.30);
  opacity: .86;
  animation: photoFloat 12s ease-in-out infinite;
}

.hero__photo--1 { left: auto; right: 8%; top: 12%; transform: rotate(5deg); }
.hero__photo--2 { right: 24%; top: 8%; transform: rotate(-7deg); }
.hero__photo--3 { left: auto; right: 4%; bottom: 13%; transform: rotate(-5deg); }
.hero__photo--4 { right: 28%; bottom: 8%; transform: rotate(7deg); }
.hero__photo--5 { left: auto; right: 42%; top: 28%; transform: rotate(3deg); }
.hero__photo--6,
.hero__photo--7,
.hero__photo--8,
.hero__photo--9 { display: none; }

.hero__inner {
  position: relative;
  z-index: 2;
  width: min(1240px, calc(100% - 36px));
  min-height: calc(100svh - 96px);
  margin: 0 auto;
  padding: clamp(80px, 10vw, 132px) 0 120px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  text-align: left;
  color: #fff;
}

.hero-logo {
  width: clamp(118px, 13vw, 190px);
  margin: 0 0 26px;
  padding: 10px;
  border-radius: 8px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 24px 70px rgba(0,0,0,.24);
  animation: logoLift 5s ease-in-out infinite;
}

.hero .kicker {
  color: #ffe89a;
  font-size: 13px;
}

.hero h1 {
  width: min(820px, 100%);
  font-size: clamp(54px, 8vw, 118px);
  line-height: .92;
  color: #fff;
  text-align: left;
  text-shadow: 0 24px 70px rgba(0,0,0,.28);
}

.hero p:not(.kicker) {
  width: min(660px, 100%);
  color: rgba(255,255,255,.88);
  text-align: left;
  font-size: clamp(18px, 1.65vw, 24px);
}

.hero__chips {
  justify-content: flex-start;
}

.hero__chips span {
  border-radius: 8px;
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.22);
}

.hero__actions {
  justify-content: flex-start;
}

.btn--primary {
  background: linear-gradient(135deg, var(--sje-yellow), var(--sje-red));
}

.stats {
  width: min(1120px, calc(100% - 36px));
  margin-top: -58px;
  border: 0;
  box-shadow: var(--sje-shadow);
}

.stats article {
  background: rgba(255,255,255,.94);
}

.split {
  width: min(1040px, calc(100% - 36px));
  padding: 96px 0 58px;
  text-align: left;
  grid-template-columns: minmax(0, 1fr);
}

.split h2 {
  max-width: 760px;
}

.split p {
  max-width: 860px;
}

.page-head {
  width: min(1120px, calc(100% - 36px));
  padding: 72px 0 42px;
  overflow: visible;
}

.page-head::before {
  inset: 34px 0 12px;
  border: 0;
  border-radius: 8px;
  background:
    linear-gradient(90deg, rgba(255,176,0,.28), rgba(255,255,255,.70) 42%, rgba(25,166,106,.12)),
    #fff;
  box-shadow: 0 18px 56px rgba(34,17,10,.08);
}

.page-head::after {
  display: block;
  right: 30px;
  bottom: 28px;
  width: 220px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--sje-red), var(--sje-yellow), var(--sje-green), var(--sje-blue));
  opacity: 1;
}

.page-head h1 {
  width: min(900px, 100%);
  color: var(--sje-ink);
}

.page-head p {
  width: min(720px, 100%);
}

.content {
  width: min(980px, calc(100% - 36px));
}

.gallery {
  width: min(1240px, calc(100% - 36px));
}

.gallery__item {
  border-radius: 8px;
  box-shadow: 0 20px 54px rgba(34,17,10,.12);
}

.footer {
  padding: 62px 18px 34px;
  background:
    radial-gradient(circle at 12% 18%, rgba(255,176,0,.14), transparent 26%),
    linear-gradient(180deg, #2a1209, #130804);
}

.footer__main {
  border-top: 0;
  padding-top: 0;
}

.footer__logo {
  width: 108px;
}

@media (max-width: 900px) {
  .topbar__inner {
    width: 100%;
  }
  .nav__list {
    gap: 0;
  }
  .hero__photo {
    opacity: .34;
  }
  .hero__photo--2,
  .hero__photo--4,
  .hero__photo--5 {
    display: none;
  }
  .hero__inner {
    min-height: calc(100svh - 88px);
  }
  .page-head::after {
    display: none;
  }
}

/* Elegant SJE direction */
.topbar {
  padding: 12px 18px;
  background: rgba(255, 250, 241, .96);
  border-bottom: 1px solid rgba(39, 19, 12, .08);
}

.topbar__inner {
  width: min(1220px, 100%);
  min-height: 78px;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.brand img {
  width: 76px;
  height: 76px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  filter: none;
}

.brand span {
  color: var(--sje-red);
}

.brand span::after {
  content: "Pavimento de segurança";
  color: #6f5548;
}

.nav__list {
  gap: 6px;
}

.nav__list > .nav__item > a {
  min-height: 44px;
  padding: 10px 12px 10px 42px;
  border-radius: 8px;
  color: #4f382d;
  background: transparent;
  position: relative;
}

.nav__list > .nav__item > a::before {
  content: "";
  display: block;
  position: absolute;
  left: 12px;
  top: 50%;
  width: 7px;
  height: 7px;
  margin: -4px 0 0;
  border-radius: 50%;
  background: var(--sje-yellow);
  box-shadow: 9px 0 0 var(--sje-red), 18px 0 0 var(--sje-green);
  opacity: 0;
  transform: none;
  transition: opacity .2s ease, transform .2s ease;
}

.nav__list > .nav__item > a:hover,
.nav__list > .nav__item.is-active > a {
  color: var(--sje-red);
  background: #fff3cf;
  box-shadow: none;
}

.nav__list > .nav__item > a:hover::before,
.nav__list > .nav__item.is-active > a::before {
  opacity: 1;
  transform: translateY(-1px);
}

.nav__submenu {
  border-radius: 8px;
  background: #fffdf7;
  box-shadow: 0 22px 58px rgba(39, 19, 12, .14);
}

.hero {
  min-height: calc(100svh - 102px);
  background:
    linear-gradient(90deg, rgba(255,250,241,.98) 0 42%, rgba(255,250,241,.70) 58%, rgba(255,250,241,.18)),
    radial-gradient(circle at 18% 20%, rgba(255,176,0,.26), transparent 25%),
    linear-gradient(135deg, #fff7df, #ffe196 48%, #f46a00);
}

.hero__photo-field::after {
  background: linear-gradient(90deg, rgba(255,250,241,.96) 0 36%, rgba(255,250,241,.42) 64%, rgba(255,250,241,.10));
}

.hero__photo {
  opacity: .92;
  border: 5px solid #fff;
  box-shadow: 0 24px 66px rgba(39,19,12,.18);
}

.hero__inner {
  color: var(--sje-ink);
}

.hero-logo {
  width: clamp(128px, 14vw, 208px);
  padding: 0;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  filter: drop-shadow(0 18px 24px rgba(229,50,18,.16));
}

.hero .kicker {
  color: var(--sje-red);
}

.hero h1 {
  color: var(--sje-ink);
  text-shadow: none;
}

.hero p:not(.kicker) {
  color: #60483d;
  text-shadow: none;
}

.hero__chips span {
  color: #4f382d;
  background: #fff;
  border: 1px solid rgba(39,19,12,.10);
  box-shadow: 0 10px 28px rgba(39,19,12,.08);
}

.btn--ghost {
  background: #fff;
}

.page-head::before {
  background:
    linear-gradient(90deg, rgba(255,176,0,.22), rgba(255,255,255,.82) 50%, rgba(25,166,106,.10)),
    #fffdf7;
}

.page-head::after {
  height: 8px;
  width: 180px;
  opacity: .9;
}

.footer {
  background: #fffaf1;
  color: var(--sje-ink);
  border-top: 1px solid rgba(39,19,12,.08);
}

.footer a {
  color: var(--sje-ink);
}

.footer__brand p,
.footer__contacts p,
.footer__legal {
  color: #6f5548;
}

.footer__main {
  border-top: 6px solid transparent;
  border-image: linear-gradient(90deg, var(--sje-red), var(--sje-yellow), var(--sje-green), var(--sje-blue)) 1;
  padding-top: 28px;
}

.footer__legal {
  border-top: 1px solid rgba(39,19,12,.10);
}

.footer__logo {
  filter: none;
}

.review-link {
  color: var(--sje-red);
}

.footer__main {
  grid-template-columns: 1.15fr 1fr 1fr .95fr;
  gap: clamp(24px, 4vw, 52px);
  align-items: start;
}

.footer__address p,
.footer__contacts p,
.footer__brand p {
  margin: 10px 0;
}

.footer-link,
.footer-action {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
  text-decoration: none;
}

.footer-icon {
  flex: 0 0 34px;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #fff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange));
  box-shadow: 0 10px 22px rgba(229, 50, 18, .16);
}

.footer-icon--mail { background: linear-gradient(135deg, var(--sje-blue), var(--sje-green)); }
.footer-icon--phone { background: linear-gradient(135deg, var(--sje-orange), var(--sje-yellow)); }
.footer-icon--facebook { background: #1877f2; font-family: Arial, sans-serif; font-size: 22px; }
.footer-icon--star { background: linear-gradient(135deg, var(--sje-yellow), var(--sje-red)); }

.footer__trust {
  display: grid;
  gap: 12px;
}

.footer__guarantee-img {
  width: 112px;
  height: auto;
  margin: 0 0 4px;
}

.footer-action {
  padding: 10px;
  border: 1px solid rgba(39,19,12,.10);
  border-radius: 8px;
  background: #fff;
}

.footer-action span:last-child {
  display: grid;
  gap: 2px;
  font-weight: 950;
}

.footer-action small {
  color: #6f5548;
  font-size: 12px;
  font-weight: 800;
}

.footer-action--google {
  color: var(--sje-red);
}

@media (max-width: 900px) {
  .brand img {
    width: 64px;
    height: 64px;
  }
  .nav__list > .nav__item > a {
    padding-left: 12px;
  }
  .nav__list > .nav__item > a::before {
    display: none;
  }
  .hero {
    background:
      linear-gradient(180deg, rgba(255,250,241,.96), rgba(255,250,241,.82)),
      linear-gradient(135deg, #fff7df, #ffe196 48%, #f46a00);
  }
}

.footer {
  padding-left: 18px;
  padding-right: 18px;
}

.footer__main,
.footer__legal {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 22px;
}

.footer__legal {
  border-top: 1px solid rgba(255,255,255,.08);
}

@media (max-width: 900px) {
  .brand {
    min-width: 0;
  }
  .brand img {
    width: 56px;
    height: 56px;
  }
  .nav__list > .nav__item > a::before {
    display: none;
  }
}

/* Final footer and page-header polish */
.footer {
  padding: clamp(42px, 6vw, 72px) 18px 22px;
  background:
    radial-gradient(circle at 12% 14%, rgba(255, 176, 0, .18), transparent 26%),
    radial-gradient(circle at 86% 24%, rgba(229, 50, 18, .18), transparent 24%),
    linear-gradient(135deg, #1c0d07 0%, #2c140b 52%, #140a07 100%);
  color: #fff8df;
  border-top: 0;
}

.footer__main {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.08fr 1fr 1.05fr 1.05fr;
  gap: clamp(24px, 3.6vw, 50px);
  align-items: stretch;
  padding: 0;
  background: transparent;
  border: 0;
  border-image: none;
}

.footer__main > div {
  min-height: 244px;
  padding: 18px 0 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  border-top: 4px solid rgba(255, 248, 223, .18);
}

.footer__brand { border-color: var(--sje-red); }
.footer__address { border-color: var(--sje-yellow); }
.footer__contacts { border-color: var(--sje-green); }
.footer__trust { border-color: var(--sje-blue); }

.footer h2 {
  margin: 0 0 16px;
  color: #fff8df;
  font-size: 18px;
  letter-spacing: 0;
}

.footer p,
.footer__brand p,
.footer__address p,
.footer__contacts p {
  margin: 0 0 12px;
  color: rgba(255, 248, 223, .76);
}

.footer strong {
  color: #fff8df;
  font-size: 18px;
}

.footer a {
  color: #fff8df;
}

.footer__logo {
  width: 122px;
  height: auto;
  margin: 0 0 16px;
  filter: drop-shadow(0 12px 20px rgba(0, 0, 0, .22));
}

.footer-link,
.footer-action {
  display: flex;
  align-items: center;
  gap: 11px;
  margin: 0 0 11px;
  color: rgba(255, 248, 223, .88);
  text-decoration: none;
}

.footer-link:hover,
.footer-action:hover {
  color: #fff8df;
}

.footer-icon {
  flex: 0 0 32px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  border: 1px solid rgba(255, 248, 223, .28);
  background: rgba(255, 255, 255, .06) !important;
  box-shadow: none;
  color: #fff8df;
  font-size: 12px;
  font-weight: 900;
}

.footer-icon--facebook {
  font-family: Arial, sans-serif;
  font-size: 20px;
}

.footer__trust {
  gap: 11px;
}

.footer__guarantee-img {
  width: 138px;
  max-width: 100%;
  height: auto;
  margin: -4px 0 4px;
  filter: drop-shadow(0 16px 26px rgba(0, 0, 0, .34));
}

.footer-action {
  min-height: 54px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid rgba(255, 248, 223, .16);
  background: rgba(255, 255, 255, .075);
}

.footer-action--google {
  border-color: rgba(255, 214, 77, .34);
  background: linear-gradient(135deg, rgba(255, 176, 0, .18), rgba(255, 255, 255, .06));
  color: #ffd64d;
}

.footer-action span:last-child {
  display: grid;
  gap: 2px;
  font-weight: 950;
  line-height: 1.15;
}

.footer-action small {
  color: rgba(255, 248, 223, .68);
  font-size: 12px;
  font-weight: 800;
}

.footer__legal {
  width: min(1180px, 100%);
  margin: 34px auto 0;
  padding: 18px 0 0;
  background: transparent;
  border: 0;
  border-top: 1px solid rgba(255, 248, 223, .16);
  border-radius: 0;
  color: rgba(255, 248, 223, .66);
}

.footer__legal nav {
  justify-content: center;
}

.footer__legal a {
  color: rgba(255, 248, 223, .84);
}

.footer__legal p {
  color: rgba(255, 248, 223, .66);
}

.page-head {
  position: relative;
  padding: 38px 0 24px;
  overflow: hidden;
}

.page-head::before {
  inset: 14px 0 8px;
  border-radius: 0 0 28px 28px;
  background:
    radial-gradient(circle at 22px 26px, var(--sje-red) 0 5px, transparent 6px),
    radial-gradient(circle at 60px 44px, var(--sje-yellow) 0 7px, transparent 8px),
    radial-gradient(circle at 104px 24px, var(--sje-green) 0 5px, transparent 6px),
    radial-gradient(circle at 150px 46px, var(--sje-blue) 0 5px, transparent 6px),
    linear-gradient(105deg, rgba(255, 253, 247, .98), rgba(255, 244, 204, .94) 55%, rgba(255, 255, 255, .98));
  background-size: 190px 74px, 190px 74px, 190px 74px, 190px 74px, auto;
  border: 1px solid rgba(39, 19, 12, .08);
  box-shadow: 0 12px 32px rgba(39, 19, 12, .06);
  animation: pageGranules 13s linear infinite;
}

.page-head::after {
  display: block;
  right: max(18px, calc((100vw - 1180px) / 2));
  bottom: 18px;
  left: auto;
  width: 140px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--sje-red), var(--sje-yellow), var(--sje-green), var(--sje-blue));
  opacity: .9;
}

.page-head h1 {
  max-width: 920px;
  font-size: clamp(32px, 4vw, 54px);
  line-height: .98;
}

.page-head p {
  max-width: 760px;
  margin-top: 12px;
  font-size: clamp(15px, 1.35vw, 19px);
}

@keyframes pageGranules {
  from { background-position: 0 0, 0 0, 0 0, 0 0, 0 0; }
  to { background-position: 190px 0, -190px 0, 95px 0, -95px 0, 0 0; }
}

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

  .footer__main > div {
    min-height: 0;
  }
}

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

  .page-head {
    padding: 30px 0 18px;
  }

  .page-head::before {
    inset: 10px 0 6px;
  }
}

/* Final hero redesign */
.hero {
  min-height: calc(100svh - 96px);
  display: block;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(circle at 84% 18%, rgba(255, 214, 77, .48), transparent 24%),
    radial-gradient(circle at 72% 82%, rgba(25, 166, 106, .28), transparent 28%),
    linear-gradient(125deg, #241006 0%, #8e260c 38%, #e74713 64%, #ffb000 100%);
}

.hero::before {
  content: "";
  position: absolute;
  inset: auto -10% -10%;
  z-index: 0;
  height: 44%;
  opacity: .54;
  transform: rotate(-2deg);
  background:
    radial-gradient(circle at 20px 20px, rgba(255,255,255,.38) 0 4px, transparent 5px),
    radial-gradient(circle at 58px 42px, rgba(25,166,106,.52) 0 5px, transparent 6px),
    radial-gradient(circle at 102px 24px, rgba(25,119,201,.48) 0 4px, transparent 5px),
    radial-gradient(circle at 148px 48px, rgba(255,176,0,.62) 0 6px, transparent 7px);
  background-size: 180px 82px;
  animation: heroSurfaceRun 18s linear infinite;
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  display: block;
  background:
    linear-gradient(90deg, rgba(22, 9, 4, .92) 0%, rgba(22, 9, 4, .76) 34%, rgba(22, 9, 4, .20) 62%, rgba(22, 9, 4, .04) 100%),
    linear-gradient(180deg, rgba(22, 9, 4, .10), rgba(22, 9, 4, .34));
  pointer-events: none;
}

#granuleCanvas {
  z-index: 2;
  opacity: .44;
  mix-blend-mode: screen;
}

.hero__photo-field {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 1;
  pointer-events: none;
}

.hero__photo-field::after {
  display: none;
}

.hero__photo {
  position: absolute;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 8px;
  border: 0;
  opacity: 1;
  filter: saturate(1.18) contrast(1.08) brightness(1.03);
  box-shadow: 0 34px 90px rgba(0, 0, 0, .34);
  animation: heroPhotoPulse 9s ease-in-out infinite;
  will-change: transform;
}

.hero__photo--1 {
  right: clamp(18px, 6vw, 92px);
  top: clamp(84px, 12vh, 132px);
  width: clamp(390px, 43vw, 710px);
  z-index: 2;
  transform: rotate(1.5deg);
  clip-path: polygon(8% 0, 100% 0, 94% 100%, 0 92%);
}

.hero__photo--2 {
  right: clamp(42px, 13vw, 230px);
  bottom: clamp(28px, 8vh, 86px);
  width: clamp(230px, 24vw, 390px);
  z-index: 3;
  transform: rotate(-5deg);
  animation-delay: -2s;
}

.hero__photo--3 {
  right: clamp(12px, 3vw, 46px);
  bottom: clamp(110px, 20vh, 210px);
  width: clamp(190px, 18vw, 320px);
  z-index: 4;
  transform: rotate(7deg);
  animation-delay: -4s;
}

.hero__photo--4 {
  right: clamp(330px, 38vw, 640px);
  top: clamp(74px, 14vh, 138px);
  width: clamp(150px, 16vw, 260px);
  z-index: 1;
  transform: rotate(-8deg);
  animation-delay: -5.5s;
}

.hero__photo--5 {
  right: clamp(270px, 34vw, 560px);
  bottom: clamp(42px, 9vh, 96px);
  width: clamp(160px, 17vw, 280px);
  z-index: 1;
  transform: rotate(5deg);
  animation-delay: -7s;
}

.hero__photo--6,
.hero__photo--7,
.hero__photo--8,
.hero__photo--9 {
  display: none;
}

.hero__inner {
  position: relative;
  z-index: 5;
  width: min(1180px, calc(100% - 36px));
  min-height: calc(100svh - 96px);
  margin: 0 auto;
  padding: clamp(84px, 10vw, 136px) 0 clamp(96px, 11vw, 148px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  text-align: left;
  color: #fff;
}

.hero__inner::before {
  display: none;
}

.hero-logo {
  width: clamp(128px, 13vw, 200px);
  height: auto;
  margin: 0 0 24px;
  padding: 0;
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  filter: drop-shadow(0 18px 24px rgba(0, 0, 0, .26));
  animation: logoLift 5.5s ease-in-out infinite;
}

.hero .kicker {
  color: #ffe287;
  font-size: 13px;
  text-shadow: 0 10px 24px rgba(0, 0, 0, .24);
}

.hero h1 {
  width: min(720px, 100%);
  color: #fff;
  font-size: clamp(52px, 7.7vw, 112px);
  line-height: .9;
  text-align: left;
  text-shadow: 0 22px 58px rgba(0, 0, 0, .34);
}

.hero p:not(.kicker) {
  width: min(610px, 100%);
  color: rgba(255, 248, 223, .92);
  font-size: clamp(18px, 1.55vw, 23px);
  text-align: left;
  text-shadow: 0 12px 28px rgba(0, 0, 0, .30);
}

.hero__chips,
.hero__actions {
  justify-content: flex-start;
}

.hero__chips span {
  color: #fff8df;
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 248, 223, .26);
  box-shadow: 0 14px 34px rgba(0, 0, 0, .16);
  backdrop-filter: blur(8px);
}

.hero .btn--primary {
  color: #27130c;
  background: linear-gradient(135deg, #ffe287, #ffb000);
  box-shadow: 0 18px 48px rgba(0, 0, 0, .24);
}

.hero .btn--ghost {
  color: #fff8df;
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 248, 223, .28);
  backdrop-filter: blur(8px);
}

@keyframes heroSurfaceRun {
  from { background-position: 0 0; }
  to { background-position: 360px 0; }
}

@keyframes heroPhotoPulse {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -10px; }
}

@media (max-width: 980px) {
  .hero {
    min-height: auto;
  }

  .hero::after {
    background:
      linear-gradient(180deg, rgba(22, 9, 4, .82), rgba(22, 9, 4, .50) 54%, rgba(22, 9, 4, .82)),
      linear-gradient(90deg, rgba(22, 9, 4, .38), rgba(22, 9, 4, .12));
  }

  .hero__photo--1 {
    width: min(78vw, 560px);
    right: -8vw;
    top: 80px;
  }

  .hero__photo--2 {
    width: min(42vw, 300px);
    right: 10vw;
    bottom: 24px;
  }

  .hero__photo--3,
  .hero__photo--4,
  .hero__photo--5 {
    display: none;
  }

  .hero__inner {
    min-height: 760px;
    padding-top: 96px;
    padding-bottom: 170px;
  }
}

@media (max-width: 620px) {
  .hero__photo--1 {
    width: 118vw;
    right: -44vw;
    top: 120px;
    opacity: .78;
  }

  .hero__photo--2 {
    display: none;
  }

  .hero__inner {
    min-height: 720px;
    padding-bottom: 96px;
  }

  .hero h1 {
    font-size: clamp(46px, 15vw, 74px);
  }
}

/* Clean rebuild: hero, internal title and homepage sections */
.hero {
  min-height: calc(100svh - 92px);
  display: grid;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    linear-gradient(115deg, rgba(255, 250, 241, .98) 0 34%, rgba(255, 245, 218, .72) 34% 54%, rgba(255, 176, 0, .20) 54% 100%),
    radial-gradient(circle at 78% 28%, rgba(229, 50, 18, .24), transparent 26%),
    #fffaf1;
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  height: auto;
  opacity: .95;
  transform: none;
  background:
    linear-gradient(112deg, transparent 0 48%, rgba(229, 50, 18, .92) 48% 68%, rgba(255, 176, 0, .92) 68% 100%);
  clip-path: polygon(56% 0, 100% 0, 100% 100%, 42% 100%);
  animation: none;
}

.hero::after {
  content: "";
  position: absolute;
  inset: auto -8% -12% 42%;
  z-index: 2;
  height: 48%;
  display: block;
  border-radius: 999px 0 0 0;
  background:
    radial-gradient(circle at 22px 28px, rgba(255,255,255,.58) 0 4px, transparent 5px),
    radial-gradient(circle at 68px 48px, rgba(25,166,106,.58) 0 6px, transparent 7px),
    radial-gradient(circle at 124px 30px, rgba(25,119,201,.50) 0 5px, transparent 6px),
    radial-gradient(circle at 166px 58px, rgba(255,176,0,.72) 0 7px, transparent 8px);
  background-size: 210px 92px;
  opacity: .72;
  transform: rotate(-3deg);
  animation: heroGranulesClean 18s linear infinite;
  pointer-events: none;
}

#granuleCanvas {
  display: none;
}

.hero__photo-field {
  position: absolute;
  inset: 0;
  z-index: 1;
  opacity: 1;
  pointer-events: none;
}

.hero__photo-field::after {
  display: none;
}

.hero__photo {
  position: absolute;
  object-fit: cover;
  aspect-ratio: 4 / 3;
  border: 0;
  border-radius: 8px;
  opacity: 1;
  filter: saturate(1.08) contrast(1.03);
  box-shadow: 0 28px 70px rgba(72, 28, 8, .24);
  animation: heroCleanFloat 10s ease-in-out infinite;
}

.hero__photo--1 {
  right: clamp(28px, 6vw, 96px);
  top: clamp(92px, 14vh, 150px);
  width: clamp(420px, 42vw, 680px);
  z-index: 3;
  transform: rotate(-1deg);
  clip-path: polygon(0 0, 100% 8%, 93% 100%, 7% 92%);
}

.hero__photo--2 {
  right: clamp(320px, 36vw, 610px);
  bottom: clamp(54px, 9vh, 96px);
  width: clamp(190px, 19vw, 315px);
  z-index: 4;
  transform: rotate(4deg);
  animation-delay: -3s;
}

.hero__photo--3 {
  right: clamp(20px, 4vw, 72px);
  bottom: clamp(52px, 9vh, 100px);
  width: clamp(210px, 22vw, 350px);
  z-index: 4;
  transform: rotate(-4deg);
  animation-delay: -5s;
}

.hero__photo--4,
.hero__photo--5,
.hero__photo--6,
.hero__photo--7,
.hero__photo--8,
.hero__photo--9 {
  display: none;
}

.hero__inner {
  position: relative;
  z-index: 5;
  width: min(1180px, calc(100% - 36px));
  min-height: calc(100svh - 92px);
  margin: 0 auto;
  padding: clamp(86px, 10vw, 132px) 0 clamp(84px, 9vw, 124px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  color: var(--sje-ink);
  text-align: left;
}

.hero__inner::before {
  display: none;
}

.hero-logo {
  width: clamp(126px, 12vw, 184px);
  margin: 0 0 22px;
  padding: 0;
  background: transparent;
  box-shadow: none;
  filter: drop-shadow(0 16px 18px rgba(229, 50, 18, .15));
  animation: logoLift 5.5s ease-in-out infinite;
}

.hero .kicker {
  color: var(--sje-red);
  text-shadow: none;
}

.hero h1 {
  width: min(650px, 100%);
  color: var(--sje-ink);
  font-size: clamp(50px, 7.4vw, 106px);
  line-height: .9;
  text-shadow: none;
}

.hero p:not(.kicker) {
  width: min(570px, 100%);
  color: #5f4638;
  font-size: clamp(18px, 1.55vw, 22px);
  text-shadow: none;
}

.hero__chips,
.hero__actions {
  justify-content: flex-start;
}

.hero__chips span {
  color: #4f382d;
  background: #fff;
  border: 1px solid rgba(39, 19, 12, .10);
  box-shadow: 0 12px 28px rgba(67, 29, 11, .08);
  backdrop-filter: none;
}

.hero .btn--primary {
  color: #fff;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange));
}

.hero .btn--ghost {
  color: var(--sje-ink);
  background: #fff;
  border-color: rgba(39, 19, 12, .12);
}

.page-head {
  width: min(1180px, calc(100% - 36px));
  margin: 0 auto;
  padding: 46px 0 18px;
  overflow: visible;
}

.page-head::before {
  display: none;
}

.page-head::after {
  content: "";
  position: static;
  display: block;
  width: min(320px, 72vw);
  height: 7px;
  margin-top: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--sje-red), var(--sje-yellow), var(--sje-green), var(--sje-blue));
  opacity: 1;
}

.page-head h1 {
  max-width: 940px;
  font-size: clamp(34px, 4.6vw, 64px);
  line-height: .98;
}

.page-head p {
  max-width: 720px;
  color: #6f5548;
}

.home-proof {
  padding: clamp(24px, 4vw, 42px);
  border-radius: 8px;
  color: #fff;
  background:
    radial-gradient(circle at 84% 18%, rgba(255,176,0,.42), transparent 24%),
    linear-gradient(135deg, #e53212, #f46a00);
  box-shadow: 0 24px 70px rgba(229, 50, 18, .20);
}

.home-proof strong {
  display: block;
  font-size: clamp(24px, 3vw, 42px);
  line-height: 1;
  margin-bottom: 12px;
}

.home-proof span {
  color: rgba(255,255,255,.86);
  font-weight: 800;
}

.home-solutions,
.home-process,
.home-cta {
  width: min(1180px, calc(100% - 36px));
  margin: 0 auto;
}

.home-solutions {
  padding: 54px 0 36px;
}

.home-section-title {
  max-width: 760px;
  margin-bottom: 24px;
}

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

.home-card {
  min-height: 260px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px;
  border-radius: 8px;
  color: #fff;
  text-decoration: none;
  overflow: hidden;
  position: relative;
  background: linear-gradient(135deg, #e53212, #f46a00);
  box-shadow: 0 18px 46px rgba(67, 29, 11, .14);
  transition: transform .24s ease, box-shadow .24s ease;
}

.home-card::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    radial-gradient(circle at 24px 28px, rgba(255,255,255,.30) 0 5px, transparent 6px),
    radial-gradient(circle at 78px 56px, rgba(255,176,0,.45) 0 7px, transparent 8px);
  background-size: 120px 96px;
  transform: rotate(8deg);
  opacity: .65;
  transition: translate .35s ease;
}

.home-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 26px 70px rgba(67, 29, 11, .20);
}

.home-card:hover::before {
  translate: 36px -20px;
}

.home-card:nth-child(2) { background: linear-gradient(135deg, #1977c9, #19a66a); }
.home-card:nth-child(3) { background: linear-gradient(135deg, #ffb000, #e53212); }
.home-card:nth-child(4) { background: linear-gradient(135deg, #27130c, #f46a00); }

.home-card span,
.home-card h3,
.home-card p {
  position: relative;
  z-index: 1;
}

.home-card span {
  font-weight: 950;
  opacity: .74;
}

.home-card h3 {
  margin: 44px 0 8px;
}

.home-card p {
  margin: 0;
  color: rgba(255,255,255,.84);
  font-weight: 700;
}

.home-process {
  display: grid;
  grid-template-columns: .8fr 1.2fr;
  gap: clamp(24px, 5vw, 72px);
  align-items: start;
  padding: 56px 0;
}

.home-process ol {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.home-process li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 16px;
  padding: 18px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(39, 19, 12, .10);
  box-shadow: 0 12px 34px rgba(67, 29, 11, .07);
}

.home-process strong {
  color: var(--sje-red);
}

.home-process span {
  color: #6f5548;
}

.home-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 72px;
  padding: clamp(26px, 4vw, 44px);
  border-radius: 8px;
  background:
    radial-gradient(circle at 86% 24%, rgba(25,166,106,.18), transparent 24%),
    linear-gradient(135deg, #fff, #fff1bd);
  border: 1px solid rgba(39, 19, 12, .08);
}

.home-cta h2 {
  max-width: 720px;
  margin-bottom: 0;
}

.home-cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.footer-link {
  white-space: nowrap;
  flex-wrap: nowrap;
}

.footer-link a {
  display: inline;
}

.footer-link--phones > span:last-child {
  display: inline;
  min-width: 0;
}

.footer-link--phones a {
  white-space: nowrap;
}

@keyframes heroGranulesClean {
  from { background-position: 0 0; }
  to { background-position: 420px 0; }
}

@keyframes heroCleanFloat {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -8px; }
}

@media (max-width: 1040px) {
  .hero::before {
    clip-path: polygon(46% 0, 100% 0, 100% 100%, 38% 100%);
  }

  .hero__photo--1 {
    right: -120px;
    width: min(72vw, 560px);
  }

  .hero__photo--2,
  .hero__photo--3 {
    display: none;
  }

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

  .home-process {
    grid-template-columns: 1fr;
  }

  .home-cta {
    align-items: flex-start;
    flex-direction: column;
  }

  .home-cta__actions {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .hero {
    background: linear-gradient(180deg, #fffaf1, #fff0bc);
  }

  .hero::before {
    opacity: .20;
    clip-path: none;
  }

  .hero::after {
    inset: auto -20% -16% 0;
  }

  .hero__photo--1 {
    right: -46vw;
    top: 120px;
    width: 115vw;
    opacity: .34;
  }

  .hero__inner {
    min-height: 700px;
    padding-top: 92px;
    padding-bottom: 92px;
  }

  .home-card-grid {
    grid-template-columns: 1fr;
  }

  .home-process li {
    grid-template-columns: 1fr;
  }

  .footer-link {
    white-space: normal;
  }
}

/* Footer contact alignment fix */
.footer__contacts .footer-link {
  display: flex !important;
  align-items: center !important;
  gap: 11px;
  min-height: 36px;
  margin: 0 0 10px !important;
  line-height: 1.2;
}

.footer__contacts > a.footer-link {
  width: fit-content;
}

.footer__contacts .footer-link,
.footer__contacts .footer-link > span:last-child {
  color: rgba(255, 248, 223, .88);
}

.footer__contacts .footer-link a,
.footer__contacts > a.footer-link {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
}

.footer__contacts .footer-icon {
  flex: 0 0 32px;
  align-self: center;
}

/* Page visual strip and footer legal layout */
.page-photo-strip {
  width: min(1180px, calc(100% - 36px));
  margin: 26px auto 56px;
  display: grid;
  grid-template-columns: 1.35fr repeat(4, 1fr);
  gap: 10px;
  height: clamp(190px, 22vw, 280px);
}

.page-photo-strip__item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: #f3d68e;
  box-shadow: 0 18px 48px rgba(67, 29, 11, .12);
}

.page-photo-strip__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 48%, rgba(39, 19, 12, .34)),
    radial-gradient(circle at 22px 24px, rgba(255,255,255,.28) 0 4px, transparent 5px);
  background-size: auto, 72px 72px;
  opacity: .76;
  transition: opacity .25s ease, transform .35s ease;
}

.page-photo-strip__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.08) contrast(1.02);
  transition: transform .55s ease, filter .35s ease;
}

.page-photo-strip__item:hover img {
  transform: scale(1.08) rotate(.8deg);
  filter: saturate(1.18) contrast(1.06);
}

.page-photo-strip__item:hover::after {
  opacity: .38;
  transform: translateY(12px);
}

.footer__legal {
  display: block;
}

.footer__legal nav {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: clamp(10px, 1.6vw, 18px);
  white-space: nowrap;
  font-size: 13px;
}

.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 18px;
}

.footer__bottom p {
  margin: 0;
}

.footer__bottom p:last-child {
  text-align: right;
  white-space: nowrap;
}

@media (max-width: 880px) {
  .page-photo-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    height: auto;
  }

  .page-photo-strip__item {
    aspect-ratio: 4 / 3;
  }

  .footer__legal nav {
    flex-wrap: wrap;
    white-space: normal;
  }

  .footer__bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .footer__bottom p:last-child {
    text-align: left;
  }
}

@media (max-width: 560px) {
  .page-photo-strip {
    grid-template-columns: 1fr;
  }
}

.btn--disabled {
  cursor: not-allowed;
  opacity: .62;
  box-shadow: none;
}

.btn--disabled:hover {
  transform: none;
  box-shadow: none;
}

/* White footer logo on dark background */
.footer .footer__logo {
  filter: brightness(0) invert(1) drop-shadow(0 14px 22px rgba(0, 0, 0, .26));
  opacity: .96;
}

/* Footer block color rails */
.footer__main > div {
  border-top-width: 5px;
  border-top-style: solid;
  padding-top: 20px;
}

.footer__brand {
  border-top-color: var(--sje-red);
  box-shadow: 0 -10px 22px rgba(229, 50, 18, .14);
}

.footer__address {
  border-top-color: var(--sje-yellow);
  box-shadow: 0 -10px 22px rgba(255, 176, 0, .13);
}

.footer__contacts {
  border-top-color: var(--sje-green);
  box-shadow: 0 -10px 22px rgba(22, 166, 106, .13);
}

.footer__trust {
  border-top-color: var(--sje-blue);
  box-shadow: 0 -10px 22px rgba(25, 119, 201, .14);
}

/* Footer final spacing and guarantee badge */
.footer {
  background:
    radial-gradient(circle at 12% 14%, rgba(255, 176, 0, .20), transparent 27%),
    radial-gradient(circle at 86% 24%, rgba(229, 50, 18, .20), transparent 25%),
    linear-gradient(135deg, #261008 0%, #3a1a0d 52%, #20100a 100%);
}

.footer__main {
  gap: clamp(18px, 2.8vw, 34px);
}

.footer__main > div {
  min-height: 244px;
  padding: 22px 16px 4px;
  border-radius: 8px 8px 0 0;
  background: linear-gradient(180deg, rgba(255, 248, 223, .055), rgba(255, 248, 223, .018));
}

.footer__guarantee-img {
  opacity: 1;
}

/* Homepage rebuilt with gallery-first structure */
.hero.hero--home-gallery {
  min-height: auto;
  padding: 0;
  overflow: hidden;
  background:
    radial-gradient(circle at 78% 18%, rgba(255, 176, 0, .24), transparent 30%),
    linear-gradient(135deg, #fffaf1 0%, #fff0bc 52%, #ffd06a 100%);
}

.hero.hero--home-gallery::before {
  content: "";
  position: absolute;
  inset: 0 0 0 46%;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange) 46%, var(--sje-yellow));
  clip-path: polygon(13% 0, 100% 0, 100% 100%, 0 100%);
  opacity: .94;
}

.hero.hero--home-gallery::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 36px 38px, rgba(255, 255, 255, .36) 0 5px, transparent 6px),
    radial-gradient(circle at 92px 74px, rgba(25, 166, 106, .24) 0 7px, transparent 8px),
    radial-gradient(circle at 156px 44px, rgba(25, 119, 201, .22) 0 5px, transparent 6px);
  background-size: 210px 132px;
  opacity: .36;
  pointer-events: none;
}

.hero--home-gallery .hero__inner {
  min-height: calc(100svh - 92px);
  display: grid;
  grid-template-columns: .92fr 1.08fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  padding: clamp(54px, 7vw, 96px) 0;
}

.hero--home-gallery .hero__copy {
  position: relative;
  z-index: 2;
}

.hero--home-gallery .hero-logo {
  width: clamp(104px, 10vw, 148px);
  margin-bottom: 18px;
}

.hero--home-gallery h1 {
  width: min(620px, 100%);
  color: var(--sje-ink);
  font-size: clamp(44px, 6.5vw, 86px);
  line-height: .95;
}

.hero--home-gallery p:not(.kicker) {
  width: min(610px, 100%);
  color: #5b4133;
}

.home-hero-gallery {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-auto-rows: clamp(92px, 10vw, 150px);
  gap: 10px;
}

.home-hero-gallery__item,
.home-gallery-wall__item {
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
}

.home-hero-gallery__item img,
.home-gallery-wall__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease, filter .35s ease;
}

.home-hero-gallery__item:hover img,
.home-gallery-wall__item:hover img {
  transform: scale(1.045);
  filter: saturate(1.06);
}

.home-hero-gallery__item--1 {
  grid-column: 1 / span 4;
  grid-row: 1 / span 2;
}

.home-hero-gallery__item--2 {
  grid-column: 5 / span 2;
  grid-row: 1 / span 1;
}

.home-hero-gallery__item--3 {
  grid-column: 5 / span 2;
  grid-row: 2 / span 2;
}

.home-hero-gallery__item--4 {
  grid-column: 1 / span 2;
  grid-row: 3 / span 1;
}

.home-hero-gallery__item--5 {
  grid-column: 3 / span 2;
  grid-row: 3 / span 1;
}

.home-hero-gallery__item--6 {
  grid-column: 1 / span 6;
  grid-row: 4 / span 1;
}

.home-quick-links,
.home-about,
.home-materials,
.home-standard {
  width: min(1180px, calc(100% - 36px));
  margin-left: auto;
  margin-right: auto;
}

.home-quick-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: -28px;
  position: relative;
  z-index: 4;
}

.home-quick-links a {
  min-height: 106px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange));
  box-shadow: 0 18px 46px rgba(67, 29, 11, .16);
  transition: transform .24s ease, box-shadow .24s ease;
}

.home-quick-links a:nth-child(2) {
  background: linear-gradient(135deg, var(--sje-green), var(--sje-blue));
}

.home-quick-links a:nth-child(3) {
  background: linear-gradient(135deg, var(--sje-yellow), var(--sje-red));
}

.home-quick-links a:hover {
  transform: translateY(-5px);
  box-shadow: 0 24px 60px rgba(67, 29, 11, .22);
}

.home-quick-links span {
  font-weight: 950;
  opacity: .72;
}

.home-quick-links strong {
  font-size: clamp(18px, 2vw, 25px);
  line-height: 1.05;
  text-transform: uppercase;
}

.home-about {
  padding: clamp(54px, 7vw, 86px) 0 34px;
  display: grid;
  grid-template-columns: .86fr 1.14fr;
  gap: clamp(24px, 5vw, 70px);
  align-items: start;
}

.home-about h2,
.home-materials h2,
.home-standard h2 {
  margin: 0;
  color: var(--sje-ink);
  font-size: clamp(30px, 4vw, 56px);
  line-height: .98;
}

.home-about p:not(.kicker),
.home-feature p:not(.kicker) {
  color: #6a4f40;
  font-size: clamp(16px, 1.25vw, 19px);
}

.home-about .btn {
  margin-top: 8px;
}

.home-gallery-wall {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin: 18px 0 clamp(48px, 6vw, 76px);
  background: #20100a;
}

.home-gallery-wall__item {
  border-radius: 0;
  aspect-ratio: 1 / .74;
}

.home-materials {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding-bottom: clamp(42px, 6vw, 72px);
}

.home-feature {
  min-height: 342px;
  padding: clamp(24px, 4vw, 44px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
  background: #fff;
  border: 1px solid rgba(39, 19, 12, .10);
  box-shadow: 0 20px 58px rgba(67, 29, 11, .10);
}

.home-feature::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 80% 16%, rgba(255, 176, 0, .20), transparent 24%),
    linear-gradient(90deg, rgba(229, 50, 18, .10), transparent 40%);
  pointer-events: none;
}

.home-feature--technical::before {
  background:
    radial-gradient(circle at 80% 16%, rgba(25, 119, 201, .18), transparent 24%),
    linear-gradient(90deg, rgba(25, 166, 106, .10), transparent 40%);
}

.home-feature > * {
  position: relative;
  z-index: 1;
}

.home-feature__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.home-feature__actions a {
  min-height: 44px;
  padding: 12px 14px;
  display: inline-flex;
  align-items: center;
  border-radius: 8px;
  color: #fff;
  background: linear-gradient(135deg, var(--sje-red), var(--sje-orange));
  font-weight: 950;
  text-decoration: none;
  text-transform: uppercase;
}

.home-feature--technical .home-feature__actions a {
  background: linear-gradient(135deg, var(--sje-green), var(--sje-blue));
}

.home-standard {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: clamp(22px, 4vw, 48px);
  align-items: center;
  margin-bottom: clamp(54px, 7vw, 88px);
  padding: clamp(24px, 4vw, 42px);
  border-radius: 8px;
  color: #fff8df;
  background:
    radial-gradient(circle at 90% 20%, rgba(255, 176, 0, .22), transparent 24%),
    linear-gradient(135deg, #2b1309, #4a1e0d);
}

.home-standard h2,
.home-standard .kicker {
  color: #fff8df;
}

.home-standard__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.home-standard__stats article {
  min-height: 122px;
  padding: 16px;
  border-radius: 8px;
  background: rgba(255, 248, 223, .08);
  border-top: 4px solid var(--sje-yellow);
}

.home-standard__stats article:nth-child(2) {
  border-top-color: var(--sje-green);
}

.home-standard__stats article:nth-child(3) {
  border-top-color: var(--sje-blue);
}

.home-standard__stats strong {
  display: block;
  margin-bottom: 8px;
  color: #fff;
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1;
}

.home-standard__stats span {
  color: rgba(255, 248, 223, .78);
  font-weight: 800;
}

@media (max-width: 980px) {
  .hero--home-gallery .hero__inner,
  .home-about,
  .home-materials,
  .home-standard {
    grid-template-columns: 1fr;
  }

  .hero.hero--home-gallery::before {
    inset: 42% 0 0;
    clip-path: polygon(0 10%, 100% 0, 100% 100%, 0 100%);
  }

  .home-quick-links {
    grid-template-columns: 1fr;
    margin-top: 18px;
  }

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

@media (max-width: 640px) {
  .hero--home-gallery .hero__inner {
    min-height: auto;
    padding-top: 42px;
  }

  .home-hero-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 150px;
  }

  .home-hero-gallery__item {
    grid-column: auto;
    grid-row: auto;
  }

  .home-gallery-wall {
    grid-template-columns: 1fr;
  }

  .home-gallery-wall__item {
    aspect-ratio: 4 / 3;
  }

  .home-standard__stats {
    grid-template-columns: 1fr;
  }
}

/* Visual content pages */
.content-layout {
  width: min(1180px, calc(100% - 36px));
  margin: clamp(24px, 4vw, 46px) auto clamp(56px, 7vw, 88px);
  display: grid;
  grid-template-columns: minmax(0, .96fr) minmax(320px, .74fr);
  gap: clamp(22px, 4vw, 54px);
  align-items: start;
}

.content-layout__copy {
  min-width: 0;
}

.content-layout__copy > .content {
  width: auto;
  max-width: none;
  margin: 0;
  padding: clamp(22px, 3.4vw, 38px);
  border-radius: 8px;
  background:
    radial-gradient(circle at 92% 12%, rgba(255, 176, 0, .12), transparent 24%),
    #fff;
  border: 1px solid rgba(39, 19, 12, .09);
  box-shadow: 0 18px 52px rgba(67, 29, 11, .08);
}

.content-layout__copy > .content h2:first-child {
  margin-top: 0;
}

.content-layout .pdf-grid {
  width: auto;
  margin: 18px 0 0;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.content-visual {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  position: sticky;
  top: 110px;
}

.content-visual__item {
  min-height: 170px;
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  color: #fff;
  text-decoration: none;
  background: #2b1309;
  box-shadow: 0 18px 46px rgba(67, 29, 11, .14);
}

.content-visual__item:first-child {
  grid-column: span 2;
  min-height: 260px;
}

.content-visual__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.08) contrast(1.02);
  transition: transform .45s ease, filter .35s ease;
}

.content-visual__item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 46%, rgba(39, 19, 12, .58));
  opacity: .78;
  pointer-events: none;
}

.content-visual__item:hover img {
  transform: scale(1.055);
  filter: saturate(1.15) contrast(1.05);
}

.content-visual__item span {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 12px;
  z-index: 1;
  font-weight: 950;
  line-height: 1.15;
  text-transform: uppercase;
}

.content-visual--experiencias {
  grid-template-columns: 1fr;
  position: static;
}

.content-visual--experiencias .content-visual__item,
.content-visual--experiencias .content-visual__item:first-child {
  grid-column: auto;
  min-height: 0;
  padding: 12px;
  background: #fff;
  border: 1px solid rgba(39, 19, 12, .10);
}

.content-visual--experiencias .content-visual__item img {
  height: auto;
  object-fit: contain;
  border-radius: 6px;
}

.content-visual--experiencias .content-visual__item::after {
  display: none;
}

.content-visual--experiencias .content-visual__item span {
  position: static;
  display: block;
  margin-top: 10px;
  color: var(--sje-ink);
  font-size: 15px;
}

.content-layout--cores-csbr,
.content-layout--cores-epdm,
.content-layout--flexidesenhos,
.content-layout--descritivo-tecnico-dos-suportes-e-envolvente,
.content-layout--descritivo-tecnico-da-colocacao,
.content-layout--inovacao {
  grid-template-columns: minmax(0, .82fr) minmax(320px, .92fr);
}

.content-layout--cores-csbr .content-visual__item:first-child,
.content-layout--cores-epdm .content-visual__item:first-child,
.content-layout--flexidesenhos .content-visual__item:first-child,
.content-layout--descritivo-tecnico-dos-suportes-e-envolvente .content-visual__item:first-child,
.content-layout--descritivo-tecnico-da-colocacao .content-visual__item:first-child,
.content-layout--inovacao .content-visual__item:first-child {
  min-height: 360px;
}

@media (max-width: 980px) {
  .content-layout,
  .content-layout--cores-csbr,
  .content-layout--cores-epdm,
  .content-layout--flexidesenhos,
  .content-layout--descritivo-tecnico-dos-suportes-e-envolvente,
  .content-layout--descritivo-tecnico-da-colocacao,
  .content-layout--inovacao {
    grid-template-columns: 1fr;
  }

  .content-visual {
    position: static;
  }
}

@media (max-width: 620px) {
  .content-visual {
    grid-template-columns: 1fr;
  }

  .content-visual__item:first-child {
    grid-column: auto;
  }

  .content-layout .pdf-grid {
    grid-template-columns: 1fr;
  }
}

/* PDF previews */
.pdf-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.pdf-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}

.pdf-card h2 {
  margin-bottom: 0;
}

.pdf-card__preview {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px solid rgba(39, 19, 12, .13);
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(247, 156, 29, .10), rgba(24, 162, 76, .08)),
    #fff;
}

.pdf-card__frame {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  pointer-events: none;
}

.content-layout .pdf-grid {
  grid-template-columns: repeat(2, minmax(240px, 1fr));
}

@media (max-width: 620px) {
  .content-layout .pdf-grid,
  .pdf-grid {
    grid-template-columns: 1fr;
  }
}
