/* =========================================================================
   CULTO — sdílený systém pro obsahové stránky (Studio, Pro architekty, Kolekce…).
   Scoped pod .cp-page. Site-wide enqueue.
   ========================================================================= */

/* skryj Blocksy page-title jen na stránkách s .cp-page (přes :has) */
body:has(.cp-page) .entry-header,
body:has(.cp-page) .page-header,
body:has(.cp-page) .ct-page-title { display: none !important; }

.cp-page {
  width: 100vw; max-width: var(--culto-shell);
  margin-left: calc(50% - min(50vw, calc(var(--culto-shell) / 2)));
  margin-right: calc(50% - min(50vw, calc(var(--culto-shell) / 2)));
  overflow-x: hidden;
  font-family: var(--font-sans);
  color: var(--foreground);
  background: var(--background);
}
.cp-page img { display: block; max-width: 100%; }
.cp-page em { font-style: normal; color: var(--accent); }

/* sekce */
.cp-sec { padding: 4rem 1.5rem; }
@media (min-width: 768px) { .cp-sec { padding: 5rem 2.5rem; } }
.cp-bordered { border-top: 2px solid #000; }
.cp-fullbleed img { width: 100%; height: auto; display: block; }

/* nadpisy */
.cp-h1 { font-family: var(--font-display); font-weight: 300; letter-spacing: -0.03em; line-height: 0.95; font-size: clamp(2.75rem, 8vw, 6rem); margin: 0; max-width: 18ch; }
.cp-h2 { font-family: var(--font-display); font-weight: 300; letter-spacing: -0.025em; line-height: 0.98; font-size: clamp(2.25rem, 6vw, 4.5rem); margin: 0 0 2.5rem; }

/* text */
.cp-lede-wrap { display: grid; grid-template-columns: 1fr; margin-top: 3rem; }
@media (min-width: 768px) { .cp-lede-wrap { grid-template-columns: repeat(12, 1fr); } }
.cp-lede { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.3rem, 2.2vw, 1.9rem); line-height: 1.35; color: var(--muted-foreground); }
@media (min-width: 768px) { .cp-lede { grid-column: 3 / 11; } }
.cp-lede > p { margin: 0 0 1.4rem; }
.cp-lede-strong { color: var(--foreground); }
.cp-lede2 { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.2rem, 1.8vw, 1.6rem); line-height: 1.35; color: var(--muted-foreground); margin: 0 0 2rem; }
.cp-prose { color: var(--muted-foreground); line-height: 1.7; margin: 0 0 1rem; max-width: 42rem; }

/* 2-sloupcové sekce */
.cp-two { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: start; }
@media (min-width: 768px) {
  .cp-two { gap: 4rem; align-items: center; }
  .cp-two-7-5 { grid-template-columns: 7fr 5fr; }
  .cp-two-5-7 { grid-template-columns: 5fr 7fr; }
}
.cp-media img, .cp-media video { width: 100%; height: auto; object-fit: contain; display: block; }
.cp-media-tall img { aspect-ratio: 4 / 5; object-fit: cover; }

/* rule block */
.cp-rule-block { border-top: 1px solid var(--foreground); padding-top: 1.5rem; }
.cp-rb-title { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.5rem, 2.5vw, 2rem); line-height: 1.1; margin-bottom: 1rem; }

/* zakladatelé */
.cp-founders { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
@media (min-width: 768px) { .cp-founders { grid-template-columns: 1fr 1fr; gap: 4rem; } }
.cp-founder { border-top: 1px solid var(--foreground); padding-top: 2rem; }
.cp-founder-photo { width: 35%; aspect-ratio: 4 / 5; overflow: hidden; margin-bottom: 1.5rem; }
.cp-founder-photo img { width: 100%; height: 100%; object-fit: cover; }
.cp-founder-name { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.75rem, 3vw, 2.25rem); }
.cp-founder-role { font-family: var(--font-mono); font-size: 0.78rem; color: var(--muted-foreground); margin-top: 0.5rem; }
.cp-q { border-left: 2px solid var(--accent-text); padding-left: 1rem; margin: 1.5rem 0 0; font-style: normal; color: var(--accent-text); line-height: 1.5; }

/* principy */
.cp-principles { display: grid; grid-template-columns: 1fr; gap: 1.5rem 4rem; }
@media (min-width: 768px) { .cp-principles { grid-template-columns: 1fr 1fr; } }
.cp-principle { border-top: 1px solid var(--foreground); padding-top: 1.5rem; }
.cp-principle-img { margin-bottom: 1.25rem; }
.cp-principle-img img { width: 100%; height: auto; max-height: 13rem; object-fit: contain; object-position: left center; display: block; }
.cp-p-title { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.4rem, 2vw, 1.85rem); margin-bottom: 0.75rem; }

/* ocenění řada */
.cp-awards-row { display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: center; }
@media (min-width: 768px) { .cp-awards-row { grid-template-columns: 3fr 9fr; } }
.cp-awards-label { font-family: var(--font-mono); font-size: 0.85rem; color: var(--muted-foreground); }
.cp-awards-imgs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2.5rem; align-items: center; }
@media (min-width: 768px) { .cp-awards-imgs { grid-template-columns: repeat(4, 1fr); } }
.cp-awards-imgs img { max-height: 4rem; width: auto; object-fit: contain; opacity: 0.75; filter: grayscale(1); transition: opacity .3s, filter .3s; justify-self: center; }
.cp-awards-imgs img:hover { opacity: 1; filter: grayscale(0); }

