/* ============================================================
   EGGO Digital — Páginas interiores (Proyectos · Blog · Artículo)
   Sigue el layout de Bloom: header con título gigante + filas de cards
   ============================================================ */

/* ---------- Header de página interior ---------- */
.ph {
  display: flex;
  flex-direction: column;
  gap: 22px;
  padding: clamp(40px, 6vw, 72px) clamp(28px, 5vw, 56px) clamp(32px, 4vw, 48px);
}
.ph-row { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; }
.ph-title { font-weight: 600; letter-spacing: -0.045em; line-height: 0.9; margin: 0; font-size: clamp(64px, 11vw, 150px); }
.ph-title em { font-family: var(--serif); font-style: italic; font-weight: 200; }
.ph-aside { display: flex; flex-direction: column; gap: 20px; align-items: flex-end; max-width: 360px; text-align: right; }
.ph-aside .lead { text-align: right; }

/* ---------- Proyectos / Casos ---------- */
.cases { display: flex; flex-direction: column; gap: var(--gap); }
.cases-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
.case-card {
  position: relative;
  border-radius: var(--r-card);
  overflow: hidden;
  background: var(--white);
  border: 1px solid var(--line);
  padding: 8px;
  display: flex;
  flex-direction: column;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.case-card:hover { transform: translateY(-5px); box-shadow: 0 22px 50px rgba(14,15,21,.10); }
.case-card.tall .case-img { aspect-ratio: 1 / 1.04; }
.case-img {
  position: relative;
  border-radius: 9px;
  overflow: hidden;
  aspect-ratio: 1 / 0.92;
  background: var(--cloud);
}
.case-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.case-card:hover .case-img img { transform: scale(1.04); }
.case-img .veil { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(8,9,13,.55)); }
.case-img .badge-cat {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  display: inline-flex; align-items: center; gap: 8px;
  height: 34px; padding: 0 14px; border-radius: 100px;
  background: rgba(255,255,255,.92); backdrop-filter: blur(8px);
  font-size: 13px; font-weight: 600; letter-spacing: .02em; color: var(--ink);
}
.case-img .badge-cat .d { width: 9px; height: 9px; border-radius: 50%; background: var(--c); }
.case-img .ov-title {
  position: absolute; left: 18px; bottom: 16px; z-index: 2; right: 18px;
  color: #fff; font-size: clamp(22px, 2vw, 30px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.02;
}
.case-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 10px 8px;
}
.case-foot .nm { font-size: 17px; font-weight: 600; letter-spacing: -0.02em; }
.case-foot .nm .sub { font-family: var(--serif); font-style: italic; font-weight: 200; color: var(--t-muted); font-size: 16px; margin-left: 8px; }
.case-foot .yr { font-size: 15px; color: var(--t-muted); }

/* metric band */
.metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.metric { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); padding: 40px; display: flex; flex-direction: column; gap: 8px; }
.metric .big { font-size: clamp(48px, 5vw, 76px); font-weight: 600; letter-spacing: -0.04em; line-height: 1; color: var(--c); }
.metric .lbl { font-size: 16px; color: var(--t-muted); line-height: 1.4; max-width: 26ch; }

/* ---------- Blog / Diario ---------- */
.feat {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 0;
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--r-card); overflow: hidden;
}
.feat .img { position: relative; min-height: 440px; background: var(--cloud); }
.feat .img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.feat .body { padding: clamp(32px, 4vw, 56px); display: flex; flex-direction: column; justify-content: center; gap: 22px; }
.feat .bcat { display: inline-flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--t-muted); }
.feat .bcat .d { width: 9px; height: 9px; border-radius: 50%; background: var(--c); }
.feat h2 { font-size: clamp(30px, 3.4vw, 48px); font-weight: 600; letter-spacing: -0.035em; line-height: 1.0; margin: 0; }
.feat .ex { font-size: 17px; line-height: 1.55; color: var(--t-muted); max-width: 46ch; }
.feat .by { display: flex; align-items: center; gap: 12px; margin-top: 8px; }
.feat .by img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; object-position: 30% 24%; }
.feat .by .n { font-size: 15px; font-weight: 600; }
.feat .by .r { font-size: 14px; color: var(--t-muted); }

