
/* ============ b.tool — generator extensions (built on variation-a) ========= */
.crumb-wrap { max-width: var(--content-max); margin: 0 auto; padding: 24px var(--pad-x) 0; }
.crumb { font-family: var(--font-ui); font-size: .75rem; letter-spacing:.06em; text-transform:uppercase; color: var(--gray); display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.crumb a { color: var(--gray); transition: color .3s; } .crumb a:hover { color: var(--orange); }
.crumb span:last-child { color: var(--ink); }
.crumb__sep { color: var(--orange); }

/* page hero (categories, listings, cms) */
.page-hero { background: var(--white); padding: 88px var(--pad-x) 72px; }
.page-hero__inner { max-width: var(--content-max); margin: 0 auto; }
.page-hero h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.5rem,5.5vw,5rem); line-height: 1.02; letter-spacing:-.02em; margin: 22px 0 0; }
.page-hero__lede { margin-top: 26px; max-width: 56ch; font-family: var(--font-ui); font-weight: 400; font-size: 1.2rem; line-height: 1.6; color: var(--gray); }
.page-hero__lede p { margin: 0 0 1em; }
/* hero with a workplace photo background + dark overlay (inline background-image) */
.page-hero--photo { background-size: cover; background-position: center; color: var(--white); padding: clamp(128px,24vh,220px) var(--pad-x) clamp(56px,9vh,88px); min-height: 58vh; display: flex; align-items: flex-end; }
.page-hero--photo h1, .page-hero--photo .page-hero__lede { color: var(--white); }
.page-hero--photo .eyebrow { color: rgba(255,255,255,.92); }

/* band head (section intro above a grid) */
.band-head { margin-bottom: 44px; max-width: 60ch; }
.band-head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.75rem,3.4vw,2.875rem); line-height: 1.06; letter-spacing:-.015em; margin: 12px 0 0; }

/* long-form editorial content placed below a product grid */
.content-band { background: var(--white); padding: 96px 0; }
.content-band__inner { max-width: 760px; }

/* generic band */
.band__inner { max-width: var(--content-max); margin: 0 auto; padding: 0 var(--pad-x); }
.gallery-band, .model-grid-band, .list-band, .contact-band { background: var(--cloud); padding: 120px 0; }
.gallery-band .eyebrow, .video-embed .eyebrow { margin-bottom: 24px; }
.gallery-band h2 { font-family: var(--font-display); font-style: normal; font-weight: 700; font-size: clamp(2.25rem,4.4vw,3.75rem); line-height: 1.05; margin: 16px 0 56px; }

/* product feature pictos */
.feat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); gap: 28px 20px; margin-bottom: 8px; }
.feat { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; }
.feat img { width: 40px; height: 40px; object-fit: contain; }
.feat span { font-family: var(--font-ui); font-weight: 500; font-size: .8125rem; line-height: 1.3; color: var(--ink); }
.pd-rich { font-family: var(--font-ui); font-weight: 400; font-size: 1rem; line-height: 1.7; color: var(--gray); max-width: 46ch; }
.pd-rich p { margin: 0 0 1em; } .pd-rich h2,.pd-rich h3 { font-family: var(--font-display); font-style: normal; color: var(--ink); margin: 1.2em 0 .4em; font-size: 1.5rem; }
.pd-rich strong { color: var(--ink); } .pd-rich ul { padding-left: 1.1em; } .pd-rich a { color: var(--orange); text-decoration: underline; }

/* gallery shots */
.shot-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.shot-grid--inline { margin-top: 40px; grid-template-columns: repeat(3,1fr); }
.shot { margin: 0; border-radius: 16px; overflow: hidden; background: var(--white); aspect-ratio: 4/3; }
.shot img { width: 100%; height: 100%; object-fit: cover; transition: transform .5s var(--ease-state); }
.shot:hover img { transform: scale(1.04); }
@media (max-width: 720px){ .shot-grid, .shot-grid--inline { grid-template-columns: 1fr 1fr; } }

