/* =================================================================
   GRUPO TERRA CAPITAL — ESTILOS PRINCIPALES
   Paleta y tipografía pensadas para transmitir solidez, calidez
   y un toque editorial/premium (igual que la referencia).
   ================================================================= */

:root{
  /* --- Color --- */
  --color-cream:        #575757d2;
  --color-cream-soft:   #8f877a;
  --color-ink:          #b8a37a;     /* texto principal */
  --color-ink-soft:     #ffffff;     /* texto secundario */
  --color-dark:         #0c0c0c;     /* secciones oscuras */
  --color-dark-soft:    #1F1D17;
  --color-gold:         #ddd8d1;     /* acento bronce/dorado */
  --color-gold-soft:    #D9C6A4;
  --color-white:        #FFFFFF;
  --color-border:       rgba(33,31,27,0.12);
  --color-border-dark:  rgba(245,242,236,0.14);

  /* --- Tipografía --- */
  --font-display: "Fraunces", Georgia, serif;
  --font-body:    "Jost", "Helvetica Neue", Arial, sans-serif;

  /* --- Layout --- */
  --max-width: 1440px;
 --gutter: clamp(24px, 5vw, 96px);
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;

  --transition: 0.35s cubic-bezier(.4,0,.2,1);
}

/* =================== RESET BÁSICO =================== */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family: var(--font-body);
  background: var(--color-cream);
  color: var(--color-ink);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; background:none; border:none; }
:focus-visible{ outline:2px solid var(--color-gold); outline-offset:3px; }

.section-eyebrow{
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 14px;
}

/* =================== BOTONES =================== */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 14px 24px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 4px;
  transition: var(--transition);
  white-space: nowrap;
}
.btn--solid{
  background: var(--color-ink);
  color: var(--color-white);
}
.btn--solid:hover{ background: var(--color-gold); color:var(--color-dark); }

.btn--outline{
  border: 1px solid var(--color-border);
  color: var(--color-ink);
}
.btn--outline:hover{ background: var(--color-ink); color: var(--color-white); border-color: var(--color-ink); }

.btn--text{
  padding: 14px 0;
  color: var(--color-ink);
  border-bottom: 1px solid transparent;
}
.btn--text:hover{ color: var(--color-gold); }

/* ===== EFECTO GLASSMORPHISM ===== */
.glass{
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.25);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}

/* Versión para fondos oscuros (ej. sobre la sección de proyectos destacados) */
.glass--dark{
  background: rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}

/* =================================================================
   ENCABEZADO
   ================================================================= */
.header{
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(161, 160, 160, 0.388);
  backdrop-filter: blur(35px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.199);
  box-shadow: 0 8px 32px rgba(0,0,0,0.06);
}
.header__inner{
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 18px var(--gutter);
  display:flex;
  align-items:center;
  gap: 40px;
}

.logo{
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
}
.logo img{ width:auto; height:100px; max-width:180px; object-fit:contain; }
.logo__text{ display:flex; flex-direction:column; line-height:1.15; }
.logo__text small{
  font-size:10px;
  letter-spacing: 0.18em;
  color: var(--color-ink-soft);
  font-weight: 500;
}
.logo__text strong{
  font-family: var(--font-display);
  font-size: 18px;
  letter-spacing: 0.06em;
  color: var(--color-ink);
}

.nav{ flex:1; }
.nav__list{ display:flex; align-items:center; justify-content:flex-end; gap:40px; }
.nav__link{
  display:flex;
  align-items:center;
  gap:6px;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--color-ink);
  padding: 8px 0;
  position:relative;
}
.nav__link::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  height:1px; width:0%;
  background: var(--color-gold);
  transition: var(--transition);
}
.nav__link:hover::after{ width:100%; }
.nav__chevron{ transition: transform var(--transition); }
.nav__item--dropdown:hover .nav__chevron,
.nav__link--dropdown[aria-expanded="true"] .nav__chevron{ transform: rotate(180deg); }

