/* ===========================================
   COMPONENTS — Reusable UI elements
   =========================================== */

/* ===========================================
   NAV — Cream background, charcoal links
   =========================================== */
.nav{position:sticky;top:0;z-index:1000;background:rgba(255,252,248,0.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}
.nav.scrolled{box-shadow:var(--sh-md)}
.nav__inner{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:70px}
.nav__logo img{height:46px;width:auto}
.nav__links{display:flex;align-items:center;gap:.15rem}
.nav__links a{padding:.45rem .75rem;font-size:.87rem;font-weight:600;color:var(--text-mid);border-radius:var(--r-sm);transition:all .2s}
.nav__links a:hover{color:var(--plum);background:var(--plum-pale)}
.nav__cta{background:var(--plum)!important;color:var(--cream)!important;padding:.5rem 1.2rem!important;border-radius:50px!important}
.nav__cta:hover{background:var(--plum-dark)!important}
.hamburger{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.hamburger span{display:block;width:22px;height:2.5px;background:var(--charcoal);border-radius:2px;transition:all .3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
@media(max-width:900px){
  .nav__links{position:fixed;top:70px;left:0;right:0;bottom:0;background:rgba(255,252,248,.98);backdrop-filter:blur(20px);flex-direction:column;align-items:stretch;padding:1.5rem;gap:.25rem;transform:translateX(100%);transition:transform .35s ease}
  .nav__links.open{transform:translateX(0)}
  .nav__links a{padding:.85rem 1rem;font-size:1.05rem}
  .hamburger{display:flex}
}

/* ===========================================
   BUTTONS
   =========================================== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.6rem;border-radius:50px;font-family:var(--font-display);font-weight:700;font-size:.92rem;transition:all .25s;cursor:pointer;border:none}
.btn:focus-visible{outline:3px solid var(--sunny);outline-offset:3px}
.btn svg{width:18px;height:18px}
.btn--sunny{background:var(--sunny);color:var(--charcoal)}
.btn--sunny:hover{background:#fff;transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,215,0,.25)}
.btn--ghost{background:rgba(245,241,233,.1);color:var(--cream);border:1.5px solid rgba(245,241,233,.3)}
.btn--ghost:hover{background:rgba(245,241,233,.18)}
.btn--plum{background:var(--plum);color:var(--cream)}
.btn--plum:hover{background:var(--plum-dark);transform:translateY(-2px)}
.btn--coral{background:var(--coral);color:#fff}
.btn--coral:hover{background:#e55a28;transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--plum);border:2px solid var(--plum)}
.btn--outline:hover{background:var(--plum);color:var(--cream)}
.btn--sm{padding:.45rem 1rem;font-size:.8rem}
.btn--teal-fill{background:var(--teal);color:#fff}
.btn--teal-fill:hover{background:var(--teal-dark);transform:translateY(-2px)}

/* ===========================================
   SECTIONS
   =========================================== */
.section{padding:4.5rem 0}
.section--cream{background:var(--cream)}
.section--warm{background:var(--surface-warm)}
.section--charcoal{background:var(--charcoal);color:var(--cream)}
.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.section__title{font-size:1.6rem;font-weight:700;letter-spacing:-.01em;color:var(--charcoal)}
.section__link{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:.86rem;color:var(--plum);transition:gap .2s}
.section__link:hover{gap:.7rem;color:var(--plum-dark)}
.section__link svg{width:16px;height:16px}
.arrow{width:16px;height:16px}

/* ===========================================
   HERO
   =========================================== */
.hero{background:linear-gradient(145deg, var(--plum) 0%, var(--plum-dark) 60%, #6B2264 100%);padding:4.5rem 0 0;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-120px;right:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(0,155,131,.18) 0%,transparent 70%)}
.hero::after{content:'';position:absolute;bottom:-100px;left:20%;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(245,241,233,.06) 0%,transparent 70%)}
.hero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:end;position:relative;z-index:1}
.hero__content{padding-bottom:4.5rem}
.hero__badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(0,155,131,.2);border:1px solid rgba(0,155,131,.35);padding:.35rem 1rem;border-radius:50px;font-size:.83rem;color:rgba(230,247,244,.9);font-weight:600;margin-bottom:1.5rem}
.hero__badge strong{color:var(--sunny)}
.hero h1{font-size:2.75rem;font-weight:800;color:var(--cream);margin-bottom:1.2rem;letter-spacing:-.02em;line-height:1.12}
.hero h1 em{font-style:normal;color:var(--sunny)}
.hero__sub{font-size:1.08rem;color:rgba(245,241,233,.65);margin-bottom:2rem;max-width:470px;line-height:1.8}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__stats{display:flex;gap:2.5rem;margin-top:2.5rem}
.hero__stat-num{font-family:var(--font-display);font-size:1.8rem;font-weight:800;color:var(--sunny)}
.hero__stat-label{font-size:.76rem;color:rgba(245,241,233,.45);margin-top:.1rem}
.hero__image{position:relative;align-self:end}
.hero__image img{width:100%;max-width:440px;border-radius:var(--r-xl) var(--r-xl) 0 0;object-fit:cover;display:block;margin:0 auto;aspect-ratio:3/4}
@media(max-width:768px){
  .hero{padding:3rem 0 0}
  .hero__inner{grid-template-columns:1fr;gap:2rem}
  .hero__content{padding-bottom:2.5rem}
  .hero h1{font-size:2rem}
  .hero__image{display:none}
  .hero__stats{gap:1.5rem}
}

/* Page hero (smaller, for inner pages) */
.page-hero{padding:3rem 0;position:relative;overflow:hidden}
.page-hero--plum{background:linear-gradient(145deg,var(--plum) 0%,var(--plum-dark) 100%)}
.page-hero--teal{background:linear-gradient(145deg,var(--teal) 0%,var(--teal-dark) 100%)}
.page-hero--charcoal{background:linear-gradient(145deg,var(--charcoal) 0%,var(--charcoal-light) 100%)}
.page-hero h1{font-size:2rem;font-weight:800;color:var(--cream);margin-bottom:.5rem}
.page-hero p{color:rgba(245,241,233,.65);font-size:1rem;max-width:550px}

/* ===========================================
   CARDS
   =========================================== */
.card{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);transition:all .3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.card__img{width:100%;overflow:hidden;position:relative;background:var(--cream)}
.card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .card__img img{transform:scale(1.04)}
.card--big .card__img{height:100%;min-height:300px}
.card--row{flex-direction:row}
.card--row .card__img{width:150px;min-height:110px;flex-shrink:0}
.card__body{padding:1.2rem;flex:1;display:flex;flex-direction:column;justify-content:center}
.card__title{font-size:.95rem;font-weight:700;line-height:1.4}
.card--big .card__title{font-size:1.2rem}
.card__excerpt{font-size:.86rem;color:var(--text-mid);line-height:1.65;margin-top:.45rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card__meta{font-size:.75rem;color:var(--text-light);margin-top:.5rem}
@media(max-width:768px){
  .card--row{flex-direction:column}
  .card--row .card__img{width:100%;min-height:180px}
  .card--big .card__img{min-height:200px}
}

/* ===========================================
   TAGS
   =========================================== */
.tag{display:inline-block;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;padding:.2rem .55rem;border-radius:50px;margin-bottom:.55rem;width:fit-content}
.tag--teal{color:var(--teal-dark);background:var(--teal-pale)}
.tag--plum{color:var(--plum);background:var(--plum-pale)}
.tag--coral{color:var(--coral);background:var(--coral-pale)}
.tag--open{background:var(--teal);color:#fff}
.tag--closed{background:var(--text-light);color:#fff}

/* ===========================================
   GRIDS
   =========================================== */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
@media(max-width:768px){.grid-3,.grid-2,.feat-grid{grid-template-columns:1fr}}

/* ===========================================
   BUSCADOR CTA
   =========================================== */
.buscador{background:linear-gradient(145deg,var(--teal) 0%,var(--teal-dark) 100%);border-radius:var(--r-xl);padding:2rem 2.5rem;display:flex;align-items:center;gap:2rem;position:relative;overflow:hidden;border:3px solid var(--cream)}
.buscador::before{content:'';position:absolute;right:-60px;top:-60px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06)}
.buscador__icon{width:52px;height:52px;background:rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid rgba(255,255,255,.18)}
.buscador__icon svg{width:24px;height:24px;color:var(--sunny)}
.buscador__content{position:relative;z-index:1;flex:1}
.buscador h2{font-size:1.25rem;color:#fff;font-weight:700;margin-bottom:.3rem;line-height:1.3}
.buscador p{color:rgba(255,255,255,.8);font-size:.88rem;margin-bottom:0;line-height:1.5}
.buscador__stats{display:flex;gap:1.5rem;margin-top:.6rem}
.buscador__stat{display:flex;align-items:baseline;gap:.3rem}
.buscador__stat-num{font-family:var(--font-display);font-size:.95rem;font-weight:800;color:var(--sunny)}
.buscador__stat-label{font-size:.7rem;color:rgba(255,255,255,.55)}
.buscador__cta{flex-shrink:0}
@media(max-width:768px){
  .buscador{flex-direction:column;padding:1.5rem;text-align:center}
  .buscador__stats{justify-content:center}
  .buscador__cta{width:100%}
  .buscador__cta .btn{width:100%;justify-content:center}
}

/* ===========================================
   WHATSAPP CTA
   =========================================== */
.wa{background:linear-gradient(135deg,#128C7E,#25D366);border-radius:var(--r-xl);padding:2.5rem 3rem;display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;position:relative;overflow:hidden}
.wa::before{content:'';position:absolute;right:-20px;bottom:-20px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.08)}
.wa__icon{width:56px;height:56px;background:rgba(255,255,255,.15);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}
.wa__icon svg{width:28px;height:28px;fill:#fff}
.wa h3{color:#fff;font-size:1.3rem;font-weight:700;margin-bottom:.3rem}
.wa p{color:rgba(255,255,255,.85);font-size:.92rem;max-width:420px}
.wa__perks{display:flex;gap:1.5rem;margin-top:.75rem;flex-wrap:wrap}
.wa__perk{display:flex;align-items:center;gap:.4rem;font-size:.82rem;font-weight:600;color:rgba(255,255,255,.9)}
.wa__perk::before{content:'';width:7px;height:7px;background:var(--sunny);border-radius:50%;flex-shrink:0}
.wa .btn{background:#fff;color:#128C7E;position:relative;z-index:1;font-size:.95rem;padding:.85rem 1.8rem}
.wa .btn:hover{background:var(--cream);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
@media(max-width:768px){.wa{grid-template-columns:1fr;padding:2rem;text-align:center}.wa__perks{justify-content:center}}

/* ===========================================
   DEADLINE BANNER
   =========================================== */
.dl-banner{background:var(--charcoal);border-radius:var(--r-xl);padding:2.75rem 3rem;position:relative;overflow:hidden}
.dl-banner::before{content:'';position:absolute;right:-30px;bottom:-30px;width:250px;height:250px;border-radius:50%;background:radial-gradient(circle,rgba(163,50,129,.15) 0%,transparent 70%)}
.dl-banner h2{color:var(--cream);font-size:1.35rem;margin-bottom:.45rem}
.dl-banner>p{color:rgba(245,241,233,.55);font-size:.9rem;margin-bottom:1.25rem;max-width:530px}
.dl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:.8rem;margin-top:1rem}
.dl-card{background:rgba(245,241,233,.06);border:1px solid rgba(245,241,233,.08);border-radius:var(--r-md);padding:1rem 1.1rem;transition:background .2s;display:block}
.dl-card:hover{background:rgba(245,241,233,.1)}
.dl-card__title{font-size:.86rem;font-weight:600;color:var(--cream);line-height:1.4;margin-bottom:.2rem}
.dl-card__meta{font-size:.73rem;color:var(--sunny);font-weight:600}

/* ===========================================
   VIDEO GRID
   =========================================== */
.vid-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem}
.vid{border-radius:var(--r-lg);overflow:hidden;position:relative;aspect-ratio:16/9;background:#111;cursor:pointer}
.vid img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.vid:hover img{transform:scale(1.05)}
.vid__over{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.25);transition:background .3s}
.vid:hover .vid__over{background:rgba(0,0,0,.1)}
.vid__play{width:58px;height:58px;background:rgba(255,255,255,.95);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(0,0,0,.3);transition:transform .3s}
.vid:hover .vid__play{transform:scale(1.1)}
.vid__play svg{width:22px;height:22px;fill:var(--plum);margin-left:3px}
@media(max-width:600px){.vid-grid{grid-template-columns:1fr}}

/* ===========================================
   COUNTRY PILLS
   =========================================== */
.pills{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.2rem}
.pill{display:inline-flex;align-items:center;gap:.45rem;background:var(--surface);border:2px solid var(--border);padding:.5rem 1.1rem;border-radius:50px;font-weight:700;font-size:.83rem;color:var(--charcoal);transition:all .2s}
.pill:hover{border-color:var(--plum);background:var(--plum);color:var(--cream);transform:translateY(-2px);box-shadow:var(--sh-md)}
.pill span[aria-hidden]{font-size:1.1rem}

/* ===========================================
   MOST READ
   =========================================== */
.mr-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.mr-item{display:flex;align-items:flex-start;gap:.85rem;background:var(--surface);border-radius:var(--r-md);padding:1.1rem;box-shadow:var(--sh-sm);transition:all .3s;border-left:4px solid var(--plum)}
.mr-item:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.mr-num{font-family:var(--font-display);font-size:1.5rem;font-weight:800;color:var(--coral);line-height:1;flex-shrink:0;min-width:2rem}
.mr-title{font-size:.86rem;font-weight:600;line-height:1.45}
@media(max-width:768px){.mr-list{grid-template-columns:1fr}}

/* ===========================================
   ABOUT SECTION
   =========================================== */
.about{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:center}
.about__photo{position:relative}
.about__photo img{width:100%;aspect-ratio:1/1;border-radius:var(--r-xl);object-fit:cover;box-shadow:var(--sh-lg)}
.about__photo::after{content:'';position:absolute;inset:10px;border:3px solid var(--teal);border-radius:var(--r-xl);pointer-events:none;z-index:-1;transform:translate(10px,10px)}
.about__label{display:inline-flex;align-items:center;gap:.5rem;font-size:.76rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);margin-bottom:.65rem}
.about h2{font-size:1.6rem;font-weight:700;color:var(--charcoal);margin-bottom:.85rem}
.about p{color:var(--text-mid);font-size:.95rem;line-height:1.8;margin-bottom:.85rem}
.about p a{color:var(--plum);font-weight:700}
.about p a:hover{text-decoration:underline}
.about__ctas{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.35rem}
@media(max-width:768px){.about{grid-template-columns:1fr}.about__photo{max-width:340px;margin:0 auto}}

/* ===========================================
   NEWSLETTER
   =========================================== */
.nl{background:linear-gradient(145deg,var(--plum) 0%,var(--plum-dark) 100%);border-radius:var(--r-xl);padding:2.5rem 3rem;text-align:center;position:relative;overflow:hidden}
.nl h2{color:var(--cream);font-size:1.3rem;margin-bottom:.3rem}
.nl p{color:rgba(245,241,233,.6);font-size:.9rem;margin-bottom:1.2rem}
.nl__form{display:flex;gap:.5rem;max-width:420px;margin:0 auto}
.nl__form input{flex:1;padding:.7rem 1rem;border:2px solid rgba(245,241,233,.2);border-radius:50px;background:rgba(255,255,255,.1);color:var(--cream);font-family:var(--font-body);font-size:.9rem}
.nl__form input::placeholder{color:rgba(245,241,233,.4)}
.nl__form input:focus{outline:none;border-color:var(--sunny)}
@media(max-width:500px){.nl{padding:2rem 1.5rem}.nl__form{flex-direction:column}}

/* ===========================================
   TABS
   =========================================== */
.tabs__nav{display:flex;gap:.25rem;border-bottom:2px solid var(--border);margin-bottom:1.5rem}
.tabs__btn{padding:.6rem 1.2rem;font-family:var(--font-display);font-weight:600;font-size:.88rem;color:var(--text-light);background:none;border:none;cursor:pointer;position:relative;transition:color .2s}
.tabs__btn--active{color:var(--plum)}
.tabs__btn.active,.tabs__btn--active{color:var(--plum)}
.tabs__btn.active::after,.tabs__btn--active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--plum);border-radius:3px 3px 0 0}
.tabs__panel{display:none}
.tabs__panel.active,.tabs__panel--active{display:block}

/* ===========================================
   FAQ ACCORDION
   =========================================== */
.faq-item{border-bottom:1px solid var(--border);padding:1rem 0}
.faq-item summary{font-family:var(--font-display);font-weight:600;font-size:.95rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.2rem;color:var(--plum);font-weight:700;transition:transform .2s}
.faq-item[open] summary::after{content:'-'}
.faq-item .faq-answer{padding:.5rem 0 1rem;color:var(--text-mid);font-size:.9rem;line-height:1.8}

/* ===========================================
   PRICING CARDS
   =========================================== */
.pricing-card{background:var(--surface);border-radius:var(--r-xl);padding:2rem;box-shadow:var(--sh-md);border:2px solid var(--border);position:relative}
.pricing-card--featured{border-color:var(--plum);box-shadow:var(--sh-lg)}
.pricing-card__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--plum);color:var(--cream);padding:.25rem 1rem;border-radius:50px;font-size:.75rem;font-weight:700;white-space:nowrap}
.pricing-card h3{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}
.pricing-card__price{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--plum);margin-bottom:1rem}
.pricing-card__features{margin-bottom:1.5rem}
.pricing-card__features li{padding:.35rem 0;font-size:.88rem;color:var(--text-mid);display:flex;align-items:center;gap:.5rem}
.pricing-card__features li::before{content:'';width:6px;height:6px;background:var(--teal);border-radius:50%;flex-shrink:0}

/* ===========================================
   STATS BAR
   =========================================== */
.stats-bar{background:var(--charcoal);border-radius:var(--r-xl);padding:2rem 3rem;display:flex;justify-content:center;gap:4rem}
.stats-bar__item{text-align:center}
.stats-bar__num{font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--sunny)}
.stats-bar__label{font-size:.78rem;color:rgba(245,241,233,.5);margin-top:.2rem}
@media(max-width:600px){.stats-bar{flex-direction:column;gap:1.5rem;padding:1.5rem}}

/* ===========================================
   TIMELINE
   =========================================== */
.timeline{position:relative;padding-left:2rem}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--border);border-radius:3px}
.timeline__item{position:relative;padding-bottom:1.5rem;padding-left:1.5rem}
.timeline__item::before{content:'';position:absolute;left:-2rem;top:.35rem;width:13px;height:13px;background:var(--plum);border-radius:50%;border:3px solid var(--bg)}
.timeline__year{font-family:var(--font-display);font-weight:700;font-size:.85rem;color:var(--plum);margin-bottom:.2rem}
.timeline__text{font-size:.9rem;color:var(--text-mid);line-height:1.6}