/* LEA app strip */
.lea { background: var(--white); padding: 120px var(--pad-x); }
.lea__inner { max-width: var(--content-max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.lea__copy h2 { font-family: var(--font-display); font-style: normal; font-weight: 700; font-size: clamp(2rem,4vw,3.25rem); margin: 16px 0 24px; }
.lea__copy p { font-family: var(--font-ui); font-weight: 200; font-size: 1.2rem; line-height: 1.6; color: var(--ink); max-width: 44ch; margin-bottom: 24px; }
.lea__shot img { width: 100%; border-radius: 20px; }
@media (max-width: 900px){ .lea__inner { grid-template-columns: 1fr; } }

/* CTA band (dark) */
.cta-band { background: var(--ink); color: var(--white); padding: 120px 0; text-align: center; }
.cta-band__inner { display: flex; flex-direction: column; align-items: center; gap: 24px; }
.cta-band h2 { font-family: var(--font-display); font-style: normal; font-weight: 700; font-size: clamp(2.25rem,4.4vw,3.75rem); margin: 0; }
.cta-band p { color: var(--gray); font-size: 1.15rem; max-width: 52ch; margin: 0; }

/* video embeds */
.video-embed { background: var(--cloud); padding: 96px 0; }
.yt-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(min(100%,320px),1fr)); gap: 24px; }
.yt { position: relative; aspect-ratio: 16/9; border-radius: 16px; overflow: hidden; background: #000; }
.yt iframe { position: absolute; inset: 0; width: 100%; height: 100%; }

/* model grid (category) — product vitrine — 3 per row for stronger presence */
.model-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.model-card { background: var(--white); border-radius: 20px; padding: 0 0 28px; display: flex; flex-direction: column; overflow: hidden; transition: transform .4s var(--ease-state), box-shadow .4s; }
.model-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-card); }
.model-card__fig { position: relative; height: 230px; display: flex; align-items: center; justify-content: center; background: var(--cloud); }
.model-card__fig img { max-height: 184px; max-width: 78%; object-fit: contain; transition: transform .5s var(--ease-state); }
.model-card:hover .model-card__fig img { transform: scale(1.05); }
.model-card__no { position: absolute; top: 16px; left: 18px; font-family: var(--font-display); font-weight: 800; font-size: .85rem; color: var(--orange); letter-spacing: .08em; }
.model-card__body { padding: 24px 24px 0; display: flex; flex-direction: column; gap: 7px; }
.model-card__name { font-family: var(--font-display); font-weight: 700; font-size: 1.35rem; line-height: 1.18; text-transform: capitalize; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.model-card__focus { font-family: var(--font-ui); font-size: .9rem; line-height: 1.5; color: var(--gray); }
.model-card__meta { display: flex; justify-content: space-between; align-items: baseline; margin-top: 6px; gap: 10px; }
.model-card__area { font-family: var(--font-ui); font-size: .625rem; letter-spacing:.14em; text-transform: uppercase; color: var(--gray); }
.model-card__price { font-family: var(--font-display); font-weight: 700; color: var(--ink); font-size: 1.15rem; }
.model-card__cta { font-family: var(--font-ui); font-weight: 600; font-size: .8rem; letter-spacing:.03em; color: var(--orange); margin-top: 12px; }
@media (max-width: 1000px){ .model-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .model-grid { grid-template-columns: 1fr; } }

/* listing grid (professions / blog / accessories) — photo cards */
.list-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px; }
.list-card { background: var(--white); border-radius: 20px; overflow: hidden; display: flex; flex-direction: column; transition: transform .4s var(--ease-state), box-shadow .4s; }
.list-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-card); }
.list-card__fig { aspect-ratio: 16/10; overflow: hidden; background: var(--cloud); }
.list-card__fig img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease-state); }
.list-card:hover .list-card__fig img { transform: scale(1.05); }
.list-card__fig--empty { display: flex; align-items: center; justify-content: center; }
.list-card__fig--empty span { font-family: var(--font-display); font-weight: 800; font-size: 2rem; color: var(--gray); opacity:.35; }
.list-card__body { padding: 24px 26px 28px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.list-card__eyebrow { font-family: var(--font-ui); font-size: .625rem; letter-spacing:.16em; text-transform: uppercase; color: var(--orange); }
.list-card__title { font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; line-height: 1.2; margin: 0; color: var(--ink); }
.list-card__desc { font-family: var(--font-ui); font-size: .9rem; line-height: 1.6; color: var(--gray); flex: 1; margin: 0; }
.list-card__cta { font-family: var(--font-ui); font-weight: 600; font-size: .8rem; letter-spacing:.03em; color: var(--orange); margin-top: 4px; }
@media (max-width: 960px){ .list-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px){ .list-grid, .model-grid { grid-template-columns: 1fr; } }

/* article (cms / blog / profession) — wide hero, comfortable reading measure */
.article { max-width: 1080px; margin: 0 auto; padding: 64px var(--pad-x) 110px; }
.article--wide { max-width: 1080px; }
.article__head { max-width: 760px; margin: 0 auto; }
.article__head h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.25rem,5vw,3.75rem); line-height: 1.06; letter-spacing:-.015em; margin: 18px 0 0; }
.article__hero { margin: 44px 0; border-radius: 22px; overflow: hidden; aspect-ratio: 16/8; }
.article__hero img { width: 100%; height: 100%; object-fit: cover; }
.article__body { max-width: 760px; margin: 0 auto; }
.article__foot { max-width: 760px; margin-left: auto; margin-right: auto; }
.article__body { font-family: var(--font-ui); font-weight: 400; font-size: 1.0625rem; line-height: 1.75; color: #2c2c2a; }
.article__body h2 { font-family: var(--font-display); font-style: normal; font-weight: 700; font-size: 1.875rem; color: var(--ink); margin: 1.6em 0 .5em; }
.article__body h3 { font-family: var(--font-display); font-style: normal; font-weight: 700; font-size: 1.4rem; color: var(--ink); margin: 1.4em 0 .4em; }
.article__body p { margin: 0 0 1.15em; }
.article__body a { color: var(--orange); text-decoration: underline; text-underline-offset: 3px; }
.article__body ul, .article__body ol { padding-left: 1.3em; margin: 0 0 1.2em; }
.article__body li { margin-bottom: .5em; }
.article__body img { border-radius: 14px; margin: 1.5em 0; }
.article__body strong { color: var(--ink); }
.article__body blockquote { border-left: 2px solid var(--orange); padding-left: 24px; margin: 1.5em 0; font-family: var(--font-display); font-style: normal; font-size: 1.3rem; color: var(--ink); }
.article__video { margin: 48px 0; }
.article__foot { margin-top: 64px; padding-top: 40px; border-top: 1px solid var(--hairline); display: flex; gap: 16px; flex-wrap: wrap; }

/* footer attribution block */
.footer__attrib { margin-top: 40px; display: flex; align-items: center; gap: 16px; max-width: 340px; }
.footer__attrib img { height: 40px; width: auto; background: var(--white); border-radius: 10px; padding: 8px 12px; }
.footer__attrib span { font-family: var(--font-ui); font-size: .75rem; line-height: 1.5; color: var(--gray); }

/* recommended model block (profession pages) */
.reco { margin: 56px 0 0; padding: 40px; background: var(--cloud); border-radius: 20px; display: grid; grid-template-columns: 1fr 200px; gap: 32px; align-items: center; }
.reco__copy h2 { font-family: var(--font-display); font-style: normal; font-weight: 700; font-size: 2.25rem; margin: 14px 0 10px; text-transform: lowercase; }
.reco__copy p { font-family: var(--font-ui); color: var(--gray); font-size: .95rem; line-height: 1.6; margin: 0 0 20px; }
.reco__actions { display: flex; gap: 20px; align-items: center; flex-wrap: wrap; }
.reco__fig { display: flex; align-items: center; justify-content: center; }
.reco__fig img { max-height: 200px; max-width: 100%; object-fit: contain; }
@media (max-width: 640px){ .reco { grid-template-columns: 1fr; } .reco__fig { order: -1; } }

/* contact */
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; }
.contact-form { display: flex; flex-direction: column; gap: 20px; }
.contact-form label { font-family: var(--font-ui); font-size: .6875rem; letter-spacing:.16em; text-transform: uppercase; color: var(--gray); display: flex; flex-direction: column; gap: 8px; }
.contact-form input, .contact-form textarea { font-family: var(--font-ui); font-size: 1rem; color: var(--ink); padding: 14px 16px; border: 1px solid var(--hairline); border-radius: 12px; background: var(--white); }
.contact-form__note { color: var(--gray); font-size: .75rem; text-transform: none; letter-spacing: 0; }
.contact-side p { font-family: var(--font-ui); color: var(--gray); line-height: 1.7; }
@media (max-width: 800px){ .contact-grid { grid-template-columns: 1fr; } }