.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.post-card {
  background: var(--white); border: 1px solid var(--line);
  border-radius: var(--r-card); overflow: hidden;
  display: flex; flex-direction: column; padding: 8px;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.post-card:hover { transform: translateY(-5px); box-shadow: 0 22px 50px rgba(14,15,21,.10); }
.post-card .ph-img { position: relative; border-radius: 9px; overflow: hidden; aspect-ratio: 1 / 0.66; background: var(--cloud); }
.post-card .ph-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.post-card:hover .ph-img img { transform: scale(1.04); }
.post-card .ph-img .tag {
  position: absolute; top: 14px; left: 14px;
  display: inline-flex; align-items: center; gap: 7px;
  height: 30px; padding: 0 12px; border-radius: 100px;
  background: rgba(255,255,255,.92); backdrop-filter: blur(8px);
  font-size: 12px; font-weight: 600; color: var(--ink);
}
.post-card .ph-img .tag .d { width: 8px; height: 8px; border-radius: 50%; background: var(--c); }
.post-card .pc-body { padding: 18px 12px 14px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.post-card .pc-date { font-size: 13px; color: var(--t-muted); }
.post-card .pc-title { font-size: 21px; font-weight: 600; letter-spacing: -0.025em; line-height: 1.12; }
.post-card .pc-read { margin-top: auto; font-size: 14px; font-weight: 600; color: var(--accent); display: inline-flex; align-items: center; gap: 7px; }

/* ---------- Artículo ---------- */
.art-hero { display: flex; flex-direction: column; align-items: center; gap: 36px; padding: clamp(40px,5vw,64px) clamp(20px,4vw,40px) 8px; text-align: center; }
.art-meta { display: inline-flex; align-items: center; gap: 14px; font-size: 14px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--t-muted); }
.art-meta .d { width: 10px; height: 10px; border-radius: 50%; background: var(--c); }
.art-title { max-width: 16ch; font-size: clamp(40px, 5.6vw, 76px); font-weight: 600; letter-spacing: -0.04em; line-height: 0.98; margin: 0; }
.art-title em { font-family: var(--serif); font-style: italic; font-weight: 200; }
.art-sub { max-width: 52ch; font-family: var(--serif); font-style: italic; font-weight: 200; font-size: clamp(20px, 2.2vw, 28px); line-height: 1.3; color: var(--t-muted); margin: 0; }
.art-byline { display: flex; align-items: center; gap: 12px; }
.art-byline img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; object-position: 30% 24%; }
.art-byline .n { font-size: 15px; font-weight: 600; text-align: left; }
.art-byline .r { font-size: 14px; color: var(--t-muted); text-align: left; }
.art-cover { width: 100%; border-radius: var(--r-card); overflow: hidden; aspect-ratio: 16/8.4; background: var(--cloud); position: relative; margin-top: 12px; }
.art-cover img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

.art-body { max-width: 720px; margin: 0 auto; padding: clamp(40px,5vw,72px) 24px; display: flex; flex-direction: column; gap: 30px; }
.art-body .statement { font-size: clamp(26px, 2.8vw, 34px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.08; }
.art-body p { font-size: 18px; line-height: 1.62; color: #2c2f38; margin: 0; }
.art-body p .em { font-weight: 600; color: var(--t-ink); }
.art-body h3 { font-size: 26px; font-weight: 600; letter-spacing: -0.02em; margin: 16px 0 0; }
.art-quote {
  position: relative;
  border-radius: var(--r-card);
  background: var(--ink);
  color: #fff;
  padding: clamp(40px,5vw,64px);
  overflow: hidden;
}
.art-quote .qmesh { position: absolute; width: 460px; height: 460px; border-radius: 50%; filter: blur(70px); right: -120px; top: -140px; background: var(--c); opacity: .55; }
.art-quote .topo { position: absolute; inset: 0; color: #fff; opacity: .07; background-size: cover; }
.art-quote p { position: relative; z-index: 2; font-family: var(--serif); font-style: italic; font-weight: 200; font-size: clamp(26px, 3vw, 40px); line-height: 1.16; color: #fff; }
.art-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); }
.art-stats.four { grid-template-columns: repeat(4, 1fr); }
.art-stats .s { background: var(--cream); border-radius: var(--r-card); padding: 28px; }
.art-stats .s .big { font-size: clamp(40px, 4.4vw, 60px); font-weight: 600; letter-spacing: -0.04em; line-height: 1; color: var(--c); }
.art-stats .s .lbl { font-size: 14.5px; color: var(--t-muted); line-height: 1.4; margin-top: 8px; }
.art-fig { border-radius: var(--r-card); overflow: hidden; aspect-ratio: 16/9; position: relative; background: var(--cloud); }
.art-fig img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.art-fig .cap { position: absolute; bottom: 0; left: 0; right: 0; z-index: 2; padding: 18px 22px; color: #fff; font-size: 14px; background: linear-gradient(180deg, transparent, rgba(8,9,13,.7)); }

.art-turno { background: var(--cream); border-radius: var(--r-card); padding: clamp(32px,4vw,52px); display: flex; flex-direction: column; gap: 24px; }
.art-turno .lbl { font-size: 13px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); display: inline-flex; align-items: center; gap: 10px; }
.art-turno .lbl .d { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); }
.art-turno ol { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 18px; counter-reset: q; }
.art-turno li { display: flex; gap: 18px; align-items: flex-start; }
.art-turno li .n { font-weight: 700; font-size: 28px; color: var(--accent); line-height: 1; flex: none; }
.art-turno li .t { font-size: 20px; line-height: 1.34; letter-spacing: -0.01em; }

.art-nav { display: flex; justify-content: space-between; gap: 24px; border-top: 1px solid var(--line); padding-top: 32px; }
.art-nav a { display: flex; flex-direction: column; gap: 8px; max-width: 46%; }
.art-nav .dir { font-size: 13px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--t-muted); }
.art-nav .t { font-size: 17px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.2; }
.art-nav a:hover .t { color: var(--accent); }
.art-nav .next { text-align: right; align-items: flex-end; margin-left: auto; }

