/*
Theme Name: Zvířecí Jména Pro
Theme URI: https://zvireci-jmena.cz
Author: Miroslav Dubina
Author URI: https://www.mdreklama.cz
Description: Moderní WordPress theme pro generátor jmen zvířat – v3.0
Version: 3.0
License: GNU General Public License v2 or later
Text Domain: zvirata
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@700;800&family=Inter:wght@400;500;600;700&display=swap');

/* ─── PROMĚNNÉ ───────────────────────────────────────── */
:root {
  --c-brown:      #7c4d2e;
  --c-brown-l:    #b07843;
  --c-brown-xl:   #e8c99a;
  --c-brown-bg:   #fdf7ef;
  --c-dark:       #1a1208;
  --c-mid:        #5a3e28;
  --c-text:       #2c1a0e;
  --c-muted:      #7a6652;
  --c-blue:       #1e6fb5;
  --c-blue-l:     #e8f2fc;
  --c-green:      #1e8a4a;
  --c-green-l:    #e6f5ec;
  --c-red:        #c0392b;
  --c-red-l:      #fdf0ef;
  --c-orange:     #d4610c;
  --c-orange-l:   #fdf0e6;
  --c-line:       #e8ddd2;
  --shadow-sm:    0 1px 4px rgba(0,0,0,.08);
  --shadow:       0 3px 16px rgba(0,0,0,.10);
  --shadow-lg:    0 8px 32px rgba(0,0,0,.14);
  --r:            10px;
  --r-sm:         6px;
  --trans:        .18s ease;
}

/* ─── RESET ──────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',system-ui,sans-serif;
  color:var(--c-text);
  background:#fff;
  line-height:1.65;
  overflow-x:hidden;
}
img { max-width:100%; height:auto; display:block; }
a   { color:var(--c-brown); text-decoration:none; transition:color var(--trans); }
a:hover { color:var(--c-dark); }

/* ─── LAYOUT ─────────────────────────────────────────── */
.wrap    { max-width:1220px; margin:0 auto; padding:0 20px; }
.content-grid {
  display:grid;
  grid-template-columns:1fr 320px;
  gap:40px;
  max-width:1220px;
  margin:40px auto;
  padding:0 20px;
}
@media(max-width:960px){ .content-grid { grid-template-columns:1fr; } }