/* ===== Reusable blok ocenění (shortcode [culto_awards]) — homepage i /studio z 1 zdroje ===== */
.culto-awards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem 2.5rem; align-items: center; width: 100%; }
@media (min-width: 768px) { .culto-awards { grid-template-columns: repeat(4, 1fr); } }
.culto-award { display: flex; align-items: center; justify-content: center; padding: 0.5rem; }
.culto-award img { width: auto; max-width: 100%; height: 4.5rem; object-fit: contain; opacity: 0.75; filter: grayscale(1); transition: opacity .3s, filter .3s; }
.culto-award img:hover { opacity: 1; filter: grayscale(0); }
@media (min-width: 768px) { .culto-award img { height: 6rem; } }
/* awards jako Synced Pattern (wp:gallery class culto-awards) — vyplní buňku, grayscale */
.wp-block-gallery.culto-awards { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem 2.5rem; align-items: center; }
@media (min-width: 768px) { .wp-block-gallery.culto-awards { grid-template-columns: repeat(4, 1fr); } }
.wp-block-gallery.culto-awards .wp-block-image { width: 100% !important; margin: 0 !important; }
.wp-block-gallery.culto-awards img,
.wp-block-gallery.culto-awards figure.wp-block-image img { width: 100% !important; height: auto !important; max-height: 5rem !important; object-fit: contain !important; opacity: 0.75; filter: grayscale(1); transition: opacity .3s, filter .3s; }
.wp-block-gallery.culto-awards img:hover { opacity: 1 !important; filter: grayscale(0) !important; }
@media (min-width: 768px) { .wp-block-gallery.culto-awards img, .wp-block-gallery.culto-awards figure.wp-block-image img { max-height: 6rem !important; } }

/* velký citát + CTA */
.cp-quote2 .cp-bigquote, .cp-bigquote { font-family: var(--font-display); font-weight: 300; line-height: 1.05; letter-spacing: -0.02em; font-size: clamp(1.75rem, 5vw, 3.75rem); max-width: 55rem; margin: 0; }
.cp-bigquote footer { font-family: var(--font-mono); color: var(--muted-foreground); font-size: 0.85rem; letter-spacing: 0.1em; margin-top: 2.5rem; font-style: normal; }
.cp-cta-row { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 3rem; }

/* tlačítka (site-wide) */
.cult-btn-solid { display: inline-flex; align-items: center; gap: 0.6rem; background: var(--foreground); color: var(--background); padding: 1rem 2rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.8rem; text-decoration: none; transition: background .2s, color .2s; }
.cult-btn-solid:hover { background: var(--accent); color: var(--foreground); }
.cult-btn-outline { display: inline-flex; align-items: center; gap: 0.6rem; border: 1px solid var(--foreground); color: var(--foreground); padding: 1rem 2rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.8rem; text-decoration: none; transition: color .2s, border-color .2s; }
.cult-btn-outline:hover { color: var(--accent); border-color: var(--accent); }

/* ===== Studio — hero „Brand Story" ===== */
/* nadpis na 2 řádky: zrušit úzkou 18ch míru (kvůli ní se `<em>` 2. řádek lámal); shell 1680px má dost místa, `<br>` drží zlom. + odsazení nadpisu od textu. */
.cp-studio .cp-hero .cp-h1 { max-width: none; margin-bottom: 2.5rem; }

/* ===== Kolekce — editorial výpis ===== */
.ck-list-wrap { padding: 0 1.5rem 6rem; }
@media (min-width: 768px) { .ck-list-wrap { padding: 0 2.5rem 8rem; } }
/* cik-cak (alternující) výpis */
.ck-list { display: flex; flex-direction: column; }
.ck-row { display: grid; grid-template-columns: 1fr; gap: 1.5rem; padding: 3rem 0; border-top: 1px solid var(--border); align-items: center; }
.ck-row:first-child { border-top: 0; }
@media (min-width: 768px) {
  .ck-row { grid-template-columns: 1fr 1fr; gap: 4rem; padding: 4rem 0; }
  .ck-row--even .ck-photo { order: 2; } /* sudý index → foto vpravo */
}
.ck-photo { display: block; overflow: hidden; background: var(--muted); }
.ck-photo img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; display: block; transition: transform .7s; }
.ck-row:hover .ck-photo img { transform: scale(1.03); }
.ck-text { display: flex; flex-direction: column; align-items: flex-start; }
.ck-index { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; color: var(--muted-foreground); margin-bottom: 0.75rem; }
.ck-name { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.8rem, 3vw, 2.75rem); line-height: 1.05; margin: 0 0 1rem; }
.ck-name a { color: var(--foreground); text-decoration: none; }
.ck-name a:hover { color: var(--accent); }
.ck-meta { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.06em; color: var(--muted-foreground); margin-bottom: 0.75rem; }
.ck-priceline { font-family: var(--font-display); font-weight: 300; font-size: 1.5rem; margin-bottom: 1.5rem; }
.ck-priceline .ck-status { font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.04em; color: var(--accent); }
.ck-desc { color: var(--muted-foreground); line-height: 1.6; margin: 0 0 1.5rem; max-width: 40rem; }
.ck-edition { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; color: var(--muted-foreground); margin-bottom: 1.5rem; }
.ck-cta { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.ck-btn-primary { display: inline-flex; align-items: center; background: var(--ink); color: var(--paper); padding: 0.95rem 1.75rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.75rem; text-decoration: none; transition: background .2s, color .2s; }
.ck-btn-primary:hover { background: var(--accent); color: var(--ink); }
.ck-btn-secondary { display: inline-flex; align-items: center; border: 1px solid var(--foreground); color: var(--foreground); padding: 0.95rem 1.75rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.75rem; text-decoration: none; transition: color .2s, border-color .2s; }
.ck-btn-secondary:hover { color: var(--accent); border-color: var(--accent); }

/* break-out „Systém" mezi produkty (full-width v rámci shellu, text na střed) */
.ck-breakout { text-align: center; border-top: 1px solid var(--border); padding: 5rem 0; }
@media (min-width: 768px) { .ck-breakout { padding: 7rem 0; } }
.ck-breakout-inner { max-width: 50rem; margin: 0 auto; }
.ck-breakout-h2 { font-family: var(--font-display); font-weight: 300; line-height: 1.05; letter-spacing: -0.02em; font-size: clamp(2rem, 5vw, 3.5rem); margin: 0 0 1.75rem; }
.ck-breakout-h2 .text-accent { color: var(--accent); font-style: normal; }
.ck-breakout-perex { color: var(--muted-foreground); line-height: 1.7; font-size: clamp(1rem, 1.4vw, 1.15rem); margin: 0 0 1.5rem; }
.ck-breakout-manifest { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.2rem, 2vw, 1.6rem); line-height: 1.3; margin: 0; }

