@font-face {
  font-family: 'alef-regular';
  font-style: normal;
  font-weight: 400;
  src: url('https://static.parastorage.com/fonts/v2/df2800f6-57a7-49d3-a1b2-a0ecdb3a137c/v1/alef-regular.hebrew.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'alef-regular';
  font-style: normal;
  font-weight: 400;
  src: url('https://static.parastorage.com/fonts/v2/df2800f6-57a7-49d3-a1b2-a0ecdb3a137c/v1/alef-regular.latin.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'play';
  font-style: normal;
  font-weight: 400;
  src: url('https://static.parastorage.com/tag-bundler/api/v1/fonts-cache/googlefont/woff2/s/play/v11/6aez4K2oVqwIvtU2H70Q13E.woff2') format('woff2');
  font-display: swap;
}

@font-face {
  font-family: 'alef-bold';
  font-style: normal;
  font-weight: 700;
  src: url('https://fonts.gstatic.com/s/alef/v24/FeVQS0NQpLYglo50L5k.ttf') format('truetype');
  font-display: swap;
}

@font-face {
  font-family: 'Alef';
  font-style: normal;
  font-weight: 700;
  src: url('https://fonts.gstatic.com/s/alef/v24/FeVQS0NQpLYglo50L5k.ttf') format('truetype');
  font-display: swap;
}

:root {
  --yellow: rgba(198, 181, 93, 0.65);
  --yellow-solid: #c6b55d;
  --yellow-light: rgba(198, 181, 93, 0.5);
  --pink: #ff0197;
  --black: #222222;
  --dark-bar: #222222;
  --text: #222222;
  --white: #ffffff;
  --gold: #c6b55d;
  --gold-nav: #b8a564;
  --container: 980px;
  --col-left: 649px;
  --col-right: 331px;
  --mesh-gap: 15px;
  --hero-h: 508px;
  --marquee-h: 68px;
  --marquee-w: 528px;
  --marquee-duration: 200s;
  --tile-w: 330px;
  --tile-h: 316px;
  --om-h: 462px;
  --contact-h: 169px;
  --tile-border: 3px solid rgb(250, 250, 250);
  --section-gap: 43px;
  --section-gap-sm: 22px;
  --about-section-gap: 43px;
  --lesson-hero-h: 338px;
  --lesson-side-h: 450px;
  --lesson-tile-h: 323px;
  --lesson-feedback-h: 346px;
  --lesson-col-wide: 658px;
  --lesson-col-narrow: 325px;
  --lesson-col-tile: 328px;
  --courses-cta-w: 240px;
  --courses-tile-w: 363px;
  --courses-wide-w: 740px;
  --courses-tile-h: 332px;
  --courses-workshops-tile-w: 370px;
  --courses-workshops-tile-h: 357px;
  --courses-gift-h: 220px;
  --kinamon-text-w: 319px;
  --kinamon-img-w: 660px;
  --kinamon-row-h: 338px;
  --kinamon-row-h-short: 337px;
  --coaching-col-left: 321px;
  --coaching-col-right: 659px;
  --coaching-hero-h: 340px;
  --coaching-hero-img-h: 334px;
  --coaching-side-h: 580px;
  --coaching-side-img-h: 574px;
  --coaching-gallery-col-w: 329px;
  --coaching-testimonial-col-w: 322px;
  --coaching-gallery-h: 334px;
  --footer-bg: rgba(250, 250, 250, 0.65);
  --signup-bg: rgba(250, 250, 250, 0.85);
  --contact-portrait-w: 280px;
  --contact-form-w: 401px;
  --contact-col-gap: 124px;
  --contact-map-w: 448px;
  --media-gallery-h: 430px;
  --media-gallery-gap: 10px;
  --media-video-thumb-h: 308px;
  --brick: url('../images/f371e5_9857f47162e34c1fa82da6684a2d096b.jpg');
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  direction: rtl;
  overflow-x: hidden;
}

body {
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-weight: 400;
  font-size: 14px;
  direction: rtl;
  text-align: right;
  color: var(--text);
  background: var(--brick) center center / cover fixed;
  min-height: 100vh;
  line-height: 1.4;
}

/* Hebrew text stays RTL even inside LTR layout grids (Wix column/image order). */
:where(
  p, h1, h2, h3, h4, h5, h6, li, dt, dd, th, td, label, legend, blockquote, figcaption,
  .text-tile, .yellow-box, .section-bar, .main-nav, .site-header, .header-phone,
  .marquee-content, .marquee-label, .label-bar,
  .about-text, .about-mission, .about-volunteer-body, .about-quote-text,
  .about-testimonial, .about-subtitle, .about-list,
  .newsletter-text-col, .newsletter-form, .contact-section, .contact-form,
  .lesson-intro, .lesson-body, .lesson-footer-panel,
  .coaching-intro, .coaching-footer-cta,
  .kinamon-service-box, .business-clients-section,
  .mesh-specialties, .mesh-contact-box, .mesh-nlp, .hero-caption, .tile-caption,
  .footer-copy, .footer-item, .gallery-album-desc, .quote-block,
  input, textarea, select
) {
  direction: rtl;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

.site-wrap,
.container,
.page-mesh,
.home-mesh {
  width: var(--container);
  max-width: var(--container);
  margin: 0 auto;
}

/* ── Header (inner pages + homepage) ── */
.site-header {
  padding: 8px 0 4px;
  text-align: center;
  background: transparent;
}

.logo-block {
  display: inline-block;
}

.logo-link {
  display: inline-block;
  margin-bottom: 4px;
}

.site-logo {
  display: block;
  height: 120px;
  width: auto;
  max-width: min(100%, 130px);
  margin: 0 auto;
  image-rendering: -webkit-optimize-contrast;
}

.logo-name,
.logo-title,
.logo-subtitle {
  display: none;
}

.header-phone {
  color: var(--pink);
  font-family: 'play', sans-serif;
  font-size: 22px;
  font-weight: 700;
  margin: 6px 0 8px;
  display: block;
  letter-spacing: normal;
}

.nav-toggle {
  display: none;
}

.main-nav {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: center;
  gap: 0;
  padding: 4px 0 10px;
  direction: rtl;
  white-space: nowrap;
}

.main-nav a {
  font-family: 'Alef', 'alef-regular', sans-serif;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.4em;
  padding: 5px 10px;
  letter-spacing: 0.05em;
  color: rgb(34, 34, 34);
  transition: color 0.4s ease;
  white-space: nowrap;
  flex-shrink: 0;
  -webkit-font-smoothing: antialiased;
}

.main-nav a:hover,
.main-nav a:focus-visible {
  color: var(--pink);
}

.main-nav a.active {
  color: var(--gold);
  text-decoration: none;
}

.main-nav a.active:hover,
.main-nav a.active:focus-visible {
  color: var(--pink);
}

.main-nav .sep {
  color: var(--pink);
  font-family: 'Alef', 'alef-regular', sans-serif;
  font-size: 19px;
  font-weight: 700;
  line-height: 1.4em;
  padding: 0 1px;
  letter-spacing: 0;
  user-select: none;
  flex-shrink: 0;
}

/* ── Bars ── */
.bar-black {
  background: var(--dark-bar);
  color: var(--white);
  text-align: center;
  padding: 8px 12px;
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.25;
  min-height: 34px;
}

.mesh-bar-top,
.mesh-bar-mid {
  font-size: 25px;
  font-family: 'alef-regular', 'Alef', sans-serif;
  letter-spacing: 0.1em;
  padding: 10px 16px;
  min-height: 40px;
  line-height: 1.3;
}

.bar-black.bar-sm {
  font-size: 14px;
  padding: 6px 12px;
}

/* ── Yellow boxes ── */
.yellow-box {
  background: var(--yellow);
  border: var(--tile-border);
  padding: 18px 22px;
}

.yellow-box h3 {
  color: var(--pink);
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 10px;
  letter-spacing: 0.03em;
}

.yellow-box ul {
  list-style: none;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.65;
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.yellow-box .pink-line {
  width: 42%;
  height: 2px;
  background: var(--pink);
  margin: 14px 0 10px;
}

.yellow-box .about-link {
  color: var(--white);
  background: transparent;
  font-size: 13px;
  display: inline-block;
  letter-spacing: 0.02em;
}

.yellow-box .about-link:hover {
  text-decoration: underline;
}

/* ── Homepage mesh (980px Wix layout) ── */
.home-mesh {
  width: var(--container);
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
  background: transparent;
  overflow: visible;
}

.home-mesh-core {
  display: grid;
  grid-template-columns: var(--col-left) var(--col-right);
  grid-template-rows: auto var(--hero-h) min-content;
  column-gap: 0;
  row-gap: 0;
  width: var(--container);
  background: transparent;
  overflow: visible;
  /* Wix col-left/col-right are physical screen positions, not RTL flow */
  direction: ltr;
}

.mesh-right-column {
  grid-column: 2;
  grid-row: 2 / 4;
  display: flex;
  flex-direction: column;
  position: relative;
  align-self: stretch;
  overflow: visible;
  min-height: 0;
  width: var(--col-right);
  max-width: 100%;
  z-index: 1;
}

.mesh-bar-top {
  grid-column: 1 / -1;
  grid-row: 1;
  border: var(--tile-border);
}

.mesh-bar-mid {
  border: var(--tile-border);
  border-top: none;
  border-bottom: var(--tile-border);
  margin: 0;
}

.mesh-left-stack {
  grid-column: 1;
  grid-row: 3;
  display: flex;
  flex-direction: column;
  gap: 0;
  align-self: stretch;
  width: var(--col-left);
  max-width: 100%;
  overflow: hidden;
}

.mesh-right-stack {
  grid-column: 2;
  grid-row: 3;
  display: flex;
  flex-direction: column;
  gap: 0;
  align-self: stretch;
}

.mesh-marquee {
  width: 100%;
  margin-left: 0;
}

.mesh-om-img {
  width: 100%;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  border: var(--tile-border);
  border-top: none;
  display: block;
}

.mesh-bottom-imgs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  direction: ltr;
  width: 100%;
  box-sizing: border-box;
}

.mesh-bottom-imgs .img-hover-tile {
  width: 100%;
  min-width: 0;
  height: var(--tile-h);
  border: var(--tile-border);
  border-top: none;
  box-sizing: border-box;
}

.mesh-bottom-imgs .img-hover-tile:last-child {
  border-left: none;
}

.mesh-contact-box {
  width: 100%;
  height: var(--contact-h);
  min-height: var(--contact-h);
  flex: 0 0 var(--contact-h);
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0;
  overflow: hidden;
  border: var(--tile-border);
  border-top: none;
  direction: rtl;
}

.mesh-full {
  width: 100%;
}

/* Bottom stack: brick gaps between white sections */
.home-mesh > .clients-section,
.home-mesh > .newsletter-section {
  width: 100%;
  max-width: 100%;
  margin-left: 0;
  margin-right: 0;
}

.home-mesh > .clients-section {
  margin-top: var(--section-gap);
  margin-bottom: var(--section-gap);
}

.home-mesh > .newsletter-section {
  margin-bottom: var(--section-gap);
}

main > .site-footer {
  margin-top: 0;
}

/* Hero: 649 + 331 */
.mesh-hero-img {
  grid-column: 1;
  grid-row: 2;
  width: 100%;
  height: var(--hero-h);
  overflow: hidden;
  display: block;
  position: relative;
  border: var(--tile-border);
  border-top: none;
}

.mesh-hero-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.mesh-hero-img .hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(34, 34, 34, 0.5);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 1;
}

.mesh-hero-img .hero-caption {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--white);
  text-align: center;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 2;
  direction: rtl;
  padding: 16px;
}

.mesh-hero-img:hover .hero-overlay,
.mesh-hero-img:hover .hero-caption {
  opacity: 1;
}

.mesh-hero-img .hero-caption .sub {
  font-size: 15px;
  letter-spacing: 0.05em;
  margin-bottom: 6px;
}

.mesh-hero-img .hero-caption h2 {
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 32px;
  font-weight: 400;
  line-height: 1.3em;
  letter-spacing: normal;
  margin: 0;
}

.mesh-specialties {
  width: 100%;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  text-align: center;
  direction: rtl;
  border: var(--tile-border);
  border-top: none;
  border-left: none;
  border-bottom: var(--tile-border);
  position: relative;
  padding: 28px 18px 14px 14px;
  background: var(--yellow);
}

.mesh-specialties h3 {
  font-size: 25px;
  margin-bottom: 8px;
  padding-inline: 36px 8px;
  max-width: 100%;
  box-sizing: border-box;
  white-space: nowrap;
}

.mesh-specialties ul {
  font-size: 20px;
  line-height: 1.4;
}

.mesh-specialties ul a {
  color: inherit;
  text-decoration: none;
}

.mesh-specialties ul a:hover {
  text-decoration: underline;
}

.mesh-specialties h3,
.mesh-specialties ul,
.mesh-specialties .about-link {
  text-align: center;
}

.mesh-specialties .about-link {
  font-size: 20px;
  line-height: 1.4;
  letter-spacing: normal;
  display: inline-flex;
  align-items: center;
  flex-direction: row;
  direction: rtl;
  gap: 6px;
  color: var(--white);
}

.mesh-specialties .about-chevron {
  font-size: 24px;
  color: var(--white);
  line-height: 1;
}

.mesh-specialties .pink-line {
  margin-left: auto;
  margin-right: auto;
}

.mesh-gafan-seal {
  position: absolute;
  top: -72px;
  right: -48px;
  width: 128px;
  height: 128px;
  z-index: 12;
  text-decoration: none;
  pointer-events: auto;
  transform: rotate(-22deg);
  transform-origin: center center;
}

.gafan-seal-svg {
  width: 100%;
  height: 100%;
  display: block;
}

.gafan-seal-svg path {
  fill: var(--yellow-solid);
}

.gafan-seal-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--black);
  line-height: 1.25;
  padding: 30px 20px;
  pointer-events: none;
  transform: rotate(29deg);
}

/* Shared image hover tiles */
.img-hover-tile {
  position: relative;
  display: block;
  overflow: hidden;
}

.img-hover-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.img-hover-tile .tile-overlay {
  position: absolute;
  inset: 0;
  background: rgba(34, 34, 34, 0.5);
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 1;
}

.img-hover-tile .tile-caption {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fafafa;
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 32px;
  font-weight: 400;
  line-height: 1.3em;
  letter-spacing: normal;
  white-space: pre-line;
  padding: 30px;
  opacity: 0;
  transition: opacity 0.4s ease;
  z-index: 2;
  direction: rtl;
  pointer-events: none;
}

.img-hover-tile:hover .tile-overlay,
.img-hover-tile:hover .tile-caption {
  opacity: 1;
}

/* Mid section stacks */

/* Marquee ticker */
.marquee-bar {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  border-bottom: var(--tile-border);
  overflow: hidden;
  width: 100%;
  height: var(--marquee-h);
  display: flex;
  align-items: center;
  flex-shrink: 0;
  direction: rtl;
}

.marquee-label {
  flex: 0 0 auto;
  min-width: 95px;
  color: var(--pink);
  font-size: 24px;
  font-weight: 400;
  line-height: 1.2;
  padding-inline-start: 14px;
  padding-inline-end: 28px;
  white-space: nowrap;
  text-align: center;
}

.marquee-viewport {
  flex: 1;
  overflow: hidden;
  min-width: 0;
  direction: ltr;
  padding-inline-end: 16px;
}

.marquee-track {
  display: flex;
  width: max-content;
  animation: marquee-scroll var(--marquee-duration) linear infinite;
}

.marquee-content {
  white-space: nowrap;
  padding: 0 10px;
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 25px;
  line-height: 1.4;
  color: var(--text);
}

.marquee-pink {
  color: var(--pink);
  font-weight: 400;
  margin-left: 6px;
}

@keyframes marquee-scroll {
  0% { transform: translateX(-33.333%); }
  100% { transform: translateX(0); }
}

.mesh-contact-box .contact-info {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 21px 18px 0;
  width: 100%;
}

.mesh-contact-box h1 {
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 26px;
  font-weight: 400;
  color: rgb(34, 34, 34);
  margin: 0 0 2px;
  line-height: 1.4;
  text-align: center;
}

.mesh-contact-box .phone {
  font-family: 'play', sans-serif;
  font-size: 26px;
  font-weight: 400;
  line-height: 1.4;
  color: rgb(34, 34, 34);
  border-bottom: 2px solid var(--pink);
  display: inline-block;
  margin: 0 0 10px;
  padding: 0 0 2px;
  text-decoration: none;
}

