/* =============================================================
   MJ Střechy — Design System CSS  v4.6.0
   Tokens point to WP theme palette vars — change palette once,
   update everywhere automatically.
   ============================================================= */

:root {
  /* Bridge WP preset palette → local tokens */

  /* Bridge WP preset font sizes → local tokens */
}

/* ─── TAXONOMY FILTER (archiv referencí) ─────────────────────── */

.mjsc-tax-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 32px;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 clamp(16px, 4vw, 48px);
}
.mjsc-tax-filter__link {
  display: inline-block;
  padding: 7px 18px;
  border: 1.5px solid rgba(0,0,0,0.15);
  border-radius: 99px;
  font-size: var(--wp--preset--font-size--small);
  font-weight: 600;
  color: var(--wp--preset--color--custom-text);
  text-decoration: none;
  transition: background 0.22s ease, color 0.22s ease, border-color 0.22s ease;
}
.mjsc-tax-filter__link:hover,
.mjsc-tax-filter__link--active {
  background: var(--wp--preset--color--custom-primary);
  color: var(--wp--preset--color--base);
  border-color: var(--wp--preset--color--custom-primary);
}

/* ─── REFERENCE GRID ─────────────────────────────────────────── */

.mjsc-ref-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 48px);
}
@media (max-width: 900px) { .mjsc-ref-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .mjsc-ref-grid { grid-template-columns: 1fr; } }

/* ─── REFERENCE CARD ─────────────────────────────────────────── */

.mjsc-ref-card {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 10px;
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.mjsc-ref-card:hover { transform: translateY(-5px); }

.mjsc-ref-card__link { text-decoration: none; color: inherit; }
.mjsc-ref-card__link::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
}

.mjsc-ref-card__img { width: 100%; aspect-ratio: 4 / 3; overflow: hidden; flex-shrink: 0; }
.mjsc-ref-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.35s ease; }
.mjsc-ref-card:hover .mjsc-ref-card__img img { transform: scale(1.04); }
.mjsc-ref-card__no-img { width: 100%; height: 100%; background: rgba(128,128,128,0.15); }

.mjsc-ref-card__body { padding: 16px 20px 20px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.mjsc-ref-card__type { font-size: var(--wp--preset--font-size--small); font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--wp--preset--color--custom-primary); }
.mjsc-ref-card__title { margin: 0; font-size: var(--wp--preset--font-size--medium); font-weight: 700; line-height: 1.35; }
.mjsc-ref-card__meta { font-size: var(--wp--preset--font-size--small); font-weight: 500; text-transform: uppercase; letter-spacing: 0.03em; }

/* Unified card style — white card works everywhere */
.mjsc-ref-card--light,
.mjsc-ref-card--dark {
  background: var(--wp--preset--color--base);
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}
.mjsc-ref-card--light:hover,
.mjsc-ref-card--dark:hover { box-shadow: 0 10px 32px rgba(0,0,0,0.15); }
.mjsc-ref-card--light .mjsc-ref-card__title,
.mjsc-ref-card--dark .mjsc-ref-card__title  { color: var(--wp--preset--color--custom-dark); }
.mjsc-ref-card--light .mjsc-ref-card__meta,
.mjsc-ref-card--dark .mjsc-ref-card__meta   { color: var(--wp--preset--color--custom-secondary); }
.mjsc-ref-card--light .mjsc-ref-card__link,
.mjsc-ref-card--dark .mjsc-ref-card__link   { color: var(--wp--preset--color--custom-dark); }

/* ─── GRID CTA & BUTTONS ─────────────────────────────────────── */

.mjsc-grid-cta { text-align: center; margin-top: 40px; }

