/* ═══════════════════════════════════════════════
   Kine&Co — Estilos principales
   Versión: 5.0 | Galileo Media Lab
═══════════════════════════════════════════════ */

/* ─── TOKENS ─── */
:root {
  --navy:    #0b1f3a;
  --blue:    #1a5fb4;
  --sky:     #3d9be9;
  --celeste: #7ec8e3;
  --ice:     #daeef8;
  --off:     #f4f8fc;
  --white:   #ffffff;
  --accent:  #f0d96b;
  --accent-d:#c9a800;
  --text:    #0e1e30;
  --muted:   #2b2f33;
  --wsap:    #25d366;
  --f-serif: 'Libertinus Serif Display', serif;
  --f-sans:  'Outfit', sans-serif;
  --r:       18px;
  --r-lg:    28px;
  --r-xl:    40px;
}

/* ─── RESET ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  font-size: 16px;
  max-width: 100%;
  overflow-x: hidden;
}
body {
  font-family: var(--f-sans);
  color: var(--text);
  background: var(--white);
  overflow-x: hidden;
  max-width: 100%;
  -webkit-font-smoothing: antialiased;
  cursor: none;
}
img { display: block; max-width: 100%; }
a  { text-decoration: none; color: inherit; }
strong  { font-weight: 600; }
em { font-size: 1.15em; }
h2 {font-size: 1em; font-weight: 300; }

/* ─── CURSOR ─── */
.cursor { position:fixed; top:0; left:0; z-index:9999; pointer-events:none; mix-blend-mode:multiply; }
.cursor-dot  { width:7px; height:7px; border-radius:50%; background:var(--blue); position:absolute; transform:translate(-50%,-50%); }
.cursor-ring { width:34px; height:34px; border-radius:50%; border:1.5px solid var(--blue); position:absolute; transform:translate(-50%,-50%); opacity:.5; transition:width .22s,height .22s,opacity .22s; }
body:has(a:hover) .cursor-ring,
body:has(button:hover) .cursor-ring { width:50px; height:50px; opacity:.8; }

/* ─── LAYOUT ─── */
.wrap { width:100%; max-width:1140px; margin:0 auto; padding:0 28px; }

/* ─── TYPOGRAPHY ─── */
.mix-head-lg {
  font-family:var(--f-sans); font-weight:200;
  font-size:clamp(3.2rem,7vw,6rem);
  line-height:.97; color:var(--navy); letter-spacing:-.03em;
}
.mix-head-lg em { font-family:var(--f-serif); font-weight:300; color:var(--sky); display:block; font-style:normal; }

.mix-head {
  font-family:var(--f-sans); font-weight:200;
  font-size:clamp(2.4rem,5vw,4rem);
  line-height:1.05; color:var(--navy); letter-spacing:-.02em;
}
.mix-head em { font-family:var(--f-serif); font-weight:200; color:var(--sky); font-style:normal; }

.mix-head-sm {
  font-family:var(--f-sans); font-weight:200;
  font-size:clamp(1.7rem,3vw,2.4rem);
  line-height:1.15; color:var(--navy); letter-spacing:-.01em;
}
.mix-head-sm em { font-family:var(--f-serif); font-weight:200; color:var(--sky); font-style:normal; }

.tag {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.68rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase;
  color:var(--blue); margin-bottom:16px;
}
.tag::before { content:''; width:18px; height:1.5px; background:var(--accent); }

.body-txt { font-family:var(--f-sans); font-weight:300; font-size:1.1rem; line-height:1.78; color:var(--muted); }

/* ─── GLASS ─── */
.glass {
  background:rgba(255,255,255,.45);
  backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 8px 40px rgba(11,31,58,.1), inset 0 1px 0 rgba(255,255,255,.9);
}

