/* ===== Base ===== */
:root{
  --bg:#fff; --fg:#1f2937; --muted:#6b7280; --border:#e5e7eb; --container:1200px;
  /* Burgundy */
  --burgundy-50:#f7eef1; --burgundy-100:#edd8dd; --burgundy-200:#dcb6c0;
  --burgundy-600:#7a2336; --burgundy-700:#671d2e; --burgundy-800:#541827; --burgundy-900:#3b0f1b;
  /* Sage */
  --sage-50:#f3f7f4; --sage-100:#e7efe9; --sage-200:#d7e5dc; --sage-700:#476a55;
}
html{scroll-behavior:smooth;}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--fg);background:var(--bg);}
img{max-width:100%;height:auto;display:block;}
a{color:var(--burgundy-600);text-decoration:none;} a:hover{text-decoration:underline;}
.container{max-width:var(--container);margin:0 auto;padding:0 16px;}
.center{text-align:center;} .muted{color:var(--muted);}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:8px;border:0;cursor:pointer;font-weight:600;font-size:16px;}
.btn-primary{background:var(--burgundy-600);color:#fff;} .btn-primary:hover{background:var(--burgundy-700);}
.btn-ghost{background:transparent;color:var(--fg);border:1px solid var(--border);}
.tag{display:inline-block;padding:4px 10px;border-radius:999px;background:var(--sage-100);color:var(--sage-700);font-size:14px;}

/* ===== Header ===== */
header{position:fixed;inset:0 0 auto 0;backdrop-filter:blur(8px);background:rgba(255,255,255,.9);border-bottom:1px solid var(--border);z-index:50;}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px;}
.brand{display:flex;align-items:center;gap:12px;height:32px;}
.brand-logo{width:40px;height:40px;background:url('heart.png') center/contain no-repeat;margin-right:12px;}
.brand-title{font-weight:800;letter-spacing:.2px;}
.brand-sub{font-size:12px;color:#6b7280;margin-top:-2px;}
.nav-links{display:none;gap:20px;align-items:center;}
.lang{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.lang button{padding:6px 10px;font-size:14px;border:0;background:transparent;cursor:pointer;}
.lang .is-active{background:var(--burgundy-600);color:#fff;}
.hamb{display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);background:#fff;cursor:pointer;}
.mobile-menu{display:none;border-bottom:1px solid var(--border);background:#fff;}
.mobile-menu a{display:block;padding:12px 16px;border-top:1px solid var(--border);}

/* ===== Layout ===== */
main{padding-top:72px;}
section{padding:80px 0;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
@media (max-width:900px){
  .grid-3,.grid-2{grid-template-columns:1fr;}
  .nav-links{display:none;}
}

/* Títulos */
.section-title{font-size:clamp(28px,4vw,40px);color:var(--burgundy-800);margin:0 0 12px;font-weight:800;}
.section-sub{font-size:20px;color:var(--burgundy-700);font-weight:300;margin:0 0 24px;}

/* Cards y listas */
.card{background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.06);overflow:hidden;}
.card .card-body{padding:24px;}
.list{display:grid;gap:10px;font-size:16px;color:#374151;}
.list .item{display:grid;grid-template-columns:20px 1fr;gap:10px;align-items:start;}
.list.no-bullets .item{grid-template-columns:1fr;}
.list.no-bullets .item>:first-child{display:none;}

/* ===== Hero full-screen con fondo + overlay oscuro ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;background:#000;text-align:center;}
.hero .container{position:relative;z-index:1;}
.hero::before{content:"";position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1748285098750-1d5c05968199?q=80&w=2226&auto=format&fit=crop&ixlib=rb-4.1.0&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D') center/cover no-repeat;}
.hero::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.55);}
.hero h1,.hero p.lead,.hero p.desc{color:#fff;}
.hero h1{font-size:clamp(40px,6vw,64px);margin:0 0 8px;color:#fff;}
.hero p.lead{font-size:clamp(18px,3vw,24px);margin:0 0 24px;font-weight:300;}
.hero p.desc{font-size:18px;max-width:760px;margin:0 auto 28px;line-height:1.6;}

/* About: foto vertical a la izquierda, texto a la derecha */
.about-row{
  display:grid;
  grid-template-columns:minmax(220px, 320px) 1fr; /* ancho foto flexible */
  gap:24px;
  align-items:stretch; /* ambos lados a la misma altura */
}

.about-portrait{
  width:100%;
  height:100%;        /* llena la altura del bloque */
  object-fit:cover;   /* recorta sin deformar */
  border-radius:12px;
}

/* ritmo y márgenes del texto */
.about-text h4{ margin:0 0 10px; }
.about-text p{ margin:0 0 16px; line-height:1.7; }
.about-text blockquote{ margin:20px 0 0; }

/* un poco más de aire interno en la card */
.card .card-body{ padding:28px; }

/* Mobile: apilar, y dar altura fija a la foto */
@media (max-width: 900px){
  .about-row{ grid-template-columns:1fr; }
  .about-portrait{ height:340px; } /* mantiene presencia sin aire extra */
}

/* About: mejor padding del título y alineación fina */
.about-row{ gap: 28px; }                /* un poco más de aire lateral */
.about-text{ padding-top: 10px; }       /* baja el título un toque */
.about-text h4{
  margin: 2px 0 14px;                   /* margen superior leve, buen espacio abajo */
  line-height: 1.1;
}

@media (max-width: 900px){
  .about-text{ padding-top: 6px; }      /* en mobile un poco menos */
}

/* ===== CTA destacado ===== */
.highlight-cta{background:linear-gradient(to bottom,#fff7f7,#fff);padding:80px 0;}
.cta-box{background:#fff0f0;border:2px solid var(--burgundy-200);border-radius:16px;padding:48px 32px;max-width:700px;margin:0 auto;box-shadow:0 8px 20px rgba(0,0,0,.08);}
.cta-box .btn-lg{font-size:18px;padding:14px 32px;}

/* Form */
.form-group{margin-bottom:14px;}
label{display:block;font-size:14px;margin-bottom:6px;}
input,textarea{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--border);font-size:14px;}
textarea{min-height:120px;resize:vertical;}

/* Footer */
footer{background:var(--burgundy-900);color:#fff;padding:48px 0;}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr;}}
.footer small,.footer a{color:#e5d6db;}

/* Reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease;}
.reveal.is-visible{opacity:1;transform:translateY(0);}

/* Utils */
.mt-8{margin-top:32px;} .mb-8{margin-bottom:32px;} .mb-16{margin-bottom:48px;}
.py-0{padding-top:0;padding-bottom:0;}
.bg-sage{background:var(--sage-50);} .bg-burgundy-soft{background:var(--burgundy-50);}

/* Right actions wrapper next to the hamburger */
.top-actions{
  display:flex;
  align-items:center;
  gap:12px;
}

/* Language pill nicer spacing */
.lang{
  display:inline-flex;
  align-items:center;
  gap:0;
  padding:2px;                 /* soft inner padding */
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
}
.lang button{
  padding:6px 12px;            /* comfy click area */
  font-size:14px;
  line-height:1;
  border:0;
  background:transparent;
  cursor:pointer;
}
.lang button:not(.is-active):hover{background:var(--burgundy-50);}
.lang .is-active{background:var(--burgundy-600);color:#fff;border-radius:8px;}