/*
Theme Name: Taino Libre
Theme URI: https://tainoestudio.com/themes/taino-libre
Author: Thony Polonia
Author URI: https://tainoestudio.com
Description: Periódico digital dominicano. Elementor Pro, SEO, mobile-first.
Version: 3.0.0
License: GNU General Public License v2 or later
Text Domain: taino-libre
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.1
Tags: news, magazine, newspaper, elementor, right-sidebar, custom-logo, featured-images, footer-widgets, translation-ready
*/

:root{
--tl-verde:#1A6B5A;
--tl-verde-hover:#155A4B;
--tl-verde-dark:#0F4A3D;
--tl-verde-light:#218E76;
--tl-verde-claro:#2E9E84;
--tl-marron:#8B4226;
--tl-marron-claro:#A0522D;
--tl-rojo:#C62828;
--tl-negro:#1A1A1A;
--tl-gris:#666;
--tl-gris-borde:#D8D4C8;
--tl-crema:#F0EEE6;
--tl-blanco:#FFFFFF;
--font-logo:'Libre Franklin','Arial Black',sans-serif;
--font-head:'Merriweather',Georgia,serif;
--font-nav:'Open Sans','Segoe UI',sans-serif;
--font-body:'Open Sans',Arial,sans-serif;
--max-w:1200px;
--sidebar:300px;
--gap:24px;
--tr:0.25s ease;
}