/* ─── BUTTONS ─── */
.btn {
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--f-sans); font-size:.86rem; font-weight:500;
  padding:12px 24px; border-radius:100px;
  transition:all .28s cubic-bezier(.23,1,.32,1);
  cursor:none; border:none; outline:none;
}
.btn svg { width:17px; height:17px; flex-shrink:0; }
.btn-solid  { background:var(--wsap); color:#fff; box-shadow:0 4px 18px rgba(11,31,58,.22); }
.btn-solid:hover  { background:var(--blue); transform:translateY(-2px); box-shadow:0 8px 28px rgba(26,95,180,.3); }
.btn-ghost  { background:transparent; color:var(--navy); border:1.5px solid rgba(11,31,58,.18); }
.btn-ghost:hover  { border-color:var(--blue); color:var(--blue); transform:translateY(-2px); }
.btn-accent { background:var(--wsap); color:#fff; box-shadow:0 4px 18px rgba(37,211,102,.3); }
.btn-accent:hover { background:#1fba58; transform:translateY(-2px); }
.btn-yellow { background:var(--accent); color:var(--navy); }
.btn-yellow:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(240,217,107,.6); }
.btn-wa     { background:var(--wsap); color:#fff; box-shadow:0 4px 18px rgba(37,211,102,.3); }
.btn-wa:hover     { background:#1fba58; transform:translateY(-2px); box-shadow:0 8px 28px rgba(37,211,102,.42); }

/* ═══════════════════════════════════════
   HEADER
═══════════════════════════════════════ */
#hdr {
  position:fixed; top:0; left:0; right:0; z-index:800;
  padding:0 28px;
  transition:background .4s, box-shadow .4s;
}
#hdr.scrolled {
  background:rgba(255,255,255,.70);
  backdrop-filter:blur(100px);
  -webkit-backdrop-filter:blur(100px);
  box-shadow:0 1px 0 rgba(11,31,58,.07);
}
.hdr-inner {
  max-width:1140px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  height:70px;
}
.logo-img         { height:44px; width:auto; display:block; }
.logo-img-scrolled{ height:38px; display:none; }
#hdr.scrolled .logo-img         { display:none; }
#hdr.scrolled .logo-img-scrolled{ display:block; }

.nav-links { display:flex; align-items:center; gap:28px; }
.nav-links a { font-size:.92rem; font-weight:400; color:var(--navy); opacity:.65; transition:opacity .2s,color .2s; cursor:none; }
.nav-links a:hover { opacity:1; color:var(--blue); }

.hdr-actions { display:flex; align-items:center; gap:8px; }
.hdr-social  { display:flex; align-items:center; gap:8px; }

.icon-btn {
  width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(11,31,58,.12);
  display:flex; align-items:center; justify-content:center;
  color:var(--navy); transition:all .2s; cursor:none;
  background:rgba(255,255,255,.5);
}
.icon-btn:hover { background:var(--navy); color:#fff; border-color:var(--navy); }
.icon-btn svg { width:15px; height:15px; }

.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:none; padding:4px; }
.burger span { display:block; width:22px; height:1.5px; background:var(--navy); border-radius:2px; transition:all .3s; }
.burger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.burger.open span:nth-child(2) { opacity:0; }
.burger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

.mob-nav {
  display:none; position:fixed; top:70px; left:0; right:0; z-index:790;
  background:rgba(255,255,255,.96); backdrop-filter:blur(20px);
  padding:24px 28px 32px; border-bottom:1px solid rgba(11,31,58,.06);
  flex-direction:column; gap:18px; box-shadow:0 12px 40px rgba(11,31,58,.1);
}
.mob-nav.open { display:flex; }
.mob-nav a  { font-size:1.05rem; font-weight:300; color:var(--navy); }
.mob-social { display:flex; gap:8px; margin-top:6px; }

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
#hero {
  min-height:100svh; padding-top:70px;
  background:linear-gradient(155deg,#eaf3fb 0%,#f6f9fd 55%,#eff7f2 100%);
  position:relative; overflow:hidden;
}

/* Blobs de fondo del hero */
.blob { position:absolute; border-radius:50%; filter:blur(70px); pointer-events:none; }
.blob-1 { width:520px; height:520px; background:rgba(61,155,233,.18); top:-100px; right:-80px; animation:drift 14s ease-in-out infinite alternate; }
.blob-2 { width:300px; height:300px; background:rgba(240,217,107,.22); bottom:8%; left:-60px; animation:drift 11s ease-in-out infinite alternate; animation-delay:-5s; }
.blob-3 { width:240px; height:240px; background:rgba(126,200,227,.15); top:40%; right:12%; animation:drift 9s ease-in-out infinite alternate; animation-delay:-3s; }
@keyframes drift { 0%{transform:translate(0,0) scale(1);} 100%{transform:translate(28px,18px) scale(1.06);} }

/* Grain */
#hero::after { content:''; position:absolute; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E"); opacity:.022; pointer-events:none; z-index:0; }

.hero-layout {
  position:relative; z-index:1;
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; min-height:calc(100svh - 70px);
  gap:48px; padding:60px 0;
}
.hero-left { display:flex; flex-direction:column; }
.hero-macro  { margin-bottom:24px; animation:fade-up .9s .15s both; }
.hero-sub    { max-width:400px; margin-bottom:36px; animation:fade-up .9s .35s both; }
.hero-ctas   { display:flex; flex-wrap:wrap; gap:10px; animation:fade-up .9s .5s both; }
.hero-stats  { display:flex; gap:28px; margin-top:44px; animation:fade-up .9s .65s both; }
.stat-num    { font-family:var(--f-sans); font-weight:200; font-size:2.2rem; color:var(--navy); line-height:1; letter-spacing:-.02em; }
.stat-num span { font-family:var(--f-serif); color:var(--sky); }
.stat-lbl    { font-size:.72rem; font-weight:400; color:var(--muted); letter-spacing:.05em; margin-top:4px; }
.stat-div    { width:1px; background:rgba(11,31,58,.1); align-self:stretch; }
@keyframes fade-up { from{opacity:0;transform:translateY(28px);} to{opacity:1;transform:none;} }

.hero-right { position:relative; height:580px; animation:fade-up .9s .3s both; }
.hero-img-main { position:absolute; right:0; top:0; width:100%; height:86%; border-radius:40px 40px 24px 40px; overflow:hidden; box-shadow:0 28px 72px rgba(11,31,58,.18); }
.hero-img-main img { width:100%; height:100%; object-fit:cover; object-position:center top; }

.hero-glass-chip { position:absolute; left:8%; bottom:20%; z-index:3; padding:16px 20px; border-radius:var(--r); min-width:120px; }
.chip-icon { width:38px; height:38px; border-radius:12px; background:linear-gradient(135deg,var(--sky),var(--blue)); display:flex; align-items:center; justify-content:center; color:#fff; margin-bottom:10px; }
.chip-icon svg { width:19px; height:19px; }
.chip-val { font-family:var(--f-sans); font-weight:600; font-size:1.4rem; color:var(--navy); line-height:1; }
.chip-lbl { font-size:.72rem; color:var(--muted); margin-top:3px; }

.hero-float-tag {
  position:absolute; top:20px; left:5%; z-index:3;
  padding:9px 16px; border-radius:100px;
  background:rgba(255,255,255,.7); backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.9);
  font-size:.75rem; font-weight:500; color:var(--navy);
  box-shadow:0 4px 16px rgba(11,31,58,.08);
  animation:fade-up .8s .7s both;
}
.scroll-hint {
  position:absolute; bottom:28px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted);
  z-index:2; animation:fade-up 1s 1.1s both;
}
.scroll-line { width:1px; height:38px; background:linear-gradient(to bottom,var(--sky),transparent); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:.4;transform:scaleY(1);} 50%{opacity:1;transform:scaleY(1.3);} }

