:root {
  --paper: #F6F0E7;
  --ivory: #FBF8F2;
  --ink: #2A2521;
  --green: #2F4A3D;
  --blue: #375058;
  --adobe: #C9A27E;
  --accent: #B85F38;
  --cacao: #3A2C27;
  --motion-ease: cubic-bezier(.22, .61, .36, 1);
  --motion-fast: 180ms;
  --motion-medium: 520ms;
  --motion-slow: 700ms;
  --motion-stagger: 90ms;
  --container: 1160px;
  --font-display: Fraunces, Georgia, "Times New Roman", serif;
  --font-body: "Source Sans 3", Jost, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --line-dark: rgba(42, 37, 33, .14);
  --line-light: rgba(251, 248, 242, .22);
  --muted-dark: rgba(42, 37, 33, .76);
  --muted-light: rgba(251, 248, 242, .78);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 88px;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body.is-menu-open {
  overflow: hidden;
}

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

svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

a {
  color: inherit;
  text-decoration-color: rgba(184, 95, 56, .55);
  text-decoration-thickness: .08em;
  text-underline-offset: .18em;
}

a:hover {
  color: var(--accent);
}

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

button {
  cursor: pointer;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 3px solid rgba(184, 95, 56, .42);
  outline-offset: 4px;
}

.svg-sprite {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.skip-link {
  position: absolute;
  left: 18px;
  top: -120px;
  z-index: 1000;
  padding: 12px 16px;
  border-radius: 10px;
  background: var(--ink);
  color: var(--ivory);
  text-decoration: none;
  transition: top var(--motion-fast) var(--motion-ease);
}

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

.container {
  width: min(100% - 36px, var(--container));
  margin-inline: auto;
}

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

h1,
h2,
h3 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.06;
  letter-spacing: 0;
}

h1 {
  font-size: clamp(2.4rem, 13vw, 4.35rem);
  max-width: 820px;
}

h2 {
  font-size: clamp(2rem, 8vw, 3rem);
  max-width: 780px;
}

h3 {
  font-size: clamp(1.28rem, 5vw, 1.62rem);
}

p {
  margin: 0;
  max-width: 68ch;
}

.copy-flow p + p,
.section-intro p + p {
  margin-top: 18px;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 16px;
  color: var(--accent);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}

.section-dark {
  color: var(--ivory);
}

.section-dark .eyebrow {
  color: var(--adobe);
}

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

.section-intro {
  margin-top: 18px;
  color: var(--muted-dark);
  font-size: 1.06rem;
}

.button-row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  margin-top: 30px;
}

.center-row {
  justify-content: center;
}

.button {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 12px 20px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  transition: transform var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), color var(--motion-fast) var(--motion-ease);
}

.button:hover {
  transform: translateY(-1px);
}

.button-primary {
  background: var(--accent);
  color: var(--ivory);
  box-shadow: 0 12px 24px rgba(58, 44, 39, .14);
}

.button-primary:hover {
  background: #a95131;
  color: var(--ivory);
}

.button-secondary {
  border-color: rgba(47, 74, 61, .28);
  color: var(--green);
  background: rgba(251, 248, 242, .62);
}

.button-secondary:hover {
  border-color: rgba(184, 95, 56, .5);
}

.button-green {
  background: var(--green);
  color: var(--ivory);
}

.button-green:hover {
  background: #263f34;
  color: var(--ivory);
}

.photo-card {
  overflow: hidden;
  border: 1px solid rgba(42, 37, 33, .12);
  border-radius: 30px;
  box-shadow: 0 10px 26px rgba(42, 37, 33, .055);
}

.photo-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(246, 240, 231, .82);
  border-bottom: 1px solid transparent;
  backdrop-filter: blur(18px);
  transition: background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}

.site-header.is-compact {
  background: rgba(251, 248, 242, .94);
  border-color: rgba(42, 37, 33, .12);
  box-shadow: 0 10px 30px rgba(42, 37, 33, .06);
}

.header-inner {
  width: min(100% - 28px, 1240px);
  min-height: 76px;
  display: flex;
  align-items: center;
  gap: 22px;
  margin-inline: auto;
  transition: min-height var(--motion-fast) var(--motion-ease);
}

.site-header.is-compact .header-inner {
  min-height: 64px;
}

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

.brand-mark {
  position: relative;
  display: grid;
  width: 38px;
  height: 38px;
  flex: 0 0 auto;
  place-items: center;
  border-radius: 50%;
  background: var(--green);
  color: var(--ivory);
  font-family: var(--font-display);
  font-size: .92rem;
  font-weight: 700;
  letter-spacing: 0;
}

