/* ============================================================
   VETERINARIA SOCIAL DE LA 29 — styles.css
   Base: diseño Claude Design · crema + verde + durazno + teal
   ============================================================ */
:root{
  --cream:#FBF6EE; --ink:#1E2A28; --ink-deep:#16201F;
  --peach:#F4A98A; --teal:#2F7E76; --green-ok:#5dde8a;
  --maxw:1100px;
  --fs:'Hanken Grotesk',system-ui,sans-serif;
  --fserif:'Newsreader',Georgia,serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--cream);color:var(--ink);font-family:var(--fs);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.skip{position:absolute;left:-999px;top:0;background:var(--peach);color:var(--ink);padding:.6rem 1rem;z-index:300;border-radius:0 0 6px 0}
.skip:focus{left:0}
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:3px}

/* keyframes blobs (del diseño) */
@keyframes bM{0%,100%{border-radius:58% 42% 35% 65%/55% 35% 65% 45%}25%{border-radius:42% 58% 65% 35%/45% 65% 35% 55%}50%{border-radius:65% 35% 42% 58%/35% 55% 45% 65%}75%{border-radius:35% 65% 58% 42%/65% 45% 55% 35%}}
@keyframes bD{0%,100%{transform:translate(0,0)}33%{transform:translate(-28px,20px)}66%{transform:translate(16px,-14px)}}
@keyframes bM2{0%,100%{border-radius:40% 60% 55% 45%/60% 40% 60% 40%}40%{border-radius:60% 40% 45% 55%/40% 60% 40% 60%}70%{border-radius:50% 50% 60% 40%/50% 70% 30% 50%}}
@keyframes bD2{0%,100%{transform:translate(0,0)}40%{transform:translate(20px,-18px)}75%{transform:translate(-12px,22px)}}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(-2deg)}}
@keyframes orbMorph{0%,100%{border-radius:58% 42% 38% 62%/55% 40% 60% 45%}50%{border-radius:42% 58% 62% 38%/45% 60% 40% 55%}}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--fs);font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:15px 30px;border-radius:3px;cursor:pointer;border:1.5px solid transparent;transition:opacity .2s,background .25s,color .25s,border-color .25s,transform .15s}
.btn:active{transform:scale(.97)}
.btn-peach{background:var(--peach);color:var(--ink)}
.btn-peach:hover{opacity:.86}
.btn-ghost{border-color:rgba(251,246,238,.2);color:var(--cream)}
.btn-ghost:hover{border-color:rgba(251,246,238,.5)}
.btn-dark{border-color:rgba(30,42,40,.2);color:var(--ink);font-size:12px;padding:13px 22px;letter-spacing:.09em}
.btn-dark:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:16px clamp(20px,5vw,56px);background:transparent;backdrop-filter:blur(0);transition:background .4s ease,border-color .4s ease,backdrop-filter .4s ease;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(30,42,40,.97);backdrop-filter:blur(18px);border-bottom-color:rgba(251,246,238,.08)}
.brand,.foot-brand{display:flex;align-items:baseline;gap:3px}
.b-la{font-family:var(--fs);font-weight:300;color:var(--cream);letter-spacing:-.01em}
.b-29{font-family:var(--fs);font-weight:900;color:var(--peach);letter-spacing:-.02em}
.nav .b-la,.nav .b-29{font-size:18px}
.nav-links{display:flex;gap:36px}
.nav-links a{font-size:12px;font-weight:500;color:rgba(251,246,238,.55);letter-spacing:.09em;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--cream)}
.nav-cta{display:inline-flex;align-items:center;gap:7px;background:var(--peach);color:var(--ink);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:10px 20px;border-radius:2px;transition:opacity .2s}
.nav-cta:hover{opacity:.82}
@media(max-width:720px){.nav-links{display:none}}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;background:var(--ink);overflow:hidden;display:flex;align-items:center}
.blob{position:absolute;pointer-events:none;will-change:transform,border-radius}
.blob-peach{right:-150px;bottom:-110px;width:600px;height:600px;background:var(--peach);opacity:.62;animation:bM 14s ease-in-out infinite,bD 18s ease-in-out infinite}
.blob-teal{left:-80px;top:-60px;width:300px;height:300px;background:var(--teal);opacity:.36;animation:bM2 11s ease-in-out infinite,bD2 16s ease-in-out infinite}
.hero-watermark{position:absolute;right:0;top:50%;transform:translateY(-50%);font-family:var(--fs);font-size:clamp(200px,30vw,480px);font-weight:900;color:transparent;-webkit-text-stroke:1.5px rgba(251,246,238,.05);line-height:.82;user-select:none;pointer-events:none;letter-spacing:-.05em;padding-right:3vw}
.hero-pets{position:absolute;right:6vw;bottom:6vh;width:clamp(190px,25vw,360px);height:clamp(260px,34vw,460px);z-index:2;pointer-events:none}
.hero-pet{position:absolute;left:0;bottom:0;width:100%;height:100%;object-fit:contain;object-position:bottom center;opacity:0;transition:opacity 1.1s ease;filter:drop-shadow(0 30px 40px rgba(0,0,0,.45));transform-origin:50% 82%;animation:heroFloat 7s ease-in-out infinite}
.hero-pet.is-active{opacity:1}
@keyframes heroFloat{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-12px) rotate(3deg)}}
.hero-inner{position:relative;z-index:3;padding:124px clamp(20px,5vw,56px) 84px;max-width:1000px;width:100%}
.pill{display:inline-flex;align-items:center;gap:9px;background:rgba(244,169,138,.1);border:1px solid rgba(244,169,138,.22);border-radius:24px;padding:6px 14px;margin-bottom:40px}
.pill-dot{width:6px;height:6px;border-radius:50%;background:var(--peach)}
.pill span:not(.pill-dot){font-size:11px;font-weight:500;letter-spacing:.14em;color:var(--peach);text-transform:uppercase}
.hero-vet{display:inline-flex;align-items:center;gap:11px;font-family:var(--fs);font-size:clamp(22px,3.6vw,40px);font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--peach);margin-bottom:6px;line-height:1}
.hero-vet svg{color:var(--peach);flex-shrink:0}
.hero-title{margin:0}
.hero-social{display:block;font-family:var(--fs);font-size:clamp(80px,14vw,220px);font-weight:900;color:var(--cream);line-height:.86;letter-spacing:-.04em}
.hero-dela{display:block;font-family:var(--fserif);font-style:italic;font-size:clamp(40px,6.5vw,106px);color:var(--peach);line-height:1.05;margin-bottom:48px}
.hero-lede{font-family:var(--fserif);font-size:clamp(15px,1.35vw,19px);color:rgba(251,246,238,.56);line-height:1.72;max-width:420px;margin-bottom:44px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-status{margin-top:40px;display:inline-flex;align-items:center;gap:10px}
.status-dot{width:8px;height:8px;border-radius:50%;background:var(--green-ok);box-shadow:0 0 0 3px rgba(93,222,138,.15)}
.status-dot.closed{background:var(--peach);box-shadow:0 0 0 3px rgba(244,169,138,.15)}
.status-txt{font-size:12px;font-weight:500;color:rgba(251,246,238,.42);letter-spacing:.07em}
.scroll-ind{position:absolute;bottom:28px;left:clamp(20px,5vw,56px);display:flex;align-items:center;gap:12px;opacity:.25}
.scroll-line{width:30px;height:1px;background:var(--cream)}
.scroll-ind span:last-child{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream)}

