/*
Theme Name: Bukovyna Online Pravda Style
Theme URI: https://bukovyna.online/
Author: ChatGPT
Description: Two-column desktop news theme inspired by Ukrainska Pravda layout (clean, readable), adapted to bukovyna.online hubs, mobile-first, Discover-friendly single with featured image. Listing cards without thumbnails.
Version: 1.2.8
Requires at least: 6.0
Requires PHP: 8.0
License: GPLv2 or later
Text Domain: bukovyna-online-modern
Tags: news, blog, two-columns, custom-menu, featured-images, translation-ready, responsive
*/

:root{
  --bg:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --card:#ffffff;
  --accent:#0b5ed7;
  --danger:#dc2626;
  --max:1180px;
  --radius:10px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit; text-decoration:none}
a:hover{color:var(--accent); text-decoration:underline}
img{max-width:100%; height:auto}
.container{max-width:var(--max); margin:0 auto; padding:0 14px}
@media(min-width:740px){ .container{padding:0 18px} }

.small{font-size:.93rem; color:var(--muted)}
hr{border:0; border-top:1px solid var(--line); margin:18px 0}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  font-size:.78rem; letter-spacing:.02em;
  padding:4px 8px;
  border:1px solid var(--line);
  border-radius:999px;
  color:var(--muted);
  background:#fff;
}
.badge.hot{border-color:rgba(220,38,38,.25); color:var(--danger)}
.badge.menu{border-color:var(--line); color:var(--muted)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px; padding:9px 12px; border-radius:10px;
  background:var(--accent);
  border:1px solid var(--accent);
  color:#fff;
}
.btn:hover{filter:brightness(1.05); text-decoration:none}
.btn.secondary{
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
}

/* Header */
.site-header{
  position:sticky; top:0; z-index:120;
  background:linear-gradient(180deg, #ffffff 0%, #fbfcff 100%);
  border-bottom:1px solid var(--line);
  box-shadow: 0 8px 24px rgba(17,24,39,.06);
}
.topbar{
  background:linear-gradient(90deg, rgba(11,94,215,.04), rgba(220,38,38,.03));
  border-bottom:1px solid var(--line);
  font-size:.86rem;
  color:var(--muted);
}
.topbar .topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 0;
  gap:10px;
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 0;
  gap:12px;
}
.brand{
  display:flex; align-items:center; gap:12px;
}
.brand img{height:44px; width:auto; display:block}
/* Logo aspect ratio fix */
.brand img,
.custom-logo{
  height:44px !important;
  width:auto !important;
  max-width:260px;
  object-fit:contain;
  display:block;
}

