/*
Theme Name: ReceptyWP
Theme URI: https://generatorreceptu.cz
Author: ChatGPT
Description: Šablona pro recepty s generátorem a pravým postranním panelem.
Version: 1.1.0
Text Domain: receptywp
*/
:root{--bg:#f8fafc;--ink:#0f172a;--muted:#64748b;--brand:#84cc16;--card:#ffffff;--ring:#e2e8f0;--shadow:0 20px 40px rgba(2,6,23,.06);--brown:#6b4f3a}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink)}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Hero */
.header-hero{position:relative;height:320px;border-bottom:1px solid var(--ring);background:#000;border-radius:0 0 24px 24px;overflow:hidden;margin-bottom:0}
.header-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.8)}
.header-hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.25),rgba(0,0,0,.55))}
.header-hero .inner{position:relative;z-index:2;height:100%;display:flex;align-items:center}
.header-hero h1{color:#fff;font-weight:800;font-size:clamp(28px,4.2vw,48px);margin:0 0 8px 0}
.header-hero p{color:#e2e8f0;margin:0;font-size:clamp(14px,2vw,18px)}

/* Top bar menu */
.topbar{background:var(--brown);color:#fff;border-bottom:1px solid rgba(255,255,255,.12);padding:0}
.topbar .container{display:flex;align-items:center;justify-content:center}
.topbar nav ul{display:flex;justify-content:center;gap:32px;list-style:none;margin:0;padding:14px 0}
.topbar nav ul li{display:inline-block}
.topbar nav ul a{color:#fff;text-transform:uppercase;font-weight:600;letter-spacing:.5px;transition:opacity .2s ease}
.topbar nav ul a:hover{opacity:.8}

/* Layout */
.layout{display:grid;grid-template-columns:1fr 320px;gap:24px;margin-top:22px}
@media (max-width:1020px){.layout{grid-template-columns:1fr}}

/* Cards & sections */
.card{background:var(--card);border:1px solid var(--ring);border-radius:18px;box-shadow:var(--shadow);padding:18px}
.section-title{display:flex;justify-content:space-between;align-items:center;margin:8px 0 12px 0}
.section-title h2{margin:0;font-size:22px}

/* Categories */
.categories{margin:40px auto 16px;max-width:1200px;text-align:center;padding:0 16px}
.categories h2{font-size:28px;margin-bottom:20px;color:#1e293b;letter-spacing:.5px}
.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;justify-items:center}
@media (max-width:900px){.category-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.category-grid{grid-template-columns:1fr}}
.cat-box{display:flex;flex-direction:column;align-items:center;background:#fff;border-radius:18px;box-shadow:0 4px 12px rgba(0,0,0,.08);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease;width:100%;max-width:320px}
.cat-box img{width:100%;height:160px;object-fit:cover}
.cat-box span{margin:10px 0 12px;font-weight:600;font-size:16px}
.cat-box:hover{transform:translateY(-4px);box-shadow:0 8px 20px rgba(0,0,0,.15)}

/* Recipe cards grid */
.grid-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:1100px){.grid-cards{grid-template-columns:repeat(3,1fr)}}
@media (max-width:800px){.grid-cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.grid-cards{grid-template-columns:1fr}}
.card-recipe{border-radius:16px;overflow:hidden;border:1px solid var(--ring);background:#fff;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease;display:block}
.card-recipe:hover{transform:translateY(-4px);box-shadow:0 10px 24px rgba(0,0,0,.12)}
.card-recipe .thumb{height:160px;background:#e2e8f0}
.card-recipe img{width:100%;height:160px;object-fit:cover;display:block}
.card-recipe .body{padding:12px}
.card-recipe h3{margin:0 0 6px 0;font-size:16px}
.card-recipe p{margin:0;color:var(--muted);font-size:14px}

/* Generator */
.generator{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:900px){.generator{grid-template-columns:repeat(2,1fr)}}
select,button{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--ring);font-size:15px}
button{background:var(--brand);color:#0f172a;font-weight:800;border:0;cursor:pointer}
button:hover{filter:brightness(.95)}

/* Banners & sidebar */
.banner {
    height: 120px;
    background: #ffffff !important;
    border: 1px solid #ddd !important;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #475569;
    font-weight: 700;
}

.sidebar .widget{margin-bottom:18px}
.widget.banner{height:260px}
.widget.text{padding:14px}

/* Footer */
.footer{margin:24px 0 40px;text-align:center;color:var(--muted)}
.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid var(--ring);padding:8px;text-align:left}
/* Sidebar bez modrého „přechodu / pruhů“ */
.sidebar .widget {
    background: #fff !important;
    border: 1px solid #ddd !important;
    box-shadow: 0 3px 10px rgba(0,0,0,.05);
    padding: 16px;
    border-radius: 14px;
}

/* Zruší defaultní WordPress pozadí */
.widget_recent_entries,
.widget_categories,
.widget_text {
    background-image: none !important;
    background-color: #fff !important;
}
.post-thumb-wrapper {
  margin-bottom: 14px;
}

.post-thumb {
  width: 100%;
  height: auto;
  border-radius: 12px;
  display: block;
}
.post-thumb-wrapper {
  margin-bottom: 14px;
  overflow: hidden;
  border-radius: 12px;
}

.post-thumb {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
/* GRID 2 sloupce pro články */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

/* Na mobilu 1 sloupec */
@media(max-width: 700px) {
  .blog-grid {
    grid-template-columns: 1fr;
  }
}

/* Karta článku */
.blog-card {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 16px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

/* Náhledový obrázek */
.post-thumb-wrapper {
  overflow: hidden;
  border-radius: 10px;
  margin-bottom: 12px;
}
.post-thumb {
  width: 100%;
  height: 180px;
  object-fit: cover;
}

/* Titulek článku */
.blog-title {
  font-size: 20px;
  margin: 8px 0;
}
.blog-title a {
  color: #0f172a;
  text-decoration: none;
  font-weight: 700;
}

/* Výňatek */
.blog-excerpt {
  color: #64748b;
  font-size: 15px;
}

/* Paginace */
.pagination {
  margin-top: 28px;
  text-align: center;
}
.pagination a,
.pagination span {
  padding: 8px 12px;
  margin: 0 4px;
  background:#fff;
  border:1px solid #94a3b8;
  border-radius:6px;
  text-decoration:none;
  color:#0f172a;
}
.pagination .current {
  background:#84cc16;
  border-color:#84cc16;
  color:#0f172a;
  font-weight:700;
}
/* Fix layoutu horního sidebaru, aby widgety byly pod sebou */
.sidebar-top .widget {
    display: block !important;
    width: 100% !important;
}

/* Zrušení jakýchkoli flex/grid nastavení, které to lámou */
.sidebar-top {
    display: block !important;
}
/* === ROZLOŽENÍ PRO STRÁNKY S OBSAHEM + SIDEBAR === */
.page-with-sidebar {
    display: grid;
    grid-template-columns: 1fr 330px;
    gap: 30px;
    margin-top: 30px;
    align-items: start;
}

/* obsah vlevo */
.page-with-sidebar main {
    width: 100%;
}

/* sidebar vpravo */
.page-with-sidebar aside {
    width: 100%;
}

/* standardní widgety — bez násilných hacků */
.sidebar .widget {
    display: block;
    width: 100%;
    margin-bottom: 20px;
}

/* sidebar má běžné chování */
.sidebar {
    display: block;
}
.page-layout {
    display: grid;
    grid-template-columns: 1fr 330px;
    gap: 30px;
    margin-top: 30px;
}

.page-content .card h1 {
    margin-bottom: 20px;
}

.page-text {
    font-size: 18px;
    line-height: 1.6;
}
/* === FIX ROZLOŽENÍ STRÁNEK S PRAVÝM SIDEBAR === */

.page-with-sidebar {
    display: grid;
    grid-template-columns: 1fr 330px;
    gap: 40px;
    margin-top: 40px;
}

.page-with-sidebar .content-area .card {
    width: 100%;
}

.page-with-sidebar .sidebar {
    width: 100%;
}

/* Sidebar widgety normálně pod sebou */
.page-with-sidebar .sidebar .widget {
    margin-bottom: 25px;
}
