/*
Theme Name: Pozemky Bohuslavice
Theme URI: https://www.pozemky-bohuslavice.cz/
Author: BSshop / Petr Horný
Author URI: https://bsshop.cz
Description: Klasická šablona pro projekt Pozemky Bohuslavice u Trutnova. Hybrid editovatelnost — Customizer pro kontakty a footer, WP Menu v patičce, hardcoded PHP pole pro strukturované sekce.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: pozemky-bohuslavice
*/

/* ============================================
   DESIGN TOKENS
   ============================================ */
:root{
  --bg:        #e6ede6;
  --bg-2:      #dbe5dc;
  --bg-dark:   #14181a;
  --ink:       #16191c;
  --ink-2:     #4d564f;
  --ink-mute:  #8a958c;
  --line:      #c8d4c9;
  --line-soft: #d6e0d7;
  --moss:      #2f4a3a;
  --moss-2:    #4a6b54;
  --gold:      #a98b56;
  --paper-on-dark:#e6ede6;

  --r-sm: 4px;
  --r-md: 10px;
  --r-lg: 20px;

  --serif: "Spectral", "Iowan Old Style", "Source Serif Pro", Georgia, serif;
  --sans:  "Manrope", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --container: 1440px;
  --gutter: clamp(20px, 4vw, 56px);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ============================================
   TYPOGRAFIE
   ============================================ */
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-2);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:currentColor;opacity:.6}
.eyebrow.center::before{display:none}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;color:var(--ink);margin:0;letter-spacing:-.01em}
h1{font-size:clamp(34px, 4vw, 58px); line-height:1.05; letter-spacing:-.02em}
h2{font-size:clamp(32px, 4.2vw, 60px); line-height:1.05}
h3{font-size:clamp(22px, 2.2vw, 30px); line-height:1.2}
.serif-italic{font-style:italic;color:var(--moss)}
.lede{font-size:clamp(16px, 1.15vw, 19px); color:var(--ink-2); line-height:1.65; max-width:60ch}

.adv-sub{
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-mute);
  font-weight:400;display:block;margin-top:8px;
}

/* ============================================
   LAYOUT HELPERS
   ============================================ */
.container{max-width:var(--container);margin:0 auto;padding-left:var(--gutter);padding-right:var(--gutter)}
section{padding:clamp(72px, 9vw, 140px) 0;position:relative}
.section-head{display:flex;flex-direction:column;gap:20px;margin-bottom:64px;max-width:780px}

/* ============================================
   HEADER (bez loga PB — jen název)
   ============================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gutter);
  background:rgba(230,237,230,.78);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease, padding .3s ease;
}
.site-header.scrolled{border-bottom-color:var(--line-soft); padding-top:12px; padding-bottom:12px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:22px;letter-spacing:.01em}
.brand-name{line-height:1}
.brand-name small{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-2);letter-spacing:.18em;text-transform:uppercase;margin-top:3px}
.nav{display:flex;align-items:center;gap:34px}
.nav a{font-size:14px;color:var(--ink-2);transition:color .15s}
.nav a:hover{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .ph{font-family:var(--mono);font-size:13px;color:var(--ink);letter-spacing:.02em}
.nav-cta .ph span{color:var(--ink-mute);margin-right:6px}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;border-radius:999px;
  background:var(--moss);color:var(--paper-on-dark);
  font-size:14px;font-weight:500;letter-spacing:.02em;
  border:1px solid var(--moss);
  cursor:pointer;transition:transform .2s ease, background .2s ease;
}
.btn:hover{background:#26392e;transform:translateY(-1px);color:var(--paper-on-dark)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--bg)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#16191c}
.btn.gold:hover{background:#947847;border-color:#947847;color:#16191c}
.btn-arrow{display:inline-block;transition:transform .2s}
.btn:hover .btn-arrow{transform:translateX(3px)}

.menu-toggle{display:none;width:40px;height:40px;border:1px solid var(--line);background:transparent;border-radius:50%;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle span{display:block;width:16px;height:1.5px;background:var(--ink);position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;right:0;height:1.5px;background:var(--ink)}
.menu-toggle span::before{top:-5px}
.menu-toggle span::after{top:5px}

@media (max-width:980px){
  .nav, .nav-cta .ph, .nav-cta .btn span:not(.btn-arrow){display:none}
  .menu-toggle{display:inline-flex}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;padding:24px var(--gutter);background:var(--bg);border-bottom:1px solid var(--line-soft);gap:18px}
}

/* ============================================
   HERO
   ============================================ */
