/*
Theme Name: FINTAC
Theme URI: https://finanzasentacones.com
Author: FINTAC
Author URI: https://finanzasentacones.com
Description: Tema editorial FINTAC — comunidad, finanzas y bienestar. Prototipo de diseño.
Version: 1.0.3
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: fintac
Tags: custom-menu, custom-logo, featured-images, translation-ready
*/

@import url('assets/css/main.css');

/* ========== Páginas interiores (prototipo) ========== */
.page-hero{padding-top:48px;padding-bottom:24px;}
.page-hero .sec-title{max-width:20ch;}
.page-body{padding-bottom:80px;}
.page-body .page-block{
  background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:48px;margin-bottom:24px;
}
.page-body .page-block p{
  font-size:16px;line-height:1.65;color:var(--ink-2);
}
.page-body .page-block p + p{margin-top:16px;}
.cat-hero .sec-title{max-width:24ch;}
.cat-count{
  margin-top:12px;font-size:13px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);
}
.cat-archive{padding-bottom:80px;}
.cat-archive-grid{margin-bottom:48px;}
.cat-archive-grid .l2-thumb{min-height:180px;position:relative;overflow:hidden;}
.cat-archive-grid .l2-thumb .card-thumb-img,
.cat-archive-grid .b-thumb .card-thumb-img,
.cat-archive-grid .r-thumb .card-thumb-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0;
}
.cat-archive-grid .l2-thumb.has-image::before,
.cat-archive-grid .l2-thumb.has-image::after{display:none;}
.cat-pagination{
  display:flex;justify-content:center;margin-top:8px;
}
.cat-pagination .page-numbers,
.cat-pagination ul.page-numbers{
  display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0;align-items:center;
}
.cat-pagination li{display:inline-flex;}
.cat-pagination .page-numbers a,
.cat-pagination .page-numbers span,
.cat-pagination li .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;
  border-radius:12px;border:1px solid var(--line);
  background:#fff;color:var(--ink-2);
  font-size:13px;font-weight:700;text-decoration:none;
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.cat-pagination ul.page-numbers{
  display:flex;flex-wrap:wrap;gap:8px;list-style:none;
  margin:0;padding:0;
}
.cat-pagination li{display:inline-flex;}
.cat-pagination .page-numbers.current{
  background:var(--brand);border-color:var(--brand);color:#fff;
}
.cat-pagination a.page-numbers:hover{
  border-color:var(--brand);color:var(--brand);transform:translateY(-1px);
}
.cat-pagination .page-numbers.dots{
  border:none;background:transparent;min-width:auto;padding:0 6px;
}
.cat-notice{
  margin-bottom:28px;padding:16px 20px;
  border-radius:16px;border:1px solid var(--line);
  background:#fff;color:var(--ink-3);font-size:14px;line-height:1.55;
}
.cat-empty{
  text-align:center;padding:64px 24px;
  border:1px dashed var(--line-2);border-radius:24px;
  background:var(--brand-50);
}
.cat-empty p{margin-bottom:20px;color:var(--ink-3);font-size:15px;}
.cat-grid-placeholder{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media (max-width:900px){.cat-grid-placeholder{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.cat-grid-placeholder{grid-template-columns:1fr;}}
.cat-grid-placeholder .l2-card{cursor:default;}

/* Menú activo (prototipo) */
.nav-menu a.active{color:var(--brand);font-weight:700;}
.nav-cats a.active{background:rgba(255,255,255,.12);color:#fff;font-weight:600;}

/* ========== Acerca de ========== */
.page-video{
  border-radius:28px;overflow:hidden;
  border:1px solid var(--line);
  background:#000;margin-bottom:24px;
  box-shadow:0 24px 60px -24px var(--brand-glow);
}
.page-video video{display:block;width:100%;height:auto;vertical-align:top;}
.page-block-title{
  font-family:'DM Serif Display',serif;
  font-size:36px;line-height:1.1;letter-spacing:-.02em;
  color:var(--ink);margin-bottom:20px;
}
.page-quote{
  margin:0;padding:48px 56px;
  background:var(--brand);color:#fff;
  border-radius:28px;text-align:center;
  border:none;
}
.page-quote p{
  font-family:'DM Serif Display',serif;font-style:italic;
  font-size:clamp(28px,4vw,42px);line-height:1.2;
  margin:0;max-width:none;color:#fff;
}

/* ========== Nosotras — Ladies Finanzas ========== */
.ladies-team{display:flex;flex-direction:column;gap:40px;}
.lady-card{
  display:grid;grid-template-columns:minmax(280px,.95fr) 1.05fr;
  gap:36px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:28px;
  padding:32px;overflow:hidden;
}
.lady-card--reverse .lady-card-media{order:2;}
.lady-card--reverse .lady-card-copy{order:1;}
@media (max-width:900px){
  .lady-card,.lady-card--reverse{grid-template-columns:1fr;}
  .lady-card--reverse .lady-card-media,.lady-card--reverse .lady-card-copy{order:unset;}
}
.lady-card-media{position:relative;border-radius:22px;overflow:hidden;}
.lady-card-photo{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;}
.lady-card-name{
  position:absolute;left:20px;bottom:20px;right:20px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-radius:16px;padding:14px 18px;
  border:1px solid rgba(226,12,100,.15);
}
.lady-card-name img{height:42px;width:auto;max-width:100%;display:block;}
.lady-card-role{
  display:inline-block;margin-bottom:12px;
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--brand);
}
.lady-card-copy p{
  font-size:16px;line-height:1.65;color:var(--ink-2);margin:0;
}
.page-contact{
  text-align:center;padding:36px 28px;
  background:var(--brand-50);border:1px solid var(--line);
  border-radius:24px;
}
.page-contact p{font-size:16px;color:var(--ink-2);margin:0;}
.page-contact a{color:var(--brand);font-weight:700;}

.page-form{
  max-width:720px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:28px;
  padding:40px 32px;
}
.page-form .wpcf7,
.page-form .wpforms-container,
.page-form .fluentform,
.page-form form{margin:0;}
@media (max-width:768px){
  .page-form{padding:28px 20px;}
}

/* ========== Contacto ========== */
.contact-layout{
  max-width:720px;
  margin:0 auto;
}
.contact-form-wrap{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:40px 32px;
}
@media (max-width:768px){
  .contact-form-wrap{padding:28px 20px;}
}
.fintac-contact-form{display:flex;flex-direction:column;gap:24px;}
.fintac-contact-honeypot{
  position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;
}
.contact-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:20px;
}
@media (max-width:640px){
  .contact-form-grid{grid-template-columns:1fr;}
}
.contact-field{display:flex;flex-direction:column;gap:8px;}
.contact-field label{
  font-size:11px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-3);
}
.contact-field input,
.contact-field select,
.contact-field textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px 16px;
  font-family:'Montserrat',sans-serif;
  font-size:15px;
  color:var(--ink);
  background:#fff;
  transition:border-color .2s, box-shadow .2s;
}
.contact-field input:focus,
.contact-field select:focus,
.contact-field textarea:focus{
  outline:none;
  border-color:var(--brand);
  box-shadow:0 0 0 3px var(--brand-glow);
}
.contact-field textarea{resize:vertical;min-height:140px;}
.contact-form-submit{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  align-self:center;
  padding:16px 28px;
  border:0;border-radius:100px;
  background:var(--brand);color:#fff;
  font-family:'Montserrat',sans-serif;
  font-size:13px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;
  transition:background .2s, transform .2s;
}
.contact-form-submit:hover{
  background:var(--brand-deep);
  transform:translateY(-1px);
}
.contact-form-notice{
  border-radius:16px;
  padding:16px 18px;
  margin-bottom:20px;
  font-size:14px;line-height:1.5;
}
.contact-form-notice strong{display:block;margin-bottom:4px;}
.contact-form-notice--success{
  background:var(--brand-soft);
  border:1px solid var(--brand-light);
  color:var(--ink);
}
.contact-form-notice--error{
  background:#fff5f7;
  border:1px solid #f5c2cf;
  color:#9b1c3d;
}
.contact-form-notice.hidden{display:none;}