.header__cta{
  flex-shrink:0;
  background: linear-gradient(135deg, #C9A566 0%, #9C7A42 100%);
  border: none;
  color: #FFFFFF !important;
  box-shadow: 0 0 20px rgba(201,165,102,0.5), 0 4px 12px rgba(0,0,0,0.2);
  animation: ctaGlow 2.5s ease-in-out infinite alternate;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

@keyframes ctaGlow{
  from{ box-shadow: 0 0 20px rgba(201,165,102,0.5), 0 4px 12px rgba(0,0,0,0.2); }
  to{ box-shadow: 0 0 32px rgba(201,165,102,0.8), 0 6px 16px rgba(0,0,0,0.3); }
}

.header__cta:hover{
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 0 40px rgba(201,165,102,0.9), 0 8px 20px rgba(0,0,0,0.35);
}

.mobile-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  padding:6px;
}
.mobile-toggle span{
  width:22px; height:2px; background:var(--color-ink); transition: var(--transition);
}

/* ---- Mega menú de proyectos ---- */
.mega-menu{
  position:absolute;
  left:0; right:0; top:100%;
  background: var(--color-dark);
  color: var(--color-white);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  padding: 36px var(--gutter) 24px;
  max-width: var(--max-width);
  margin: 0 auto;
  box-shadow: 0 30px 60px rgba(0,0,0,0.25);

  opacity:0;
  visibility:hidden;
  transform: translateY(-8px);
  transition: var(--transition);
}
.mega-menu.is-open{
  opacity:1; visibility:visible; transform:translateY(0);
}
.mega-menu__grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}
.mega-menu__item{ display:block; }
.mega-menu__icon{
  width: 34px; height:34px;
  display:flex; align-items:center; justify-content:center;
  color: var(--color-gold);
  margin-bottom: 14px;
}
.mega-menu__name{
  font-family: var(--font-display);
  font-size: 15px;
  letter-spacing: 0.04em;
  text-transform: none;
  margin-bottom: 8px;
}
.mega-menu__desc{
  font-size: 12.5px;
  color: rgba(245,242,236,0.6);
  line-height:1.5;
  margin-bottom: 16px;
  
}
.mega-menu__thumb{
  width:100%;
  aspect-ratio: 4/3;
  border-radius: var(--radius-sm);
  overflow:hidden;
}
.mega-menu__thumb img{ width:100%; height:100%; object-fit:cover; transition: transform .5s ease; }
.mega-menu__item:hover .mega-menu__thumb img{ transform: scale(1.06); }

.mega-menu__footer{
  border-top: 1px solid var(--color-border-dark);
  margin-top: 28px;
  padding-top: 18px;
  display:flex;
  justify-content:center;
}
.mega-menu__all{
  display:flex; align-items:center; gap:8px;
  font-size: 12px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
  color: var(--color-cream);
}
.mega-menu__all:hover{ color: var(--color-gold); }

/* ---- Menú móvil ---- */
/* ---- Menú móvil (drawer lateral derecho) ---- */
.mobile-nav-overlay{
  display:none;
  position: fixed;
  inset: 0;
  background: rgba(12,12,12,0.45);
  z-index: 98;
  opacity: 0;
  transition: opacity var(--transition);
}
.mobile-nav-overlay.is-open{ display:block; opacity: 1; }

.mobile-nav{
  display:flex;
  flex-direction:column;
  background: var(--color-cream);
  padding: 90px 28px 32px;

  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(320px, 82vw);
  max-width: 340px;
  z-index: 99;
  overflow-y: auto;

  transform: translateX(100%);
  transition: transform 0.4s cubic-bezier(.4,0,.2,1);
  box-shadow: -20px 0 50px rgba(0,0,0,0.2);
}
.mobile-nav.is-open{ transform: translateX(0); }

.mobile-nav__close{
  position: absolute;
  top: 22px;
  right: 24px;
  color: var(--color-ink);
  padding: 6px;
}

.mobile-nav__link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  border-bottom: 1px solid var(--color-border);
  font-size: 15px;
  width: 100%;
  text-align:left;
}