/* ===========================================
   BREADCRUMB
   =========================================== */
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-light);padding:1rem 0;flex-wrap:wrap}
.breadcrumb a{color:var(--text-mid);transition:color .2s}
.breadcrumb a:hover{color:var(--plum)}
.breadcrumb__sep{color:var(--border)}

/* ===========================================
   PAGINATION
   =========================================== */
.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin:2.5rem 0}
.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-sm);font-family:var(--font-display);font-weight:600;font-size:.85rem;transition:all .2s}
.pagination a{background:var(--surface);border:1px solid var(--border);color:var(--text-mid)}
.pagination a:hover{border-color:var(--plum);color:var(--plum)}
.pagination .active{background:var(--plum);color:var(--cream);border:none}
.pagination .dots{background:none;border:none;color:var(--text-light)}

/* ===========================================
   FORMS
   =========================================== */
.form-group{margin-bottom:1.2rem}
.form-group label{display:block;font-family:var(--font-display);font-weight:600;font-size:.85rem;margin-bottom:.4rem;color:var(--text)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.7rem 1rem;border:2px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:.9rem;color:var(--text);background:var(--surface);transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--plum)}
.form-group textarea{resize:vertical;min-height:120px}
.form-group .help-text{font-size:.78rem;color:var(--text-light);margin-top:.3rem}
.form-check{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;color:var(--text-mid)}
.form-check input[type="checkbox"]{margin-top:.25rem;accent-color:var(--plum)}