/* ===== Pro architekty ===== */
.ca-muted { background: var(--background); }
.ca-head { max-width: 56rem; margin-bottom: 3rem; }
.ca-head .cp-h2 { margin-bottom: 1.25rem; }

/* hero */
.ca-hero { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: end; }
@media (min-width: 768px) { .ca-hero { grid-template-columns: 7fr 5fr; gap: 4rem; } }
.ca-hero-meta { display: flex; flex-wrap: wrap; gap: 0.4rem 1rem; margin-top: 1.5rem; font-family: var(--font-mono); font-size: 0.75rem; color: var(--muted-foreground); }
.ca-hero-meta strong { color: var(--accent); font-weight: 400; }
.ca-hero-meta .ca-dot { opacity: 0.4; }
.ca-hero-cta { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 2rem; }
.ca-hero-img { aspect-ratio: 4 / 5; overflow: hidden; background: var(--muted); }
.ca-hero-img img { width: 100%; height: 100%; object-fit: cover; }
.ca-hero-fig figcaption { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.18em; color: var(--muted-foreground); margin-top: 0.75rem; }

/* Pro architekty — full-bleed hero (obraz přes celou šířku + glass panel, jako homepage) */
.ca-hero-full { padding: 1.5rem; }
@media (min-width: 768px) { .ca-hero-full { padding: 1.5rem 2.5rem; } }
.ca-hero-full .ca-hero-plate { position: relative; }
.ca-hero-media { width: 100%; height: 72vh; object-fit: cover; display: block; }
.ca-hero-full .ca-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, color-mix(in oklab, var(--ink) 72%, transparent), color-mix(in oklab, var(--ink) 18%, transparent) 45%, transparent); }
.ca-hero-full .ca-hero-content { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: flex-end; gap: 2rem; padding: 1.5rem; }
@media (min-width: 768px) { .ca-hero-full .ca-hero-content { padding: 3rem; } }
.ca-hero-title { font-family: var(--font-display); font-weight: 300; color: var(--paper); line-height: 0.9; letter-spacing: -0.03em; font-size: clamp(2.25rem, 6.5vw, 5rem); margin: 0; max-width: 18ch; text-shadow: 0 2px 28px rgba(0,0,0,0.5); }
.ca-hero-title em { color: var(--accent); font-style: normal; }
.ca-hero-panel { align-self: flex-start; max-width: 52rem; display: flex; flex-direction: column; gap: 1.1rem; padding: 1.5rem 1.75rem; background: color-mix(in oklab, var(--ink) 30%, transparent); -webkit-backdrop-filter: blur(12px) saturate(130%); backdrop-filter: blur(12px) saturate(130%); border: 1px solid color-mix(in oklab, var(--paper) 22%, transparent); }
.ca-hero-sub { font-family: var(--font-display); font-weight: 300; color: var(--paper); font-size: clamp(1rem, 1.5vw, 1.3rem); line-height: 1.4; margin: 0; }
.ca-hero-full .ca-hero-meta { color: color-mix(in oklab, var(--paper) 85%, transparent); }
.ca-hero-full .ca-hero-meta strong { color: var(--accent); }
.ca-hero-full .ca-hero-meta .ca-dot { opacity: 0.5; }
.ca-hero-panel .cult-btn-solid { background: var(--paper); color: var(--ink); }
.ca-hero-panel .cult-btn-solid:hover { background: var(--accent); color: var(--ink); }
.ca-hero-panel .cult-btn-outline { border-color: color-mix(in oklab, var(--paper) 55%, transparent); color: var(--paper); }
.ca-hero-panel .cult-btn-outline:hover { color: var(--accent); border-color: var(--accent); }