.brand-mark span {
  position: absolute;
  right: 3px;
  bottom: 5px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
}

.brand-text {
  display: grid;
  line-height: 1.15;
}

.brand-text strong {
  font-size: .98rem;
}

.brand-text small {
  margin-top: 3px;
  color: var(--muted-dark);
  font-size: .78rem;
}

.site-nav {
  display: none;
}

.site-nav a {
  position: relative;
  color: var(--ink);
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none;
}

.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--motion-fast) var(--motion-ease);
}

.site-nav a:hover::after,
.site-nav a:focus-visible::after {
  transform: scaleX(1);
}

.header-cta {
  display: none;
}

.menu-toggle {
  display: inline-grid;
  width: 42px;
  height: 42px;
  margin-left: auto;
  place-items: center;
  border: 1px solid rgba(42, 37, 33, .16);
  border-radius: 50%;
  background: rgba(251, 248, 242, .78);
}

.menu-toggle span {
  width: 18px;
  height: 2px;
  background: var(--ink);
  transition: transform var(--motion-fast) var(--motion-ease);
}

.menu-toggle[aria-expanded="true"] span:first-child {
  transform: translateY(5px) rotate(45deg);
}

.menu-toggle[aria-expanded="true"] span:last-child {
  transform: translateY(-5px) rotate(-45deg);
}

.site-nav.is-open {
  position: fixed;
  inset: 76px 0 auto;
  display: grid;
  gap: 0;
  padding: 10px 18px 22px;
  background: var(--ivory);
  border-bottom: 1px solid var(--line-dark);
  box-shadow: 0 22px 50px rgba(42, 37, 33, .12);
}

.site-nav.is-open a {
  padding: 15px 0;
  border-bottom: 1px solid var(--line-dark);
  font-size: 1.04rem;
}

/* Hero */
.hero {
  padding-top: 56px;
}

.hero-grid {
  display: grid;
  gap: 42px;
}

.hero-copy {
  display: grid;
  align-content: center;
}

.hero-kicker {
  margin-bottom: 16px;
  color: var(--green);
  font-weight: 800;
}

.hero-lead {
  margin-top: 22px;
  color: var(--muted-dark);
  font-size: clamp(1.06rem, 2.5vw, 1.25rem);
}

.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border: 1px solid rgba(47, 74, 61, .18);
  border-radius: 999px;
  padding: 9px 13px;
  background: rgba(251, 248, 242, .7);
  color: var(--green);
  font-size: .96rem;
  font-weight: 800;
}

.pill svg {
  width: 19px;
  height: 19px;
  flex: 0 0 auto;
}

.hero-photo {
  aspect-ratio: 4 / 5;
  max-height: 660px;
}

/* Emotional section */
.emotion-grid {
  display: grid;
  gap: 32px;
}

.emotion-section .copy-flow > p:not(.eyebrow) {
  color: var(--muted-dark);
}

.emotion-section h2 {
  margin-bottom: 22px;
}

.list-card {
  padding: 28px;
  border: 1px solid var(--line-dark);
  border-radius: 24px;
  background: var(--ivory);
}

.round-icon {
  display: grid;
  width: 58px;
  height: 58px;
  margin-bottom: 20px;
  place-items: center;
  border-radius: 50%;
  background: rgba(201, 162, 126, .22);
  color: var(--green);
}

.round-icon svg {
  width: 31px;
  height: 31px;
}

.list-card h3 {
  margin-bottom: 16px;
}

.stagger-list {
  display: grid;
  gap: 13px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.stagger-list li {
  position: relative;
  padding-left: 18px;
  color: var(--muted-dark);
}

.stagger-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .72em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
}

/* Work */
.work-section {
  background: linear-gradient(180deg, var(--paper), rgba(251, 248, 242, .56));
}

.section-heading {
  display: grid;
  gap: 0;
}

.wide-copy {
  margin-top: 22px;
  color: var(--muted-dark);
  font-size: 1.05rem;
}

.wide-copy p + p {
  margin-top: 16px;
}

.work-grid {
  display: grid;
  gap: 16px;
  margin-top: 38px;
}

.work-card {
  position: relative;
  min-height: 220px;
  padding: 24px;
  border: 1px solid rgba(42, 37, 33, .12);
  border-radius: 8px;
  background: var(--ivory);
  transition: transform var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}

.work-card > span {
  display: block;
  width: 100%;
  height: 3px;
  margin-bottom: 22px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--motion-medium) var(--motion-ease);
}

.is-visible .work-card > span,
.work-card.is-visible > span {
  transform: scaleX(1);
}