/* small-screen safety: long words / URLs must never force horizontal scroll */
h1, h2, h3, p, a, li, .page-hero__lede, .article__body, .pd-rich, .list-card__desc { overflow-wrap: anywhere; }
img, iframe, video { max-width: 100%; }

/* hero tagline under the headline (all locales) — softens the header→models jump */
.hero__tagline { margin-top: 14px; font-family: var(--font-display); font-weight: 600; font-size: clamp(1.1rem,2vw,1.6rem); color: var(--orange); letter-spacing: .01em; }
.page-hero__tagline { margin-top: 12px; font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem,1.8vw,1.4rem); color: var(--orange); }

/* "trust" logo strip between hero and models */
.trust-band { background: var(--white); padding: 56px var(--pad-x) 8px; }
.trust-band__inner { max-width: var(--content-max); margin: 0 auto; text-align: center; }
.trust-band__label { font-family: var(--font-ui); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--gray); margin: 0 0 28px; }
.trust-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 40px 56px; }
.trust-logos img { height: 38px; width: auto; opacity: .55; filter: grayscale(1); transition: opacity .3s; }
.trust-logos img:hover { opacity: 1; filter: grayscale(0); }

/* price excl-tax marker (HT) shown next to every price */
.price-tax { font-family: var(--font-ui); font-weight: 600; font-size: .55em; letter-spacing: .06em; color: var(--gray); margin-inline-start: .35em; vertical-align: .12em; }