/* ─── HORNÍ LIŠTA ────────────────────────────────────── */
.topbar {
  background:var(--c-dark);
  color:rgba(255,255,255,.7);
  font-size:.76rem;
  font-weight:600;
  letter-spacing:.4px;
  padding:7px 0;
  text-transform:uppercase;
}
.topbar .wrap {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.topbar a { color:rgba(255,255,255,.7); }
.topbar a:hover { color:#fff; }

/* ─── HEADER ─────────────────────────────────────────── */
.site-header {
  background:#fff;
  border-bottom:1px solid var(--c-line);
  position:sticky;
  top:0;
  z-index:200;
  box-shadow: var(--shadow-sm);
}
.header-inner {
  display:flex;
  align-items:center;
  gap:24px;
  height:72px;
}
.site-branding { display:flex; align-items:center; gap:12px; flex-shrink:0; }
/* Logo – všechny varianty selektoru aby to vždy chytilo */
.site-logo img,
img.custom-logo,
.custom-logo-link img,
.site-branding a img,
.site-branding img {
    height: 48px !important;
    width: auto !important;
    max-width: 160px !important;
    border-radius: var(--r-sm);
    display: block;
}
.site-name {
  font-family:'Playfair Display',serif;
  font-size:1.3rem;
  font-weight:800;
  color:var(--c-brown);
  line-height:1.1;
  white-space:nowrap;
}
.site-desc { font-size:.72rem; color:var(--c-muted); margin-top:1px; }

/* NAV */
.main-nav { margin-left:auto; }
.main-nav ul { list-style:none; display:flex; gap:2px; }
.main-nav a {
  display:block;
  padding:8px 13px;
  border-radius:var(--r-sm);
  font-size:.88rem;
  font-weight:600;
  color:var(--c-text);
  transition:background var(--trans);
}
.main-nav a:hover,
.main-nav .current-menu-item a { background:var(--c-brown-bg); color:var(--c-brown); }

/* Hamburger */
.nav-toggle {
  display:none; background:none; border:none; cursor:pointer;
  width:38px; height:38px; flex-direction:column;
  justify-content:center; gap:6px; padding:4px; margin-left:auto;
}
.nav-toggle span {
  display:block; height:2px; background:var(--c-text);
  border-radius:2px; transition:var(--trans);
}
@media(max-width:840px){
  .nav-toggle { display:flex; }
  .main-nav {
    display:none; position:absolute; top:72px; left:0; right:0;
    background:#fff; border-bottom:2px solid var(--c-line);
    padding:12px 20px; margin:0;
    box-shadow:var(--shadow);
  }
  .main-nav.open { display:block; }
  .main-nav ul   { flex-direction:column; gap:2px; }
  .main-nav a    { padding:12px 14px; }
}

/* ─── HERO ───────────────────────────────────────────── */
.site-hero {
  position:relative;
  height:clamp(380px,55vh,650px);
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,#3d1f0a 0%,var(--c-brown) 60%,#0d4a7a 100%);
}
.hero-video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0; opacity:.55;
}
.hero-yt-wrap {
  position:absolute; inset:-30%; z-index:0; pointer-events:none;
}
.hero-yt-wrap iframe { width:100%; height:100%; border:none; }
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(to bottom,rgba(20,8,0,.25) 0%,rgba(20,8,0,.) 50%,rgba(20,8,0,.55) 100%);
}
.hero-content {
  position:relative; z-index:2;
  text-align:center; color:#fff;
  padding:20px; max-width:780px;
}
.hero-badge {
  display:inline-block; background:var(--c-brown); color:#fff;
  font-size:.75rem; font-weight:700; letter-spacing:.8px;
  text-transform:uppercase; padding:5px 16px; border-radius:100px;
  margin-bottom:18px;
}
.hero-content h1 {
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,5vw,3.6rem);
  font-weight:800; line-height:1.12;
  text-shadow:0 2px 16px rgba(0,0,0,.4);
  margin-bottom:16px;
}
.hero-content p {
  font-size:clamp(1rem,1.8vw,1.18rem);
  opacity:.88; max-width:560px; margin:0 auto 28px;
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.hero-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.hero-scroll {
  position:absolute; bottom:22px; left:50%; transform:translateX(-50%);
  z-index:2; color:rgba(255,255,255,.6); font-size:1.4rem;
  animation:bob 2s ease-in-out infinite;
}
@keyframes bob { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }
/* fallback emoji animace */
.hero-deco { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.hero-deco span {
  position:absolute; opacity:.12;
  animation:floaty 9s ease-in-out infinite;
  font-size:clamp(2rem,4vw,4rem);
}
@keyframes floaty { 0%,100%{transform:translateY(0) rotate(-6deg)} 50%{transform:translateY(-18px) rotate(6deg)} }

/* ─── TLAČÍTKA ───────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:11px 24px; border-radius:var(--r-sm); border:2px solid transparent;
  font-weight:700; font-size:.93rem; cursor:pointer;
  text-decoration:none; transition:all var(--trans); white-space:nowrap;
}
.btn-primary { background:var(--c-brown); color:#fff; border-color:var(--c-brown); }
.btn-primary:hover { background:var(--c-dark); border-color:var(--c-dark); color:#fff; transform:translateY(-1px); box-shadow:var(--shadow); }
.btn-ghost { background:rgba(255,255,255,.12); color:#fff; border-color:rgba(255,255,255,.5); backdrop-filter:blur(6px); }
.btn-ghost:hover { background:rgba(255,255,255,.24); color:#fff; }
.btn-sm { padding:7px 14px; font-size:.82rem; }
.btn-outline { background:transparent; color:var(--c-brown); border-color:var(--c-brown); }
.btn-outline:hover { background:var(--c-brown); color:#fff; }

/* ─── KATEGORIE PRUHY ─────────────────────────────────── */
.cat-bar {
  background:var(--c-brown-bg);
  border-top:3px solid var(--c-brown);
  border-bottom:1px solid var(--c-line);
  padding:0;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  white-space:nowrap;
}
.cat-bar .wrap { display:flex; gap:0; }
.cat-bar a {
  display:inline-block;
  padding:13px 18px;
  font-size:.82rem;
  font-weight:700;
  color:var(--c-mid);
  text-transform:uppercase;
  letter-spacing:.5px;
  border-right:1px solid var(--c-line);
  transition:background var(--trans), color var(--trans);
}
.cat-bar a:hover,
.cat-bar a.active { background:var(--c-brown); color:#fff; }

/* ─── MAGAZINE FEATURED ──────────────────────────────── */
.magazine-featured {
  display:grid;
  grid-template-columns:1.7fr 1fr;
  gap:0;
  margin:0 0 40px;
  border-radius:var(--r);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  min-height:420px;
}
@media(max-width:768px){ .magazine-featured { grid-template-columns:1fr; } }

.mf-main { position:relative; }
.mf-main-img {
  width:100%; height:100%; min-height:420px;
  object-fit:cover; display:block;
}
.mf-main-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.2) 55%,transparent 100%);
}
.mf-main-body {
  position:absolute; bottom:0; left:0; right:0;
  padding:28px 28px 32px;
  color:#fff;
}
.mf-label {
  display:inline-block; background:var(--c-brown);
  color:#fff; font-size:.72rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.8px;
  padding:3px 12px; border-radius:100px; margin-bottom:12px;
}
.mf-main-body h2 {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.3rem,2.5vw,2rem);
  font-weight:800; line-height:1.2;
  margin-bottom:10px;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
}
.mf-main-body h2 a { color:#fff; }
.mf-main-body h2 a:hover { text-decoration:underline; }
.mf-main-body p { font-size:.9rem; opacity:.82; line-height:1.5; }
.mf-meta { font-size:.76rem; opacity:.7; margin-top:10px; }

.mf-stack { background:#fff; display:flex; flex-direction:column; }
.mf-item {
  display:flex; gap:0; flex:1;
  border-bottom:1px solid var(--c-line);
  overflow:hidden; transition:background var(--trans);
}
.mf-item:last-child { border-bottom:none; }
.mf-item:hover { background:var(--c-brown-bg); }
.mf-item-img { width:110px; flex-shrink:0; overflow:hidden; }
.mf-item-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.mf-item:hover .mf-item-img img { transform:scale(1.06); }
.mf-item-body { padding:14px 16px; display:flex; flex-direction:column; justify-content:center; }
.mf-item-body .label-sm {
  font-size:.68rem; font-weight:800; text-transform:uppercase;
  letter-spacing:.6px; color:var(--c-brown); margin-bottom:5px;
}
.mf-item-body h3 {
  font-family:'Playfair Display',serif;
  font-size:.92rem; font-weight:700; line-height:1.3;
  margin-bottom:4px;
}
.mf-item-body h3 a { color:var(--c-text); }
.mf-item-body h3 a:hover { color:var(--c-brown); }
.mf-item-body .meta-sm { font-size:.72rem; color:var(--c-muted); }

/* ─── KATEGORIE SEKCE ────────────────────────────────── */
.section-head {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:18px; gap:12px;
}
.section-title {
  font-family:'Playfair Display',serif;
  font-size:1.4rem; font-weight:800;
  color:var(--c-dark);
  display:flex; align-items:center; gap:10px;
}
.section-title-bar {
  display:inline-block; width:4px; height:22px;
  background:var(--c-brown); border-radius:2px; flex-shrink:0;
}
.section-more {
  font-size:.8rem; font-weight:700; color:var(--c-brown);
  white-space:nowrap;
}
.section-more:hover { color:var(--c-dark); text-decoration:underline; }

/* ─── CARDS GRID ─────────────────────────────────────── */
.cards-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-bottom:40px;
}
@media(max-width:1100px){ .cards-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:720px) { .cards-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px) { .cards-grid { grid-template-columns:1fr; } }

/* ─── POST CARD ──────────────────────────────────────── */
.post-card {
  border-radius:var(--r); overflow:hidden; background:#fff;
  box-shadow:var(--shadow-sm); border:1px solid var(--c-line);
  display:flex; flex-direction:column;
  transition:box-shadow var(--trans), transform var(--trans);
}
.post-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-3px); }