.work-card h3 {
  margin-bottom: 12px;
}

.work-card p {
  color: var(--muted-dark);
}

@media (hover: hover) {
  .work-card:hover {
    border-color: rgba(184, 95, 56, .36);
    box-shadow: 0 16px 30px rgba(42, 37, 33, .055);
    transform: translateY(-3px);
  }
}

/* About */
.about-section {
  overflow: hidden;
  background: var(--green);
  padding-bottom: 0;
}

.about-grid {
  display: grid;
  gap: 32px;
  padding-bottom: 68px;
}

.about-photo {
  aspect-ratio: 4 / 5;
}

.about-copy {
  display: grid;
  align-content: center;
}

.credential-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 22px 0 24px;
  padding: 0;
  list-style: none;
}

.credential-list li {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid rgba(201, 162, 126, .34);
  border-radius: 999px;
  padding: 6px 9px;
  color: var(--ivory);
  font-size: .82rem;
  line-height: 1.25;
}

.credential-list svg {
  width: 15px;
  height: 15px;
  color: var(--adobe);
}

.about-toggle {
  width: fit-content;
  margin-top: 28px;
  border-color: rgba(251, 248, 242, .25);
  background: rgba(251, 248, 242, .08);
  color: var(--ivory);
}

.about-toggle:hover {
  background: rgba(251, 248, 242, .14);
  color: var(--ivory);
}

.about-story-shell {
  display: grid;
  grid-template-rows: 0fr;
  margin-inline: calc((100vw - min(100vw - 36px, var(--container))) / -2);
  background: var(--paper);
  color: var(--ink);
  transition: grid-template-rows 440ms var(--motion-ease);
}

.about-story-shell.is-open {
  grid-template-rows: 1fr;
}

.about-story {
  overflow: hidden;
  width: min(100% - 36px, var(--container));
  margin-inline: auto;
}

.about-story-shell.is-open .about-story {
  padding-block: 70px 76px;
}

.story-heading {
  display: grid;
  gap: 26px;
  margin-bottom: 42px;
}

.story-kicker {
  margin-bottom: 10px;
  color: var(--accent);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.story-quote {
  position: relative;
  margin: 0;
  padding: 25px;
  border: 1px solid rgba(42, 37, 33, .14);
  border-radius: 18px;
  background: rgba(251, 248, 242, .68);
  color: var(--green);
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 7vw, 2.55rem);
  line-height: 1.13;
}

.story-quote span {
  display: block;
  width: 10px;
  height: 10px;
  margin-bottom: 18px;
  border-radius: 50%;
  background: var(--accent);
}

.timeline {
  position: relative;
  display: grid;
  gap: 28px;
}

.timeline::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 6px;
  bottom: 6px;
  width: 1px;
  background: rgba(47, 74, 61, .22);
}

.timeline-item {
  position: relative;
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 18px;
}

.timeline-item > span {
  z-index: 1;
  display: grid;
  width: 38px;
  height: 38px;
  place-items: center;
  border: 1px solid rgba(47, 74, 61, .2);
  border-radius: 50%;
  background: var(--paper);
  color: var(--accent);
  font-size: .78rem;
  font-weight: 900;
}

.timeline-item h3 {
  color: var(--green);
  margin-bottom: 10px;
}

.timeline-item p {
  color: var(--muted-dark);
}

.story-note {
  margin-top: 38px;
  padding: 24px;
  border-left: 4px solid var(--accent);
  border-radius: 0 18px 18px 0;
  background: var(--ivory);
}

.story-note p:last-child {
  color: var(--muted-dark);
}

.story-cta {
  display: flex;
  justify-content: stretch;
  margin-top: 28px;
}

.story-cta .button {
  width: 100%;
}

/* Process */
.process-section {
  background: var(--ivory);
}

.steps-grid {
  display: grid;
  gap: 16px;
  margin-top: 34px;
}

.step-card {
  padding: 24px;
  border: 1px solid var(--line-dark);
  border-radius: 8px;
  background: var(--paper);
}

.step-card > span {
  display: inline-block;
  margin-bottom: 16px;
  color: var(--accent);
  font-size: .82rem;
  font-weight: 900;
  letter-spacing: .12em;
}

.step-card h3 {
  margin-bottom: 12px;
}

.step-card p {
  color: var(--muted-dark);
}

.process-line {
  display: none;
}

/* Prices */
.price-grid {
  display: grid;
  gap: 30px;
}

.price-card {
  display: grid;
  gap: 0;
  padding: 24px;
  border: 1px solid var(--line-dark);
  border-radius: 22px;
  background: var(--ivory);
}

