/*
Theme Name: SoloTV
Theme URI: https://making.cl
Author: Making.cl
Author URI: https://making.cl
Description: Tema oficial de SoloTV - El Canal de Valparaíso.
Version: 1.1.9
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: solotv
Tags: dark, broadcast, television, chile, valparaiso, custom-menu, featured-images, custom-logo
*/

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --color-bg:           #0d0d0d;
  --color-surface:      #161616;
  --color-red:          #e8001c;
  --color-red-dark:     #b8001a;
  --color-white:        #ffffff;
  --color-gray:         #8a8a8a;
  --color-border:       #2a2a2a;
  --font-display:       'Oswald', 'Arial Narrow', sans-serif;
  --font-body:          'Nunito Sans', 'Segoe UI', sans-serif;
  --logo-height:        44px;
  --logo-height-mobile: min(var(--logo-height), 40px);
  --hero-overlay:       0.92;
  --hero-title-size:    clamp(56px, 8vw, 110px);
  --nav-padding:        12px;
  --nav-padding-mobile: 10px;
  --footer-cols:        repeat(4, 1fr);
  --header-height: calc(var(--logo-height) + var(--nav-padding) * 2);
  --header-height-mobile: calc(var(--logo-height-mobile) + var(--nav-padding-mobile) * 2);
}

html { scroll-behavior: smooth; }
body { background: var(--color-bg); color: var(--color-white); font-family: var(--font-body); font-size: 16px; line-height: 1.6; overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }

.admin-bar #site-header { top: 32px; }
.admin-bar #hero { padding-top: calc(var(--header-height) + 32px); }
.admin-bar #page-content { padding-top: calc(var(--header-height) + 32px + 40px); }
@media screen and (max-width: 782px) {
  .admin-bar #site-header { top: 46px; }
  .admin-bar #hero { padding-top: calc(var(--header-height-mobile) + 46px); }
  .admin-bar #page-content { padding-top: calc(var(--header-height-mobile) + 46px + 32px); }
}

#site-header { position: fixed; top: 0; left: 0; width: 100%; z-index: 999; background: rgba(10,10,10,0.95); backdrop-filter: blur(8px); border-bottom: 1px solid var(--color-border); padding: var(--nav-padding) 0; display: flex; align-items: center; transition: top 0.2s; overflow: visible; }
.header-inner { width: 100%; max-width: 1400px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; min-width: 0; overflow: visible; }

.site-logo { display: flex; align-items: center; flex-shrink: 0; min-width: 0; }
.site-logo a { display: flex; align-items: center; min-width: 0; }
.site-logo img, .site-logo .custom-logo { height: var(--logo-height) !important; width: auto !important; max-width: 240px; object-fit: contain; display: block; }
.site-logo .logo-placeholder { display: flex; align-items: center; gap: 4px; font-family: var(--font-display); font-weight: 700; letter-spacing: -1px; font-size: calc(var(--logo-height) * 0.6); line-height: 1; white-space: nowrap; }
.site-logo .logo-solo { color: var(--color-white); }
.site-logo .logo-tv   { color: var(--color-red); }
.logo-icon { width: calc(var(--logo-height) * 0.8); height: calc(var(--logo-height) * 0.8); margin-right: 6px; flex-shrink: 0; }