[data-theme="dark"]{--tl-crema:#151515;--tl-blanco:#1E1E1E;--tl-negro:#E8E8E8;--tl-gris:#AAA;--tl-gris-borde:#333}
[data-theme="dark"] .tl-header{background:#151515}
[data-theme="dark"] .tl-card{background:#1E1E1E;border:1px solid #333}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);font-size:14px;line-height:1.6;color:var(--tl-negro);background:var(--tl-crema);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--tl-negro);text-decoration:none;transition:color var(--tr)}
a:hover{color:var(--tl-verde)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);color:var(--tl-negro);line-height:1.3;font-weight:700}
p{margin-bottom:12px}
ul,ol{list-style:none}
.sr-only{clip:rect(1px,1px,1px,1px);position:absolute!important;height:1px;width:1px;overflow:hidden}

.tl-container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 16px}

/* === TOPBAR cream bg === */
.tl-topbar{background:var(--tl-crema);color:var(--tl-gris);font-size:11px;font-family:var(--font-nav);height:32px;line-height:32px;border-bottom:1px solid var(--tl-gris-borde)}
.tl-topbar .tl-container{display:flex;justify-content:space-between;align-items:center}
.tl-topbar__right{display:flex;align-items:center;gap:12px}
.tl-topbar__search{display:flex;background:var(--tl-blanco);border:1px solid var(--tl-gris-borde);border-radius:3px;height:24px}
.tl-topbar__search input{background:0;border:0;color:var(--tl-negro);font-size:11px;padding:0 8px;width:150px;outline:0}
.tl-topbar__search input::placeholder{color:#aaa}
.tl-topbar__search button{background:var(--tl-verde);border:0;color:#fff;padding:0 8px;height:24px;cursor:pointer;display:flex;align-items:center}
.tl-topbar__dm{background:0;border:0;color:var(--tl-gris);cursor:pointer;padding:4px}
.tl-topbar__dm svg{width:16px;height:16px}

/* === HEADER: logo izq + nav der en misma línea === */
.tl-header{background:var(--tl-crema);padding:10px 0;position:relative}
.tl-header .tl-container{display:flex;align-items:center;justify-content:space-between}

.tl-logo{text-decoration:none;display:flex;align-items:center;flex-shrink:0}
.tl-logo__wrap{display:flex;flex-direction:column}
.tl-logo__name{font-family:var(--font-logo);font-size:clamp(24px,3vw,36px);font-weight:900;line-height:1;display:flex;align-items:baseline;gap:0}
.tl-logo__taino{color:var(--tl-marron)}
.tl-logo__libre{color:var(--tl-verde)}
.tl-logo__slogan{display:block;background:var(--tl-verde);color:#fff;font-family:var(--font-nav);font-size:clamp(6px,1vw,9px);font-weight:600;letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:3px 10px;margin-top:2px}

/* Hamburger — oculto en desktop, visible mobile */
.tl-hamburger{display:none;background:var(--tl-verde);border:0;cursor:pointer;padding:5px 10px;border-radius:4px}
.tl-hamburger span{display:block;width:24px;height:3px;background:#fff;margin:3px 0;border-radius:2px;transition:var(--tr)}

/* === NAV desktop — separado del logo a la derecha === */
.tl-nav-links{display:flex;align-items:center;font-family:var(--font-nav);margin-left:auto}
.tl-nav-links ul{display:flex;gap:clamp(14px,2.5vw,28px);list-style:none;padding:0;margin:0;flex-wrap:wrap;justify-content:flex-end}
.tl-nav-links a{font-size:clamp(11px,1.1vw,13px);font-weight:600;color:var(--tl-negro);text-transform:uppercase;letter-spacing:.04em;padding:4px 0;white-space:nowrap}
.tl-nav-links a:hover{color:var(--tl-verde)}
.tl-nav-links .current-menu-item a{color:var(--tl-verde)}

/* === SEPARATOR diagonal marrón/verde cruzado === */
.tl-separator{width:100%;height:22px;position:relative;overflow:hidden;margin:4px 0}
.tl-separator::before{content:'';position:absolute;top:0;left:0;width:56%;height:100%;background:var(--tl-marron);clip-path:polygon(0 0,100% 0,93% 100%,0 100%)}
.tl-separator::after{content:'';position:absolute;top:0;right:0;width:52%;height:100%;background:var(--tl-verde);clip-path:polygon(8% 0,100% 0,100% 100%,0 100%)}

/* === AD BANNER entre separador y hero, ancho completo === */
.tl-ad-banner{text-align:center;padding:10px 0;background:var(--tl-crema);margin-bottom:10px}
.tl-ad-banner .tl-container{max-width:var(--max-w)}
.tl-ad-banner img{width:100%;max-height:110px;object-fit:contain;margin:0 auto;display:block}
.tl-ad-banner__label{font-size:9px;color:#bbb;text-transform:uppercase;letter-spacing:.1em;display:block;margin-top:2px}

/* === BREAKING NEWS === */
.tl-breaking{background:var(--tl-verde-dark);height:30px;overflow:hidden;display:flex;align-items:center}
.tl-breaking__label{background:var(--tl-rojo);color:#fff;font-family:var(--font-nav);font-size:10px;font-weight:700;text-transform:uppercase;padding:0 12px;height:30px;line-height:30px;white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:6px}
.tl-breaking__label svg{width:12px;height:12px;fill:#fff}
.tl-breaking__ticker{overflow:hidden;flex:1;height:30px}
.tl-breaking__scroll{display:flex;gap:40px;animation:ticker 30s linear infinite;white-space:nowrap;line-height:30px}
.tl-breaking__scroll a{font-size:11px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:6px}
.tl-breaking__scroll a::before{content:'●';color:var(--tl-verde-claro);font-size:6px}
.tl-breaking__scroll a:hover{color:#fff}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* === HERO GRID — boxed, poco margen lateral === */
.tl-hero{max-width:var(--max-w);margin:0 auto;padding:0 10px}
.tl-hero__grid{display:grid;grid-template-columns:1fr;gap:3px;background:var(--tl-gris-borde)}
@media(min-width:768px){.tl-hero__grid{grid-template-columns:58% 1fr;grid-template-rows:auto auto auto}.tl-hero__main{grid-row:1/4}}

.tl-hero-item{position:relative;overflow:hidden;background:var(--tl-negro);min-height:120px}
.tl-hero-item a{display:block;height:100%;position:relative}
.tl-hero-item__img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
.tl-hero-item:hover .tl-hero-item__img{transform:scale(1.04)}
.tl-hero-item__overlay{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(0deg,rgba(26,107,90,.9) 0%,rgba(26,107,90,.35) 50%,transparent 100%);z-index:2}
.tl-hero-item__cat{display:inline-block;background:var(--tl-verde);color:#fff;font-family:var(--font-nav);font-size:9px;font-weight:700;text-transform:uppercase;padding:2px 8px;margin-bottom:6px}
.tl-hero-item__title{color:#fff;font-family:var(--font-head);line-height:1.25;text-shadow:0 1px 4px rgba(0,0,0,.3);margin:0}
.tl-hero-item__meta{font-size:10px;color:rgba(255,255,255,.6);margin-top:4px}

.tl-hero__main{min-height:260px}
.tl-hero__main .tl-hero-item__title{font-size:clamp(18px,3vw,26px)}
.tl-hero__main .tl-hero-item__overlay{padding:24px}
@media(min-width:768px){.tl-hero__main{min-height:400px}}
.tl-hero__side .tl-hero-item__title{font-size:13px}
.tl-hero__side .tl-hero-item__overlay{padding:10px 14px}
.tl-hero__side .tl-hero-item__cat{font-size:8px;padding:1px 6px;margin-bottom:3px}

/* === SECTION HEADER === */
.tl-sec-hdr{display:flex;align-items:center;margin-bottom:20px;padding-bottom:8px;border-bottom:3px solid var(--tl-verde)}
.tl-sec-hdr h2{font-family:var(--font-nav);font-size:16px;font-weight:800;text-transform:uppercase}
.tl-sec-hdr h2 span{font-weight:400;color:var(--tl-gris)}
.tl-sec-hdr__line{flex:1;height:1px;background:var(--tl-gris-borde);margin-left:16px}

/* === LAYOUT === */
.tl-layout{display:grid;grid-template-columns:1fr;gap:var(--gap);margin-bottom:48px}
@media(min-width:1024px){.tl-layout{grid-template-columns:1fr var(--sidebar)}}

/* === CARDS === */
.tl-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:600px){.tl-grid{grid-template-columns:repeat(2,1fr)}}

.tl-card{background:var(--tl-blanco);overflow:hidden;transition:box-shadow var(--tr);border-radius:4px}
.tl-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.08)}
.tl-card__img-wrap{overflow:hidden;position:relative;aspect-ratio:16/10}
.tl-card__img{width:100%;height:100%;object-fit:cover;transition:transform var(--tr)}
.tl-card:hover .tl-card__img{transform:scale(1.04)}
.tl-card__cat{position:absolute;bottom:8px;left:8px;background:var(--tl-verde);color:#fff;font-family:var(--font-nav);font-size:9px;font-weight:700;text-transform:uppercase;padding:2px 8px;z-index:2}
.tl-card__body{padding:12px 14px}
.tl-card__title{font-family:var(--font-head);font-size:15px;font-weight:700;line-height:1.35;margin-bottom:6px}
.tl-card__title a{color:inherit}
.tl-card__title a:hover{color:var(--tl-verde)}
.tl-card__excerpt{font-size:12px;color:var(--tl-gris);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:8px}
.tl-card__meta{display:flex;justify-content:space-between;font-size:11px;color:var(--tl-gris);padding-top:8px;border-top:1px solid var(--tl-gris-borde)}

/* === SIDEBAR === */
.tl-sidebar{font-size:13px}
.tl-widget{background:var(--tl-blanco);margin-bottom:20px;padding:16px;border-radius:4px}
.tl-widget__hdr{padding-bottom:8px;margin-bottom:12px;border-bottom:3px solid var(--tl-verde)}
.tl-widget__hdr h3{font-family:var(--font-nav);font-size:14px;font-weight:800;text-transform:uppercase}
.tl-widget__hdr h3 span{font-weight:400;color:var(--tl-gris)}

.tl-mr__item{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--tl-gris-borde)}
.tl-mr__item:last-child{border:0}
.tl-mr__img{width:70px;height:50px;object-fit:cover;flex-shrink:0;border-radius:3px}
.tl-mr__title{font-family:var(--font-head);font-size:12px;font-weight:700;line-height:1.3;margin-bottom:3px}
.tl-mr__title a{color:inherit}
.tl-mr__title a:hover{color:var(--tl-verde)}
.tl-mr__meta{font-size:10px;color:var(--tl-gris)}

.tl-tags{display:flex;flex-wrap:wrap;gap:6px}
.tl-tags a{padding:4px 10px;font-family:var(--font-nav);font-size:10px;font-weight:600;text-transform:uppercase;border:1px solid var(--tl-gris-borde);color:var(--tl-gris);transition:all var(--tr);border-radius:3px}
.tl-tags a:hover,.tl-tags a.active{background:var(--tl-verde);color:#fff;border-color:var(--tl-verde)}

.tl-nl{background:var(--tl-verde-dark);padding:20px;color:#fff;border-radius:4px}
.tl-nl__title{font-family:var(--font-nav);font-size:14px;font-weight:700;margin-bottom:4px}
.tl-nl__desc{font-size:11px;color:rgba(255,255,255,.6);margin-bottom:12px}
.tl-nl input{width:100%;padding:8px 12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-size:12px;margin-bottom:8px;outline:0;border-radius:3px}
.tl-nl input::placeholder{color:rgba(255,255,255,.4)}
.tl-nl button{width:100%;padding:8px;background:var(--tl-verde-claro);color:#fff;border:0;font-family:var(--font-nav);font-size:12px;font-weight:700;text-transform:uppercase;cursor:pointer;border-radius:3px;transition:background var(--tr)}
.tl-nl button:hover{background:var(--tl-verde-light)}

/* === SINGLE === */
.tl-single__cat{display:inline-block;background:var(--tl-verde);color:#fff;font-family:var(--font-nav);font-size:10px;font-weight:700;text-transform:uppercase;padding:3px 10px;margin-bottom:14px;border-radius:3px}
.tl-single__title{font-size:clamp(22px,3.5vw,32px);margin-bottom:14px}
.tl-single__meta{display:flex;flex-wrap:wrap;gap:14px;font-size:12px;color:var(--tl-gris);padding-bottom:14px;border-bottom:1px solid var(--tl-gris-borde);margin-bottom:20px}
.tl-single__meta img{border-radius:50%}
.tl-single__featured{width:100%;margin-bottom:20px;border-radius:4px}
.tl-single__content{font-size:15px;line-height:1.8;max-width:680px}
.tl-single__content p{margin-bottom:20px}
.tl-single__content blockquote{border-left:3px solid var(--tl-verde);padding:14px 20px;margin:20px 0;font-style:italic;background:var(--tl-crema);border-radius:0 4px 4px 0}

.tl-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--tl-verde),var(--tl-verde-claro));z-index:10000;width:0%;transition:width .1s linear}

.tl-share{display:flex;gap:6px;margin:14px 0}
.tl-share a{width:32px;height:32px;border-radius:3px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;transition:opacity var(--tr)}
.tl-share a:hover{opacity:.8;color:#fff}
.tl-share .fb{background:#1877F2}.tl-share .tw{background:#000}.tl-share .wa{background:#25D366}.tl-share .tg{background:#0088cc}.tl-share .em{background:#555}

.tl-author{display:flex;gap:14px;padding:20px;background:var(--tl-crema);border-radius:4px;margin:28px 0}
.tl-author img{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}
.tl-author__name{font-family:var(--font-nav);font-size:14px;font-weight:700;margin-bottom:3px}
.tl-author__bio{font-size:12px;color:var(--tl-gris)}

.tl-related{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:600px){.tl-related{grid-template-columns:repeat(3,1fr)}}

.tl-crumbs{font-size:11px;color:var(--tl-gris);padding:14px 0}
.tl-crumbs a{color:var(--tl-verde)}

.tl-pag{display:flex;justify-content:center;gap:4px;padding:28px 0;font-family:var(--font-nav)}
.tl-pag .nav-links{display:flex;gap:4px}
.tl-pag a,.tl-pag span{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;border:1px solid var(--tl-gris-borde);font-size:12px;font-weight:600;border-radius:3px}
.tl-pag a:hover,.tl-pag .current{background:var(--tl-verde);color:#fff;border-color:var(--tl-verde)}

.tl-404{text-align:center;padding:60px 0;min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center}
.tl-404 h1{font-family:var(--font-logo);font-size:80px;color:var(--tl-verde);opacity:.15}
.tl-404 p{margin-bottom:20px}
.tl-btn{display:inline-block;background:var(--tl-verde);color:#fff;padding:10px 24px;font-family:var(--font-nav);font-weight:700;font-size:12px;text-transform:uppercase;border:0;cursor:pointer;border-radius:3px;transition:background var(--tr)}
.tl-btn:hover{background:var(--tl-verde-hover);color:#fff}

/* === FOOTER === */
.tl-footer{background:var(--tl-verde-dark);color:rgba(255,255,255,.7);padding:40px 0 0;font-size:12px}
.tl-footer a{color:rgba(255,255,255,.7)}
.tl-footer a:hover{color:#fff}
.tl-footer__grid{display:grid;grid-template-columns:1fr;gap:28px;padding-bottom:28px}
@media(min-width:768px){.tl-footer__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.tl-footer__grid{grid-template-columns:2fr 1fr 1fr 1.2fr}}
.tl-footer__col-title{font-family:var(--font-nav);font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.15)}
.tl-footer__nav li{margin-bottom:5px}
.tl-footer__social{display:flex;gap:6px;margin-top:12px}
.tl-footer__social a{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border-radius:3px;font-size:11px;font-weight:700}
.tl-footer__social a:hover{background:var(--tl-verde)}
.tl-footer__nl{display:flex;margin-top:8px}
.tl-footer__nl input{flex:1;padding:6px 10px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-size:11px;outline:0;border-radius:3px 0 0 3px}
.tl-footer__nl button{padding:6px 14px;background:var(--tl-verde);border:0;color:#fff;font-size:11px;font-weight:700;cursor:pointer;border-radius:0 3px 3px 0}
.tl-footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding:14px 0;font-size:11px;text-align:center;color:rgba(255,255,255,.5)}
.tl-footer__bottom a{color:var(--tl-verde-claro)}

/* === MOBILE MENU === */
.tl-mob-ov{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:10000;opacity:0;visibility:hidden;transition:var(--tr)}
.tl-mob-ov.on{opacity:1;visibility:visible}
.tl-mob-menu{position:fixed;top:0;right:-100%;width:80%;max-width:300px;height:100vh;background:var(--tl-verde-dark);z-index:10001;transition:right var(--tr);padding:20px;overflow-y:auto}
.tl-mob-menu.on{right:0}
.tl-mob-menu__close{background:0;border:0;color:#fff;font-size:24px;cursor:pointer;position:absolute;top:12px;right:12px}
.tl-mob-menu ul{margin-top:40px;list-style:none;padding:0}
.tl-mob-menu li{border-bottom:1px solid rgba(255,255,255,.12)}
.tl-mob-menu a{display:block;padding:12px 0;color:#fff;font-family:var(--font-nav);font-size:13px;font-weight:600;text-transform:uppercase}

/* === RESPONSIVE === */
@media(max-width:767px){
.tl-topbar{display:none!important}
.tl-nav-links{display:none!important}
.tl-breaking{display:none!important}
.tl-header{padding:8px 0 4px}
.tl-header .tl-container{flex-direction:column;align-items:center;gap:0;padding:0}
.tl-logo{width:100%;text-align:center;padding:0 4px}
.tl-logo__name{font-size:clamp(3rem,14vw,4.2rem);justify-content:center;width:100%}
.tl-logo__slogan{font-size:clamp(7px,2.5vw,11px);padding:5px 0;width:100%}
.tl-hamburger{display:flex!important;align-items:center;justify-content:center;width:38px;height:30px;margin:6px auto 2px;padding:4px 8px}
.tl-hero{padding:0 6px}
}

@media(min-width:768px){
.tl-mob-ov,.tl-mob-menu{display:none!important}
.tl-hamburger{display:none!important}
}

/* === ANIMATIONS === */
@keyframes fadeUp{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:none}}
[data-a]{opacity:0;transform:translateY(12px);transition:opacity .5s ease,transform .5s ease}
[data-a].v{opacity:1;transform:none}
[data-s]>*{opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease}
[data-s].v>*:nth-child(1){transition-delay:0;opacity:1;transform:none}
[data-s].v>*:nth-child(2){transition-delay:.07s;opacity:1;transform:none}
[data-s].v>*:nth-child(3){transition-delay:.14s;opacity:1;transform:none}
[data-s].v>*:nth-child(4){transition-delay:.21s;opacity:1;transform:none}

@media print{.tl-topbar,.tl-header,.tl-nav-links,.tl-separator,.tl-nav-bar,.tl-breaking,.tl-footer,.tl-sidebar,.tl-share,.tl-nl,.tl-mob-menu,.tl-mob-ov,.tl-ad-banner{display:none!important}body{color:#000;background:#fff}}