/* ===========================================
   FOOTER
   =========================================== */
.footer{background:var(--charcoal);color:rgba(245,241,233,.7);padding:4rem 0 2rem}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer__brand img{height:42px;filter:brightness(10)}
.footer__brand p{font-size:.86rem;line-height:1.7;margin-top:1rem;max-width:270px}
.footer h4{color:var(--cream);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.9rem}
.footer__links a{display:block;padding:.25rem 0;font-size:.86rem;color:rgba(245,241,233,.5);transition:color .2s}
.footer__links a:hover{color:var(--sunny)}
.footer__social{display:flex;gap:.55rem;margin-top:.4rem;flex-wrap:wrap}
.footer__social a{width:34px;height:34px;border-radius:8px;background:rgba(245,241,233,.08);display:flex;align-items:center;justify-content:center;color:rgba(245,241,233,.55);transition:all .2s}
.footer__social a:hover{background:var(--plum);color:#fff}
.footer__social svg{width:15px;height:15px;fill:currentColor}
.footer__bottom{border-top:1px solid rgba(245,241,233,.08);padding-top:1.4rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.78rem;color:rgba(245,241,233,.3)}
.footer__bottom a{color:rgba(245,241,233,.45)}
.footer__bottom a:hover{color:var(--sunny)}
@media(max-width:768px){.footer__grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:480px){.footer__grid{grid-template-columns:1fr}}

/* ===========================================
   HERO SMALL (inner pages)
   =========================================== */
.hero-sm{background:linear-gradient(145deg,var(--teal) 0%,var(--teal-dark) 100%);padding:3.5rem 0;position:relative;overflow:hidden}
.hero-sm::before{content:'';position:absolute;top:-80px;right:-40px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%)}
.hero-sm h1{font-size:2.2rem;font-weight:800;color:var(--cream);margin-bottom:.5rem}
.hero-sm p{color:rgba(245,241,233,.6);font-size:1rem;max-width:550px}
.hero-sm__actions{margin-top:1.5rem}