.mesh-contact-box .contact-email {
  padding: 0 12px 16px;
  background: transparent;
}

.mesh-contact-box .contact-email a {
  font-family: 'play', sans-serif;
  color: #ffffff;
  font-size: 21px;
  font-weight: 400;
  line-height: normal;
  letter-spacing: normal;
  text-align: center;
  text-decoration: none;
}

/* Course tiles row */
.mesh-courses {
  display: grid;
  grid-template-columns: 330px 330px 320px;
  gap: 0;
}

.mesh-courses .course-tile {
  position: relative;
  height: 316px;
  overflow: hidden;
  display: block;
}

.mesh-courses .course-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mesh-courses .course-tile .label-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(34, 34, 34, 0.7);
  color: var(--white);
  text-align: center;
  padding: 7px 8px;
  font-size: 13px;
  font-weight: 400;
}

.mesh-nlp {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.mesh-nlp img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.mesh-nlp .yellow-box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  direction: rtl;
}

.mesh-nlp h2 {
  font-size: 20px;
  font-weight: 400;
  margin-bottom: 6px;
}

/* Gafan approval row */
.mesh-gafan-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.mesh-gafan-badges {
  background: var(--yellow);
  border: 3px solid rgba(250,250,250,0.6);
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 16px;
  text-align: center;
  align-items: center;
}

.mesh-gafan-badges .badge-item {
  padding: 10px 8px;
}

.mesh-gafan-badges .badge-item img {
  max-height: 52px;
  margin: 0 auto 6px;
  object-fit: contain;
}

.mesh-gafan-badges .badge-item span {
  font-size: 13px;
  font-weight: 400;
}

.mesh-about-img {
  display: block;
  overflow: hidden;
}

.mesh-about-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 160px;
}

/* Client carousel */
.clients-carousel {
  position: relative;
  background: var(--white);
  padding: 14px 40px;
  overflow: hidden;
  direction: ltr;
}

.clients-section {
  background: var(--white);
  padding: 14px 36px;
  position: relative;
  overflow: hidden;
  width: var(--container);
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  border-top: 1px solid #d8d8d8;
  border-bottom: 1px solid #d8d8d8;
  box-sizing: border-box;
  direction: ltr;
}

.media-gallery,
.media-video-thumbs-wrap {
  direction: ltr;
}

.clients-viewport {
  overflow: hidden;
}

.clients-track {
  display: flex;
  align-items: center;
  gap: 32px;
  transition: transform 0.4s ease;
}

.clients-track img {
  height: 72px;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  flex-shrink: 0;
}

.clients-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 22px;
  color: #ccc;
  cursor: pointer;
  padding: 8px;
  z-index: 2;
  line-height: 1;
}

.clients-arrow:hover { color: #888; }
.clients-arrow.prev,
.media-gallery-arrow.prev,
.media-video-page-arrow.prev,
.lightbox .nav.prev {
  left: 8px !important;
  right: auto !important;
}

.clients-arrow.prev {
  left: 6px !important;
}

.clients-arrow.next,
.media-gallery-arrow.next,
.media-video-page-arrow.next,
.lightbox .nav.next {
  right: 8px !important;
  left: auto !important;
}

.clients-arrow.next {
  right: 6px !important;
}

.clients-arrow,
.media-gallery-arrow,
.media-video-page-arrow,
.lightbox .nav {
  direction: ltr;
  unicode-bidi: isolate;
}

.clients-arrow.prev,
.clients-arrow.next,
.media-gallery-arrow.prev,
.media-gallery-arrow.next,
.media-video-page-arrow.prev,
.media-video-page-arrow.next,
.lightbox .nav.prev,
.lightbox .nav.next {
  font-size: 0;
  line-height: 0;
}

.clients-arrow.prev::before,
.clients-arrow.next::before {
  display: block;
  font-size: 22px;
  line-height: 1;
  color: inherit;
}

.media-gallery-arrow.prev::before,
.media-gallery-arrow.next::before,
.media-video-page-arrow.prev::before,
.media-video-page-arrow.next::before {
  display: block;
  font-size: 28px;
  line-height: 1;
  color: inherit;
}

.lightbox .nav.prev::before,
.lightbox .nav.next::before {
  display: block;
  font-size: 44px;
  line-height: 1;
  color: inherit;
}

.clients-arrow.prev::before,
.media-gallery-arrow.prev::before,
.media-video-page-arrow.prev::before,
.lightbox .nav.prev::before {
  content: '\2190';
}

.clients-arrow.next::before,
.media-gallery-arrow.next::before,
.media-video-page-arrow.next::before,
.lightbox .nav.next::before {
  content: '\2192';
}

/* Newsletter / contact form block */
.newsletter-section {
  background: var(--signup-bg);
  border: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.6);
  padding: 32px 36px;
  width: var(--container);
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.newsletter-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
  direction: ltr;
}

.newsletter-form-col {
  direction: rtl;
}

.newsletter-text-col {
  direction: rtl;
  text-align: right;
}

.newsletter-text-col h2 {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 16px;
}

.newsletter-text-col p {
  font-size: 14px;
  line-height: 1.65;
  margin-bottom: 12px;
}

.newsletter-form .field-wrap {
  position: relative;
  margin-bottom: 12px;
}

.newsletter-form input {
  width: 100%;
  border: 1px solid var(--black);
  padding: 12px 14px;
  font-family: inherit;
  font-size: 14px;
  direction: rtl;
  background: var(--white);
}

.newsletter-form .field-wrap label {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  color: #555;
  pointer-events: none;
}

.newsletter-form button,
.contact-form button {
  background: #b8a45f;
  color: var(--white);
  border: none;
  padding: 8px 28px;
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  margin-top: 4px;
  display: block;
  width: fit-content;
  margin-right: auto;
  margin-left: 0;
}

.newsletter-form .field-wrap textarea,
.registration-form textarea {
  width: 100%;
  border: 1px solid var(--black);
  padding: 12px 14px;
  font-family: inherit;
  font-size: 14px;
  direction: rtl;
  background: var(--white);
  resize: vertical;
  min-height: 96px;
}

.newsletter-form .field-wrap-textarea label,
.registration-form .field-wrap-textarea label {
  top: 14px;
  transform: none;
}

.registration-mesh {
  padding-bottom: var(--section-gap);
}

.registration-back {
  text-align: center;
  margin: 18px 0 0;
}

.registration-back-link {
  display: inline-block;
  font-size: 18px;
  font-weight: 700;
  color: var(--black);
  text-decoration: none;
}

.registration-back-link:hover {
  color: var(--pink);
}

.registration-form-section {
  margin-top: 24px;
}

.registration-form-wrap {
  max-width: 520px;
  margin: 0 auto;
  direction: rtl;
}

.registration-form-heading {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
  text-align: center;
}

.registration-form-lead {
  text-align: center;
  margin-bottom: 20px;
}

/* Inner page contact form (legacy) */
.contact-section {
  background: var(--white);
  border: 1px solid #ddd;
  padding: 28px 36px 32px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.08);
}

.contact-section h2 {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 18px;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}

.contact-text p {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.65;
  margin-bottom: 10px;
  border-bottom: 1px solid #e8e8e8;
  padding-bottom: 10px;
}

.contact-text p:last-child {
  border-bottom: none;
}

.contact-form label {
  display: block;
  font-size: 14px;
  margin-bottom: 3px;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1px solid #ccc;
  padding: 7px 10px;
  font-family: inherit;
  font-size: 14px;
  margin-bottom: 10px;
  direction: rtl;
  background: var(--white);
  box-sizing: border-box;
}

.contact-form textarea {
  resize: vertical;
  min-height: 90px;
}

.form-success {
  display: none;
  text-align: center;
  padding: 20px;
  color: var(--pink);
  font-size: 17px;
}

/* Footer */
.site-footer {
  background: var(--footer-bg);
  padding: 24px 0 18px;
  text-align: center;
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}

.site-footer .footer-inner {
  width: var(--container);
  max-width: 100%;
  margin: 0 auto;
  padding: 0 16px;
  box-sizing: border-box;
}

.site-footer.container {
  width: 100%;
  max-width: none;
}

.footer-top-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  direction: rtl;
  position: relative;
  width: 100%;
  padding: 0 48px;
}

.footer-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'play', sans-serif;
  font-size: 18px;
  color: var(--black);
}

.footer-item a {
  color: var(--black);
  font-family: inherit;
}

.footer-item img {
  width: auto;
  height: 34px;
  flex-shrink: 0;
}

.footer-phone .phone-sep {
  color: var(--pink);
  margin: 0 6px;
}

.social-links {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
}

.social-links a {
  display: block;
  line-height: 0;
  transition: opacity 0.2s;
}

.social-links a:hover {
  opacity: 0.8;
}

.social-links img {
  width: 33px;
  height: 33px;
  display: block;
}

.footer-scroll-top {
  display: none;
}

.footer-copy {
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 15px;
  font-weight: 400;
  color: #222;
  line-height: normal;
}

.footer-copy a { color: var(--pink); }

/* Floating UI */
.scroll-top-fixed {
  position: fixed;
  right: 18px;
  bottom: 82px;
  width: 48px;
  height: 48px;
  background: rgb(34, 34, 34);
  color: #ffffff;
  border: 2px solid var(--pink);
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  line-height: 1;
  font-weight: 400;
  z-index: 99;
  padding: 0;
  transition: background 0.2s ease;
}

.scroll-top-fixed:hover,
.scroll-top-fixed:focus-visible {
  background: #111111;
}

.chat-btn {
  position: fixed;
  bottom: 18px;
  right: 18px;
  left: auto;
  background: var(--gold);
  color: var(--white);
  padding: 9px 16px;
  border-radius: 3px;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 7px;
  z-index: 100;
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
  cursor: pointer;
  border: none;
  font-family: inherit;
}

.chat-widget {
  position: fixed;
  bottom: 70px;
  right: 18px;
  z-index: 110;
  display: none;
}

.chat-widget.open {
  display: block;
}

.chat-panel {
  width: 340px;
  max-width: calc(100vw - 36px);
  background: #f5f0e4;
  border-radius: 4px;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
  direction: rtl;
}

.chat-header {
  background: #b8a45f;
  color: var(--white);
  padding: 12px 14px;
  position: relative;
}

.chat-close {
  position: absolute;
  top: 10px;
  left: 10px;
  background: none;
  border: none;
  color: var(--white);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 0 4px;
}

.chat-header-info {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: flex-end;
}

.chat-header-logo {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  object-fit: cover;
}

.chat-header-title {
  font-size: 16px;
  font-weight: 700;
}

.chat-header-status {
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 6px;
  justify-content: flex-end;
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #4cd964;
  display: inline-block;
}

.chat-body {
  padding: 16px 16px 56px;
  position: relative;
  background: #f5f0e4;
}

.chat-time {
  text-align: center;
  font-size: 11px;
  color: #888;
  margin-bottom: 12px;
}

.chat-bubble {
  background: var(--white);
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.55;
  margin-bottom: 16px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

.chat-form {
  background: var(--white);
  border-radius: 6px;
  padding: 14px 16px 16px;
}

.chat-field {
  display: block;
  margin-bottom: 14px;
}

.chat-field span {
  display: block;
  font-size: 14px;
  color: #555;
  margin-bottom: 4px;
  text-align: right;
}

.chat-field input,
.chat-field textarea {
  width: 100%;
  border: none;
  border-bottom: 1px solid #ccc;
  padding: 6px 0;
  font-family: inherit;
  font-size: 14px;
  direction: rtl;
  background: transparent;
  resize: vertical;
}

.chat-field input:focus,
.chat-field textarea:focus {
  outline: none;
  border-bottom-color: var(--gold);
}

.chat-submit {
  background: #4a4a4a;
  color: var(--white);
  border: none;
  border-radius: 4px;
  padding: 10px 24px;
  font-family: inherit;
  font-size: 14px;
  cursor: pointer;
  margin-top: 4px;
}

.chat-submit:disabled {
  opacity: 0.7;
  cursor: wait;
}

.chat-form-success {
  display: none;
  color: var(--pink);
  font-size: 14px;
  margin-top: 10px;
  text-align: center;
}

.chat-avatar {
  position: absolute;
  bottom: 10px;
  left: 14px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  object-fit: cover;
}

/* Inner page layouts */
.page-mesh {
  width: var(--container);
  max-width: 100%;
  margin: 0 auto;
}

.section-bar {
  background: var(--dark-bar);
  color: var(--white);
  text-align: center;
  padding: 10px 16px;
  font-size: 25px;
  font-weight: 400;
  font-family: 'alef-regular', 'Alef', sans-serif;
  letter-spacing: 0.1em;
}

.section-white-stripe,
.courses-white-stripe {
  height: 3px;
  background: rgb(250, 250, 250);
  border-left: var(--tile-border);
  border-right: var(--tile-border);
}

.page-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.page-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.page-grid-alt {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.page-grid-alt .img-tile img,
.grid-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.grid-tile {
  position: relative;
  overflow: hidden;
  display: block;
  background: #ccc;
}

.grid-tile .label-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(34,34,34,0.7);
  color: var(--white);
  text-align: center;
  padding: 7px 10px;
  font-size: 13px;
}

.text-tile h2 {
  font-size: 26px;
  font-weight: 400;
  margin-bottom: 14px;
}

.text-tile p {
  font-size: 14px;
  line-height: 1.65;
  margin-bottom: 8px;
}

.pink, .text-tile .pink { color: var(--pink); }

.text-tile .read-more {
  color: var(--pink);
  font-size: 13px;
  margin-top: 10px;
  display: inline-block;
}

.btn-pink {
  display: inline-block;
  background: var(--pink);
  color: var(--white);
  padding: 8px 24px;
  border-radius: 50px;
  font-size: 20px;
  border: 2px solid var(--black);
  cursor: pointer;
  font-family: 'alef-regular', 'Alef', sans-serif;
  letter-spacing: 0.05em;
  margin-top: 10px;
}

.btn-gold {
  display: inline-block;
  background: var(--gold);
  color: var(--white);
  padding: 8px 24px;
  font-size: 20px;
  border: 2px solid #555555;
  border-radius: 50px;
  cursor: pointer;
  font-family: 'alef-regular', 'Alef', sans-serif;
  letter-spacing: 0.05em;
}

/* Gallery */
.gallery-mesh {
  background: transparent;
  overflow: visible;
  margin-bottom: var(--section-gap);
}

.gallery-mesh .section-bar {
  margin: 0;
  border: var(--tile-border);
}

.gallery-intro {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  padding: 14px 28px;
  text-align: center;
}

.gallery-intro p {
  font-size: 15px;
  line-height: normal;
  margin: 0;
}

.gallery-album-desc {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  padding: 14px 28px;
  text-align: center;
}

.gallery-album-desc p {
  font-size: 15px;
  line-height: normal;
  margin: 0;
}

.gallery-recipes-intro {
  padding: 14px 28px;
}

.gallery-album-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  direction: rtl;
}

.gallery-album-tile {
  display: block;
  position: relative;
  overflow: hidden;
  border: var(--tile-border);
  border-top: none;
  background: #ddd;
}

.gallery-album-tile::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  aspect-ratio: 1;
  background: rgba(0, 0, 0, 0.42);
  opacity: 0;
  transition: opacity 0.25s ease;
  z-index: 1;
  pointer-events: none;
}

.gallery-album-tile:hover::before {
  opacity: 1;
}

.gallery-album-tile img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  transition: transform 0.3s;
  position: relative;
  z-index: 0;
}

.gallery-album-tile:hover img {
  transform: scale(1.02);
}

.gallery-album-caption {
  position: relative;
  z-index: 2;
  background: rgba(34, 34, 34, 0.82);
  color: var(--white);
  text-align: center;
  padding: 7px 6px;
  font-size: 12px;
  line-height: 1.35;
  min-height: 36px;
}

.album-page .album-back {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  padding: 14px 20px 18px;
  margin: 0;
  font-size: 14px;
  text-align: left;
}

.album-page .album-back a {
  color: var(--pink);
}

.album-pdf-cta {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  padding: 18px;
  text-align: center;
}

.album-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: var(--tile-border);
  border-top: none;
}

.album-photo-grid .gallery-item {
  cursor: pointer;
  overflow: hidden;
  border: var(--tile-border);
  border-top: none;
  border-right: none;
  aspect-ratio: 1;
  position: relative;
}

