/* ── Tokens ─────────────────────────────────────────── */
:root{
  --ink:#232a30;
  --ink-soft:#5c6870;
  --cyan:#0fb4e6;
  --cyan-deep:#0a89b8;
  --cyan-ink:#075e7f;
  --tint:#eaf7fc;
  --tint-2:#f5fbfd;
  --bg:#ffffff;
  --line:#e3edf1;
  --star:#f6a723;
  --wa:#25d366;
  --wa-deep:#1da851;
  --radius:18px;
  --radius-sm:12px;
  --maxw:1120px;
  --shadow:0 24px 60px -34px rgba(10,89,120,.45);
  --shadow-sm:0 10px 30px -18px rgba(10,89,120,.4);
  --display:"Sora", system-ui, sans-serif;
  --body:"Figtree", system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--body); font-size:16px; line-height:1.62;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3{font-family:var(--display); line-height:1.1; margin:0; letter-spacing:-.01em}
:focus-visible{outline:2.5px solid var(--cyan); outline-offset:3px; border-radius:4px}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}
.hl{color:var(--cyan)}

/* bracket signature motif */
.bracket{
  width:16px; height:16px; flex:0 0 auto; display:inline-block; position:relative;
  border:2px solid currentColor; border-radius:4px; vertical-align:middle;
}
.bracket::before{
  content:""; position:absolute; top:50%; left:-7px; right:-7px; height:2px;
  background:currentColor; transform:translateY(-50%);
}

/* ── Buttons ────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:9px; justify-content:center;
  font-family:var(--display); font-weight:600; font-size:.98rem;
  padding:13px 22px; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-wa{background:var(--wa); color:#04240f; box-shadow:0 12px 26px -12px rgba(37,211,102,.7)}
.btn-wa:hover{background:var(--wa-deep); color:#fff; transform:translateY(-2px)}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--cyan); color:var(--cyan-ink)}
.btn-light{background:#fff; color:var(--cyan-ink)}
.btn-light:hover{transform:translateY(-2px); box-shadow:0 16px 30px -16px rgba(0,0,0,.35)}
.ico-wa{width:20px; height:20px; fill:currentColor; flex:0 0 auto}

/* ── Header ─────────────────────────────────────────── */
.site-head{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.86); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.head-inner{display:flex; align-items:center; gap:20px; height:70px}
.brand-logo{height:48px; width:auto}
.nav{display:flex; gap:26px; margin-left:auto; font-family:var(--display); font-weight:500; font-size:.95rem}
.nav a{color:var(--ink-soft); position:relative; padding:4px 0}
.nav a:hover{color:var(--cyan-ink)}
.nav a::after{content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--cyan); transition:right .25s ease; border-radius:2px}
.nav a:hover::after{right:0}
.head-cta{padding:10px 18px; font-size:.92rem}
.nav-toggle{display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; margin-left:auto}
.nav-toggle span{width:24px; height:2.5px; background:var(--ink); border-radius:2px; transition:.25s}

/* ── Hero ───────────────────────────────────────────── */
.hero{
  position:relative; overflow:hidden;
  background:
    radial-gradient(900px 500px at 88% -10%, rgba(15,180,230,.16), transparent 60%),
    radial-gradient(700px 500px at -5% 110%, rgba(15,180,230,.08), transparent 55%),
    var(--bg);
}
.hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:52px; align-items:center;
  padding:76px 22px 84px;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:11px; margin:0 0 18px;
  font-family:var(--display); font-weight:600; font-size:.78rem;
  text-transform:uppercase; letter-spacing:.14em; color:var(--cyan-deep);
}
.hero h1{font-size:clamp(2.3rem, 5.2vw, 3.7rem); font-weight:700}
.lead{font-size:1.16rem; color:var(--ink-soft); margin:20px 0 30px; max-width:34ch}
.hero-cta{display:flex; flex-wrap:wrap; gap:13px; margin-bottom:26px}
.rating{display:inline-flex; align-items:center; gap:9px; font-size:.96rem; color:var(--ink-soft)}
.rating .stars{color:var(--star); letter-spacing:2px; font-size:1.05rem}
.rating strong{font-family:var(--display); color:var(--ink); font-size:1.05rem}
.rating:hover .rating-txt{color:var(--cyan-ink)}