/* ========== Finanzas para llevar ========== */
.fpl-wrap{max-width:720px;margin:0 auto;}
.fpl-card{
  background:#fff;border:1px solid var(--line);border-radius:28px;
  padding:48px;text-align:center;
}
.fpl-list{
  list-style:none;margin:28px 0 32px;padding:0;
  display:flex;flex-direction:column;gap:14px;text-align:left;
}
.fpl-list li{
  position:relative;padding:16px 18px 16px 52px;
  background:var(--brand-soft);border-radius:14px;
  font-size:15px;font-weight:600;color:var(--ink);
}
.fpl-list li::before{
  content:"";position:absolute;left:18px;top:50%;transform:translateY(-50%);
  width:10px;height:10px;border-radius:50%;background:var(--brand);
}
.fpl-soon{margin:28px 0 20px;}
.fpl-soon-badge{
  display:inline-block;padding:8px 16px;border-radius:100px;
  background:var(--brand);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
}
.fpl-soon p{margin-top:10px;font-size:14px;color:var(--ink-3);}
.fpl-email{font-size:15px;color:var(--ink-2);margin:0;}
.fpl-email a{color:var(--brand);font-weight:700;}

/* ========== Red FINTAC ========== */
.red-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
@media (max-width:1024px){.red-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:640px){.red-grid{grid-template-columns:1fr;}}
.red-card{
  position:relative;
  aspect-ratio:3/4;
  border-radius:24px;overflow:hidden;
  border:1px solid var(--line);
  transition:transform .35s cubic-bezier(.4,0,.2,1), box-shadow .35s;
}
.red-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 50px -18px var(--brand-glow);
}
.red-card-photo{position:absolute;inset:0;}
.red-card-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  display:block;transition:transform .6s;
}
.red-card:hover .red-card-photo img{transform:scale(1.05);}
.red-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(91,22,69,.92) 0%, rgba(226,12,100,.25) 45%, transparent 72%);
  opacity:.88;transition:opacity .3s;
}
.red-card:hover .red-card-overlay{opacity:1;}
.red-card-info{
  position:absolute;left:0;right:0;bottom:0;
  padding:24px 22px 22px;z-index:2;color:#fff;
}
.red-card-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--accent);margin-bottom:10px;
  box-shadow:0 0 0 4px rgba(194,155,94,.35);
}
.red-card-name{
  font-family:'DM Serif Display',serif;
  font-size:clamp(22px,2.5vw,28px);line-height:1.1;margin:0;
}