.album-photo-grid .gallery-item.is-hidden {
  display: none;
}

.album-photo-grid .gallery-item::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.42);
  opacity: 0;
  transition: opacity 0.25s ease;
  pointer-events: none;
}

.album-photo-grid .gallery-item:hover::after {
  opacity: 1;
}

.album-photo-grid .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s;
  display: block;
}

.album-photo-grid .gallery-item:hover img {
  transform: scale(1.02);
}

.album-page--recipe .album-photo-grid {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--yellow);
  padding: 28px 24px;
  min-height: 360px;
}

.album-page--recipe .album-photo-grid .gallery-item {
  width: auto;
  max-width: min(100%, 520px);
  aspect-ratio: auto;
  border: none;
  flex: 0 0 auto;
}

.album-page--recipe .album-photo-grid .gallery-item img {
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: min(72vh, 760px);
  object-fit: contain;
  margin: 0 auto;
}

.album-load-more-wrap {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  text-align: center;
  padding: 14px 16px;
}

.album-load-more {
  border: none;
  background: transparent;
  color: #4a4a4a;
  font-size: 14px;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
}

.album-load-more:hover {
  color: var(--pink);
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
}

.gallery-grid .gallery-item {
  cursor: pointer;
  overflow: hidden;
  aspect-ratio: 1;
}

.gallery-grid .gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s;
}

.gallery-grid .gallery-item:hover img { transform: scale(1.04); }

.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.88);
  z-index: 200;
  align-items: center;
  justify-content: center;
}

.lightbox.open { display: flex; }

.lightbox img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
}

.lightbox .close {
  position: absolute;
  top: 16px;
  right: 16px;
  color: var(--white);
  font-size: 30px;
  cursor: pointer;
  background: none;
  border: none;
}

.lightbox .nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  color: var(--white);
  font-size: 44px;
  cursor: pointer;
  background: none;
  border: none;
  padding: 16px;
  opacity: 0.7;
}

.lightbox .prev { left: 8px; }
.lightbox .next { right: 8px; }

.quote-block {
  display: grid;
  grid-template-columns: 110px 1fr;
  align-items: center;
  gap: 18px;
  padding: 20px 24px;
}

.quote-block .quote-text {
  font-size: 17px;
  line-height: 1.55;
}

.quote-block .highlight { color: var(--pink); font-weight: 700; }

/* About page */
.about-mesh {
  background: transparent;
  overflow: visible;
}

.about-mesh > section:not(:last-child) {
  margin-bottom: var(--about-section-gap);
}

.about-mesh > .newsletter-section {
  margin-bottom: var(--section-gap);
}

.about-story {
  position: relative;
}

.about-story-body {
  position: relative;
}

.about-gafan-seal {
  position: absolute;
  top: -78px;
  right: -62px;
  width: 114px;
  height: 114px;
  z-index: 12;
  text-decoration: none;
  pointer-events: auto;
  transform: rotate(-22deg);
  transform-origin: center center;
}

.about-gafan-seal .gafan-seal-text {
  font-size: 14px;
  letter-spacing: 0.03em;
  font-weight: 400;
  font-family: 'Avenir', 'Heebo', sans-serif;
  transform: rotate(29deg);
}

.about-signature {
  display: block;
  width: 108px;
  height: auto;
  margin: 6px auto 10px;
}

.about-block .section-bar {
  margin: 0;
  border: var(--tile-border);
}

.about-block .yellow-box,
.about-volunteer-box,
.about-quote-text {
  border: 3px solid rgb(250, 250, 250);
  border-top: none;
  background: var(--yellow);
}

.about-mesh .yellow-box {
  background: var(--yellow);
}

.about-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  direction: rtl;
}

/* Wix about page: 650px text + 329px photo (980px total) */
.about-grid-2.about-grid-story {
  grid-template-columns: minmax(0, 650px) minmax(0, 329px);
  direction: rtl;
  align-items: stretch;
}

/* Wix: 577px text + 403px photo */
.about-grid-2.about-grid-house {
  grid-template-columns: minmax(0, 577px) minmax(0, 403px);
  direction: ltr;
  align-items: stretch;
}

.about-grid-2.about-grid-education {
  grid-template-columns: minmax(0, 577px) minmax(0, 403px);
  direction: ltr;
  align-items: stretch;
}

.about-grid-2.about-grid-img-first {
  direction: ltr;
}

.about-photo {
  overflow: hidden;
  border: 3px solid rgb(250, 250, 250);
  border-top: none;
  min-height: 340px;
  padding: 0;
}

.about-photo .about-photo-slideshow {
  position: relative;
  min-height: 340px;
  height: 100%;
  border: none;
  background: var(--white);
}

.about-photo img,
.about-photo .about-photo-slideshow .slideshow-slide img {
  width: 100%;
  height: 100%;
  min-height: 340px;
  object-fit: cover;
  display: block;
}

.about-photo-tall .about-photo-slideshow,
.about-photo-tall .about-photo-slideshow .slideshow-slide img {
  min-height: 500px;
}

.about-grid-story .about-photo-tall {
  min-height: 0;
  height: auto;
  max-height: none;
  align-self: stretch;
  display: flex;
  flex-direction: column;
}

.about-grid-story .about-photo-tall .about-photo-slideshow {
  min-height: 0;
  height: 100%;
  max-height: none;
  flex: 1 1 auto;
}

.about-grid-story .about-photo-tall .about-photo-slideshow .slideshow-slide img {
  min-height: 0;
  height: 100%;
  max-height: none;
  object-position: top center;
}

.about-grid-house .about-photo-slideshow,
.about-grid-house .about-photo-slideshow .slideshow-slide img {
  min-height: 247px;
}

.about-photo.about-photo-cert {
  min-height: 0;
  height: 100%;
  background: var(--white);
  display: flex;
  flex-direction: column;
  align-self: stretch;
}

.about-photo-cert .about-photo-slideshow,
.about-photo-cert .about-cert-slideshow {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  background: var(--white);
}

.about-photo-cert .about-cert-slideshow .slideshow-slide img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: contain;
  object-position: center center;
  background: var(--white);
  display: block;
}

.about-text {
  padding: 28px 32px;
}