/* ===========================================
   MENTORIA CTA BANNER
   =========================================== */
.mentoria-banner{background:linear-gradient(145deg,var(--plum) 0%,var(--plum-dark) 100%);border-radius:var(--r-xl);padding:2.5rem 3rem;text-align:center;position:relative;overflow:hidden}
.mentoria-banner::before{content:'';position:absolute;left:-30px;top:-30px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(0,155,131,.15) 0%,transparent 70%)}
.mentoria-banner h2{color:var(--cream);font-size:1.3rem;margin-bottom:.4rem}
.mentoria-banner p{color:rgba(245,241,233,.6);font-size:.9rem;margin-bottom:1.2rem;max-width:500px;margin-left:auto;margin-right:auto}

/* ===========================================
   PRICING GRID
   =========================================== */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}

/* ===========================================
   RICH CONTENT (HTML from editor)
   =========================================== */
.rich-content h2{font-size:1.4rem;font-weight:700;margin:2rem 0 .8rem;color:var(--charcoal)}
.rich-content h3{font-size:1.15rem;font-weight:700;margin:1.5rem 0 .6rem;color:var(--charcoal)}
.rich-content p{margin-bottom:1rem;line-height:1.8;color:var(--text-mid)}
.rich-content a{color:var(--plum);font-weight:600}
.rich-content a:hover{text-decoration:underline}
.rich-content img{border-radius:var(--r-md);margin:1rem 0}
.rich-content ul,.rich-content ol{margin:1rem 0;padding-left:1.5rem}
.rich-content li{margin-bottom:.4rem;line-height:1.7;color:var(--text-mid)}
.rich-content blockquote{border-left:4px solid var(--plum);padding:1rem 1.5rem;margin:1.5rem 0;background:var(--plum-pale);border-radius:0 var(--r-sm) var(--r-sm) 0}