/* princip — dlaždice */
.ca-tiles { display: grid; grid-template-columns: 1fr; gap: 1px; background: var(--border); }
@media (min-width: 768px) { .ca-tiles { grid-template-columns: repeat(3, 1fr); } }
.ca-tile { background: var(--background); padding: 2.5rem; }
.ca-tile-top { display: flex; align-items: center; justify-content: space-between; color: var(--accent); margin-bottom: 1.5rem; }
.ca-tile-top svg { width: 2.5rem; height: 2.5rem; }
.ca-tile-n { font-family: var(--font-mono); font-size: 0.75rem; }
.ca-tile-t { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.5rem, 2.5vw, 2rem); margin-bottom: 1rem; line-height: 1.1; }

/* specs dl */
.ca-specs { display: grid; grid-template-columns: 1fr; gap: 1.25rem 1.5rem; margin-top: 2rem; }
@media (min-width: 600px) { .ca-specs { grid-template-columns: 1fr 1fr; } }
.ca-specs > div { border-top: 1px solid var(--border); padding-top: 0.5rem; }
.ca-specs dt { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-foreground); margin-bottom: 0.25rem; }
.ca-specs dd { font-family: var(--font-display); margin: 0; }

/* platformy */
.ca-platf { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; align-items: end; }
.ca-platf figure { margin: 0; display: flex; flex-direction: column; align-items: center; }
.ca-platf-w { font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted-foreground); border-top: 1px solid color-mix(in oklab, var(--foreground) 60%, transparent); padding: 0.5rem 0.75rem 0; margin-bottom: 0.75rem; }
.ca-platf img { width: 100%; height: auto; object-fit: contain; }
.ca-platf figcaption { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; color: var(--muted-foreground); margin-top: 0.75rem; text-align: center; }

/* barvy — vzorník */
.ca-colors { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--border); }
@media (min-width: 600px) { .ca-colors { grid-template-columns: repeat(3, 1fr); } }
.ca-swatch { background: var(--background); }
.ca-swatch > span { display: block; aspect-ratio: 1 / 1; }
.ca-swatch > img { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
.ca-swatch > div { padding: 1rem; }
.ca-swatch b { font-family: var(--font-display); font-weight: 300; font-size: 1.1rem; display: block; }
.ca-swatch i { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted-foreground); font-style: normal; display: block; margin-top: 0.2rem; }
.ca-swatch small { font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.16em; color: var(--muted-foreground); display: block; margin-top: 0.4rem; }

/* proces */
.ca-steps { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 640px) { .ca-steps { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .ca-steps { grid-template-columns: repeat(4, 1fr); } }
.ca-step-img { aspect-ratio: 4 / 3; display: flex; align-items: end; justify-content: center; overflow: hidden; margin-bottom: 1.5rem; }
.ca-step-img img { width: 100%; height: 100%; object-fit: contain; }
.ca-step-h { display: flex; align-items: baseline; justify-content: space-between; border-top: 1px solid var(--foreground); padding-top: 1rem; }
.ca-step-n { font-family: var(--font-display); font-weight: 300; font-size: clamp(2.5rem, 5vw, 3.5rem); line-height: 1; }
.ca-step-time { font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted-foreground); }
.ca-step-t { font-family: var(--font-display); font-size: 1.4rem; margin: 0.75rem 0; }