.art-share { display: flex; align-items: center; gap: 14px; justify-content: center; padding-top: 8px; }
.art-share span { font-size: 14px; color: var(--t-muted); }

/* ============================================================
   About / Nosotros
   ============================================================ */
.about-hero { position: relative; overflow: hidden; }
.about-hero .mesh { position: absolute; border-radius: 50%; filter: blur(80px); opacity: calc(0.22 + var(--grad)*0.2); pointer-events: none; }
.about-hero .ph { position: relative; z-index: 3; }
.about-portrait { position: relative; z-index: 2; margin: 0 8px 8px; border-radius: var(--r-card); overflow: hidden; aspect-ratio: 16/8.6; background: var(--cloud); }
.about-portrait img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }

/* statement / claim block over image */
.claim-block { position: relative; overflow: hidden; border-radius: var(--r-block); aspect-ratio: 16/8.2; display: flex; align-items: center; justify-content: center; }
.claim-block img.cover { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.claim-block .scrim { position: absolute; inset: 0; background: radial-gradient(120% 120% at 50% 40%, rgba(14,15,21,.28), rgba(14,15,21,.72)); z-index: 2; }
.claim-block .claim { position: relative; z-index: 3; color: #fff; text-align: center; max-width: 18ch; font-size: clamp(34px,5vw,68px); font-weight: 600; letter-spacing: -0.035em; line-height: .98; }
.claim-block .claim em { font-family: var(--serif); font-style: italic; font-weight: 200; }

/* mosaic — la cordada (ambiental) */
.cordada { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; gap: var(--gap); margin-top: 36px; }
.cordada .m { position: relative; overflow: hidden; border-radius: var(--r-card); background: var(--cloud); }
.cordada .m img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.cordada .m:hover img { transform: scale(1.05); }
.cordada .m.w2 { grid-column: span 2; }
.cordada .m.h2 { grid-row: span 2; }
.cordada .m.tag::after { content: attr(data-tag); position: absolute; left: 14px; bottom: 14px; z-index: 2; color: #fff; font-size: 14px; font-weight: 600; letter-spacing: -0.01em; text-shadow: 0 1px 12px rgba(0,0,0,.5); }
.cordada .m.tag::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(8,9,13,.6)); z-index: 1; }

/* valores / manifiestos */
.valores { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); margin-top: 40px; }
.valor { position: relative; overflow: hidden; background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); padding: 34px; display: flex; flex-direction: column; gap: 16px; min-height: 250px; transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.valor:hover { transform: translateY(-4px); box-shadow: 0 22px 50px rgba(14,15,21,.08); }
.valor .vnum { font-size: 13px; font-weight: 600; letter-spacing: .1em; color: var(--c); }
.valor .vrule { height: 4px; width: 56px; border-radius: 3px; background: var(--c); }
.valor .vt { font-size: clamp(22px,2vw,28px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; margin-top: auto; }
.valor .vd { font-size: 15px; line-height: 1.5; color: var(--t-muted); }

/* Play to Scale steps */
.method { display: grid; grid-template-columns: 360px 1fr; gap: var(--gap); margin-top: 8px; }
.method .intro { background: var(--ink); color: #fff; border-radius: var(--r-card); padding: 40px; position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; gap: 40px; }
.method .intro .topo { position: absolute; inset: 0; color: #fff; opacity: .08; background-size: cover; }
.method .intro > * { position: relative; z-index: 2; }
.method .intro .mt { font-size: clamp(30px,3vw,42px); font-weight: 600; letter-spacing: -0.03em; line-height: 1; }
.method .intro .mt em { font-family: var(--serif); font-style: italic; font-weight: 200; }
.method .intro .md { font-size: 15.5px; line-height: 1.5; color: var(--t-muted-dark); }
.method .steps { display: flex; flex-direction: column; gap: var(--gap); }
.method .step { display: grid; grid-template-columns: 56px 1fr; gap: 22px; align-items: center; background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); padding: 24px 28px; transition: background .25s var(--ease); }
.method .step:hover { background: var(--cream); }
.method .step .sn { font-weight: 700; font-size: 26px; letter-spacing: -0.03em; color: var(--c); }
.method .step .st { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; }
.method .step .sd { font-size: 14.5px; color: var(--t-muted); line-height: 1.4; margin-top: 3px; }

@media (max-width: 900px) {
  .valores { grid-template-columns: 1fr; }
  .cordada { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 160px; }
  .cordada .m.w2 { grid-column: span 2; }
  .method { grid-template-columns: 1fr; }
}

/* ============================================================
   Contacto
   ============================================================ */
.contact { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
.contact-form { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); padding: clamp(28px,4vw,48px); display: flex; flex-direction: column; gap: 20px; }
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 13px; font-weight: 600; letter-spacing: .02em; color: var(--t-ink); }
.field input, .field textarea, .field select {
  font-family: var(--sans); font-size: 16px; color: var(--t-ink);
  background: var(--paper); border: 1px solid var(--line); border-radius: 10px;
  padding: 14px 16px; outline: none; transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent); }