/* ===========================================
   FAQ (details/summary variant)
   =========================================== */
.faq-list{max-width:700px}
.faq-q{font-family:var(--font-display);font-weight:600;font-size:.95rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;padding:.8rem 0}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:'+';font-size:1.2rem;color:var(--plum);font-weight:700}
details[open] .faq-q::after{content:'\2212'}
.faq-a{padding:0 0 1rem;color:var(--text-mid);font-size:.9rem;line-height:1.8}

/* ===========================================
   ADMIN HEADER
   =========================================== */
.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}
.admin-actions{display:flex;gap:.4rem;align-items:center}

/* ===========================================
   BREADCRUMB BAR
   =========================================== */
.breadcrumb-bar{background:var(--surface-warm);border-bottom:1px solid var(--border);padding:.6rem 0}
.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-light);flex-wrap:wrap}
.breadcrumb a{color:var(--text-mid);font-weight:500}
.breadcrumb a:hover{color:var(--plum)}
.breadcrumb__sep{color:var(--border)}

/* ===========================================
   BADGES
   =========================================== */
.badge{display:inline-flex;align-items:center;padding:.25rem .7rem;border-radius:50px;font-size:.72rem;font-weight:700;font-family:var(--font-display);letter-spacing:.02em}
.badge--teal{background:var(--teal);color:#fff}
.badge--sunny{background:var(--sunny);color:var(--charcoal)}
.badge--plum{background:var(--plum);color:#fff}
.badge--muted{background:var(--surface-warm);color:var(--text-light)}
.badge--ghost{background:rgba(255,255,255,.15);color:var(--cream);border:1px solid rgba(255,255,255,.25)}

/* ===========================================
   SEARCH & FILTERS
   =========================================== */
.search-section{max-width:900px;margin:0 auto}
.filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;align-items:end}
.filters__field label{display:block;font-family:var(--font-display);font-weight:600;font-size:.78rem;margin-bottom:.3rem;color:var(--text-mid)}
.filters__field input,.filters__field select{width:100%;padding:.6rem .8rem;border:2px solid var(--border);border-radius:var(--r-sm);font-family:var(--font-body);font-size:.88rem;background:var(--surface);transition:border-color .2s}
.filters__field input:focus,.filters__field select:focus{outline:none;border-color:var(--plum)}
.filters__action{display:flex;align-items:end}
.filters__action .btn{width:100%}

/* ===========================================
   TOOLBAR
   =========================================== */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.toolbar__count{font-size:.88rem;color:var(--text-mid)}

/* ===========================================
   SCHOLARSHIP CARDS
   =========================================== */
.scholarship-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:1.25rem}
@media(max-width:520px){.scholarship-grid{grid-template-columns:1fr}}
.scholarship-card{background:var(--surface);border-radius:var(--r-lg);padding:1.4rem;border-left:4px solid var(--plum);box-shadow:var(--sh-sm);transition:all .3s}
.scholarship-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);border-left-color:var(--teal)}
.scholarship-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.6rem}
.scholarship-card__title{font-size:1rem;font-weight:700;line-height:1.4;flex:1}
.scholarship-card__title a{color:var(--text);text-decoration:none}
.scholarship-card__title a:hover{color:var(--plum)}
.scholarship-card__meta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}
.scholarship-card__meta-item{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text-light)}
.scholarship-card__meta-item svg{flex-shrink:0;color:var(--text-light)}
.scholarship-card__desc{font-size:.86rem;color:var(--text-mid);line-height:1.65;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.scholarship-card__link{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-display);font-weight:700;font-size:.82rem;color:var(--plum);margin-top:.75rem;transition:gap .2s}
.scholarship-card__link:hover{gap:.6rem;color:var(--plum-dark)}