/* WhatsApp CTA */
.btn--wa { background: #25D366; color: #fff; display: inline-flex; align-items: center; gap: 9px; }
.btn--wa:hover { background: #1ebe5b; }
.btn--wa svg { width: 18px; height: 18px; fill: currentColor; }
.pd-sticky-cta .btn--wa { margin-top: 10px; }
.contact-form__actions { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.article__foot { align-items: center; }

/* ============ RTL fixes (Hebrew) ============ */
/* the b.tool wordmark must never be bidi-reordered — keep it LTR + isolated */
.logo, .footer__brand .logo { direction: ltr !important; unicode-bidi: isolate; }
[dir="rtl"] .model-card__no { left: auto; right: 18px; }
[dir="rtl"] .crumb { direction: rtl; }
[dir="rtl"] .model-card__cta, [dir="rtl"] .list-card__cta { direction: rtl; }

/* ===================== accessibility + fix pass (May 31) ===================== */
/* skip link for keyboard users */
/* hidden off the TOP (not left:-9999px, which in RTL extends the page 9999px and
   creates a huge horizontal scroll on every Hebrew page) */
.skip-link { position: absolute; inset-inline-start: 0; top: -60px; z-index: 2000; background: var(--ink); color: #fff; padding: 12px 22px; border-radius: 0 0 12px 0; font-family: var(--font-ui); font-weight: 600; font-size: .85rem; transition: top .2s; }
.skip-link:focus { top: 0; }
#main-content { scroll-margin-top: 96px; }

/* D2 — visible keyboard focus everywhere (button reset had removed the outline) */
:where(a, button, input, textarea, select, [tabindex]):focus-visible { outline: 2px solid var(--orange); outline-offset: 2px; border-radius: 4px; }
.btn:focus-visible, .model-card:focus-visible, .list-card:focus-visible { outline: 2px solid var(--orange); outline-offset: 3px; }

/* D1 — WCAG-AA contrast: darken the meta/body gray on light surfaces, keep it light
   on the dark footer / CTA band / photo heroes (scoped CSS-variable override) */
:root { --gray: #5f5f59; }
.footer, .cta-band, .page-hero--photo { --gray: #c6c5bf; }

/* P4 — bump small interactive targets to 44px */
.pd-size { min-height: 44px; }

/* V-BTN — product price CTA must stack: Contact + WhatsApp were collapsing into
   circles with vertically-stacked letters in the narrow info rail */
.pd-sticky-cta { position: static; bottom: auto; margin-top: 40px; padding: 0; background: transparent; box-shadow: none; border-radius: 0; flex-direction: column; align-items: stretch; gap: 14px; }
.pd-sticky-cta__price { flex-direction: row; align-items: baseline; justify-content: space-between; }
.pd-sticky-cta .btn { width: 100%; justify-content: center; white-space: nowrap; margin-top: 0; }
.pd-sticky-cta .btn--wa { margin-top: 0; }

/* datasheet / brochure download link */
.pd__caption .link, .article__datasheet .link { font-family: var(--font-ui); font-weight: 600; font-size: .85rem; }
.article__datasheet { margin-top: 36px; }

/* contact page — method cards (the dead form was removed; email + WhatsApp lead) */
.contact-lead__intro { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.3rem,2.4vw,1.95rem); line-height: 1.3; color: var(--ink); margin: 0 0 36px; max-width: 22ch; }
.contact-methods { display: flex; flex-direction: column; gap: 16px; max-width: 440px; }
.contact-method { display: flex; align-items: center; gap: 18px; padding: 20px 22px; background: var(--white); border: 1px solid var(--hairline); border-radius: 16px; transition: transform .3s var(--ease-state), box-shadow .3s; }
.contact-method:hover { transform: translateY(-3px); box-shadow: var(--shadow-card); }
.contact-method__icon { width: 46px; height: 46px; flex: none; border-radius: 12px; display: flex; align-items: center; justify-content: center; background: var(--cloud); color: var(--ink); }
.contact-method--wa .contact-method__icon { background: #25D366; color: #fff; }
.contact-method__icon svg { width: 24px; height: 24px; }
.contact-method--wa .contact-method__icon svg { fill: currentColor; }
.contact-method__body { display: flex; flex-direction: column; gap: 2px; }
.contact-method__label { font-family: var(--font-ui); font-size: .65rem; letter-spacing: .16em; text-transform: uppercase; color: var(--gray); }
.contact-method__val { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: var(--ink); }
[dir="rtl"] .contact-method { direction: rtl; }

/* ===================== home — investor-grade composition ===================== */
.hero--home { padding-top: clamp(56px,9vh,104px); padding-bottom: 0; }
.hero__grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 48px; align-items: center; }
.hero--home .hero__headline { font-size: clamp(2.6rem,6vw,5.5rem); line-height: .98; }
.hero--home .hero__deck { margin-bottom: 26px; }
.hero--home .hero__sub { margin-top: 26px; font-size: 1.12rem; max-width: 48ch; font-weight: 300; }
.hero--home .hero__tagline { margin-top: 10px; }
.hero__figure { position: relative; display: flex; align-items: center; justify-content: center; min-height: 340px; }
.hero__figure::before { content: ""; position: absolute; width: 68%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, var(--orange-soft), transparent 70%); filter: blur(24px); }
.hero__figure img { position: relative; max-height: 520px; max-width: 100%; object-fit: contain; filter: drop-shadow(0 40px 64px rgba(14,14,14,.20)); animation: hero-float 6s var(--ease-breath) infinite alternate; }
@keyframes hero-float { from { transform: translateY(-9px); } to { transform: translateY(9px); } }

/* credential strip under the hero */
.cred-strip { list-style: none; margin: 56px 0 0; padding: 28px 0 0; border-top: 1px solid var(--hairline); display: flex; flex-wrap: wrap; gap: 14px 40px; }
.cred-strip li { font-family: var(--font-ui); font-size: .72rem; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: var(--gray); position: relative; padding-inline-start: 20px; }
.cred-strip li::before { content: ""; position: absolute; inset-inline-start: 0; top: 50%; width: 7px; height: 7px; border-radius: 50%; background: var(--orange); transform: translateY(-50%); }

/* value / proof band */
.value-band { background: var(--white); padding: 120px 0; }
.value-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 32px; }
.value { border-top: 2px solid var(--ink); padding-top: 20px; }
.value__k { font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; color: var(--ink); margin-bottom: 10px; }
.value__b { font-family: var(--font-ui); font-size: .95rem; line-height: 1.6; color: var(--gray); margin: 0; }
@media (max-width: 900px){ .value-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px){ .value-grid { grid-template-columns: 1fr; } }

/* home LÉA teaser headline + closing CTA actions */
.lea__copy h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(2rem,4vw,3.25rem); margin: 14px 0 18px; }
.cta-band__actions { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* hero entrance stagger */
.hero--home .hero__deck, .hero--home .hero__headline, .hero--home .hero__tagline, .hero--home .hero__sub, .hero--home .hero__cta, .hero--home .hero__figure, .hero--home .cred-strip { animation: rise-in .7s var(--ease-state) both; }
.hero--home .hero__headline { animation-delay: .06s; } .hero--home .hero__tagline { animation-delay: .12s; } .hero--home .hero__sub { animation-delay: .18s; } .hero--home .hero__cta { animation-delay: .24s; } .hero--home .hero__figure { animation-delay: .1s; } .hero--home .cred-strip { animation-delay: .32s; }
@keyframes rise-in { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

@media (max-width: 860px){
  .hero__grid { grid-template-columns: 1fr; }
  .hero__figure { order: -1; min-height: 220px; }
  .hero__figure img { max-height: 280px; }
}
@media (prefers-reduced-motion: reduce){
  .hero__figure img, .hero--home [class*="hero__"], .hero--home .cred-strip { animation: none; }
}

/* ===================== home v2 — sector-entry funnel (June pass) ===================== */
/* dark photographic hero (replaces the light split hero) */
.hero--cover { position: relative; background-size: cover; background-position: center; color: var(--white); padding: clamp(120px,22vh,210px) var(--pad-x) clamp(64px,11vh,112px); }
.hero--cover .hero__inner { max-width: var(--content-max); margin: 0 auto; }
.hero--cover .hero__copy { max-width: 34ch; animation: rise-in .7s var(--ease-state) both; }
.hero--cover .eyebrow { color: rgba(255,255,255,.92); }
.hero--cover .hero__headline { color: var(--white); font-family: var(--font-display); font-weight: 800; font-size: clamp(2.1rem,4.8vw,3.7rem); line-height: 1.05; letter-spacing: -.01em; margin: 18px 0 0; text-wrap: balance; }
.hero--cover .hero__sub { margin-top: 24px; max-width: 50ch; font-family: var(--font-ui); font-weight: 300; font-size: clamp(1.05rem,1.6vw,1.25rem); line-height: 1.6; color: rgba(255,255,255,.9); }
.hero--cover .hero__cta { margin-top: 38px; display: flex; gap: 14px; flex-wrap: wrap; }

/* white outline button for use on dark photo surfaces */
.btn--ghost { background: transparent; color: var(--white); box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.7); }
.btn--ghost:hover { background: rgba(255,255,255,.12); box-shadow: inset 0 0 0 1.5px var(--white); }

/* proof stat strip (light, sits between the dark hero and the white body) */
.proof-band { background: var(--white); border-bottom: 1px solid var(--hairline); }
.proof-band__inner { max-width: var(--content-max); margin: 0 auto; padding: 44px var(--pad-x); display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.proof { text-align: center; }
.proof__v { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.8rem,3.4vw,2.6rem); line-height: 1; color: var(--ink); }
.proof__k { font-family: var(--font-ui); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gray); margin-top: 8px; }
@media (max-width: 600px){ .proof-band__inner { grid-template-columns: 1fr 1fr; gap: 30px 16px; } }

/* sector entry tiles */
.sectors-band { background: var(--white); padding: 120px 0; }
.sector-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.sector-tile { display: flex; flex-direction: column; justify-content: space-between; gap: 24px; min-height: 184px; padding: 30px; border: 1px solid var(--hairline); border-radius: 20px; background: var(--white); transition: transform .4s var(--ease-state), box-shadow .4s, border-color .4s; }
.sector-tile:hover { transform: translateY(-6px); box-shadow: var(--shadow-card); border-color: transparent; }
.sector-tile__name { font-family: var(--font-display); font-weight: 700; font-size: 1.55rem; line-height: 1.1; color: var(--ink); }
.sector-tile__desc { font-family: var(--font-ui); font-size: .9rem; line-height: 1.5; color: var(--gray); margin: 8px 0 0; }
.sector-tile__cta { font-family: var(--font-ui); font-weight: 600; font-size: .8rem; letter-spacing: .03em; color: var(--orange); }
@media (max-width: 900px){ .sector-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px){ .sector-grid { grid-template-columns: 1fr; } }

/* flagship spotlight (3 models) + range CTA */
.spotlight-band { background: var(--cloud); padding: 120px 0; }
.spotlight-foot { margin-top: 52px; text-align: center; }

/* closing CTA — local trust line */
.cta-band__local { font-family: var(--font-ui); font-size: .8rem; letter-spacing: .08em; text-transform: uppercase; color: var(--gray); margin: 8px 0 0; }

/* professions index — sector-grouped sections */
.prof-sector { margin-bottom: 80px; scroll-margin-top: 110px; }
.prof-sector:last-child { margin-bottom: 0; }
.prof-sector__head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 30px; padding-bottom: 14px; border-bottom: 2px solid var(--ink); }
.prof-sector__head h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.5rem,3vw,2.25rem); line-height: 1; margin: 0; }
.prof-sector__count { font-family: var(--font-ui); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gray); white-space: nowrap; }
[dir="rtl"] .sector-tile, [dir="rtl"] .prof-sector__head { direction: rtl; }