.hero{
  padding-top:clamp(140px, 16vh, 180px);
  padding-bottom:clamp(60px, 7vw, 100px);
  position:relative;overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:clamp(36px, 5vw, 80px);
  align-items:stretch;
}
.hero-copy h1 .accent{color:var(--moss);font-style:italic}
.hero-copy .lede{margin-top:28px}
.hero-actions{margin-top:36px;display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-meta{
  margin-top:48px;
  display:flex;flex-wrap:wrap;gap:30px 48px;
  padding-top:28px;border-top:1px solid var(--line);
}
.hero-meta div{font-family:var(--mono);font-size:12px;color:var(--ink-2);letter-spacing:.06em;text-transform:uppercase}
.hero-meta strong{display:block;font-family:var(--serif);font-style:normal;font-weight:500;font-size:26px;letter-spacing:-.01em;color:var(--ink);text-transform:none;margin-top:6px;line-height:1.1}

/* Hero video — click-to-play (poster + play btn, po kliknutí iframe) */
.video-wrap{
  position:relative;
  border-radius:var(--r-lg);
  overflow:hidden;
  width:100%;
  height:100%;
  min-height:420px;
  box-shadow: 0 30px 70px -30px rgba(20,24,26,.45), 0 2px 6px rgba(20,24,26,.06);
  background:#111;
  display:block;
}
/* Iframe vložený JS — !important kvůli inline width/height atributům od YouTube */
.video-wrap iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
}
.video-poster{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  cursor:pointer; transition:transform .6s ease;
}
.video-poster::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.45) 100%);
}
.video-wrap:hover .video-poster{transform:scale(1.03)}
.video-poster:focus-visible{outline:2px solid var(--moss);outline-offset:-4px}

/* MP4 varianta — autoplay loop muted, žádné branding ani cookies */
.video-wrap-mp4 .video-mp4{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  background:#111;
}
.video-wrap-mp4 .video-tag,
.video-wrap-mp4 .video-caption{
  position:absolute;z-index:2;pointer-events:none;
}
.video-wrap-mp4 .video-tag{
  left:20px;top:20px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;background:rgba(20,24,26,.6);backdrop-filter:blur(6px);
  padding:8px 14px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;
}
.video-wrap-mp4 .video-caption{
  left:0;right:0;bottom:0;
  padding:22px 24px 20px;
  color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));
}
.play-btn{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:96px;height:96px;border-radius:50%;
  background:rgba(230,237,230,.94);
  display:grid;place-items:center;cursor:pointer;
  border:none; z-index:2;
  transition: transform .2s ease, background .2s ease;
}
.play-btn:hover{transform:translate(-50%,-50%) scale(1.06); background:#fff}
.play-btn svg{margin-left:5px;color:var(--moss)}
.video-tag{
  position:absolute;left:20px;top:20px;z-index:2;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;background:rgba(20,24,26,.6);backdrop-filter:blur(6px);
  padding:8px 14px;border-radius:999px;
  display:inline-flex;align-items:center;gap:8px;
}
.video-tag .dot{width:6px;height:6px;background:#e3463a;border-radius:50%;animation:blink 1.6s infinite}
@keyframes blink{50%{opacity:.3}}
.video-caption{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:22px 24px 20px;
  color:#fff;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;
}

@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr;align-items:start}
  .video-wrap{aspect-ratio:16/10; min-height:0; height:auto; order:-1}
  .hero-meta{gap:24px 32px}
  .hero-meta strong{font-size:22px}
}

/* ============================================
   BENEFITS (4 sloupce)
   ============================================ */