.about-story .about-text,
.about-mission,
.about-grid-house .about-text,
.about-grid-education .about-text {
  direction: rtl;
  text-align: center;
  color: rgb(34, 34, 34);
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.about-story .about-text {
  padding: 16px 44px 12px;
  min-height: 0;
  box-sizing: border-box;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.about-story .about-text p {
  font-size: 16px;
  line-height: 1.35;
  margin: 0;
  letter-spacing: normal;
  width: 100%;
  max-width: none;
}

.about-story .about-text p.about-spacer {
  min-height: 6px;
}

.about-story .about-closing-1,
.about-story .about-closing-2 {
  text-align: center;
}

.about-story .about-closing-2 {
  margin-bottom: 10px;
}

.about-story-signoff {
  position: relative;
  margin-top: 4px;
  min-height: 68px;
}

.about-story .about-signature {
  position: absolute;
  left: 0;
  right: auto;
  bottom: 0;
  transform: none;
  display: block;
  width: 108px;
  height: auto;
  margin: 0;
}

.about-story .about-story-blog-btn {
  position: absolute;
  right: 0;
  bottom: 24px;
  left: auto;
  margin: 0;
  width: 140px;
  text-align: center;
  font-size: 16px;
  padding: 4px 18px;
  box-sizing: border-box;
}

.about-grid-house .about-text {
  padding: 9px 10px;
  min-height: 247px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-grid-house .about-text p {
  font-size: 18px;
  line-height: normal;
  margin: 0;
  letter-spacing: normal;
}

.about-mission {
  padding: 27px 0 28px;
}

.about-mission p {
  font-size: 20px;
  line-height: normal;
  margin: 0 auto;
  max-width: 403px;
  letter-spacing: normal;
}

.about-grid-education .about-text {
  text-align: center;
  color: rgb(85, 85, 85);
  font-family: 'alef-regular', 'Alef', sans-serif;
  padding: 14px 8px;
  min-height: 0;
  height: 100%;
  align-self: stretch;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-grid-education .about-photo-cert {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.about-grid-education .about-subtitle {
  color: rgb(250, 250, 250);
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 5px;
  font-family: 'alef-regular', 'Alef', sans-serif;
  text-align: center;
  letter-spacing: normal;
  line-height: 1.5;
}

.about-grid-education .about-list {
  list-style: none;
  font-size: 18px;
  line-height: 1.5;
  color: rgb(85, 85, 85);
  font-family: 'alef-regular', 'Alef', sans-serif;
  margin: 0;
  padding: 0;
}

.about-grid-education .about-list li {
  margin: 0;
}

.about-mesh .btn-gold {
  margin-top: 12px;
}

/* Wix quote strip: 202px image + 778px text (980px total), 121px tall */
.about-quote-row {
  display: grid;
  grid-template-columns: 202px minmax(0, 778px);
  direction: ltr;
  gap: 0;
  max-width: 980px;
}

.about-quote-img {
  overflow: hidden;
  border: 3px solid rgb(250, 250, 250);
  width: 202px;
  height: 121px;
  min-height: 121px;
  padding: 0;
}

.about-quote-slideshow {
  position: relative;
  min-height: 121px;
  height: 121px;
  border: none;
  background: var(--white);
}

.about-quote-img img,
.about-quote-slideshow .slideshow-slide img {
  width: 100%;
  height: 121px;
  min-height: 121px;
  object-fit: cover;
  display: block;
}

.about-quote-text {
  direction: rtl;
  min-height: 121px;
  height: 121px;
  padding: 0 12px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  position: relative;
  border-top: 3px solid rgb(250, 250, 250);
  font-family: 'alef-regular', 'Alef', sans-serif;
  color: rgb(34, 34, 34);
}

.about-quote-text.text-tile p {
  margin: 0;
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.about-quote-text.text-tile .about-quote-definition {
  font-size: 25px;
  line-height: 27px;
  text-align: center;
  white-space: nowrap;
  color: rgb(34, 34, 34);
  letter-spacing: normal;
}

.about-quote-text.text-tile .about-quote-source {
  position: absolute;
  bottom: 4px;
  left: 10px;
  font-size: 11px;
  line-height: 27px;
  text-align: left;
  direction: rtl;
  color: rgb(34, 34, 34);
  letter-spacing: normal;
}

.about-quote-text .highlight {
  color: var(--pink);
  font-weight: 700;
  font-size: inherit;
}

/* Wix volunteer strip: 286px image + 694px text (980px total), 204px tall */
.about-volunteer-row {
  display: grid;
  grid-template-columns: 286px minmax(0, 694px);
  direction: ltr;
  gap: 0;
  max-width: 980px;
}

.about-volunteer-img {
  overflow: hidden;
  border: var(--tile-border);
  width: 286px;
  height: 204px;
  min-height: 204px;
}

.about-volunteer-img img {
  width: 100%;
  height: 204px;
  min-height: 204px;
  object-fit: cover;
  display: block;
}

.about-volunteer-box {
  padding: 0;
  overflow: hidden;
  height: 204px;
  min-height: 204px;
}

.about-volunteer-body {
  padding: 12px 20px;
  text-align: center;
  direction: rtl;
  font-family: 'alef-regular', 'Alef', sans-serif;
  color: rgb(34, 34, 34);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-volunteer-body p {
  font-size: 18px;
  line-height: normal;
  margin: 0;
}

.about-block .about-volunteer-row .about-volunteer-img,
.about-block .about-volunteer-row .about-volunteer-box {
  border-top: none;
}

.about-testimonials {
  display: grid;
  grid-template-columns: 1fr 2px 325px 2px 1fr;
  gap: 0;
  padding: 22px 22px 31px;
  align-items: start;
  direction: rtl;
}

.about-testimonial {
  padding: 0 10px;
  min-width: 0;
}

.about-testimonial-divider {
  width: 2px;
  height: 155px;
  background: var(--pink);
  justify-self: center;
  align-self: start;
  margin-top: 53px;
}

.about-testimonial-quote {
  font-size: 13px;
  line-height: normal;
  margin: 0;
  color: rgb(34, 34, 34);
  font-family: 'alef-regular', 'Alef', sans-serif;
  text-align: center;
}

.about-testimonial-name {
  font-size: 11px;
  line-height: normal;
  margin: 0;
  color: rgb(34, 34, 34);
  font-family: 'alef-regular', 'Alef', sans-serif;
  text-align: center;
}

.about-testimonial .about-testimonial-quote + .about-testimonial-name {
  margin-top: 0;
}

.about-clients {
  margin-top: 0;
  margin-bottom: var(--section-gap);
  border: var(--tile-border);
}

.about-mesh .newsletter-section {
  width: 100%;
  max-width: 100%;
}

/* Courses page */
.courses-mesh {
  background: transparent;
  overflow: visible;
  display: flex;
  flex-direction: column;
}

.courses-mesh .section-bar {
  margin: 0;
  border: var(--tile-border);
}

.courses-gift-row {
  margin-top: var(--section-gap);
  direction: ltr;
}

.courses-gift-row .gift-title-box,
.courses-gift-row .gift-details {
  border: var(--tile-border);
}

.courses-bottom-stripe {
  margin-bottom: var(--section-gap);
}

.courses-mesh + .courses-newsletter {
  margin-top: 0;
  margin-bottom: var(--section-gap);
}

.courses-grid-3 {
  display: grid;
  grid-template-columns: var(--courses-cta-w) var(--courses-tile-w) calc(var(--container) - var(--courses-cta-w) - var(--courses-tile-w));
  direction: rtl;
  gap: 0;
  width: var(--container);
  max-width: 100%;
}

.courses-row-workshops {
  grid-template-columns: var(--courses-cta-w) var(--courses-workshops-tile-w) var(--courses-workshops-tile-w);
  direction: ltr;
}

.courses-row-workshops .courses-tile {
  height: var(--courses-workshops-tile-h);
  min-height: var(--courses-workshops-tile-h);
}

.courses-row-workshops .courses-cta {
  min-height: var(--courses-workshops-tile-h);
  height: var(--courses-workshops-tile-h);
}

.courses-grid-2 {
  display: grid;
  grid-template-columns: var(--courses-cta-w) var(--courses-wide-w);
  direction: rtl;
  gap: 0;
  width: var(--container);
  max-width: 100%;
}

.courses-row .grid-tile,
.courses-row-private .grid-tile,
.courses-row-business .grid-tile,
.courses-cta,
.courses-marquee {
  border: var(--tile-border);
  border-top: none;
}

.courses-tile {
  position: relative;
  overflow: hidden;
  display: block;
  height: var(--courses-tile-h);
  min-height: var(--courses-tile-h);
  background: var(--white);
}

.courses-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.courses-tile-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  transition: opacity 0.35s ease;
  z-index: 1;
  pointer-events: none;
}

.courses-tile:hover .courses-tile-overlay {
  opacity: 1;
}

.courses-tile .label-bar {
  z-index: 2;
  font-size: 25px;
  font-weight: 400;
  line-height: normal;
  font-family: 'alef-regular', 'Alef', sans-serif;
  letter-spacing: normal;
  padding: 7px 10px;
  transition: background 0.35s ease, padding 0.35s ease;
}

.courses-tile:hover .label-bar {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  padding: 30px;
  text-align: center;
}

.courses-cta {
  background: var(--yellow);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: var(--courses-tile-h);
  padding: 20px;
  text-align: center;
  position: relative;
}

.courses-cta-title {
  font-size: 66px;
  font-weight: 400;
  line-height: 0.9em;
  letter-spacing: normal;
  margin: 0 0 16px;
  color: var(--black);
  font-family: 'alef-regular', 'Alef', sans-serif;
  text-align: center;
}

.courses-cta-title a,
.courses-cta-title a:hover,
.courses-cta-title a:focus,
.courses-cta-title a:visited,
.courses-cta-title a:active {
  color: inherit;
  text-decoration: none;
}

.courses-cta-title-stacked {
  line-height: 0.9em;
}

.courses-cta-courses {
  overflow: visible;
  position: relative;
}

.courses-gafan-seal {
  top: -58px;
  right: -42px;
  width: 128px;
  height: 128px;
  transform: rotate(-22deg);
  transform-origin: center center;
}

.courses-gafan-seal .gafan-seal-text {
  font-size: 14px;
  letter-spacing: 0.03em;
  font-weight: 400;
  font-family: 'Avenir', 'Heebo', sans-serif;
  transform: rotate(29deg);
}

.courses-btn-pink {
  font-size: 16px;
  padding: 6px 22px;
  margin-top: 0;
}

.courses-marquee.marquee-bar {
  width: 100%;
  height: 55px;
  min-height: 55px;
  border-top: none;
  border-bottom: var(--tile-border);
  direction: ltr;
}

.courses-marquee .marquee-viewport {
  width: 100%;
}

.courses-marquee .marquee-content {
  font-size: 25px;
  line-height: normal;
}

.courses-span-2 {
  grid-column: span 2;
}

.courses-row-private .courses-cta,
.courses-row-private .courses-tile {
  min-height: var(--courses-workshops-tile-h);
  height: var(--courses-workshops-tile-h);
}

.courses-row-business {
  direction: ltr;
  grid-template-columns: var(--courses-wide-w) var(--courses-cta-w);
}

.courses-row-business--flip {
  grid-template-columns: var(--courses-cta-w) var(--courses-wide-w);
}

.courses-row-business .courses-cta,
.courses-row-business .courses-tile {
  min-height: var(--courses-workshops-tile-h);
  height: var(--courses-workshops-tile-h);
}

.courses-mesh--business-lectures .courses-row-business .courses-tile .label-bar {
  font-size: 25px;
  font-weight: 400;
  line-height: normal;
  font-family: 'alef-regular', 'Alef', sans-serif;
  letter-spacing: normal;
  padding: 7px 10px;
}

.gift-title-box {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: var(--courses-gift-h);
  background: var(--yellow);
}

.courses-gift-title {
  font-size: 60px;
  font-weight: 400;
  line-height: 0.9em;
  letter-spacing: normal;
  margin: 0;
  color: var(--black);
  font-family: 'alef-regular', 'Alef', sans-serif;
  text-align: center;
}

.gift-details {
  background: var(--yellow);
  padding: 20px 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: var(--courses-gift-h);
  text-align: center;
}

.gift-details p {
  font-size: 20px;
  line-height: normal;
  letter-spacing: normal;
  margin: 0 0 6px;
  color: var(--black);
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.gift-details .phone-link,
.gift-sample-link {
  color: var(--pink);
}

.gift-sample-link {
  margin-top: 8px;
  font-size: 20px;
  line-height: normal;
  letter-spacing: normal;
  display: inline-block;
}

.courses-newsletter .newsletter-text-col h2 {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.4em;
  margin-bottom: 16px;
}

.courses-newsletter .newsletter-text-col p {
  font-size: 19px;
  line-height: 1.4em;
  margin-bottom: 12px;
}

.courses-newsletter--business .newsletter-inner {
  grid-template-columns: 0.8fr 1.2fr;
}

.courses-newsletter--business .newsletter-text-col h2 {
  font-size: 24px;
  white-space: nowrap;
}

/* Personal coaching page */
.coaching-mesh {
  background: transparent;
  overflow: visible;
  margin-bottom: var(--section-gap);
}

.coaching-mesh .section-bar {
  margin: 0;
  border: var(--tile-border);
}

.coaching-hero {
  border: var(--tile-border);
  border-top: none;
  overflow: hidden;
  height: var(--coaching-hero-h);
}

.coaching-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.coaching-grid-2 {
  display: grid;
  grid-template-columns: var(--coaching-col-right) var(--coaching-col-left);
  direction: rtl;
  gap: 0;
  align-items: stretch;
}

.coaching-grid-3 {
  display: grid;
  grid-template-columns:
    var(--coaching-gallery-col-w)
    var(--coaching-gallery-col-w)
    var(--coaching-testimonial-col-w);
  grid-template-rows: var(--coaching-gallery-h);
  direction: rtl;
  gap: 0;
  align-items: stretch;
}

.coaching-grid-2 > *,
.coaching-grid-3 > * {
  border: var(--tile-border);
  border-top: none;
}

.coaching-grid-3 > .coaching-tile {
  height: var(--coaching-gallery-h);
  max-height: var(--coaching-gallery-h);
  overflow: hidden;
}

.coaching-intro.text-tile h2,
.coaching-intro.text-tile p {
  font-weight: 400;
}

.coaching-intro {
  padding: 0 32px 28px;
  text-align: center;
  direction: rtl;
  min-height: var(--coaching-side-h);
  height: auto;
  align-self: stretch;
}

.coaching-intro h2 {
  font-size: 25px;
  font-weight: 400;
  margin: 23px 0 6px;
  color: var(--white);
  font-family: 'alef-regular', 'Alef', sans-serif;
  line-height: normal;
}

.coaching-intro p {
  font-size: 22px;
  line-height: normal;
  margin: 0;
  color: #222222;
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-weight: 400;
}

.coaching-intro .coaching-lead {
  margin-bottom: 13px;
}

.coaching-intro .coaching-spacer {
  height: 20px;
  font-size: 20px;
  line-height: normal;
}

.coaching-intro .coaching-spacer--lg {
  height: 40px;
}

.coaching-highlight {
  font-size: 25px;
  margin: 0;
  font-weight: 400;
  line-height: normal;
  color: var(--pink);
}

.coaching-schedule {
  margin-top: 0;
  font-size: 20px;
  line-height: normal;
}

.coaching-contact-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 18px;
  margin: 12px 0;
}

.coaching-contact-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
  font-size: 20px;
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.coaching-intro .coaching-note {
  font-size: 13px;
  line-height: 2em;
  margin-top: 0;
  font-family: 'play', sans-serif;
  font-weight: 400;
  color: #222222;
}

.coaching-intro .coaching-note-asterisk {
  font-size: 20px;
  line-height: 1;
}

.coaching-note {
  font-size: 13px;
  line-height: 1.4em;
  margin-top: 10px;
  color: var(--text);
}

.coaching-side-col {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: var(--coaching-side-h);
  align-self: stretch;
  overflow: hidden;
}

.coaching-side-img {
  flex: 1 1 0;
  min-height: 0;
  display: block;
  height: auto;
  padding: 0;
  box-sizing: border-box;
  overflow: hidden;
}

.coaching-side-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.coaching-side-bar {
  background: var(--dark-bar);
  color: var(--white);
  text-align: center;
  padding: 10px 12px;
  font-size: 25px;
  font-weight: 400;
  font-family: 'alef-regular', 'Alef', sans-serif;
  text-decoration: none;
  border-top: var(--tile-border);
  border-bottom: var(--tile-border);
  margin-top: 0;
  flex-shrink: 0;
}

.coaching-tile {
  position: relative;
  display: block;
  height: var(--coaching-gallery-h);
  background: transparent;
}

.coaching-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.coaching-grid-3 > .coaching-feedback-col {
  display: flex;
  flex-direction: column;
  height: var(--coaching-gallery-h);
  max-height: var(--coaching-gallery-h);
  min-height: var(--coaching-gallery-h);
  overflow: hidden;
}

.coaching-testimonial-slideshow {
  flex: 1 1 0;
  min-height: 0;
  height: 100%;
  position: relative;
}

.coaching-testimonial-slideshow .slideshow-slide {
  background: transparent;
  transition: none;
  overflow: hidden;
}

.coaching-testimonial-slideshow .slideshow-slide:not(.is-active) {
  visibility: hidden;
  opacity: 0;
  z-index: 0;
}

.coaching-testimonial-slideshow .slideshow-slide.is-active {
  visibility: visible;
  opacity: 1;
  z-index: 1;
}

.coaching-testimonial-inner {
  width: 100%;
  height: auto;
  padding: 4px 8px 3px;
  font-size: var(--coaching-testimonial-font, 10px);
  line-height: var(--coaching-testimonial-line, 1.06);
  text-align: right;
  direction: rtl;
  color: #222222;
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-weight: 400;
  overflow: visible;
  box-sizing: border-box;
}

.coaching-testimonial-inner.text-tile p,
.coaching-testimonial-inner p {
  font-size: inherit;
  line-height: inherit;
  margin: 0;
}

.coaching-feedback-col {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

.coaching-grid-3-back {
  display: grid;
  grid-template-columns:
    var(--coaching-testimonial-col-w)
    var(--coaching-gallery-col-w)
    var(--coaching-gallery-col-w);
  direction: ltr;
  width: 100%;
}

.coaching-grid-3-back .coaching-page-back--below-grid {
  grid-column: 1;
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0;
  text-align: left;
  direction: ltr;
}

.coaching-footer-cta {
  width: 100vw;
  max-width: 100vw;
  margin: 14px calc(50% - 50vw) 42px;
  padding: 34px 0 31px;
  background: rgba(250, 250, 250, 0.85);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.6);
  border: none;
  text-align: center;
  direction: rtl;
}

.coaching-footer-cta-rule {
  display: block;
  width: var(--container);
  max-width: calc(100% - 32px);
  height: 1px;
  border: none;
  background: #222222;
  margin: 0 auto 15px;
}

.coaching-footer-cta-rule--bottom {
  margin: 11px auto 0;
}

.coaching-footer-cta-inner {
  width: var(--container);
  max-width: calc(100% - 32px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.coaching-footer-cta-inner h3,
.coaching-footer-cta-inner p {
  max-width: 530px;
  width: 100%;
  text-align: center;
}

.coaching-footer-cta h3 {
  font-size: 30px;
  font-weight: 700;
  line-height: normal;
  margin: 0;
  color: var(--text);
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.coaching-footer-cta p {
  font-size: 16px;
  font-weight: 400;
  line-height: normal;
  margin: 0;
  color: var(--text);
  font-family: 'alef-regular', 'Alef', sans-serif;
}

/* Page slideshows */
.page-slideshow {
  position: relative;
  overflow: hidden;
  background: #111;
}

.lesson-feedback-text.page-slideshow {
  background: transparent;
}

.coaching-testimonial-slideshow.page-slideshow {
  background: transparent;
  overflow: hidden;
  height: 100%;
}

.coaching-testimonial-slideshow.page-slideshow .slideshow-slide {
  background: transparent;
}

.slideshow-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.8s ease;
  z-index: 0;
}

.slideshow-slide.is-active {
  opacity: 1;
  z-index: 1;
}

.slideshow-slide img {
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center;
  display: block;
}

.slideshow-counter {
  position: absolute;
  left: 10px;
  bottom: 8px;
  color: var(--white);
  font-size: 12px;
  z-index: 2;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.6);
}

/* Private lesson page */
.lesson-mesh {
  background: transparent;
  overflow: visible;
  margin-bottom: var(--section-gap);
}

.lesson-hero-block .section-bar,
.lesson-body-block .section-bar {
  margin: 0;
  border: var(--tile-border);
}

.lesson-hero-slideshow {
  border: var(--tile-border);
  border-top: none;
  height: var(--lesson-hero-h);
  min-height: var(--lesson-hero-h);
  position: relative;
}

.lesson-page--visual-design {
  width: var(--container);
  max-width: 100%;
}

.lesson-page--visual-design .lesson-hero-block {
  display: block;
  width: 100%;
}

.lesson-page--visual-design .lesson-hero-slideshow {
  width: 100%;
  height: var(--lesson-hero-h);
  min-height: var(--lesson-hero-h);
  display: block;
  position: relative;
}

.lesson-page--visual-design .lesson-body-block {
  width: 100%;
}

.lesson-page--visual-design .lesson-grid-2 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) minmax(0, 1fr);
  direction: ltr;
  gap: 0;
  width: 100%;
  align-items: stretch;
}

.lesson-page--visual-design .lesson-side-col--photo-only {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: var(--lesson-side-h);
}

.lesson-page--visual-design .lesson-side-col:not(.lesson-side-col--photo-only) {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: var(--lesson-side-h);
  height: var(--lesson-side-h);
}

.lesson-page--visual-design .lesson-side-col:not(.lesson-side-col--photo-only) .lesson-side-slideshow {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
}

.lesson-page--visual-design .lesson-side-col .lesson-side-bar {
  border: var(--tile-border);
  box-sizing: border-box;
  width: 100%;
  margin-top: 0;
  flex-shrink: 0;
}

.lesson-page--visual-design .lesson-side-col--photo-only .lesson-side-slideshow {
  flex: 1 1 auto;
  height: var(--lesson-side-h);
  min-height: var(--lesson-side-h);
}

.lesson-page--visual-design .lesson-intro {
  min-height: var(--lesson-side-h);
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 18px 22px 14px;
  box-sizing: border-box;
}

.lesson-page--visual-design .lesson-intro.text-tile p {
  line-height: normal;
  margin: 0;
}

.lesson-page--visual-design .lesson-intro p.pink {
  margin-top: 16px;
}

.lesson-page--visual-design .lesson-intro p.lesson-intro-break {
  margin-top: 16px;
}

.lesson-page--visual-design .lesson-intro .lesson-contact-row {
  margin-top: auto;
  padding-top: 10px;
}

.lesson-page--visual-design .lesson-grid-3 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) 1fr 1fr;
  grid-template-rows: var(--lesson-tile-h);
  direction: ltr;
  gap: 0;
  width: 100%;
  align-items: stretch;
}

.lesson-page--visual-design .lesson-feedback-col,
.lesson-page--visual-design .lesson-feedback-col--with-bar,
.lesson-page--visual-design .lesson-tile-slideshow {
  min-height: var(--lesson-tile-h);
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
}

.lesson-page--visual-design .lesson-feedback-col,
.lesson-page--visual-design .lesson-feedback-col--with-bar {
  display: flex;
  flex-direction: column;
}

.lesson-page--visual-design .lesson-feedback-col .lesson-feedback-text,
.lesson-page--visual-design .lesson-feedback-col--with-bar .lesson-feedback-text {
  flex: 1 1 auto;
  min-height: 0;
}

.lesson-page--visual-design .lesson-feedback-col--with-bar .lesson-page-back {
  margin: 0;
  padding: 6px 8px 8px;
  flex-shrink: 0;
  text-align: left;
  direction: ltr;
}

.lesson-page--visual-design .lesson-intro .lesson-schedule {
  margin-top: 10px;
  color: #222;
}

.lesson-page--visual-design .lesson-contact-item[href^="mailto"] span {
  color: #222222;
}

.lesson-page--visual-design .lesson-feedback-col--with-bar > .lesson-side-bar {
  border: var(--tile-border);
  box-sizing: border-box;
}

.lesson-page--visual-design .lesson-side-col--photo-only .lesson-side-slideshow {
  flex: 1 1 auto;
  height: 100%;
  min-height: var(--lesson-side-h);
}

.lesson-page--visual-design .lesson-hero-slideshow img,
.lesson-page--visual-design .lesson-side-slideshow img,
.lesson-page--visual-design .lesson-tile-slideshow img {
  object-fit: cover;
}

.lesson-page--visual-design .lesson-intro-lead {
  font-size: 18px;
  font-weight: 400;
  color: #fafafa;
  line-height: normal;
  margin: 0 0 8px;
}

.lesson-page--visual-design .lesson-intro.text-tile h2,
.lesson-page--visual-design .lesson-intro.text-tile .lesson-intro-lead {
  color: #fafafa;
}

.lesson-page--visual-design .lesson-intro p.pink,
.lesson-page--visual-design .lesson-intro .lesson-schedule.pink {
  color: var(--pink);
}

.lesson-page--visual-design .lesson-intro .lesson-schedule:not(.pink) {
  color: #222;
}

.lesson-page--visual-design .lesson-intro p.lesson-subhead:not(.pink) {
  color: #222;
  margin-top: 16px;
}

.lesson-page--visual-design .lesson-intro p.pink a {
  color: var(--pink);
  text-decoration: none;
}

.lesson-page--visual-design .lesson-intro p.pink a:hover {
  text-decoration: underline;
}

.lesson-page--visual-design .lesson-feedback-text {
  height: 100%;
  min-height: 0;
  flex: 1 1 0;
}

.lesson-page--visual-design .lesson-feedback-text.testimonial-slideshow .slideshow-slide {
  transition: none;
}

.lesson-page--visual-design .lesson-feedback-text.testimonial-slideshow .slideshow-slide:not(.is-active) {
  visibility: hidden;
  opacity: 0;
}

.lesson-page--visual-design .lesson-feedback-text-inner {
  overflow: visible;
  height: auto;
  padding: 8px 10px 6px;
  font-size: var(--lesson-visual-design-feedback-font, 11px);
  line-height: var(--lesson-visual-design-feedback-line, 1.06);
  text-align: right;
  direction: rtl;
}

.lesson-page--visual-design .lesson-feedback-text-inner.text-tile p,
.lesson-page--visual-design .lesson-feedback-text-inner p {
  font-size: inherit;
  line-height: inherit;
  margin: 0;
}

.lesson-page--visual-design .business-clients-section {
  width: 100%;
  margin-top: var(--section-gap);
  margin-bottom: 0;
  border: var(--tile-border);
  border-top: none;
  background: var(--white);
}

main > .lesson-mesh.page-mesh {
  margin-left: auto;
  margin-right: auto;
}

.lesson-page--visual-design .lesson-back-link {
  background: var(--yellow);
  border: 3px solid rgb(250, 250, 250);
  border-radius: 0;
  font-size: 18px;
  letter-spacing: 0.02em;
}

.lesson-page--promotional-events .lesson-intro,
.lesson-page--promotional-events .lesson-intro.text-tile,
.lesson-page--promotional-events .lesson-intro.text-tile h2,
.lesson-page--promotional-events .lesson-intro.text-tile p {
  text-align: center;
}

.lesson-page--promotional-events .lesson-intro h2.lesson-intro-hero {
  color: #fafafa;
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 6px;
}

.lesson-page--promotional-events .lesson-intro p.lesson-intro-opening {
  font-size: 15px;
  font-weight: 400;
  color: #222;
  margin: 0 0 8px;
}

.lesson-page--promotional-events .lesson-intro .lesson-contact-row {
  justify-content: center;
}

.lesson-page--promotional-events .lesson-side-col .lesson-side-bar {
  border-top: var(--tile-border);
  border-left: none;
  border-right: none;
  border-bottom: none;
  width: 100%;
  box-sizing: border-box;
}

.lesson-page--promotional-events .lesson-grid-3-back > .lesson-page-back--below-grid {
  grid-column: 1;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 6px 8px 8px;
  border: var(--tile-border);
  border-top: none;
  box-sizing: border-box;
  text-align: left;
  direction: ltr;
}

.lesson-page--promotional-events .lesson-grid-3-back .lesson-back-link {
  border: none;
  background: var(--yellow);
}

/* Course workshop pages (tables & culture, home styling courses) */
.lesson-page--tables-culture {
  width: var(--container);
  max-width: 100%;
}

.lesson-page--tables-culture .lesson-grid-2 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) minmax(0, 1fr);
  direction: ltr;
  gap: 0;
  align-items: stretch;
}

.lesson-page--tables-culture .lesson-side-col {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: var(--lesson-side-h);
  align-self: stretch;
  overflow: hidden;
}

.lesson-page--tables-culture .lesson-side-slideshow {
  flex: 1 1 0;
  min-height: 0;
  height: auto;
  position: relative;
}

.lesson-page--tables-culture .lesson-side-slideshow .slideshow-slide,
.lesson-page--tables-culture .lesson-side-slideshow img {
  height: 100%;
}

.lesson-page--tables-culture .lesson-side-bar {
  margin-top: 0;
  flex-shrink: 0;
}

.lesson-page--tables-culture .lesson-side-slideshow img {
  object-fit: cover;
  object-position: center 22%;
}

.lesson-page--tables-culture .lesson-intro {
  text-align: center;
  direction: rtl;
  padding: 16px 18px 12px;
  line-height: 1.35;
  height: auto;
  min-height: var(--lesson-side-h);
  align-self: stretch;
}

.lesson-page--tables-culture .lesson-grid-3 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) 1fr 1fr;
  grid-template-rows: auto;
  direction: ltr;
  gap: 0;
  align-items: stretch;
}