/* ---------- Encabezados de sección ---------- */
.sec-head{display:flex;align-items:center;gap:18px;margin-bottom:64px}
.sec-label{font-size:10px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--teal);white-space:nowrap}
.sec-label.light{color:rgba(251,246,238,.4)}
.sec-rule{flex:1;height:1px;background:rgba(30,42,40,.1)}
.sec-count{font-size:10px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(30,42,40,.28);white-space:nowrap}
@media(max-width:720px){.sec-count{display:none}}

/* ---------- SERVICIOS (rediseño con orbes) ---------- */
.servicios{position:relative;background:var(--cream);padding:clamp(72px,10vw,104px) 0}
.svc-list{display:flex;flex-direction:column;gap:clamp(40px,7vw,72px)}
.svc{display:flex;align-items:center;gap:clamp(28px,5vw,64px)}
.svc-rev{flex-direction:row-reverse}
.svc-orb{position:relative;flex-shrink:0;width:clamp(180px,26vw,300px);height:clamp(180px,26vw,300px);animation:orbMorph 16s ease-in-out infinite;overflow:visible}
.orb-peach{background:radial-gradient(circle at 38% 32%, #F8C3AC, var(--peach))}
.orb-teal{background:radial-gradient(circle at 38% 32%, #5AA59C, var(--teal))}
.svc-orb img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:auto;height:auto;max-width:122%;max-height:122%;object-fit:contain;filter:drop-shadow(0 16px 20px rgba(30,42,40,.3));transition:transform .5s cubic-bezier(.16,1,.3,1)}
.svc:hover .svc-orb img{transform:translate(-50%,-50%) scale(1.04)}
.svc-body{flex:1;min-width:0}
.svc-num{display:inline-block;font-size:11px;font-weight:700;color:var(--teal);letter-spacing:.18em;margin-bottom:14px}
.svc-name{font-family:var(--fs);font-size:clamp(28px,4.6vw,52px);font-weight:800;color:var(--ink);line-height:1;letter-spacing:-.025em;margin-bottom:14px}
.svc-desc{font-family:var(--fserif);font-size:clamp(15px,1.5vw,19px);color:rgba(30,42,40,.55);line-height:1.6;max-width:42ch}
.svc-quote{margin-top:clamp(48px,7vw,76px);padding-top:48px;border-top:1px solid rgba(30,42,40,.08)}
.svc-quote p{font-family:var(--fserif);font-style:italic;font-size:clamp(17px,2vw,24px);color:rgba(30,42,40,.4);line-height:1.55;max-width:520px}
@media(max-width:720px){
  .svc-list{gap:56px}
  .svc,.svc-rev{flex-direction:column;text-align:center;gap:18px}
  .svc-desc{margin:0 auto}
  .svc-orb{width:min(66vw,250px);height:min(66vw,250px)}
  .svc-orb img{top:50%;bottom:auto;transform:translate(-50%,-50%);max-width:116%;max-height:116%}
  .svc:hover .svc-orb img{transform:translate(-50%,-50%)}
}

/* mascotas flotantes entre secciones */
.sec-pet{position:absolute;z-index:5;pointer-events:none;filter:drop-shadow(0 16px 22px rgba(30,42,40,.22));animation:floaty 8s ease-in-out infinite}
.float-c{top:15%;right:4vw;left:auto;width:clamp(120px,13vw,180px)}
@media(max-width:720px){.sec-pet{display:none}.hero-pets{right:-4vw;bottom:2vh;width:46vw;height:62vw;opacity:.9}}

/* ---------- DECLARACIÓN ---------- */
.declara{position:relative;background:var(--teal);padding:clamp(72px,10vw,104px) 0;overflow:hidden}
.declara-quote{margin-bottom:64px}
.declara-big{font-family:var(--fserif);font-style:italic;font-size:clamp(28px,5vw,68px);color:var(--cream);line-height:1.18;font-weight:300;max-width:880px;margin-top:24px}
.declara-rule{height:1px;width:100%;background:rgba(251,246,238,.12);margin-bottom:56px}
.declara-grid{display:flex;gap:52px;flex-wrap:wrap;align-items:flex-start}
.d-col{flex:1;min-width:200px}
.d-label{font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:rgba(251,246,238,.38);margin-bottom:18px}
.d-days{font-size:15px;font-weight:600;color:rgba(251,246,238,.65);margin-bottom:6px}
.d-hours{font-family:var(--fs);font-size:clamp(32px,4.2vw,54px);font-weight:900;color:var(--peach);letter-spacing:-.02em;line-height:1}
.d-note{margin-top:12px;font-size:13px;color:rgba(251,246,238,.36)}
.d-div{width:1px;align-self:stretch;background:rgba(251,246,238,.12)}
.d-list{list-style:none;display:flex;flex-direction:column;gap:13px}
.d-list li{position:relative;padding-left:18px;font-size:15px;font-weight:500;color:var(--cream)}
.d-list li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--peach)}
.d-status{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:13px;min-width:110px}
.d-ring{width:76px;height:76px;border-radius:50%;border:1.5px solid rgba(251,246,238,.16);display:grid;place-items:center}
.d-ringdot{width:14px;height:14px;border-radius:50%;background:var(--green-ok);box-shadow:0 0 16px var(--green-ok)}
.d-ringdot.closed{background:var(--peach);box-shadow:0 0 16px var(--peach)}
.d-statxt{font-size:15px;font-weight:700;color:var(--cream)}
.d-statnote{font-size:11px;color:rgba(251,246,238,.36);letter-spacing:.07em}
@media(max-width:720px){.declara-grid{flex-direction:column}.d-div{display:none}}

/* ---------- CONTACTO ---------- */
.contacto{background:var(--cream);padding:clamp(72px,10vw,104px) 0}
.contacto-grid{display:flex;gap:64px;align-items:flex-start}
.c-col{flex:1;min-width:260px}
.c-label{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(30,42,40,.36);margin-bottom:24px}
.c-phone{display:block;font-family:var(--fs);font-size:clamp(26px,4vw,50px);font-weight:800;color:var(--ink);letter-spacing:-.025em;line-height:1.12;margin-bottom:6px;transition:color .2s}
.c-phone:last-of-type{margin-bottom:36px}
.c-phone:hover{color:var(--teal)}
.c-note{font-family:var(--fserif);font-size:15px;color:rgba(30,42,40,.46);line-height:1.7;max-width:340px}
.c-div{width:1px;align-self:stretch;min-height:300px;background:rgba(30,42,40,.09)}
.c-addr{font-family:var(--fs);font-size:clamp(22px,3vw,40px);font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1.1;margin-bottom:4px}
.c-sub{font-family:var(--fserif);font-size:17px;color:rgba(30,42,40,.52)}
.c-col .btn-dark{margin-top:24px}
.c-map{margin-top:26px;height:200px;border-radius:8px;overflow:hidden;border:1px solid rgba(47,126,118,.14)}
.c-map iframe{width:100%;height:100%;border:0;filter:grayscale(.25) contrast(1.02)}
@media(max-width:720px){.contacto-grid{flex-direction:column;gap:48px}.c-div{display:none}}

/* ---------- FAQ ---------- */
.faq{background:var(--cream);padding:0 0 clamp(72px,10vw,104px)}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-list details{border:1px solid rgba(30,42,40,.1);border-radius:10px;padding:0 22px;transition:border-color .25s,background .25s}
.faq-list details[open]{border-color:rgba(47,126,118,.4);background:rgba(47,126,118,.04)}
.faq-list summary{list-style:none;cursor:pointer;font-weight:700;font-size:1.02rem;padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:1rem;color:var(--ink)}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font-family:var(--fs);font-size:1.5rem;color:var(--teal);transition:transform .25s}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list details p{font-family:var(--fserif);color:rgba(30,42,40,.6);padding:0 0 18px;font-size:1rem}