.brand .brand-text{display:flex; flex-direction:column; gap:2px}
.brand .brand-text a{font-weight:800; letter-spacing:.02em; font-size:1.02rem}
.brand .tagline{font-size:.82rem; color:var(--muted)}
.nav-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px;
  border-radius:10px; border:1px solid var(--line);
  background:#fff; color:var(--text)
}
.primary-nav{display:none}
.primary-nav ul{list-style:none; margin:0; padding:0; display:flex; gap:8px; flex-wrap:wrap}
.primary-nav a{padding:8px 10px; border-radius:10px}
.primary-nav a:hover{background:#f3f4f6; text-decoration:none}

/* Dropdown menu (desktop) */
.primary-nav li{position:relative}
.primary-nav .sub-menu{
  display:none;
  position:absolute;
  top:100%;
  left:0;
  min-width:220px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:10px;
  padding:8px;
  margin-top:6px;
  z-index:200;
}
.primary-nav .sub-menu li{width:100%}
.primary-nav .sub-menu a{
  display:block;
  padding:10px 10px;
  border-radius:8px;
  white-space:nowrap;
}
.primary-nav li:hover > .sub-menu,
.primary-nav li:focus-within > .sub-menu{display:block}

.search-wrap{display:none}
.search-wrap form{display:flex; align-items:center; gap:8px}
.search-wrap input[type="search"]{
  width:220px; max-width:48vw;
  padding:9px 10px; border-radius:10px;
  border:1px solid var(--line);
  background:#fff; color:var(--text);
}
.search-wrap button{
  padding:9px 10px; border-radius:10px;
  border:1px solid var(--line);
  background:#fff; color:var(--text);
  cursor:pointer;
}
.mobile-menu{display:none; border-top:1px solid var(--line); padding:12px 0}
.mobile-menu ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px}
.mobile-menu a{padding:10px 12px; border-radius:10px; background:#fff; border:1px solid var(--line)}
.mobile-menu a:hover{background:#f3f4f6; text-decoration:none}
@media(min-width:980px){
  .nav-toggle{display:none}
  .primary-nav{display:block}
  .search-wrap{display:block}
  .mobile-menu{display:none !important}
}

/* Two-column layout (Pravda-like) */
.layout{
  display:grid;
  gap:18px;
  grid-template-columns: 1fr;
  margin-top:14px;
}
@media(min-width:980px){
  .layout{
    grid-template-columns: 1.65fr .85fr;
    align-items:start;
  }
}
.maincol{}
.sidebar{}

/* Lists */
.section-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin:18px 0 10px}
.section-head h2{margin:0; font-size:1.12rem}
.section-head a{color:var(--muted); font-size:.92rem}
.section-head a:hover{color:var(--accent)}

.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:12px;
}
.card h3{margin:6px 0 6px; line-height:1.25; font-size:1.02rem}
.meta{display:flex; flex-wrap:wrap; gap:10px; align-items:center; color:var(--muted); font-size:.86rem}
.meta a{color:var(--muted)}
.meta a:hover{color:var(--accent)}
.excerpt{color:var(--muted); margin:8px 0 0}

/* Thumbnails on listings (announces) */
.thumb{display:block; margin:10px 0 10px;}
.thumb img{width:100%; height:auto; border-radius:10px;}

/* Hero */
.hero-card{
  padding:14px;
  border-radius:var(--radius);
  background:#fff;
  border:1px solid var(--line);
}
.hero-card h1{line-height:1.12; margin:10px 0; font-size:1.55rem}
@media(min-width:740px){ .hero-card h1{font-size:1.85rem} }
.hero-card .lead{color:var(--muted); font-size:1.02rem}
.hero-card .actions{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}