.price-row {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px 12px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line-dark);
}

.price-row:first-child {
  padding-top: 0;
}

.price-row svg {
  width: 22px;
  height: 22px;
  color: var(--green);
}

.price-row span {
  font-weight: 800;
}

.price-row strong {
  grid-column: 2;
  color: var(--green);
  font-size: 1.02rem;
  line-height: 1.35;
}

.price-card .button {
  margin-top: 22px;
}

/* Important */
.important-section {
  background: var(--paper);
}

.urgent-box {
  display: grid;
  gap: 28px;
  padding: 28px;
  border-radius: 24px;
  background: var(--blue);
  color: var(--ivory);
}

.urgent-box p {
  color: var(--muted-light);
}

.urgent-box p + p {
  margin-top: 16px;
}

.urgent-actions {
  display: grid;
  gap: 12px;
  align-content: center;
}

.urgent-actions a {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid rgba(251, 248, 242, .18);
  border-radius: 14px;
  padding: 14px;
  color: var(--ivory);
  font-weight: 900;
  text-decoration: none;
  transition: transform var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease), border-color var(--motion-fast) var(--motion-ease);
}

.urgent-actions a:hover {
  border-color: rgba(201, 162, 126, .7);
  background: rgba(251, 248, 242, .08);
  color: var(--ivory);
  transform: translateY(-1px);
}

.urgent-actions svg {
  width: 22px;
  height: 22px;
  color: var(--adobe);
}

/* FAQ */
.faq-grid {
  display: grid;
  gap: 34px;
}

.accordion {
  display: grid;
  gap: 10px;
}

.faq-item {
  border-top: 1px solid var(--line-dark);
}

.faq-item:last-child {
  border-bottom: 1px solid var(--line-dark);
}

.faq-item button {
  position: relative;
  display: grid;
  width: 100%;
  grid-template-columns: 1fr 28px;
  gap: 18px;
  align-items: center;
  border: 0;
  padding: 18px 0;
  background: transparent;
  color: var(--ink);
  font-weight: 900;
  text-align: left;
}

.faq-item button span::before,
.faq-item button span::after {
  content: "";
  position: absolute;
  right: 4px;
  top: 50%;
  width: 16px;
  height: 2px;
  background: var(--accent);
  transition: transform var(--motion-fast) var(--motion-ease);
}

.faq-item button span::after {
  transform: rotate(90deg);
}

.faq-item button[aria-expanded="true"] span::after {
  transform: rotate(0deg);
}

.faq-panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 280ms var(--motion-ease);
}

.faq-panel > p {
  overflow: hidden;
  color: var(--muted-dark);
  opacity: 0;
  transition: opacity 240ms var(--motion-ease);
}

.faq-item button[aria-expanded="true"] + .faq-panel {
  grid-template-rows: 1fr;
}

.faq-item button[aria-expanded="true"] + .faq-panel > p {
  padding-bottom: 18px;
  opacity: 1;
}

/* Contact */
.contact-section,
.site-footer {
  background: var(--cacao);
}

.contact-grid {
  display: grid;
  gap: 32px;
}

.contact-copy p + p {
  margin-top: 18px;
}

.contact-form {
  display: grid;
  gap: 16px;
  padding: 22px;
  border: 1px solid rgba(251, 248, 242, .16);
  border-radius: 22px;
  background: rgba(251, 248, 242, .06);
}

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

.field label,
.checkbox-field {
  color: var(--ivory);
  font-weight: 800;
}

.field input,
.field textarea,
.field select {
  width: 100%;
  border: 1px solid rgba(251, 248, 242, .18);
  border-radius: 12px;
  padding: 12px 13px;
  background: rgba(251, 248, 242, .96);
  color: var(--ink);
  transition: border-color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}

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

.field input:focus,
.field textarea:focus,
.field select:focus {
  border-color: rgba(184, 95, 56, .75);
  box-shadow: 0 0 0 4px rgba(184, 95, 56, .13);
  outline: 0;
}

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

.checkbox-field {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: .95rem;
}

.checkbox-field input {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  margin-top: 5px;
  accent-color: var(--accent);
}

.checkbox-field a {
  color: var(--ivory);
}

.form-message {
  min-height: 1.65em;
  color: var(--adobe);
  font-weight: 800;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity var(--motion-fast) var(--motion-ease), transform var(--motion-fast) var(--motion-ease);
}

.form-message.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.contact-form .wpcf7 {
  width: 100%;
}

.contact-form .wpcf7-form {
  display: grid;
  gap: 16px;
}