/* #9 — model-card image was a fixed 230px: on phones one card ate the screen before
   the name showed, hiding the scrollable grid. Shrink the figure on small screens. */
@media (max-width: 560px){
  .model-card__fig { height: 160px; }
  .model-card__fig img { max-height: 128px; }
}

/* scroll-reveal (only active once JS adds .reveal-on, so content never hides without JS) */
.reveal-on .model-card, .reveal-on .list-card, .reveal-on .value, .reveal-on .band-head,
.reveal-on .lea__inner, .reveal-on .cta-band__inner, .reveal-on .shot,
.reveal-on .article__hero, .reveal-on .contact-method, .reveal-on .proof, .reveal-on .sector-tile {
  opacity: 0; transform: translateY(24px); transition: opacity .65s var(--ease-state), transform .65s var(--ease-state); transition-delay: calc(var(--rv-i, 0) * 60ms);
}
.reveal-on .in-view { opacity: 1 !important; transform: none !important; }

/* ===================== home hero — flagship product name (orange) ===================== */
.hero--cover .hero__product { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.3rem,2.6vw,1.9rem); letter-spacing: .02em; color: var(--orange); margin: 16px 0 0; }

/* ===================== product price simulator ===================== */
.pd-price { border: 1px solid var(--hairline); border-radius: 18px; padding: 22px 24px; background: var(--white); }
.pd-price__from { font-family: var(--font-ui); font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--gray); }
.pd-price__monthly { display: flex; align-items: baseline; gap: 6px; margin-top: 4px; flex-wrap: wrap; }
.pd-price__amt { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem,5vw,2.8rem); line-height: 1; color: var(--ink); }
.pd-price__per { font-family: var(--font-ui); font-size: 1rem; color: var(--gray); }
.pd-price__terms { font-family: var(--font-ui); font-size: .9rem; font-weight: 600; color: var(--orange); margin-top: 6px; }
.pd-price__rule { border: none; border-top: 1px solid var(--hairline); margin: 16px 0; }
.pd-price__total { font-family: var(--font-ui); font-size: 1rem; color: var(--ink); }
.pd-price__total strong { font-weight: 800; }
.pd-price__total--ht { font-size: .85rem; color: var(--gray); margin-top: 2px; }
.pd-price__pills { display: flex; align-items: center; gap: 8px; margin: 18px 0 4px; flex-wrap: wrap; }
.pd-term { min-width: 46px; padding: 9px 14px; border-radius: 999px; border: 1px solid var(--hairline); background: var(--cloud); font-family: var(--font-ui); font-weight: 600; font-size: .95rem; color: var(--ink); cursor: pointer; transition: background .25s var(--ease-state), color .25s, border-color .25s; }
.pd-term:hover { border-color: var(--orange); }
.pd-term.is-active { background: var(--ink); color: var(--white); border-color: var(--ink); }
.pd-price__unit { font-family: var(--font-ui); font-size: .85rem; color: var(--gray); }
.pd-price__note { font-family: var(--font-ui); font-size: .72rem; color: var(--gray); margin: 10px 0 0; line-height: 1.45; }
[dir="rtl"] .pd-price { text-align: right; }