.mjsc-btn-outline {
  display: inline-block;
  padding: 13px 36px;
  border: 2px solid rgba(255,255,255,0.75);
  border-radius: 6px;
  color: var(--wp--preset--color--base);
  font-weight: 700;
  font-size: var(--wp--preset--font-size--small);
  letter-spacing: 0.03em;
  text-decoration: none;
  transition: background 0.22s ease, border-color 0.22s ease;
}
.mjsc-btn-outline:hover { background: rgba(255,255,255,0.15); border-color: var(--wp--preset--color--base); }

.mjsc-btn-outline--on-light { border-color: var(--wp--preset--color--custom-primary); color: var(--wp--preset--color--custom-primary); }
.mjsc-btn-outline--on-light:hover { background: var(--wp--preset--color--custom-primary); color: var(--wp--preset--color--base); }

/* ─── BLOG POST GRID ─────────────────────────────────────────── */

.mjsc-post-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 clamp(16px, 4vw, 48px);
}
@media (max-width: 900px) { .mjsc-post-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .mjsc-post-grid { grid-template-columns: 1fr; } }

/* Blog post card — same base visual as reference card */
.mjsc-post-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--wp--preset--color--base);
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}
.mjsc-post-card:hover { box-shadow: 0 10px 32px rgba(0,0,0,0.15); transform: translateY(-5px); }

.mjsc-post-card__link { text-decoration: none; color: inherit; }
.mjsc-post-card__link::after { content: ''; position: absolute; inset: 0; z-index: 1; }

.mjsc-post-card__img { width: 100%; aspect-ratio: 4/3; overflow: hidden; flex-shrink: 0; }
.mjsc-post-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.35s ease; }
.mjsc-post-card:hover .mjsc-post-card__img img { transform: scale(1.04); }
.mjsc-post-card__img--placeholder { background: var(--wp--preset--color--custom-accent); aspect-ratio: 4/3; }
.mjsc-post-card__body { padding: 16px 20px 20px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.mjsc-post-card__title { margin: 0; font-size: var(--wp--preset--font-size--medium); font-weight: 700; color: var(--wp--preset--color--custom-dark); line-height: 1.35; }
.mjsc-post-card__excerpt { margin: 0; font-size: var(--wp--preset--font-size--medium); color: var(--wp--preset--color--custom-secondary); line-height: 1.55; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

/* ─── ARCHIVE DYNAMIC HEADER ─────────────────────────────────── */

.mjsc-arch-hd { text-align: center; padding: 0 clamp(16px,4vw,48px); }
.mjsc-arch-hd__title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  color: var(--wp--preset--color--base);
  margin: 0 0 12px;
  line-height: 1.2;
}
.mjsc-arch-hd__sub {
  font-size: var(--wp--preset--font-size--medium);
  color: rgba(255,255,255,0.7);
  margin: 0;
  font-weight: 400;
}
.mjsc-arch-hd__sub strong { color: rgba(255,255,255,0.9); }

/* ─── PAGINATION ─────────────────────────────────────────────── */

.mjsc-pagination { text-align: center; margin-top: 48px; }
.mjsc-pagination .page-numbers { display: inline-flex; list-style: none; margin: 0; padding: 0; gap: 6px; flex-wrap: wrap; justify-content: center; }
.mjsc-pagination .page-numbers li a,
.mjsc-pagination .page-numbers li span {
  display: flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 12px;
  border-radius: 6px; border: 1px solid rgba(0,0,0,0.15);
  text-decoration: none; font-size: var(--wp--preset--font-size--small); font-weight: 600;
}
.mjsc-pagination .page-numbers li span.current,
.mjsc-pagination .page-numbers li a:hover { background: var(--wp--preset--color--custom-primary); color: var(--wp--preset--color--base); border-color: var(--wp--preset--color--custom-primary); }
.mjsc-pagination .page-numbers li a.prev,
.mjsc-pagination .page-numbers li a.next { padding: 0 16px; }
.mjsc-no-results { text-align: center; color: var(--wp--preset--color--custom-secondary); padding: 48px 0; }

/* ─── SINGLE REFERENCE — sidebar meta ───────────────────────── */

.mjsc-reference-meta { margin: 0; padding: 0; }
.mjsc-reference-meta__row { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.1); }
.mjsc-reference-meta__row:last-child { border-bottom: none; padding-bottom: 0; }
.mjsc-reference-meta__label { font-size: var(--wp--preset--font-size--small); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(255,255,255,0.5); white-space: nowrap; flex-shrink: 0; }
.mjsc-reference-meta__value { font-size: var(--wp--preset--font-size--small); font-weight: 600; color: var(--wp--preset--color--base); text-align: right; margin: 0; }