.contact-form .wpcf7-form p {
  margin: 0;
  max-width: none;
}

.contact-form .wpcf7-form label {
  display: block;
  color: var(--ivory);
  font-weight: 800;
}

.contact-form .wpcf7-form-control-wrap {
  display: block;
  margin-top: 7px;
}

.contact-form .wpcf7 input[type="text"],
.contact-form .wpcf7 input[type="email"],
.contact-form .wpcf7 input[type="tel"],
.contact-form .wpcf7 input[type="url"],
.contact-form .wpcf7 input[type="number"],
.contact-form .wpcf7 input[type="date"],
.contact-form .wpcf7 textarea,
.contact-form .wpcf7 select {
  width: 100%;
  border: 1px solid rgba(251, 248, 242, .18);
  border-radius: 12px;
  padding: 12px 13px;
  background: rgba(251, 248, 242, .96);
  color: var(--ink);
  transition: border-color var(--motion-fast) var(--motion-ease), box-shadow var(--motion-fast) var(--motion-ease);
}

.contact-form .wpcf7 textarea {
  min-height: 112px;
  resize: vertical;
}

.contact-form .wpcf7 input:focus,
.contact-form .wpcf7 textarea:focus,
.contact-form .wpcf7 select:focus {
  border-color: rgba(184, 95, 56, .75);
  box-shadow: 0 0 0 4px rgba(184, 95, 56, .13);
  outline: 0;
}

.contact-form .wpcf7 input[type="checkbox"] {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  margin: 5px 8px 0 0;
  accent-color: var(--accent);
}

.contact-form .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
}

.contact-form .wpcf7-acceptance label {
  display: flex;
  align-items: flex-start;
  gap: 2px;
  font-size: .95rem;
}

.contact-form .wpcf7-acceptance a {
  color: var(--ivory);
}

.contact-form .wpcf7-submit {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 12px 20px;
  background: var(--accent);
  color: var(--ivory);
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
  box-shadow: 0 12px 24px rgba(58, 44, 39, .14);
  transition: transform var(--motion-fast) var(--motion-ease), background var(--motion-fast) var(--motion-ease);
}

.contact-form .wpcf7-submit:hover {
  background: #a95131;
  transform: translateY(-1px);
}

.contact-form .wpcf7-submit:disabled {
  cursor: wait;
  opacity: .7;
}

.contact-form .wpcf7-not-valid {
  border-color: rgba(184, 95, 56, .85) !important;
}

.contact-form .wpcf7-not-valid-tip {
  margin-top: 6px;
  color: var(--adobe);
  font-size: .92rem;
  font-weight: 800;
}

.contact-form .wpcf7-response-output {
  margin: 0 !important;
  border: 1px solid rgba(201, 162, 126, .5) !important;
  border-radius: 14px;
  padding: 12px 14px !important;
  color: var(--ivory);
  font-weight: 800;
}

.contact-form .wpcf7 form.sent .wpcf7-response-output {
  border-color: rgba(201, 162, 126, .8) !important;
  background: rgba(47, 74, 61, .28);
}

.contact-form .wpcf7 form.invalid .wpcf7-response-output,
.contact-form .wpcf7 form.unaccepted .wpcf7-response-output,
.contact-form .wpcf7 form.payment-required .wpcf7-response-output {
  border-color: rgba(184, 95, 56, .7) !important;
  background: rgba(184, 95, 56, .12);
}

.contact-form .wpcf7-spinner {
  margin: 0 0 0 10px;
}

.contact-form-wrapper form {
  display: grid;
  gap: 1rem;
}

.contact-form-wrapper label {
  display: grid;
  gap: .4rem;
  color: var(--ivory);
  font-size: .95rem;
  font-weight: 800;
}

.contact-form-wrapper input,
.contact-form-wrapper textarea,
.contact-form-wrapper select {
  width: 100%;
  border: 1px solid rgba(251, 248, 242, .18);
  border-radius: 16px;
  padding: .95rem 1rem;
  background: var(--ivory);
  color: var(--ink);
  font: inherit;
}

.contact-form-wrapper textarea {
  min-height: 150px;
  resize: vertical;
}

.contact-form-wrapper input:focus,
.contact-form-wrapper textarea:focus,
.contact-form-wrapper select:focus {
  border-color: var(--accent);
  outline: 2px solid rgba(184, 95, 56, .45);
  outline-offset: 2px;
}

.contact-form-wrapper .wpcf7-acceptance label {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  font-size: .9rem;
}

.contact-form-wrapper input[type="checkbox"] {
  width: auto;
  margin-top: .2rem;
  accent-color: var(--accent);
}