.benefits{padding-top:clamp(60px, 7vw, 100px)}
.benefits-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
}
.benefit{
  background:var(--bg);padding:36px 32px 32px;
  display:flex;flex-direction:column;gap:18px;
  min-height:240px;
}
.benefit-icon{
  width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line);
  display:grid;place-items:center;color:var(--moss);
}
.benefit h4{font-family:var(--serif);font-size:22px;font-weight:500;line-height:1.2;color:var(--ink)}
.benefit p{margin:0;font-size:14px;color:var(--ink-2);line-height:1.6}
@media (max-width:1000px){.benefits-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){
  .benefits-grid{
    grid-template-columns:1fr;
    gap:12px;background:transparent;border:0;border-radius:0;
  }
  .benefit{border:1px solid var(--line);border-radius:var(--r-md);min-height:0}
}

/* ============================================
   ADVANTAGES
   ============================================ */
.advantages{background:var(--bg-2)}
.adv-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:72px}
.adv-head .lede{margin:0}
.adv-list{display:flex;flex-direction:column;gap:0}
.adv-row{
  display:grid;grid-template-columns: 120px 1fr 1.4fr;
  gap:40px;align-items:start;
  padding:48px 0;
  border-top:1px solid var(--line);
}
.adv-row:last-child{border-bottom:1px solid var(--line)}
.adv-num{
  font-family:var(--serif);font-size:64px;font-weight:400;
  color:var(--moss);font-feature-settings:"lnum";
  line-height:1;
}
.adv-title{font-family:var(--serif);font-size:clamp(24px, 2vw, 32px);font-weight:500;line-height:1.2}
.adv-body{font-size:15.5px;color:var(--ink-2);line-height:1.65;max-width:54ch}
@media (max-width:900px){
  .adv-head{grid-template-columns:1fr;gap:24px}
  .adv-row{grid-template-columns:1fr;gap:14px;padding:34px 0}
  .adv-num{font-size:46px}
}

/* ============================================
   LOKALITA
   ============================================ */
.lokalita-grid{
  display:grid;grid-template-columns: 1.05fr .95fr;
  gap:clamp(28px, 5vw, 80px);
  align-items:center;
}
.lokalita-img{
  border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio: 4/3;
  background-color:var(--bg-2);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  position:relative;
}
.lokalita-img::after{
  content:"";position:absolute;inset:auto 0 0 0;height:40%;
  background:linear-gradient(180deg,transparent,rgba(20,24,26,.35));
}
.lokalita-stats{
  margin-top:32px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  border-top:1px solid var(--line);padding-top:28px;
}
.lokalita-stats div small{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);display:block;margin-bottom:8px}
.lokalita-stats div b{font-family:var(--serif);font-weight:500;font-size:26px;color:var(--ink);letter-spacing:-.01em}
@media (max-width:900px){.lokalita-grid{grid-template-columns:1fr}}

/* ============================================
   POZEMKY (tmavá sekce + ceník)
   ============================================ */