.lesson-page--tables-culture .lesson-grid-3 > .lesson-tile-slideshow {
  height: auto;
  min-height: var(--lesson-tile-h);
  max-height: none;
  overflow: hidden;
}

.lesson-page--tables-culture .lesson-feedback-col {
  display: flex;
  flex-direction: column;
  min-height: var(--lesson-tile-h);
  height: auto;
  background: rgba(198, 181, 93, 0.65);
  overflow: visible;
}

.lesson-page--tables-culture .lesson-feedback-col .lesson-feedback-text {
  flex: 1 1 auto;
  min-height: 0;
  overflow: visible;
  height: auto;
  background: transparent;
}

.lesson-page--tables-culture .lesson-feedback-text.page-slideshow {
  overflow: visible;
  height: auto;
}

.lesson-page--tables-culture .lesson-feedback-text .slideshow-slide {
  background: transparent;
  position: relative;
  inset: auto;
  height: auto;
  overflow: visible;
}

.lesson-page--tables-culture .lesson-feedback-text .slideshow-slide.is-active {
  opacity: 1;
  z-index: 1;
}

.lesson-page--tables-culture .lesson-feedback-text-inner {
  height: auto;
  overflow: visible;
  width: 100%;
  padding: 6px 8px 8px;
  font-size: 13px;
  line-height: 1.25;
  color: #222222;
  text-align: right;
  direction: rtl;
  box-sizing: border-box;
}

.lesson-page--tables-culture .lesson-feedback-text-inner.text-tile p,
.lesson-page--tables-culture .lesson-feedback-text-inner p {
  font-size: 13px;
  line-height: 1.25;
  margin: 0;
}

.lesson-page--tables-culture .lesson-feedback-text-inner p.lesson-feedback-spacer {
  font-size: 8px;
  line-height: 8px;
  height: 8px;
  margin: 0;
  padding: 0;
}

.lesson-page--tables-culture .lesson-page-back--below-grid {
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0;
  text-align: left;
  direction: ltr;
}

.lesson-page--table-set .lesson-page-back--below-grid {
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0;
  text-align: left;
  direction: ltr;
}