.pc-thumb {
  position:relative; overflow:hidden;
  aspect-ratio:3/2; background:var(--c-brown-bg);
  flex-shrink:0;
}
.pc-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.post-card:hover .pc-thumb img { transform:scale(1.07); }
.pc-thumb-empty { aspect-ratio:3/2; background:linear-gradient(135deg,#f5e8d5,#ecdcc0); display:flex; align-items:center; justify-content:center; font-size:2.8rem; }

.pc-cat {
  position:absolute; top:10px; left:10px;
  font-size:.68rem; font-weight:800; text-transform:uppercase;
  letter-spacing:.5px; padding:3px 10px; border-radius:100px; color:#fff;
}
.pc-cat.c-brown  { background:var(--c-brown); }
.pc-cat.c-blue   { background:var(--c-blue); }
.pc-cat.c-green  { background:var(--c-green); }
.pc-cat.c-red    { background:var(--c-red); }
.pc-cat.c-orange { background:var(--c-orange); }

.pc-body { padding:16px; flex:1; display:flex; flex-direction:column; }
.pc-meta { font-size:.72rem; color:var(--c-muted); margin-bottom:7px; display:flex; gap:8px; align-items:center; }
.pc-title {
  font-family:'Playfair Display',serif;
  font-size:.97rem; font-weight:700; line-height:1.35;
  margin-bottom:8px; flex:1;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.pc-title a { color:var(--c-text); }
.pc-title a:hover { color:var(--c-brown); }
.pc-excerpt {
  font-size:.82rem; color:var(--c-muted); line-height:1.55;
  margin-bottom:12px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.pc-read { font-size:.78rem; font-weight:700; color:var(--c-brown); margin-top:auto; }
.pc-read:hover { color:var(--c-dark); text-decoration:underline; }

/* ─── GENERÁTOR ──────────────────────────────────────── */
.gen-wrap { max-width:1100px; margin:0 auto; padding:0 20px 60px; }

.gen-promo {
  border-radius:var(--r);
  background:linear-gradient(120deg,var(--c-brown) 0%,#9e6833 50%,#1e6fb5 100%);
  color:#fff; padding:32px 36px; margin-bottom:28px;
  box-shadow:var(--shadow-lg);
}
.gen-promo h2 { font-family:'Playfair Display',serif; font-size:1.7rem; margin-bottom:8px; }
.gen-promo p  { opacity:.88; font-size:1rem; }

.gen-card {
  background:#fff; border:1px solid var(--c-line);
  border-radius:var(--r); padding:28px;
  box-shadow:var(--shadow-sm); margin-bottom:24px;
}
.gen-card h3 {
  font-family:'Playfair Display',serif;
  font-size:1.2rem; font-weight:800;
  margin-bottom:18px; color:var(--c-dark);
  padding-bottom:12px; border-bottom:2px solid var(--c-line);
}

/* Druh zvířete – pill tlačítka */
.species-pills { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:22px; }
.species-btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 16px; border-radius:100px;
  border:2px solid var(--c-line); background:#fff;
  cursor:pointer; font-weight:600; font-size:.86rem;
  color:var(--c-text); transition:all var(--trans);
}
.species-btn:hover  { border-color:var(--c-brown-l); background:var(--c-brown-bg); }
.species-btn.active { background:var(--c-brown); border-color:var(--c-brown); color:#fff; }

/* Controls row */
.gen-controls {
  display:grid; grid-template-columns:1fr 1fr 1fr auto;
  gap:14px; align-items:end; margin-bottom:20px;
}
@media(max-width:660px){ .gen-controls { grid-template-columns:1fr 1fr; } .gen-controls .gcol-btn { grid-column:1/-1; } }

.gen-controls label { display:block; font-size:.8rem; font-weight:700; color:var(--c-muted); margin-bottom:5px; text-transform:uppercase; letter-spacing:.4px; }
.gen-controls select,
.gen-controls input[type=text] {
  width:100%; padding:10px 14px;
  border:1.5px solid var(--c-line); border-radius:var(--r-sm);
  font-size:.92rem; background:#fff; color:var(--c-text);
  outline:none; transition:border-color var(--trans);
}
.gen-controls select:focus, .gen-controls input:focus { border-color:var(--c-brown-l); }

/* Names grid */
.names-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:10px; }
.name-chip {
  background:var(--c-brown-bg); border-radius:var(--r-sm);
  padding:10px 14px; display:flex; align-items:center;
  justify-content:space-between; font-weight:600; font-size:.92rem;
  border-left:4px solid var(--c-brown-l);
  transition:box-shadow var(--trans), transform var(--trans);
}
.name-chip:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.name-chip.type-cat     { border-left-color:#e8720c; }
.name-chip.type-dog     { border-left-color:#7c4d2e; }
.name-chip.type-parrot  { border-left-color:#1e8a4a; }
.name-chip.type-guinea  { border-left-color:#8b3f9e; }
.name-chip.type-mouse   { border-left-color:#c0392b; }
.name-chip.type-rabbit  { border-left-color:#1e6fb5; }
.name-chip.type-hamster { border-left-color:#d4610c; }
.name-chip.type-turtle  { border-left-color:#1e8a4a; }
.name-chip.type-fish    { border-left-color:#0891b2; }

.fav-btn {
  background:none; border:none; cursor:pointer;
  font-size:1.05rem; padding:0 0 0 8px; opacity:.4;
  transition:opacity var(--trans), transform var(--trans); line-height:1;
}
.fav-btn:hover { opacity:1; transform:scale(1.3); }
.fav-btn.saved { opacity:1; }

/* No results */
.gen-empty {
  text-align:center; padding:36px 20px;
  background:var(--c-brown-bg); border-radius:var(--r);
  color:var(--c-muted); font-size:.9rem;
}

/* Fav table */
.fav-head { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; margin-bottom:16px; }
.fav-head h3 { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:800; color:var(--c-dark); }

.data-table { width:100%; border-collapse:collapse; font-size:.88rem; }
.data-table th { background:var(--c-brown-bg); color:var(--c-muted); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; padding:10px 14px; text-align:left; border-bottom:2px solid var(--c-line); }
.data-table td { padding:10px 14px; border-bottom:1px solid var(--c-line); }
.data-table tr:hover td { background:var(--c-brown-bg); }

/* ─── INFO BOXES ──────────────────────────────────────── */
.info-boxes-row {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin:32px 0;
}
@media(max-width:720px){ .info-boxes-row { grid-template-columns:1fr; } }

.info-box {
  border-radius:var(--r); padding:24px;
  border-top:4px solid transparent;
}
.info-box h3 {
  font-family:'Playfair Display',serif;
  font-size:1.05rem; font-weight:800;
  margin-bottom:10px;
}
.info-box p { font-size:.88rem; line-height:1.65; color:var(--c-mid); }

.info-box.amber  { background:#fffbeb; border-top-color:#f59e0b; }
.info-box.amber h3 { color:#92400e; }
.info-box.sky    { background:#f0f9ff; border-top-color:#0ea5e9; }
.info-box.sky h3 { color:#075985; }
.info-box.jade   { background:#f0fdf4; border-top-color:#22c55e; }
.info-box.jade h3 { color:#14532d; }
.info-box.rose   { background:#fff1f2; border-top-color:#f43f5e; }
.info-box.rose h3{ color:#881337; }

/* ─── SINGLE POST ────────────────────────────────────── */
.entry-wrap { background:#fff; border-radius:var(--r); box-shadow:var(--shadow-sm); border:1px solid var(--c-line); overflow:hidden; }
.entry-head { padding:36px 40px 0; }
@media(max-width:600px){ .entry-head { padding:24px 20px 0; } }
.entry-cat-badge {
  display:inline-block; background:var(--c-brown); color:#fff;
  font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.6px;
  padding:3px 12px; border-radius:100px; margin-bottom:14px;
}
.entry-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(1.6rem,3.5vw,2.4rem);
  font-weight:800; line-height:1.2;
  margin-bottom:16px; color:var(--c-dark);
}
.entry-meta-row { display:flex; align-items:center; gap:16px; flex-wrap:wrap; font-size:.8rem; color:var(--c-muted); padding-bottom:24px; border-bottom:1px solid var(--c-line); }
.entry-meta-row strong { color:var(--c-text); font-weight:600; }
.entry-feat-img { width:100%; max-height:500px; object-fit:cover; }
.entry-content { padding:36px 40px; font-size:1.04rem; line-height:1.78; }
@media(max-width:600px){ .entry-content { padding:24px 20px; } }
.entry-content h2 { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:800; color:var(--c-dark); margin:36px 0 14px; }
.entry-content h3 { font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; color:var(--c-brown); margin:28px 0 10px; }
.entry-content p  { margin-bottom:18px; }
.entry-content ul, .entry-content ol { padding-left:26px; margin-bottom:18px; }
.entry-content li { margin-bottom:7px; }
.entry-content blockquote {
  border-left:4px solid var(--c-brown-l); margin:28px 0;
  padding:16px 22px; background:var(--c-brown-bg);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-style:italic; font-size:1.05rem;
}
.entry-content img { border-radius:var(--r-sm); margin:12px 0; }

/* ─── SIDEBAR ─────────────────────────────────────────── */
.sidebar { display:flex; flex-direction:column; gap:24px; }
.widget {
  background:#fff; border-radius:var(--r);
  border:1px solid var(--c-line); padding:22px;
  box-shadow:var(--shadow-sm);
}
.widget-title {
  font-family:'Playfair Display',serif;
  font-size:1rem; font-weight:800; color:var(--c-dark);
  margin-bottom:16px; padding-bottom:10px;
  border-bottom:2px solid var(--c-line);
}

/* Zajímavosti v sidebaru */
.zaj-item { display:flex; gap:12px; padding:10px 0; border-bottom:1px solid var(--c-line); }
.zaj-item:last-child { border-bottom:none; }
.zaj-thumb { width:76px; height:56px; border-radius:var(--r-sm); overflow:hidden; flex-shrink:0; }
.zaj-thumb img { width:100%; height:100%; object-fit:cover; }
.zaj-body h4 { font-size:.85rem; font-weight:600; line-height:1.3; margin-bottom:4px; }
.zaj-body h4 a { color:var(--c-text); }
.zaj-body h4 a:hover { color:var(--c-brown); }
.zaj-body .zaj-meta { font-size:.72rem; color:var(--c-muted); }

/* ─── FOOTER ─────────────────────────────────────────── */
.site-footer { background:var(--c-dark); color:rgba(255,255,255,.75); margin-top:60px; }
.footer-inner {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px;
  padding:56px 0 36px;
}
@media(max-width:860px){ .footer-inner { grid-template-columns:1fr 1fr; } }
@media(max-width:500px){ .footer-inner { grid-template-columns:1fr; } }
.footer-col h4 { font-family:'Playfair Display',serif; color:#fff; font-size:1.05rem; margin-bottom:16px; }
.footer-col p  { font-size:.85rem; line-height:1.7; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:7px; }
.footer-col a  { color:rgba(255,255,255,.65); font-size:.85rem; }
.footer-col a:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding:20px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; font-size:.78rem; color:rgba(255,255,255,.5); }
.footer-bottom a { color:rgba(255,255,255,.5); }
.footer-bottom a:hover { color:#fff; }

/* ─── STRÁNKOVÁNÍ ────────────────────────────────────── */
.pagination-wrap { display:flex; justify-content:center; gap:6px; margin:36px 0; flex-wrap:wrap; }
.page-numbers {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:38px; height:38px; padding:0 10px;
  border-radius:var(--r-sm); font-weight:600; font-size:.88rem;
  border:1.5px solid var(--c-line); background:#fff; color:var(--c-text);
  transition:all var(--trans);
}
.page-numbers:hover:not(.current) { border-color:var(--c-brown); color:var(--c-brown); }
.page-numbers.current { background:var(--c-brown); border-color:var(--c-brown); color:#fff; }

/* ─── ADMIN AI GENERÁTOR ─────────────────────────────── */
.zv-wrap { max-width:1060px; }
.zv-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media(max-width:760px){ .zv-grid { grid-template-columns:1fr; } }
.zv-panel { background:#fff; border:1px solid #ddd; border-radius:8px; padding:24px; }
.zv-panel h2 { font-size:1rem; margin:0 0 18px; padding-bottom:12px; border-bottom:1px solid #eee; }
.zv-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px; }
.zv-row.full { grid-template-columns:1fr; }
.zv-row label { display:block; font-weight:600; font-size:.82rem; color:#505050; margin-bottom:4px; }
.zv-row input,.zv-row select,.zv-row textarea {
  width:100%; padding:8px 11px; border:1.5px solid #d0d0d0;
  border-radius:5px; font-size:.9rem;
}
.zv-row input:focus,.zv-row select:focus { border-color:#7c4d2e; outline:none; }
#zv-log {
  background:#0f172a; color:#7dd3fc; font-family:monospace;
  font-size:.8rem; padding:14px; border-radius:6px;
  height:220px; overflow-y:auto; margin-top:12px; line-height:1.7;
}
#zv-progress { background:#e5e7eb; border-radius:100px; height:18px; overflow:hidden; margin:10px 0; }
#zv-bar { height:100%; background:linear-gradient(90deg,var(--c-brown),var(--c-brown-l)); width:0; transition:width .35s; display:flex; align-items:center; justify-content:center; color:#fff; font-size:.72rem; font-weight:700; }

/* ─── UTILITIES ──────────────────────────────────────── */
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }
.text-center { text-align:center; }

/* ─── OPRAVY LAYOUTU (logo, header, footer) ─── */

/* Logo – WP vygeneruje img.custom-logo nebo a.custom-logo-link > img */
img.custom-logo,
a.custom-logo-link img,
.site-branding a img,
.site-branding > a img,
.site-header img {
    height: 48px !important;
    width: auto !important;
    max-width: 160px !important;
    max-height: 48px !important;
    border-radius: 8px;
    object-fit: contain;
}

/* Branding wrapper – zabraň přetečení loga */
.site-branding {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
    overflow: hidden;
    max-width: 360px;
}

.site-name-wrap { min-width: 0; }

/* Header inner – flex, zabraň přetečení */
.header-inner {
    display: flex;
    align-items: center;
    gap: 20px;
    height: 70px;
    overflow: visible;
    position: relative;
}

/* Nav na desktopu */
.main-nav { margin-left: auto; flex-shrink: 0; }

/* Topbar fix */
.topbar { font-size: .75rem; }

/* Hero – ujisti se že je nad headerem */
.site-hero { margin-top: 0; }

/* Footer widgety – nadpisy */
.site-footer h4,
.footer-col h4 { color: #fff; margin-bottom: 12px; }

.site-footer a,
.footer-col a   { color: rgba(255,255,255,.65); }
.site-footer a:hover { color: #fff; }

/* Footer nav menu inline */
.footer-navigation ul,
footer nav ul   { list-style: none; display: flex; flex-wrap: wrap; gap: 12px; margin: 0; padding: 0; }
footer nav a    { color: rgba(255,255,255,.5); font-size: .8rem; }
footer nav a:hover { color: #fff; }

/* Zajímavosti inline v těle stránky – karty vedle sebe */
.zajimavosti-inline {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 24px;
}
.zajimavosti-inline .widget {
    background: #fff;
    border: 1px solid var(--c-line);
    border-radius: var(--r);
    padding: 22px;
    box-shadow: var(--shadow-sm);
}
.zajimavosti-inline .widget-title {
    font-family: 'Playfair Display', serif;
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--c-dark);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--c-line);
}
.zajimavosti-inline .zaj-list { display: flex; flex-direction: column; gap: 12px; }
.zajimavosti-inline .zaj-item { display: flex; gap: 12px; align-items: flex-start; }
.zajimavosti-inline .zaj-thumb { width: 80px; height: 60px; flex-shrink: 0; border-radius: var(--r-sm); overflow: hidden; }
.zajimavosti-inline .zaj-thumb img { width: 100%; height: 100%; object-fit: cover; }
.zajimavosti-inline .zaj-body h4 { font-size: .88rem; font-weight: 600; line-height: 1.3; margin-bottom: 3px; }
.zajimavosti-inline .zaj-body h4 a { color: var(--c-text); }
.zajimavosti-inline .zaj-body h4 a:hover { color: var(--c-brown); }
.zajimavosti-inline .zaj-meta { font-size: .74rem; color: var(--c-muted); }