/* ===================== client pass (June 18) ===================== */
/* #5 + #6 — numbers must read left-to-right on RTL (Hebrew) pages. Phone numbers, prices and
   the flattened Hapo stat figures (e.g. "+37 000", "+75 000", "4.5") get bidi-reordered in
   Hebrew; force LTR on explicit numeric spans, and use plaintext on the mirrored stat figures
   so each gets its own base direction (digits → LTR, Hebrew → RTL). */
.ltr-num { direction: ltr; unicode-bidi: isolate; }
[dir="rtl"] .article__body strong, [dir="rtl"] .article__body td,
[dir="rtl"] .proof__v, [dir="rtl"] .pd-price__amt { unicode-bidi: plaintext; }
[dir="rtl"] .proof__v { white-space: nowrap; }

/* in-page contact anchor (home hero "Contact" button → closing contact band) clears the nav */
#contact { scroll-margin-top: 96px; }

/* #10 — footer developer credit: one discreet line under the copyright */
.footer__credit { margin-top: 6px; font-family: var(--font-ui); font-size: .72rem; color: var(--gray); opacity: .85; }
.footer__credit a { color: var(--gray); text-decoration: underline; text-underline-offset: 2px; }
.footer__credit a:hover { color: var(--orange); }

/* #9 — tighten product galleries on mobile and remove the empty vertical band that sat under
   a gallery (cloud) before the video band (cloud). */
.gallery-band + .video-embed { padding-top: 0; }
@media (max-width: 720px){
  .shot-grid, .shot-grid--inline { gap: 10px; }
  .gallery-band { padding: 48px 0; }
  .video-embed { padding: 48px 0; }
  .lea { padding: 56px var(--pad-x); }
}

/* mirror "grid" cleanup — flattened Hapo stat/benefit/feature runs become clean cards
   (number+label pairs render as stat cards). Replaces the old vertical wall of one-word
   paragraphs on the rich landing pages (e.g. the Hapo LÉA expertise page). */
.frag-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 16px; margin: 32px 0 36px; }
.frag-card { background: var(--cloud); border-radius: 14px; padding: 22px 24px; display: flex; flex-direction: column; gap: 7px; }
.frag-stat { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.9rem,4vw,2.7rem); line-height: 1; color: var(--ink); unicode-bidi: plaintext; }
.frag-title { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; line-height: 1.25; color: var(--ink); }
.frag-cap { font-family: var(--font-ui); font-size: .92rem; line-height: 1.5; color: var(--gray); }
[dir="rtl"] .frag-card { text-align: right; }