/* ═══════════════════════════════════════
   MARQUEE
═══════════════════════════════════════ */
.cov-strip { background:var(--navy); padding:16px 0; overflow:hidden; }
.cov-track { display:flex; align-items:center; white-space:nowrap; animation:marquee 16s linear infinite; }
.cov-track:hover { animation-play-state:paused; }
.cov-text-item { display:inline-flex; align-items:center; padding:0 28px; font-size:.8rem; font-weight:300; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.85); flex-shrink:0; }
.cov-sep { width:1px; height:20px; background:rgba(255,255,255,.15); flex-shrink:0; }
@keyframes marquee { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }

/* ═══════════════════════════════════════
   NOSOTROS
═══════════════════════════════════════ */
#nosotros { padding:120px 0; background:var(--white); }
.about-grid { display:grid; grid-template-columns:1.05fr 1fr; gap:72px; align-items:center; }
.about-comp { position:relative; height:560px; }

.ac-main { position:absolute; top:0; right:0; width:65%; height:70%; border-radius:40px 40px 12px 40px; overflow:hidden; box-shadow:0 24px 80px rgba(11,31,58,.08); z-index:2; }
.ac-main img { width:100%; height:100%; object-fit:cover; object-position:top center; }
.ac-secondary { position:absolute; bottom:0; left:0; width:52%; height:50%; border-radius:24px; overflow:hidden; box-shadow:0 16px 40px rgba(11,31,58,.12); z-index:2; }
.ac-secondary img { width:100%; height:100%; object-fit:cover; }
.ac-accent { position:absolute; top:45px; left:40px; width:17%; height:15%; background:var(--accent); border-radius:18px; z-index:1; box-shadow:0 12px 36px rgba(240,217,107,.45); }
.ac-icon-float { position:absolute; z-index:4; padding:14px 16px; border-radius:var(--r); display:flex; align-items:center; gap:10px; }
.ac-icon-float.pos-1 { bottom:56%; right:-22px; }
.ac-icon-float.pos-2 { bottom:8%; right:8%; }
.ac-icon-num { font-family:var(--f-sans); font-weight:600; font-size:1.5rem; color:var(--navy); line-height:1; }
.ac-icon-num span { font-family:var(--f-serif); color:var(--sky); font-weight:300; }
.ac-icon-lbl { font-size:.7rem; color:var(--muted); line-height:1.3; }

