/* ============================================================
   Veterinaria Sta. María — Sistema de diseño (rediseño C · marca)
   Newsreader + Hanken Grotesk · paleta teal/verde/rojo
   ============================================================ */
:root{
    --paper:#F6FAFB;
    --paper-2:#E9F4F6;
    --paper-3:#D6EBEF;
    --ink:#15303A;
    --ink-2:#4C636C;
    --clay:#0891A1;
    --clay-d:#0E7490;
    --green:#0E6E7C;
    --green-d:#0B525C;
    --amber:#F59E0B;
    --red:#DC2626;
    --red-d:#B91C1C;
    --line:rgba(15,42,48,.13);
    --line-2:rgba(15,42,48,.07);
    --shadow:0 22px 48px -28px rgba(8,60,70,.5);
    --serif:"Newsreader",Georgia,"Times New Roman",serif;
    --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
    --wrap:1180px;
  }
  *{ box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  body{
    margin:0; background:var(--paper); color:var(--ink);
    font-family:var(--sans); font-size:17px; line-height:1.6;
    -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  }
  h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; margin:0; }
  p{ margin:0; }
  a{ color:inherit; text-decoration:none; }
  img{ max-width:100%; display:block; }
  .wrap{ max-width:var(--wrap); margin:0 auto; padding:0 24px; }
  :focus-visible{ outline:3px solid var(--clay); outline-offset:3px; border-radius:4px; }

  .eyebrow{ font-size:13px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; }

  /* ---- buttons ---- */
  .btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px;
    font-family:var(--sans); font-weight:700; font-size:16px; line-height:1;
    padding:16px 24px; border-radius:13px; border:2px solid transparent; cursor:pointer;
    transition:transform .14s ease, box-shadow .2s ease, background .2s ease; white-space:nowrap; }
  .btn i{ width:19px; height:19px; }
  .btn-clay{ background:var(--clay); color:#fff; box-shadow:0 12px 26px -12px rgba(188,86,48,.7); }
  .btn-clay:hover{ background:var(--clay-d); transform:translateY(-2px); }
  .btn-wa{ background:#1FA855; color:#fff; box-shadow:0 12px 26px -12px rgba(31,168,85,.6); }
  .btn-wa:hover{ background:#178a45; transform:translateY(-2px); }
  .btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
  .btn-ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
  .btn-light{ background:#fff; color:var(--ink); }
  .btn-light:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }

  /* ---- top utility strip ---- */
  .strip{ background:var(--green-d); color:#F4ECDD; font-size:14px; }
  .strip .wrap{ display:flex; align-items:center; justify-content:center; gap:22px; padding:9px 24px; flex-wrap:wrap; }
  .strip a{ display:inline-flex; align-items:center; gap:7px; font-weight:600; }
  .strip a:hover{ color:#fff; }
  .strip i{ width:15px; height:15px; color:var(--amber); }
  .strip .sep{ opacity:.4; }
  .dot{ width:8px; height:8px; border-radius:50%; background:#7AC143; box-shadow:0 0 0 0 rgba(122,193,67,.6); animation:pulse 2.2s infinite; }
  @keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(122,193,67,.55); } 70%{ box-shadow:0 0 0 9px rgba(122,193,67,0); } 100%{ box-shadow:0 0 0 0 rgba(122,193,67,0); } }

  /* ---- header ---- */
  header{ position:sticky; top:0; z-index:60; background:rgba(251,246,238,.9);
    backdrop-filter:saturate(140%) blur(10px); border-bottom:1px solid var(--line-2); }
  .nav{ display:flex; align-items:center; gap:28px; padding:14px 24px; max-width:var(--wrap); margin:0 auto; }
  .logo{ display:flex; align-items:center; gap:11px; }
  .logo img{ height:46px; width:auto; }
  .nav-links{ display:flex; gap:28px; margin-left:8px; }
  .nav-links a{ font-weight:600; font-size:15.5px; color:var(--ink-2); position:relative; padding:4px 0; }
  .nav-links a:hover{ color:var(--ink); }
  .nav-links a::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--clay); transition:width .2s; }
  .nav-links a:hover::after{ width:100%; }
  .nav-spacer{ flex:1; }
  .nav-cta{ display:flex; align-items:center; gap:12px; }
  .nav-phone{ display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--clay); }
  .nav-phone i{ width:18px; height:18px; }
  .burger{ display:none; background:none; border:1.5px solid var(--line); border-radius:11px; padding:9px; cursor:pointer; color:var(--ink); }
  .burger i{ width:24px; height:24px; display:block; }

  /* mobile menu */
  .mobile-menu{ display:none; position:fixed; inset:0; z-index:80; background:var(--paper);
    flex-direction:column; padding:22px 24px; }
  .mobile-menu.open{ display:flex; }
  .mm-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
  .mm-top img{ height:44px; }
  .mm-close{ background:none; border:1.5px solid var(--line); border-radius:11px; padding:9px; cursor:pointer; color:var(--ink); }
  .mm-close i{ width:24px; height:24px; display:block; }
  .mobile-menu nav{ display:flex; flex-direction:column; gap:4px; }
  .mobile-menu nav a{ font-family:var(--serif); font-size:30px; font-weight:500; padding:12px 0; border-bottom:1px solid var(--line-2); }
  .mm-actions{ margin-top:auto; display:flex; flex-direction:column; gap:12px; padding-top:20px; }
  .mm-actions .btn{ width:100%; padding:18px; font-size:17px; }

  /* ---- hero ---- */
  .hero{ position:relative; min-height:clamp(560px,82vh,820px); display:flex; align-items:flex-end;
    overflow:hidden; }
  .hero .ph{ position:absolute; inset:0; }
  .hero::after{ content:""; position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(36,26,16,.32) 0%, rgba(36,26,16,.18) 38%, rgba(33,24,15,.82) 100%); }
  .hero .wrap{ position:relative; z-index:2; padding-top:60px; padding-bottom:58px; width:100%; }
  .hero-badge{ display:inline-flex; align-items:center; gap:9px; background:rgba(255,255,255,.14);
    border:1px solid rgba(255,255,255,.3); backdrop-filter:blur(4px); color:#fff;
    font-weight:700; font-size:13.5px; letter-spacing:.04em; padding:8px 15px; border-radius:999px; margin-bottom:22px; white-space:nowrap; }
  .hero h1{ color:#fff; font-size:clamp(40px,6.6vw,80px); max-width:16ch; }
  .hero h1 em{ font-style:italic; color:var(--amber); }
  .hero p.sub{ color:rgba(255,255,255,.92); font-size:clamp(17px,2vw,21px); max-width:48ch; margin:22px 0 0; line-height:1.5; }
  .hero-cta{ display:flex; gap:14px; margin-top:30px; flex-wrap:wrap; }
  .hero-wa-note{ color:rgba(255,255,255,.78); font-size:15px; margin-top:16px; display:flex; align-items:center; gap:8px; }
  .hero-wa-note a{ color:#fff; font-weight:700; text-decoration:underline; text-underline-offset:3px; }

  /* ---- placeholders ---- */
  .ph{ position:relative; overflow:hidden;
    background-color:var(--paper-3);
    background-image:repeating-linear-gradient(135deg, rgba(8,145,161,.10) 0 2px, transparent 2px 15px); }
  .ph[data-label]::before{ content:attr(data-label); position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
    font-family:ui-monospace,"SF Mono",Menlo,monospace; font-size:12.5px; letter-spacing:.02em; color:var(--ink-2);
    background:rgba(251,246,238,.82); border:1px solid var(--line); border-radius:8px; padding:7px 12px; white-space:nowrap; max-width:88%; text-align:center; }
  .hero .ph{ background-color:#0e3a42;
    background-image:repeating-linear-gradient(135deg, rgba(0,0,0,.14) 0 2px, transparent 2px 17px),
      linear-gradient(150deg,#125862,#0c3138); }
  .hero .ph::before{ z-index:3; top:24px; left:auto; right:24px; transform:none; background:rgba(0,0,0,.5); color:#f3ead9; border-color:rgba(255,255,255,.3); }

  /* ---- trust bar ---- */
  .trust{ background:var(--green); color:#F2ECDF; }
  .trust .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:2px; padding:0; }
  .trust .item{ padding:28px 26px; display:flex; flex-direction:column; gap:4px; position:relative; }
  .trust .item + .item::before{ content:""; position:absolute; left:0; top:24px; bottom:24px; width:1px; background:rgba(255,255,255,.15); }
  .trust .big{ font-family:var(--serif); font-size:30px; font-weight:600; color:#fff; line-height:1; }
  .trust .lbl{ font-size:14.5px; color:rgba(242,236,223,.82); font-weight:500; }

  /* ---- section scaffolding ---- */
  section{ padding:84px 0; }
  .sec-head{ max-width:640px; margin-bottom:46px; }
  .sec-head .eyebrow{ color:var(--clay); display:block; margin-bottom:14px; }
  .sec-head h2{ font-size:clamp(32px,4.4vw,52px); }
  .sec-head p{ color:var(--ink-2); font-size:18px; margin-top:16px; }

  /* ---- services ---- */
  .svc-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:0; border:1px solid var(--line); border-radius:20px; overflow:hidden; background:#fff; }
  .svc{ padding:30px 26px; border-right:1px solid var(--line-2); border-bottom:1px solid var(--line-2); transition:background .2s; }
  .svc:hover{ background:var(--paper-2); }
  .svc .ic{ width:46px; height:46px; border-radius:12px; background:var(--paper-2); color:var(--clay);
    display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
  .svc:hover .ic{ background:var(--clay); color:#fff; }
  .svc .ic i{ width:23px; height:23px; }
  .svc h3{ font-size:21px; margin-bottom:7px; }
  .svc p{ color:var(--ink-2); font-size:15px; line-height:1.5; }

  /* ---- urgency banner ---- */
  .urg{ background:var(--red); color:#fff; border-radius:0; padding:0; }
  .urg-inner{ max-width:var(--wrap); margin:0 auto; padding:64px 24px; display:flex; align-items:center; gap:40px; flex-wrap:wrap; }
  .urg-text{ flex:1; min-width:280px; }
  .urg .eyebrow{ color:rgba(255,255,255,.78); display:block; margin-bottom:14px; }
  .urg h2{ color:#fff; font-size:clamp(30px,4.4vw,50px); max-width:18ch; }
  .urg h2 em{ font-style:italic; }
  .urg p{ color:rgba(255,255,255,.9); font-size:18px; margin-top:14px; max-width:46ch; }
  .urg-cta{ display:flex; flex-direction:column; gap:13px; min-width:230px; }
  .urg-cta .btn{ font-size:17px; padding:18px 26px; }
  .urg-cta .btn-light{ color:var(--red-d); }

  /* ---- why us ---- */
  .why{ background:var(--paper-2); }
  .why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
  .why-card{ background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:34px 30px; }
  .why-card .ic{ width:52px; height:52px; border-radius:13px; background:var(--green); color:#fff;
    display:flex; align-items:center; justify-content:center; margin-bottom:20px; }
  .why-card .ic i{ width:26px; height:26px; }
  .why-card h3{ font-size:24px; margin-bottom:10px; }
  .why-card p{ color:var(--ink-2); font-size:16px; }

  /* ---- nosotros ---- */
  .about-grid{ display:grid; grid-template-columns:1.05fr 1fr; gap:56px; align-items:center; }
  .about-img{ border-radius:20px; aspect-ratio:5/4; box-shadow:var(--shadow); }
  .about-stat{ display:flex; gap:30px; margin:26px 0 30px; }
  .about-stat .n{ font-family:var(--serif); font-size:46px; font-weight:600; color:var(--clay); line-height:1; }
  .about-stat .t{ font-size:14.5px; color:var(--ink-2); margin-top:4px; }
  .about-text h2{ font-size:clamp(30px,4vw,46px); }
  .about-text p{ color:var(--ink-2); font-size:17.5px; margin-top:18px; }
  .about-text .lead{ color:var(--ink); font-size:20px; }

  /* ---- testimonials ---- */
  .testi{ background:var(--green-d); color:#F2ECDF; }
  .testi .sec-head .eyebrow{ color:var(--amber); }
  .testi .sec-head h2{ color:#fff; }
  .t-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
  .t-card{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:18px; padding:30px 28px; display:flex; flex-direction:column; }
  .stars{ display:flex; gap:3px; color:var(--amber); margin-bottom:16px; }
  .stars i{ width:18px; height:18px; fill:var(--amber); }
  .t-card blockquote{ margin:0; font-family:var(--serif); font-size:20px; line-height:1.42; color:#fff; font-style:italic; }
  .t-foot{ margin-top:auto; padding-top:22px; display:flex; align-items:center; gap:12px; }
  .t-avatar{ width:42px; height:42px; border-radius:50%; background:var(--clay); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:16px; }
  .t-name{ font-weight:700; font-size:15.5px; color:#fff; }
  .t-src{ font-size:13px; color:rgba(242,236,223,.6); }

  /* ---- final cta ---- */
  .final{ text-align:center; }
  .final .eyebrow{ color:var(--clay); display:block; margin-bottom:16px; }
  .final h2{ font-size:clamp(34px,5vw,60px); max-width:18ch; margin:0 auto; }
  .final p{ color:var(--ink-2); font-size:19px; margin:18px auto 32px; max-width:50ch; }
  .final-cta{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

  /* ---- footer ---- */
  footer{ background:var(--ink); color:#D9CFC2; padding:64px 0 120px; }
  .foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:44px; }
  .foot-brand img{ height:54px; margin-bottom:18px; filter:brightness(1.05); }
  .foot-brand p{ font-size:15px; color:#A99C8C; max-width:34ch; }
  .foot-col h4{ font-family:var(--sans); font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--amber); margin:0 0 16px; }
  .foot-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
  .foot-col li{ display:flex; gap:11px; font-size:15.5px; color:#D9CFC2; align-items:flex-start; }
  .foot-col li i{ width:18px; height:18px; color:var(--amber); flex-shrink:0; margin-top:3px; }
  .foot-col a:hover{ color:#fff; text-decoration:underline; text-underline-offset:3px; }
  .foot-bottom{ max-width:var(--wrap); margin:48px auto 0; padding:24px 24px 0; border-top:1px solid rgba(255,255,255,.1);
    display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:13.5px; color:#897C6C; }

  /* ---- mobile sticky bar ---- */
  .sticky-bar{ display:none; position:fixed; left:0; right:0; bottom:0; z-index:70;
    background:var(--paper); border-top:1px solid var(--line); padding:10px 12px calc(10px + env(safe-area-inset-bottom));
    gap:10px; box-shadow:0 -8px 28px -16px rgba(42,32,23,.4); }
  .sticky-bar .btn{ flex:1; padding:15px 10px; font-size:16px; border-radius:12px; }

  /* ================= RESPONSIVE ================= */
  @media (max-width:1000px){
    .svc-grid{ grid-template-columns:repeat(3,1fr); }
    .trust .wrap{ grid-template-columns:repeat(2,1fr); }
    .trust .item:nth-child(3)::before, .trust .item:nth-child(odd)::before{ display:none; }
  }
  @media (max-width:860px){
    .nav-links{ display:none; }
    .nav-phone span{ display:none; }
    .burger{ display:block; }
    .nav-cta .btn{ display:none; }
    .why-grid{ grid-template-columns:1fr; }
    .t-grid{ grid-template-columns:1fr; }
    .about-grid{ grid-template-columns:1fr; gap:32px; }
    .about-img{ order:-1; }
    .foot-grid{ grid-template-columns:1fr; gap:34px; }
    .sticky-bar{ display:flex; }
    section{ padding:60px 0; }
    .urg-inner{ padding:48px 24px; }
  }
  @media (max-width:560px){
    body{ font-size:16px; }
    .svc-grid{ grid-template-columns:repeat(2,1fr); border-radius:16px; }
    .trust .wrap{ grid-template-columns:1fr 1fr; }
    .hero-cta .btn{ flex:1; }
    .strip .horario{ display:none; }
    .about-stat{ gap:22px; }
  }
  @media (prefers-reduced-motion:reduce){ *{ animation:none !important; scroll-behavior:auto; } }

/* ---- imágenes reales (rediseño C) ---- */
.hero-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; z-index:0; }
.hero::after{ z-index:1; }
img.about-img{ width:100%; height:100%; object-fit:cover; }

/* ============================================================
   PAGE HERO (inner) + componentes de páginas internas
   ============================================================ */
.nav-links a.active{ color:var(--ink); }
.nav-links a.active::after{ width:100%; }

.page-hero{ background:linear-gradient(150deg,var(--clay-d),var(--green-d)); color:#fff; padding:52px 0 46px; }
.page-hero .eyebrow{ color:rgba(255,255,255,.82); display:block; margin-bottom:12px; }
.page-hero h1{ color:#fff; font-size:clamp(32px,5vw,54px); max-width:20ch; }
.page-hero p{ color:rgba(255,255,255,.9); font-size:18px; margin-top:14px; max-width:56ch; }
.breadcrumb{ display:flex; gap:8px; align-items:center; font-size:14px; color:rgba(255,255,255,.72); margin-bottom:20px; flex-wrap:wrap; }
.breadcrumb a:hover{ color:#fff; }
.breadcrumb span{ opacity:.5; }

.detail{ display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
.detail.reverse .detail-img{ order:2; }
img.detail-img{ border-radius:20px; aspect-ratio:5/4; width:100%; height:100%; object-fit:cover; box-shadow:var(--shadow); }
.detail h2{ font-size:clamp(28px,4vw,42px); }
.detail p{ color:var(--ink-2); font-size:17.5px; margin-top:16px; }
.detail-list{ list-style:none; padding:0; margin:22px 0 0; display:flex; flex-direction:column; gap:12px; }
.detail-list li{ display:flex; gap:12px; align-items:flex-start; font-size:16px; }
.detail-list li i{ width:22px; height:22px; color:var(--green); flex-shrink:0; margin-top:2px; }
.schedule{ display:inline-flex; align-items:center; gap:8px; margin-top:22px; background:var(--paper-2); color:var(--clay-d); border:1px solid var(--line); padding:8px 14px; border-radius:999px; font-weight:600; font-size:14.5px; }
.schedule i{ width:17px; height:17px; }
.detail-cta{ margin-top:26px; display:flex; gap:12px; flex-wrap:wrap; }

.related{ background:var(--paper-2); }
.related-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.related-grid a{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px; display:flex; flex-direction:column; gap:9px; transition:transform .18s, box-shadow .18s; }
.related-grid a:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.related-grid .ic{ width:40px; height:40px; border-radius:10px; background:var(--paper-3); color:var(--clay); display:flex; align-items:center; justify-content:center; }
.related-grid .ic i{ width:21px; height:21px; }
.related-grid h4{ font-family:var(--serif); font-weight:500; font-size:17px; }

.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:start; }
.contact-form{ background:#fff; border:1px solid var(--line); border-radius:20px; padding:32px; box-shadow:var(--shadow); }
.contact-form h2{ font-size:24px; margin-bottom:20px; }
.fg{ margin-bottom:18px; }
.fg label{ display:block; font-weight:600; font-size:14px; margin-bottom:7px; color:var(--ink); }
.fg input, .fg textarea{ width:100%; padding:13px 15px; border:1.5px solid var(--line); border-radius:12px; font-family:var(--sans); font-size:16px; color:var(--ink); background:var(--paper); }
.fg input:focus, .fg textarea:focus{ outline:none; border-color:var(--clay); box-shadow:0 0 0 3px rgba(8,145,161,.13); }
.fg textarea{ resize:vertical; min-height:120px; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.info-card{ background:var(--paper-2); border:1px solid var(--line); border-radius:18px; padding:26px; margin-bottom:18px; }
.info-card h3{ font-size:20px; margin-bottom:16px; }
.info-row{ display:flex; gap:12px; align-items:flex-start; margin-bottom:13px; font-size:15.5px; color:var(--ink-2); }
.info-row i{ width:20px; height:20px; color:var(--clay); flex-shrink:0; margin-top:2px; }
.info-row a{ color:var(--clay); }
.info-row a:hover{ text-decoration:underline; }
.map{ border-radius:18px; overflow:hidden; border:1px solid var(--line); }
.map iframe{ display:block; width:100%; height:360px; border:0; }

.team-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,220px)); gap:22px; justify-content:center; }
.team-card{ text-align:center; }
.team-card img{ width:100%; aspect-ratio:1; object-fit:cover; border-radius:16px; box-shadow:var(--shadow); }
.team-card h3{ font-size:18px; margin-top:14px; }
.team-card p{ color:var(--ink-2); font-size:14px; }

@media (max-width:860px){
  .detail{ grid-template-columns:1fr; gap:30px; }
  .detail .detail-img, .detail.reverse .detail-img{ order:-1; }
  .related-grid{ grid-template-columns:repeat(2,1fr); }
  .contact-grid{ grid-template-columns:1fr; gap:30px; }
  .team-grid{ grid-template-columns:repeat(2,1fr); }
}