.field textarea { resize: vertical; min-height: 120px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.disc-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.disc-pill { display: inline-flex; align-items: center; gap: 8px; padding: 9px 14px; border-radius: 100px; border: 1px solid var(--line); font-size: 13.5px; font-weight: 500; cursor: pointer; user-select: none; transition: border-color .2s, background .2s; }
.disc-pill .d { width: 9px; height: 9px; border-radius: 50%; background: var(--c); }
.disc-pill input { display: none; }
.disc-pill.on, .disc-pill:hover { border-color: var(--c); background: color-mix(in srgb, var(--c) 10%, transparent); }

.contact-side { display: flex; flex-direction: column; gap: var(--gap); }
.contact-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); padding: 32px; display: flex; flex-direction: column; gap: 14px; }
.contact-card.dark { background: var(--ink); color: #fff; position: relative; overflow: hidden; }
.contact-card.dark .topo { position: absolute; inset: 0; color: #fff; opacity: .08; background-size: cover; }
.contact-card.dark > * { position: relative; z-index: 2; }
.contact-card .cc-lbl { font-size: 13px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--t-muted); display: inline-flex; align-items: center; gap: 10px; }
.contact-card.dark .cc-lbl { color: var(--t-muted-dark); }
.contact-card .cc-lbl .d { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); }
.contact-card .cc-big { font-size: clamp(22px,2.2vw,30px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; }
.contact-card a.cc-link { font-size: 19px; font-weight: 600; letter-spacing: -0.02em; color: var(--accent); }
.contact-card.dark a.cc-link { color: #fff; }
.contact-card .cc-row { display: flex; flex-direction: column; gap: 4px; }
.contact-card .cc-row .k { font-size: 13px; color: var(--t-muted); }
.contact-card.dark .cc-row .k { color: var(--t-muted-dark); }
.contact-card .cc-row .v { font-size: 17px; font-weight: 500; }

/* mapa estilizado de Santander */
.map { position: relative; overflow: hidden; border-radius: var(--r-card); aspect-ratio: 16/9; background: #dfe6ea; border: 1px solid var(--line); }
.map .pin { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-100%); z-index: 3; }
.map .pin .dot { width: 22px; height: 22px; border-radius: 50%; background: var(--accent); border: 4px solid #fff; box-shadow: 0 4px 14px rgba(14,15,21,.3); }
.map .pin .pulse { position: absolute; left: 50%; top: 11px; transform: translate(-50%,-50%); width: 22px; height: 22px; border-radius: 50%; background: var(--accent); opacity: .35; animation: pulse 2.4s var(--ease) infinite; }
@keyframes pulse { to { transform: translate(-50%,-50%) scale(3.4); opacity: 0; } }
.map .lbl { position: absolute; left: 16px; bottom: 14px; z-index: 3; background: rgba(255,255,255,.94); border-radius: 10px; padding: 10px 14px; font-size: 14px; font-weight: 500; box-shadow: 0 6px 18px rgba(14,15,21,.12); }

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

@media (max-width: 900px) {
  .cases-row, .metrics, .posts-grid, .art-stats { grid-template-columns: 1fr; }
  .art-stats.four { grid-template-columns: 1fr 1fr; }
  .feat { grid-template-columns: 1fr; }
  .ph-aside { align-items: flex-start; text-align: left; max-width: none; }
  .ph-aside .lead { text-align: left; }
}
@media (max-width: 600px) {
  .posts-grid { grid-template-columns: 1fr; }
  .art-stats.four { grid-template-columns: 1fr; }
}

/* ===================== SERVICIOS ===================== */
.serv-hero { position: relative; overflow: hidden; }
.serv-hero { padding: clamp(36px, 6vw, 104px) clamp(28px, 6vw, 112px); }
.serv-hero-grid {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 1.05fr 0.9fr;
  gap: clamp(32px, 6vw, 80px); align-items: center;
}
.serv-hero-text .ph-title {
  margin: 14px 0 20px;
  font-size: clamp(38px, 5.2vw, 72px);
  line-height: 0.98;
}
.serv-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.serv-hero-img {
  border-radius: var(--r-lg, 22px); overflow: hidden;
  box-shadow: 0 30px 70px rgba(14,15,21,0.18);
  aspect-ratio: 4 / 5; max-height: 560px; margin: 0 auto;
  width: 100%; background: var(--cloud);
}
.serv-hero-img img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }

/* Deep-dive filas de servicio */
.serv-list { display: flex; flex-direction: column; gap: clamp(28px, 4vw, 56px); margin-top: 48px; }
.serv-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 4vw, 56px); align-items: center;
}
.serv-row.alt .serv-row-img { order: 2; }
.serv-row-img {
  border-radius: 20px; overflow: hidden; aspect-ratio: 3 / 2;
  background: var(--cloud); box-shadow: 0 18px 44px rgba(14,15,21,0.10);
}
.serv-row-img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s var(--ease); }
.serv-row:hover .serv-row-img img { transform: scale(1.04); }
.serv-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-weight: 600; font-size: 14px; letter-spacing: -0.01em;
  color: var(--c); text-transform: none;
}
.serv-tag .d { width: 10px; height: 10px; border-radius: 50%; background: var(--c); }
.serv-name {
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(28px, 3.4vw, 44px); line-height: 1.05; margin: 10px 0 12px;
}
.serv-desc { font-size: 17px; line-height: 1.55; color: var(--t-ink); max-width: 48ch; }
.serv-incl {
  list-style: none; padding: 0; margin: 18px 0 16px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px 20px;
}
.serv-incl li { position: relative; padding-left: 22px; font-size: 15px; color: var(--t-muted); line-height: 1.4; }
.serv-incl li::before {
  content: ""; position: absolute; left: 0; top: 7px;
  width: 11px; height: 11px; border-radius: 50%;
  background: var(--c); opacity: .85;
}
.serv-out { font-size: 15.5px; line-height: 1.5; color: var(--t-ink); border-left: 3px solid var(--c); padding-left: 14px; }
.serv-out strong { font-weight: 700; }