/* ke stažení */
.ca-dl { position: relative; display: grid; grid-template-columns: 1fr; gap: 2rem; background: var(--background); border: 1px solid var(--border); padding: 1.5rem; align-items: center; }
.ca-dl-ribbon { position: absolute; top: 1rem; right: 1rem; z-index: 2; background: var(--ink, #1a1a1a); color: var(--paper, #f7f4ef); font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.18em; text-transform: uppercase; padding: 0.4rem 0.75rem; border-radius: 999px; }
@media (min-width: 768px) { .ca-dl { grid-template-columns: 7fr 5fr; padding: 2.5rem; } }
.ca-dl-label { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.18em; color: var(--muted-foreground); margin-bottom: 1rem; }
.ca-dl-title { font-family: var(--font-display); font-weight: 300; font-size: clamp(1.75rem, 3vw, 2.5rem); line-height: 1.05; margin-bottom: 1rem; }
.ca-formats { display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem; margin: 1rem 0 1.5rem; }
.ca-formats span { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.1em; padding: 0.25rem 0.5rem; border: 1px solid var(--foreground); }
.ca-formats em { font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.12em; color: var(--muted-foreground); font-style: normal; margin-left: 0.5rem; }
.ca-dl-img { aspect-ratio: 4 / 3; background: color-mix(in oklab, var(--secondary, var(--muted)) 60%, var(--paper)); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.ca-dl-img img { width: 100%; height: 100%; object-fit: contain; mix-blend-mode: multiply; }
.ca-dl-meta { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.18em; color: var(--muted-foreground); margin-top: 1.5rem; }

/* ===== Revize II — Fáze C (Pro architekty) ===== */
/* Barva — větší text vlevo; blok přepnut na 7-5 (užší vzorník vpravo = menší fota) */
#barvy .cp-prose { font-size: clamp(1.1rem, 1.7vw, 1.45rem); line-height: 1.55; }
/* Pro vaše úpravy — výrazná typografie titulku + čistý bílý rám náhledu */
#ke-stazeni .ca-dl-title { font-size: clamp(2.25rem, 4.5vw, 3.5rem); line-height: 1.02; }
.ca-dl-img { background: var(--background); }
.ca-dl-img img { mix-blend-mode: normal; }

/* ===== Revize II — Fáze D (Kontakt, page 39) ===== */
/* pryč theme page-title „Kontakt" nad hero */
body.page-id-39 .ct-page-title,
body.page-id-39 .entry-header,
body.page-id-39 .page-header { display: none !important; }
/* hero nadpis — stejný font jako zbytek webu, responsivní (max 2 řádky, bez přetékání) */
.culto-kontakt-h1 { font-family: var(--font-display); font-weight: 300; letter-spacing: -0.03em; line-height: 1; font-size: clamp(2.5rem, 6vw, 4.5rem); margin: 0 0 2rem; max-width: 16ch; }

/* Revize II — textové akcenty sytější rose na bílé. Hero přes video (ca-hero-title) zůstává --oldrose (na tmavém). */
.cp-page em { color: var(--accent-text); }
.ca-hero-title em { color: var(--accent); }
.ca-tile-top { color: var(--accent-text); }
.ca-link:hover { color: var(--accent-text); border-color: var(--accent-text); }
.ck-breakout-h2 .text-accent { color: var(--accent-text); }
.cp-q { border-left-color: var(--accent-text); }

/* ===== Revize II — mobil (P1) ===== */
/* sticky header: na mobilu plné neprůhledné pozadí (velký text neprosvítá); desktop ponechán glass */
@media (max-width: 767px) {
  #header.ct-header { background: var(--paper); -webkit-backdrop-filter: none; backdrop-filter: none; }
}
/* obsah neskončí pod sticky headerem při kotvení na #anchor */
.ch-sec, .cp-sec, .ch-system, .ch-arch, .ch-ig, .ch-news, .ch-hero-lead { scroll-margin-top: 5rem; }

/* ===== Revize II — P2/Global ===== */
/* Loga (ocenění/social proof) — jednotná optická výška, centrovat (fix nestejných velikostí) */
.wp-block-gallery.culto-awards figure.wp-block-image { display: flex !important; align-items: center; justify-content: center; }
.wp-block-gallery.culto-awards img,
.wp-block-gallery.culto-awards figure.wp-block-image img { width: auto !important; max-width: 100% !important; height: auto !important; max-height: 3.25rem !important; object-fit: contain !important; }
@media (min-width: 768px) { .wp-block-gallery.culto-awards img, .wp-block-gallery.culto-awards figure.wp-block-image img { max-height: 4rem !important; } }
/* Tap target ≥44px — footer social ikony (byly 36px) */
.cf-social a { width: 2.75rem; height: 2.75rem; }

/* realizace */
.ca-real-head { display: flex; flex-wrap: wrap; align-items: end; justify-content: space-between; gap: 1rem; margin-bottom: 3rem; }
.ca-real-head .cp-h2 { margin: 0; }
.ca-real { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 768px) { .ca-real { grid-template-columns: repeat(3, 1fr); } }
.ca-real figure { margin: 0; }
.ca-real-img { aspect-ratio: 4 / 5; overflow: hidden; background: var(--muted); }
.ca-insp .ca-real-img { aspect-ratio: 4 / 3; }
.ca-real-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .7s; }
.ca-real figure:hover .ca-real-img img { transform: scale(1.02); }
.ca-real figcaption { display: flex; justify-content: space-between; gap: 1rem; font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted-foreground); margin-top: 0.75rem; }
.ca-real-link { display: block; }
.ca-real-more { margin-top: 2.5rem; text-align: center; }

/* dílna */
.ca-shop-img { aspect-ratio: 4 / 3; overflow: hidden; background: var(--muted); }
.ca-shop-img img { width: 100%; height: 100%; object-fit: cover; }
.ca-shop-map { aspect-ratio: 4 / 3; overflow: hidden; background: var(--muted); }
.ca-shop-map iframe { width: 100%; height: 100%; border: 0; display: block; }
.ca-addr { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 2rem 0; }
.ca-addr > div { border-top: 1px solid var(--border); padding-top: 0.5rem; }
.ca-addr dt { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.18em; color: var(--muted-foreground); margin-bottom: 0.4rem; }
.ca-addr dd { font-family: var(--font-display); margin: 0; line-height: 1.2; }

/* kontakt */
.ca-person { display: flex; align-items: flex-start; gap: 1.25rem; margin-top: 2.5rem; }
.ca-person-photo { width: 5rem; height: 5rem; border-radius: 9999px; overflow: hidden; background: var(--muted); flex-shrink: 0; }
.ca-person-photo img { width: 100%; height: 100%; object-fit: cover; }
.ca-person-name { font-family: var(--font-display); font-size: 1.2rem; }
.ca-person-role { font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted-foreground); margin-bottom: 0.5rem; }
.ca-link { display: block; font-family: var(--font-mono); font-size: 0.75rem; color: var(--foreground); border-bottom: 1px solid var(--foreground); width: fit-content; text-decoration: none; margin-top: 0.25rem; }
.ca-link:hover { color: var(--accent); border-color: var(--accent); }
.ca-note { font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted-foreground); margin-top: 2rem; }