.about-icons-row { display:flex; gap:12px; flex-wrap:wrap; margin-top:28px; }
.about-icon-pill {
  display:flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:100px;
  background:var(--off); border:1px solid rgba(61,155,233,.15);
  font-size:.8rem; font-weight:400; color:var(--text);
  transition:all .2s; cursor:none;
}
.about-icon-pill:hover { background:var(--ice); border-color:var(--sky); transform:translateY(-2px); }
.about-icon-pill span { font-size:1rem; }

/* ═══════════════════════════════════════
   MACRO INTERLUDE — luz aurora animada
═══════════════════════════════════════ */
.macro-interlude {
  padding:100px 0;
  background:var(--navy);
  position:relative; overflow:hidden;
}

/* Textura SVG de fondo */
.macro-texture {
  position:absolute; inset:0; z-index:0; pointer-events:none; overflow:hidden;
}
.macro-texture svg { width:100%; height:100%; }

/* Contenedor de bolas de luz aurora */
.glow-container {
  position:absolute; inset:0;
  overflow:hidden; pointer-events:none; z-index:1;
}
.glow-ball {
  position:absolute; aspect-ratio:1;
  width:85%; top:-68%; left:-30%;
  border-radius:50%;
  background:radial-gradient(circle at center,rgba(61,155,233,.34) 0%,rgba(126,200,227,.24) 25%,rgba(11,31,58,0) 65%);
  filter:blur(30px); opacity:.8;
  animation:auroraMove 9s infinite linear;
  will-change:transform;
}
.ball-2 {
  width:67%; top:-123%; left:46%;
  background:radial-gradient(circle at center,rgba(126,200,227,.30) 0%,rgba(61,155,233,.22) 35%,transparent 70%);
  animation-duration:16s; animation-delay:-8s; opacity:.7;
}
@keyframes auroraMove {
  0%   { transform:translate3d(0%,40%,0) rotate(0deg); }
  25%  { transform:translate3d(30%,10%,0) rotate(90deg); }
  50%  { transform:translate3d(55%,45%,0) rotate(180deg); }
  75%  { transform:translate3d(20%,70%,0) rotate(270deg); }
  100% { transform:translate3d(0%,40%,0) rotate(360deg); }
}

.macro-inner { position:relative; z-index:2; max-width:820px; margin:0 auto; text-align:center; }
.macro-phrase {
  font-family:var(--f-sans); font-weight:200;
  font-size:clamp(2.5rem,4.8vw,4.5rem);
  line-height:.98; color:rgba(255,255,255,.92);
  letter-spacing:-.03em; margin-bottom:28px;
}
.macro-phrase em { font-family:var(--f-serif); font-style:normal; font-weight:300; color:var(--celeste); display:block; }
.macro-phrase strong { font-weight:300; color:var(--accent); }
.macro-sub    { color:rgba(255,255,255,.75); font-weight:300; max-width:650px; margin:0 auto 8px; line-height:1.7; }
.macro-author { font-size:.75rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.28); }

/* ═══════════════════════════════════════
   SERVICIOS
═══════════════════════════════════════ */
#servicios { padding:120px 0; background:var(--off); }
.srv-head { margin-bottom:64px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:end; }
.srv-head-right .body-txt { max-width:320px; }
.srv-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }

#srv-fkt, #srv-rpg, #srv-dlm, #srv-osteopatia, #srv-puncion { scroll-margin-top:90px; }

.srv-card {
  border-radius:var(--r-xl); overflow:hidden;
  position:relative; height:360px; cursor:none;
  transition:transform .4s cubic-bezier(.23,1,.32,1), box-shadow .4s;
}
a.srv-card { text-decoration:none; color:inherit; display:block; }
.srv-card:hover { transform:translateY(-8px) scale(1.01); box-shadow:0 28px 70px rgba(11,31,58,.18); }