/* פותחים שולחן — tables-culture centered layout */
.lesson-page--tables-culture.lesson-page--table-set .lesson-intro,
.lesson-page--tables-culture.lesson-page--table-set .lesson-intro.text-tile,
.lesson-page--tables-culture.lesson-page--table-set .lesson-intro.text-tile h2,
.lesson-page--tables-culture.lesson-page--table-set .lesson-intro.text-tile p {
  text-align: center;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-intro h2.lesson-intro-hero {
  color: #fafafa;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 700;
  margin: 0 0 6px;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-intro .lesson-contact-row {
  justify-content: center;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-intro p:has(.btn-pink) {
  text-align: center;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-side-slideshow img {
  object-fit: cover;
  object-position: center 12%;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-grid-3 > .lesson-tile-slideshow:nth-child(2) img {
  object-fit: cover;
  object-position: center 55%;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-grid-3 > .lesson-tile-slideshow:nth-child(3) img {
  object-fit: cover;
  object-position: center 45%;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-feedback-text-inner {
  font-size: 12px;
  line-height: 1.55;
  padding: 8px 10px 4px;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-feedback-text-inner p {
  margin: 0 0 6px;
}

.lesson-static-photo {
  position: relative;
  overflow: hidden;
  background: #111;
}

.lesson-static-photo img {
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center;
  display: block;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-back-link {
  background: var(--yellow);
  border: 3px solid rgb(250, 250, 250);
  color: #222;
  border-radius: 0;
  padding: 4px 10px;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  display: inline-block;
}

.lesson-page--tables-culture.lesson-page--table-set .lesson-back-link .lesson-back-arrow {
  color: var(--pink);
  font-weight: 700;
  font-size: 25px;
}

.lesson-grid-3-back {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) 1fr 1fr;
  direction: ltr;
  width: 100%;
  gap: 0;
  margin: 0;
  padding: 0;
}

.lesson-grid-3-back .lesson-back-slot {
  grid-column: 1;
  border: var(--tile-border);
  border-top: none;
  padding: 6px 8px 8px;
  text-align: left;
  direction: ltr;
  box-sizing: border-box;
}

.lesson-grid-3-back .lesson-back-slot .lesson-page-back--below-grid {
  margin: 0;
  padding: 0;
  width: auto;
}

.lesson-grid-3-back > .lesson-page-back--below-grid {
  grid-column: 1;
  width: auto;
  max-width: none;
  margin: 0;
  margin-inline: 0;
  padding: 0;
  justify-self: start;
}

.lesson-page--tables-culture .lesson-intro.text-tile h2,
.lesson-page--tables-culture .lesson-intro.text-tile p {
  text-align: center;
}

.lesson-page--tables-culture .lesson-intro .lesson-contact-row {
  justify-content: center;
}

.lesson-page--tables-culture .lesson-intro h2 {
  font-size: 22px;
  line-height: 1.2;
  margin-bottom: 4px;
}

.lesson-page--tables-culture .lesson-intro p {
  font-size: 13px;
  line-height: 1.35;
  margin-bottom: 2px;
}

.lesson-page--tables-culture .lesson-intro p.lesson-subhead {
  font-size: 15px;
}

.lesson-page--tables-culture .lesson-intro .lesson-schedule {
  font-size: 14px;
  margin-top: 4px;
}

.lesson-page--event-consulting .lesson-intro {
  min-height: var(--lesson-side-h);
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: 18px 22px 14px;
}

.lesson-page--event-consulting .lesson-intro h2 {
  margin: 0 0 8px;
}

.lesson-page--event-consulting .lesson-intro.text-tile p {
  line-height: normal;
  margin: 0;
}

.lesson-page--event-consulting .lesson-intro p.lesson-subhead {
  margin-top: 16px;
}

.lesson-page--event-consulting .lesson-intro p.pink:not(.lesson-subhead),
.lesson-page--event-consulting .lesson-intro p.lesson-intro-closing {
  margin-top: 16px;
  color: var(--pink);
}

.lesson-page--event-consulting .lesson-intro .lesson-contact-row {
  margin-top: auto;
  padding-top: 12px;
  justify-content: center;
}

.lesson-page--styling-photography {
  width: var(--container);
  max-width: 100%;
}

.lesson-page--styling-photography .lesson-hero-block,
.lesson-page--styling-photography .lesson-body-block {
  width: 100%;
}

.lesson-page--styling-photography .lesson-hero-slideshow {
  width: 100%;
  height: var(--lesson-hero-h);
  min-height: var(--lesson-hero-h);
  display: block;
  position: relative;
}

.lesson-page--styling-photography .lesson-grid-2 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) minmax(0, 1fr);
  direction: ltr;
  align-items: stretch;
}

.lesson-page--styling-photography .lesson-side-col--photo-only {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: var(--lesson-side-h);
}

.lesson-page--styling-photography .lesson-side-col:not(.lesson-side-col--photo-only) {
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-height: var(--lesson-side-h);
  height: var(--lesson-side-h);
}

.lesson-page--styling-photography .lesson-side-col:not(.lesson-side-col--photo-only) .lesson-side-slideshow {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
}

.lesson-page--styling-photography .lesson-side-col .lesson-photo-credit {
  border: var(--tile-border);
  box-sizing: border-box;
  width: 100%;
  margin-top: 0;
  flex-shrink: 0;
}

.lesson-page--styling-photography .lesson-side-col--photo-only .lesson-side-slideshow {
  flex: 1 1 auto;
  height: var(--lesson-side-h);
  min-height: var(--lesson-side-h);
}

.lesson-page--styling-photography .lesson-intro {
  min-height: var(--lesson-side-h);
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 18px 22px 14px;
  box-sizing: border-box;
}

.lesson-page--styling-photography .lesson-intro.text-tile p {
  line-height: normal;
  margin: 0;
}

.lesson-page--styling-photography .lesson-intro p.lesson-subhead.pink {
  margin-top: 16px;
}

.lesson-page--styling-photography .lesson-intro p.lesson-schedule {
  margin-top: 16px;
}

.lesson-page--styling-photography .lesson-intro p.lesson-intro-break {
  margin-top: 16px;
}

.lesson-page--styling-photography .lesson-intro .lesson-contact-row {
  margin-top: auto;
  padding-top: 10px;
}

.lesson-page--styling-photography .lesson-intro-lead {
  font-size: 20px;
  font-weight: 700;
  color: #fafafa;
  margin: 0 0 8px;
}

.lesson-page--styling-photography .lesson-grid-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: var(--lesson-tile-h);
  direction: ltr;
  align-items: stretch;
}

.lesson-page--styling-photography .lesson-tile-slideshow {
  min-height: var(--lesson-tile-h);
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
}

.lesson-page--styling-photography .lesson-hero-slideshow img,
.lesson-page--styling-photography .lesson-side-slideshow img,
.lesson-page--styling-photography .lesson-tile-slideshow img {
  object-fit: cover;
  object-position: center;
}

.lesson-page--styling-photography .lesson-intro p.pink,
.lesson-page--styling-photography .lesson-intro .lesson-schedule {
  color: var(--pink);
}

.lesson-photo-credit {
  background: #222;
  color: #fff;
  text-align: right;
  direction: rtl;
  padding: 9px 18px;
  font-size: 15px;
  border: var(--tile-border);
  border-top: none;
}

.lesson-page--styling-photography .business-clients-section {
  width: 100%;
  margin-top: var(--section-gap);
  margin-bottom: 0;
  border: var(--tile-border);
  border-top: none;
  background: var(--white);
}

.lesson-page--styling-photography .lesson-grid-3-back {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  direction: ltr;
  width: 100%;
}

.lesson-page--styling-photography .lesson-grid-3-back .lesson-page-back--below-grid {
  grid-column: 1;
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0;
  text-align: left;
  direction: ltr;
}

.lesson-page--styling-photography .lesson-page-back {
  padding: 8px 0;
  text-align: left;
  direction: ltr;
}

.lesson-page--styling-photography .lesson-back-link {
  background: var(--yellow);
  border: 3px solid rgb(250, 250, 250);
  border-radius: 0;
  font-size: 18px;
  letter-spacing: 0.02em;
}

.lesson-page--home-styling {
  width: var(--container);
  max-width: 100%;
}

.lesson-page--home-styling .lesson-hero-block {
  display: block;
  width: 100%;
}

.lesson-page--home-styling .lesson-hero-slideshow {
  width: 100%;
  height: var(--lesson-hero-h);
  min-height: var(--lesson-hero-h);
  display: block;
  position: relative;
}

.lesson-page--home-styling .lesson-body-block {
  width: 100%;
}

.lesson-page--home-styling .lesson-grid-2 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) minmax(0, 1fr);
  direction: ltr;
  align-items: stretch;
}

.lesson-page--home-styling .lesson-grid-3 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) 1fr 1fr;
  grid-template-rows: var(--lesson-tile-h);
  direction: ltr;
  align-items: stretch;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro {
  height: var(--lesson-side-h);
  min-height: var(--lesson-side-h);
  max-height: var(--lesson-side-h);
  align-self: stretch;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: 18px 22px 14px;
  text-align: right;
  direction: rtl;
  overflow: hidden;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro .lesson-contact-row {
  margin-top: auto;
  padding-top: 8px;
  justify-content: flex-start;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro.text-tile,
.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro.text-tile h2,
.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro.text-tile p {
  text-align: right;
  line-height: normal;
  margin-bottom: 0;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro {
  min-height: var(--lesson-side-h);
  height: auto;
  max-height: none;
  align-self: stretch;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  padding: 14px 18px 12px;
  text-align: center;
  direction: rtl;
  overflow: visible;
  line-height: 1.35;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro.text-tile h2.lesson-intro-hero {
  font-size: 22px;
  font-weight: 700;
  color: #fafafa;
  line-height: 1.25;
  margin: 0 0 4px;
  text-align: center;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p.lesson-intro-opening {
  font-size: 16px;
  font-weight: 400;
  color: #222222;
  line-height: 1.3;
  margin: 0 0 6px;
  text-align: center;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro.text-tile p {
  font-size: 13px;
  line-height: 1.3;
  text-align: center;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p.lesson-subhead {
  font-size: 16px;
  margin-top: 2px;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p.lesson-schedule {
  font-size: 15px;
  margin-top: 6px;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p:has(.btn-pink) {
  margin-top: auto;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro .btn-pink {
  margin-top: 0;
  margin-bottom: 4px;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro .lesson-contact-row {
  justify-content: center;
  margin-top: 4px;
  padding-top: 0;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro .lesson-contact-item {
  font-size: 12px;
  line-height: 1.6;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro .lesson-contact-row {
  margin-top: auto;
  padding-top: 8px;
  justify-content: flex-start;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro.text-tile,
.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro.text-tile h2,
.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro.text-tile p {
  text-align: right;
  line-height: normal;
  margin-bottom: 0;
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-intro-accent {
  font-size: 18px;
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-intro-body {
  font-size: 15px;
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-schedule {
  font-size: 18px;
  line-height: normal;
}

.lesson-page--home-styling .lesson-intro .lesson-contact-item {
  font-size: 13px;
  line-height: 2em;
  color: #222222;
}

.lesson-page--home-styling .lesson-intro.text-tile h2.lesson-intro-hero {
  font-size: 25px;
  font-weight: 700;
  color: #fafafa;
  line-height: normal;
  margin: 0 0 6px;
  text-align: right;
}

.lesson-page--home-styling .lesson-intro-hero {
  font-size: 25px;
  font-weight: 700;
  color: #fafafa;
  line-height: normal;
  margin: 0 0 6px;
  text-align: right;
}

.lesson-page--home-styling .lesson-intro-opening {
  font-size: 20px;
  font-weight: 400;
  color: #222222;
  line-height: normal;
  text-align: right;
}

.lesson-page--home-styling .lesson-intro-accent {
  font-size: 18px;
  font-weight: 700;
  line-height: normal;
  text-align: right;
  color: var(--pink);
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-intro-accent:first-of-type {
  margin-top: 4px;
}

.lesson-page--home-styling .lesson-intro-body {
  font-size: 15px;
  color: #222222;
  line-height: normal;
  text-align: right;
}

.lesson-page--home-styling .lesson-intro-body.lesson-section-head {
  font-weight: 700;
  color: #222222;
  font-size: 15px;
  margin-top: 5px;
}

.lesson-page--home-styling .lesson-intro-body.lesson-services-head {
  font-weight: 700;
  color: #222222;
  font-size: 15px;
  margin-top: 5px;
}

.lesson-page--home-styling .lesson-intro .lesson-schedule {
  font-size: 18px;
  color: #222222;
  line-height: normal;
}

.lesson-page--home-styling .lesson-hero-slideshow img {
  object-fit: cover;
  object-position: center 30%;
}

.lesson-page--home-styling .lesson-side-slideshow img {
  object-fit: cover;
  object-position: 52% 10%;
}

.lesson-page--home-styling .lesson-side-bar {
  margin-top: 0;
  font-size: 15px;
  width: 100%;
  box-sizing: border-box;
}

.lesson-page--home-styling .lesson-grid-3 > .lesson-tile-slideshow:nth-child(2) img {
  object-fit: cover;
  object-position: center 45%;
}

.lesson-page--home-styling .lesson-grid-3 > .lesson-tile-slideshow:nth-child(3) img {
  object-fit: cover;
  object-position: center 40%;
}

.lesson-page--home-styling .lesson-tile-slideshow {
  min-height: var(--lesson-tile-h);
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
}

.lesson-page--home-styling .lesson-side-col {
  display: flex;
  flex-direction: column;
  height: var(--lesson-side-h);
  min-height: var(--lesson-side-h);
  max-height: var(--lesson-side-h);
  overflow: hidden;
}

.lesson-page--home-styling-course .lesson-side-col {
  height: 100%;
  min-height: var(--lesson-side-h);
  max-height: none;
  align-self: stretch;
}

.lesson-page--home-styling-course .lesson-side-col .lesson-side-bar {
  border-top: var(--tile-border);
  border-left: none;
  border-right: none;
  border-bottom: none;
  flex-shrink: 0;
}

.lesson-page--home-styling .lesson-side-slideshow {
  flex: 1 1 auto;
  height: auto;
  min-height: 0;
  max-height: none;
}

.lesson-page--home-styling .lesson-feedback-col {
  display: flex;
  flex-direction: column;
  background: var(--yellow);
  min-height: var(--lesson-tile-h);
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
}

.lesson-page--home-styling .lesson-feedback-col--with-bar {
  background: transparent;
}

.lesson-page--home-styling .lesson-feedback-col--with-bar .lesson-feedback-text {
  background: rgba(198, 181, 93, 0.65);
}

.lesson-page--home-styling .lesson-feedback-text {
  flex: 1 1 0;
  min-height: 0;
  height: 100%;
  overflow: hidden;
  background: transparent;
}

.lesson-page--home-styling .lesson-feedback-text.testimonial-slideshow .slideshow-slide {
  transition: none;
}

.lesson-page--home-styling .lesson-feedback-text .slideshow-slide {
  background: transparent;
}

.lesson-page--home-styling-service .lesson-intro {
  height: auto;
  min-height: var(--lesson-side-h);
  max-height: none;
  align-self: stretch;
  text-align: center;
  overflow: visible;
  padding: 14px 20px 12px;
}

.lesson-page--home-styling-service .lesson-side-col {
  height: auto;
  min-height: var(--lesson-side-h);
  max-height: none;
  align-self: stretch;
}

.lesson-page--home-styling-service .lesson-intro.text-tile,
.lesson-page--home-styling-service .lesson-intro.text-tile h2,
.lesson-page--home-styling-service .lesson-intro.text-tile p {
  text-align: center;
  line-height: 1.2;
  margin-bottom: 0;
}

.lesson-page--home-styling-service .lesson-intro.text-tile h2.lesson-intro-hero {
  text-align: center;
}

.lesson-page--home-styling-service .lesson-intro.text-tile p.lesson-intro-opening {
  font-size: 18px;
}

.lesson-page--home-styling-service .lesson-intro.text-tile p.lesson-intro-accent {
  font-size: 17px;
}

.lesson-page--home-styling-service .lesson-intro.text-tile p.lesson-intro-body {
  font-size: 14px;
}

.lesson-page--home-styling-service .lesson-intro.text-tile p.lesson-schedule {
  font-size: 17px;
}

.lesson-page--home-styling-service .lesson-intro .lesson-contact-row {
  justify-content: center;
  margin-top: auto;
  padding-top: 8px;
}

.lesson-page--home-styling .lesson-feedback-text-inner {
  padding: 4px 8px 3px;
  font-size: var(--lesson-home-styling-feedback-font, 12px);
  line-height: var(--lesson-home-styling-feedback-line, 1.12);
  text-align: right;
  direction: rtl;
  height: auto;
  overflow: visible;
}

.lesson-page--home-styling .lesson-feedback-text-inner.text-tile p,
.lesson-page--home-styling .lesson-feedback-text-inner p {
  font-size: inherit;
  line-height: inherit;
  margin: 0;
  text-align: right;
  color: #222222;
}

.lesson-page--home-styling .lesson-feedback-text-inner p:first-child {
  color: #222222;
  font-weight: 400;
}

.lesson-page--home-styling .lesson-grid-3 > .lesson-feedback-col {
  border-left: var(--tile-border);
  border-right: var(--tile-border);
  border-bottom: var(--tile-border);
  border-top: none;
  box-sizing: border-box;
}

.lesson-page--home-styling .lesson-grid-3-back .lesson-back-slot,
.lesson-page--home-styling .lesson-grid-3-back > .lesson-page-back--below-grid {
  grid-column: 1;
  width: auto;
  max-width: none;
  margin: 0;
  padding: 0 0 8px;
  border: none;
  background: transparent;
  box-sizing: border-box;
  text-align: left;
  direction: ltr;
  justify-self: start;
}

.lesson-page--home-styling .lesson-grid-3-back .lesson-back-slot .lesson-page-back--below-grid {
  margin: 0;
  padding: 0;
  width: auto;
  border: none;
  background: transparent;
}

.lesson-page--home-styling .lesson-back-link {
  background: var(--yellow);
  border: 3px solid rgb(250, 250, 250);
  border-radius: 0;
  font-size: 18px;
  letter-spacing: 0.02em;
  text-decoration: none;
  display: inline-block;
}

.lesson-page--home-styling .lesson-back-link .lesson-back-arrow {
  color: var(--pink);
  font-weight: 700;
}

.lesson-page--home-styling .lesson-back-link:hover {
  color: #222222;
  opacity: 0.92;
}

.lesson-page--home-styling .lesson-contact-item span {
  color: #222222;
}

.lesson-page--home-styling-course .lesson-hero-block .section-bar {
  font-size: 20px;
  line-height: 1.35;
  letter-spacing: 0.05em;
  white-space: normal;
  padding: 10px 14px;
}

.lesson-page--home-styling-course .lesson-intro,
.lesson-page--home-styling-course .lesson-intro h2,
.lesson-page--home-styling-course .lesson-intro p,
.lesson-page--home-styling-course .lesson-intro.text-tile,
.lesson-page--home-styling-course .lesson-intro.text-tile h2,
.lesson-page--home-styling-course .lesson-intro.text-tile p,
.lesson-page--home-styling-course .lesson-intro-hero,
.lesson-page--home-styling-course .lesson-intro-opening,
.lesson-page--home-styling-course .lesson-intro-accent,
.lesson-page--home-styling-course .lesson-intro-body {
  text-align: center;
}

.lesson-page--home-styling-course .lesson-intro .lesson-contact-row {
  justify-content: center;
}

.lesson-hero-slideshow .slideshow-slide,
.lesson-hero-slideshow img {
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

.lesson-body-block {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.lesson-grid-2 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) minmax(0, 1fr);
  direction: ltr;
  gap: 0;
  align-items: stretch;
}

.lesson-grid-3 {
  display: grid;
  grid-template-columns: var(--lesson-col-narrow) 1fr 1fr;
  grid-template-rows: minmax(var(--lesson-tile-h), auto);
  direction: ltr;
  gap: 0;
  align-items: start;
}

.lesson-grid-2 > *,
.lesson-grid-3 > * {
  border: var(--tile-border);
  border-top: none;
}

.lesson-grid-3 > .lesson-tile-slideshow {
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
  overflow: hidden;
}

.lesson-intro {
  padding: 28px 32px;
  text-align: center;
  direction: rtl;
  background: var(--yellow);
  font-family: 'alef-regular', 'Alef', sans-serif;
  height: 100%;
  box-sizing: border-box;
}

.lesson-intro h2 {
  font-size: 25px;
  font-weight: 400;
  margin-bottom: 0;
  color: #fafafa;
  line-height: normal;
}

.lesson-intro h3,
.lesson-intro h3.pink {
  font-size: 18px;
  font-weight: 400;
  margin-bottom: 0;
  color: var(--pink);
  line-height: normal;
  letter-spacing: normal;
}

.lesson-intro p {
  font-size: 15px;
  line-height: normal;
  margin-bottom: 0;
  color: #222222;
}

.lesson-page--private-class .lesson-intro-spacer {
  height: 12px;
  font-size: 12px;
  line-height: normal;
  margin: 0;
}

.lesson-page--private-class .lesson-intro h2,
.lesson-page--private-class .lesson-intro h3,
.lesson-page--private-class .lesson-intro p {
  line-height: normal;
  margin-bottom: 0;
}

.lesson-page--private-class .lesson-contact-row {
  direction: ltr;
  gap: 24px;
}

.lesson-page--private-class .lesson-contact-item img {
  flex-shrink: 0;
}

/* Wix: feedback + tiles share 323px row; back link below feedback */
.lesson-page--private-class .lesson-grid-3 {
  grid-template-rows: var(--lesson-tile-h);
  align-items: stretch;
}

.lesson-page--private-class .lesson-grid-3 > .lesson-feedback-col {
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
  min-height: var(--lesson-tile-h);
  overflow: hidden;
  align-self: stretch;
}

.lesson-page--private-class .lesson-feedback-text {
  height: 100%;
  min-height: 0;
  flex: 1 1 0;
}

.lesson-page--private-class .lesson-feedback-text.testimonial-slideshow .slideshow-slide {
  transition: none;
}

.lesson-page--private-class .lesson-feedback-text.testimonial-slideshow .slideshow-slide:not(.is-active) {
  visibility: hidden;
  opacity: 0;
}

.lesson-page--private-class .lesson-feedback-text-inner {
  overflow: visible;
  height: auto;
  font-size: var(--lesson-private-feedback-font, 11px);
  line-height: var(--lesson-private-feedback-line, 1.06);
  padding: 4px 8px 3px;
}

.lesson-page--private-class .lesson-feedback-text-inner.text-tile p,
.lesson-page--private-class .lesson-feedback-text-inner p {
  font-size: inherit;
  line-height: inherit;
  margin: 0;
}

.lesson-page--private-class .lesson-grid-3 > .lesson-tile-slideshow {
  height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
  align-self: stretch;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course) .lesson-intro,
.lesson-page--home-styling:not(.lesson-page--home-styling-course) .lesson-intro h2,
.lesson-page--home-styling:not(.lesson-page--home-styling-course) .lesson-intro p {
  text-align: right;
}

.lesson-page--home-styling-course .lesson-intro,
.lesson-page--home-styling-course .lesson-intro h2,
.lesson-page--home-styling-course .lesson-intro p,
.lesson-page--home-styling-course .lesson-intro.text-tile,
.lesson-page--home-styling-course .lesson-intro.text-tile h2,
.lesson-page--home-styling-course .lesson-intro.text-tile p {
  text-align: center;
}

.lesson-page--home-styling-course .lesson-intro.text-tile h2.lesson-intro-hero {
  text-align: center;
}

.lesson-intro.yellow-box h3,
.yellow-box.lesson-intro h3 {
  font-size: 18px;
  color: var(--pink);
}

.lesson-intro p.lesson-subhead {
  margin-top: 0;
  font-size: 18px;
  color: var(--pink);
}

.lesson-intro p.lesson-subhead.lesson-subhead-services {
  font-size: 17px;
}

.lesson-intro p.lesson-gift-link {
  font-size: 18px;
}

.lesson-gift-link a {
  color: var(--pink);
  font-size: 18px;
}

.lesson-voucher {
  font-size: 12px;
  line-height: normal;
}

.lesson-voucher .voucher-open,
.lesson-voucher .voucher-action {
  color: var(--pink);
}

.lesson-voucher .voucher-label {
  color: #222222;
}

.lesson-contact-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin: 0;
}

.lesson-page--home-styling .lesson-intro.text-tile h2.lesson-intro-hero {
  font-size: 25px;
  font-weight: 700;
  color: #fafafa;
  line-height: normal;
  margin: 0 0 6px;
}

.lesson-page--home-styling .lesson-intro.text-tile p {
  line-height: normal;
  margin-bottom: 0;
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-intro-opening {
  font-size: 20px;
  font-weight: 400;
  color: #222222;
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-intro-accent {
  font-size: 18px;
  font-weight: 700;
  color: var(--pink);
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-intro-body {
  font-size: 15px;
  color: #222222;
}

.lesson-page--home-styling .lesson-intro.text-tile p.lesson-schedule {
  font-size: 18px;
  color: #222222;
  line-height: normal;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro {
  padding: 18px 22px 14px;
  text-align: right;
}

.lesson-page--home-styling:not(.lesson-page--home-styling-course):not(.lesson-page--home-styling-service) .lesson-intro .lesson-contact-row {
  justify-content: flex-start;
}

/* Course workshop page — centered intro footer visible. */
.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro {
  min-height: var(--lesson-side-h);
  height: auto;
  max-height: none;
  overflow: visible;
  text-align: center;
  direction: rtl;
  padding: 14px 18px 12px;
  line-height: 1.35;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro.text-tile h2.lesson-intro-hero {
  font-size: 22px;
  color: #fafafa;
  line-height: 1.25;
  margin: 0 0 4px;
  text-align: center;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p.lesson-intro-opening {
  font-size: 16px;
  font-weight: 400;
  color: #222222;
  line-height: 1.3;
  margin: 0 0 6px;
  text-align: center;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro.text-tile h2,
.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro.text-tile p,
.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p.lesson-subhead,
.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro p.lesson-schedule,
.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro strong {
  text-align: center;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro.text-tile p {
  font-size: 13px;
  line-height: 1.3;
}

.lesson-page--home-styling.lesson-page--home-styling-course .lesson-intro .lesson-contact-row {
  justify-content: center;
  margin-top: 4px;
  padding-top: 0;
}

.lesson-contact-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #222222;
  font-size: 18px;
  font-family: 'play', sans-serif;
  line-height: 2em;
}

.lesson-side-col {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  min-height: 100%;
}

.lesson-side-slideshow {
  flex: 1 1 auto;
  width: 100%;
  min-height: var(--lesson-side-h);
  height: auto;
  position: relative;
  overflow: hidden;
}

.lesson-side-col:not(.lesson-side-col--photo-only) .lesson-side-slideshow {
  min-height: calc(var(--lesson-side-h) - 37px);
}

.lesson-side-slideshow .slideshow-slide,
.lesson-side-slideshow img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

.lesson-side-bar {
  background: var(--dark-bar);
  color: var(--white);
  text-align: center;
  padding: 9px 12px;
  font-size: 15px;
  text-decoration: none;
  border-top: var(--tile-border);
  border-bottom: var(--tile-border);
  width: 100%;
  flex: 0 0 auto;
  margin-top: auto;
}

.lesson-side-col--photo-only .lesson-side-slideshow {
  flex: 1 1 auto;
  min-height: var(--lesson-side-h);
}

.lesson-feedback-col--with-bar {
  display: flex;
  flex-direction: column;
  background: var(--yellow);
}

.lesson-feedback-col--with-bar > .lesson-side-bar {
  margin-top: 0;
  border-top: none;
  flex-shrink: 0;
}

.lesson-feedback-col--with-bar .lesson-feedback-text {
  flex: 1 1 auto;
  min-height: 0;
}

.lesson-page-back {
  margin: 10px 0 0;
  padding: 6px 8px 8px;
  text-align: left;
  direction: ltr;
}

.lesson-page-back--below-grid {
  width: auto;
  max-width: none;
  margin: 0;
  margin-inline: 0;
  padding: 0;
  text-align: left;
  direction: ltr;
}

.lesson-back-link {
  display: inline-block;
  background: var(--yellow);
  border: 3px solid rgb(250, 250, 250);
  color: #222222;
  padding: 4px 10px;
  border-radius: 0;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  font-family: 'alef-regular', 'Alef', sans-serif;
  box-sizing: border-box;
  line-height: 1.2;
}

.lesson-back-link .lesson-back-arrow {
  color: var(--pink);
  font-weight: 700;
  font-size: 25px;
  line-height: 1;
}

.lesson-back-link:hover {
  color: #222222;
  opacity: 0.92;
}

.lesson-tile-slideshow {
  height: var(--lesson-tile-h);
  min-height: var(--lesson-tile-h);
  max-height: var(--lesson-tile-h);
  position: relative;
  overflow: hidden;
}

.lesson-tile-slideshow .slideshow-slide,
.lesson-tile-slideshow img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
}

.lesson-feedback-col {
  display: flex;
  flex-direction: column;
  position: relative;
  background: rgba(198, 181, 93, 0.65);
  height: 100%;
  overflow: hidden;
}

.lesson-feedback-col .lesson-feedback-text {
  flex: 1 1 auto;
  min-height: 0;
}

.lesson-feedback-col .lesson-page-back {
  margin-top: auto;
  margin-bottom: 0;
  flex-shrink: 0;
  padding: 6px 8px 8px;
  text-align: left;
  direction: ltr;
}

.lesson-feedback-text {
  height: 100%;
  position: relative;
  background: transparent;
}

.lesson-feedback-text .slideshow-slide {
  background: transparent;
}

.lesson-feedback-text-inner {
  height: 100%;
  padding: 10px 12px 12px;
  font-size: 11px;
  line-height: 1.35em;
  text-align: right;
  direction: rtl;
  color: var(--text);
  overflow: hidden;
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.lesson-feedback-text-inner p {
  margin-bottom: 4px;
}

.lesson-footer-block {
  margin-top: var(--section-gap);
}

.lesson-footer-panel {
  padding: 0;
}

.lesson-intro-only {
  border: var(--tile-border);
  border-top: none;
}

.lesson-intro-only .lesson-intro {
  min-height: auto;
}

.lesson-footer-cta-only {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  padding: 24px 32px 28px;
  text-align: center;
  direction: rtl;
}

.lesson-footer-cta-only h3 {
  font-size: 22px;
  margin-bottom: 12px;
  color: #222;
}

.lesson-footer-cta-only p {
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: 6px;
}

.lesson-footer-rule {
  border: none;
  border-top: 1px solid var(--black);
  margin: 0;
  height: 0;
}

.lesson-footer-panel .newsletter-inner {
  padding: 30px 36px 28px;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: 32px;
  align-items: start;
}

.lesson-footer-panel .newsletter-text-col h3 {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 6px;
}

.lesson-footer-panel .newsletter-text-col p {
  font-size: 19px;
  line-height: normal;
  margin-bottom: 0;
}

.lesson-footer-panel .newsletter-form .field-wrap {
  margin-bottom: 10px;
}

.lesson-footer-panel .newsletter-form input {
  padding: 10px 12px;
  font-size: 14px;
}

.lesson-footer-panel .newsletter-form button {
  margin-top: 2px;
}

/* Kinamon for Home page */
.kinamon-mesh {
  background: transparent;
  overflow: visible;
  display: flex;
  flex-direction: column;
  margin-bottom: var(--section-gap);
}

.kinamon-mesh:has(> .clients-section:last-child) {
  margin-bottom: 0;
}

.kinamon-mesh .section-bar {
  margin: 0;
  border: var(--tile-border);
  white-space: nowrap;
}

.kinamon-grid-row {
  display: grid;
  grid-template-columns: var(--kinamon-img-w) var(--kinamon-text-w);
  direction: rtl;
  gap: 0;
  width: var(--container);
  max-width: 100%;
}

.kinamon-grid-row--flip {
  direction: ltr;
}

.kinamon-grid-row .yellow-box,
.kinamon-grid-row .kinamon-img-tile {
  border: var(--tile-border);
  border-top: none;
}

.kinamon-grid-row .kinamon-img-tile {
  overflow: hidden;
  display: block;
  height: var(--kinamon-row-h);
}

.kinamon-grid-row--short .kinamon-img-tile,
.kinamon-grid-row--short .kinamon-service-box {
  height: var(--kinamon-row-h-short);
  min-height: var(--kinamon-row-h-short);
}

.kinamon-grid-row .kinamon-img-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.kinamon-service-box {
  padding: 18px 14px 14px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  height: var(--kinamon-row-h);
  min-height: var(--kinamon-row-h);
  direction: rtl;
  text-align: center;
  overflow: hidden;
}

.kinamon-service-title {
  font-size: 30px;
  font-weight: 400;
  color: #fafafa;
  line-height: normal;
  margin-bottom: 4px;
}

.kinamon-service-title-line {
  display: block;
}

.kinamon-service-title a {
  color: inherit;
  text-decoration: none;
}

.kinamon-service-lead,
.kinamon-service-box .kinamon-service-lead {
  font-family: 'alef-bold', 'Alef', 'alef-regular', sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: normal;
  color: var(--black);
  margin: 0 0 2px;
}

.yellow-box .kinamon-service-lead {
  color: var(--black);
}

.kinamon-service-spacer {
  height: 18px;
  margin: 0;
  font-size: 18px;
  line-height: normal;
}

.kinamon-service-spacer--sm {
  height: 13px;
  font-size: 13px;
}

.kinamon-service-spacer--xs {
  height: 8px;
  font-size: 8px;
}

.kinamon-service-box p {
  font-size: 15px;
  line-height: normal;
  margin-bottom: 2px;
  color: var(--black);
}

.kinamon-service-box .pink-line {
  width: 275px;
  max-width: 85%;
  height: 2px;
  background: var(--pink);
  margin-top: auto;
  margin-bottom: 6px;
  flex-shrink: 0;
}

.kinamon-service-footer {
  margin-top: auto;
  flex-shrink: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 10px;
}

.kinamon-service-footer .pink-line {
  margin-top: 0;
  margin-bottom: 6px;
}

.yellow-box.kinamon-service-box .pink-line {
  width: 275px;
  max-width: 85%;
  height: 2px;
  background: var(--pink);
  margin-top: auto;
  margin-bottom: 6px;
  flex-shrink: 0;
}

.kinamon-service-box .read-more {
  color: #fafafa;
  font-size: 20px;
  line-height: 1.4;
  text-decoration: none;
  flex-shrink: 0;
}

.kinamon-bottom-stripe {
  margin-bottom: 0;
}

.business-clients-section {
  width: var(--container);
  max-width: 100%;
  border: var(--tile-border);
  border-top: none;
}

.kinamon-mesh > .business-clients-section {
  margin-top: var(--section-gap);
  margin-bottom: var(--section-gap);
  border-top: var(--tile-border);
}

.kinamon-mesh > .clients-section {
  margin-bottom: var(--section-gap);
}

.footer-phone span {
  white-space: nowrap;
}

/* Media / כתבו עליי page */
.media-mesh {
  background: transparent;
  overflow: visible;
  display: flex;
  flex-direction: column;
  margin-bottom: var(--section-gap);
}

.media-block:first-child .media-section-bar {
  margin-top: 12px;
}

.media-block {
  margin-bottom: var(--section-gap);
}

.media-block:last-child {
  margin-bottom: 0;
}

.media-block + .media-block .media-section-bar {
  margin-top: 0;
}

.media-section-bar {
  background: var(--dark-bar);
  color: var(--white);
  text-align: center;
  padding: 10px 16px;
  border: var(--tile-border);
  box-sizing: border-box;
}

.media-section-bar h2 {
  font-size: 25px;
  font-weight: 400;
  font-family: 'alef-regular', 'Alef', sans-serif;
  line-height: normal;
  letter-spacing: normal;
}

.media-section-note {
  font-size: 12px;
  font-weight: 400;
  color: #fafafa;
}

.media-section-body {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  height: var(--media-gallery-h);
  min-height: 0;
  position: relative;
  margin-bottom: 0;
  overflow: hidden;
  box-sizing: border-box;
}

.media-section-body--video {
  background: var(--yellow-light);
  padding: 0;
  height: auto;
  min-height: 0;
  margin-bottom: 0;
  overflow: hidden;
  box-sizing: border-box;
}

.media-video-section {
  padding: 0;
}

.media-video-player {
  position: relative;
  width: 100%;
  height: 450px;
  background: #111;
}

.media-video-player iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.media-gallery {
  position: relative;
  height: var(--media-gallery-h);
  min-height: 0;
  overflow: hidden;
  direction: ltr;
}

.media-gallery-viewport {
  overflow: hidden;
  width: 100%;
  height: var(--media-gallery-h);
}

.media-gallery-track {
  display: flex;
  transition: transform 0.5s ease;
  will-change: transform;
  direction: ltr;
}

.media-gallery-slide {
  flex: 0 0 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--media-gallery-gap);
  height: var(--media-gallery-h);
  min-height: 0;
}

.media-lightbox-item {
  border: none;
  padding: 0;
  margin: 0;
  background: transparent;
  cursor: zoom-in;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: var(--media-gallery-h);
  min-height: 0;
  overflow: hidden;
}

.media-lightbox-item img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  background: transparent;
}

.media-gallery-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  border: none;
  background: rgba(255, 255, 255, 0.55);
  color: #666;
  font-size: 28px;
  line-height: 1;
  width: 36px;
  height: 56px;
  cursor: pointer;
  padding: 0;
}

.media-gallery-arrow:hover {
  background: rgba(255, 255, 255, 0.85);
  color: #333;
}

.media-gallery-arrow.prev {
  left: 8px !important;
  right: auto !important;
}

.media-gallery-arrow.next {
  right: 8px !important;
  left: auto !important;
}

.media-gallery-counter {
  position: absolute;
  left: 12px;
  bottom: 10px;
  color: var(--white);
  font-size: 13px;
  z-index: 2;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.6);
}

.media-video-thumbs-wrap {
  position: relative;
  border-top: var(--tile-border);
  background: transparent;
  direction: ltr;
}

.media-video-thumbs-viewport {
  overflow: hidden;
}

.media-video-thumbs-track {
  display: flex;
  transition: transform 0.35s ease;
}

.media-video-thumbs-page {
  flex: 0 0 100%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 13px;
  padding: 28px 52px 20px;
  box-sizing: border-box;
}

.media-video-page-arrow {
  position: absolute;
  top: calc(28px + var(--media-video-thumb-h) / 2);
  transform: translateY(-50%);
  z-index: 3;
  border: none;
  background: rgba(255, 255, 255, 0.55);
  color: #666;
  font-size: 28px;
  line-height: 1;
  width: 36px;
  height: 56px;
  cursor: pointer;
  padding: 0;
}

.media-video-page-arrow:hover {
  background: rgba(255, 255, 255, 0.85);
  color: #333;
}

.media-video-page-arrow.prev {
  left: 8px !important;
  right: auto !important;
}

.media-video-page-arrow.next {
  right: 8px !important;
  left: auto !important;
}

.media-video-page-nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  padding: 0 20px 22px;
  direction: rtl;
}

.media-video-page-link {
  border: none;
  background: transparent;
  color: var(--pink);
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 13px;
  cursor: pointer;
  padding: 0;
}

.media-video-page-link.next::before {
  content: '‹';
  margin-left: 4px;
  font-size: 16px;
  line-height: 1;
}

.media-video-page-link.prev::after {
  content: '›';
  margin-right: 4px;
  font-size: 16px;
  line-height: 1;
}

.media-video-page-link:hover {
  text-decoration: underline;
}

.media-video-page-counter {
  color: var(--pink);
  font-size: 13px;
}

.media-video-thumb {
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.media-video-thumb img {
  width: 100%;
  height: var(--media-video-thumb-h);
  object-fit: cover;
  display: block;
}

.media-video-thumb span {
  display: block;
  padding: 8px 6px 0;
  font-size: 13px;
  line-height: 1.35;
  color: var(--pink);
  text-align: center;
  font-family: 'alef-regular', 'Alef', sans-serif;
}

.media-video-thumb.is-active span {
  font-weight: 700;
}

.media-contact-section {
  border: var(--tile-border);
  border-top: none;
  background: var(--white);
}

/* Contact us page */
.contact-us-mesh {
  display: flex;
  flex-direction: column;
  margin-bottom: var(--section-gap);
}

.contact-us-mesh .section-bar {
  border: var(--tile-border);
}

.contact-hero {
  border: var(--tile-border);
  border-top: none;
  line-height: 0;
  overflow: hidden;
}

.contact-hero img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  min-height: 200px;
}

.contact-olive-panel {
  background: var(--yellow);
  border: var(--tile-border);
  border-top: none;
  padding: 32px 0 36px;
}

.contact-main-grid {
  display: grid;
  grid-template-columns: var(--contact-portrait-w) var(--contact-form-w);
  gap: var(--contact-col-gap);
  align-items: start;
  direction: rtl;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
}

.contact-form-panel {
  width: var(--contact-form-w);
  max-width: 100%;
  overflow: visible;
}

.contact-form-lead {
  font-size: 28px;
  line-height: normal;
  margin: 0 auto 14px;
  text-align: center;
  font-family: 'alef-regular', 'Alef', sans-serif;
  white-space: nowrap;
  width: max-content;
  max-width: 100%;
}

.contact-form--main {
  display: flex;
  flex-direction: column;
}

.contact-form--main input,
.contact-form--main textarea {
  width: 100%;
  border: 1px solid #222;
  padding: 3px 5px;
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 15px;
  line-height: 1.4;
  margin-bottom: 0;
  direction: rtl;
  background: #fafafa;
  box-sizing: border-box;
}

.contact-form--main input {
  height: 38px;
}

.contact-form--main input[name="name"] {
  margin-bottom: 6px;
}

.contact-form--main input[name="email"] {
  margin-bottom: 7px;
}

.contact-form--main input[name="phone"] {
  margin-bottom: 10px;
}

.contact-form--main input[name="subject"] {
  margin-bottom: 11px;
}

.contact-form--main textarea {
  resize: vertical;
  min-height: 184px;
  height: 184px;
  margin-bottom: 8px;
}

.contact-form.contact-form--main .contact-submit-dark {
  background: #222;
  color: #fafafa;
  border: none;
  padding: 3px 14px;
  min-height: 31px;
  font-family: 'alef-regular', 'Alef', sans-serif;
  font-size: 20px;
  line-height: 1.4;
  cursor: pointer;
  margin: 12px 0 19px;
  align-self: flex-end;
  width: fit-content;
}

.contact-info-panel {
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: center;
  width: var(--contact-portrait-w);
  max-width: 100%;
  padding-top: 17px;
}

.contact-info-lines {
  width: 100%;
  text-align: center;
}

.contact-submit-dark {
  background: #222;
  color: var(--white);
  border: none;
  padding: 6px 22px;
  font-family: inherit;
  font-size: 20px;
  cursor: pointer;
  margin: 12px 0 0;
  display: block;
}

.contact-phones .phone-sep {
  color: var(--pink);
  margin: 0 4px;
}

.contact-form-success {
  font-size: 20px;
  text-align: right;
  color: var(--text);
}

.contact-info-lines a,
.contact-info-lines p {
  font-family: 'play', sans-serif;
  font-size: 20px;
  line-height: 1.5;
  margin: 0;
}

.contact-info-lines a {
  color: var(--text);
  text-decoration: none;
}

.contact-phones a {
  color: var(--text);
  text-decoration: none;
}

.contact-portrait img {
  width: var(--contact-portrait-w);
  max-width: 100%;
  height: 421px;
  display: block;
  object-fit: cover;
}

.contact-address-block {
  text-align: center;
  margin: 38px auto 14px;
  max-width: var(--contact-map-w);
}

.contact-address,
.contact-accessibility {
  font-size: 20px;
  line-height: 1.5;
  margin-bottom: 6px;
}

.contact-map {
  position: relative;
  width: 100%;
  max-width: var(--contact-map-w);
  margin: 0 auto;
  padding-top: 56%;
  background: #ddd;
  border: 1px solid #bbb;
}

.contact-map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.contact-bottom-newsletter {
  background: var(--signup-bg);
  border: var(--tile-border);
  border-top: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.6);
  padding: 0;
  width: 100%;
  max-width: 100%;
}

.contact-bottom-newsletter .contact-bottom-divider {
  margin: 0;
  border: none;
  border-top: 1px solid var(--black);
  height: 0;
}

.contact-bottom-newsletter .contact-bottom-divider--top {
  margin: 32px 0 13px;
}

.contact-bottom-newsletter .contact-bottom-divider--bottom {
  margin: 0 0 27px;
}

.contact-bottom-inner {
  grid-template-columns: var(--contact-form-w) minmax(0, 1fr);
  gap: 22px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 40px 23px;
  align-items: start;
}

.contact-bottom-form-col {
  padding-top: 109px;
}

.contact-bottom-inner .newsletter-form .field-wrap {
  margin-bottom: 5px;
}

.contact-bottom-inner .newsletter-form .field-wrap:last-of-type {
  margin-bottom: 0;
}

.contact-bottom-inner .newsletter-form input {
  height: 33px;
  padding: 3px 14px 3px 5px;
  font-size: 15px;
  background: var(--white);
  border: 1px solid var(--black);
}

.contact-bottom-inner .newsletter-form .field-wrap label {
  font-size: 15px;
  right: 14px;
}

.contact-bottom-inner .newsletter-form button {
  display: block;
  width: fit-content;
  margin: 0;
  margin-right: auto;
  margin-left: 0;
  background: #b8a565;
  font-size: 20px;
  padding: 6px 28px;
}

.contact-bottom-text {
  padding-top: 0;
}

.contact-bottom-lead {
  font-size: 20px;
  font-weight: 700;
  line-height: normal;
  margin-bottom: 0;
}

.contact-bottom-text p {
  border-bottom: none;
  padding-bottom: 0;
  font-size: 15px;
  line-height: normal;
  margin-bottom: 0;
}

.contact-bottom-text a {
  color: var(--pink);
}

@media (max-width: 1200px) {
  .gallery-album-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* Responsive */
@media (max-width: 1000px) {
  body {
    background-attachment: scroll;
    overflow-x: hidden;
  }

  .site-wrap,
  .container,
  .page-mesh,
  .home-mesh {
    max-width: 100%;
    width: 100%;
    padding-left: 12px;
    padding-right: 12px;
  }

  .home-mesh-core {
    width: 100%;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .mesh-bar-top,
  .mesh-hero-img,
  .mesh-right-column,
  .mesh-specialties,
  .mesh-gafan-seal,
  .mesh-left-stack,
  .mesh-right-stack,
  .mesh-marquee,
  .mesh-om-img,
  .mesh-bar-mid,
  .mesh-bottom-imgs,
  .mesh-contact-box {
    grid-column: 1;
    grid-row: auto;
    width: 100%;
    margin-left: 0;
  }

  .mesh-right-column {
    display: flex;
    flex-direction: column;
  }

  .mesh-gafan-seal {
    right: 4px;
    top: 4px;
    width: 110px;
    height: 110px;
  }

  .mesh-gafan-seal .gafan-seal-text {
    font-size: 12px;
    padding: 24px 16px;
  }

  .mesh-marquee {
    width: 100%;
  }

  .mesh-om-img {
    min-height: 280px;
    flex: none;
  }

  .clients-section {
    width: 100%;
    max-width: 100%;
  }

  .newsletter-section {
    width: 100%;
  }

  .site-footer .footer-inner {
    width: 100%;
  }

  .mesh-bottom-imgs {
    width: 100%;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .mesh-bottom-imgs .img-hover-tile {
    width: 100%;
    height: 200px;
  }

  .mesh-hero-img { height: 300px; }
  .mesh-specialties { height: auto; min-height: 200px; }

  .mesh-specialties h3 {
    white-space: normal;
    font-size: 22px;
    padding-inline: 12px;
  }
  .mesh-courses,
  .mesh-nlp,
  .mesh-gafan-row {
    grid-template-columns: 1fr;
  }

  .mesh-courses { grid-template-columns: 1fr 1fr; }

  .newsletter-inner,
  .about-testimonials {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .courses-newsletter--business .newsletter-text-col h2 {
    white-space: normal;
    font-size: 22px;
  }

  .about-testimonial-divider {
    display: none;
  }

  .about-quote-row,
  .about-volunteer-row {
    grid-template-columns: 1fr;
    direction: rtl;
  }

  .about-volunteer-img,
  .about-volunteer-img img,
  .about-volunteer-box {
    width: 100%;
    height: auto;
    min-height: 204px;
  }

  .about-volunteer-body {
    display: block;
    padding: 22px 20px;
  }

  .about-quote-img,
  .about-quote-slideshow,
  .about-quote-img img,
  .about-quote-slideshow .slideshow-slide img {
    width: 100%;
    height: auto;
    min-height: 121px;
  }

  .about-quote-text {
    height: auto;
    min-height: 121px;
    padding: 16px 12px 28px;
  }

  .about-quote-text.text-tile .about-quote-definition {
    white-space: normal;
    font-size: 25px;
    line-height: 27px;
  }

  .about-quote-text.text-tile .about-quote-source {
    position: static;
    margin-top: 8px;
    text-align: center;
  }

  .about-grid-2.about-grid-story,
  .about-grid-2.about-grid-house,
  .about-grid-2.about-grid-education {
    grid-template-columns: 1fr;
    direction: rtl;
  }

  .about-gafan-seal {
    right: 4px;
    top: 4px;
    width: 110px;
    height: 110px;
  }

  .about-gafan-seal .gafan-seal-text {
    font-size: 12px;
    padding: 24px 16px;
  }

  .about-photo-tall .about-photo-slideshow,
  .about-photo-tall .about-photo-slideshow .slideshow-slide img {
    min-height: 320px;
  }

  .about-grid-story .about-photo-tall,
  .about-grid-story .about-photo-tall .about-photo-slideshow,
  .about-grid-story .about-photo-tall .about-photo-slideshow .slideshow-slide img {
    height: 280px;
    max-height: 280px;
    min-height: 0;
  }

  .about-story .about-text {
    padding: 18px 20px 16px;
  }

  .about-story .about-signature {
    position: static;
    transform: none;
    margin: 8px 0 0;
    align-self: flex-start;
  }

  .about-story .about-story-blog-btn {
    position: static;
    display: block;
    margin: 14px auto 0;
  }

  .about-story-signoff {
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .courses-grid-3,
  .courses-grid-2 {
    grid-template-columns: 1fr;
    direction: rtl;
  }

  .courses-span-2 {
    grid-column: span 1;
  }

  .courses-tile {
    height: 280px;
    min-height: 280px;
  }

  .courses-cta,
  .courses-row-private .courses-cta,
  .courses-row-private .courses-tile,
  .courses-row-business .courses-cta,
  .courses-row-business .courses-tile {
    min-height: 280px;
    height: auto;
  }

  .courses-cta-title {
    font-size: 48px;
  }

  .courses-gift-title {
    font-size: 44px;
  }

  .courses-gafan-seal {
    top: -40px;
    right: -20px;
    width: 100px;
    height: 100px;
  }

  .coaching-grid-2,
  .coaching-grid-3,
  .coaching-grid-3-back {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    direction: rtl;
  }

  .coaching-grid-3 > .coaching-tile,
  .coaching-grid-3 > .coaching-feedback-col {
    height: auto;
    max-height: none;
  }

  .coaching-grid-3-back .coaching-page-back--below-grid {
    grid-column: auto;
  }

  .coaching-hero,
  .coaching-hero img {
    height: 220px;
  }

  .coaching-side-img,
  .coaching-side-img img {
    min-height: 360px;
  }

  .coaching-tile {
    height: 260px;
    min-height: 260px;
  }

  .coaching-feedback-col {
    height: auto;
    overflow: visible;
  }

  .coaching-testimonial-inner {
    overflow: visible;
  }

  .coaching-intro {
    min-height: auto;
  }

  .coaching-intro p {
    font-size: 18px;
  }

  .coaching-intro h2,
  .coaching-highlight {
    font-size: 22px;
  }

  .lesson-grid-2,
  .lesson-grid-3 {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    direction: rtl;
  }

  .lesson-grid-3 > * {
    height: auto;
    max-height: none;
    overflow: hidden;
  }

  .lesson-hero-slideshow {
    height: 260px;
  }

  .lesson-side-slideshow {
    min-height: 320px;
    height: auto;
    flex: 1 1 auto;
  }

  .lesson-tile-slideshow {
    height: 280px;
  }

  .lesson-feedback-col {
    height: 300px;
  }

  .page-grid-2, .page-grid-3, .page-grid-alt, .contact-grid,
  .kinamon-grid-row {
    grid-template-columns: 1fr;
  }

  .gallery-album-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .kinamon-grid-row .kinamon-img-tile,
  .kinamon-grid-row .kinamon-service-box {
    height: auto;
    min-height: 280px;
  }

  .album-photo-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-top-row {
    flex-direction: column;
  }

  .logo-title { font-size: 40px; }
  .site-logo { height: 100px; }
  .header-phone {
    font-size: 18px;
  }

  .nav-toggle {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    width: 44px;
    height: 44px;
    margin: 4px auto 8px;
    background: transparent;
    border: 2px solid var(--pink);
    border-radius: 4px;
    cursor: pointer;
    padding: 8px;
    -webkit-tap-highlight-color: transparent;
  }

  .nav-toggle-bar {
    display: block;
    height: 2px;
    width: 22px;
    background: var(--pink);
    border-radius: 1px;
    transition: transform 0.2s ease, opacity 0.2s ease;
  }

  .site-header.nav-open .nav-toggle-bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .site-header.nav-open .nav-toggle-bar:nth-child(2) {
    opacity: 0;
  }

  .site-header.nav-open .nav-toggle-bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  .main-nav {
    display: none;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 2px;
    padding: 0 4px 12px;
    overflow: visible;
  }

  .site-header.nav-open .main-nav {
    display: flex;
  }

  .main-nav .sep {
    display: none;
  }

  .main-nav a {
    font-size: 17px;
    padding: 12px 16px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid rgba(184, 165, 100, 0.35);
  }

  .main-nav a:last-child {
    border-bottom: none;
  }

  .main-nav a.active {
    color: var(--gold);
  }

  .main-nav a:hover,
  .main-nav a:focus-visible,
  .main-nav a.active:hover,
  .main-nav a.active:focus-visible {
    color: var(--pink);
  }

  .mesh-bar-top,
  .mesh-bar-mid,
  .bar-black,
  .section-bar,
  .media-section-bar h2 {
    font-size: 18px;
    letter-spacing: 0.05em;
    padding: 8px 12px;
  }

  .newsletter-section {
    padding: 24px 16px;
  }

  .newsletter-form input,
  .newsletter-form textarea,
  .newsletter-form select,
  .contact-form input,
  .contact-form textarea,
  .contact-form select,
  .registration-form input,
  .registration-form textarea,
  .registration-form select,
  .chat-form input,
  .chat-form textarea {
    font-size: 16px;
  }

  .btn-pink,
  .btn-gold,
  .courses-btn-pink {
    font-size: 17px;
    padding: 10px 22px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .lesson-contact-row {
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }

  .lesson-contact-item {
    font-size: 16px;
  }

  .gift-details {
    padding: 16px 18px;
  }

  .registration-form-wrap {
    width: 100%;
    padding: 0 4px;
  }

  .scroll-top-fixed {
    right: 12px;
    bottom: 76px;
    width: 44px;
    height: 44px;
    font-size: 26px;
  }

  .chat-btn {
    right: 12px;
    bottom: 12px;
    min-height: 44px;
    padding: 10px 14px;
    font-size: 14px;
  }

  .chat-widget {
    right: 12px;
    left: 12px;
    bottom: 64px;
  }

  .chat-panel {
    width: 100%;
    max-width: none;
  }

  .lightbox .close {
    top: 10px;
    right: 10px;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .lightbox .nav {
    font-size: 36px;
    padding: 20px 10px;
    min-width: 44px;
    min-height: 44px;
  }

  .clients-section {
    padding: 14px 16px;
  }

  .media-video-thumbs-page {
    grid-template-columns: 1fr;
    padding: 16px 44px 12px;
    gap: 10px;
  }

  .media-video-player {
    height: 240px;
  }

  .media-video-page-arrow {
    top: calc(16px + 50%);
    width: 32px;
    height: 48px;
    font-size: 24px;
  }

  .media-video-page-nav {
    padding-bottom: 20px;
    gap: 12px;
  }

  .media-gallery-slide {
    grid-template-columns: 1fr;
  }

  .media-lightbox-item,
  .media-lightbox-item img,
  .media-gallery,
  .media-gallery-slide,
  .media-gallery-viewport,
  .media-section-body:not(.media-section-body--video) {
    height: 280px;
    min-height: 0;
  }

  .media-video-thumb img {
    height: auto;
    aspect-ratio: 16 / 9;
  }

  .contact-main-grid,
  .contact-bottom-inner {
    grid-template-columns: 1fr;
    width: 100%;
  }

  .contact-bottom-form-col {
    padding-top: 0;
  }

  .contact-form-panel,
  .contact-info-panel {
    width: 100%;
  }

  .contact-portrait img {
    width: 100%;
    max-width: var(--contact-portrait-w);
    height: auto;
    margin: 0 auto;
  }
}

@media (max-width: 600px) {
  .site-wrap,
  .container,
  .page-mesh,
  .home-mesh {
    padding-left: 10px;
    padding-right: 10px;
  }

  :root {
    --section-gap: 28px;
    --section-gap-sm: 16px;
  }

  .site-logo {
    height: 84px;
  }

  .header-phone {
    font-size: 17px;
  }

  .mesh-hero-img {
    height: 240px;
  }

  .mesh-bottom-imgs {
    grid-template-columns: 1fr;
  }

  .mesh-bottom-imgs .img-hover-tile {
    height: 180px;
  }

  .mesh-courses {
    grid-template-columns: 1fr;
  }

  .courses-cta-title {
    font-size: 36px;
  }

  .courses-gift-title {
    font-size: 32px;
  }

  .courses-tile {
    height: 240px;
    min-height: 240px;
  }

  .courses-cta,
  .courses-row-private .courses-cta,
  .courses-row-private .courses-tile,
  .courses-row-business .courses-cta,
  .courses-row-business .courses-tile {
    min-height: 240px;
  }

  .lesson-hero-slideshow {
    height: 220px;
  }

  .lesson-tile-slideshow {
    height: 240px;
  }

  .lesson-side-slideshow {
    min-height: 260px;
  }

  .lesson-feedback-col {
    height: auto;
    min-height: 240px;
  }

  .coaching-hero,
  .coaching-hero img {
    height: 180px;
  }

  .coaching-tile {
    height: 220px;
    min-height: 220px;
  }

  .coaching-side-img,
  .coaching-side-img img {
    min-height: 280px;
  }

  .album-photo-grid {
    grid-template-columns: 1fr;
  }

  .gallery-album-grid {
    grid-template-columns: 1fr;
  }

  .media-video-thumbs-page {
    padding: 16px 36px 12px;
  }

  .media-video-page-arrow {
    width: 28px;
    height: 40px;
    font-size: 20px;
  }

  .kinamon-grid-row .kinamon-img-tile,
  .kinamon-grid-row .kinamon-service-box {
    min-height: 220px;
  }

  .yellow-box {
    padding: 14px 16px;
  }

  .text-tile h2 {
    font-size: 20px;
  }

  .marquee-content {
    font-size: 13px;
  }

  .footer-phone span {
    white-space: normal;
  }

  .footer-top-row {
    padding: 0 8px;
    gap: 14px;
  }

  .footer-item {
    font-size: 16px;
  }
}