/* B2B formulář */
.ca-form { background: var(--background); border: 1px solid var(--border); padding: 2rem; display: flex; flex-direction: column; gap: 1.25rem; }
.ca-form-row { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 600px) { .ca-form-row { grid-template-columns: 1fr 1fr; } }
.ca-form label { display: block; }
.ca-form label > span { display: block; font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted-foreground); margin-bottom: 0.5rem; }
.ca-checks { display: grid; grid-template-columns: 1fr; gap: 0.5rem; font-family: var(--font-mono); font-size: 0.8rem; }
@media (min-width: 600px) { .ca-checks { grid-template-columns: 1fr 1fr; } }
.ca-checks label { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; }
.ca-checks-label { display: block; font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted-foreground); margin-bottom: 0.5rem; }
.ca-form button { width: 100%; background: var(--accent); color: var(--foreground); border: 0; padding: 1rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.8rem; cursor: pointer; transition: background .2s, color .2s; }
.ca-form button:hover { background: var(--foreground); color: var(--background); }
.ca-form-note { font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.16em; color: var(--muted-foreground); text-align: center; }
.ca-form-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.ca-form-ok { background: var(--background); border: 1px solid var(--border); padding: 2rem; }
.ca-form-ok h3 { font-family: var(--font-display); font-weight: 300; font-size: 1.8rem; margin: 0 0 1rem; }

/* ===== WPForms „Pro architekty" — brand styl (scoped na .ca-form-wrap).
   !important přebíjí ID-scoped (#wpforms-ID) + inline theme styly WPForms. ===== */
.ca-form-wrap .wpforms-container { margin: 0 !important; }
.ca-form-wrap .wpforms-form { background: var(--background); border: 1px solid var(--border); padding: 2rem; }
.ca-form-wrap .wpforms-field-container { display: flex; flex-direction: column; gap: 1.25rem; }
.ca-form-wrap .wpforms-field { padding: 0 !important; margin: 0 !important; }
.ca-form-wrap .wpforms-field-label {
  display: block; font-family: var(--font-mono) !important; font-size: 0.72rem !important; font-weight: 400 !important;
  color: var(--muted-foreground) !important; margin: 0 0 0.45rem !important; line-height: 1.3; text-transform: none;
}
.ca-form-wrap .wpforms-required-label { color: var(--terracota) !important; }
.ca-form-wrap input[type="text"],
.ca-form-wrap input[type="email"],
.ca-form-wrap input.wpforms-field-medium,
.ca-form-wrap input.wpforms-field-large,
.ca-form-wrap textarea {
  width: 100% !important; max-width: 100% !important; background: transparent !important; border: 0 !important;
  border-bottom: 1px solid var(--border) !important; border-radius: 0 !important; padding: 0.5rem 0 !important;
  color: var(--foreground) !important; font-family: var(--font-mono) !important; font-size: 0.8rem !important; box-shadow: none !important;
}
.ca-form-wrap input:focus,
.ca-form-wrap textarea:focus { border-bottom-color: var(--foreground) !important; outline: none !important; box-shadow: none !important; }
.ca-form-wrap textarea { min-height: 7rem !important; resize: vertical; }
.ca-form-wrap .wpforms-field-checkbox ul { display: grid !important; grid-template-columns: 1fr; gap: 0.5rem 1.5rem; list-style: none; margin: 0; padding: 0; }
@media (min-width: 600px) { .ca-form-wrap .wpforms-field-checkbox ul { grid-template-columns: 1fr 1fr; } }
.ca-form-wrap .wpforms-field-checkbox li { font-family: var(--font-mono); font-size: 0.78rem; color: var(--foreground); display: flex; align-items: flex-start; gap: 0.5rem; margin: 0 !important; }
.ca-form-wrap .wpforms-field-label-inline { font-weight: 400 !important; color: inherit !important; }
.ca-form-wrap .wpforms-field.culto-gdpr .wpforms-field-checkbox ul { grid-template-columns: 1fr; }
.ca-form-wrap .wpforms-field.culto-gdpr li { font-size: 0.68rem; color: var(--muted-foreground); }
.ca-form-wrap .wpforms-submit-container { margin-top: 1.5rem !important; }
.ca-form-wrap button.wpforms-submit {
  width: 100%; background: var(--ink) !important; color: #fff !important; border: 0 !important; border-radius: 0 !important;
  padding: 1.1rem !important; font-family: var(--font-mono) !important; text-transform: uppercase; letter-spacing: 0.08em;
  font-size: 0.8rem !important; cursor: pointer; box-shadow: none !important; transition: background .2s, color .2s;
}
.ca-form-wrap button.wpforms-submit:hover { background: var(--terracota) !important; color: #fff !important; }

/* ===== CULTO patička (nahrazuje Blocksy footer) ===== */
#footer.ct-footer { display: none !important; }
.culto-footer { background: var(--background); color: var(--foreground); border-top: 1px solid var(--border); margin: 4rem auto 0; max-width: var(--culto-shell); font-family: var(--font-mono); }

/* Hlavička Blocksy: editorial šířka + STICKY s glass efektem (backdrop-blur). */
#header { --theme-normal-container-max-width: var(--culto-shell); }
#header.ct-header {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in oklab, var(--paper) 72%, transparent);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid color-mix(in oklab, var(--border) 65%, transparent);
}
/* vnitřní řádky průhledné, ať prosvítá glass blur */
#header.ct-header [data-row] { background: transparent !important; }