#site-navigation { overflow: visible; }
#primary-menu { display: flex; align-items: center; gap: 4px; list-style: none; padding: 0; margin: 0; overflow: visible; }
#primary-menu > li { position: relative; }
#primary-menu > li > a { font-family: var(--font-display); font-size: 13px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: var(--color-white); padding: 8px 14px; border-radius: 4px; transition: color 0.2s, background 0.2s; white-space: nowrap; display: flex; align-items: center; gap: 6px; }
#primary-menu > li > a:hover, #primary-menu > li:hover > a { color: var(--color-red); background: rgba(232,0,28,0.08); }
#primary-menu > li.menu-item-has-children > a::after { content: ''; display: inline-block; flex-shrink: 0; margin-left: 2px; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 5px solid currentColor; transition: transform 0.2s; }
#primary-menu > li.menu-item-has-children:hover > a::after, #primary-menu > li.menu-item-has-children.is-open > a::after { transform: rotate(180deg); }
#primary-menu > li > ul.sub-menu { display: none; position: absolute; top: calc(100% + 6px); left: 0; z-index: 9999; min-width: 210px; background: #111111; border: 1px solid var(--color-border); border-top: 2px solid var(--color-red); border-radius: 0 0 6px 6px; box-shadow: 0 8px 28px rgba(0,0,0,0.6); padding: 6px 0; list-style: none; }
#primary-menu > li.menu-item-has-children:hover > ul.sub-menu, #primary-menu > li.menu-item-has-children.is-open > ul.sub-menu { display: block; animation: submenu-appear 0.15s ease; }
@keyframes submenu-appear { from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);} }
#primary-menu > li > ul.sub-menu > li > a { display: block; font-family: var(--font-display); font-size: 12px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; color: rgba(255,255,255,0.82); padding: 10px 20px; white-space: nowrap; transition: color 0.15s, background 0.15s, padding-left 0.15s; }
#primary-menu > li > ul.sub-menu > li > a:hover { color: var(--color-white); background: rgba(232,0,28,0.12); padding-left: 26px; }
#primary-menu > li > ul.sub-menu > li + li { border-top: 1px solid rgba(255,255,255,0.06); }
#primary-menu > li > ul.sub-menu > li > ul.sub-menu { display: none; position: absolute; top: 0; left: 100%; margin-left: 2px; border-top: 2px solid var(--color-red); border-radius: 0 6px 6px 6px; }
#primary-menu > li > ul.sub-menu > li.menu-item-has-children:hover > ul.sub-menu, #primary-menu > li > ul.sub-menu > li.menu-item-has-children.is-open > ul.sub-menu { display: block; }

.nav-live-btn { display: flex; align-items: center; gap: 8px; background: var(--color-red); color: var(--color-white) !important; padding: 10px 20px !important; border-radius: 6px !important; font-family: var(--font-display) !important; font-weight: 700 !important; font-size: 13px !important; letter-spacing: 1px; transition: background 0.2s !important; white-space: nowrap; flex-shrink: 0; }
.nav-live-btn:hover { background: var(--color-red-dark) !important; }
.live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-white); flex-shrink: 0; animation: pulse-dot 1.4s ease-in-out infinite; }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.7);} }
.menu-toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 4px; flex-shrink: 0; }
.menu-toggle span { display: block; width: 24px; height: 2px; background: var(--color-white); border-radius: 2px; transition: all 0.3s; }

#hero { position: relative; min-height: 100vh; display: flex; flex-direction: column; justify-content: center; overflow: hidden; padding-top: var(--header-height); }
.hero-bg { position: absolute; inset: 0; z-index: 0; }
.hero-bg img { width: 100%; height: 100%; object-fit: cover; object-position: center right; }
.hero-bg::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to right,rgba(10,10,10,var(--hero-overlay)) 0%,rgba(10,10,10,.75) 45%,rgba(10,10,10,.20) 70%,rgba(10,10,10,.05) 100%); }
.hero-content { position: relative; z-index: 1; max-width: 1400px; margin: 0 auto; padding: 80px 32px 120px; width: 100%; }
.hero-label { display: inline-block; font-family: var(--font-display); font-size: 12px; font-weight: 600; letter-spacing: 3px; text-transform: uppercase; color: var(--color-red); margin-bottom: 20px; }
.hero-title { font-family: var(--font-display); font-size: var(--hero-title-size); font-weight: 700; line-height: 0.95; text-transform: uppercase; letter-spacing: -2px; max-width: 600px; margin-bottom: 24px; }
.hero-title .red { color: var(--color-red); }
.hero-title .script { font-family: 'Dancing Script', cursive; font-size: clamp(52px,7.5vw,100px); font-weight: 700; color: var(--color-red); text-transform: none; letter-spacing: 0; display: block; line-height: 1.1; }
.hero-subtitle { font-size: clamp(16px,2vw,20px); color: rgba(255,255,255,.85); max-width: 420px; margin-bottom: 40px; line-height: 1.5; }
.hero-subtitle .highlight { color: var(--color-red); font-weight: 700; }
.hero-buttons { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.btn-primary { display: inline-flex; align-items: center; gap: 10px; background: var(--color-red); color: var(--color-white); font-family: var(--font-display); font-size: 14px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 16px 28px; border-radius: 8px; border: 2px solid var(--color-red); transition: background .2s,transform .15s; }
.btn-primary:hover { background: var(--color-red-dark); border-color: var(--color-red-dark); transform: translateY(-2px); }
.btn-secondary { display: inline-flex; align-items: center; gap: 10px; background: transparent; color: var(--color-white); font-family: var(--font-display); font-size: 14px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 16px 28px; border-radius: 8px; border: 2px solid rgba(255,255,255,.4); transition: border-color .2s,transform .15s; }
.btn-secondary:hover { border-color: var(--color-white); transform: translateY(-2px); }

#features-bar { background: var(--color-surface); border-top: 3px solid var(--color-red); border-bottom: 1px solid var(--color-border); }
.features-inner { max-width: 1400px; margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: repeat(4,1fr); }
.feature-item { display: flex; align-items: flex-start; gap: 16px; padding: 32px 24px; border-right: 1px solid var(--color-border); }
.feature-item:last-child { border-right: none; }
.feature-icon { width: 40px; height: 40px; flex-shrink: 0; color: var(--color-red); }
.feature-icon svg { width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.feature-text h3 { font-family: var(--font-display); font-size: 15px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--color-white); margin-bottom: 6px; line-height: 1.2; }
.feature-text p { font-size: 13px; color: var(--color-gray); line-height: 1.5; }

#news-ticker { background: var(--color-red); height: 44px; display: flex; align-items: stretch; position: relative; }
.ticker-label { display: flex; align-items: center; gap: 8px; background: #8a0010; padding: 0 20px; white-space: nowrap; flex-shrink: 0; font-family: var(--font-display); font-size: 12px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; position: relative; z-index: 2; }
.ticker-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-white); flex-shrink: 0; animation: pulse-dot 1.4s ease-in-out infinite; }
.ticker-scroll-area { flex: 1 1 0; min-width: 0; overflow: hidden; display: flex; align-items: center; }
.ticker-track { display: flex; white-space: nowrap; animation: ticker-scroll 35s linear infinite; will-change: transform; }
.ticker-track:hover { animation-play-state: paused; }
.ticker-item { font-family: var(--font-body); font-size: 13px; font-weight: 600; padding: 0 36px; display: inline-flex; align-items: center; gap: 8px; }
.ticker-item::before { content: '•'; font-size: 16px; }
@keyframes ticker-scroll { 0%{transform:translateX(0);}100%{transform:translateX(-50%);} }

