/* =========================================================
   DoctoryPlus · GLOBAL CSS — colores, header, footer,
   buscador, clusters, tarjetas, rating, responsive
   ========================================================= */

:root{
  /* Marca */
  --brand:#2DA1AF; --brand-ink:#1a6d76;

  /* UI */
  --bg:#f7fafc; --surface:#ffffff;
  --text:#0f172a; --muted:#64748b; --line:#e5e7eb;

  /* radio & sombras */
  --radius:16px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04);
  --shadow-md:0 6px 24px rgba(0,0,0,.08);
  --ring:0 0 0 3px rgba(45,161,175,.18);

  --container:1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand);text-decoration:none;transition:color .15s}
a:hover{text-decoration:none}
.container{width:min(var(--container),92vw);margin-inline:auto}
.muted{color:var(--muted)}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:static;width:auto;height:auto;padding:8px;background:#000;color:#fff}

/* ---------- BOTONES ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.6rem 1.2rem;border-radius:999px;font-weight:600;
  border:1px solid transparent;transition:background .18s,transform .18s,box-shadow .18s;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:none}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn-solid{background:var(--brand);color:#fff;box-shadow:var(--shadow-sm)}
.btn-solid:hover{background:var(--brand-ink)}
.btn-ghost{background:rgba(45,161,175,.08);color:var(--brand);border-color:rgba(45,161,175,.25)}
.btn-lg{padding:.75rem 1.6rem;font-size:1rem}

/* =========================================================
   HEADER — glass + nav underline + user dropdown
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:60;width:100%;
  backdrop-filter:saturate(180%) blur(12px);
  transition:background .25s,box-shadow .25s;
}
.site-header.header-solid{background:#ffffffee;border-bottom:1px solid var(--line)}
.site-header.header-transparent{background:transparent}
.site-header.is-scrolled{background:#ffffffee;box-shadow:var(--shadow-sm)}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:1.2rem;padding:1rem 0;
}
.logo{
  font-weight:900;font-size:1.45rem;letter-spacing:-.02em;
  display:inline-flex;align-items:center;gap:.35rem;color:var(--text);
}
.logo .dot{color:var(--brand)} .logo .accent{color:var(--brand)}

/* nav desktop */
.main-nav{display:flex}
.main-nav .menu{display:flex;gap:.6rem;margin:0;padding:0;list-style:none}
.main-nav .menu>li>a{
  position:relative;display:inline-flex;align-items:center;padding:.6rem .75rem;border-radius:12px;color:var(--text);transition:background .16s;
}
.main-nav .menu>li>a:hover{background:#f0f9fb;text-decoration:none}
.main-nav .menu>li>a::after{
  content:"";position:absolute;left:.75rem;right:.75rem;bottom:4px;height:2px;border-radius:2px;
  background:var(--brand);transform:scaleX(0);transform-origin:left;transition:transform .22s;opacity:.85;
}
.main-nav .menu>li>a:hover::after{transform:scaleX(1)}

/* CTA + burger + user menu (derecha) */
.header-cta{display:flex;align-items:center;gap:.8rem}
.header-cta .btn-solid.header-cta__btn{padding:.55rem 1.2rem;font-size:.95rem}

/* ===== User dropdown ===== */
.hdr-user{position:relative;display:inline-flex;align-items:center}
.hdr-user-toggle{
  display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--line);border-radius:999px;
  background:#fff;padding:.45rem .75rem;font-weight:800;color:#0f172a;box-shadow:var(--shadow-sm);
  cursor:pointer;transition:box-shadow .18s, transform .18s;
}
.hdr-user-toggle:hover{transform:translateY(-1px)}
.hdr-user-toggle:focus-visible{outline:none;box-shadow:var(--ring)}
.hdr-user .avatar{
  width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:var(--brand);color:#fff;font-size:.85rem;font-weight:900
}
.hdr-user .chev{font-size:.8rem;color:#64748b}

/* Menu */
.hdr-user-menu{
  position:absolute;right:0;top:calc(100% + 8px);
  background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-md);
  min-width:200px;padding:6px;display:none;
}
.hdr-user-menu a{
  display:flex;align-items:center;gap:8px;padding:10px 10px;border-radius:10px;color:#0b1220;font-weight:700
}
.hdr-user-menu a:hover{background:#f0f9fb;text-decoration:none}

@media (hover:hover){
  .hdr-user:hover .hdr-user-menu,
  .hdr-user:focus-within .hdr-user-menu{display:block}
}
/* en móvil se abre por .is-open (JS) */
.hdr-user.is-open .hdr-user-menu{display:block}

/* Hamburger */
.hamburger{
  display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:12px;
  background:#fff;cursor:pointer;align-items:center;justify-content:center;gap:5px;
}
.hamburger span{width:20px;height:2px;background:#182233;border-radius:2px;transition:.24s}
.site-header.nav-open .hamburger span:nth-child(1){transform:translateY(5px) rotate(45deg)}
.site-header.nav-open .hamburger span:nth-child(2){opacity:0}
.site-header.nav-open .hamburger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

@media (max-width:900px){
  .hamburger{display:flex}
  .main-nav{
    position:fixed;inset:72px 0 auto 0;padding:1rem 1.2rem;display:none;
    background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm);
  }
  .main-nav .menu{flex-direction:column;gap:.25rem}
  .site-header.nav-open .main-nav{display:block}
}

/* ---------- BASE GRID ---------- */
.site-main{padding-bottom:64px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}

/* =========================================================
   BUSCADOR (igual home + archivos)
   ========================================================= */
.dp-search--bar{
  position:relative;display:flex;align-items:center;gap:10px;flex-wrap:nowrap;
  width:min(920px,94vw);padding:.5rem 1rem .5rem .9rem;
  background:#fff;border:1px solid #dbe7ea;border-radius:999px;box-shadow:var(--shadow-md);
  transition:box-shadow .18s;
}
.dp-search--bar:focus-within{box-shadow:0 10px 30px rgba(0,0,0,.12), var(--ring)}
.dp-field{display:flex;align-items:center;gap:10px}
.dp-field--input{flex:1 1 auto;min-width:260px}
.dp-field--input input[type="search"]{
  width:100%;border:0;outline:0;padding:.7rem 2px;font-size:1.1rem;border-radius:999px;color:#0b1220;
}
.dp-field--input input::placeholder{color:#94a3b8}
.dp-divider{width:1px;height:28px;background:#e7eef1;flex:0 0 1px}
.dp-field--select{position:relative}
.dp-select select{
  -webkit-appearance:none;appearance:none;
  border:1px solid #dbe7ea;background:#fff;color:#0b1220;
  border-radius:999px;padding:.6rem 34px .6rem 12px;height:44px;min-width:170px;line-height:1;
  box-shadow:var(--shadow-sm);transition:border-color .16s,box-shadow .16s;
}
.dp-select select:focus{outline:none;border-color:#bfeaf0;box-shadow:var(--ring)}
.dp-select::after{
  content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  font-size:.8rem;color:#64748b;pointer-events:none;
}
.dp-submit{
  border-radius:999px;padding:.7rem 1.3rem;border:0;background:var(--brand);color:#fff;font-weight:700;
  cursor:pointer;box-shadow:var(--shadow-sm);transition:background .16s,transform .16s;
}
.dp-submit:hover{background:var(--brand-ink);transform:translateY(-1px)}
/* dropdown sugerencias */
.dp-suggest{position:absolute;top:calc(100% + 10px);left:0;right:0;background:#fff;border:1px solid #dbe7ea;border-radius:14px;box-shadow:var(--shadow-md);max-height:380px;overflow:auto;z-index:40}
.dp-suggest .sg-group{padding:6px 0;border-top:1px solid #f1f5f9}.dp-suggest .sg-group:first-child{border-top:0}
.dp-suggest .sg-title{padding:6px 12px;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.06em}
.dp-suggest a.sg-item{display:flex;align-items:center;gap:8px;padding:10px 12px;color:#0b1220}
.dp-suggest a.sg-item:hover,.dp-suggest a.sg-item.is-active{background:#f0f9fb;text-decoration:none}
.dp-suggest .sg-type{font-size:12px;color:#64748b;margin-left:auto}

/* =========================================================
   CLUSTERS (términos)
   ========================================================= */
.cluster-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px
}
.cluster-card{
  background:#fff;border:1px solid #e6edf0;border-radius:18px;box-shadow:var(--shadow-sm);
  overflow:hidden;display:grid;grid-template-rows:160px auto;
  transition:transform .18s,box-shadow .18s,border-color .18s;text-decoration:none;
}
.cluster-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#d7eef2}
.cluster-card .cluster-media{height:160px}
.cluster-card .cluster-media img,.cluster-card .cluster-ph{width:100%;height:100%;object-fit:cover;display:block}
.cluster-card .cluster-ph{background:linear-gradient(135deg,#e9fbfe,#fff)}
.cluster-body{display:grid;grid-template-rows:auto 1fr auto;gap:.55rem;padding:1rem}
.cluster-title{font-weight:800;font-size:1.05rem;margin:0;color:#0d2e33}
.cluster-desc{color:#334155;text-align:justify;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-size:.92rem;line-height:1.35}
.cluster-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem}
.cluster-count{color:var(--muted);font-size:.9rem}
.cluster-btn{margin-left:auto}

/* =========================================================
   DOCTOR CARD (vertical) + rating
   ========================================================= */
.grid-cards{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.card-vertical{
  background:#fff;border:1px solid #e6edf0;border-radius:18px;box-shadow:var(--shadow-sm);
  overflow:hidden;display:grid;grid-template-rows:1fr auto;min-height:330px;
  transition:transform .18s,box-shadow .18s,border-color .18s;
}
.card-vertical:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#d7eef2}
.card-vertical .media img,.card-vertical .ph-media{width:100%;height:100%;object-fit:cover;display:block}
.card-vertical .ph-media{background:#e5e7eb;display:grid;place-items:center;font-weight:800;color:#94a3b8}
.card-vertical .content{display:grid;grid-template-rows:auto 1fr auto;padding:1rem;gap:.6rem}
.card-vertical h3{margin:0;font-size:1.05rem}
.card-vertical h3 a{color:#0b1220;font-weight:800;text-decoration:none}
.tax-badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:#f1fbfd;border:1px solid #dbeff3;font-size:.73rem;color:#036672}
.badge--muted{background:#f6f7fb;border-color:#e7e8f3;color:#475569}
.excerpt{color:#475569;font-size:.9rem;text-align:justify}
.card-vertical .content a.btn-ghost{max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-vertical .content .btn{width:100%}
.card-vertical .content a.btn-ghost + .btn,
.card-vertical .content .btn + .btn{margin-top:8px}

/* rating Google */
.rating{display:flex;align-items:center;gap:6px}
.stars{display:inline-flex;line-height:1}
.star{font-size:14px}
.star-full{color:#f59e0b}
.star-half{background:linear-gradient(90deg,#f59e0b 50%,#e2e8f0 50%);-webkit-background-clip:text;background-clip:text;color:transparent}
.star-empty{color:#e2e8f0}
.rating-num{font-weight:700}
.rating-count{color:#64748b;font-size:12px}

/* =========================================================
   FOOTER
   ========================================================= */
.footer-cta{background:linear-gradient(180deg,#e9fbfe,#ffffff);border-top:1px solid var(--line)}
.footer-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:1.6rem;padding:2rem 0}
.footer-cta h2{margin:0;font-size:1.55rem;font-weight:800}
.footer-cta p{margin:.25rem 0 0;color:var(--muted);max-width:38ch}
.site-footer{background:#0b1f22;color:#d1e6e8;border-top:1px solid rgba(255,255,255,.05)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;padding:3rem 0}
@media (max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.footer-grid{grid-template-columns:1fr}}
.site-footer .logo{font-size:1.35rem;color:#fff}
.site-footer .logo .dot,.site-footer .logo .accent{color:#7fe1ee}
.footer-desc{color:#a8cfd3;margin:.7rem 0 1.2rem;font-size:.95rem;line-height:1.4;max-width:28ch}
.footer-badges{list-style:none;margin:0;padding:0;display:grid;gap:.35rem;color:#94c7cd;font-size:.9rem}
.footer-col h3{margin:0 0 .7rem;font-size:1rem;color:#eaffff;letter-spacing:.01em}
.footer-list{margin:0;padding:0;list-style:none;display:grid;gap:.45rem;font-size:.95rem}
.footer-list a{color:#d1e6e8;position:relative;padding-bottom:2px}
.footer-list a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:#7fe1ee;transform:scaleX(0);transform-origin:left;transition:transform .25s}
.footer-list a:hover{text-decoration:none;color:#fff}
.footer-list a:hover::after{transform:scaleX(1)}
.footer-legal{border-top:1px solid rgba(255,255,255,.12);font-size:.9rem}
.legal-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0 1.6rem}
.legal-links{display:flex;gap:1.1rem;list-style:none;margin:0;padding:0}
.legal-links a{color:#cfe9ec}
@media (max-width:640px){
  .footer-cta-inner{flex-direction:column;align-items:flex-start}
  .legal-inner{flex-direction:column;align-items:flex-start}
}

/* =========================================================
   RESPONSIVE ajustes buscador
   ========================================================= */
@media (max-width:900px){
  .dp-search--bar{flex-wrap:wrap;padding:1rem;gap:10px}
  .dp-field--input{order:1;min-width:100%}
  .dp-divider{display:none}
  .dp-field--select{order:2;width:calc(50% - 6px)}
  .dp-select select{width:100%}
  .dp-submit{order:3;width:100%}
}

/* ─────────────────────────────────────────────
   Identidad Google (SVG inline, 100% visible)
   ───────────────────────────────────────────── */
.rating--google{gap:8px;align-items:center}
.g-mark,.g-mark-lg{display:inline-flex;align-items:center;line-height:0}
.g-mark svg{width:16px;height:16px;display:block}
.g-mark-lg svg{width:24px;height:24px;display:block;margin-right:6px}
.g-source{font-size:12px;color:var(--muted)}