/* Footer tlačítka — zaručit kontrast v ne-hover stavu (přebíjí dědičnost z .cf-col a) */
.culto-footer .cf-news-btn { background: var(--ink); color: var(--paper); }
.culto-footer .cf-social a { background: var(--ink); color: var(--paper); }
.culto-footer .cf-social a:hover { background: var(--accent); color: var(--ink); }

/* Náhrada Blocksy syté modré (palette-1 + odkazy) teplým akcentem — obecně na webu */
body {
  --theme-palette-color-1: var(--terracota);
  --theme-link-initial-color: var(--terracota);
  --theme-link-hover-color: var(--ink);
  --theme-link-active-color: var(--terracota);
}
.entry-content blockquote, .culto-home blockquote, .cp-page blockquote { border-inline-start-color: var(--terracota); }
.cf-news { background: var(--accent); color: var(--foreground); border-bottom: 1px solid var(--border); display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.5rem; }
@media (min-width: 768px) { .cf-news { padding: 1.5rem 2.5rem; } }
.cf-news-text { font-size: 0.85rem; max-width: 48rem; }
.cf-news-btn { background: var(--foreground); color: var(--background); padding: 0.75rem 1.5rem; text-decoration: none; text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.72rem; white-space: nowrap; transition: opacity .2s; }
.cf-news-btn:hover { opacity: 0.85; }
.cf-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem 1.5rem; padding: 3rem 1.5rem; }
@media (min-width: 768px) { .cf-cols { grid-template-columns: repeat(4, 1fr); padding: 3rem 2.5rem; } }
.cf-col { display: flex; flex-direction: column; gap: 0.6rem; font-size: 0.8rem; }
.cf-col a { color: var(--foreground); text-decoration: none; }
.cf-col a:hover { color: var(--accent); }
/* Footer nav = WP „Footer" menu, položky do 2 sloupců (editovatelné v administraci) */
.cf-menu-wrap { grid-column: span 2; }
.cf-menu { list-style: none; margin: 0; padding: 0; columns: 2; column-gap: 1.5rem; }
.cf-menu li { margin-bottom: 0.6rem; break-inside: avoid; }
.cf-menu a { color: var(--foreground); text-decoration: none; font-size: 0.8rem; }
.cf-menu a:hover { color: var(--accent); }
.cf-col-h { color: var(--foreground); }
.cf-col a[href^="tel:"], .cf-col a[href^="mailto:"] { color: var(--muted-foreground); }
.cf-social { display: flex; gap: 0.75rem; }
.cf-social a { width: 2.25rem; height: 2.25rem; display: flex; align-items: center; justify-content: center; background: var(--foreground); color: var(--background); text-decoration: none; transition: background .2s, color .2s; }
.cf-social a:hover { background: var(--accent); color: var(--foreground); }
.cf-bar { display: grid; grid-template-columns: 1fr; gap: 0.5rem; padding: 1.5rem; border-top: 1px solid var(--border); color: var(--muted-foreground); font-size: 0.75rem; }
@media (min-width: 768px) { .cf-bar { grid-template-columns: 1fr 1fr; padding: 1.5rem 2.5rem; } .cf-bar div:last-child { text-align: right; } }

/* ===== FAQ stránka — nativní core/details bloky ===== */
.cp-page details.wp-block-details { border-top: 1px solid var(--border); padding: 1.5rem 0; }
.cp-page details.wp-block-details summary { display: flex; align-items: center; justify-content: space-between; gap: 1rem; cursor: pointer; list-style: none; font-family: var(--font-display); font-weight: 300; font-size: clamp(1.25rem, 2vw, 1.6rem); }
.cp-page details.wp-block-details summary::-webkit-details-marker { display: none; }
.cp-page details.wp-block-details summary::marker { content: ""; }
.cp-page details.wp-block-details summary::after { content: "+"; font-family: var(--font-mono); color: var(--accent); display: inline-block; transition: transform .2s; }
.cp-page details.wp-block-details[open] summary::after { transform: rotate(45deg); }
.cp-page details.wp-block-details p { color: var(--muted-foreground); line-height: 1.6; max-width: 44rem; margin: 1rem 0 0; }
.cp-faq-more { border-top: 1px solid var(--border); padding-top: 2rem; font-family: var(--font-mono); font-size: 0.85rem; color: var(--muted-foreground); }
.cp-faq-more a { color: var(--foreground); border-bottom: 1px solid var(--foreground); text-decoration: none; }
.cp-faq-more a:hover { color: var(--accent); }

/* ===== Info stránky (Doprava a platba) ===== */
.cp-info-block .cp-h2 { margin-bottom: 2rem; }
.cp-info-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 768px) { .cp-info-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem 3rem; } }
.cp-info-k { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-foreground); border-top: 1px solid var(--foreground); padding-top: 0.75rem; margin-bottom: 0.75rem; }
.cp-info-grid a { color: var(--foreground); border-bottom: 1px solid var(--border); text-decoration: none; }
.cp-info-grid a:hover { color: var(--accent); border-color: var(--accent); }