/* Customer journey */
.journey {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 14px; margin-top: 44px;
}
.jph {
  position: relative; background: var(--white); border: 1px solid var(--line);
  border-radius: 16px; padding: 18px 16px; display: flex; flex-direction: column; gap: 8px;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.jph:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(14,15,21,0.08); }
.jnum {
  width: 34px; height: 34px; border-radius: 50%; background: var(--ink); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--sans); font-weight: 700; font-size: 15px;
}
.jph .jt { font-weight: 700; font-size: 15.5px; letter-spacing: -0.02em; line-height: 1.15; }
.jph .jd { font-size: 13px; line-height: 1.4; color: var(--t-muted); }

.curve-wrap { margin-top: 40px; }
.curve-cap {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 8px;
  font-size: 13px; font-weight: 600; color: var(--t-muted); text-transform: uppercase; letter-spacing: .06em;
}
.curve-cap .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); display: inline-block; }
.curve { width: 100%; height: auto; display: block; }
.curve .cpt circle { fill: var(--ink); }
.curve .clbl text { font-family: var(--sans); font-size: 17px; font-weight: 600; fill: var(--t-ink); text-anchor: middle; }

@media (max-width: 900px) {
  .serv-hero-grid { grid-template-columns: 1fr; }
  .serv-hero-img { aspect-ratio: 16 / 11; max-height: 420px; }
  .serv-row, .serv-row.alt { grid-template-columns: 1fr; }
  .serv-row.alt .serv-row-img { order: 0; }
  .serv-incl { grid-template-columns: 1fr; }
  .journey { grid-template-columns: repeat(2, 1fr); }
  .curve .clbl text { font-size: 22px; }
}

/* ===================== NOSOTROS · EL FUNDADOR ===================== */
.founder { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(28px, 5vw, 72px); align-items: center; }
.founder-img {
  position: relative; border-radius: var(--r-card, 22px); overflow: hidden;
  aspect-ratio: 4 / 5; max-height: 600px; background: var(--cloud);
  box-shadow: 0 30px 70px rgba(14,15,21,0.18);
}
.founder-img img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.founder-badge {
  position: absolute; left: 16px; bottom: 16px; z-index: 2;
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.92); backdrop-filter: blur(8px);
  padding: 9px 14px; border-radius: var(--r-pill);
  font-size: 13px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink);
}
.founder-badge .d { width: 9px; height: 9px; border-radius: 50%; background: var(--accent); }
.founder-body { display: flex; flex-direction: column; gap: 18px; }
.founder-role { font-family: var(--serif); font-style: italic; font-weight: 200; font-size: 20px; color: var(--t-muted); }
.founder-quote {
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(22px, 2.6vw, 32px); line-height: 1.25; margin: 6px 0;
  border-left: 3px solid var(--accent); padding-left: 18px;
}
.founder-sign { font-weight: 700; letter-spacing: -0.02em; }
.founder-sign span { display: block; font-weight: 500; font-size: 14px; color: var(--t-muted); letter-spacing: 0; }
@media (max-width: 900px) {
  .founder { grid-template-columns: 1fr; }
  .founder-img { max-height: 460px; aspect-ratio: 4/3; }
}

/* ===================== CASOS (índice estilo Wolff Olins, oscuro) ===================== */
.casos-intro { position: relative; overflow: hidden; }
.casos-intro-inner { position: relative; z-index: 2; max-width: 920px; display: flex; flex-direction: column; gap: 22px; }
.casos-intro .display { color: var(--t-on-dark); }
.casos-intro .lead { max-width: 60ch; }

.kases { display: flex; flex-direction: column; gap: var(--gap); }
.kases-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }

