/* =========================
GROOMIA - Style (PetPal Inspired)
========================= */

:root{
  --g-blue:#2f6bff;
  --g-blue-2:#1f4fd6;
  --g-ink:#0f172a;
  --g-text:#334155;
  --g-muted:#64748b;
  --g-bg:#ffffff;
  --g-tint:#f6f8ff;
  --g-card:#ffffff;
  --g-border:#e9eef8;
  --g-shadow: 0 20px 45px rgba(15, 23, 42, .10);
  --radius-xl: 22px;
  --radius-lg: 18px;
  --radius-md: 14px;
}

/* Base */
*{ box-sizing:border-box; }
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--g-bg);
  color: var(--g-ink);
  padding-top: 78px;
  line-height: 1.65;
}
a{ text-decoration:none; }
img{ max-width:100%; height:auto; }

.p-muted{ color: var(--g-muted); }
.h2-title{
  font-weight: 800;
  letter-spacing: -0.02em;
  font-size: clamp(1.6rem, 2vw, 2.15rem);
}
.section-pad{ padding: 84px 0; }
.section-tint{ background: var(--g-tint); }
.section-head{ margin-bottom: 34px; }

/* Navbar */
.nav-soft{
  height: 78px;
  border-bottom: 1px solid rgba(233,238,248,.9);
}
.nav-soft .nav-link{
  color: var(--g-text) !important;
  font-weight: 600;
  padding: .55rem .85rem;
  border-radius: 999px;
}
.nav-soft .nav-link:hover{
  background: rgba(47,107,255,.08);
  color: var(--g-blue) !important;
}
.btn-groomia{
  background: var(--g-blue);
  border: none;
  color: #fff;
  font-weight: 800;
  letter-spacing: .2px;
  box-shadow: 0 14px 28px rgba(47,107,255,.22);
}
.btn-groomia:hover{ background: var(--g-blue-2); color:#fff; }
.btn-outline-dark{ border-width: 2px; font-weight: 800; }

/* Hero */
.hero-petpal{
  position: relative;
  padding: 86px 0 70px;
  overflow:hidden;
  background:
    radial-gradient(1000px 500px at 10% 20%, rgba(47,107,255,.18), transparent 60%),
    radial-gradient(800px 500px at 90% 20%, rgba(47,107,255,.14), transparent 55%),
    linear-gradient(180deg, #ffffff, #ffffff);
}
.hero-shape{
  position:absolute;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  filter: blur(0px);
  opacity: .25;
  pointer-events:none;
}
.hero-shape-1{
  left:-200px; top:-180px;
  background: radial-gradient(circle at 30% 30%, rgba(47,107,255,.9), rgba(47,107,255,0));
}
.hero-shape-2{
  right:-210px; bottom:-220px;
  background: radial-gradient(circle at 30% 30%, rgba(47,107,255,.75), rgba(47,107,255,0));
}
.badge-soft{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(47,107,255,.08);
  border: 1px solid rgba(47,107,255,.15);
  font-weight: 700;
  color: var(--g-text);
}
.badge-soft .dot{
  width:10px; height:10px; border-radius:50%;
  background: var(--g-blue);
  box-shadow: 0 0 0 6px rgba(47,107,255,.15);
}
.display-title{
  font-weight: 900;
  letter-spacing: -0.03em;
  font-size: clamp(2.05rem, 3.3vw, 3.1rem);
  line-height: 1.08;
}
.text-accent{ color: var(--g-blue); }
.lead-soft{
  color: var(--g-text);
  font-size: 1.08rem;
  max-width: 560px;
}

.hero-metrics{
  display:flex;
  gap:14px;
  flex-wrap: wrap;
}
.metric{
  background: var(--g-card);
  border: 1px solid var(--g-border);
  border-radius: 999px;
  padding: 10px 14px;
  box-shadow: 0 10px 22px rgba(15,23,42,.06);
}
.metric-n{ font-weight: 900; }
.metric-s{ color: var(--g-muted); font-size: .92rem; }

.hero-media{
  position: relative;
  border-radius: var(--radius-xl);
  background: #fff;
  border: 1px solid var(--g-border);
  box-shadow: var(--g-shadow);
  padding: 18px;
}
.hero-img{
  border-radius: calc(var(--radius-xl) - 6px);
  width: 100%;
  max-height: 430px;
  object-fit: cover;
}
.floating-card{
  position:absolute;
  background:#fff;
  border: 1px solid var(--g-border);
  border-radius: 16px;
  padding: 12px 14px;
  box-shadow: 0 16px 30px rgba(15,23,42,.12);
  width: 220px;
}
.floating-card-1{ left: -10px; bottom: 18px; }
.floating-card-2{ right: -10px; top: 18px; }
.fc-title{ font-weight: 900; }
.fc-text{ color: var(--g-muted); font-size: .92rem; }

/* Cards */
.card-soft{
  background: var(--g-card);
  border: 1px solid var(--g-border);
  border-radius: var(--radius-xl);
  padding: 28px;
  box-shadow: 0 14px 30px rgba(15,23,42,.06);
}
.icon-pill{
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(47,107,255,.10);
  border: 1px solid rgba(47,107,255,.18);
  font-size: 24px;
}
.link-soft{
  font-weight: 900;
  color: var(--g-blue);
}
.link-soft:hover{ color: var(--g-blue-2); }

/* Pets */
.pet-card-soft{
  background: #fff;
  border: 1px solid var(--g-border);
  border-radius: var(--radius-xl);
  overflow:hidden;
  box-shadow: 0 16px 32px rgba(15,23,42,.07);
}
.pet-img{
  width:100%;
  height: 180px;
  object-fit: cover;
}
.pet-meta{
  padding: 14px 14px 16px;
}
.pet-name{
  font-weight: 900;
}
.pet-sub{
  color: var(--g-muted);
  font-size: .92rem;
}

/* Club visual */
.mini-feature{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding: 14px 14px;
  background:#fff;
  border: 1px solid var(--g-border);
  border-radius: 18px;
  box-shadow: 0 12px 24px rgba(15,23,42,.06);
}
.mini-ico{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(47,107,255,.10);
  border: 1px solid rgba(47,107,255,.18);
  font-size: 18px;
}
.mini-title{ font-weight: 900; }
.mini-text{ color: var(--g-muted); font-size: .92rem; }

.club-card-visual{
  background: linear-gradient(135deg, rgba(47,107,255,.96), rgba(31,79,214,.96));
  color:#fff;
  border-radius: var(--radius-xl);
  padding: 26px;
  box-shadow: 0 26px 55px rgba(47,107,255,.25);
}
.club-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.club-label{
  opacity:.9;
  font-weight: 800;
  font-size: .92rem;
}
.club-name{
  font-weight: 950;
  font-size: 1.35rem;
  letter-spacing:-.02em;
}
.club-stats{
  display:flex;
  gap:14px;
  margin-top: 18px;
}
.cs{
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 18px;
  padding: 12px 14px;
  flex:1;
}
.cs-n{ font-weight: 950; font-size: 1.2rem; }
.cs-s{ opacity:.9; font-size: .92rem; }

.club-progress .cp-text{
  font-weight: 900;
  margin-bottom: 10px;
}
.cp-bar{
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.20);
  overflow:hidden;
}
.cp-fill{
  height:100%;
  border-radius: 999px;
  background: rgba(255,255,255,.95);
}
.club-foot{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.chip{
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.20);
  padding: 8px 12px;
  border-radius: 999px;
  font-weight: 800;
  font-size: .88rem;
}

/* Lists & notes */
.list-check{
  margin: 0;
  padding-left: 0;
  list-style: none;
}
.list-check li{
  padding-left: 28px;
  margin: 10px 0;
  position: relative;
  color: var(--g-text);
  font-weight: 600;
}
.list-check li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  width: 20px;
  height: 20px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 8px;
  background: rgba(47,107,255,.12);
  border: 1px solid rgba(47,107,255,.18);
  color: var(--g-blue);
  font-weight: 900;
}
.note-soft{
  background:#fff;
  border: 1px solid var(--g-border);
  border-radius: var(--radius-xl);
  padding: 14px 18px;
  box-shadow: 0 12px 24px rgba(15,23,42,.06);
  display:inline-block;
}