/* ========== Tarjetas enlazables ========== */
a.b-card,a.l2-card{
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
}

/* ========== Lectura de nota ========== */
.article{background:#fff;}
.article-inner{
  max-width:760px;
  margin:0 auto;
  padding-top:40px;
  padding-bottom:64px;
}
.article-hero{
  padding:0 0 28px;
  border-bottom:1px solid var(--line);
  margin-bottom:8px;
}
.article-back{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brand);margin-bottom:20px;text-decoration:none;
  transition:gap .2s;
}
.article-back:hover{gap:10px;}
.article-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  font-size:13px;color:var(--ink-3);margin-bottom:16px;
}
.article-cat{
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--brand);
}
.article-meta-sep{opacity:.5;}
.article-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(32px,4.5vw,52px);line-height:1.1;letter-spacing:-.02em;
  color:var(--ink);margin:0 0 20px;
}
.article-deck{
  font-size:clamp(17px,2vw,20px);line-height:1.6;
  color:var(--ink-2);margin:0 0 24px;
}
.article-actions{margin-top:8px;}
.article-actions .share-row{margin-left:0;}
.article-actions .share-label{color:var(--ink-3);}
.article-actions .share-btn{
  width:36px;height:36px;border-radius:10px;
  background:#fff;border:1px solid var(--line);color:var(--ink-2);
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .2s;
  text-decoration:none;cursor:pointer;padding:0;
}
.article-actions .share-btn:hover{
  background:var(--brand);border-color:var(--brand);color:#fff;transform:translateY(-2px);
}

.article-cover{padding:0 0 32px;margin:0;}
.article-cover-frame{
  border-radius:20px;overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 16px 40px -24px var(--brand-glow);
  aspect-ratio:16/9;
  background:var(--brand-50);
}
@media (max-width:768px){.article-cover-frame{aspect-ratio:4/3;}}
.article-cover-img{
  width:100%;height:100%;object-fit:cover;object-position:center;display:block;
}
.article-cover-caption{
  margin-top:12px;font-size:13px;color:var(--ink-3);
  text-align:center;font-style:italic;
}

.article-body{padding:0;}

.article-callout{
  padding:28px 32px;margin-bottom:36px;
  background:var(--brand);color:#fff;border-radius:24px;
}
.article-callout-label{
  display:block;font-size:10px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;opacity:.85;margin-bottom:10px;
}
.article-callout p{
  font-family:'DM Serif Display',serif;font-size:clamp(22px,3vw,30px);
  line-height:1.25;margin:0;font-style:italic;
}

.article-content{font-size:17px;line-height:1.75;color:var(--ink-2);}
.article-content p{margin:0 0 20px;}
.article-content h2{
  font-family:'DM Serif Display',serif;
  font-size:clamp(28px,3.5vw,36px);line-height:1.15;
  color:var(--ink);margin:40px 0 16px;letter-spacing:-.02em;
  scroll-margin-top:100px;
}
.article-content h3{
  font-size:18px;font-weight:700;color:var(--ink);
  margin:0 0 10px;
}
.article-content strong{color:var(--ink);font-weight:700;}

.article-stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
  margin:28px 0 36px;
}
@media (max-width:600px){.article-stats{grid-template-columns:1fr;}}
.article-stat{
  padding:24px;border-radius:20px;
  background:var(--brand-soft);border:1px solid var(--line);
  text-align:center;
}
.article-stat-num{
  display:block;font-family:'DM Serif Display',serif;
  font-size:clamp(32px,4vw,44px);color:var(--brand);line-height:1;
  margin-bottom:8px;
}
.article-stat-label{font-size:13px;line-height:1.45;color:var(--ink-3);}