.srv-card-bg { position:absolute; inset:0; background:#0e2040; }
.srv-card-bg img { width:100%; height:100%; object-fit:cover; object-position:center top; transition:transform .6s cubic-bezier(.23,1,.32,1), opacity .4s; opacity:.85; }
.srv-card:hover .srv-card-bg img { transform:scale(1.06); opacity:.7; }

.srv-card-grad {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(11,31,58,.92) 0%,rgba(11,31,58,.55) 45%,rgba(11,31,58,.1) 100%);
  transition:background .4s;
}
.srv-card:hover .srv-card-grad {
  background:linear-gradient(to top,rgba(10,47,85,.97) 0%,rgba(26,95,180,.75) 50%,rgba(61,155,233,.3) 100%);
}

.srv-card-content { position:absolute; bottom:0; left:0; right:0; z-index:2; padding:22px; }
.srv-glass-pill {
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 12px; border-radius:100px;
  background:rgba(255,255,255,.15); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.25);
  font-size:.68rem; font-weight:500; letter-spacing:.1em; text-transform:uppercase;
  color:rgba(255,255,255,.9); margin-bottom:12px;
}
.srv-glass-pill span { width:6px; height:6px; border-radius:50%; background:var(--accent); display:block; }

.srv-name-txt { font-family:var(--f-sans); font-weight:300; font-size:1.2rem; color:#fff; line-height:1.2; }
.srv-name-txt em { font-family:var(--f-serif); font-weight:300; color:var(--celeste); font-style:normal; }

.srv-detail {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s cubic-bezier(.23,1,.32,1), opacity .35s;
  opacity: 0;
}
.srv-card:hover .srv-detail { max-height:250px; opacity:1; }
.srv-detail p { font-size:.8rem; font-weight:300; color:rgba(255,255,255,.72); line-height:1.6; margin-top:10px; padding-top:10px; border-top:1px solid rgba(255,255,255,.15); }
.srv-detail .srv-wa-lnk { display:inline-flex; align-items:center; gap:5px; margin-top:10px; font-size:.95rem; font-weight:500; color:var(--accent); }

.srv-icon-badge {
  position:absolute; top:16px; right:16px; z-index:3;
  width:38px; height:38px; border-radius:12px;
  background:rgba(255,255,255,.18); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.3);
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
  transition:background .3s;
}
.srv-card:hover .srv-icon-badge { background:var(--accent); }

.srv-card-cta {
  border-radius:var(--r-xl); height:360px;
  background:linear-gradient(135deg,var(--accent) 0%,#fffbdf 100%);
  display:flex; flex-direction:column; justify-content:space-between;
  padding:28px; position:relative; overflow:hidden;
  transition:transform .35s, box-shadow .35s;
}
.srv-card-cta:hover { transform:translateY(-8px); box-shadow:0 28px 60px rgba(240,217,107,.4); }
.srv-cta-bg-letter { position:absolute; right:-10px; bottom:-30px; font-family:var(--f-serif); font-size:10rem; font-weight:300; color:rgba(11,31,58,.07); line-height:1; pointer-events:none; }

/* ═══════════════════════════════════════
   COBERTURAS
═══════════════════════════════════════ */
#coberturas { padding:80px 0; background:var(--white); }
.cob-layout { display:grid; grid-template-columns:1fr 1.35fr; gap:80px; align-items:center; }
.cob-logos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.cob-logo-card {
  border-radius:var(--r); border:1px solid rgba(11,31,58,.08);
  background:var(--off); padding:10px 8px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px; min-height:100px; transition:all .25s;
}
.cob-logo-card:hover { border-color:var(--sky); background:var(--ice); transform:translateY(-4px); box-shadow:0 8px 24px rgba(61,155,233,.12); }
.cob-logo-card img  { height:40px; width:auto; object-fit:contain; max-width:110px; }
.cob-logo-card span { font-size:.85rem; color:var(--muted); font-weight:400; text-align:center; }
.cob-note { margin-top:20px; font-size:.9rem; color:var(--muted); padding-left:12px; border-left:2px solid var(--accent); line-height:1.6; }

/* ═══════════════════════════════════════
   REVIEWS
═══════════════════════════════════════ */
#reviews { padding:80px 0; background:var(--off); }
.rev-head { margin-bottom:60px; }
.rev-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.rev-card {
  padding:26px; border-radius:var(--r-lg);
  background:var(--white); border:1px solid rgba(11,31,58,.06);
  display:flex; flex-direction:column; gap:14px;
  transition:transform .3s, box-shadow .3s;
}
.rev-card:hover { transform:translateY(-5px); box-shadow:0 16px 44px rgba(11,31,58,.08); }
.rev-stars span  { color:var(--accent-d); font-size:.88rem; }
.rev-quote { font-family:var(--f-serif); font-weight:300; font-size:1.02rem; line-height:1.65; color:var(--text); flex:1; }
.rev-foot  { display:flex; align-items:center; gap:10px; margin-top:auto; }
.rev-av    { width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--ice),var(--celeste)); display:flex; align-items:center; justify-content:center; font-weight:600; font-size:.78rem; color:var(--blue); flex-shrink:0; }
.rev-name  { font-size:.82rem; font-weight:500; color:var(--navy); }
.rev-date  { font-size:.7rem; color:var(--muted); }
.google-note {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 48px auto 0;
  padding: 10px 20px;
  border-radius: 100px;
  background: var(--white);
  border: 1px solid rgba(11,31,58,.1);
  box-shadow: 0 4px 16px rgba(11,31,58,.07);
  font-size: .82rem;
  font-weight: 500;
  color: var(--navy);
  text-decoration: none;
  transition: box-shadow .2s, transform .2s;
  cursor: pointer;
}
.google-note:hover {
  box-shadow: 0 8px 28px rgba(11,31,58,.12);
  transform: translateY(-2px);
}
.google-note svg { width: 18px; height: 18px; }
.google-note a { color: inherit; font-weight: 500; }
.google-note svg { width:17px; height:17px; }