.mobile-nav__item--dropdown{ border-bottom: 1px solid var(--color-border); }
.mobile-nav__item--dropdown .mobile-nav__link{ border-bottom:none; }

.mobile-nav__chevron{ transition: transform var(--transition); }
.mobile-nav__link--dropdown[aria-expanded="true"] .mobile-nav__chevron{ transform: rotate(180deg); }

.mobile-submenu{
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition);
  display:flex;
  flex-direction:column;
}
.mobile-submenu.is-open{ max-height: 600px; padding-bottom: 12px; }
.mobile-submenu__link{
  padding: 10px 0 10px 12px;
  font-size: 13.5px;
  color: var(--color-ink-soft);
  border-left: 2px solid var(--color-border);
}
.mobile-submenu__link:hover{ color: var(--color-ink); border-left-color: var(--color-gold); }

.mobile-nav__cta{ margin-top:24px; justify-content:center; }

/* Hamburguesa -> X cuando el menú está abierto */
.mobile-toggle.is-active span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.mobile-toggle.is-active span:nth-child(2){ opacity: 0; }
.mobile-toggle.is-active span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }
/* =================================================================
   HERO
   ================================================================= */
.hero{
  display:grid;
  grid-template-columns: minmax(320px, 40%) 1fr;
  min-height: clamp(560px, 90vh, 900px);
  position:relative;
}
.hero__text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding: 60px var(--gutter);
}
.hero__eyebrow{
  display:flex; align-items:center; gap:8px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: 26px;
}
.hero__title{
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(40px, 4.6vw, 58px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  color: var(--color-ink);
}
.hero__divider{
  display:block;
  width: 56px; height:2px;
  background: var(--color-gold);
  margin: 28px 0 24px;
}
.hero__description{
  font-size: 15px;
  color: var(--color-ink-soft);
  max-width: 380px;
  margin-bottom: 38px;
}
.hero__actions{ display:flex; align-items:center; gap:32px; flex-wrap:wrap; }

.hero__media{
  position:relative;
  overflow:hidden;
}
.hero__media img{
  width:100%;
  height:130%;
  object-fit:cover;
  position:absolute;
  inset: -15% 0 auto 0;
  will-change: transform;
  transform: translate3d(0, 0, 0) scale(1.08);
}
.hero__floating-card{
  position:absolute;
  right: 32px;
  bottom: 32px;
  width: min(380px, calc(100% - 64px));
  border-radius: var(--radius-md);
  padding: 26px 28px;
  display:flex;
  align-items:center;
  gap:18px;
  cursor: pointer;
  isolation: isolate;
  overflow: hidden;

  background: linear-gradient(
    160deg,
    rgba(208, 199, 185, 0.55) 0%,
    rgba(156,122,66,0.45) 100%
  );
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.18);

  box-shadow:
    0 20px 60px -10px rgba(176,141,87,0.5),
    0 8px 24px rgba(0,0,0,0.25),
    inset 0 1px 1px rgba(255,255,255,0.25);

  transition: transform 0.5s cubic-bezier(.2,.8,.2,1), box-shadow 0.5s ease;
}
.hero__floating-card .card__icon{
  width:54px; height:54px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(6px);
  display:flex; align-items:center; justify-content:center;
  color: #FFFFFF;
  flex-shrink:0;
}
.hero__floating-card .card__tag{
  display:flex; align-items:center; gap:6px;
  font-family: var(--font-body);
  font-size: 10px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  color: #FFFFFF;
  margin-bottom: 6px;
}
.hero__floating-card .card__title{
  font-family: var(--font-display);
  font-style: normal;
  font-weight: 900;
  font-size: 22px;
  letter-spacing: -0.01em;
  line-height: 1.15;
  color: #FFFFFF;
  margin-bottom: 4px;
}
.hero__floating-card .card__subtitle{
  font-family: var(--font-body);
  font-size: 20px;
  font-weight: 300;
  color: rgba(255,255,255,0.85);
  margin-bottom: 12px;
}
.hero__floating-card .card__link{
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display:inline-flex; align-items:center; gap:6px;
  color: #FFFFFF;
  border-bottom: 1.5px solid rgba(255,255,255,0.6);
}
.hero__scroll-indicator{
  position:absolute;
  left: 26px;
  bottom: 36px;
  display:flex; align-items:center; gap:14px;
  z-index: 2;
}
.hero__scroll-indicator span{
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}
.hero__scroll-indicator::after{
  content:"";
  width:1px; height:90px;
  background: var(--color-border);
}
/* Resplandor difuso, sin bordes definidos, tipo "glow" ambiental */
.hero__floating-card::before{
  content:"";
  position:absolute;
  top:-40%; left:-20%;
  width: 140%; height:140%;
  background: radial-gradient(
    circle at 30% 20%,
    rgba(255,255,255,0.35) 0%,
    rgba(255,255,255,0.08) 30%,
    transparent 60%
  );
  filter: blur(30px);
  pointer-events: none;
  z-index: -1;
}