#page-content { width: 100%; padding-top: calc(var(--header-height) + 40px); padding-bottom: 80px; }

.page-entry-header { max-width: 900px; margin: 0 auto 40px; padding: 24px 32px 32px; border-bottom: 1px solid var(--color-border); }
.page-entry-title { font-family: var(--font-display); font-size: clamp(28px,4vw,48px); font-weight: 700; text-transform: uppercase; letter-spacing: -1px; color: var(--color-white); line-height: 1.1; }
.page-entry-title::after { content: ''; display: block; width: 48px; height: 3px; background: var(--color-red); margin-top: 12px; }
.page-entry-meta { font-size: 13px; color: var(--color-gray); margin-top: 12px; }

.page-content-wrap { width: 100%; }

#page-content.layout-boxed .page-content-wrap { max-width: 900px; margin-left: auto; margin-right: auto; padding-left: 32px; padding-right: 32px; }
#page-content.layout-wide .page-content-wrap { max-width: 100%; padding-left: 0; padding-right: 0; }
#page-content.layout-narrow .page-content-wrap { max-width: 640px; margin-left: auto; margin-right: auto; padding-left: 32px; padding-right: 32px; }
#page-content.layout-centered .page-content-wrap { max-width: 900px; margin-left: auto; margin-right: auto; padding-left: 32px; padding-right: 32px; text-align: center; }
#page-content.layout-centered .page-content-wrap p,
#page-content.layout-centered .page-content-wrap li,
#page-content.layout-centered .page-content-wrap h1,
#page-content.layout-centered .page-content-wrap h2,
#page-content.layout-centered .page-content-wrap h3,
#page-content.layout-centered .page-content-wrap h4 { text-align: center; }

