:root {
  --burgundy:#810B38;
  --paper:#F1E2D1;
  --sand:#DCC3AA;
  --brown:#541A1A;
  --ink:#1f1113;
  --muted:#735e55;
  --white:#fffaf4;
  --line:rgba(84,26,26,.18);
  --glass:rgba(84,26,26,.42);
  --shadow:0 28px 90px rgba(84,26,26,.18);
  --radius:30px;
}
* {
  box-sizing:border-box
}
html {
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:var(--burgundy) var(--paper)
}
::-webkit-scrollbar {
  width:12px;
  height:12px
}
::-webkit-scrollbar-track {
  background:linear-gradient(180deg,var(--paper),#ead3bd)
}
::-webkit-scrollbar-thumb {
  background:linear-gradient(180deg,var(--burgundy),var(--brown));
  border:3px solid var(--paper);
  border-radius:999px
}
::-webkit-scrollbar-thumb:hover {
  background:var(--brown)
}
body {
  margin:0;
  font-family:Inter,Arial,Helvetica,sans-serif;
  color:var(--ink);
  background:var(--paper);
  overflow-x:hidden;
  text-rendering:geometricPrecision
}
body.menu-open {
  overflow:hidden
}
a {
  color:inherit;
  text-decoration:none
}
img {
  display:block;
  max-width:100%
}
button,input,textarea,select {
  font:inherit
}
.container {
  width:min(1180px,calc(100% - 40px));
  margin:auto
}
.grain {
  position:fixed;
  inset:0;
  z-index:80;
  pointer-events:none;
  opacity:.045;
  background-image:radial-gradient(var(--brown) .8px,transparent .8px);
  background-size:5px 5px;
  mix-blend-mode:multiply
}
.site-header {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
  padding:18px 0;
  transition:.25s ease
}
.nav-shell {
  width:min(1180px,calc(100% - 28px));
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(84,26,26,.34);
  color:#fff;
  border-radius:999px;
  padding:10px 12px 10px 20px;
  backdrop-filter:blur(18px);
  box-shadow:0 16px 50px rgba(0,0,0,.15)
}
body.scrolled .nav-shell {
  background:rgba(84,26,26,.78);
  border-color:rgba(255,255,255,.18)
}
.brand {
  width:144px;
  height:36px;
  display:flex;
  align-items:center;
  flex:0 0 144px
}
.brand img {
  width:144px;
  height:36px;
  object-fit:contain;
  object-position:left center;
  background:transparent
}
.nav-links {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:3px
}
.nav-links a {
  position:relative;
  display:inline-flex;
  align-items:center;
  padding:11px 13px;
  border-radius:999px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.01em;
  color:rgba(255,255,255,.78);
  transition:.22s ease;
  white-space:nowrap;
  overflow:hidden
}
.nav-links a::before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(241,226,209,.08));
  opacity:0;
  transition:.22s ease
}
.nav-links a span,.nav-links a {
  z-index:1
}
.nav-links a:hover,.nav-links a.active {
  color:#fff;
  transform:translateY(-1px)
}
.nav-links a:hover::before,.nav-links a.active::before {
  opacity:1
}
.nav-links a.active {
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.15)
}
.nav-cta {
  background:var(--paper)!important;
  color:var(--brown)!important;
  padding:11px 18px!important;
  box-shadow:0 12px 30px rgba(0,0,0,.12)!important
}
.header-actions {
  display:flex;
  align-items:center;
  gap:8px
}
.sound-toggle,.menu-btn {
  border:1px solid rgba(255,255,255,.24);
  background:rgba(255,255,255,.12);
  color:#fff;
  border-radius:999px;
  display:inline-grid;
  place-items:center;
  width:42px;
  height:42px;
  cursor:pointer;
  transition:.22s ease
}
.sound-toggle:hover,.menu-btn:hover {
  background:var(--paper);
  color:var(--brown);
  transform:translateY(-1px)
}
.sound-toggle {
  font-weight:950;
  font-size:18px;
  position:relative;
  overflow:hidden
}
.sound-toggle .sound-on {
  display:none
}
.sound-toggle .sound-off {
  display:block;
  font-size:24px;
  line-height:1
}
.sound-toggle.is-on .sound-on {
  display:block
}
.sound-toggle.is-on .sound-off {
  display:none
}
body:not(.has-hero-video) .sound-toggle {
  display:none
}
.menu-btn {
  display:none;
  gap:4px;
  padding:0
}
.menu-btn span {
  width:18px;
  height:2px;
  background:currentColor;
  border-radius:99px;
  display:block;
  transition:.22s ease
}
.menu-open .menu-btn span:nth-child(1) {
  transform:translateY(6px) rotate(45deg)
}
.menu-open .menu-btn span:nth-child(2) {
  opacity:0
}
.menu-open .menu-btn span:nth-child(3) {
  transform:translateY(-6px) rotate(-45deg)
}
.hero {
  min-height:100vh;
  position:relative;
  display:grid;
  align-items:end;
  color:#fff;
  overflow:hidden;
  background:#17090b
}
.hero::before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(26,8,10,.24),rgba(26,8,10,.84)),var(--hero) top center/cover no-repeat;
  transform:scale(1.02);
  animation:slowZoom 18s ease-in-out infinite alternate;
  z-index:0
}
.hero::after {
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-1px;
  height:32%;
  background:linear-gradient(180deg,rgba(241,226,209,0),var(--paper));
  z-index:1
}
.home-hero::before {
  display:none
}
.hero-video {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:top center;
  opacity:.62;
  z-index:0;
  filter:saturate(.94) contrast(1.04)
}
.hero-shade {
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 20% 25%,rgba(129,11,56,.32),transparent 20%),linear-gradient(180deg,rgba(20,6,8,.42),rgba(20,6,8,.4));
  z-index:1
}
.hero-content {
  position:relative;
  z-index:2;
  padding:170px 0 98px
}
.home-hero-content {
  padding-bottom:112px
}
.eyebrow {
  display:inline-flex;
  align-items:center;
  gap:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:12px;
  font-weight:950;
  color:rgba(255,255,255,.84)
}
.dot {
  width:9px;
  height:9px;
  border-radius:50%;
  background:var(--paper);
  box-shadow:17px 0 var(--sand),34px 0 var(--burgundy),51px 0 #fff
}
h1 {
  font-size:clamp(44px,8vw,118px);
  line-height:.86;
  letter-spacing:-.075em;
  margin:20px 0 0;
  max-width:1050px
}
.type-title {
  font-size:clamp(48px,9.2vw,142px);
  min-height:2em;
  text-transform:uppercase;
  max-width:1180px
}
.typed-word {
  display:inline-block;
  color:var(--paper);
  text-shadow:0 10px 40px rgba(0,0,0,.25)
}
.cursor {
  display:inline-block;
  width:.08em;
  height:.8em;
  margin-left:.04em;
  background:var(--paper);
  transform:translateY(.08em);
  animation:blink .85s steps(1) infinite
}
.hero-desc {
  font-size:clamp(18px,2vw,25px);
  line-height:1.45;
  max-width:760px;
  color:rgba(255,255,255,.82);
  margin:24px 0 0
}
.hero-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:34px
}
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border-radius:999px;
  padding:14px 20px;
  border:1px solid var(--line);
  font-weight:950;
  transition:.25s cubic-bezier(.2,.8,.2,1);
  cursor:pointer;
  white-space:nowrap
}
.btn.primary {
  background:var(--burgundy);
  border-color:var(--burgundy);
  color:#fff;
  box-shadow:0 16px 42px rgba(129,11,56,.24)
}
.btn.dark {
  background:var(--brown);
  border-color:var(--brown);
  color:#fff
}
.btn.ghost {
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.22);
  color:#fff;
  backdrop-filter:blur(12px)
}
.btn:hover {
  transform:translateY(-3px);
  box-shadow:0 18px 50px rgba(84,26,26,.18)
}
.identity-strip {
  position:relative;
  z-index:3;
  margin-top:-52px
}
.strip {
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr .8fr;
  overflow:hidden;
  border-radius:26px;
  box-shadow:var(--shadow)
}
.strip span {
  height:92px
}
.strip span:nth-child(1) {
  background:var(--burgundy)
}
.strip span:nth-child(2) {
  background:var(--paper)
}
.strip span:nth-child(3) {
  background:var(--sand)
}
.strip span:nth-child(4) {
  background:var(--brown)
}
.section {
  padding:50px 0
}
.section-head {
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:30px;
  margin-bottom:34px
}
.section-head p {
  max-width:560px;
  font-size:18px;
  line-height:1.65;
  color:var(--muted)
}
.kicker {
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:950;
  color:var(--burgundy)
}
h2 {
  font-size:clamp(34px,5vw,70px);
  line-height:.94;
  letter-spacing:-.058em;
  margin:10px 0 0
}
h3 {
  letter-spacing:-.03em
}
.split {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:32px;
  align-items:center
}
.wide-gap {
  gap:54px
}
.text-block p,.method-card p,.prose-card p,.brief-card p {
  font-size:18px;
  line-height:1.7;
  color:var(--muted)
}
.triad-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  background:rgba(255,250,244,.48);
  border:1px solid var(--line);
  border-radius:calc(var(--radius) + 8px);
  box-shadow:var(--shadow);
  overflow:hidden
}
.triad-card {
  position:relative;
  padding:34px;
  min-height:550px;
  display:flex;
  flex-direction:column
}
.triad-card+ .triad-card {
  border-left:1px solid var(--line)
}
.triad-num {
  font-size:12px;
  letter-spacing:.16em;
  font-weight:950;
  color:var(--burgundy)
}
.triad-card h2 {
  font-size:clamp(28px,3vw,42px);
  margin:28px 0 18px
}
.triad-card p {
  font-size:16.5px;
  line-height:1.68;
  color:var(--muted);
  margin:0 0 30px
}
.logo-link {
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  border-top:1px solid var(--line);
  padding-top:22px;
  font-weight:950;
  color:var(--burgundy)
}
.logo-link img {
  width:74px;
  height:74px;
  object-fit:contain;
  border:1px solid var(--line);
  border-radius:50%;
  padding:13px;
  background:var(--paper);
  transition:.25s ease
}
.logo-link:hover img {
  transform:rotate(8deg) scale(1.05);
  border-color:var(--burgundy)
}
.media-card {
  min-height:560px;
  border-radius:calc(var(--radius) + 8px);
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow);
  background:var(--brown)
}
.media-card img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover
}
.caption {
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;
  background:rgba(241,226,209,.88);
  backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.35);
  border-radius:24px;
  padding:18px;
  color:var(--brown)
}
.caption strong {
  color:var(--burgundy)
}
.method-card,.prose-card,.brief-card,.contact-info-card,.contact-form-card {
  background:rgba(255,250,244,.58);
  border:1px solid var(--line);
  border-radius:calc(var(--radius) + 8px);
  padding:36px;
  box-shadow:0 18px 60px rgba(84,26,26,.08)
}
.method-card {
  background:var(--brown);
  color:#fff
}
.method-card p {
  color:rgba(255,255,255,.76)
}
.method-card .kicker {
  color:var(--paper)
}
.service-modern-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px
}
.service-modern {
  min-height:250px;
  border:1px solid var(--line);
  background:linear-gradient(145deg,rgba(255,250,244,.72),rgba(220,195,170,.35));
  border-radius:28px;
  padding:24px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
  overflow:hidden;
  transition:.25s ease
}
.service-modern::after {
  content:"";
  position:absolute;
  right:-40px;
  top:-40px;
  width:120px;
  height:120px;
  background:var(--burgundy);
  border-radius:50%;
  opacity:.09;
  transition:.25s ease
}
.service-modern span {
  font-size:12px;
  letter-spacing:.16em;
  font-weight:950;
  color:var(--burgundy)
}
.service-modern h3 {
  font-size:24px;
  line-height:1.02;
  margin:20px 0
}
.service-modern p {
  font-size:15px;
  color:var(--muted);
  line-height:1.55;
  margin:0
}
.service-modern:hover {
  transform:translateY(-6px);
  box-shadow:var(--shadow);
  border-color:rgba(129,11,56,.34)
}
.service-modern:hover::after {
  transform:scale(1.8);
  opacity:.13
}
.services-showcase {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px
}
.service-tile {
  min-height:360px;
  border-radius:32px;
  overflow:hidden;
  background:var(--white);
  border:1px solid var(--line);
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  box-shadow:0 18px 60px rgba(84,26,26,.08);
  transition:.25s ease
}
.service-media {
  background:linear-gradient(180deg,rgba(84,26,26,.08),rgba(84,26,26,.38)),var(--img) center/cover no-repeat;
  min-height:100%
}
.service-body {
  padding:30px;
  display:flex;
  flex-direction:column;
  justify-content:end
}
.service-body span {
  font-size:12px;
  font-weight:950;
  letter-spacing:.16em;
  color:var(--burgundy)
}
.service-body h2 {
  font-size:clamp(30px,3vw,46px)
}
.service-body p {
  color:var(--muted);
  line-height:1.6
}
.service-tile:hover {
  transform:translateY(-5px);
  box-shadow:var(--shadow)
}
.slider {
  background:rgba(255,250,244,.58);
  border:1px solid var(--line);
  border-radius:calc(var(--radius) + 8px);
  padding:18px;
  box-shadow:0 18px 60px rgba(84,26,26,.08);
  overflow:hidden
}
.slider-top {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin:4px 4px 16px
}
.slider-controls {
  display:flex;
  gap:8px
}
.slider-controls button,.lightbox-arrow,.lightbox-close {
  border:1px solid var(--line);
  background:var(--paper);
  color:var(--brown);
  border-radius:50%;
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:.22s ease
}
.slider-controls svg,.lightbox-arrow svg {
  width:22px;
  height:22px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.4
}
.slider-controls button:hover {
  background:var(--burgundy);
  color:#fff
}
.slider-window {
  overflow:hidden;
  border-radius:26px
}
.slider-track {
  display:flex;
  transition:transform .6s cubic-bezier(.2,.8,.2,1)
}
.slide {
  min-width:100%;
  position:relative;
  border:0;
  padding:0;
  background:#111;
  aspect-ratio:16/10;
  cursor:pointer;
  overflow:hidden
}
.slide img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.6s ease
}
.slide:hover img {
  transform:scale(1.04)
}
.slide span {
  position:absolute;
  left:18px;
  bottom:18px;
  background:rgba(84,26,26,.74);
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(10px);
  border-radius:999px;
  padding:10px 14px;
  font-weight:900
}
.slider-thumbs {
  display:flex;
  gap:10px;
  margin-top:12px;
  overflow:auto;
  padding-bottom:4px
}
.slider-thumbs button {
  border:2px solid transparent;
  background:transparent;
  padding:0;
  border-radius:14px;
  overflow:hidden;
  width:88px;
  flex:0 0 88px;
  height:54px;
  cursor:pointer;
  opacity:.58;
  transition:.2s
}
.slider-thumbs button.active {
  opacity:1;
  border-color:var(--burgundy)
}
.slider-thumbs img {
  width:100%;
  height:100%;
  object-fit:cover
}
.steps {
  display:grid;
  gap:10px
}
.step {
  display:grid;
  grid-template-columns:70px 1fr;
  gap:18px;
  align-items:start;
  border:1px solid var(--line);
  background:rgba(255,250,244,.5);
  border-radius:24px;
  padding:18px
}
.step span {
  width:46px;
  height:46px;
  border-radius:50%;
  background:var(--burgundy);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:950
}
.step h3 {
  margin:0 0 6px;
  font-size:23px
}
.step p {
  margin:0;
  color:var(--muted);
  line-height:1.55
}
.project-grid {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px
}
.project-tile {
  min-height:420px;
  position:relative;
  overflow:hidden;
  border-radius:32px;
  background:#16090b;
  color:#fff;
  box-shadow:0 18px 60px rgba(84,26,26,.14)
}
.project-tile:nth-child(1) {
  grid-column:span 2;
  min-height:520px
}
.project-tile img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.75;
  transition:.55s ease
}
.project-tile::after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent,rgba(31,17,19,.82))
}
.project-tile div {
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:2;
  background:rgba(84,26,26,.58);
  border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(14px);
  border-radius:24px;
  padding:20px
}
.project-tile span {
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:950;
  color:var(--paper)
}
.project-tile h2 {
  font-size:clamp(32px,5vw,68px)
}
.project-tile:hover img {
  transform:scale(1.06);
  opacity:.6
}
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px
}
.gallery-item {
  position:relative;
  border:0;
  padding:0;
  background:#111;
  aspect-ratio:16/10;
  border-radius:26px;
  overflow:hidden;
  cursor:pointer;
  box-shadow:0 15px 45px rgba(84,26,26,.08)
}
.gallery-item:nth-child(1) {
  grid-column:span 2;
  grid-row:span 2
}
.gallery-item img {
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.5s ease
}
.gallery-item span {
  position:absolute;
  left:12px;
  right:12px;
  bottom:12px;
  background:rgba(84,26,26,.68);
  color:#fff;
  border-radius:999px;
  padding:10px 12px;
  font-size:13px;
  font-weight:900;
  backdrop-filter:blur(10px)
}
.gallery-item:hover img {
  transform:scale(1.06);
  opacity:.76
}
.event-slider-wrap {
  margin-top:22px
}
.contact-panel {
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:18px;
  background:var(--brown);
  color:#fff;
  border-radius:calc(var(--radius) + 10px);
  padding:24px;
  box-shadow:var(--shadow)
}
.contact-copy,.contact-panel .form {
  padding:34px
}
.contact-copy p {
  color:rgba(255,255,255,.78);
  line-height:1.7;
  font-size:18px
}
.form {
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  border-radius:28px;
  padding:28px
}
.field-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px
}
.field {
  display:grid;
  gap:8px;
  margin-bottom:14px
}
.field label {
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:rgba(255,255,255,.68);
  font-weight:950
}
.field input,.field select,.field textarea {
  width:100%;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.10);
  color:#fff;
  border-radius:18px;
  padding:14px 15px;
  outline:0;
  transition:.22s ease
}
.field textarea {
  min-height:132px;
  resize:vertical
}
.field input:focus,.field select:focus,.field textarea:focus {
  border-color:var(--paper);
  box-shadow:0 0 0 4px rgba(241,226,209,.12)
}
.field select option {
  background:var(--paper);
  color:var(--brown)
}
.contact-layout {
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:22px;
  align-items:start
}
.contact-info-card h2 {
  margin-bottom:20px
}
.contact-lines {
  display:grid;
  gap:12px
}
.contact-lines a,.contact-lines p,.footer-block a,.footer-block p {
  display:flex;
  align-items:flex-start;
  gap:10px;
  line-height:1.45;
  color:var(--muted)
}
.contact-lines svg,.footer-block svg {
  width:20px;
  height:20px;
  flex:0 0 20px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.9
}
.whatsapp-large {
  margin-top:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  background:#1fa763;
  color:#fff;
  border-radius:24px;
  padding:20px;
  font-weight:950;
  box-shadow:0 18px 42px rgba(31,167,99,.22)
}
.whatsapp-large svg {
  width:26px;
  height:26px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8
}
.mini-socials {
  display:flex;
  gap:10px;
  margin-top:18px
}
.mini-socials a {
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--brown);
  color:#fff;
  display:grid;
  place-items:center
}
.mini-socials svg {
  width:21px;
  height:21px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8
}
.compact-cta {
  padding-top:0
}
.cta-panel {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:30px;
  background:linear-gradient(135deg,var(--brown),var(--burgundy));
  color:#fff;
  border-radius:36px;
  padding:38px;
  box-shadow:var(--shadow)
}
.cta-panel h2 {
  font-size:clamp(32px,4vw,58px)
}
.cta-panel p {
  font-size:18px;
  line-height:1.7;
  max-width:720px;
  color:rgba(255,255,255,.78)
}
.footer {
  background:var(--brown);
  color:#fff;
  padding:64px 0 24px;
  margin-top:80px
}
.footer-shell {
  display:grid;
  grid-template-columns:1.2fr 1fr .7fr;
  gap:34px
}
.footer-brand img {
  width:170px;
  height:auto;
  filter:brightness(0) invert(1)
}
.footer-brand p {
  max-width:430px;
  color:rgba(255,255,255,.72);
  line-height:1.7
}
.footer-socials {
  display:flex;
  gap:10px;
  margin-top:20px
}
.footer-socials a {
  width:44px;
  height:44px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.12);
  transition:.22s
}
.footer-socials a:hover {
  background:var(--paper);
  color:var(--brown);
  transform:translateY(-2px)
}
.footer-socials svg {
  width:21px;
  height:21px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.8
}
.footer-block {
  display:grid;
  gap:11px;
  align-content:start
}
.footer-block h3 {
  margin:0 0 10px;
  color:var(--paper);
  font-size:22px
}
.footer-block a,.footer-block p {
  color:rgba(255,255,255,.74);
  margin:0
}
.footer-menu a {
  display:block
}
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.14);
  margin-top:42px;
  padding-top:22px;
  display:flex;
  justify-content:space-between;
  gap:18px;
  color:rgba(255,255,255,.58);
  font-size:14px
}
.whatsapp-float {
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:90;
  width:58px;
  height:58px;
  border-radius:50%;
  background:#1fa763;
  color:#fff;
  display:grid;
  place-items:center;
  box-shadow:0 18px 48px rgba(31,167,99,.34);
  transition:.25s ease
}
.whatsapp-float:hover {
  transform:translateY(-4px) scale(1.03)
}
.whatsapp-float svg {
  width:29px;
  height:29px;
  fill:none;
  stroke:currentColor;
  stroke-width:1.7
}
.lightbox {
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  background:rgba(22,7,9,.94);
  color:#fff;
  padding:24px
}
.lightbox.is-open {
  display:grid;
  align-items:center
}
.lightbox figure {
  margin:0;
  min-width:0;
  padding:10px
}
.lightbox img {
  width:100%;
  max-height:76vh;
  object-fit:contain;
  border-radius:24px;
  box-shadow:0 28px 80px rgba(0,0,0,.36)
}
.lightbox figcaption {
  text-align:center;
  margin-top:12px;
  color:rgba(255,255,255,.7);
  font-weight:800
}
.lightbox-close {
  position:absolute;
  right:24px;
  top:24px;
  z-index:2;
  font-size:30px
}
.lightbox-arrow {
  background:rgba(241,226,209,.12);
  border-color:rgba(255,255,255,.18);
  color:#fff
}
.lightbox-arrow:hover,.lightbox-close:hover {
  background:var(--paper);
  color:var(--brown)
}
.lightbox-strip {
  grid-column:1/-1;
  display:flex;
  gap:3px;
  overflow:auto;
  padding:4px 76px 6px
}
.lightbox-strip button {
  border:2px solid transparent;
  background:transparent;
  border-radius:14px;
  overflow:hidden;
  flex:0 0 94px;
  height:58px;
  padding:0;
  opacity:.55;
  cursor:pointer
}
.lightbox-strip button.active {
  border-color:var(--paper);
  opacity:1
}
.lightbox-strip img {
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:0
}
.prose-card h2 {
  font-size:clamp(32px,4vw,56px)
}
.prose-card h3 {
  font-size:28px;
  margin:34px 0 8px;
  color:var(--burgundy)
}
.prose-card a {
  color:var(--burgundy);
  font-weight:900
}
.brief-card {
  position:sticky;
  top:120px;
  background:var(--brown);
  color:#fff
}
.brief-card p {
  color:rgba(255,255,255,.76)
}
.brief-card .kicker {
  color:var(--paper)
}
.admin-page {
  background:#15090b;
  color:var(--paper)
}
.admin-page .grain,.admin-page .whatsapp-float {
  display:none
}
.admin-layout {
  min-height:100vh;
  display:grid;
  grid-template-columns:290px 1fr
}
.admin-sidebar {
  background:#0f0608;
  border-right:1px solid rgba(255,255,255,.11);
  padding:24px;
  position:sticky;
  top:0;
  height:100vh
}
.admin-brand {
  width:160px;
  height:46px;
  margin-bottom:34px
}
.admin-brand img {
  filter:brightness(0) invert(1)
}
.admin-sidebar nav {
  display:grid;
  gap:8px
}
.admin-sidebar a {
  padding:14px 15px;
  border-radius:18px;
  color:rgba(255,255,255,.72);
  font-weight:850
}
.admin-sidebar a.active,.admin-sidebar a:hover {
  background:rgba(255,255,255,.08);
  color:#fff
}
.admin-main {
  padding:32px
}
.admin-top {
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  margin-bottom:24px
}
.admin-main h1 {
  font-size:clamp(42px,7vw,86px);
  margin:6px 0 0
}
.admin-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px
}
.admin-grid article,.admin-panel {
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:28px;
  padding:22px
}
.admin-grid span {
  color:rgba(255,255,255,.62)
}
.admin-grid b {
  display:block;
  font-size:44px;
  margin-top:10px
}
.admin-panel {
  margin-top:16px;
  overflow:auto
}
.admin-panel h2 {
  font-size:34px
}
.admin-panel table {
  width:100%;
  border-collapse:collapse;
  min-width:640px
}
.admin-panel th,.admin-panel td {
  text-align:left;
  padding:16px;
  border-bottom:1px solid rgba(255,255,255,.08)
}
.admin-panel td span {
  background:rgba(241,226,209,.12);
  color:var(--paper);
  border-radius:999px;
  padding:7px 10px;
  font-weight:900;
  font-size:12px
}
.reveal {
  opacity:0;
  transform:translateY(24px);
  transition:.8s cubic-bezier(.2,.8,.2,1)
}
.reveal.in {
  opacity:1;
  transform:none
}
@keyframes slowZoom {
to {
    transform:scale(1.1)
  }
}
@keyframes blink {
50% {
    opacity:0
  }
}
@media(max-width:1100px) {
.nav-links a {
    font-size:12px;
    padding:10px 10px
  }
.service-modern-grid {
    grid-template-columns:repeat(2,1fr)
  }
}
@media(max-width:920px) {
.container {
    width:min(100% - 28px,1180px)
  }
.site-header {
    padding:12px 0
  }
.nav-shell {
    padding:9px 10px 9px 14px
  }
.brand {
    width:144px;
    height:36px;
    flex-basis:144px
  }
.menu-btn {
    display:inline-grid
  }
.nav-links {
    position:fixed;
    left:14px;
    right:14px;
    top:84px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    background:rgba(84,26,26,.96);
    border:1px solid rgba(255,255,255,.14);
    border-radius:26px;
    padding:12px;
    box-shadow:0 30px 70px rgba(0,0,0,.22)
  }
.menu-open .nav-links {
    display:flex
  }
.nav-links a {
    font-size:15px;
    padding:15px 16px
  }
.nav-cta {
    justify-content:center
  }
.hero-content {
    padding:150px 0 78px
  }
.type-title {
    font-size:clamp(44px,14vw,76px);
    min-height:2.6em
  }
.strip span {
    height:50px
  }
.section {
    padding:72px 0
  }
.section-head,.split,.contact-panel,.contact-layout,.footer-shell,.admin-layout {
    grid-template-columns:1fr
  }
.section-head {
    align-items:flex-start
  }
.triad-grid {
    grid-template-columns:1fr
  }
.triad-card {
    min-height:auto
  }
.triad-card+ .triad-card {
    border-left:0;
    border-top:1px solid var(--line)
  }
.media-card {
    min-height:410px
  }
.service-modern-grid,.services-showcase,.project-grid,.gallery-grid,.field-grid,.admin-grid {
    grid-template-columns:1fr
  }
.service-tile {
    grid-template-columns:1fr
  }
.service-media {
    min-height:220px
  }
.project-tile:nth-child(1),.gallery-item:nth-child(1) {
    grid-column:auto;
    grid-row:auto
  }
.contact-copy,.contact-panel .form {
    padding:22px
  }
.cta-panel {
    flex-direction:column;
    align-items:flex-start
  }
.footer-bottom {
    flex-direction:column
  }
.lightbox.is-open {
    grid-template-columns:1fr;
  }
.lightbox-arrow {
    position:fixed;
    top:50%;
    transform:translateY(-50%);
    z-index:2
  }
.lightbox-arrow.prev {
    left:12px
  }
.lightbox-arrow.next {
    right:12px
  }
.lightbox-strip {
    padding:4px 0 6px
  }
.admin-sidebar {
    position:relative;
    height:auto
  }
.brief-card {
    position:relative;
    top:auto
  }
.reverse-mobile .media-card {
    order:-1
  }
}
@media(max-width:520px) {
h1 {
    font-size:35px
  }
.hero-desc {
    font-size:17px
  }
.hero-actions .btn {
    width:100%
  }
.brand {
    width:132px;
    flex-basis:132px
  }
.brand img {
    width:132px;
    height:33px
  }
.sound-toggle,.menu-btn {
    width:39px;
    height:39px
  }
.triad-card,.method-card,.prose-card,.brief-card,.contact-info-card,.contact-form-card {
    padding:24px
  }
.service-modern {
    min-height:210px
  }
.footer {
    margin-top:48px
  }
.whatsapp-float {
    right:16px;
    bottom:16px;
    width:54px;
    height:54px
  }
.lightbox {
    padding:160px 0 100px;
  }
.lightbox-close {
    right:14px;
    top:14px
  }
.slide span {
    left:12px;
    bottom:12px;
    max-width:calc(100% - 24px);
    white-space:normal
  }
}
@media(prefers-reduced-motion:reduce) {
* {
    animation:none!important;
    transition:none!important;
    scroll-behavior:auto!important
  }
}
.page-hero {
  min-height:76vh
}
.contact-form-card .form {
  background:var(--brown);
  border-color:rgba(255,255,255,.12)
}
/* V3 refinements */
.header-actions {
  display:none
}
.sound-toggle {
  display:none!important
}
@media(max-width:920px) {
.header-actions {
    display:flex
  }
.menu-btn {
    display:inline-grid
  }
}
.nav-links a:hover {
  background:rgba(241,226,209,.14)
}
.nav-links a {
  max-height:38px
}
.nav-links a.active {
  background:rgba(241,226,209,.20);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(241,226,209,.34);
  max-height:38px
}
.hero-content {
  padding:200px 0 110px
}
.home-hero-content {
  padding:200px 0 110px
}
.type-title {
  line-height:.86;
  min-height:1.78em
}
.type-title .type-fixed,.type-title .typed-word {
  display:block
}
.type-title .typed-word {
  color:var(--paper)
}
.type-title .cursor {
  display:none
}
.eyebrow {
  gap:65px
}
.hero-actions {
  margin-top:42px;
  gap:16px;
  align-items:center
}
.hero-actions .btn {
  padding:16px 26px;
  border-radius:18px;
  min-width:188px
}
.hero-actions .btn.primary {
  background:var(--paper);
  border-color:var(--paper);
  color:var(--brown);
  box-shadow:0 22px 60px rgba(241,226,209,.18)
}
.hero-actions .btn.ghost {
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.34)
}
.triad-grid {
  background:transparent;
  border:0;
  box-shadow:none;
  gap:16px;
  overflow:visible
}
.triad-card {
  background:rgba(255,250,244,.62);
  border:1px solid var(--line);
  border-radius:30px;
  min-height:430px;
  padding:28px;
  box-shadow:0 18px 55px rgba(84,26,26,.08)
}
.triad-card+ .triad-card {
  border-left:1px solid var(--line)
}
.logo-link {
  border-top:0;
  padding-top:0;
  justify-content:flex-start;
  width:max-content;
  background:var(--brown);
  color:#fff;
  border-radius:999px;
  padding:12px 16px;
  transition:.22s
}
.logo-link:hover {
  background:var(--burgundy);
  transform:translateY(-2px)
}
.logo-link img {
  display:none!important
}
.slider {
  position:relative;
  width:100%;
  padding:0;
  border:0;
  border-radius:34px;
  background:transparent;
  box-shadow:none;
  overflow:visible
}
.slider-window {
  border-radius:34px;
  box-shadow:var(--shadow);
  background:var(--brown)
}
.slider-track {
  transition:transform .7s cubic-bezier(.16,.84,.22,1)
}
.slide {
  transition:opacity .5s ease
}
.slide img {
  transition:transform .75s cubic-bezier(.16,.84,.22,1),opacity .5s
}
.slide span {
  display:none!important
}
.slider-arrow {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:54px;
  height:54px;
  border-radius:50%;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.34);
  background:rgba(84,26,26,.56);
  color:#fff;
  backdrop-filter:blur(12px);
  cursor:pointer;
  transition:.22s
}
.slider-arrow:hover {
  background:var(--paper);
  color:var(--brown)
}
.slider-arrow.left {
  left:18px
}
.slider-arrow.right {
  right:18px
}
.slider-arrow svg {
  width:25px;
  height:25px;
  fill:none;
  stroke:currentColor;
  stroke-width:2.4
}
.slider-thumbs,.lightbox-strip {
  justify-content:center
}
.slider-thumbs {
  margin-top:16px;
  padding:8px 0 4px
}
.slider-thumbs button {
  width:98px;
  flex-basis:98px;
  height:58px;
  border-radius:16px
}
.lightbox img {
  transition:opacity .22s ease,transform .22s ease
}
.lightbox-strip {
  padding-left:10px;
  scrollbar-width:none
}
.lightbox figcaption {
  display:none
}
.method-merged .container,.method-wide {
  max-width:1180px
}
.method-wide {
  background:linear-gradient(135deg,rgba(84,26,26,.98),rgba(129,11,56,.92));
  color:#fff;
  border-radius:38px;
  padding:42px;
  box-shadow:var(--shadow)
}
.method-wide p {
  font-size:18px;
  line-height:1.75;
  color:rgba(255,255,255,.78);
  max-width:920px
}
.method-wide .kicker {
  color:var(--paper)
}
.method-wide .btn {
  margin-top:10px;
  background:var(--paper);
  color:var(--brown);
  border-color:var(--paper)
}
.service-modern-grid {
  grid-template-columns:repeat(3,1fr);
  align-items:stretch
}
.service-modern {
  background:linear-gradient(145deg,rgba(255,250,244,.76),rgba(241,226,209,.52));
  border-radius:32px;
  min-height:220px;
  padding:26px;
  box-shadow:0 18px 55px rgba(84,26,26,.075)
}
.service-modern::before {
  content:"";
  position:absolute;
  inset:auto 18px 18px auto;
  width:62px;
  height:62px;
  border-radius:20px;
  background:linear-gradient(135deg,var(--burgundy),var(--brown));
  opacity:.12;
  transform:rotate(12deg)
}
.service-modern h3 {
  font-size:clamp(22px,2.4vw,32px)
}
.about-identity {
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:22px
}
.about-main {
  background:var(--brown);
  color:#fff;
  border-radius:38px;
  padding:42px;
  box-shadow:var(--shadow);
  min-height:520px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end
}
.about-main h2 {
  font-size:clamp(38px,5.5vw,78px)
}
.about-main p {
  color:rgba(255,255,255,.78);
  font-size:18px;
  line-height:1.72
}
.about-main .kicker {
  color:var(--paper)
}
.about-stack {
  display:grid;
  gap:16px
}
.about-stack article {
  position:relative;
  background:rgba(255,250,244,.64);
  border:1px solid var(--line);
  border-radius:30px;
  padding:28px;
  box-shadow:0 18px 55px rgba(84,26,26,.075);
  overflow:hidden
}
.about-stack article::after {
  content:"";
  position:absolute;
  right:-28px;
  top:-28px;
  width:110px;
  height:110px;
  background:var(--burgundy);
  border-radius:50%;
  opacity:.08
}
.about-stack span {
  font-size:12px;
  letter-spacing:.16em;
  color:var(--burgundy);
  font-weight:950
}
.about-stack h3 {
  font-size:32px;
  margin:14px 0 8px
}
.about-stack p {
  color:var(--muted);
  font-size:17px;
  line-height:1.68;
  margin:0
}
.about-page+.compact-cta {
  padding-top:0
}
.project-tile div {
  background:rgba(84,26,26,.42)
}
.gallery-item span {
  display:none!important
}
.event-slider-wrap {
  display:none!important
}
.footer-block a {
  transition:.22s ease
}
.footer-block a:hover {
  color:var(--paper);
  transform:translateX(4px)
}
.footer-menu a:hover {
  padding-left:4px
}
.footer-block p {
  color:rgba(255,255,255,.74)
}
@media(max-width:1100px) {
.service-modern-grid {
    grid-template-columns:repeat(2,1fr)
  }
}
@media(max-width:920px) {
.hero-content,.home-hero-content {
    padding:140px 0 78px
  }
.type-title {
    font-size:clamp(48px,15vw,82px);
    min-height:1.9em
  }
.eyebrow {
    gap:34px
  }
.triad-card+ .triad-card {
    border-left:1px solid var(--line);
    border-top:0
  }
.about-identity,.service-modern-grid {
    grid-template-columns:1fr
  }
.about-main {
    min-height:auto
  }
.slider-arrow {
    width:46px;
    height:46px
  }
.section {
    padding:64px 0
  }
.nav-links a.active {
    background:rgba(241,226,209,.16)
  }
}
@media(max-width:520px) {
.container {
    width:min(100% - 24px,1180px)
  }
.site-header {
    padding:10px 0
  }
.nav-shell {
    width:min(100% - 18px,1180px);
    padding:8px 9px 8px 12px
  }
.brand,.brand img {
    width:124px;
    height:31px;
    flex-basis:124px
  }
.hero {
    min-height:86vh
  }
.page-hero {
    min-height:68vh
  }
.hero-content,.home-hero-content {
    padding:122px 0 64px
  }
.type-title {
    font-size:48px;
    letter-spacing:-.06em
  }
.hero-actions {
    gap:10px;
    margin-top:30px
  }
.hero-actions .btn {
    width:100%;
    min-width:0;
    border-radius:16px
  }
.section {
    padding:54px 0
  }
.triad-card,.about-main,.about-stack article,.method-wide,.cta-panel {
    padding:24px;
    border-radius:26px
  }
.slider-window {
    border-radius:24px
  }
.slider-arrow {
    width:42px;
    height:42px
  }
.slider-arrow.left {
    left:10px
  }
.slider-arrow.right {
    right:10px
  }
.slider-thumbs button {
    width:72px;
    flex-basis:72px;
    height:44px
  }
.gallery-grid {
    gap:10px
  }
.gallery-item {
    border-radius:18px
  }
.footer {
    padding-top:46px
  }
.footer-shell {
    gap:24px
  }
.lightbox-strip button {
    flex-basis:72px;
    height:46px
  }
.lightbox img {
    border-radius:18px
  }
}
.home-method .split {
  grid-template-columns:1fr;
  gap:22px
}
.home-method .method-card {
  background:linear-gradient(145deg,rgba(255,250,244,.72),rgba(220,195,170,.34));
  color:var(--ink);
  border:1px solid var(--line);
  border-radius:38px
}
.home-method .method-card p {
  color:var(--muted);
  max-width:980px
}
.home-method .method-card .kicker {
  color:var(--burgundy)
}
.home-method .method-card .btn.primary {
  background:var(--brown);
  border-color:var(--brown);
  color:#fff
}
/* V4 requested refinements */
.nav-links {
  gap:10px
}
.hero-content,.home-hero-content {
  padding:150px 0 10px
}
.hero-actions {
  margin-top:34px;
  gap:14px
}
.hero-actions .btn {
  position:relative;
  overflow:hidden;
  border-radius:999px;
  padding:15px 24px;
  min-width:178px;
  border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(18px);
  white-space:normal;
  text-align:center;
  line-height:1.15
}
.hero-actions .btn::before {
  content:"";
  position:absolute;
  inset:1px;
  border-radius:inherit;
  background:linear-gradient(135deg,rgba(255,255,255,.24),rgba(255,255,255,.04));
  opacity:.9;
  z-index:-1
}
.hero-actions .btn.primary {
  background:rgba(241,226,209,.18);
  color:#fff;
  border-color:rgba(241,226,209,.46);
  box-shadow:0 20px 70px rgba(0,0,0,.24),inset 0 1px 0 rgba(255,255,255,.16)
}
.hero-actions .btn.ghost {
  background:rgba(84,26,26,.28);
  border-color:rgba(255,255,255,.24);
  box-shadow:0 20px 70px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.12)
}
.hero-actions .btn:hover {
  transform:translateY(-2px);
  background:rgba(241,226,209,.28);
  color:#fff;
  border-color:rgba(255,255,255,.52);
  box-shadow:0 24px 80px rgba(0,0,0,.3)
}
.slider > .slider-thumbs {
  display:none!important
}
.slider-window {
  width:100%
}
.slider-track {
  will-change:transform
}
.slide {
  will-change:transform
}
.slider-arrow i,.lightbox-arrow i,.lightbox-close i {
  font-size:20px
}
.lightbox-close {
  display:grid;
  place-items:center
}
.method-wide {
  background:linear-gradient(135deg,rgba(255,250,244,.70),rgba(220,195,170,.32));
  color:var(--ink);
  border:1px solid var(--line);
  box-shadow:0 20px 60px rgba(84,26,26,.10);
  position:relative;
  overflow:hidden
}
.method-wide::before {
  content:"";
  position:absolute;
  right:-90px;
  top:-120px;
  width:330px;
  height:330px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(129,11,56,.18),transparent 68%)
}
.method-wide .kicker {
  color:var(--burgundy)
}
.method-wide p {
  color:var(--muted);
  position:relative
}
.method-wide h2 {
  position:relative
}
.method-wide .btn {
  position:relative;
  background:var(--burgundy);
  border-color:var(--burgundy);
  color:#fff
}
.method-wide .btn:hover {
  background:var(--brown);
  border-color:var(--brown)
}
.btn.primary,.btn.dark,.logo-link {
  box-shadow:0 16px 40px rgba(84,26,26,.18)
}
.cta-panel .btn.primary,.method-wide .btn,.contact-form-card .btn.primary,.logo-link {
  background:var(--burgundy);
  border-color:var(--burgundy);
  color:#fff
}
.cta-panel .btn.primary:hover,.contact-form-card .btn.primary:hover,.logo-link:hover {
  background:var(--paper);
  border-color:var(--paper);
  color:var(--brown)
}
.services-showcase {
  gap:18px
}
.service-tile {
  grid-template-columns:190px 1fr;
  min-height:210px;
  border-radius:30px;
  background:linear-gradient(135deg,rgba(255,250,244,.76),rgba(241,226,209,.42));
  border:1px solid rgba(84,26,26,.14);
  box-shadow:0 18px 54px rgba(84,26,26,.08);
  overflow:hidden;
  transition:.26s cubic-bezier(.2,.8,.2,1)
}
.service-tile:hover {
  transform:translateY(-4px);
  box-shadow:0 30px 72px rgba(84,26,26,.14);
  border-color:rgba(129,11,56,.26)
}
.service-media {
  min-height:100%;
  border-radius:0;
  background:linear-gradient(180deg,rgba(84,26,26,.02),rgba(84,26,26,.32)),var(--img) center/cover no-repeat;
  filter:saturate(.92)
}
.service-body {
  padding:30px;
  display:flex;
  flex-direction:column;
  justify-content:center
}
.service-body span {
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:var(--brown);
  color:var(--paper);
  font-weight:950;
  margin-bottom:18px
}
.service-body h2 {
  font-size:clamp(25px,3vw,42px);
  margin:0 0 12px
}
.service-body p {
  font-size:16.5px;
  line-height:1.62;
  margin:0;
  color:var(--muted)
}
.menu-btn {
  border-radius:16px;
  background:rgba(255,255,255,.13);
  border-color:rgba(255,255,255,.2);
  position:relative
}
.menu-btn span {
  width:20px;
  height:2px
}
.menu-open .menu-btn {
  background:var(--paper);
  color:var(--brown);
  border-color:var(--paper)
}
.menu-open .menu-btn span:nth-child(1) {
  transform:translateY(6px) rotate(45deg)
}
.menu-open .menu-btn span:nth-child(3) {
  transform:translateY(-6px) rotate(-45deg)
}
.footer-socials a i,.mini-socials a i {
  font-size:20px
}
.footer-block a i,.footer-block p i,.contact-lines a i,.contact-lines p i {
  color:var(--paper)
}
.whatsapp-float i {
  font-size:29px
}
.whatsapp-large i {
  font-size:26px
}
.footer-block a:hover,.footer-menu a:hover {
  color:var(--paper);
  transform:none!important;
  padding-left:0!important
}
.footer-socials a:hover {
  transform:none!important;
  color:var(--brown)
}
.btn {
  max-width:100%;
  white-space:normal;
  text-align:center
}
.section,.container {
  max-width:100%
}
@media(max-width:920px) {
.hero-content,.home-hero-content {
    padding:132px 0 42px
  }
.hero-actions .btn {
    min-width:0
  }
.service-tile {
    grid-template-columns:1fr
  }
.service-media {
    min-height:220px
  }
.nav-links {
    gap:6px
  }
.nav-links a {
    width:100%
  }
.method-wide {
    padding:30px
  }
}
@media(max-width:520px) {
body {
    overflow-x:hidden
  }
.container {
    width:min(100% - 24px,1180px)
  }
.hero {
    min-height:82vh
  }
.page-hero {
    min-height:58vh
  }
.hero-content,.home-hero-content {
    padding:118px 0 34px
  }
.hero-actions {
    align-items:stretch
  }
.hero-actions .btn {
    width:100%;
    padding:14px 16px
  }
.slider {
    width:100%;
    overflow:hidden;
    border-radius:24px
  }
.slider-window {
    border-radius:24px
  }
.slider-arrow {
    width:40px;
    height:40px
  }
.service-body {
    padding:24px
  }
.service-media {
    min-height:190px
  }
.method-wide {
    border-radius:26px;
    padding:24px
  }
.btn.dark,.btn.primary {
    width:auto
  }
.section-head {
    gap:12px
  }
.footer-block a,.footer-block p {
    line-height:1.45
  }
}
@media(max-width:400px) {
.hero {
    min-height:65vh
  }
}
/* v5 final refinements */
.nav-links {
  gap:10px!important
}
.eyebrow {
  gap:65px!important
}
.hero-content,.home-hero-content {
  padding:150px 0 10px!important
}
.logo-link {
  justify-content:center!important;
  width:auto!important;
  max-width:100%
}
.logo-link img {
  display:none!important
}
/* stronger glass hero CTAs */
.hero-actions {
  display:flex;
  align-items:center;
  gap:12px;
  max-width:560px
}
.hero-actions .btn {
  border-radius:999px;
  padding:15px 22px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.11);
  color:#fff;
  backdrop-filter:blur(18px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 18px 48px rgba(0,0,0,.18)
}
.hero-actions .btn.primary {
  background:linear-gradient(135deg,rgba(241,226,209,.96),rgba(220,195,170,.72));
  color:var(--brown);
  border-color:rgba(255,255,255,.44)
}
.hero-actions .btn.ghost {
  background:rgba(84,26,26,.32);
  color:#fff
}
.hero-actions .btn:hover {
  transform:translateY(-2px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.26),0 24px 60px rgba(0,0,0,.24)
}
/* services page cards */
.services-showcase {
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:18px!important
}
.service-tile {
  display:block!important;
  min-height:0!important;
  border-radius:30px!important;
  background:rgba(255,250,244,.62)!important;
  overflow:hidden!important;
  box-shadow:0 18px 54px rgba(84,26,26,.08)!important
}
.service-media {
  aspect-ratio:16/9!important;
  min-height:0!important;
  width:100%!important;
  background:linear-gradient(180deg,rgba(84,26,26,.02),rgba(84,26,26,.25)),var(--img) center/cover no-repeat!important
}
.service-body h2 {
  font-size:clamp(22px,2.35vw,34px)!important;
  line-height:1!important;
  margin:0!important;
  letter-spacing:-.045em!important
}
.service-body p,.service-body span {
  display:none!important
}
.service-tile:hover .service-media {
  filter:saturate(1.04) contrast(1.03)
}
/* contact and forms */
.field textarea {
  min-height:160px!important
}
.field input::placeholder,.field textarea::placeholder {
  color:rgba(241,226,209,.72)!important
}
.field input,.field select,.field textarea {
  color:#fff!important
}
.form .btn {
  margin-left:auto;
  margin-right:auto;
  display:flex
}
.contact-form-card .form {
  padding:26px
}
.contact-form-card .form .btn,.contact-panel .form .btn {
  white-space:nowrap;
  min-width:170px
}
.mini-socials a {
  background:rgba(84,26,26,.08)!important;
  color:var(--brown)!important;
  border:1px solid rgba(84,26,26,.16)!important
}
.mini-socials a:hover {
  background:var(--brown)!important;
  color:var(--paper)!important
}
/* footer */
.footer-brand p {
  text-align:left!important
}
.footer-logo {
  display:inline-block;
  cursor:pointer;
  width:max-content
}
.footer-logo img {
  cursor:pointer
}
.footer-bottom {
  justify-content:flex-start!important;
  text-align:left!important
}
.footer-block a:hover,.footer-menu a:hover {
  color:var(--paper)!important;
  background:transparent!important;
  transform:none!important;
  padding-left:0!important;
  text-decoration:none!important
}
.footer-socials a:hover {
  transform:none!important
}
/* cleaner burger */
.menu-btn {
  background:transparent!important;
  border-color:rgba(255,255,255,.22)!important;
  border-radius:50%!important;
  box-shadow:none!important
}
.menu-btn:hover {
  background:rgba(255,255,255,.12)!important;
  color:#fff!important
}
.menu-btn span {
  width:21px!important;
  height:2px!important;
  transform-origin:center!important
}
.menu-open .menu-btn {
  background:transparent!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.28)!important
}
.menu-open .menu-btn span:nth-child(1) {
  transform:translateY(6px) rotate(45deg)!important
}
.menu-open .menu-btn span:nth-child(2) {
  opacity:0!important
}
.menu-open .menu-btn span:nth-child(3) {
  transform:translateY(-6px) rotate(-45deg)!important
}
/* home phone section tightening */
.services-preview .section-head {
  align-items:center
}
.services-preview .section-head .btn {
  white-space:nowrap
}
.contact-panel .btn,.cta-panel .btn {
  white-space:nowrap
}
@media(max-width:1100px) {
.services-showcase {
    grid-template-columns:repeat(2,minmax(0,1fr))!important
  }
}
@media(max-width:920px) {
.eyebrow {
    gap:65px!important
  }
.services-preview .section-head {
    display:grid;
    grid-template-columns:1fr auto;
    align-items:end;
    gap:14px
  }
.services-preview .section-head h2 {
    font-size:clamp(30px,8vw,48px)
  }
.services-preview .service-modern-grid {
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important
  }
.service-modern {
    padding:12px!important;
    min-height:170px!important;
    border-radius:20px!important
  }
.service-modern h3 {
    font-size:clamp(16px,4.5vw,22px)!important;
    line-height:1.02!important;
    word-break:normal;
    overflow-wrap:anywhere
  }
.hero-actions {
    grid-template-columns:repeat(2,minmax(0,1fr));
    width:100%;
    max-width:100%;
    gap:10px
  }
.hero-actions .btn {
    width:100%!important;
    min-width:0!important;
    padding:13px 10px!important;
    font-size:16px;
    line-height:1.1;
    white-space:nowrap;
    border-radius:18px!important
  }
.contact-copy,.contact-panel .form {
    padding:18px!important
  }
.form {
    padding:20px!important
  }
.footer .container {
    width:min(100% - 32px,1180px)
  }
.footer-bottom {
    text-align:center!important;
    justify-content:center!important;
    align-items:center!important
  }
}
@media(max-width:620px) {
.services-showcase {
    grid-template-columns:1fr!important
  }
.services-preview .section-head {
    grid-template-columns:1fr;
    align-items:start
  }
.services-preview .section-head .btn {
    width:max-content;
    max-width:100%;
    padding-left:16px;
    padding-right:16px
  }
.contact-panel {
    padding:14px!important
  }
.contact-copy,.contact-panel .form,.contact-form-card,.contact-info-card {
    padding:16px!important
  }
.form {
    border-radius:22px!important;
    padding:16px!important
  }
.hero-actions .btn {
    font-size:14px;
    padding:12px 8px!important;
    letter-spacing:-.01em
  }
}
/* v7 requested refinements */
.brand img,
.footer-logo img {
  content: url('/assets/images/logo.png');
}
.hero-content,
.home-hero-content {
  padding: 150px 0 10px !important;
}
.field textarea {
  min-height: 160px !important;
}
.contact-lines a,
.contact-lines p,
.footer-block a,
.footer-block p {
  align-items: center;
  text-align: start !important;
}
.contact-info-card .mini-socials a,
.contact-info-card .contact-lines a i,
.contact-info-card .contact-lines p i {
  color: var(--burgundy) !important;
}
.contact-info-card .mini-socials a {
  background: rgba(129, 11, 56, .08) !important;
  border-color: rgba(129, 11, 56, .18) !important;
}
.contact-info-card .mini-socials a:hover {
  background: var(--burgundy) !important;
  color: var(--paper) !important;
}
.footer .footer-socials a i,
.footer .footer-block a i,
.footer .footer-block p i {
  color: var(--paper) !important;
}
.footer .footer-socials a:hover i {
  color: var(--brown) !important;
}
.contact-shortcut .btn.ghost,
.compact-cta .btn.ghost,
.contact-copy .btn.ghost {
  white-space: nowrap;
}
.contact-form-card .btn.primary,
.contact-panel .btn.primary {
  display: flex;
  margin-inline: auto;
}
.service-body {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.service-tile {
  color: inherit;
}
.lightbox {
  background: rgba(22, 7, 9, .78);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  padding: 24px clamp(14px, 4vw, 54px) 26px;
}
.lightbox.is-open {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 18px;
  align-items: center;
}
.lightbox figure {
  margin: auto;
  padding: 0;
}
.lightbox img {
  width: 100%;
  aspect-ratio: 16 / 10;
  max-height: min(72vh, 720px);
  object-fit: cover;
  border-radius: 34px;
  border: 1px solid rgba(241, 226, 209, .24);
  box-shadow: 0 34px 110px rgba(0, 0, 0, .48);
  background: var(--brown);
  transition: opacity .28s ease, transform .28s ease;
}
.lightbox.is-changing img {
  opacity: .45;
  transform: scale(.985);
}
.lightbox figcaption {
  display: none;
}
.lightbox-close,
.lightbox-arrow {
  border: 1px solid rgba(241, 226, 209, .24);
  background: rgba(84, 26, 26, .42);
  color: var(--paper);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.lightbox-close:hover,
.lightbox-arrow:hover {
  background: var(--paper);
  color: var(--brown);
}
.lightbox-close {
  right: clamp(14px, 3vw, 34px);
  top: clamp(14px, 3vw, 28px);
}
.lightbox-arrow {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  z-index: 3;
}
.lightbox-arrow.prev {
  left: clamp(10px, 3vw, 34px);
}
.lightbox-arrow.next {
  right: clamp(10px, 3vw, 34px);
}
.lightbox-strip {
  width: min(880px, 100%);
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 4px 4px 8px;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.lightbox-strip::-webkit-scrollbar {
  display: none;
}
.lightbox-strip button {
  flex: 0 0 92px;
  height: 58px;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 16px;
  background: rgba(241, 226, 209, .08);
  opacity: .55;
  cursor: pointer;
  overflow: hidden;
  transition: border-color .22s ease, opacity .22s ease, transform .22s ease;
}
.lightbox-strip button.active {
  border-color: var(--paper);
  opacity: 1;
  outline: 2px solid rgba(129, 11, 56, .55);
  outline-offset: 3px;
}
.lightbox-strip button:hover {
  opacity: 1;
}
.lightbox-strip img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
}
@media (max-width: 920px) {
.nav-links {
    background: rgba(84, 26, 26, .38) !important;
    backdrop-filter: blur(22px) saturate(1.08) !important;
    -webkit-backdrop-filter: blur(22px) saturate(1.08) !important;
    border: 1px solid rgba(241, 226, 209, .22) !important;
    box-shadow: 0 28px 70px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .08) !important;
  }
.menu-btn {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    background: transparent !important;
    border: 1px solid rgba(241, 226, 209, .22) !important;
    overflow: hidden;
  }
.menu-btn span {
    position: absolute;
    left: 12px;
    height: 2px !important;
    border-radius: 999px !important;
    background: #fff !important;
    transition: transform .28s cubic-bezier(.16, .84, .22, 1), opacity .2s ease, width .28s ease, top .28s ease !important;
  }
.menu-btn span:nth-child(1) {
    top: 15px;
    width: 20px !important;
  }
.menu-btn span:nth-child(2) {
    top: 21px;
    width: 16px !important;
  }
.menu-btn span:nth-child(3) {
    top: 27px;
    width: 20px !important;
  }
.menu-open .menu-btn {
    background: rgba(241, 226, 209, .10) !important;
    color: #fff !important;
    border-color: rgba(241, 226, 209, .30) !important;
  }
.menu-open .menu-btn span:nth-child(1) {
    top: 21px !important;
    transform: rotate(45deg) !important;
    width: 21px !important;
  }
.menu-open .menu-btn span:nth-child(2) {
    opacity: 0 !important;
    transform: translateX(8px) !important;
  }
.menu-open .menu-btn span:nth-child(3) {
    top: 21px !important;
    transform: rotate(-45deg) !important;
    width: 21px !important;
  }
}
@media (max-width: 620px) {
.lightbox {
    padding: 76px 12px 20px;
  }
.lightbox img {
    border-radius: 22px;
    max-height: 62vh;
  }
.lightbox-arrow {
    width: 44px;
    height: 44px;
  }
.lightbox-strip {
    justify-content: flex-start;
    gap: 8px;
  }
.lightbox-strip button {
    flex-basis: 72px;
    height: 46px;
    border-radius: 12px;
  }
}


.site-header, .nav-shell {
    filter: none !important;      /* Muted this */
    backdrop-filter: none !important; /* Muted this to avoid double-blur conflicts */
}
/* 1. The Container (The shell) */
.nav-links {
    /* Critical for rendering */
    z-index: 9999;
    transform: translateZ(0); /* Forces GPU Hardware Acceleration */
    
    /* The Blur Effect */
    -webkit-backdrop-filter: blur(22px) saturate(1.08) !important;
    backdrop-filter: blur(22px) saturate(1.08) !important;
    }

/* 2. The Individual Links */
.nav-links a {
    /* Critical for rendering */
    position: relative;
    z-index: 10000;
    transform: translateZ(0); /* Forces GPU for the links specifically */
    
    /* The Blur Effect (Same as container) */
    -webkit-backdrop-filter: blur(20px) saturate(150%) !important;
    backdrop-filter: blur(20px) saturate(150%) !important;
}

.nav-shell, nav.nav-links {
    overflow: hidden; /* CRITICAL: Clips the blur to your border-radius */
}

.nav-shell::before, nav.nav-links::before {
    content: "";
    margin: auto;
    margin-left: 45px;
    margin-right: 45px;
    height: 60px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: -1;
    border-radius: inherit; /* CRITICAL: Copies your rounded corners */
}

.nav-shell::before {
      /* The Blur */
    -webkit-backdrop-filter: blur(22px) saturate(1.08);
    backdrop-filter: blur(22px) saturate(1.08);
    background: rgba(84, 26, 26, 0.38);
}

@media (max-width: 920px) {
  .nav-shell::before, nav.nav-links::before {
    margin-left: 13px;
    margin-right: 13px;
  }
}

/* V24 nav height refinement */
.nav-links a,
.nav-links a.active {
  max-height: 38px;
}

.form-note {
  margin: 12px 0 0;
  font-weight: 700;
  line-height: 1.5;
  color: #541a1a;
}

.form-note.is-success {
  color: #2f6e46;
}

.form-note.is-error {
  color: #810b38;
}

button[disabled] {
  cursor: not-allowed;
  opacity: .72;
}

/* v33 form and error refinements */
.form.is-sending {
  cursor: not-allowed;
}

.form.is-sending input,
.form.is-sending select,
.form.is-sending textarea,
.form.is-sending button {
  cursor: not-allowed;
}

.form .btn.is-success {
  background: #2f6e46;
  color: #fff;
  border-color: #2f6e46;
}

.simple-error-main {
  min-height: calc(100vh - 240px);
  display: grid;
  place-items: center;
  padding: 160px 20px 80px;
}

.simple-error-section {
  width: min(720px, 100%);
  text-align: center;
}

.simple-error-section h1 {
  margin: 14px 0 12px;
  font-size: clamp(42px, 8vw, 82px);
  line-height: 0.95;
  color: #541a1a;
}

.simple-error-section p {
  max-width: 560px;
  margin: 0 auto 26px;
  color: rgba(84, 26, 26, 0.78);
  font-size: 17px;
  line-height: 1.7;
}


/* v34 public form validation colors */
.form-note.is-error {
  color: #F1E2D1;
  background: rgba(129, 11, 56, 0.22);
  border: 1px solid rgba(241, 226, 209, 0.18);
  border-radius: 12px;
  padding: 10px 12px;
}

/* v36 form success button keeps normal identity color */
.form .btn.is-done {
  background: var(--burgundy);
  color: var(--paper);
  border-color: rgba(241, 226, 209, 0.28);
}

.form .btn.is-done:hover {
  background: var(--burgundy);
  color: var(--paper);
}