.hero__floating-card:hover{
  transform: translateY(-6px);
  box-shadow:
    0 28px 70px -10px rgba(176,141,87,0.65),
    0 10px 28px rgba(0,0,0,0.3),
    inset 0 1px 1px rgba(255,255,255,0.3);
}

.hero__floating-card:active{
  transform: translateY(-2px) scale(0.98);
  transition: transform 0.15s ease;
}
/* =================================================================
   PROYECTOS DESTACADOS
   ================================================================= */
.featured{
  background: var(--color-dark);
  color: var(--color-cream);
  padding: 88px var(--gutter) 100px;
}
.featured__header{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap: 40px;
  max-width: var(--max-width);
  margin: 0 auto 48px;
}
.featured__eyebrow{
  font-size: 12px; font-weight:600; letter-spacing:0.16em; text-transform:uppercase;
  color: var(--color-gold);
  margin-bottom: 16px;
}
.featured__title{
  font-family: var(--font-display);
  font-weight:400;
  font-size: clamp(28px, 3.2vw, 38px);
  line-height: 1.18;
  margin-bottom: 26px;
  color: #ffffff;
}
.featured__all-link{
  display:inline-flex; align-items:center; gap:8px;
  font-size: 12px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;
  border-bottom: 1px solid var(--color-gold);
  padding-bottom: 4px;
  color: var(--color-cream);
}
.featured__nav{ display:flex; gap:12px; flex-shrink:0; }
.featured__arrow{
  width:48px; height:48px;
  border-radius:50%;
  border:1px solid var(--color-border-dark);
  display:flex; align-items:center; justify-content:center;
  color: var(--color-cream);
  transition: var(--transition);
}
.featured__arrow:hover{ background: var(--color-gold); border-color: var(--color-gold); color: var(--color-dark); }

.featured__track{
  max-width: var(--max-width);
  margin: 0 auto;
  display:flex;
  gap: 24px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding-bottom: 4px;
}
.featured__track::-webkit-scrollbar{ display:none; }

.project-card{
  position:relative;
  flex: 0 0 clamp(240px, 23vw, 320px);
  aspect-ratio: 3/4;
  border-radius: var(--radius-md);
  overflow:hidden;
  isolation:isolate;
}
.project-card img{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  transition: transform .6s ease;
}
.project-card:hover img{ transform: scale(1.07); }
.project-card::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.78) 100%);
  z-index:1;
}
.project-card__info{
  position:absolute; left:0; right:0; bottom:0;
  z-index:2;
  padding: 22px;
}
.project-card__name{
  font-family: var(--font-display);
  font-size: 19px;
  margin-bottom: 4px;
  color: #fff4f4;
}
.project-card__category{
  font-size: 15px;
  font-weight:600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-gold-soft);
  margin-bottom: 10px;
}
.project-card__price{
  font-size: 20px;
  color: rgba(245,242,236,0.85);
}

/* =================================================================
   NOSOTROS
   ================================================================= */