.contact-form-wrapper input[type="submit"] {
  width: fit-content;
  border: 0;
  border-radius: 999px;
  padding: .95rem 1.4rem;
  background: var(--accent);
  color: var(--ivory);
  cursor: pointer;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(58, 44, 39, .14);
}

.contact-form-wrapper input[type="submit"]:hover {
  background: #9F4F33;
}

.contact-form-wrapper .wpcf7-not-valid-tip,
.wpcf7-not-valid-tip {
  margin-top: .25rem;
  color: var(--adobe);
  font-size: .85rem;
  font-weight: 800;
}

.contact-form-wrapper .wpcf7-response-output,
.wpcf7-response-output {
  border-radius: 16px;
  padding: 1rem !important;
  margin: 1rem 0 0 !important;
}

/* Footer */
.site-footer {
  border-top: 1px solid rgba(251, 248, 242, .12);
  color: var(--ivory);
  padding: 36px 0;
}

.footer-grid {
  display: grid;
  gap: 24px;
}

.footer-grid p {
  color: var(--muted-light);
}

.footer-grid address,
.footer-grid nav {
  display: grid;
  gap: 8px;
  font-style: normal;
}

.footer-grid a {
  color: var(--ivory);
}

/* Legal pages */
.legal-page {
  background: var(--paper);
}

.legal-hero {
  padding-top: 70px;
}

.legal-container {
  max-width: 960px;
}

.legal-container h1 {
  color: var(--green);
  font-size: clamp(2.8rem, 9vw, 4.25rem);
}

.legal-card {
  margin-top: 34px;
  padding: 24px;
  border: 1px solid rgba(42, 37, 33, .12);
  border-radius: 18px;
  background: var(--ivory);
  box-shadow: 0 10px 26px rgba(42, 37, 33, .045);
}

.legal-block {
  padding: 24px 0;
  border-top: 1px solid rgba(42, 37, 33, .12);
}

.legal-block:first-child {
  padding-top: 0;
  border-top: 0;
}

.legal-block:last-child {
  padding-bottom: 0;
}

.legal-block h2 {
  margin-bottom: 14px;
  color: var(--green);
  font-size: clamp(1.45rem, 5vw, 2rem);
}

.legal-block p,
.legal-block address,
.legal-block li {
  color: var(--muted-dark);
}

.legal-block p + p {
  margin-top: 14px;
}

.legal-block address {
  font-style: normal;
  margin-bottom: 18px;
}

.legal-block ul {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding-left: 22px;
}

.legal-placeholder {
  color: var(--accent);
  font-weight: 800;
}

.legal-related {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding-top: 24px;
  border-top: 1px solid rgba(42, 37, 33, .12);
}

.legal-related a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(47, 74, 61, .2);
  border-radius: 999px;
  padding: 10px 15px;
  color: var(--green);
  font-weight: 900;
  text-decoration: none;
}

.legal-related a:hover {
  border-color: rgba(184, 95, 56, .45);
  color: var(--accent);
}

/* Context return */
.return-button {
  position: fixed;
  right: 16px;
  top: 50%;
  z-index: 45;
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border: 1px solid rgba(42, 37, 33, .12);
  border-radius: 50%;
  background: rgba(251, 248, 242, .86);
  color: var(--green);
  box-shadow: 0 12px 26px rgba(42, 37, 33, .12);
  backdrop-filter: blur(12px);
}

.return-button svg {
  width: 22px;
  height: 22px;
}

.return-button[hidden] {
  display: none;
}

/* Motion */
.reveal-hero,
.reveal-stack,
.reveal-card,
.about-reveal,
.story-reveal,
.reveal-step {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity var(--motion-medium) var(--motion-ease), transform var(--motion-medium) var(--motion-ease);
}

.hero-photo.reveal-hero {
  transform: translateX(18px);
}

.is-loaded .reveal-hero,
.is-visible .reveal-stack,
.is-visible .reveal-card,
.is-visible .about-reveal,
.is-visible .reveal-step,
.about-story-shell.is-open .story-reveal {
  opacity: 1;
  transform: translate(0, 0);
}

.reveal-hero:nth-child(2) {
  transition-delay: 120ms;
}

.hero-pills .reveal-hero:nth-child(1) {
  transition-delay: 220ms;
}

.hero-pills .reveal-hero:nth-child(2) {
  transition-delay: 310ms;
}

.button-row.reveal-hero {
  transition-delay: 410ms;
}

.hero-photo.reveal-hero {
  transition-duration: var(--motion-slow);
  transition-delay: 180ms;
}