/* ===========================================
   BOLSA DETAIL LAYOUT
   =========================================== */
.bolsa-hero__tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}
.bolsa-layout{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}
@media(max-width:800px){.bolsa-layout{grid-template-columns:1fr}}
.bolsa-main__image{width:100%;border-radius:var(--r-lg);margin-bottom:1.5rem}
.bolsa-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.bolsa-section h2{font-size:1.2rem;margin-bottom:1rem}

/* Sidebar card */
.sidebar-card{background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-md);overflow:hidden;position:sticky;top:90px}
.sidebar-card__header{background:var(--charcoal);color:var(--cream);padding:.8rem 1.2rem;font-family:var(--font-display);font-weight:700;font-size:.9rem}
.sidebar-card__body{padding:1rem 1.2rem}
.sidebar-card__footer{padding:0 1.2rem 1.2rem}
.sidebar-row{display:flex;justify-content:space-between;align-items:center;padding:.55rem 0;border-bottom:1px solid var(--border)}
.sidebar-row:last-child{border-bottom:none}
.sidebar-row__label{font-size:.78rem;color:var(--text-light);font-weight:600;font-family:var(--font-display)}
.sidebar-row__value{font-size:.88rem;font-weight:500;text-align:right}
.sidebar-row__value a{color:var(--plum)}
.sidebar-source{margin-top:.75rem;text-align:center}
.sidebar-source a{color:var(--plum)}