.about{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:stretch;
}
.about__media{ height: 600px; overflow: hidden; }
.about__media img{ width:100%; height:100%; object-fit:cover; }
.about__content{
  display:flex; flex-direction:column; justify-content:center;
  padding: 80px var(--gutter);
}
.about__title{
  font-family: var(--font-display);
  font-weight:400;
  font-size: clamp(28px, 3vw, 36px);
  line-height:1.2;
  margin-bottom: 22px;
}
.about__text{
  font-size: 15px;
  color: var(--color-ink-soft);
  max-width: 460px;
  margin-bottom: 36px;
}
.about__stats{
  display:flex;
  gap: 40px;
  flex-wrap:wrap;
}
.about__stat{ display:flex; flex-direction:column; gap:6px; }
.about__stat .num{
  font-family: var(--font-display);
  font-size: 32px;
  color: var(--color-gold);
}
.about__stat .label{
  font-size: 11.5px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-ink-soft);
}

/* =================================================================
   FOOTER / CONTACTO
   ================================================================= */
.footer{
  background: #0c0c0c;
  color: var(--color-cream);
}
.footer__top{
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 80px var(--gutter) 56px;
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
}
.logo--footer .logo__text strong{ color: var(--color-cream); }
.logo--footer .logo__text small{ color: rgba(245,242,236,0.5); }
.footer__tagline{
  margin-top: 18px;
  font-size: 13.5px;
  color: rgba(245,242,236,0.6);
  max-width: 280px;
}
.footer__heading{
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 15px;
  margin-bottom: 18px;
  color: var(--color-gold-soft);
}
.footer__col p, .footer__col li{
  font-size: 13.5px;
  color: rgba(245,242,236,0.72);
  margin-bottom: 10px;
}
.footer__col a:hover{ color: var(--color-gold); }
.footer__social{ display:flex; gap:12px; }
.footer__social a{
  width:36px; height:36px;
  border-radius:50%;
  border:1px solid var(--color-border-dark);
  display:flex; align-items:center; justify-content:center;
}
.footer__social a:hover{ background: var(--color-gold); border-color: var(--color-gold); color: var(--color-dark); }

.footer__bottom{
  border-top: 1px solid var(--color-border-dark);
  padding: 22px var(--gutter);
  text-align:center;
  font-size: 12px;
  color: rgba(245,242,236,0.5);
}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media (max-width: 1080px){
  .mega-menu__grid{ grid-template-columns: repeat(2,1fr); row-gap: 32px; }
  .about{ grid-template-columns: 1fr; }
  .about__media{ min-height: 360px; order:-1; }
  .footer__top{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 1200px){
  .hero__title{ font-size: clamp(34px, 5vw, 50px); }
  .hero__text{ padding: 48px clamp(24px, 4vw, 64px); }
  .featured__header{ gap: 24px; }
  @media (max-width: 1200px){
  .hero__title{ font-size: clamp(34px, 5vw, 50px); }
  .hero__text{ padding: 48px clamp(24px, 4vw, 64px); }
  .featured__header{ gap: 24px; }

  .header__inner{ gap: 24px; }
  .nav__list{ gap: clamp(20px, 3vw, 36px); }
  .nav__link{ font-size: 12.5px; }
  .header__cta{ padding: 12px 18px; font-size: 11px; }
  .logo__text strong{ font-size: 16px; }
}
}
@media (max-width: 880px){
  .nav, .header__cta{ display:none; }
  .mobile-toggle{ display:flex; }
  .mega-menu{ display:none; } /* en móvil se usa el menú lateral simple */

  .hero{ grid-template-columns: 1fr; }
  .hero__media{ height: 60vh; order:-1; }
  .hero__text{ padding: 48px 24px; }
  .hero__scroll-indicator{ display:none; }

  .featured{ padding: 64px 24px 72px; }
  .featured__header{ flex-direction:column; align-items:flex-start; gap:24px; }

  .footer__top{ grid-template-columns: 1fr; padding: 56px 24px; }
}

@media (max-width: 560px){
  .header__inner{ padding: 14px 20px; }
  .hero__floating-card{ left:16px; right:16px; width:auto; }
  .project-card{ flex-basis: 78vw; }
}
/* =================================================================
   TESTIMONIOS
   ================================================================= */
.testimonials{
  padding: 88px var(--gutter) 100px;
  max-width: var(--max-width);
  margin: 0 auto;
}
.testimonials__header{ text-align:center; margin-bottom: 56px; }
.testimonials__title{
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(28px, 3.2vw, 38px);
  line-height: 1.2;
}

.testimonials__grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 28px;
}