.is-visible .reveal-card:nth-child(1),
.is-visible .reveal-step:nth-child(1),
.about-story-shell.is-open .story-reveal:nth-child(1) {
  transition-delay: 70ms;
}

.is-visible .reveal-card:nth-child(2),
.is-visible .reveal-step:nth-child(2),
.about-story-shell.is-open .story-reveal:nth-child(2) {
  transition-delay: 140ms;
}

.is-visible .reveal-card:nth-child(3),
.is-visible .reveal-step:nth-child(3),
.about-story-shell.is-open .story-reveal:nth-child(3) {
  transition-delay: 210ms;
}

.is-visible .reveal-card:nth-child(4),
.is-visible .reveal-step:nth-child(4),
.about-story-shell.is-open .story-reveal:nth-child(4) {
  transition-delay: 280ms;
}

.is-visible .reveal-card:nth-child(5),
.about-story-shell.is-open .story-reveal:nth-child(5) {
  transition-delay: 350ms;
}

.is-visible .reveal-card:nth-child(6),
.about-story-shell.is-open .story-reveal:nth-child(6) {
  transition-delay: 420ms;
}

.about-reveal:nth-child(1) {
  transition-delay: 60ms;
}

.about-reveal:nth-child(2) {
  transition-delay: 130ms;
}

.about-reveal:nth-child(3) {
  transition-delay: 200ms;
}

.about-reveal:nth-child(4) {
  transition-delay: 270ms;
}

.about-reveal:nth-child(5) {
  transition-delay: 340ms;
}

@media (min-width: 720px) {
  body {
    font-size: 18px;
  }

  .section {
    padding: 96px 0;
  }

  h1 {
    font-size: clamp(3.5rem, 7vw, 4.85rem);
  }

  h2 {
    font-size: clamp(2.45rem, 4.2vw, 3.25rem);
  }

  .hero-grid,
  .emotion-grid,
  .price-grid,
  .contact-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(300px, .95fr);
    align-items: center;
  }

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

  .price-row {
    grid-template-columns: 30px 1fr auto;
    align-items: center;
  }

  .price-row strong {
    grid-column: auto;
    text-align: right;
    white-space: nowrap;
  }

  .price-row:nth-child(3) strong {
    max-width: 320px;
    white-space: normal;
  }

  .urgent-box,
  .faq-grid {
    grid-template-columns: minmax(0, 1fr) minmax(300px, .9fr);
    align-items: start;
  }

  .footer-grid {
    grid-template-columns: 1.3fr .8fr .6fr;
  }
}

@media (min-width: 980px) {
  .header-inner {
    min-height: 84px;
  }

  .menu-toggle {
    display: none;
  }

  .site-nav {
    display: flex;
    align-items: center;
    gap: 18px;
    margin-left: auto;
  }

  .header-cta {
    display: inline-flex;
    min-height: 42px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 10px 15px;
    background: var(--accent);
    color: var(--ivory);
    font-size: .9rem;
    font-weight: 900;
    text-decoration: none;
  }

  .header-cta:hover {
    background: #a95131;
    color: var(--ivory);
  }

  .hero {
    min-height: calc(100vh - 84px);
    padding: 70px 0 96px;
  }

  .hero-grid,
  .about-grid {
    grid-template-columns: minmax(0, 1.03fr) minmax(360px, .8fr);
  }

  .about-grid {
    grid-template-columns: minmax(320px, .76fr) minmax(0, 1fr);
    align-items: center;
  }

  .emotion-grid {
    grid-template-columns: minmax(0, 1fr) 420px;
  }

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

  .work-section .wide-copy {
    text-align: justify;
  }

  .about-copy .copy-flow {
    text-align: justify;
  }

  .story-heading {
    grid-template-columns: minmax(260px, .72fr) minmax(0, 1fr);
    align-items: end;
  }

  .story-cta {
    justify-content: flex-end;
  }

  .story-cta .button {
    width: auto;
  }

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

  .process-section .container {
    position: relative;
  }

  .process-line {
    position: absolute;
    left: calc((100% - min(100%, var(--container))) / 2 + 12%);
    right: calc((100% - min(100%, var(--container))) / 2 + 12%);
    bottom: 180px;
    display: block;
    height: 1px;
    background: var(--accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--motion-slow) var(--motion-ease);
  }

  .process-section.is-visible .process-line {
    transform: scaleX(1);
  }

  .contact-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 30px;
  }

  .contact-form .field:nth-of-type(5),
  .contact-form .field:nth-of-type(6),
  .contact-form .field:nth-of-type(7),
  .checkbox-field,
  .contact-form .button,
  .form-message {
    grid-column: 1 / -1;
  }

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

  .contact-form .wpcf7-form p:nth-of-type(5),
  .contact-form .wpcf7-form p:nth-of-type(6),
  .contact-form .wpcf7-form p:nth-of-type(7),
  .contact-form .wpcf7-form p:has(.wpcf7-acceptance),
  .contact-form .wpcf7-form p:has(.wpcf7-submit),
  .contact-form .wpcf7-response-output {
    grid-column: 1 / -1;
  }
}