/* Carousel mobile */
.rev-carousel-wrap { display:none; position:relative; }
.rev-carousel-track {
  display:flex; gap:16px; overflow-x:auto;
  scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none;
  padding-bottom:8px; cursor:grab;
  -webkit-overflow-scrolling:touch; scroll-behavior:smooth; user-select:none;
}
.rev-carousel-track.dragging { cursor:grabbing; scroll-behavior:auto; }
.rev-carousel-track.dragging .rev-card { pointer-events:none; }
.rev-carousel-track::-webkit-scrollbar { display:none; }
.rev-carousel-track .rev-card { min-width:calc(100vw - 80px); scroll-snap-align:start; flex-shrink:0; }
.rev-dots { display:flex; justify-content:center; gap:8px; margin-top:20px; }
.rev-dot { width:8px; height:8px; border-radius:50%; background:rgba(11,31,58,.2); border:none; padding:0; cursor:pointer; transition:background .2s, transform .2s; }
.rev-dot.active { background:var(--blue); transform:scale(1.2); }

/* ═══════════════════════════════════════
   TURNOS CTA — aurora animada
═══════════════════════════════════════ */
#turnos { padding:70px 0; background:var(--white); }
.turnos-box {
  border-radius:48px; padding:80px 60px;
  background:linear-gradient(135deg,var(--navy) 0%,#0d2d58 100%);
  position:relative; overflow:hidden; text-align:center;
}
.turnos-box::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 55% 80% at 80% 50%,rgba(61,155,233,.22) 0%,transparent 65%),
             radial-gradient(ellipse 40% 60% at 15% 30%,rgba(126,200,227,.12) 0%,transparent 55%);
}
.turnos-box > * { position:relative; z-index:1; }

/* Aurora igual que macro-interlude */
.tb-blob { position:absolute; aspect-ratio:1; border-radius:50%; pointer-events:none; will-change:transform; }
.tb-1 {
  width:55%; top:-80%; left:-10%;
  background:radial-gradient(circle at center,rgba(61,155,233,.28) 0%,rgba(126,200,227,.18) 30%,transparent 65%);
  filter:blur(28px); opacity:.85;
  animation:auroraMove 12s infinite linear;
}
.tb-2 {
  width:45%; top:-60%; left:50%;
  background:radial-gradient(circle at center,rgba(126,200,227,.22) 0%,rgba(61,155,233,.16) 35%,transparent 70%);
  filter:blur(36px); opacity:.7;
  animation:auroraMove 18s infinite linear; animation-delay:-9s;
}