.hero-media{position:relative}
.hero-photo{
  border-radius:26px; overflow:hidden; box-shadow:var(--shadow);
  border:6px solid #fff; aspect-ratio:1/1; background:var(--tint);
  transform:rotate(1.4deg);
}
.hero-photo img{width:100%; height:100%; object-fit:cover}
.hero-card{
  position:absolute; left:-18px; bottom:26px; background:#fff;
  display:flex; align-items:center; gap:13px; padding:14px 20px 14px 16px;
  border-radius:16px; box-shadow:var(--shadow-sm); border:1px solid var(--line);
}
.hero-card .bracket{color:var(--cyan); width:22px; height:22px}
.hc-label{margin:0; font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-soft)}
.hc-value{margin:2px 0 0; font-family:var(--display); font-weight:600; font-size:.98rem}

/* ── Sections ───────────────────────────────────────── */
.section{padding:80px 0}
.section-tint{background:linear-gradient(180deg,var(--tint-2),var(--tint))}
.sec-head{text-align:center; max-width:620px; margin:0 auto 46px}
.sec-head .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem); font-weight:700}
.sec-head-left{text-align:left; margin:0 0 30px}
.sec-head-left .eyebrow{justify-content:flex-start}

/* ── Services ───────────────────────────────────────── */
.services-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:16px}
.service{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:26px 22px; transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}
.service:hover{transform:translateY(-4px); box-shadow:var(--shadow-sm); border-color:transparent}
.service-ico{
  width:48px; height:48px; border-radius:13px; display:grid; place-items:center;
  background:var(--tint); color:var(--cyan-deep); margin-bottom:16px;
}
.service-ico svg{width:26px; height:26px; stroke:currentColor; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round}
.service h3{font-size:1.06rem; font-weight:600}

.promo{
  margin-top:34px; display:flex; flex-wrap:wrap; align-items:center; gap:24px;
  background:linear-gradient(120deg,var(--cyan),var(--cyan-deep)); color:#fff;
  border-radius:var(--radius); padding:26px 30px; box-shadow:var(--shadow);
}
.promo-tag{
  font-family:var(--display); font-weight:600; font-size:.74rem; letter-spacing:.12em;
  text-transform:uppercase; background:rgba(255,255,255,.22); padding:6px 12px; border-radius:999px;
}
.promo-body{flex:1; min-width:220px}
.promo-body h3{font-size:1.2rem; margin-bottom:4px}
.promo-body p{margin:0; opacity:.92; font-size:.95rem}
.promo-price{display:flex; align-items:baseline; gap:12px; font-family:var(--display)}
.promo-old{opacity:.7; text-decoration:line-through; font-size:1rem}
.promo-new{font-size:1.7rem; font-weight:700}

/* ── Team ───────────────────────────────────────────── */
.team-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px; max-width:760px; margin:0 auto}
.member{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:28px; display:flex; gap:18px; align-items:flex-start;
}
.member-avatar{
  width:58px; height:58px; flex:0 0 auto; border-radius:16px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--cyan),var(--cyan-deep)); color:#fff;
  font-family:var(--display); font-weight:700; font-size:1.25rem;
}
.member h3{font-size:1.12rem; font-weight:600}
.member .role{color:var(--cyan-ink); font-weight:500; font-size:.95rem; margin:3px 0 0}
.member .detail{color:var(--ink-soft); font-size:.92rem; margin:8px 0 0}

/* ── Gallery ────────────────────────────────────────── */
.gallery{display:grid; grid-template-columns:repeat(5,1fr); gap:12px}
.gallery a{
  border-radius:var(--radius-sm); overflow:hidden; aspect-ratio:1/1; background:var(--tint);
  box-shadow:var(--shadow-sm);
}
.gallery img{width:100%; height:100%; object-fit:cover; transition:transform .4s ease}
.gallery a:hover img{transform:scale(1.07)}