.kase {
  position: relative; display: flex; flex-direction: column;
  background: var(--ink-card); border: 1px solid var(--line-dark);
  border-radius: var(--r-block); overflow: hidden;
  color: var(--t-on-dark);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
a.kase:hover { transform: translateY(-6px); border-color: rgba(255,255,255,0.28); box-shadow: 0 30px 70px rgba(0,0,0,0.5); }

.kase-media { position: relative; overflow: hidden; aspect-ratio: 16/9; background: #06070b; }
.kase-feature .kase-media { aspect-ratio: 16/7.4; }
.kase-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
a.kase:hover .kase-media img { transform: scale(1.05); }
.kase-media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,9,13,0) 45%, rgba(8,9,13,.55)); }

.kase-cat {
  position: absolute; left: 16px; top: 16px; z-index: 2;
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(8,9,13,0.6); backdrop-filter: blur(8px);
  padding: 8px 13px; border-radius: var(--r-pill);
  font-size: 12.5px; font-weight: 600; letter-spacing: .01em; color: #fff;
}
.kase-cat .d { width: 9px; height: 9px; border-radius: 50%; background: var(--c); }
.kase-go {
  position: absolute; right: 16px; bottom: 16px; z-index: 2;
  display: inline-flex; align-items: center; gap: 7px;
  background: #fff; color: var(--ink);
  padding: 9px 15px; border-radius: var(--r-pill);
  font-size: 13.5px; font-weight: 600;
  opacity: 0; transform: translateY(8px); transition: opacity .3s var(--ease), transform .3s var(--ease);
}
a.kase:hover .kase-go { opacity: 1; transform: translateY(0); }

.kase-body { padding: clamp(22px, 2.6vw, 34px); display: flex; flex-direction: column; gap: 12px; }
.kase-claim {
  margin: 0; font-weight: 600; letter-spacing: -0.035em; line-height: 1.0;
  font-size: clamp(24px, 2.6vw, 38px); color: var(--t-on-dark);
}
.kase-feature .kase-claim { font-size: clamp(30px, 4.4vw, 60px); }
.kase-claim em { font-family: var(--serif); font-style: italic; font-weight: 200; }
.kase-client { font-size: 15px; color: var(--t-muted-dark); letter-spacing: -0.01em; }
.kase-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.kase-tags span {
  font-size: 12.5px; font-weight: 500; color: var(--t-on-dark);
  border: 1px solid var(--line-dark); border-radius: var(--r-pill); padding: 6px 12px;
}
.kase-feature { display: grid; grid-template-columns: 1.25fr 1fr; align-items: stretch; }
.kase-feature .kase-media { aspect-ratio: auto; height: 100%; min-height: 340px; }
.kase-feature .kase-body { justify-content: center; }

/* Próximamente */
.kase-soon { opacity: .72; }
.kase-soon .kase-media img { filter: grayscale(0.7); }
.kase-soon-flag {
  position: absolute; right: 16px; top: 16px; z-index: 2;
  background: rgba(255,255,255,0.14); border: 1px solid var(--line-dark); color: #fff;
  padding: 7px 13px; border-radius: var(--r-pill); font-size: 12px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
}

@media (max-width: 900px) {
  .kases-grid { grid-template-columns: 1fr; }
  .kase-feature { grid-template-columns: 1fr; }
  .kase-feature .kase-media { min-height: 0; aspect-ratio: 16/9; }
}

/* Casos — subsección Próximamente */
.casos-soon-head { margin: clamp(30px, 5vw, 60px) 8px 4px; display: flex; flex-direction: column; gap: 12px; }
.casos-soon-head .display { color: var(--t-on-dark); }
.casos-soon-head .lead { max-width: 62ch; }

/* ===================== SUMMIT (home de sección) ===================== */
/* Subtítulo de bloques del think tank */
.summit-eyebrow { flex-wrap: wrap; }