/* ===== Detail článku „CULTO v médiích" — akce (zdroj + zpět na výpis) ===== */
.culto-article-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 1rem 1.5rem; margin: 2.5rem 0 0; }
.culto-source-btn {
  display: inline-flex; align-items: center; gap: 0.75rem;
  background: var(--ink); color: var(--paper) !important;
  padding: 1.1rem 2rem; font-family: var(--font-mono);
  text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.8rem;
  text-decoration: none; box-shadow: 6px 6px 0 0 var(--accent);
  transition: transform .2s, box-shadow .2s;
}
/* text zůstává bílý i na hover (jinak ho přebije Blocksy --theme-link-hover-color → černá na černé) */
.culto-source-btn:hover { background: var(--ink); color: var(--paper) !important; transform: translate(3px, 3px); box-shadow: 2px 2px 0 0 var(--accent); }
.culto-back-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  border: 1px solid var(--foreground); color: var(--foreground) !important;
  padding: 1rem 1.75rem; font-family: var(--font-mono);
  text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.75rem;
  text-decoration: none; transition: color .2s, border-color .2s;
}
.culto-back-btn:hover { color: var(--accent) !important; border-color: var(--accent); }

/* viditelný placeholder k doplnění (jen staging) */
.cp-todo { background: color-mix(in oklab, var(--terracota) 22%, var(--paper)); color: var(--ink); padding: 0.1em 0.4em; font-family: var(--font-mono); font-size: 0.85em; }

/* =========================================================================
   Revize VI — Pro architekty
   ========================================================================= */
/* HERO — odstranit „obdélník" (glass panel) pod CTA; zůstávají jen tlačítka.
   Třída .ca-hero-panel zůstává kvůli světlému stylu tlačítek na tmavém hero. */
.ca-hero-full .ca-hero-panel {
  padding: 0; background: transparent; border: 0;
  -webkit-backdrop-filter: none; backdrop-filter: none;
}

/* =========================================================================
   Revize VII (2026-06-28) — FAQ dvousloupcový layout
   Levý sloupec = „Otázky, na které se nás ptáte" (zákazníci),
   pravý = „Otázky a odpovědi pro profíky". Pod sloupci sdílená
   vystředěná CTA → /kontakt. Mobil: sloupce se skládají pod sebe.
   ========================================================================= */
.cp-faq-cols { display: grid; grid-template-columns: 1fr; gap: 3.5rem; align-items: start; }
@media (min-width: 900px) {
  .cp-faq-cols { grid-template-columns: 1fr 1fr; column-gap: 4rem; row-gap: 0; grid-template-rows: auto auto; }
  /* subgrid → nadpisy obou sloupců sdílí výšku řádku, takže černé linky
     i seznamy otázek lícují i při různě dlouhých nadpisech */
  .cp-faq-col { display: grid; grid-template-rows: subgrid; grid-row: span 2; }
}
.cp-faq-h {
  font-family: var(--font-display); font-weight: 300;
  letter-spacing: -0.03em; line-height: 1.0; text-wrap: balance;
  font-size: clamp(1.9rem, 3.2vw, 2.7rem);
  margin: 0 0 1.75rem; max-width: 18ch;
}
.cp-faq-col .cp-faq-list.cp-bordered { border-top: 2px solid #000; padding-top: 0.25rem; }

/* sdílená vystředěná CTA pod oběma sloupci */
.cp-faq-cta { border-top: 2px solid #000; text-align: center; }
.cp-faq-cta p { margin: 0; font-family: var(--font-mono); font-size: 0.9rem; color: var(--muted-foreground); }
.cp-faq-cta a { color: var(--foreground); border-bottom: 1px solid var(--foreground); text-decoration: none; }
.cp-faq-cta a:hover { color: var(--accent); }

/* ============ Revize VIII (2026-06-28) ============ */

/* Newsletter /culto-newsletter/ (1143) */
/* (6) panel „obdélník" — stejná Nude rose jako homepage banner místo béžové #faf9f5 */
body.page-id-1143 .wp-block-columns.has-background { background-color: var(--accent) !important; }
/* (8) skrýt page-title „CULTO Newsletter" (stránka není .cp-page; titulek má třídu .page-title, ne .ct-page-title) */
body.page-id-1143 .page-title,
body.page-id-1143 .ct-page-title { display: none !important; }
/* (7) nadpis „Nenechte si ujít…" zarovnat k levému okraji inputu (= padding formuláře spacing-80) + zvětšit */
body.page-id-1143 .wp-block-columns.has-background > .wp-block-column:last-child > p {
  padding-left: var(--wp--preset--spacing--80);
  padding-right: var(--wp--preset--spacing--80);
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  line-height: 1.4;
  margin-bottom: 1.25rem;
}

/* (9) Studio video — černé rohové křížky jako na homepage hero (.cp-media.plate) */
.cp-media.plate .crosshair { width: 30px; height: 30px; opacity: 1; }
.cp-media.plate .crosshair::before { width: 1px; }
.cp-media.plate .crosshair::after  { height: 1px; }
.cp-media.plate > .crosshair-tl { top: -15px; left: -15px; }
.cp-media.plate > .crosshair-tr { top: -15px; right: -15px; }
.cp-media.plate > .crosshair-bl { bottom: -15px; left: -15px; }
.cp-media.plate > .crosshair-br { bottom: -15px; right: -15px; }
