/*
Theme Name: Drevobatys
Theme URI: https://drevobatys.sk
Author: Drevobatys
Description: Vlastná téma pre Drevobatys — drevovýroba dýhovaných dverí, požiarnych uzáverov a stolárskych výrobkov na mieru. Moderný jednostránkový dizajn s podporou produktov, prispôsobenia kontaktov a responzívnym rozložením.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.7
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: drevobatys
*/

:root{
  --ink:#211b14;
  --ink-soft:#3a3227;
  --paper:#f4f2ec;
  --card:#fbfaf6;
  --oak:#b0762f;
  --oak-deep:#8a5a20;
  --ember:#a4432b;
  --smoke:#6e655a;
  --line:#ddd6c9;
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{font-family:'Bricolage Grotesque','Inter',sans-serif}
a{color:inherit}
img{max-width:100%;height:auto}
:focus-visible{outline:3px solid var(--oak);outline-offset:3px;border-radius:4px}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

/* ---------- topbar + header ---------- */
.topbar{background:var(--ink);color:#e9e2d5;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;gap:16px;padding-top:7px;padding-bottom:7px;flex-wrap:wrap}
.topbar a{text-decoration:none;opacity:.9}
.topbar a:hover{opacity:1;color:#fff}
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(244,242,236,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding-top:14px;padding-bottom:14px;gap:16px}
.logo{display:flex;flex-direction:column;align-items:flex-start;gap:6px;text-decoration:none}
.logo .brand-text{display:flex;flex-direction:column}
.logo svg{flex:none}
.logo .logo-img{max-height:44px;width:auto}
.logo b{font-family:'Bricolage Grotesque';font-weight:700;font-size:1.25rem;letter-spacing:.01em;display:block}
.logo .tagline{display:block;font-size:.7rem;color:var(--smoke);letter-spacing:.14em;text-transform:uppercase;margin-left:2px}
nav.main ul{list-style:none;display:flex;gap:26px;align-items:center}
nav.main a{text-decoration:none;font-weight:500;font-size:.95rem;color:var(--ink-soft)}
nav.main a:hover{color:var(--oak-deep)}
nav.main .sub-menu{display:none}
.btn{
  display:inline-block;background:var(--ink);color:#f6f1e7;text-decoration:none;
  padding:12px 26px;border-radius:999px;font-weight:600;font-size:.95rem;
  border:1px solid var(--ink);cursor:pointer;transition:background .2s,color .2s;
}
.btn:hover{background:var(--oak-deep);border-color:var(--oak-deep);color:#fff}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#f6f1e7}
.menu-toggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:1rem;cursor:pointer}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero .grain{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.hero .wrap{position:relative;padding-top:96px;padding-bottom:104px;max-width:920px}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--oak-deep);font-weight:600;
  margin-bottom:22px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--oak);border-radius:2px}
.hero h1{font-size:clamp(2.4rem,5.6vw,4.3rem);font-weight:600;line-height:1.06;letter-spacing:-.015em;max-width:16ch}
.hero h1 em{font-style:normal;color:var(--oak-deep)}
.hero p.lead{margin:26px 0 36px;font-size:1.13rem;color:var(--ink-soft);max-width:56ch}
.hero .cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.hero .tel{font-family:'Bricolage Grotesque';font-weight:600;font-size:1.05rem;text-decoration:none;color:var(--ink)}
.hero .tel small{display:block;font-family:'Inter';font-weight:400;font-size:.75rem;color:var(--smoke)}
.hero-facts{display:flex;gap:34px;margin-top:56px;flex-wrap:wrap}
.hero-facts div b{font-family:'Bricolage Grotesque';font-size:1.5rem;font-weight:700;display:block;line-height:1.15}
.hero-facts div span{font-size:.84rem;color:var(--smoke)}

/* ---------- sections ---------- */
section.blk{padding:88px 0}
.sec-head{max-width:640px;margin-bottom:46px}
.sec-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:600;letter-spacing:-.01em;line-height:1.15}
.sec-head p{margin-top:14px;color:var(--smoke)}