.pozemky{background:var(--bg-dark);color:var(--paper-on-dark)}
.pozemky h2, .pozemky h3{color:#e6ede6}
.pozemky .eyebrow{color:#a8b3a9}
.pozemky .eyebrow::before{background:#a8b3a9}
.poz-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px, 5vw, 72px);align-items:start}
.poz-copy p{color:#bcc7be;font-size:16px;line-height:1.7;max-width:55ch}
.poz-meta{margin-top:36px;display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.poz-meta .cell{border:1px solid #2c3530;border-radius:var(--r-md);padding:20px}
.poz-meta small{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#8a958c;display:block;margin-bottom:8px}
.poz-meta b{font-family:var(--serif);font-weight:500;font-size:22px;color:#e6ede6}
.cenik-card{
  background:#1c2220;border:1px solid #2c3530;
  border-radius:var(--r-lg);overflow:hidden;
  padding:24px;
}
.cenik-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.cenik-card header h4{font-family:var(--serif);font-weight:500;font-size:22px;color:#e6ede6;margin:0}
.cenik-img{
  border-radius:var(--r-md); overflow:hidden;
  background:#0f1411;cursor:zoom-in;position:relative;
}
.cenik-img img{width:100%;height:auto;display:block;transition:transform .4s}
.cenik-img:hover img{transform:scale(1.02)}
.cenik-legend{display:flex;gap:18px;margin-top:16px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:#8a958c;text-transform:uppercase;flex-wrap:wrap}
@media (max-width:900px){.poz-grid{grid-template-columns:1fr}}

/* ============================================
   GALERIE (mosaic)
   ============================================ */
.gallery-head{display:flex;justify-content:space-between;align-items:end;flex-wrap:wrap;gap:24px;margin-bottom:48px}
.gallery-head .lede{margin:0}
.gallery{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: clamp(90px, 8.5vw, 130px);
  gap:12px;
}
.g-item{
  overflow:hidden;border-radius:var(--r-md);
  cursor:zoom-in; position:relative;
  background:var(--bg-2);
}
.g-item img{
  width:100%;height:100%;
  object-fit:cover;
  object-position: var(--gal-pos, center);
  transition:transform .6s ease, filter .4s;
}
.g-item:hover img{transform:scale(1.05); filter:brightness(.9)}
.g-item::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 60%, rgba(0,0,0,.25));
  opacity:0;transition:opacity .3s;
}
.g-item:hover::after{opacity:1}

.g-1  { grid-column: 1 / span 7;  grid-row: 1 / span 4; }
.g-2  { grid-column: 8 / span 5;  grid-row: 1 / span 2; }
.g-3  { grid-column: 8 / span 5;  grid-row: 3 / span 2; }
.g-4  { grid-column: 1 / span 4;  grid-row: 5 / span 3; }
.g-5  { grid-column: 5 / span 5;  grid-row: 5 / span 3; }
.g-6  { grid-column: 10 / span 3; grid-row: 5 / span 3; }
.g-7  { grid-column: 1 / span 5;  grid-row: 8 / span 3; }
.g-8  { grid-column: 6 / span 4;  grid-row: 8 / span 2; }
.g-9  { grid-column: 10 / span 3; grid-row: 8 / span 2; }
.g-10 { grid-column: 6 / span 7;  grid-row: 10 / span 1; }
.g-11 { grid-column: 1 / span 6;  grid-row: 11 / span 2; }
.g-12 { grid-column: 7 / span 6;  grid-row: 11 / span 2; }

@media (max-width:900px){
  .gallery{grid-template-columns:repeat(6,1fr);grid-auto-rows:100px;gap:10px}
  .g-1  { grid-column: 1 / span 6; grid-row: span 3; }
  .g-2  { grid-column: 1 / span 3; grid-row: span 2; }
  .g-3  { grid-column: 4 / span 3; grid-row: span 2; }
  .g-4  { grid-column: 1 / span 2; grid-row: span 2; }
  .g-5  { grid-column: 3 / span 4; grid-row: span 2; }
  .g-6  { grid-column: 1 / span 6; grid-row: span 3; }
  .g-7  { grid-column: 1 / span 4; grid-row: span 2; }
  .g-8  { grid-column: 5 / span 2; grid-row: span 2; }
  .g-9  { grid-column: 1 / span 3; grid-row: span 2; }
  .g-10 { grid-column: 4 / span 3; grid-row: span 2; }
  .g-11 { grid-column: 1 / span 6; grid-row: span 2; }
  .g-12 { grid-column: 1 / span 6; grid-row: span 2; }
}
@media (max-width:540px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px;gap:12px}
  .g-1,.g-2,.g-3,.g-4,.g-5,.g-6,.g-7,.g-8,.g-9,.g-10,.g-11,.g-12{
    grid-column:span 2;grid-row:span 1;
  }
  .g-1{grid-row:span 2}
}

/* ============================================
   LIGHTBOX
   ============================================ */
.lightbox{
  position:fixed;inset:0;z-index:100;
  background:rgba(15,17,18,.94);
  display:none;align-items:center;justify-content:center;
  padding:40px;
}
.lightbox.open{display:flex}
.lightbox img{
  max-width:92vw;
  max-height:80vh;
  object-fit:contain;
  border-radius:4px;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.lb-close,.lb-prev,.lb-next{
  position:absolute;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);
  color:#fff;width:48px;height:48px;border-radius:50%;
  display:grid;place-items:center;cursor:pointer;transition:background .2s;
}
.lb-close:hover,.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.16)}
.lb-close{top:24px;right:24px}
.lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.lb-next{right:24px;top:50%;transform:translateY(-50%)}
.lb-caption{position:absolute;left:0;right:0;bottom:24px;text-align:center;color:#cbc4af;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase}

@media (max-width:540px){
  .lightbox{padding:16px}
  .lightbox img{max-width:96vw;max-height:70vh}
  .lb-close{top:12px;right:12px}
  .lb-prev{left:8px}
  .lb-next{right:8px}
}

/* ============================================
   KONTAKT
   ============================================ */
.contact{background:var(--bg)}
.contact-grid{
  display:grid;grid-template-columns: 1.05fr .95fr;
  gap:clamp(32px, 5vw, 72px);
  align-items:start;
}
.form-card{
  background:var(--bg-2);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:clamp(28px, 3vw, 44px);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;grid-column:span 2}
.field.half{grid-column:span 1}
.field label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2)}
.field input, .field textarea{
  font-family:inherit;font-size:15px;color:var(--ink);
  background:var(--bg);
  border:1px solid var(--line);
  border-radius:var(--r-sm);
  padding:14px 16px;outline:none;transition:border-color .15s, background .15s;
  width:100%;
}
.field textarea{min-height:140px;resize:vertical}
.field input:focus, .field textarea:focus{border-color:var(--moss);background:#f1f6f2}
.checkbox{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:var(--ink-2);grid-column:span 2;line-height:1.5}
.checkbox input{width:18px;height:18px;accent-color:var(--moss);margin-top:2px;flex-shrink:0}
.form-submit{grid-column:span 2;display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:6px;flex-wrap:wrap}
.form-note{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.06em}

.form-success{
  display:none; align-items:center;gap:14px;padding:16px 18px;border-radius:var(--r-md);
  background:#e3ecdf;border:1px solid #b9cdb1;color:#2f4a3a;font-size:14px;
  grid-column:span 2;
}
.form-success.show{display:flex}

/* Vzhled WPForms / CF7 v rámci .form-card */
.form-card .wpforms-form input[type=text],
.form-card .wpforms-form input[type=email],
.form-card .wpforms-form input[type=tel],
.form-card .wpforms-form textarea,
.form-card .wpcf7-form input[type=text],
.form-card .wpcf7-form input[type=email],
.form-card .wpcf7-form input[type=tel],
.form-card .wpcf7-form textarea{
  font-family:inherit;font-size:15px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:14px 16px;width:100%;
}
.form-card .wpforms-form label,
.form-card .wpcf7-form label{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-2);
}
.form-card .wpforms-submit,
.form-card .wpcf7-form input[type=submit]{
  background:var(--moss);color:var(--paper-on-dark);
  border:1px solid var(--moss);border-radius:999px;
  padding:13px 22px;font-weight:500;cursor:pointer;
}

.contact-info{display:flex;flex-direction:column;gap:28px}
.ci-card{
  border:1px solid var(--line);border-radius:var(--r-md);padding:28px;background:var(--bg);
  display:flex;flex-direction:column;gap:18px;
}
.ci-card h3{font-size:22px}
.ci-line{display:flex;align-items:center;gap:14px}
.ci-line .ico{width:38px;height:38px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;color:var(--moss);flex-shrink:0}
.ci-line small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:2px}
.ci-line b{font-weight:500;font-size:16px;color:var(--ink)}

.map-wrap{
  border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);
  aspect-ratio:4/3;background:var(--bg-2);
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.92) contrast(1.02)}