/* ─── GALLERY (single reference) ─────────────────────────────── */

.mjsc-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
@media (max-width: 600px) { .mjsc-gallery { grid-template-columns: repeat(2, 1fr); } }
.mjsc-gallery__item { display: block; aspect-ratio: 4/3; overflow: hidden; border-radius: 6px; cursor: zoom-in; }
.mjsc-gallery__item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s ease; }
.mjsc-gallery__item:hover img { transform: scale(1.05); }

/* ─── BLOG POST CONTENT TYPOGRAPHY (single-post only) ───────── */

body.single-post .wp-block-post-content li { line-height: 1.7; color: var(--wp--preset--color--custom-text); margin-bottom: 0.35em; }
body.single-post .wp-block-post-content strong { color: var(--wp--preset--color--custom-dark); }
body.single-post .wp-block-post-content .wp-block-heading { margin-top: 0; }

/* ─── WPFORMS — override hardcoded theme colors with palette vars */

.wpforms-container .wpforms-form .wpforms-field input[type="text"],
.wpforms-container .wpforms-form .wpforms-field input[type="email"],
.wpforms-container .wpforms-form .wpforms-field input[type="tel"],
.wpforms-container .wpforms-form .wpforms-field textarea {
  border-color: var(--wp--preset--color--custom-primary) !important;
  color: var(--wp--preset--color--custom-text) !important;
}
.wpforms-container .wpforms-form button[type="submit"],
.wpforms-container .wpforms-form .wpforms-submit {
  background-color: var(--wp--preset--color--custom-primary) !important;
  border-color: var(--wp--preset--color--custom-primary) !important;
  color: var(--wp--preset--color--base) !important;
}


/* ─── FOOTER CONTACT ICONS ────────────────────────────────────── */
figure:has(.wp-image-740),
figure:has(.wp-image-741),
figure:has(.wp-image-742) {
  margin: 0 !important;
  line-height: 0;
  flex-shrink: 0;
}
.wp-image-740,
.wp-image-741,
.wp-image-742 {
  width: 20px !important;
  height: 20px !important;
  object-fit: contain;
  display: block;
}
.wp-block-group:has(.wp-image-740),
.wp-block-group:has(.wp-image-741),
.wp-block-group:has(.wp-image-742) {
  gap: 10px !important;
  align-items: center !important;
}

/* ─── HEADER PHONE BUTTON → IKONKA NA MOBILU ─────────────────── */
@media (max-width: 782px) {
  .wp-block-button__link[href^="tel:"] {
    font-size: 0 !important;
    padding: 11px !important;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    line-height: 0;
  }
  .wp-block-button__link[href^="tel:"]::before {
    content: '';
    display: block;
    width: 20px;
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07A19.5 19.5 0 0 1 4.69 12a19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 3.6 1.27h3a2 2 0 0 1 2 1.72c.127.96.361 1.903.7 2.81a2 2 0 0 1-.45 2.11L7.91 8.91a16 16 0 0 0 6.06 6.06l.9-.9a2 2 0 0 1 2.11-.45c.907.339 1.85.573 2.81.7A2 2 0 0 1 21.73 16.92z'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
  }
}

/* ─── BÍLÝ PROUŽEK před footereem — odebrat spodní padding z <main> */
main.wp-block-group {
  padding-bottom: 0 !important;
}