/* ── Reviews ────────────────────────────────────────── */
.reviews{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.review{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:26px; display:flex; flex-direction:column; gap:14px;
}
.review .stars{color:var(--star); letter-spacing:2px}
.review p{margin:0; color:var(--ink); font-size:.98rem}
.review .who{display:flex; align-items:center; gap:11px; margin-top:auto}
.review .who .av{
  width:38px; height:38px; border-radius:50%; background:var(--tint); color:var(--cyan-deep);
  display:grid; place-items:center; font-family:var(--display); font-weight:700;
}
.review .who b{font-family:var(--display); font-weight:600; font-size:.95rem}
.review .who span{display:block; font-size:.8rem; color:var(--ink-soft)}

/* ── Ubicación ──────────────────────────────────────── */
.ubic-grid{display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start}
.info-list{list-style:none; margin:0 0 28px; padding:0; display:grid; gap:16px}
.info-list li{display:flex; gap:14px; align-items:flex-start}
.info-ico{font-size:1.2rem; line-height:1.4}
.info-k{display:block; font-size:.78rem; text-transform:uppercase; letter-spacing:.09em; color:var(--ink-soft)}
.info-v{display:inline-block; font-family:var(--display); font-weight:600; font-size:1.02rem; margin-top:2px}
a.info-v:hover{color:var(--cyan-ink)}
.hours{border:1px solid var(--line); border-radius:var(--radius); overflow:hidden}
.hours-row{display:flex; justify-content:space-between; gap:16px; padding:13px 18px; font-size:.96rem}
.hours-row:not(:last-child){border-bottom:1px solid var(--line)}
.hours-row .day{color:var(--ink-soft)}
.hours-row .time{font-family:var(--display); font-weight:600}
.map-wrap{border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--line)}
.map{width:100%; height:420px; border:0; display:block}

/* ── CTA band ───────────────────────────────────────── */
.cta-band{background:linear-gradient(120deg,var(--cyan),var(--cyan-deep)); color:#fff}
.cta-inner{display:flex; align-items:center; justify-content:space-between; gap:28px; padding:52px 22px; flex-wrap:wrap}
.cta-inner h2{font-size:clamp(1.6rem,3vw,2.2rem); font-weight:700}
.cta-inner p{margin:8px 0 0; opacity:.92; font-size:1.05rem}

/* ── Footer ─────────────────────────────────────────── */
.site-foot{background:#101a20; color:#c6d3da; padding:56px 0 26px; font-size:.94rem}
.foot-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:40px}
.foot-logo{height:42px; background:#fff; padding:8px 12px; border-radius:9px}
.foot-note{color:#8ea2ad; margin:16px 0 0; max-width:34ch}
.site-foot h3{font-family:var(--display); font-size:.82rem; text-transform:uppercase; letter-spacing:.1em; color:#fff; margin:0 0 14px}
.foot-links{list-style:none; margin:0; padding:0; display:grid; gap:9px}
.foot-links a:hover{color:var(--cyan)}
.foot-hours{display:grid; gap:8px}
.foot-hours .fh{display:flex; justify-content:space-between; gap:14px}
.foot-hours .fh .day{color:#8ea2ad}
.foot-bottom{display:flex; justify-content:space-between; align-items:center; gap:16px; margin-top:40px; padding-top:22px; border-top:1px solid #23323b; color:#8ea2ad; font-size:.85rem; flex-wrap:wrap}
.foot-bottom a:hover{color:var(--cyan)}

/* ── Reveal animation ───────────────────────────────── */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1; transform:none}

/* ── Responsive ─────────────────────────────────────── */
@media (max-width:960px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .reviews{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .nav, .head-cta{display:none}
  .nav-toggle{display:flex}
  .site-head.open .nav{
    display:flex; position:absolute; top:70px; left:0; right:0; flex-direction:column; gap:0;
    background:#fff; border-bottom:1px solid var(--line); padding:8px 0;
  }
  .site-head.open .nav a{padding:14px 24px}
  .site-head.open .nav a::after{display:none}
  .hero-grid{grid-template-columns:1fr; gap:44px; padding:52px 22px 64px}
  .hero-media{max-width:440px; margin:0 auto}
  .ubic-grid{grid-template-columns:1fr; gap:32px}
  .reviews{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr; gap:30px}
}
@media (max-width:520px){
  .services-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .cta-inner{flex-direction:column; align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1; transform:none; transition:none}
  html{scroll-behavior:auto}
  *{transition:none !important}
}