@media (max-width:900px){
  .contact-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .field.half{grid-column:span 1}
  .field{grid-column:span 1}
  .checkbox, .form-submit, .form-success{grid-column:span 1}
}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--bg-dark);color:#8a958c;
  padding:60px var(--gutter) 36px;
  font-size:13px;
}
.foot-grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;
  padding-bottom:36px;border-bottom:1px solid #2c3530;
}
.foot-grid h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#a8b3a9;margin:0 0 14px;font-weight:500}
.foot-grid a{display:block;color:#bcc7be;padding:4px 0;transition:color .15s}
.foot-grid a:hover{color:#e6ede6}
.foot-brand{font-family:var(--serif);font-size:24px;color:#e6ede6;margin-bottom:14px}
.foot-tagline{max-width:42ch;line-height:1.65;margin:0}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col li a{display:block;color:#bcc7be;padding:4px 0;transition:color .15s}
.foot-col li a:hover{color:#e6ede6}
.foot-bottom{
  max-width:var(--container);margin:0 auto;padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#6e7870;
}
@media (max-width:980px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr}}

/* ============================================
   REVEAL ON SCROLL
   ============================================ */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* Selection */
::selection{background:var(--moss);color:var(--paper-on-dark)}

/* Screen reader only */
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;
  width:1px;word-wrap:normal!important;
}

/* ============================================
   COOKIES BANNER — sjednocený vzhled
   pro nejčastější WP pluginy (Complianz,
   CookieYes, Cookie Notice & Compliance).
   ============================================ */

/* ---- Complianz ---- */
.cmplz-cookiebanner{
  font-family:var(--sans)!important;
  border-radius:var(--r-lg)!important;
  box-shadow:0 30px 70px -20px rgba(20,24,26,.35)!important;
  border:1px solid var(--line)!important;
  background:var(--bg)!important;
  color:var(--ink)!important;
}
.cmplz-cookiebanner .cmplz-title{
  font-family:var(--serif)!important;font-weight:500!important;
  color:var(--ink)!important;
}
.cmplz-cookiebanner .cmplz-message{
  color:var(--ink-2)!important;font-size:14px!important;line-height:1.6!important;
}
.cmplz-cookiebanner .cmplz-btn{
  border-radius:999px!important;
  font-family:var(--sans)!important;
  font-weight:500!important;font-size:14px!important;
  padding:11px 20px!important;
  border:1px solid var(--moss)!important;
  letter-spacing:.02em!important;
}
.cmplz-cookiebanner .cmplz-accept,
.cmplz-cookiebanner .cmplz-accept-all{
  background:var(--moss)!important;color:var(--paper-on-dark)!important;
}
.cmplz-cookiebanner .cmplz-deny,
.cmplz-cookiebanner .cmplz-save-preferences{
  background:transparent!important;color:var(--ink)!important;border-color:var(--ink)!important;
}
.cmplz-cookiebanner .cmplz-categories label{font-size:13px!important;color:var(--ink-2)!important}

/* ---- CookieYes ---- */
.cky-consent-container .cky-consent-bar{
  background:var(--bg)!important;border:1px solid var(--line)!important;
  border-radius:var(--r-lg)!important;
  color:var(--ink)!important;font-family:var(--sans)!important;
  box-shadow:0 30px 70px -20px rgba(20,24,26,.35)!important;
}
.cky-consent-container .cky-title{font-family:var(--serif)!important;color:var(--ink)!important}
.cky-consent-container .cky-notice-des,
.cky-consent-container .cky-notice-des p{color:var(--ink-2)!important;font-size:14px!important;line-height:1.6!important}
.cky-consent-container .cky-btn{
  border-radius:999px!important;padding:11px 20px!important;
  font-weight:500!important;font-size:14px!important;
}
.cky-consent-container .cky-btn-accept{background:var(--moss)!important;color:var(--paper-on-dark)!important;border:1px solid var(--moss)!important}
.cky-consent-container .cky-btn-reject{background:transparent!important;color:var(--ink)!important;border:1px solid var(--ink)!important}
.cky-consent-container .cky-btn-customize{background:transparent!important;color:var(--moss)!important;border:1px solid var(--moss)!important}

/* ---- Cookie Notice & Compliance (Hu-manity) ---- */
#cookie-notice{
  font-family:var(--sans)!important;
}
#cookie-notice .cookie-notice-container{
  background:var(--bg)!important;color:var(--ink-2)!important;
  border-top:1px solid var(--line)!important;
}
#cookie-notice .cn-button{
  border-radius:999px!important;padding:11px 20px!important;
  font-weight:500!important;font-size:14px!important;
  background:var(--moss)!important;color:var(--paper-on-dark)!important;
  border:1px solid var(--moss)!important;
}
#cookie-notice .cn-button.cn-button-custom{
  background:transparent!important;color:var(--ink)!important;border-color:var(--ink)!important;
}