.testimonial-card{
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 32px;
  display:flex;
  flex-direction:column;
  gap: 18px;
  transition: var(--transition);
}
.testimonial-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(33,31,27,0.08);
}

.testimonial-card__stars{
  display:flex;
  gap: 3px;
  color: var(--color-gold);
}

.testimonial-card__text{
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--color-ink);
  flex:1;
}

.testimonial-card__author{
  display:flex;
  align-items:center;
  gap: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--color-border);
}
.testimonial-card__avatar{
  width: 42px; height:42px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink:0;
}
.testimonial-card__avatar--initials{
  width: 42px; height:42px;
  border-radius: 50%;
  background: var(--color-ink);
  color: var(--color-cream);
  display:flex; align-items:center; justify-content:center;
  font-family: var(--font-display);
  font-size: 15px;
  flex-shrink:0;
}
.testimonial-card__name{ font-size: 13.5px; font-weight:600; }
.testimonial-card__project{ font-size: 12px; color: var(--color-ink-soft); }
/* =================================================================
   BADGE "VER TOUR" EN TARJETAS DE PROYECTO
   ================================================================= */
.project-card{ cursor: pointer; }

.project-card__badge{
  position:absolute; top:16px; right:16px; z-index:3;
  display:flex; align-items:center; gap:6px;
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.25);
  color:#fff;
  font-family: var(--font-body);
  font-size:10px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;
  padding:7px 14px 7px 10px;
  border-radius:20px;
  transition: var(--transition);
}
.project-card__badge svg{ flex-shrink:0; }
.project-card:hover .project-card__badge{
  background: var(--color-gold);
  color: var(--color-dark);
  border-color: var(--color-gold);
}

.featured__hint{
  font-size: 12.5px;
  color: rgba(245,242,236,0.55);
  font-style: italic;
  margin-top: -12px;
  margin-bottom: 26px;
}
/* ===============================
   FIX HEADER MÓVIL
   Menú hamburguesa al extremo derecho
================================ */

@media (max-width: 880px){
  .header__inner{
    width: 100%;
    justify-content: space-between;
    gap: 0;
  }

  .logo{
    flex: 0 1 auto;
  }

  .mobile-toggle{
    margin-left: auto;
    display: flex;
  }
}
/* ===============================
   PARALLAX FUERTE SIN ACERCAR TANTO
================================ */

.hero__media,
.about__media{
  position: relative;
  overflow: hidden;
}

.hero__media img,
.about__media img{
  position: absolute;
  inset: -14% 0 auto 0;
  width: 100%;
  height: 128%;
  object-fit: cover;
  object-position: center center;
  will-change: transform;
  transform: translate3d(0, 0, 0) scale(1.03);
}

/* Ajuste especial para la imagen de Nosotros */
/* Ajuste especial para la imagen de Nosotros - zoom out */
.about__media img{
  height: 118%;
  inset: -10% 0 auto 0;
  object-position: center center;
}
@media (max-width: 880px){
  .hero__media img,
  .about__media img{
    height: 122%;
    inset: -11% 0 auto 0;
    transform: translate3d(0, 0, 0) scale(1.02);
  }
}
.mobile-nav__link,
.mobile-nav__link--dropdown,
.mobile-nav__link--dropdown svg{
  color: var(--color-gold-soft);
}

.mobile-nav__link--dropdown svg path{
  stroke: currentColor;
}

.mobile-nav__link:focus,
.mobile-nav__link--dropdown:focus{
  outline: none;
}