/* ---------- produkcia: veneer strips ---------- */
.strips{display:flex;gap:10px;min-height:440px}
.strip{
  position:relative;flex:1;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:26px 22px;text-decoration:none;color:#f6f1e7;
  transition:flex .45s cubic-bezier(.4,0,.2,1);
  min-width:0;background:linear-gradient(160deg,#6d5433,#38291a);
}
.strip:hover,.strip:focus-visible{flex:2.4}
.strip .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.strip::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(23,17,10,.85) 0%,rgba(23,17,10,.2) 55%,rgba(23,17,10,.05) 80%)}
.strip h3{position:relative;z-index:2;font-size:1.12rem;font-weight:600;line-height:1.25;
  writing-mode:vertical-rl;transform:rotate(180deg);align-self:flex-start}
.strip p{position:relative;z-index:2;font-size:.85rem;opacity:0;max-height:0;overflow:hidden;transition:opacity .35s .1s;color:#e6ddcd}
.strip:hover h3,.strip:focus-visible h3{writing-mode:horizontal-tb;transform:none}
.strip:hover p,.strip:focus-visible p{opacity:1;max-height:140px;margin-top:8px}
.strip .badge{
  position:absolute;top:16px;left:16px;z-index:2;
  background:var(--ember);color:#fff;font-size:.68rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;padding:5px 10px;border-radius:999px;
}

/* ---------- povrchy ---------- */
.surface{background:var(--ink);color:#ece5d6}
.surface .sec-head h2{color:#f6f1e7}
.surface .sec-head p{color:#b9ae9c}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.panel{
  border:1px solid rgba(246,241,231,.14);
  border-radius:var(--radius);padding:34px 32px;background:rgba(246,241,231,.04);
}
.panel h3{font-size:1.35rem;font-weight:600;margin-bottom:12px;color:#f6f1e7}
.panel h3 span{color:var(--oak)}
.panel p{color:#c9bfae;font-size:.97rem}
.panel .chip-row{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.78rem;border:1px solid rgba(246,241,231,.25);padding:5px 12px;border-radius:999px;color:#e0d7c5}

/* ---------- proces ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;counter-increment:step}
.step::before{
  content:counter(step,decimal-leading-zero);
  font-family:'Bricolage Grotesque';font-weight:700;font-size:1rem;color:var(--oak-deep);
  display:inline-block;border-bottom:2px solid var(--oak);padding-bottom:6px;margin-bottom:14px;
}
.step h3{font-size:1.08rem;font-weight:600;margin-bottom:8px}
.step p{font-size:.9rem;color:var(--smoke)}

/* 6 krokov (šablóna „Ako pracujeme") — tri stĺpce v dvoch radoch */
.steps.steps-6{grid-template-columns:repeat(3,1fr)}

/* ---------- ďalšie výrobky ---------- */
.tags{display:flex;flex-wrap:wrap;gap:10px;max-width:820px}
.tags span{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:10px 20px;font-size:.95rem;font-weight:500}

/* ---------- galéria ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery-grid img{width:100%;height:260px;object-fit:cover;border-radius:var(--radius);display:block}

/* galéria dielne na tmavom pozadí (sekcia .surface) */
.dielna-grid{margin-top:8px}
.surface .gallery-grid img{border:1px solid rgba(246,241,231,.14)}

/* ---------- FooGallery ---------- */
/* tmavá sekcia dielne (Ako pracujeme) */
.dielna-foogallery{margin-top:8px}
.dielna-foogallery .fg-image,
.dielna-foogallery img{border-radius:var(--radius)}
.dielna-foogallery .fg-item{border-radius:var(--radius);overflow:hidden}
.surface .fg-caption-title,
.surface .fg-caption-desc{color:#ece5d6}
/* detail produktu (svetlé pozadie) */
.produkt-foogallery{margin-top:36px}
.produkt-foogallery .fg-image,
.produkt-foogallery img{border-radius:var(--radius)}
.produkt-foogallery .fg-item{border-radius:var(--radius);overflow:hidden}

/* ---------- kontakt ---------- */
.contact{background:var(--card);border-top:1px solid var(--line)}
.contact .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:start}
.contact h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:600;line-height:1.12;letter-spacing:-.01em}
.contact .grid>div:first-child p{margin-top:16px;color:var(--smoke);max-width:44ch}
.contact .cta{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}
.c-list{display:grid;gap:6px}
.c-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.c-item:last-child{border-bottom:none}
.c-item .k{flex:none;width:110px;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--smoke);padding-top:3px}
.c-item .v{font-weight:500}
.c-item .v a{text-decoration:none}
.c-item .v a:hover{color:var(--oak-deep)}
.c-item .v small{display:block;font-weight:400;color:var(--smoke)}

/* CTA sekcia na spodku vnútorných stránok */
.contact-cta{background:var(--card);border-top:1px solid var(--line)}

/* ---------- vnútorné stránky / články ---------- */
.page-hero{border-bottom:1px solid var(--line);background:var(--card)}
.page-hero .wrap{padding-top:64px;padding-bottom:54px;max-width:860px}
.page-hero h1{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:600;line-height:1.1;letter-spacing:-.01em}
.content-area .wrap{max-width:860px;padding-top:56px;padding-bottom:88px}
.entry-content p,.entry-content ul,.entry-content ol{margin-bottom:1.2em}
.entry-content ul,.entry-content ol{padding-left:1.4em}
.entry-content h2{font-size:1.6rem;margin:1.6em 0 .6em}
.entry-content h3{font-size:1.25rem;margin:1.4em 0 .5em}
.entry-content img{border-radius:var(--radius)}
.entry-content a{color:var(--oak-deep)}
.product-single .featured{margin-bottom:32px;text-align:center}
.product-single .featured img{
  width:auto;max-width:100%;
  max-height:480px;              /* strop výšky — uprav podľa chuti */
  border-radius:var(--radius);
}
.back-link{display:inline-block;margin-top:40px;text-decoration:none;font-weight:600;color:var(--oak-deep)}

/* ---------- footer ---------- */
footer.site-footer{background:var(--ink);color:#a89d8a;font-size:.88rem}
footer.site-footer .wrap{padding-top:48px;padding-bottom:24px}

.footer-top{
  display:grid;grid-template-columns:1.7fr 1fr 1.1fr;gap:40px;
  padding-bottom:28px;border-bottom:1px solid rgba(246,241,231,.12);
}
.footer-brand-name{
  font-family:'Bricolage Grotesque';font-weight:700;font-size:1.2rem;color:#f6f1e7;
  margin-bottom:10px;letter-spacing:.01em;
}
.footer-brand-desc{color:#a89d8a;max-width:42ch;line-height:1.55;font-size:.85rem}
.footer-social{margin-top:16px;display:flex;gap:12px}
.footer-social a{
  color:#d8cfbe;text-decoration:none;font-weight:600;font-size:.8rem;
  border:1px solid rgba(246,241,231,.2);border-radius:999px;padding:5px 14px;transition:.2s;
}
.footer-social a:hover{background:var(--oak-deep);border-color:var(--oak-deep);color:#fff}

.footer-col h4{
  font-family:'Bricolage Grotesque';font-size:.78rem;font-weight:600;color:#f6f1e7;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px;
}
.footer-col ul{list-style:none;display:grid;gap:8px}
.footer-col ul a{color:#c9bfae;text-decoration:none;transition:color .2s;font-size:.85rem}
.footer-col ul a:hover{color:var(--oak)}
.footer-contact-item{margin-bottom:9px;line-height:1.5;font-size:.85rem}
.footer-contact-item a{color:#c9bfae;text-decoration:none}
.footer-contact-item a:hover{color:var(--oak)}

.footer-bottom{
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;align-items:center;
  padding-top:18px;font-size:.8rem;color:#8a8072;
}
.footer-bottom a{color:#d8cfbe;text-decoration:none}
.footer-bottom a:hover{color:#fff}

@media (max-width:820px){
  .footer-top{grid-template-columns:1fr 1fr;gap:30px}
  .footer-brand{grid-column:1 / -1}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr;gap:26px}
  .footer-bottom{flex-direction:column;gap:6px;text-align:center}
}

/* ---------- kontaktný formulár ---------- */
.contact-form{margin-top:34px;display:grid;gap:16px;max-width:520px}
.contact-form .field{display:grid;gap:6px}
.contact-form label{font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:var(--smoke);font-weight:600}
.contact-form input,
.contact-form textarea{
  font-family:'Inter',sans-serif;font-size:1rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;width:100%;transition:border-color .2s;
}
.contact-form input:focus,
.contact-form textarea:focus{outline:none;border-color:var(--oak)}
.contact-form textarea{resize:vertical;min-height:120px}
.contact-form button{justify-self:start;border:none}
.contact-form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
#contact-response{font-size:.92rem;font-weight:500}
#contact-response.ok{color:#2f5127}
#contact-response.err{color:#7a2f1e}

/* ---------- stránka Kontakt ---------- */
.kontakt-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.kontakt-info .c-list{display:grid;gap:6px}
.kontakt-form h2{font-size:1.6rem;font-weight:600;letter-spacing:-.01em}

.db-form{display:grid;gap:18px;margin-top:4px}
.db-form .field{display:grid;gap:6px}
.db-form .field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.db-form label{font-size:.82rem;font-weight:600;color:var(--ink-soft);letter-spacing:.02em}
.db-form input,
.db-form textarea{
  width:100%;font-family:'Inter',system-ui,sans-serif;font-size:.98rem;
  color:var(--ink);background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;transition:border-color .2s;
}
.db-form input:focus,
.db-form textarea:focus{outline:none;border-color:var(--oak)}
.db-form textarea{resize:vertical;min-height:130px}
.db-form .btn{justify-self:start;border:none;margin-top:4px}

.form-note{border-radius:10px;padding:14px 16px;margin-bottom:20px;font-size:.94rem}
.form-note.ok{background:#e9f2e5;border:1px solid #bcd8ac;color:#2f5220}
.form-note.err{background:#f6e5e1;border:1px solid #e0b3a8;color:#7a2e1c}

.kontakt-map{margin-top:56px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);line-height:0}

/* ---------- archív produkcie (stránka Produkcia) ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prod-card{
  display:flex;flex-direction:column;text-decoration:none;color:var(--ink);
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s;
}
.prod-card:hover{transform:translateY(-4px);border-color:var(--oak);
  box-shadow:0 14px 30px -18px rgba(33,27,20,.5)}
.prod-thumb{position:relative;aspect-ratio:4/3;overflow:hidden;background:linear-gradient(160deg,#6d5433,#38291a)}
.prod-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.prod-fallback{position:absolute;inset:0;background:linear-gradient(160deg,#7c5b36,#38291a)}
.prod-thumb .badge{
  position:absolute;top:14px;left:14px;z-index:2;
  background:var(--ember);color:#fff;font-size:.68rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;padding:5px 10px;border-radius:999px;
}
.prod-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.prod-body h2{font-size:1.2rem;font-weight:600;line-height:1.25;margin-bottom:8px}
.prod-body p{font-size:.9rem;color:var(--smoke);margin-bottom:16px}
.prod-meta{margin-top:auto;font-size:.82rem;font-weight:600;color:var(--oak-deep)}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .strips{flex-direction:column;min-height:0}
  .strip{min-height:110px;flex:none;padding:20px 22px}
  .strip h3{writing-mode:horizontal-tb;transform:none}
  .strip p{opacity:1;max-height:none;margin-top:6px}
  .strip:hover{flex:none}
  .two-col,.contact .grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .steps.steps-6{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .kontakt-layout{grid-template-columns:1fr;gap:40px}
  .prod-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:700px){
  nav.main{display:none;position:absolute;top:100%;left:0;right:0;background:var(--paper);
    border-bottom:1px solid var(--line);padding:18px 24px}
  nav.main ul{flex-direction:column;align-items:flex-start;gap:16px}
  nav.main.open{display:block}
  .menu-toggle{display:block}
  header.site .btn{display:none}
  section.blk{padding:64px 0}
  .steps{grid-template-columns:1fr}
  .steps.steps-6{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .hero .wrap{padding-top:64px;padding-bottom:72px}
  .db-form .field-row{grid-template-columns:1fr}
}
@media (max-width:560px){
  .prod-grid{grid-template-columns:1fr}
}