/* ---------- FOOTER ---------- */
.foot{background:var(--ink);padding:56px 0 32px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:44px;border-bottom:1px solid rgba(251,246,238,.07)}
.foot-brand{flex-direction:column;align-items:flex-start;gap:0}
.foot-brand>span{display:inline}
.foot-brand .b-la,.foot-brand .b-29{font-size:24px}
.foot-name{font-family:var(--fserif);font-size:14px;color:rgba(251,246,238,.34);line-height:1.65;margin-top:10px}
.foot-h{font-size:10px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(251,246,238,.3);margin-bottom:14px}
.foot-col a,.foot-col p{display:block;font-size:14px;font-weight:500;color:rgba(251,246,238,.72);margin-bottom:7px;transition:color .2s}
.foot-col a:hover{color:var(--peach)}
.foot-col .dim{color:rgba(251,246,238,.34);font-weight:400}
.foot-maps{color:var(--peach)!important;font-size:12px!important;letter-spacing:.05em}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;gap:16px;flex-wrap:wrap}
.foot-bottom span:first-child{font-family:var(--fserif);font-size:13px;color:rgba(251,246,238,.2)}
.foot-by{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(251,246,238,.14)}

/* ---------- REVEAL ROBUSTO (sin JS => visible) ---------- */
.is-anim [data-r]{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.is-anim [data-r].in{opacity:1;transform:none}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  [data-r]{opacity:1!important;transform:none!important}
  .svc-orb img,.sec-pet,.hero-pet{animation:none!important}
}