/* CTA */
.cta-petpal{
  padding: 70px 0 90px;
  background: linear-gradient(180deg, #ffffff, var(--g-tint));
}
.cta-box{
  background: #fff;
  border: 1px solid var(--g-border);
  border-radius: var(--radius-xl);
  padding: 26px;
  box-shadow: var(--g-shadow);
}
.cta-title{ font-weight: 950; letter-spacing:-.02em; }
.cta-sub{ color: var(--g-muted); }

/* Footer */
.footer-petpal{
  padding: 60px 0 30px;
  background: #0b1220;
  color: rgba(255,255,255,.85);
}
.footer-petpal .p-muted{ color: rgba(255,255,255,.70); }
.f-title{
  font-weight: 900;
  margin-bottom: 10px;
}
.f-links{
  list-style:none;
  padding-left:0;
  margin:0;
}
.f-links li{ margin: 10px 0; }
.f-links a{
  color: rgba(255,255,255,.78);
  font-weight: 700;
}
.f-links a:hover{ color: #fff; }

.f-bottom{
  margin-top: 34px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.12);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  color: rgba(255,255,255,.70);
  font-weight: 700;
}
.dot-sep{ opacity: .7; }

/* Responsive */
@media (max-width: 991px){
  .hero-petpal{ padding: 64px 0 50px; }
  .floating-card{ display:none; }
  .hero-media{ margin-top: 14px; }
  .section-pad{ padding: 70px 0; }
}
@media (max-width: 575px){
  body{ padding-top: 74px; }
  .nav-soft{ height: 74px; }
  .hero-img{ max-height: 320px; }
}
/* HERO MINI */
.hero-mini{
padding:100px 0 60px;
background:linear-gradient(180deg,#ffffff,#f6f8ff);
text-align:center;
}

/* CHIPS SUAVES */
.chip-soft{
background:rgba(47,107,255,.12);
border:1px solid rgba(47,107,255,.18);
padding:8px 14px;
border-radius:999px;
font-weight:800;
font-size:.9rem;
}
/* =========================
LUXURY VERSION
========================= */

.lux-hero{
padding:140px 0 110px;
background:#ffffff;
}

.lux-title{
font-size:2.6rem;
font-weight:900;
letter-spacing:-1px;
}

.lux-sub{
color:#555;
font-size:1.1rem;
max-width:650px;
margin:20px auto 0;
}

.lux-section-title{
font-size:2rem;
font-weight:800;
margin-bottom:15px;
}

.lux-text{
color:#555;
font-size:1.05rem;
}

.lux-list{
list-style:none;
padding-left:0;
margin-top:25px;
}

.lux-list li{
margin-bottom:12px;
font-weight:600;
}

.lux-img{
border-radius:20px;
box-shadow:0 25px 50px rgba(0,0,0,.08);
}

.lux-club{
background:#f6f8ff;
padding:100px 0;
}

.lux-card{
background:white;
padding:40px;
border-radius:25px;
box-shadow:0 25px 50px rgba(0,0,0,.08);
max-width:500px;
margin:40px auto 0;
}

.lux-card-title{
font-weight:900;
font-size:1.3rem;
}

.lux-levels span{
margin:0 10px;
font-weight:800;
}

.lux-cta{
background:#0b1220;
color:white;
padding:110px 0;
}
/* =========================
SUCURSALES PREMIUM
========================= */

.sucursal-card{
background:white;
border-radius:25px;
box-shadow:0 25px 50px rgba(0,0,0,.07);
overflow:hidden;
transition:.3s;
height:100%;
}

.sucursal-card:hover{
transform:translateY(-8px);
box-shadow:0 30px 60px rgba(0,0,0,.12);
}

.sucursal-header{
background:#0b1220;
color:white;
padding:20px;
font-weight:800;

font-size:1.1rem;
}

.sucursal-body{
padding:25px;
}
/* FILTRO BOX */
.filter-box{
background:white;
padding:25px;
border-radius:25px;
box-shadow:0 15px 30px rgba(0,0,0,.06);
}

.pet-level{
font-weight:800;
font-size:.9rem;
}
/* CLUB PRO VISUAL CARD */

.club-visual-card{
background:linear-gradient(135deg,#2f6bff,#1f4fd6);
color:white;
border-radius:30px;
padding:35px;
box-shadow:0 30px 60px rgba(47,107,255,.3);
}

.club-pet-name{
font-size:1.3rem;
font-weight:900;
}

.nivel-box{
background:white;
border-radius:20px;
padding:30px;
box-shadow:0 20px 40px rgba(0,0,0,.07);
font-weight:800;
}
/* PERFIL MASCOTA */

.perfil-foto-box{
background:white;
padding:15px;
border-radius:25px;
box-shadow:0 25px 50px rgba(0,0,0,.08);
}

.perfil-foto{
width:100%;
border-radius:20px;
object-fit:cover;
}

.perfil-sub{
color:#666;
font-size:1.1rem;
}

.perfil-box{
background:white;
padding:20px;
border-radius:18px;
box-shadow:0 15px 30px rgba(0,0,0,.05);
font-weight:600;
}

.perfil-nivel{
font-size:1.1rem;
font-weight:800;
}

.perfil-descripcion{
background:#f6f8ff;
padding:20px;
border-radius:18px;
}
/* =========================
AUTH PREMIUM
========================= */

.auth-body{
background:
radial-gradient(circle at 20% 30%, rgba(47,107,255,.12), transparent 40%),
radial-gradient(circle at 80% 70%, rgba(47,107,255,.12), transparent 40%),
#ffffff;
min-height:100vh;
display:flex;
align-items:center;
justify-content:center;
}

.auth-wrapper{
width:100%;
padding:20px;
}

.auth-card{
background:white;
max-width:420px;
margin:auto;
padding:40px;
border-radius:30px;
box-shadow:0 30px 60px rgba(0,0,0,.08);
}

.auth-title{
font-weight:900;
font-size:1.8rem;
}

.auth-subtitle{
color:#666;
font-size:.95rem;
}

.auth-input{
height:50px;
border-radius:14px;
border:1px solid #e5e7eb;
padding-left:15px;
}

.auth-input:focus{
border-color:#2f6bff;
box-shadow:0 0 0 2px rgba(47,107,255,.1);
}

.toggle-pass{
position:absolute;
right:15px;
top:38px;
cursor:pointer;
font-size:1rem;
}

.auth-footer a{
color:#2f6bff;
font-weight:700;
text-decoration:none;
}

.auth-footer a:hover{
text-decoration:underline;
}

/* RESPONSIVE */

@media(max-width:576px){

.auth-card{
padding:30px 25px;
border-radius:25px;
}

}
/* LOGIN PRO */

.auth-section{
padding:140px 0 100px;
background:
radial-gradient(circle at 20% 20%, rgba(47,107,255,.08), transparent 40%),
radial-gradient(circle at 80% 80%, rgba(47,107,255,.08), transparent 40%);
}

.auth-card-pro{
background:white;
padding:40px;
border-radius:30px;
box-shadow:0 30px 60px rgba(0,0,0,.08);
}

.auth-input{
height:50px;
border-radius:14px;
border:1px solid #e5e7eb;
}

.auth-input:focus{
border-color:#2f6bff;
box-shadow:0 0 0 2px rgba(47,107,255,.1);
}

.auth-link{
color:#2f6bff;
font-weight:600;
text-decoration:none;
}

.auth-link:hover{
text-decoration:underline;
}

.toggle-pass{
position:absolute;
right:15px;
top:38px;
cursor:pointer;
}

@media(max-width:576px){
.auth-section{
padding:120px 20px 80px;
}
.auth-card-pro{
padding:30px 25px;
}
}
/* =========================
DASHBOARD PRO
========================= */

/* =========================
DASHBOARD SECTION PRO
========================= */

.dashboard-section{
padding:40px 0 70px;
background:#f8f9ff;
}

.dashboard-header{
display:flex;
justify-content:space-between;
align-items:center;
flex-wrap:wrap;
gap:15px;
margin-bottom:20px;
}

.dashboard-title{
font-weight:900;
font-size:1.8rem;
margin-bottom:4px;
}

.dashboard-sub{
color:#666;
font-size:.95rem;
margin:0;
}

.metric-card{
background:white;
padding:30px;
border-radius:25px;
box-shadow:0 20px 40px rgba(0,0,0,.06);
text-align:center;
}

.metric-icon{
font-size:1.8rem;
margin-bottom:10px;
}

.metric-number{
font-size:1.5rem;
font-weight:900;
}

.metric-label{
color:#666;
font-size:.9rem;
}

.action-card{
background:white;
padding:30px;
border-radius:25px;
box-shadow:0 20px 40px rgba(0,0,0,.06);
}

@media(max-width:768px){
.dashboard-header{
flex-direction:column;
align-items:flex-start;
}
}
/* FOOTER LEGAL */

.small-footer{
font-size:13px;
color:rgba(255,255,255,.65);
margin-top:25px;
display:flex;
flex-wrap:wrap;
justify-content:center;
gap:8px;
text-align:center;
}

.small-footer a{
color:rgba(255,255,255,.8);
text-decoration:none;
font-weight:600;
}

.small-footer a:hover{
text-decoration:underline;
color:#ffffff;
}

.dot-sep{
opacity:.5;
}
/* FORM CARD PRO */

.form-card-pro{
background:white;
padding:40px;
border-radius:30px;
box-shadow:0 30px 60px rgba(0,0,0,.07);
}

@media(max-width:768px){
.form-card-pro{
padding:25px;
}
}
.club-stats{
display:flex;
justify-content:space-between;
}

.cs{
text-align:center;
}

.cs-n{
font-size:1.4rem;
font-weight:900;
}

.cs-s{
font-size:.8rem;
opacity:.8;
}

.cp-bar{
height:8px;
background:rgba(255,255,255,.3);
border-radius:10px;
overflow:hidden;
margin-top:5px;
}

.cp-fill{
height:100%;
background:#fff;
border-radius:10px;
transition:width .4s ease;
}
.form-card-pro{
background:white;
padding:40px;
border-radius:30px;
box-shadow:0 30px 60px rgba(0,0,0,.07);
}

.pet-card-soft{
background:white;
border-radius:25px;
overflow:hidden;
box-shadow:0 20px 40px rgba(0,0,0,.06);
transition:.3s;
}

.pet-card-soft:hover{
transform:translateY(-6px);
}

.pet-img{
width:100%;
height:200px;
object-fit:cover;
}

.pet-meta{
padding:15px;
}

.pet-name{
font-weight:800;
}

.pet-sub{
font-size:.85rem;
color:#666;
}
/* =========================
LISTA PRO MASCOTAS
========================= */

.pet-list-pro{
background:white;
border-radius:25px;
box-shadow:0 25px 50px rgba(0,0,0,.06);
overflow:hidden;
}

.pet-row{
display:flex;
justify-content:space-between;
align-items:center;
padding:20px;
border-bottom:1px solid #f1f1f1;
flex-wrap:wrap;
gap:15px;
}

.pet-row:last-child{
border-bottom:none;
}

.pet-row:hover{
background:#f8f9ff;
}

.pet-left{
display:flex;
align-items:center;
gap:15px;
}

.pet-avatar{
width:60px;
height:60px;
border-radius:50%;
object-fit:cover;
border:3px solid #f1f1f1;
}

.pet-info{
display:flex;
flex-direction:column;
}

.pet-name-row{
font-weight:800;
font-size:1rem;
}

.pet-meta-row{
font-size:.85rem;
color:#666;
}

.pet-actions{
display:flex;
gap:8px;
flex-wrap:wrap;
}

/* MOBILE */
@media(max-width:768px){
.pet-row{
flex-direction:column;
align-items:flex-start;
}
.pet-actions{
width:100%;
}
.pet-actions a{
flex:1;
text-align:center;
}
}
/* =========================
CITAS PRO
========================= */

.citas-list-pro{
background:white;
border-radius:25px;
box-shadow:0 25px 50px rgba(0,0,0,.06);
overflow:hidden;
}

.cita-row{
display:flex;
justify-content:space-between;
align-items:center;
padding:20px;
border-bottom:1px solid #f1f1f1;
flex-wrap:wrap;
gap:15px;
}

.cita-row:last-child{
border-bottom:none;
}

.cita-row:hover{
background:#f8f9ff;
}

.cita-left{
display:flex;
gap:15px;
align-items:center;
}

.cita-date{
font-weight:800;
font-size:.95rem;
}

.cita-date span{
font-weight:500;
font-size:.85rem;
color:#666;
}

.cita-mascota{
font-weight:700;
}

.cita-sucursal{
font-size:.85rem;
color:#666;
}

.cita-right{
display:flex;
align-items:center;
gap:10px;
flex-wrap:wrap;
}

/* BADGES MODERNOS */
.badge-soft{
padding:6px 12px;
border-radius:50px;
font-size:.75rem;
font-weight:700;
}

.badge-soft-warning{
background:#fff3cd;
color:#856404;
}

.badge-soft-success{
background:#d4edda;
color:#155724;
}

.badge-soft-danger{
background:#f8d7da;
color:#721c24;
}

.badge-soft-secondary{
background:#e2e3e5;
color:#383d41;
}

/* MOBILE */
@media(max-width:768px){

.cita-row{
flex-direction:column;
align-items:flex-start;
}

.cita-right{
width:100%;
}

}
.auth-card-pro{
background:white;
padding:40px;
border-radius:30px;
box-shadow:0 30px 60px rgba(0,0,0,.08);
}

.auth-input{
height:48px;
border-radius:14px;
border:1px solid #e5e7eb;
}

.auth-input:focus{
border-color:#2f6bff;
box-shadow:0 0 0 2px rgba(47,107,255,.1);
}

.auth-section{
padding:120px 0 80px;
background:
radial-gradient(circle at 20% 20%, rgba(47,107,255,.08), transparent 40%),
radial-gradient(circle at 80% 80%, rgba(47,107,255,.08), transparent 40%);

}
/* =========================
NAVBAR FIX MOBILE
========================= */

/* Navbar base */
.nav-soft{
background:white;
box-shadow:0 5px 20px rgba(0,0,0,.05);
}

/* Collapse móvil */
@media(max-width:991px){

.navbar-collapse{
background:white;
padding:20px;
border-radius:20px;
box-shadow:0 20px 40px rgba(0,0,0,.08);
margin-top:10px;
}

.navbar-nav .nav-link{
color:#1f2937 !important;
font-weight:600;
padding:10px 0;
}

.navbar-nav .nav-link:hover{
color:#2f6bff !important;
}

}
.reserva-section{
padding:120px 0;
background:#f6f8fc;
}

.reserva-title{
text-align:center;
font-weight:800;
font-size:28px;
margin-bottom:40px;
}

.mascotas-grid{
max-width:700px;
margin:auto;
}

.pet-card{
background:white;
border-radius:14px;
padding:18px;
margin-bottom:20px;
box-shadow:0 10px 20px rgba(0,0,0,.08);
cursor:pointer;
transition:.2s;
}

.pet-card:hover{
transform:scale(1.02);
}

.pet-card-inner{
display:flex;
align-items:center;
gap:15px;
}

.pet-avatar img{
width:70px;
height:70px;
border-radius:50%;
object-fit:cover;
}

.pet-name{
font-weight:700;
font-size:18px;
}

.pet-breed{
font-size:14px;
color:#666;
}

.pet-warning{
margin-top:5px;
font-size:13px;
color:#ff5a5a;
background:#ffeaea;
display:inline-block;
padding:3px 8px;
border-radius:8px;
}

.btn-reservar{
display:block;
margin:30px auto 0;
background:#0d2a5c;
color:white;
padding:15px 40px;
border-radius:12px;
border:none;
font-size:16px;
font-weight:700;
}

.pet-new{
text-align:center;
margin-top:20px;
}

.pet-new a{
color:#0d2a5c;
font-weight:600;
}
.nav-logo{
width:42px;
height:42px;
object-fit:contain;
}

/* CONTENEDOR FOTO */

.pet-avatar{
width:70px;
height:70px;
border-radius:50%;
overflow:hidden;
flex-shrink:0;
}

/* IMAGEN */

.pet-avatar img{
width:100%;
height:100%;
object-fit:cover;
display:block;
}
.pet-card{
background:#fff;
border-radius:16px;
padding:18px;
margin-bottom:18px;
box-shadow:0 8px 20px rgba(0,0,0,.06);
transition:.2s;
border:1px solid #eef2f7;
cursor:pointer;
}

.pet-card:hover{
transform:translateY(-2px);
box-shadow:0 12px 25px rgba(0,0,0,.08);
}

.pet-card-inner{
display:flex;
align-items:center;
gap:16px;
}

.pet-info{
flex:1;
}

.pet-name{
font-size:18px;
font-weight:700;
color:#0d2a5c;
}

.pet-breed{
font-size:14px;
color:#6c7a89;
margin-top:2px;
}

.pet-warning{
margin-top:6px;
font-size:12px;
background:#ffe7e7;
color:#d11a2a;
padding:4px 10px;
border-radius:20px;
display:inline-block;
font-weight:600;
}
.reserva-search{
max-width:450px;
margin:0 auto 40px;
}

.sucursales-grid{
max-width:700px;
margin:auto;
}

.sucursal-card{
display:flex;
align-items:center;
gap:20px;
background:white;
border-radius:16px;
padding:20px;
margin-bottom:18px;
box-shadow:0 10px 20px rgba(0,0,0,.05);
border:1px solid #eef2f7;
}

.sucursal-icon{
font-size:30px;
color:#0d2a5c;
}

.sucursal-info{
flex:1;
}

.sucursal-name{
font-weight:700;
font-size:18px;
color:#0d2a5c;
}

.sucursal-dir{
font-size:14px;
color:#6c7a89;
margin-top:4px;
}

.sucursal-phone{
font-size:13px;
color:#999;
margin-top:4px;
}

.sucursal-action{
flex-shrink:0;
}
.servicio-card{
background:white;
padding:30px;
border-radius:16px;
text-align:center;
box-shadow:0 10px 25px rgba(0,0,0,.05);
transition:.2s;
margin-bottom:20px;
}

.servicio-card:hover{
transform:translateY(-4px);
box-shadow:0 15px 30px rgba(0,0,0,.08);
}

.servicio-icon{
font-size:40px;
margin-bottom:10px;
}

.servicio-name{
font-weight:700;
font-size:20px;
color:#0d2a5c;
}

.servicio-desc{
font-size:14px;
color:#666;
margin-top:5px;
}
.extra-card{
display:block;
cursor:pointer;
margin-bottom:20px;
}

.extra-card input{
display:none;
}

.extra-inner{
background:white;
padding:20px;
border-radius:16px;
text-align:center;
box-shadow:0 10px 20px rgba(0,0,0,.05);
transition:.2s;
border:2px solid transparent;
}

.extra-card input:checked + .extra-inner{
border-color:#4f8cff;
background:#f5f8ff;
}

.extra-inner:hover{
transform:translateY(-3px);
}

.extra-name{
font-weight:700;
font-size:16px;
color:#0d2a5c;
}

.extra-desc{
font-size:13px;
color:#666;
margin-top:6px;
}

.extra-price{
font-weight:700;
margin-top:8px;
color:#4f8cff;
}
.fecha-selector{
max-width:350px;
margin:0 auto;
}

.fecha-input{
padding:14px;
border-radius:12px;
font-size:16px;
border:2px solid #e6ecf3;
}

.fecha-input:focus{
border-color:#4f8cff;
box-shadow:none;
}
.hora-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(90px,1fr));
gap:15px;
max-width:600px;
margin:auto;
}

.hora-card{
cursor:pointer;
}

.hora-card input{
display:none;
}

.hora-inner{
background:white;
padding:14px;
text-align:center;
border-radius:10px;
font-weight:600;
border:2px solid #e6ecf3;
transition:.2s;
}

.hora-card input:checked + .hora-inner{
background:#4f8cff;
color:white;
border-color:#4f8cff;
}

.hora-inner:hover{
border-color:#4f8cff;
}
.confirm-card{
max-width:520px;
margin:auto;
background:white;
padding:30px;
border-radius:16px;
box-shadow:0 10px 25px rgba(0,0,0,.08);
}

.timer-box{
text-align:center;
font-weight:700;
font-size:18px;
color:#e63946;
margin-top:15px;
}
.citas-list-pro{
display:flex;
flex-direction:column;
gap:14px;
}

.cita-row{
display:flex;
justify-content:space-between;
align-items:center;
background:white;
padding:18px;
border-radius:14px;
box-shadow:0 6px 14px rgba(0,0,0,.06);
}

.cita-left{
display:flex;
gap:18px;
align-items:center;
}

.cita-date{
font-weight:700;
font-size:14px;
color:#0d2a5c;
}

.cita-date span{
font-size:13px;
color:#888;
}

.cita-info{
font-size:14px;
}

.cita-mascota{
font-weight:600;
}

.cita-sucursal{
color:#777;
font-size:13px;
}

.cita-servicio{
font-size:13px;
color:#888;
}

.cita-actions{
display:flex;
gap:6px;
}

.empty-box{
background:white;
padding:40px;
border-radius:16px;
text-align:center;
box-shadow:0 8px 20px rgba(0,0,0,.06);
}