:root{
  --portal-primary:#7b1e3a;
  --portal-primary-dark:#5e132c;
  --portal-gold:#d4a94f;
  --portal-surface:#ffffff;
  --portal-soft:#f7f3ef;
  --portal-text:#261b1d;
  --portal-muted:#6a5b5f;
}
html{scroll-behavior:smooth}
body.portal-publico-body{
  background:linear-gradient(180deg,#f8f4ef 0%,#fffdfb 24%,#f7f3ef 100%);
  color:var(--portal-text);
}
.portal-container{max-width:1280px}
.portal-hero{
  position:relative;
  overflow:hidden;
  padding:34px 0 64px;
  background:radial-gradient(circle at top left,rgba(255,255,255,.16),transparent 28%),linear-gradient(135deg,#5f0f2f 0%,#812144 55%,#b56d42 100%);
  color:#fff;
}
.portal-hero::after{
  content:"";
  position:absolute;
  inset:auto -8% -55px auto;
  width:280px;
  height:280px;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  filter:blur(2px);
}
.portal-logo-circle{
  width:88px;height:88px;border-radius:24px;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);box-shadow:0 20px 40px rgba(0,0,0,.12)
}
.portal-logo-circle img{max-width:68px;max-height:68px;object-fit:contain}
.portal-kicker{display:inline-block;font-size:.83rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;opacity:.82;margin-bottom:.55rem}
.portal-title{font-size:clamp(2rem,4vw,3.4rem);line-height:1.02;font-weight:800;max-width:850px;margin:0 0 .85rem}
.portal-subtitle{max-width:760px;font-size:1.04rem;color:rgba(255,255,255,.84);margin:0}
.portal-pill-btn{border-radius:999px;padding:.85rem 1.25rem;font-weight:700}
.portal-search-card{
  margin-top:32px;
  background:rgba(255,255,255,.95);
  color:var(--portal-text);
  border:1px solid rgba(255,255,255,.3);
  border-radius:32px;
  padding:28px;
  box-shadow:0 28px 60px rgba(58,14,32,.18)
}
.portal-search-copy h2{font-size:clamp(1.55rem,3vw,2.35rem);font-weight:800;margin-bottom:.55rem}
.portal-search-copy p,.portal-section-sub{color:var(--portal-muted)}
.portal-search-label{display:inline-flex;align-items:center;padding:.45rem .8rem;border-radius:999px;background:#f7ede7;color:var(--portal-primary);font-weight:700;font-size:.88rem;margin-bottom:1rem}
.portal-search-form .form-control{border:none;background:transparent;box-shadow:none;padding-left:3rem;font-size:1.08rem}
.portal-search-input-wrap{
  position:relative;
  background:#fff;
  border:1px solid #ecd8dd;
  border-radius:999px;
  min-height:68px;
  display:flex;
  align-items:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 14px 30px rgba(123,30,58,.08)
}
.portal-search-input-wrap i{position:absolute;left:1.2rem;font-size:1.15rem;color:var(--portal-primary)}
.portal-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.portal-stat-card{display:flex;gap:14px;align-items:center;background:linear-gradient(180deg,#fff,#f9f4f1);border:1px solid #edd8de;border-radius:24px;padding:18px;min-height:112px}
.portal-stat-icon{width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,#7b1e3a,#b35b40);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;box-shadow:0 12px 22px rgba(123,30,58,.2)}
.portal-stat-value{font-size:1.6rem;font-weight:800;line-height:1}
.portal-stat-label{font-size:.92rem;color:var(--portal-muted);margin-top:.35rem}
.portal-main{margin-top:-24px;padding-bottom:56px}
.portal-quick-section{margin-bottom:34px}
.portal-quick-card{display:flex;align-items:flex-start;gap:16px;background:#fff;border:1px solid #efdee2;border-radius:26px;padding:22px;box-shadow:0 12px 28px rgba(69,23,37,.06);height:100%;color:inherit;transition:transform .18s ease, box-shadow .18s ease}
.portal-quick-card:hover{transform:translateY(-4px);box-shadow:0 18px 34px rgba(69,23,37,.12)}
.portal-quick-card h3{font-size:1.06rem;font-weight:800;margin:0 0 .35rem}
.portal-quick-card p{margin:0;color:var(--portal-muted)}
.portal-quick-icon{width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.bg-soft-primary{background:#f5e9ee;color:#7b1e3a}.bg-soft-success{background:#ebf7f0;color:#16814d}.bg-soft-warning{background:#fff4e5;color:#b36b00}
.portal-section{margin-top:38px}
.portal-section-head{display:flex;justify-content:space-between;align-items:end;gap:18px;flex-wrap:wrap;margin-bottom:20px}
.portal-section-kicker{display:block;color:var(--portal-primary);font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:.8rem;margin-bottom:.45rem}
.portal-section-head h2{margin:0;font-size:clamp(1.4rem,3vw,2rem);font-weight:800}
.portal-results-pill{display:inline-flex;align-items:center;border-radius:999px;background:#fff;border:1px solid #ead8de;padding:.75rem 1rem;color:var(--portal-primary);font-weight:700;box-shadow:0 10px 24px rgba(69,23,37,.06)}
.portal-feature-card,.portal-colonia-card{background:#fff;border:1px solid #efdee2;border-radius:28px;overflow:hidden;box-shadow:0 16px 32px rgba(69,23,37,.08);transition:transform .2s ease, box-shadow .2s ease}
.portal-feature-card:hover,.portal-colonia-card:hover{transform:translateY(-5px);box-shadow:0 22px 40px rgba(69,23,37,.14)}
.portal-feature-media,.portal-colonia-media{position:relative}
.portal-feature-media img{width:100%;height:255px;object-fit:cover}.portal-colonia-media img{width:100%;height:220px;object-fit:cover}
.portal-feature-badge{position:absolute;left:18px;bottom:18px;background:rgba(123,30,58,.92);color:#fff;padding:.55rem .85rem;border-radius:999px;font-weight:700;box-shadow:0 12px 24px rgba(25,8,14,.18)}
.portal-feature-body,.portal-colonia-body{padding:22px}
.portal-feature-body h3,.portal-colonia-body h3{font-size:1.18rem;font-weight:800;margin-bottom:.6rem}
.portal-feature-body p{color:var(--portal-muted);margin:0}
.portal-mini-badge{display:inline-flex;align-items:center;padding:.45rem .7rem;border-radius:999px;background:#f5e9ee;color:var(--portal-primary);font-weight:800;white-space:nowrap}
.portal-meta-list{display:grid;gap:.7rem;color:var(--portal-muted);font-size:.96rem}
.portal-meta-list div{display:flex;gap:.65rem;align-items:flex-start}.portal-meta-list i{color:var(--portal-primary);margin-top:.12rem}
.portal-card-actions{margin-top:1rem}
.portal-empty-state{background:#fff;border:1px solid #efdee2;border-radius:30px;padding:38px 26px;text-align:center;box-shadow:0 16px 34px rgba(69,23,37,.08)}
.portal-empty-icon{width:82px;height:82px;border-radius:24px;background:#f5e9ee;color:var(--portal-primary);display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 1rem}
.portal-footer{padding:28px 0;background:linear-gradient(135deg,#481224,#6a1833 56%,#8b4b2d);color:#fff}
.portal-footer span{color:rgba(255,255,255,.75)}
@media (max-width:991px){.portal-hero{padding:28px 0 52px}.portal-search-card{padding:22px}.portal-stats-grid{grid-template-columns:1fr 1fr}}
@media (max-width:767px){.portal-main{margin-top:0}.portal-search-card{border-radius:24px}.portal-stats-grid{grid-template-columns:1fr}.portal-title{font-size:2rem}.portal-hero-top{align-items:flex-start}.portal-logo-circle{width:74px;height:74px;border-radius:20px}.portal-logo-circle img{max-width:56px;max-height:56px}}

.portal-public-detail .detail-hero{
  position:relative;
  overflow:hidden;
  padding:28px 0 52px;
  background:radial-gradient(circle at top right,rgba(255,255,255,.16),transparent 26%),linear-gradient(135deg,#5f0f2f 0%,#7b1e3a 48%,#b56d42 100%);
  color:#fff;
}
.portal-public-detail .detail-main{margin-top:-22px;padding-bottom:28px}
.detail-hero-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:34px;padding:28px;backdrop-filter:blur(8px);box-shadow:0 22px 46px rgba(42,10,22,.18)}
.detail-title{font-size:clamp(2rem,4vw,3.2rem);line-height:1.02;font-weight:800;margin:0 0 .8rem}
.detail-subtitle{max-width:720px;color:rgba(255,255,255,.82);font-size:1.05rem}
.detail-pill-row{display:flex;flex-wrap:wrap;gap:10px}
.detail-pill{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);padding:.75rem 1rem;border-radius:999px;font-weight:700}
.detail-highlight{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.15);padding:16px 18px;border-radius:24px;max-width:520px}
.detail-highlight-photo{width:72px;height:72px;border-radius:22px;overflow:hidden;border:3px solid rgba(255,255,255,.2);flex-shrink:0}
.detail-highlight-photo img{width:100%;height:100%;object-fit:cover}
.detail-highlight-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.72);font-weight:700}
.detail-highlight-name{font-size:1.12rem;font-weight:800;line-height:1.15}
.detail-highlight-role{color:rgba(255,255,255,.82)}
.detail-cover-card{position:relative;border-radius:30px;overflow:hidden;min-height:360px;box-shadow:0 22px 40px rgba(25,8,14,.22)}
.detail-cover-image{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.detail-cover-overlay{position:relative;z-index:1;background:linear-gradient(180deg,rgba(27,9,16,.18),rgba(27,9,16,.78));height:100%;min-height:360px;padding:24px;display:flex;flex-direction:column;justify-content:flex-end;text-align:center}
.detail-cover-overlay strong{font-size:1.08rem}
.detail-cover-overlay span{color:rgba(255,255,255,.75);margin-top:.25rem}
.persona-detalle-card{background:#fff;border:1px solid #efdee2;border-radius:30px;padding:22px;box-shadow:0 18px 34px rgba(69,23,37,.08);transition:transform .18s ease,box-shadow .18s ease}
.persona-detalle-card:hover{transform:translateY(-4px);box-shadow:0 26px 40px rgba(69,23,37,.14)}
.persona-detalle-card.is-featured{border-color:#d7b9bf;box-shadow:0 22px 42px rgba(69,23,37,.12)}
.persona-detalle-top{display:flex;gap:18px;align-items:flex-start;margin-bottom:18px}
.persona-detalle-media{width:108px;height:108px;border-radius:26px;overflow:hidden;flex-shrink:0;background:#f3ece8}
.persona-detalle-media img{width:100%;height:100%;object-fit:cover}
.persona-detalle-head h3{font-size:1.28rem;font-weight:800;margin-bottom:.55rem}
.persona-detalle-contact{display:grid;gap:.45rem;color:var(--portal-muted);font-size:.95rem}
.persona-detalle-contact div{display:flex;gap:.55rem;align-items:flex-start}.persona-detalle-contact i{color:var(--portal-primary);margin-top:.12rem}
.persona-detalle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.persona-asset-card{border:1px solid #efdee2;border-radius:24px;padding:16px;background:linear-gradient(180deg,#fff,#fffaf5);min-height:240px;display:flex;flex-direction:column;align-items:center;text-align:center}
.persona-asset-card.is-empty{background:#faf6f2}
.persona-asset-title{display:flex;align-items:center;gap:8px;font-weight:800;color:var(--portal-primary);margin-bottom:12px}
.persona-qr-image,.persona-qr-canvas{width:120px !important;height:120px !important;background:#fff;border-radius:16px;padding:8px;border:1px solid #ead8de}
.persona-asset-meta{margin-top:10px;color:var(--portal-muted);font-size:.92rem;line-height:1.35}
.persona-doc-preview{width:120px;height:120px;border-radius:20px;background:linear-gradient(135deg,#f5e9ee,#fff7ef);display:flex;align-items:center;justify-content:center;font-size:2.25rem;color:var(--portal-primary);border:1px solid #ead8de}
.persona-asset-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--portal-muted)}
.persona-asset-empty i{font-size:2rem;color:#b49aa2}
.detail-panel{background:#fff;border:1px solid #efdee2;border-radius:30px;padding:24px;box-shadow:0 16px 34px rgba(69,23,37,.08)}
.detail-map{min-height:380px;border-radius:24px;overflow:hidden}
@media (max-width:991px){.portal-public-detail .detail-main{margin-top:0}.detail-hero-card{padding:22px}.detail-cover-card,.detail-cover-overlay{min-height:300px}}
@media (max-width:767px){.persona-detalle-top{flex-direction:column;align-items:center;text-align:center}.persona-detalle-grid{grid-template-columns:1fr}.detail-pill-row{flex-direction:column;align-items:flex-start}.detail-highlight{flex-direction:column;align-items:flex-start}.detail-highlight-photo{width:64px;height:64px}.detail-title{font-size:2rem}}
