
/* SECTION HELPERS */
.sec-label{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:.75rem}
.sec-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(1.6rem,3vw,2.2rem);color:var(--navy);line-height:1.15;margin-bottom:.75rem}
.sec-title span{color:var(--blue-light)}
.divider{width:48px;height:3px;background:var(--gold);border-radius:2px;margin:.9rem 0 1rem}
.sec-header{margin-bottom:3rem}
.sec-header.centered{text-align:center}
.sec-header.centered .divider{margin:.9rem auto 1rem}
.sec-header.centered .sec-desc{margin:0 auto}
.sec-desc{color:var(--gray-500);font-size:.92rem;line-height:1.75;max-width:620px}

/* INFO BAND */
.info-band{background:var(--gold-pale);border-bottom:3px solid var(--gold);padding:.9rem 0}
.info-band-inner{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.info-band-icon{width:36px;height:36px;border-radius:6px;background:var(--navy);display:grid;place-items:center;color:var(--gold-light);font-size:.85rem;flex-shrink:0}
.info-band-text{font-size:.83rem;color:var(--gray-700);flex:1}
.info-band-text strong{color:var(--navy)}
.info-band-link{font-size:.8rem;font-weight:600;color:var(--blue);white-space:nowrap;display:flex;align-items:center;gap:.35rem;transition:color var(--t)}
.info-band-link:hover{color:var(--gold)}

/* FILTER TABS */
.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{background:var(--white);border:1.5px solid var(--gray-200);border-radius:20px;padding:.45rem 1.1rem;font-size:.78rem;font-weight:600;color:var(--gray-500);cursor:pointer;transition:all var(--t);display:flex;align-items:center;gap:.4rem}
.filter-btn:hover{border-color:var(--navy);color:var(--navy)}
.filter-btn.active{background:var(--navy);border-color:var(--navy);color:#fff}
.filter-btn.active i{color:var(--gold-light)}
.filter-btn i{font-size:.72rem;color:var(--gray-400)}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* SERVICE CARD */
.svc-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow var(--t),transform var(--t),border-color var(--t)}
.svc-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px);border-color:var(--gray-100)}
.svc-card[data-hidden="true"]{display:none}

/* Image area */
.svc-img{height:190px;background:var(--gray-50);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.svc-img img{width:100%;height:100%;object-fit:contain;padding:1.25rem;transition:transform var(--t-slow)}
.svc-card:hover .svc-img img{transform:scale(1.06)}
.svc-img-fallback{font-size:3rem;color:var(--gray-200)}
.svc-cat-badge{position:absolute;top:.75rem;left:.75rem;background:var(--navy);color:var(--gold-light);font-size:.62rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:.2rem .6rem;border-radius:3px}

/* Card body */
.svc-body{padding:1.35rem 1.5rem;flex:1;display:flex;flex-direction:column;gap:.5rem}
.svc-title{font-weight:700;font-size:.95rem;color:var(--navy);line-height:1.4}
.svc-desc{font-size:.82rem;color:var(--gray-500);line-height:1.65;flex:1}

/* Card footer */
.svc-footer{padding:1rem 1.5rem;border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}
.svc-footer-label{font-size:.7rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gray-400)}
.svc-cta{background:var(--navy);color:#fff;font-weight:700;font-size:.78rem;padding:.55rem 1.25rem;border-radius:4px;display:inline-flex;align-items:center;gap:.45rem;transition:background var(--t),transform var(--t);white-space:nowrap}
.svc-cta:hover{background:var(--blue);transform:translateX(2px);color:#fff}
.svc-cta i{font-size:.7rem}

/* GOB.EC badge */
.gob-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.68rem;color:var(--gray-400);border:1px solid var(--gray-200);padding:.2rem .5rem;border-radius:3px}
.gob-badge i{color:var(--gold)}

/* CTA SECTION */
.cta-section{background:linear-gradient(135deg,var(--navy-dark),var(--navy));padding:4rem 0;position:relative;overflow:hidden}
.cta-section::after{content:'';position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(255,255,255,.012) 40px,rgba(255,255,255,.012) 41px)}
.cta-inner{position:relative;z-index:1;text-align:center;max-width:600px;margin:0 auto}
.cta-inner h2{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:clamp(1.5rem,3vw,2rem);color:#fff;margin-bottom:.75rem}
.cta-inner h2 span{color:var(--gold-light)}
.cta-inner p{color:rgba(255,255,255,.6);font-size:.9rem;margin-bottom:2rem;line-height:1.7}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-accent{background:var(--gold);color:var(--navy-dark);font-weight:700;font-size:.85rem;padding:.75rem 1.75rem;border-radius:4px;display:inline-flex;align-items:center;gap:.5rem;transition:background var(--t),transform var(--t)}
.btn-accent:hover{background:var(--gold-light);transform:translateY(-2px);color:var(--navy-dark)}
.btn-outline-light{background:transparent;border:1.5px solid rgba(255,255,255,.35);color:#fff;font-weight:600;font-size:.85rem;padding:.73rem 1.75rem;border-radius:4px;display:inline-flex;align-items:center;gap:.5rem;transition:border-color var(--t),background var(--t)}
.btn-outline-light:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}

/* EMPTY STATE */
#emptyState{display:none;grid-column:1/-1;text-align:center;padding:4rem 2rem;color:var(--gray-400)}
#emptyState i{font-size:2.5rem;display:block;margin-bottom:1rem}

/* RESPONSIVE */
@media(max-width:1024px){.services-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:1fr}.stat+.stat::before{display:none}}
@media(max-width:768px){.gov-strip-links,.nav-links{display:none}.section{padding:3.5rem 0}.footer-grid{grid-template-columns:1fr}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr}.filter-bar{gap:.35rem}.filter-btn{font-size:.73rem;padding:.4rem .85rem}}