/* Share */
.sidebar-share{margin-top:1rem;padding:1rem;background:var(--surface-warm);border-radius:var(--r-md)}
.sidebar-share__label{font-family:var(--font-display);font-weight:600;font-size:.78rem;color:var(--text-light);display:block;margin-bottom:.5rem}
.sidebar-share__icons{display:flex;gap:.5rem}
.sidebar-share__icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:50%;transition:all .2s}
.sidebar-share__icon:hover{background:var(--plum);transform:translateY(-2px)}
.sidebar-share__icon svg{width:16px;height:16px;fill:var(--text-mid)}
.sidebar-share__icon:hover svg{fill:var(--cream)}

/* ===========================================
   ARTICLE (BLOG POST) LAYOUT
   =========================================== */
.article-hero{position:relative;min-height:380px;background-size:cover;background-position:center;display:flex;align-items:flex-end}
.article-hero__overlay{width:100%;padding:3rem 0 2rem;background:linear-gradient(transparent,rgba(45,48,71,.85))}
.article-hero__overlay h1{color:var(--cream);font-size:2rem;margin-top:.75rem}
.article-hero__meta{color:rgba(245,241,233,.6);font-size:.85rem;margin-top:.5rem}
.article-layout{max-width:760px;margin:0 auto}
.article-body .lead{font-size:1.1rem;font-weight:500;color:var(--text);line-height:1.7;margin-bottom:1.5rem}
.article-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.article-tags__label{font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--text-light);margin-right:.3rem}
.tag-pill{display:inline-block;padding:.3rem .7rem;background:var(--plum-pale);color:var(--plum);border-radius:50px;font-size:.75rem;font-weight:600;transition:all .2s}
.tag-pill:hover{background:var(--plum);color:var(--cream)}
.article-share{display:flex;align-items:center;gap:.75rem;margin-top:1.5rem;padding:1rem;background:var(--surface-warm);border-radius:var(--r-md);font-family:var(--font-display);font-weight:600;font-size:.82rem;color:var(--text-light)}

/* ===========================================
   POST GRID
   =========================================== */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}

/* ===========================================
   TAXONOMY GRID
   =========================================== */
.taxonomy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.taxonomy-card{display:flex;flex-direction:column;align-items:center;padding:1.5rem 1rem;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--sh-sm);transition:all .3s;text-align:center;text-decoration:none;border:2px solid transparent}
.taxonomy-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:var(--plum)}
.taxonomy-card__name{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.3rem}
.taxonomy-card__count{font-size:.82rem;color:var(--text-light)}

/* ===========================================
   EMPTY STATE
   =========================================== */
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-light)}
.empty-state p{margin-bottom:1rem}

/* ===========================================
   PAGINATION
   =========================================== */
.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.pagination__link{font-family:var(--font-display);font-weight:600;font-size:.88rem;color:var(--plum);padding:.5rem 1rem;border:2px solid var(--plum);border-radius:50px;transition:all .2s}
.pagination__link:hover{background:var(--plum);color:var(--cream)}
.pagination__info{font-size:.85rem;color:var(--text-light)}