@media (max-width: 520px) {
  .brand-text small {
    display: none;
  }

  .button,
  .hero-pills .pill {
    width: 100%;
  }

  .hero-pills {
    align-items: stretch;
  }

  .section {
    padding: 68px 0;
  }

  .about-grid {
    padding-bottom: 58px;
  }

  .about-story-shell.is-open .about-story {
    padding-block: 58px;
  }

  .urgent-box,
  .list-card,
  .price-card,
  .contact-form {
    padding: 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: .001ms !important;
  }

  .reveal-hero,
  .reveal-stack,
  .reveal-card,
  .about-reveal,
  .story-reveal,
  .reveal-step {
    opacity: 1 !important;
    transform: none !important;
  }
}
/* Contact Form 7 – corrección definitiva: una sola columna */
.contact-form.contact-form-cf7,
.contact-form-wrapper.contact-form-cf7 {
  display: block !important;
  grid-template-columns: none !important;
  width: 100%;
}

.contact-form.contact-form-cf7 > .wpcf7,
.contact-form-wrapper.contact-form-cf7 > .wpcf7 {
  display: block !important;
  width: 100%;
  max-width: 100%;
}

.contact-form.contact-form-cf7 .wpcf7-form,
.contact-form-wrapper.contact-form-cf7 .wpcf7-form {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 1rem !important;
  width: 100%;
  max-width: 100%;
}

.contact-form.contact-form-cf7 .wpcf7-form p,
.contact-form-wrapper.contact-form-cf7 .wpcf7-form p,
.contact-form.contact-form-cf7 .form-field,
.contact-form-wrapper.contact-form-cf7 .form-field {
  grid-column: 1 / -1 !important;
  width: 100%;
  max-width: none;
  margin: 0;
}

.contact-form.contact-form-cf7 label,
.contact-form-wrapper.contact-form-cf7 label {
  display: grid;
  gap: 0.45rem;
  width: 100%;
  color: var(--ivory);
  font-size: 0.95rem;
  font-weight: 800;
}

.contact-form.contact-form-cf7 input,
.contact-form.contact-form-cf7 textarea,
.contact-form.contact-form-cf7 select,
.contact-form-wrapper.contact-form-cf7 input,
.contact-form-wrapper.contact-form-cf7 textarea,
.contact-form-wrapper.contact-form-cf7 select {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.contact-form.contact-form-cf7 textarea,
.contact-form-wrapper.contact-form-cf7 textarea {
  min-height: 150px;
  resize: vertical;
}

.contact-form.contact-form-cf7 .wpcf7-form-control-wrap,
.contact-form-wrapper.contact-form-cf7 .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

.contact-form.contact-form-cf7 .wpcf7-acceptance .wpcf7-list-item,
.contact-form-wrapper.contact-form-cf7 .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
}

.contact-form.contact-form-cf7 .wpcf7-acceptance label,
.contact-form-wrapper.contact-form-cf7 .wpcf7-acceptance label,
.contact-form.contact-form-cf7 .form-acceptance label,
.contact-form-wrapper.contact-form-cf7 .form-acceptance label {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  width: 100%;
  font-size: 0.9rem;
  line-height: 1.45;
}

.contact-form.contact-form-cf7 input[type="checkbox"],
.contact-form-wrapper.contact-form-cf7 input[type="checkbox"] {
  width: auto;
  min-width: 1rem;
  margin-top: 0.25rem;
  accent-color: var(--accent);
}

.contact-form.contact-form-cf7 input[type="submit"],
.contact-form-wrapper.contact-form-cf7 input[type="submit"],
.contact-form.contact-form-cf7 .wpcf7-submit,
.contact-form-wrapper.contact-form-cf7 .wpcf7-submit {
  width: fit-content;
  max-width: 100%;
}

.contact-form.contact-form-cf7 .wpcf7-response-output,
.contact-form-wrapper.contact-form-cf7 .wpcf7-response-output {
  grid-column: 1 / -1 !important;
  border-radius: 16px;
  padding: 1rem !important;
  margin: 1rem 0 0 !important;
}