/* moneyline — Hebrew-first RTL, accessible (תקן 5568 / WCAG-AA).
   Logical properties only (inset/start/end). Placeholder brand palette until Noa (#496). */

:root {
  --ink: #1a2233;        /* text on light — AA on all surfaces used */
  --ink-soft: #444f63;   /* 7.0:1 on #fff */
  --bg: #f7f8fa;
  --card: #ffffff;
  --brand: #0b4f8a;      /* 7.2:1 on white */
  --brand-dark: #083a66;
  --accent: #b45309;     /* 4.6:1 on white */
  --ok-bg: #e7f5ec; --ok-ink: #14532d;
  --err-bg: #fdecec; --err-ink: #991b1b;
  --line: #cdd5e0;
  --focus: #b45309;
}

* { box-sizing: border-box; }
html { font-size: 100%; }
html[data-fs="1"] { font-size: 115%; }
html[data-fs="2"] { font-size: 130%; }
html[data-fs="-1"] { font-size: 90%; }

body {
  margin: 0;
  font-family: "Heebo", "Assistant", Arial, sans-serif;
  font-size: 1.125rem;           /* 18px base — elderly-friendly */
  line-height: 1.65;
  color: var(--ink);
  background: var(--bg);
}

.wrap { max-inline-size: 62rem; margin-inline: auto; padding-inline: 1rem; }

/* skip link */
.skip-link {
  position: absolute; inset-block-start: -3em; inset-inline-start: 0.5em;
  background: var(--brand-dark); color: #fff; padding: .5em 1em;
  border-radius: 0 0 .5em .5em; z-index: 10;
}
.skip-link:focus { inset-block-start: 0; }

/* header */
header { background: var(--brand-dark); color: #fff; }
.header-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: .75rem; padding-block: .75rem; }
.brand { color: #fff; text-decoration: none; font-weight: 700; font-size: 1.3rem; display: flex; flex-direction: column; }
.brand-tag { font-size: .8rem; font-weight: 400; opacity: .95; }
.header-tools { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; }
header nav a { color: #fff; text-decoration: underline; margin-inline-start: .9rem; }
header nav a:first-child { margin-inline-start: 0; }
header nav .cta-link { font-weight: 700; }
.hello { opacity: .95; }

/* font-size widget */
.fontsize { display: flex; gap: .25rem; }
.fontsize button {
  min-inline-size: 2.4rem; min-block-size: 2.4rem;
  border: 1px solid #fff; background: transparent; color: #fff;
  border-radius: .4rem; font-size: 1rem; cursor: pointer;
}
.fontsize button[aria-pressed="true"] { background: #fff; color: var(--brand-dark); }

/* main */
main { padding-block: 1.5rem 3rem; }
h1 { font-size: 1.9rem; line-height: 1.3; }
h2 { font-size: 1.4rem; margin-block-start: 2rem; }
.lead { font-size: 1.2rem; color: var(--ink-soft); }
a { color: var(--brand); }
.muted { color: var(--ink-soft); font-size: .95rem; }

.hero { background: var(--card); border: 1px solid var(--line); border-radius: .75rem; padding: 1.5rem; margin-block-end: 1rem; }
.steps li, .topics li { margin-block-end: .5rem; }
.notice-dev { background: #fff8e6; border: 1px solid #d9a514; border-radius: .5rem; padding: .75rem 1rem; margin-block-start: 2rem; }

/* forms */
form { background: var(--card); border: 1px solid var(--line); border-radius: .75rem; padding: 1.25rem; max-inline-size: 46rem; }
fieldset { border: 1px solid var(--line); border-radius: .5rem; margin-block: 1.25rem; padding: 1rem; }
fieldset.inner { margin-block: .75rem; }
legend { font-weight: 700; padding-inline: .4rem; }
.field { margin-block-end: 1.1rem; }
label { display: block; font-weight: 600; margin-block-end: .3rem; }
.choice { display: flex; align-items: flex-start; gap: .5rem; font-weight: 400; margin-block-end: .4rem; }
.choice input { inline-size: 1.35rem; block-size: 1.35rem; margin-block-start: .2rem; flex: none; }
.choices { display: grid; grid-template-columns: repeat(auto-fill, minmax(14rem, 1fr)); gap: .25rem .75rem; }

input[type=text], input[type=email], input[type=tel], input[type=password],
input[type=date], input[type=file], select, textarea {
  inline-size: 100%;
  font: inherit;
  padding: .55rem .7rem;
  border: 1px solid var(--ink-soft);
  border-radius: .45rem;
  background: #fff;
  color: var(--ink);
  min-block-size: 2.75rem;      /* touch target */
}
.help { color: var(--ink-soft); font-size: .92rem; margin-block: .25rem 0; }
.err { color: var(--err-ink); font-weight: 600; margin-block: .3rem 0; }
.has-error input, .has-error select, .has-error textarea { border-color: var(--err-ink); border-width: 2px; }
.req { color: var(--err-ink); }
.lock-note { background: #eef3f9; border-inline-start: 4px solid var(--brand); padding: .6rem .9rem; border-radius: .4rem; }

/* buttons */
.btn {
  display: inline-block;
  font: inherit; font-weight: 700;
  padding: .65rem 1.4rem;
  border-radius: .5rem;
  border: 2px solid var(--brand);
  background: #fff; color: var(--brand);
  text-decoration: none; cursor: pointer;
  min-block-size: 2.75rem;
}
.btn-primary { background: var(--brand); color: #fff; }
.btn-primary:hover { background: var(--brand-dark); }
.btn-lg { font-size: 1.15rem; padding: .8rem 1.8rem; }

/* alerts */
.alert { padding: .8rem 1rem; border-radius: .5rem; margin-block: 1rem; border: 1px solid; }
.alert-ok { background: var(--ok-bg); color: var(--ok-ink); border-color: var(--ok-ink); }
.alert-error { background: var(--err-bg); color: var(--err-ink); border-color: var(--err-ink); }

/* conditional sections: visible without JS; JS toggles [hidden] */
.cond[hidden] { display: none; }

.doclist li { margin-block-end: .35rem; }

/* LTR fragments (email/phone) inside RTL text — keep whole, wrap as a unit */
.ltr-chunk { direction: ltr; unicode-bidi: isolate; display: inline-block; }

/* footer */
footer { background: var(--brand-dark); color: #fff; padding-block: 1rem; margin-block-start: 2rem; }
footer a { color: #fff; }

/* focus — clearly visible everywhere */
:focus-visible { outline: 3px solid var(--focus); outline-offset: 2px; border-radius: .2rem; }

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}