/* Claim de 3 líneas (negrita · cursiva · pequeño) — usado en el bloque azul */
.summit-claim { display: flex; flex-direction: column; gap: 1px; }
.summit-claim .sc-bold { font-size: clamp(26px, 3.2vw, 42px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.08; color: #fff; }
.summit-claim .sc-italic { font-family: var(--serif); font-style: italic; font-weight: 200; font-size: clamp(26px, 3.2vw, 42px); line-height: 1.08; color: rgba(255,255,255,0.82); }
.summit-claim .sc-small { font-size: 17px; line-height: 1.5; color: rgba(255,255,255,0.82); max-width: 48ch; margin-top: 14px; }

/* Intro — qué es */
.summit-intro {
  display: grid; grid-template-columns: 1fr 1.05fr;
  gap: clamp(28px, 5vw, 80px);
  padding: clamp(40px, 6vw, 88px) clamp(28px, 5vw, 56px);
  align-items: start;
}
.summit-intro .si-lead {
  font-size: clamp(28px, 3.4vw, 44px); font-weight: 600;
  letter-spacing: -0.03em; line-height: 1.05; margin: 0;
}
.summit-intro .si-lead em { font-family: var(--serif); font-style: italic; font-weight: 200; color: var(--accent); }
.summit-intro .si-body { display: flex; flex-direction: column; gap: 18px; }
.summit-intro .si-body p { font-size: 17.5px; line-height: 1.6; color: #2c2f38; margin: 0; max-width: 56ch; }
.summit-intro .si-body p .em { font-weight: 600; color: var(--t-ink); }
.summit-not { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.summit-not .chip-no {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px; border-radius: var(--r-pill);
  border: 1px solid var(--line); font-size: 14px; color: var(--t-muted);
}
.summit-not .chip-no s { text-decoration-color: var(--coral); }
.summit-not .chip-yes {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px; border-radius: var(--r-pill);
  background: var(--accent); color: #fff; font-size: 14px; font-weight: 600;
}

/* Embajador — Alex Txikon */
.embajador {
  display: grid; grid-template-columns: 0.78fr 1.22fr;
  gap: clamp(28px, 5vw, 72px); align-items: center;
  padding: clamp(36px, 5vw, 80px) clamp(28px, 5vw, 56px);
}
.embajador-img {
  position: relative; border-radius: var(--r-card); overflow: hidden;
  aspect-ratio: 3 / 4; max-height: 620px; background: var(--ink);
  box-shadow: 0 30px 70px rgba(14,15,21,0.20);
}
.embajador-img img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.embajador-body { display: flex; flex-direction: column; gap: 20px; }
.embajador-quote {
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(24px, 2.9vw, 38px); line-height: 1.22; margin: 0;
  letter-spacing: -0.01em;
}
.embajador-quote em { color: var(--accent); }
.embajador-name { font-weight: 700; letter-spacing: -0.02em; font-size: 18px; }
.embajador-name span { display: block; font-weight: 500; font-size: 14.5px; color: var(--t-muted); letter-spacing: 0; margin-top: 2px; }
.embajador-note { font-size: 16px; line-height: 1.55; color: var(--t-muted); max-width: 50ch; }

/* ¿Para quién existe? — audiencias */
.aud-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); margin-top: 40px; }
.aud-card {
  position: relative; overflow: hidden; border-radius: var(--r-card);
  background: var(--white); border: 1px solid var(--line);
  padding: 28px; display: flex; flex-direction: column; gap: 14px;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.aud-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(14,15,21,.08); }
.aud-card .glow {
  position: absolute; width: 180px; height: 180px; border-radius: 50%;
  filter: blur(46px); top: -56px; right: -56px;
  opacity: calc(0.20 + var(--grad)*0.34); background: var(--c);
}
.aud-card > * { position: relative; z-index: 2; }
.aud-card .ac-tag {
  align-self: flex-start; display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: var(--r-pill); border: 1px solid var(--line);
  font-size: 12.5px; font-weight: 600; color: var(--t-muted);
}
.aud-card .ac-tag .d { width: 9px; height: 9px; border-radius: 50%; background: var(--c); }
.aud-card .ac-name { font-size: clamp(22px, 2.2vw, 28px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.04; }
.aud-card .ac-who { font-family: var(--serif); font-style: italic; font-weight: 200; font-size: 17px; color: var(--t-ink); opacity: .72; }
.aud-card .ac-desc { font-size: 14.5px; line-height: 1.5; color: var(--t-muted); }

@media (max-width: 900px) {
  .summit-intro { grid-template-columns: 1fr; }
  .embajador { grid-template-columns: 1fr; }
  .embajador-img { max-height: 520px; aspect-ratio: 3/4; }
  .aud-grid { grid-template-columns: 1fr; }
}

/* ---- Bloque azul (hero Summit + interior) ---- */
.block.blue { background: var(--blue); color: #fff; }
.block.blue .eyebrow { color: rgba(255,255,255,0.72); }
.block.blue .eyebrow .dot { background: #fff; }
.block.blue .lead { color: rgba(255,255,255,0.86); }
.block.blue .display { color: #fff; }

.summit-hero {
  display: grid; grid-template-columns: 1.02fr 0.98fr;
  align-items: center; gap: clamp(24px, 4vw, 60px);
  padding: clamp(40px, 5vw, 80px) clamp(28px, 5vw, 56px);
}
.summit-hero.alt .sh-media { order: -1; }
.sh-text { display: flex; flex-direction: column; gap: 26px; align-items: flex-start; }
.sh-lead { font-size: clamp(28px, 3.5vw, 48px); font-weight: 600; letter-spacing: -0.035em; line-height: 1.05; color: #fff; margin: 0; }
.sh-lead em { font-family: var(--serif); font-style: italic; font-weight: 200; }
.sh-sub { font-size: 17px; line-height: 1.6; color: rgba(255,255,255,0.86); max-width: 48ch; margin: 0; }
.btn-bright { background: #fff; color: var(--blue); height: 58px; padding: 0 30px; font-size: 17px; box-shadow: 0 14px 34px rgba(0,0,0,0.22); }
.btn-bright:hover { background: var(--cream); }

.sh-media { position: relative; min-height: 320px; display: flex; }
.sh-img {
  position: relative; width: 100%;
  aspect-ratio: 4 / 4.4; max-height: 580px;
  border-radius: var(--r-block); overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.28);
}
.sh-img img { width: 100%; height: 100%; object-fit: cover; object-position: center 18%; display: block; }
.sh-credit {
  position: absolute; right: 14px; bottom: 11px; z-index: 2;
  font-size: 12px; font-weight: 500; letter-spacing: 0.01em;
  color: rgba(255,255,255,0.82); text-shadow: 0 1px 5px rgba(0,0,0,0.55);
}

/* Cita del embajador sobre el hero azul (interior) */
.sh-quote {
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(24px, 3vw, 40px); line-height: 1.2; margin: 0; color: #fff; letter-spacing: -0.01em;
}
.sh-name { font-weight: 700; letter-spacing: -0.02em; font-size: 18px; color: #fff; }
.sh-name span { display: block; font-weight: 500; font-size: 14.5px; color: rgba(255,255,255,0.7); letter-spacing: 0; margin-top: 2px; }
.sh-note { font-size: 16px; line-height: 1.55; color: rgba(255,255,255,0.82); max-width: 52ch; margin: 0; }

.back-wrap { display: flex; justify-content: center; padding: clamp(20px,4vw,40px) 24px 0; }

@media (max-width: 900px) {
  .summit-hero { grid-template-columns: 1fr; }
  .summit-hero.alt .sh-media { order: 0; }
  .sh-img { max-height: 460px; aspect-ratio: 4/3.6; }
}

/* ===================== MÉTODO · PLAY TO SCALE® ===================== */
/* Fusión: dos conceptos que se unen */
.fusion { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: clamp(16px,3vw,40px); margin-top: 44px; }
.fusion-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); padding: clamp(24px,3vw,40px); display: flex; flex-direction: column; gap: 10px; }
.fusion-card .fc-k { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--c, var(--blue)); }
.fusion-card .fc-t { font-size: clamp(22px,2.4vw,30px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; }
.fusion-card .fc-d { font-size: 15px; line-height: 1.5; color: var(--t-muted); }
.fusion-plus { width: 60px; height: 60px; border-radius: 50%; background: var(--blue); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 30px; font-weight: 600; flex: none; box-shadow: 0 14px 34px rgba(61,56,245,.3); }

/* Arsenal metodológico (4 cards con imagen) */
.metodo-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap); margin-top: 40px; }
.metodo-card { background: var(--white); border: 1px solid var(--line); border-radius: var(--r-card); overflow: hidden; display: flex; flex-direction: column; transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.metodo-card:hover { transform: translateY(-5px); box-shadow: 0 22px 50px rgba(14,15,21,.10); }
.metodo-card .mc-img { position: relative; aspect-ratio: 4/3.4; overflow: hidden; background: var(--cloud); }
.metodo-card .mc-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.metodo-card:hover .mc-img img { transform: scale(1.05); }
.metodo-card .mc-body { padding: 20px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.metodo-card .mc-k { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--t-muted); }
.metodo-card .mc-k .d { width: 8px; height: 8px; border-radius: 50%; background: var(--c, var(--blue)); }
.metodo-card .mc-title { font-size: 19px; font-weight: 600; letter-spacing: -0.025em; line-height: 1.1; }
.metodo-card .mc-desc { font-size: 14px; line-height: 1.45; color: var(--t-muted); }

/* Manifiesto sobre bloque azul */
.manifest { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); margin-top: 44px; }
.manifest-item { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.16); border-radius: var(--r-card); padding: 28px; display: flex; flex-direction: column; gap: 10px; }
.manifest-item .mi-num { font-family: var(--serif); font-style: italic; font-weight: 200; font-size: 42px; line-height: 1; color: #fff; opacity: .55; }
.manifest-item .mi-title { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; color: #fff; line-height: 1.1; }
.manifest-item .mi-text { font-size: 15px; line-height: 1.55; color: rgba(255,255,255,0.82); }
.manifest-item.wide { grid-column: 1 / -1; }

/* Galería "en acción" */
.metodo-gallery { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; gap: var(--gap); margin-top: 40px; }
.metodo-gallery .g { position: relative; overflow: hidden; border-radius: var(--r-card); background: var(--cloud); aspect-ratio: 4/3; }
.metodo-gallery .g.tall { grid-row: span 2; aspect-ratio: 4/6.2; }
.metodo-gallery .g img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .7s var(--ease); }
.metodo-gallery .g:hover img { transform: scale(1.05); }

@media (max-width: 980px) {
  .fusion { grid-template-columns: 1fr; }
  .fusion-plus { margin: 0 auto; transform: rotate(90deg); }
  .metodo-cards { grid-template-columns: 1fr 1fr; }
  .manifest { grid-template-columns: 1fr; }
  .metodo-gallery { grid-template-columns: 1fr 1fr; }
  .metodo-gallery .g.tall { grid-row: span 1; aspect-ratio: 4/3; }
}
@media (max-width: 560px) {
  .metodo-cards { grid-template-columns: 1fr; }
}