/* Ticker */
.ticker ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px}
.ticker li a{
  display:flex; gap:10px; align-items:flex-start;
  padding:10px 10px; border-radius:10px;
  border:1px solid var(--line);
  background:#fff;
}
.ticker li a:hover{background:#f9fafb; text-decoration:none}
.ticker time{color:var(--muted); font-size:.82rem; white-space:nowrap; margin-top:1px}

/* Sidebar widgets */
.widget h3{margin:0 0 10px; font-size:1rem}
.widget ul{margin:0; padding-left:18px}
.widget a{color:var(--text)}
.widget a:hover{color:var(--accent)}

/* Single (featured image ON) */
.single-wrap{max-width:860px; margin:0 auto; padding:16px 12px}
@media(min-width:740px){ .single-wrap{padding:20px 16px} }
.single-wrap h1{line-height:1.12; font-size:1.65rem; margin:8px 0}
@media(min-width:740px){ .single-wrap h1{font-size:2.1rem} }
.single-meta{display:flex; flex-wrap:wrap; gap:10px; color:var(--muted); font-size:.92rem; margin:10px 0 12px}
.single-meta a{color:var(--muted)}
.single-meta a:hover{color:var(--accent)}
.single-lead{color:var(--muted); font-size:1.06rem; margin:12px 0}
.content p{margin:0 0 14px}
.content h2, .content h3{margin:22px 0 10px; line-height:1.2}
.content ul, .content ol{margin:0 0 16px 22px}
.content blockquote{
  margin:18px 0; padding:14px 16px;
  border-left:3px solid var(--accent);
  background:#f3f7ff;
  border-radius:10px;
}

/* Footer */
.site-footer{margin-top:30px; border-top:1px solid var(--line); background:#fff}
.footer-inner{padding:22px 0; display:grid; gap:14px}
.footer-inner .cols{display:grid; gap:14px; grid-template-columns:1fr}
@media(min-width:900px){ .footer-inner .cols{grid-template-columns:1.3fr 1fr 1fr} }
.footer-inner a{color:var(--muted)}
.footer-inner a:hover{color:var(--accent)}
.footer-bottom{padding:14px 0; color:var(--muted); font-size:.86rem; border-top:1px solid var(--line)}

/* WP */
.screen-reader-text{position:absolute; left:-10000px; top:auto; width:1px; height:1px; overflow:hidden}


/* Smaller left-aligned thumbnails in article previews */
.card{display:block; overflow:hidden}
.thumb{
  float:left;
  width:120px;
  min-width:120px;
  margin:6px 12px 6px 0;
}
.thumb img{
  width:120px;
  height:80px;
  object-fit:cover;
  border-radius:8px;
}

/* Clear float after card */
.card::after{content:"";display:block;clear:both}

/* Full article images always 100% width */
.content img{
  width:100% !important;
  height:auto !important;
  display:block;
  margin:14px 0;
  border-radius:10px;
}


/* Compact mobile feed (UP-like) */
@media(max-width:520px){
  .card{padding:10px}
  .thumb{
    width:92px;
    min-width:92px;
    margin:6px 10px 6px 0;
  }
  .thumb{aspect-ratio:16/9}
  .thumb img{border-radius:8px}
  .card h3{font-size:.98rem; line-height:1.22}
  .excerpt{display:none} /* compact like mobile news feeds */
  .meta{gap:8px; font-size:.82rem}
}


/* Sidebar fresh news with thumbnails */
.side-news{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px}
.side-link{display:flex; gap:10px; align-items:flex-start}
.side-thumbwrap{flex:0 0 92px}
.side-thumb{width:92px; height:auto; display:block; border-radius:8px}
.side-title{font-size:.95rem; line-height:1.25; color:var(--text)}
.side-link:hover{text-decoration:none}
.side-link:hover .side-title{color:var(--accent)}

/* Homepage slider */
.slider{padding:12px; background:linear-gradient(135deg, rgba(11,94,215,.06), rgba(220,38,38,.04)); border:1px solid rgba(17,24,39,.08)}
.slider-head{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:10px}
.slider-head h2{margin:0; font-size:1.06rem}
.slider-dots{display:flex; gap:6px; align-items:center}
.slider-dots .dot{
  width:9px; height:9px; border-radius:999px;
  border:1px solid var(--line); background:#fff; cursor:pointer;
}
.slider-dots .dot.active{background:var(--accent); border-color:var(--accent)}
.slider-viewport{position:relative}
.slide{border:1px solid rgba(17,24,39,.10); border-radius:12px; overflow:hidden; background:#fff}
.slide-link{display:block}
.slide-media{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
.slide-media.noimg{background:#f3f4f6}
.slide-body{padding:12px}
.slide-body h3{margin:8px 0 6px; font-size:1.12rem; line-height:1.2}
.slide-body .excerpt{margin:0; color:var(--muted)}
.slider-nav{display:flex; gap:10px; justify-content:flex-end; margin-top:10px}

/* Watermark logo overlay (≈5% of image width) */
.slide-media .wm{
  position:absolute;
  right:10px;
  bottom:10px;
  width:5%;
  min-width:26px;
  max-width:56px;
  aspect-ratio:1/1;
  background-image:url('../assets/logo.png');
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  opacity:.35;
  pointer-events:none;
  filter:grayscale(100%);
}

@media(max-width:520px){
  .slider-nav{justify-content:space-between}
  .slide-body h3{font-size:1.02rem}
  .slide-body .excerpt{display:none}
}