.turnos-tag2 { display:inline-flex; align-items:center; gap:7px; font-size:.68rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:var(--white); margin-bottom:20px; }
.turnos-tag2::before { content:''; width:18px; height:1px; background:var(--accent); }
.turnos-title { font-family:var(--f-sans); font-weight:200; font-size:clamp(2rem,4vw,3rem); line-height:1.1; color:#fff; margin-bottom:14px; letter-spacing:-.02em; }
.turnos-title em { font-family:var(--f-serif); font-weight:300; color:var(--celeste); font-style:normal; }
.turnos-sub   { color:rgba(255,255,255,.8); font-weight:300; margin-bottom:32px; }
.turnos-phone { margin-top:18px; font-size:.9rem; color:rgba(255,255,255,.7); }
.turnos-phone a { color:var(--celeste); }

/* ═══════════════════════════════════════
   CONTACTO
═══════════════════════════════════════ */
#contacto { padding:120px 0 80px; background:var(--off); }
.con-grid { display:grid; grid-template-columns:1fr 1.6fr; gap:64px; align-items:start; }
.con-text .mix-head-sm { margin-bottom:36px; }
.con-row   { display:flex; align-items:flex-start; gap:14px; margin-bottom:22px; }
.con-icon  { width:42px; height:42px; border-radius:13px; background:var(--ice); color:var(--blue); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.con-icon svg { width:18px; height:18px; }
.con-lbl   { font-size:.67rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); margin-bottom:3px; font-weight:500; }
.con-val   { font-size:.92rem; color:var(--text); font-weight:300; }
.con-val a:hover { color:var(--blue); }
.social-row{ display:flex; gap:8px; margin-top:28px; }
.s-btn { display:flex; align-items:center; gap:6px; padding:8px 16px; border-radius:100px; font-size:.78rem; font-weight:400; border:1px solid; transition:all .2s; cursor:none; }
.s-btn svg { width:15px; height:15px; }
.s-btn.ig { border-color:rgba(193,53,132,.3); color:#c13584; }
.s-btn.ig:hover { background:#c13584; color:#fff; border-color:#c13584; }
.s-btn.fb { border-color:rgba(24,119,242,.3); color:#1877f2; }
.s-btn.fb:hover { background:#1877f2; color:#fff; border-color:#1877f2; }
.map-wrap {
  border-radius: 32px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(11,31,58,.1);
  height: 420px;
  position: relative;
  isolation: isolate;
}
.map-wrap iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
  max-width: 100%;
  position: absolute;
  top: 0; left: 0;
}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
footer { background:var(--navy); padding:28px 0; }
.footer-inner { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:12px; }
.footer-logo  { height:36px; width:auto; }
.footer-copy  { font-size:.73rem; color:rgba(255,255,255,.28); }
.footer-links { display:flex; gap:18px; align-items:center; }
.footer-links a { font-size:.73rem; color:rgba(255,255,255,.32); transition:color .2s; display:flex; align-items:center; gap:6px; }
.footer-links a:hover { color:var(--celeste); }
.made-galileo img { height:17px; width:auto; opacity:.85; transition:opacity .2s; }
.made-galileo:hover img { opacity:1; }

/* ═══════════════════════════════════════
   FLOATING WHATSAPP
═══════════════════════════════════════ */
.wa-float-wrap { position:fixed; bottom:28px; right:28px; z-index:700; display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.wa-bubble {
  position:relative; background:var(--blue); border-radius:100px;
  padding:11px 20px; font-family:var(--f-sans); font-size:.82rem; font-weight:500; color:#fff;
  box-shadow:0 6px 24px rgba(11,31,58,.28); white-space:nowrap;
  opacity:0; transform:translateY(8px) scale(.95); transform-origin:bottom right;
  transition:opacity .35s cubic-bezier(.23,1,.32,1), transform .35s cubic-bezier(.23,1,.32,1);
  pointer-events:none;
}
.wa-bubble::after { content:''; position:absolute; bottom:-6px; right:22px; width:12px; height:12px; background:var(--blue); transform:rotate(45deg); border-radius:2px; z-index:-1; }
.wa-float-wrap:hover .wa-bubble,
.wa-float-wrap.show-bubble .wa-bubble { opacity:1; transform:translateY(0) scale(1); }
.wa-float {
  position:relative; width:58px; height:58px; border-radius:50%;
  background:#25d366; display:flex; align-items:center; justify-content:center;
  color:#fff; cursor:none; text-decoration:none;
}
.wa-float svg { width:28px; height:28px; position:relative; z-index:2; }
.wa-float::before, .wa-float::after {
  content:''; position:absolute; inset:0; border-radius:50%;
  background:#25d366; animation:wa-pulse 2.4s ease-out infinite; z-index:0;
}
.wa-float::after { animation-delay:.8s; }
@keyframes wa-pulse {
  0%   { transform:scale(1);   opacity:.6; }
  70%  { transform:scale(1.7); opacity:0; }
  100% { transform:scale(1.7); opacity:0; }
}
.wa-float:hover { transform:scale(1.08); box-shadow:0 8px 32px rgba(37,211,102,.55); transition:transform .25s, box-shadow .25s; }

/* ═══════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════ */
.rv  { opacity:0; transform:translateY(36px);  transition:opacity .8s cubic-bezier(.23,1,.32,1), transform .8s cubic-bezier(.23,1,.32,1); }
.rvl { opacity:0; transform:translateX(-36px); transition:opacity .8s cubic-bezier(.23,1,.32,1), transform .8s cubic-bezier(.23,1,.32,1); }
.rvr { opacity:0; transform:translateX(36px);  transition:opacity .8s cubic-bezier(.23,1,.32,1), transform .8s cubic-bezier(.23,1,.32,1); }
.rv.in, .rvl.in, .rvr.in { opacity:1; transform:none; }
.d1{transition-delay:.08s!important;} .d2{transition-delay:.16s!important;} .d3{transition-delay:.24s!important;}
.d4{transition-delay:.32s!important;} .d5{transition-delay:.40s!important;} .d6{transition-delay:.48s!important;}

.srv-card.active .srv-detail {
  max-height: 250px;
  opacity: 1;
}
.srv-card.active .srv-card-grad {
  background: linear-gradient(
    to top,
    rgba(10,47,85,.97) 0%,
    rgba(26,95,180,.75) 50%,
    rgba(61,155,233,.3) 100%
  );
}
.srv-card.active .srv-icon-badge {
  background: var(--accent);
}
.srv-card.active .srv-card-bg img {
  transform: scale(1.06);
  opacity: .7;
}

/* ═══════════════════════════════════════
   RESPONSIVE — 960px
═══════════════════════════════════════ */
@media(max-width:960px){
  body { cursor:auto; }
  .cursor { display:none; }
  .btn, .s-btn, .about-icon-pill { cursor:auto; }
  .hero-layout { grid-template-columns:1fr; padding:48px 0 40px; }
  .hero-right  { height:65vw; min-height:360px; }
  .hero-img-main { border-radius:30px; }
  .scroll-hint { display:none; }
  .about-grid, .cob-layout, .con-grid { grid-template-columns:1fr; gap:48px; }
  .about-comp  { height:420px; order:-1; overflow: visible;}
  .srv-head    { grid-template-columns:1fr; }
  .srv-grid    { grid-template-columns:1fr 1fr; }
  .rev-grid    { grid-template-columns:1fr; }
  .turnos-box  { padding:56px 28px; border-radius:32px; }
  .map-wrap    { height:300px; }
  .cob-logos-grid { grid-template-columns:repeat(3,1fr); }
}

/* ═══════════════════════════════════════
   RESPONSIVE — 600px (mobile)
═══════════════════════════════════════ */
@media(max-width:600px){
  /* Header */
  .hdr-social { display:none; }
  .nav-links  { display:none; }
  .burger     { display:flex; }

  /* Sections */
  #nosotros, #servicios, #coberturas, #reviews, #turnos, #contacto { padding:70px 0; }

  /* Hero */
  .hero-right { height:80vw; min-height:500px; }
  .hero-glass-chip { left:4%; bottom:8%; }

  /* About */
  .about-comp { height:360px; }
  .ac-icon-float.pos-1 { right:4px; }

  /* Servicios */
  .srv-grid { grid-template-columns:1fr; }

  .cov-track { display:flex; align-items:center; white-space:nowrap; animation:marquee 4s linear infinite; }

  /* Coberturas — 2 columnas, gap reducido */
  .cob-layout { gap:32px; }
  .cob-logos-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .cob-logo-card  { min-height:80px; padding:8px 6px; }
  .cob-logo-card img { height:32px; max-width:90px; }
  .cob-logo-card span { font-size:.75rem; }

  /* Turnos */
  .turnos-box { padding:48px 20px; border-radius:24px; }

  /* Contacto */
  .map-wrap { height:260px; }

  /* Footer */
  .footer-inner { flex-direction:column; text-align:center; }
  .footer-links { justify-content:center; }

  /* WA float */
  .wa-float-wrap { bottom:20px; right:20px; }
  .wa-bubble { font-size:.76rem; padding:9px 16px; }
}

  #hero,
  .macro-interlude,
  .macro-texture,
  .glow-container,
  .turnos-box { overflow:hidden; }

  .hero-float-tag { 
    left:5%; 
    transform:translateX(-50%); 
    white-space:nowrap;
    max-width:calc(100% - 32px);
  }

  .ac-icon-float.pos-1 { right:8px; }

  .cov-strip { max-width:100vw; overflow:hidden; }

/* ═══════════════════════════════════════
   RESPONSIVE — 400px (xs)
═══════════════════════════════════════ */
@media(max-width:400px){
  .wrap { padding:0 16px; }
  .cob-logos-grid { gap:8px; }
  .cob-logo-card img { height:26px; max-width:75px; }
  .hero-stats { gap:16px; }
}