.page-entry-content { color: rgba(255,255,255,.88); line-height: 1.8; font-size: 16px; }
.page-entry-content h1,.page-entry-content h2,.page-entry-content h3,.page-entry-content h4 { font-family: var(--font-display); color: var(--color-white); margin: 32px 0 16px; text-transform: uppercase; letter-spacing: .5px; }
.page-entry-content p { margin-bottom: 20px; }
.page-entry-content a { color: var(--color-red); text-decoration: underline; text-underline-offset: 3px; }
.page-entry-content a:hover { color: var(--color-white); }
.page-entry-content ul,.page-entry-content ol { padding-left: 24px; margin-bottom: 20px; }
.page-entry-content ul { list-style: disc; } .page-entry-content ol { list-style: decimal; }
.page-entry-content li { margin-bottom: 8px; }
.page-entry-content img { border-radius: 4px; max-width: 100%; height: auto; }
.page-entry-content figure { margin: 32px 0; }
.page-entry-content figcaption { font-size: 12px; color: var(--color-gray); margin-top: 8px; text-align: center; }
.page-entry-content blockquote { border-left: 3px solid var(--color-red); padding: 16px 24px; margin: 24px 0; color: var(--color-gray); font-style: italic; background: var(--color-surface); border-radius: 0 4px 4px 0; }
.page-entry-content table { width: 100%; border-collapse: collapse; margin: 24px 0; font-size: 14px; }
.page-entry-content th,.page-entry-content td { padding: 10px 14px; border: 1px solid var(--color-border); text-align: left; }
.page-entry-content th { background: var(--color-surface); color: var(--color-white); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 1px; font-size: 12px; }
.page-entry-content iframe,.page-entry-content video,.page-entry-content audio { display: block; max-width: 100%; }
.page-entry-content .wp-block-embed { margin: 32px 0; }
.page-entry-content .wp-block-embed__wrapper { position: relative; }
.page-entry-content .wp-block-embed-youtube .wp-block-embed__wrapper::before,.page-entry-content .wp-block-embed-vimeo .wp-block-embed__wrapper::before { content: ''; display: block; padding-top: 56.25%; }
.page-entry-content .wp-block-embed-youtube iframe,.page-entry-content .wp-block-embed-vimeo iframe { position: absolute; inset: 0; width: 100%; height: 100%; }
.page-entry-content .wp-block-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.page-entry-content .wp-block-button__link { background: var(--color-red); color: var(--color-white); padding: 12px 24px; border-radius: 6px; font-family: var(--font-display); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; font-size: 13px; text-decoration: none; transition: background .2s; }
.page-entry-content .wp-block-button__link:hover { background: var(--color-red-dark); }
.page-entry-content hr,.page-entry-content .wp-block-separator { border: none; border-top: 1px solid var(--color-border); margin: 40px 0; }
.page-entry-content .aligncenter { display: block; margin-left: auto !important; margin-right: auto !important; text-align: center; }
.page-entry-content .alignwide  { display: block; width: 100%; max-width: 1200px; margin-left: auto; margin-right: auto; }
.page-entry-content .alignfull  { display: block; width: 100%; max-width: 100%; }
.page-entry-content .alignleft  { float: left;  margin-right: 24px; margin-bottom: 16px; }
.page-entry-content .alignright { float: right; margin-left:  24px; margin-bottom: 16px; }
.page-entry-content::after { content: ''; display: table; clear: both; }

.no-posts { color: var(--color-gray); font-size: 16px; text-align: center; padding: 48px 0; }
.solotv-admin-hint { font-size: 12px; color: #888; border: 1px dashed #444; padding: 12px; border-radius: 6px; line-height: 1.5; font-style: italic; }

#site-footer { background: #0a0a0a; border-top: 1px solid var(--color-border); padding: 56px 32px 0; }
.footer-inner { max-width: 1400px; margin: 0 auto; }
.footer-widgets { display: grid; grid-template-columns: var(--footer-cols,repeat(4,1fr)); gap: 40px; padding-bottom: 48px; border-bottom: 1px solid var(--color-border); }
.footer-widget-area { min-width: 0; }
.footer-widget-area .widget-title,.footer-widget-area h2.widget-title { font-family: var(--font-display); font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--color-red); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid var(--color-border); }
.footer-widget-area ul { list-style: none; }
.footer-widget-area ul li { margin-bottom: 10px; }
.footer-widget-area ul li a,.footer-widget-area .footer-nav-menu li a,.footer-social-list li a { font-size: 13px; color: var(--color-gray); transition: color .2s; }
.footer-widget-area ul li a:hover,.footer-widget-area .footer-nav-menu li a:hover,.footer-social-list li a:hover { color: var(--color-white); }
.footer-widget-area p { font-size: 13px; color: var(--color-gray); line-height: 1.6; margin-bottom: 10px; }
.footer-widget-area a { color: var(--color-gray); transition: color .2s; }
.footer-widget-area a:hover { color: var(--color-white); }
#footer-corporate { display: flex; flex-direction: column; align-items: flex-start; gap: 10px; padding: 36px 0; border-bottom: 1px solid var(--color-border); }
.footer-corp-logo { flex-shrink: 0; }
.footer-corp-logo img { height: 56px; width: auto; max-width: 200px; object-fit: contain; display: block; }
.footer-corp-logo .corp-logo-text { font-family: var(--font-display); font-size: 22px; font-weight: 700; line-height: 1; }
.footer-corp-logo .corp-logo-text .red { color: var(--color-red); }
.footer-corp-title { font-family: var(--font-display); font-size: 13px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--color-red); margin: 0; }
.footer-corp-desc { font-size: 13px; color: var(--color-gray); line-height: 1.7; max-width: 680px; margin: 0; }
#footer-copyright { display: flex; justify-content: space-between; align-items: center; padding: 16px 0; font-size: 12px; color: var(--color-gray); flex-wrap: wrap; gap: 8px; }
.footer-credit-link { color: var(--color-red); transition: color .2s; }
.footer-credit-link:hover { color: var(--color-white); }