.article-list{
  margin:0 0 24px;padding:0;list-style:none;
  display:flex;flex-direction:column;gap:12px;
}
.article-list li{
  position:relative;padding:14px 18px 14px 44px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  font-size:15px;line-height:1.55;
}
.article-list li::before{
  content:"";position:absolute;left:18px;top:20px;
  width:8px;height:8px;border-radius:50%;background:var(--brand);
}
.article-list--ordered{counter-reset:article-step;}
.article-list--ordered li::before{
  content:counter(article-step);counter-increment:article-step;
  width:24px;height:24px;border-radius:50%;
  background:var(--brand);color:#fff;
  font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  top:14px;left:12px;
}

.article-pullquote{
  margin:36px 0;padding:0;border:none;
  text-align:center;
}
.article-pullquote p{
  font-family:'DM Serif Display',serif;font-style:italic;
  font-size:clamp(26px,3.5vw,38px);line-height:1.2;
  color:var(--brand);margin:0 0 12px;
}
.article-pullquote cite{
  font-size:12px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-3);font-style:normal;
}

.article-quote{
  margin:32px 0;padding:32px 36px;
  background:var(--brand-50);border-left:4px solid var(--brand);
  border-radius:0 20px 20px 0;
}
.article-quote p{
  font-family:'DM Serif Display',serif;font-style:italic;
  font-size:clamp(20px,2.5vw,26px);line-height:1.35;
  color:var(--ink);margin:0;
}

.article-inline-media{margin:32px 0;}
.article-inline-img{
  width:100%;border-radius:20px;display:block;
  border:1px solid var(--line);
}
.article-inline-media figcaption{
  margin-top:10px;font-size:13px;color:var(--ink-3);text-align:center;
}

.article-highlight{
  margin:32px 0;padding:28px 32px;
  background:#fff;border:2px solid var(--brand-light);
  border-radius:20px;
}
.article-highlight p{margin:0;font-size:16px;line-height:1.6;}

.article-editorial{
  display:flex;gap:20px;align-items:flex-start;
  margin:48px 0 32px;padding:28px 32px;
  background:#fff;border:1px solid var(--line);border-radius:24px;
}
.article-editorial-icon{
  flex-shrink:0;width:48px;height:48px;border-radius:50%;
  border:1px solid var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
}
.article-editorial-label{
  display:block;font-size:10px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--brand);margin-bottom:4px;
}
.article-editorial-copy strong{
  display:block;font-size:18px;color:var(--ink);margin-bottom:8px;
}
.article-editorial-copy p{
  font-size:14px;line-height:1.6;color:var(--ink-3);margin:0;
}

.article-tags{margin-bottom:16px;}
.article-tags-label{
  display:block;font-size:10px;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-3);margin-bottom:12px;
}
.article-tags-list{display:flex;flex-wrap:wrap;gap:8px;}
.article-tag{
  padding:8px 14px;border-radius:100px;
  background:var(--brand-soft);border:1px solid var(--line);
  font-size:12px;font-weight:600;color:var(--ink-2);
}

.article-nav{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  margin-top:40px;padding-top:32px;
  border-top:1px solid var(--line);
}
@media (max-width:640px){.article-nav{grid-template-columns:1fr;}}
.article-nav-link{
  display:flex;flex-direction:column;gap:6px;
  padding:20px 22px;border-radius:18px;
  background:#fff;border:1px solid var(--line);
  text-decoration:none;transition:all .25s;
}
.article-nav-link:hover{
  border-color:var(--brand-light);
  box-shadow:0 12px 32px -16px var(--brand-glow);
  transform:translateY(-2px);
}
.article-nav-link--next{text-align:right;}
.article-nav--end{grid-template-columns:1fr;justify-items:end;}
.article-nav--start{grid-template-columns:1fr;justify-items:start;}
.article-nav--end .article-nav-link,
.article-nav--start .article-nav-link{max-width:100%;}
@media (min-width:641px){
  .article-nav--end .article-nav-link,
  .article-nav--start .article-nav-link{max-width:calc(50% - 8px);}
}
@media (max-width:640px){
  .article-nav-link--next{text-align:left;}
}
.article-nav-label{
  font-size:11px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--brand);
}
.article-nav-title{
  font-family:'DM Serif Display',serif;
  font-size:17px;line-height:1.25;color:var(--ink);
}

.article-related{
  padding-top:48px;padding-bottom:80px;
  border-top:1px solid var(--line);
  background:var(--brand-50);
}
.article-related .latest a.l2-card{cursor:pointer;}
