/*
Theme Name: Karino
Description: Rezervační web pro výcvik a výchovu psů.
Version: 1.0
Text Domain: karino
*/

:root{
  --dark:#1A100E; --dark-2:#2a1c16; --cream:#EBDBC8; --cream-2:#f6efe6;
  --brown:#8a6d4d; --gray:#bebebe; --line:#e6ddd2; --white:#fff;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family:'Inter',system-ui,-apple-system,sans-serif; color:var(--dark-2);
  background:var(--white); line-height:1.6; font-size:16px;
}
h1,h2,h3,h4{ font-family:'Raleway',sans-serif; color:var(--dark); line-height:1.18; margin:0 0 .5em; font-weight:700; }
a{ color:var(--brown); }
img{ max-width:100%; height:auto; }
.container{ max-width:1140px; margin:0 auto; padding:0 22px; }

/* Header */
.site-header{ position:sticky; top:0; z-index:100; background:var(--dark); color:var(--cream); }
.site-header .container{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.brand{ font-family:'Raleway',sans-serif; font-weight:800; font-size:26px; letter-spacing:.18em; color:var(--white); text-decoration:none; text-transform:uppercase; }
.brand span{ color:var(--cream); }
.main-nav{ display:flex; align-items:center; gap:8px; }
.main-nav a{ color:var(--cream); text-decoration:none; font-weight:600; font-size:15px; padding:8px 14px; border-radius:6px; transition:background .15s; }
.main-nav a:hover{ background:rgba(235,219,200,.14); }
.main-nav a.btn{ background:var(--cream); color:var(--dark); }
.main-nav a.btn:hover{ background:var(--white); }
.nav-toggle{ display:none; background:none; border:0; color:var(--cream); font-size:26px; cursor:pointer; }

/* Hero */
.hero{ background:linear-gradient(135deg,#1A100E 0%,#3a2418 100%); color:var(--cream); padding:96px 0; position:relative; overflow:hidden; }
.hero .eyebrow{ text-transform:uppercase; letter-spacing:.22em; font-size:13px; color:var(--cream); opacity:.75; margin-bottom:16px; }
.hero h1{ color:var(--white); font-size:clamp(34px,5vw,58px); max-width:16ch; margin-bottom:.4em; }
.hero p.lead{ font-size:19px; max-width:52ch; color:#e9ddcd; margin-bottom:30px; }
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }

/* Buttons */
.btn{ display:inline-block; background:var(--cream); color:var(--dark); padding:13px 26px; border-radius:8px; font-weight:700; text-decoration:none; border:2px solid var(--cream); transition:transform .1s, background .15s; cursor:pointer; }
.btn:hover{ transform:translateY(-2px); }
.btn-outline{ background:transparent; color:var(--cream); border-color:var(--cream); }
.btn-outline:hover{ background:var(--cream); color:var(--dark); }
.btn-dark{ background:var(--dark); color:var(--white); border-color:var(--dark); }

/* Sections */
section{ padding:72px 0; }
.section-head{ text-align:center; max-width:640px; margin:0 auto 48px; }
.section-head .eyebrow{ text-transform:uppercase; letter-spacing:.18em; font-size:13px; color:var(--brown); font-weight:700; margin-bottom:10px; }
.section-head h2{ font-size:clamp(28px,3.5vw,40px); }
.bg-cream{ background:var(--cream-2); }

/* Steps */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.step{ background:var(--white); border:1px solid var(--line); border-radius:14px; padding:32px 26px; text-align:center; }
.step .num{ width:52px; height:52px; border-radius:50%; background:var(--dark); color:var(--cream); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:22px; margin:0 auto 18px; font-family:'Raleway',sans-serif; }
.step h3{ font-size:20px; }

/* Calendar embed wrapper */
.cal-wrap{ background:var(--white); border:1px solid var(--line); border-radius:16px; padding:26px; box-shadow:0 10px 40px rgba(26,16,14,.06); }

/* Page content */
.page-wrap{ padding:56px 0 80px; }
.page-wrap h1.page-title{ text-align:center; margin-bottom:36px; font-size:clamp(28px,4vw,42px); }
.entry-content{ max-width:760px; margin:0 auto; }
.entry-content.entry-wide{ max-width:100%; }

/* Footer */
.site-footer{ background:var(--dark); color:var(--cream); padding:48px 0 28px; margin-top:60px; }
.site-footer .container{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; }
.site-footer .brand{ font-size:22px; }
.site-footer .muted{ opacity:.7; font-size:14px; }
.site-footer a{ color:var(--cream); }

@media (max-width:860px){
  .steps{ grid-template-columns:1fr; }
  .main-nav{ position:absolute; top:72px; left:0; right:0; background:var(--dark); flex-direction:column; align-items:stretch; padding:10px 22px 18px; gap:4px; display:none; }
  .main-nav.open{ display:flex; }
  .main-nav a{ padding:12px 14px; }
  .nav-toggle{ display:block; }
}