@media (max-width: 1200px) { .footer-widgets { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 1024px) {
  .features-inner { grid-template-columns: repeat(2,1fr); }
  .feature-item:nth-child(2) { border-right: none; }
  .feature-item:nth-child(3) { border-top: 1px solid var(--color-border); }
  .feature-item:nth-child(4) { border-top: 1px solid var(--color-border); border-right: none; }
}
@media (max-width: 768px) {
  #site-header { padding: var(--nav-padding-mobile) 0; }
  .header-inner { padding: 0 16px; gap: 12px; }
  .site-logo img, .site-logo .custom-logo { height: var(--logo-height-mobile) !important; max-width: 160px !important; }
  .site-logo .logo-placeholder { font-size: calc(var(--logo-height-mobile) * 0.6) !important; }
  .logo-icon { width: calc(var(--logo-height-mobile) * 0.8) !important; height: calc(var(--logo-height-mobile) * 0.8) !important; }
  .nav-live-btn { padding: 8px 12px !important; font-size: 11px !important; gap: 6px !important; }
  .menu-toggle { display: flex; }
  #primary-menu { display: none; }
  #primary-menu.mobile-open { display: flex !important; flex-direction: column; align-items: stretch; position: absolute; top: var(--header-height-mobile); left: 0; width: 100%; background: #0d0d0d; border-bottom: 2px solid var(--color-red); z-index: 998; max-height: 80vh; overflow-y: auto; padding: 8px 0; }
  #primary-menu.mobile-open > li { width: 100%; border-bottom: 1px solid rgba(255,255,255,0.07); }
  #primary-menu.mobile-open > li > a { display: flex; justify-content: space-between; padding: 13px 20px; font-size: 13px; width: 100%; }
  #primary-menu.mobile-open > li > ul.sub-menu { display: none !important; position: static !important; top: auto !important; left: auto !important; width: 100%; min-width: 0; background: rgba(255,255,255,0.04); border: none; border-top: 1px solid rgba(255,255,255,0.08); border-radius: 0; box-shadow: none; padding: 4px 0; animation: none; }
  #primary-menu.mobile-open > li.is-open > ul.sub-menu { display: block !important; }
  #primary-menu.mobile-open > li > ul.sub-menu > li > a { padding: 11px 20px 11px 36px; font-size: 12px; color: rgba(255,255,255,0.75); }
  #primary-menu.mobile-open > li > ul.sub-menu > li > a:hover { color: var(--color-white); background: rgba(232,0,28,0.1); padding-left: 40px; }
  #hero { padding-top: var(--header-height-mobile); }
  #page-content { padding-top: calc(var(--header-height-mobile) + 32px); }
  .hero-title { font-size: clamp(44px,12vw,72px); }
  .hero-content { padding: 48px 20px 80px; }
  .features-inner { grid-template-columns: 1fr; }
  .feature-item { border-right: none; border-top: 1px solid var(--color-border); }
  .feature-item:first-child { border-top: none; }
  .footer-widgets { grid-template-columns: 1fr; gap: 32px; }
  #footer-copyright { flex-direction: column; text-align: center; }
  .page-entry-header { padding: 16px 20px 24px; }
  #page-content.layout-boxed .page-content-wrap,
  #page-content.layout-narrow .page-content-wrap,
  #page-content.layout-centered .page-content-wrap { max-width: 100%; padding-left: 20px; padding-right: 20px; }
  .page-entry-content .alignleft,
  .page-entry-content .alignright { float: none; margin-left: 0; margin-right: 0; width: 100%; }
}
@media (max-width: 400px) {
  .nav-live-btn span[data-customizer] { display: none; }
  .nav-live-btn { padding: 8px 10px !important; }
}
