

/* ==========================================================================
   BASE — ELEMENT DEFAULTS
   ========================================================================== */

html {
  scroll-behavior: smooth;
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

::selection {
  background: var(--jomi-selection-bg);
  color: var(--jomi-selection-text);
}



body {
  color: var(--jomi-text-body);
  font-family: var(--jomi-font-family);
  font-size: var(--jomi-font-size-body);
  font-weight: var(--jomi-font-weight-regular);
  line-height: var(--jomi-line-height-body);
  background: var(--jomi-surface-page);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

strong {
  font-weight: var(--jomi-font-weight-semibold);
}

/* Small & micro text */
small,
.small {
  font-size: var(--jomi-font-size-small);
  line-height: var(--jomi-line-height-small);
}
.micro {
  font-size: var(--jomi-font-size-micro);
  line-height: var(--jomi-line-height-micro);
}

/* Headings */
h1, .jomi-h1,
h2, .jomi-h2,
h3, .jomi-h3,
h4, .jomi-h4,
h5, .jomi-h5,
h6, .jomi-h6 {
  font-family: var(--jomi-font-family);
  letter-spacing: var(--jomi-letter-spacing-tight);
  margin: 0 0 0.5em;
  color: var(--jomi-color-text);
}

h1, .jomi-h1 {
  font-size: var(--jomi-font-size-h1);
  line-height: var(--jomi-line-height-h1);
  font-weight: var(--jomi-font-weight-bold);
}
h2, .jomi-h2 {
  font-size: var(--jomi-font-size-h2);
  line-height: var(--jomi-line-height-h2);
  font-weight: var(--jomi-font-weight-bold);
}
h3, .jomi-h3 {
  font-size: var(--jomi-font-size-h3);
  line-height: var(--jomi-line-height-h3);
  font-weight: var(--jomi-font-weight-semibold);
}
h4, .jomi-h4 {
  font-size: var(--jomi-font-size-h4);
  line-height: var(--jomi-line-height-h4);
  font-weight: var(--jomi-font-weight-semibold);
}
h5 .jomi-h5 {
  font-size: var(--jomi-font-size-h5);
  line-height: var(--jomi-line-height-h5);
  font-weight: var(--jomi-font-weight-medium);
}
h6, .jomi-h6 {
  font-size: var(--jomi-font-size-h6);
  line-height: var(--jomi-line-height-h6);
  font-weight: var(--jomi-font-weight-medium);
}

/* Links */
a {
  color: var(--jomi-color-link);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
a:hover {
  color: var(--jomi-color-link-hover);
}

/* Global focus-visible for keyboard users */
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
[tabindex]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--jomi-focus-ring);
  border-radius: 6px;
}

/* Rules & media */
hr {
  border: 0;
  border-top: 1px solid var(--jomi-border-default);
}

img,
svg,
video {
  max-width: 100%;
  height: auto;
}

/* ==========================================================================
   LAYOUT — HELPERS
   ========================================================================== */

.container {
  width: min(100%, 72rem);
  margin-inline: auto;
  padding-inline: clamp(1rem, 0.5rem + 2vw, 2rem);
}

.section {
  padding-block: clamp(2rem, 1.2rem + 3vw, 4rem);
  background: transparent;
  border-top: 1px solid transparent;
}

/* Background helpers that apply contextual tokens */
.has-bg-dark {
  background: var(--jomi-color-primary);
  color: var(--jomi-text-on-dark);
}
.has-bg-dark a {
  color: var(--jomi-link-on-dark);
}
.has-bg-dark a:hover {
  color: var(--jomi-link-on-dark-hover);
}

.has-bg-secondary {
  background: var(--jomi-color-secondary);
  color: var(--jomi-text-on-secondary);
}
.has-bg-secondary a {
  color: var(--jomi-link-on-secondary);
}
.has-bg-secondary a:hover {
  color: var(--jomi-link-on-secondary-hover);
}

/* ==========================================================================
   COMPONENT OVERRIDES — DIVI/ET
   ========================================================================== */

.jomi-col-break-after-avoid.et_pb_text p:has(strong):has(+ ul) {
  padding-bottom: 0;
}

.jomi-col-break-after-avoid.et_pb_text p:has(strong):has(+ ul) {

  break-after: avoid-column;
  break-after: avoid;
  -webkit-column-break-after: avoid;
}

.jomi-col-break-after-avoid.et_pb_text p:has(strong):has(+ ul) + ul {
  break-before: avoid-column;
  break-before: avoid;
  break-inside: avoid;
  -webkit-column-break-before: avoid;
  -webkit-column-break-inside: avoid;
}

@media (min-width: 768px) {
  :is(.jomi-col2, .jomi-col3) > .et_pb_text_inner {
    columns: 2;
    column-gap: 4rem;
    column-rule: 1px solid var(--jomi-border-default);
  }

  /* prevent list items from breaking across columns */
  .jomi-col-break-inside-avoid:is(.jomi-col2, .jomi-col3) > .et_pb_text_inner ul,
  .jomi-col-break-inside-avoid:is(.jomi-col2, .jomi-col3) > .et_pb_text_inner ol,
  .jomi-col-break-inside-avoid:is(.jomi-col2, .jomi-col3) > .et_pb_text_inner li {
    break-inside: avoid;
    -webkit-column-break-inside: avoid; /* Safari/Chrome */
    -moz-column-break-inside: avoid; /* Firefox */
  }
}

@media (min-width: 1200px) {
  .jomi-col3 > .et_pb_text_inner {
    columns: 3;
    column-gap: 6rem;
  }
}

/* Table list layout */
.et_pb_text.jomi-table-list .et_pb_text_inner > ul {
  display: grid;
  gap: var(--jomi-form-gap);
  grid-template-columns: auto 1fr;
}

.et_pb_text.jomi-table-list .et_pb_text_inner > ul > li {
  display: contents;
}

.et_pb_text.jomi-table-list .et_pb_text_inner > ul > li > strong {
  color: var(--jomi-color-accent);
}

.et_pb_text.jomi-table-list .et_pb_text_inner ul {
  list-style: none;
  padding: 0;
}

/* ==========================================================================
   NAVIGATION
   ========================================================================== */

header ul:is(.et-menu, .et_mobile_menu) .menu-item > a {
  color: var(--jomi-color-primary);
  font-size: var(--jomi-font-size-small);
  font-family: var(--jomi-font-family-heading, var(--jomi-font-family-body));
  text-transform: uppercase;
  letter-spacing: 0.05em; /* subtle spacing */
  font-weight: 600; /* semi-bold for clarity */
  line-height: 1.4;
}

/* Hover/focus state */
header ul:is(.et-menu, .et_mobile_menu) .menu-item > a:hover,
header ul:is(.et-menu, .et_mobile_menu) .menu-item > a:focus {
  color: var(--jomi-color-accent);
  text-decoration: none;
}


/* logo visibility */
header .et_pb_menu__logo img {
    visibility: hidden;
}

header > .has_et_pb_sticky .et_pb_menu__logo img {
    visibility: visible;
}


@media (min-width: 981px) {
/*   header .et_pb_menu .et_pb_menu__wrap {
    justify-content: flex-end;
  } */
}


/* ==========================================================================
   ALERTS (generic; can be used inside/outside forms)
   ========================================================================== */

.jomi-alert {
  /* tokens (override these in jomi-schemeX if needed) */
  --jomi-alert-bg: var(--jomi-surface-card, #e4ecf0);
  --jomi-alert-border: var(--jomi-color-border);
  --jomi-alert-text: var(--jomi-text-body);
  --jomi-alert-accent: var(--jomi-color-primary); /* used for <strong> and links */

  background: var(--jomi-alert-bg);
  border: 2px solid var(--jomi-alert-border);
  border-radius: var(--jomi-form-radius);
  padding: 1rem 1.25rem;
  margin-block: var(--jomi-form-gap);
  color: var(--jomi-alert-text);
  font-size: var(--jomi-font-size-micro);
  line-height: var(--jomi-line-height-micro);
}

.jomi-alert strong {
  color: var(--jomi-alert-accent);
}

.jomi-alert a {
  color: var(--jomi-color-accent);
  text-decoration: underline;
}
.jomi-alert a:hover { color: var(--jomi-color-primary); }

/* === Modifiers ============================================================ */

/* Info: derived from PRIMARY (navy) */
.jomi-alert.info {
  --jomi-alert-accent: var(--jomi-color-primary);
  --jomi-alert-bg: color-mix(in srgb, var(--jomi-color-primary) 10%, #fff);
  --jomi-alert-border: color-mix(in srgb, var(--jomi-color-primary) 40%, #fff);
}

/* Success: derived from SECONDARY (grey-blue) */
.jomi-alert.success {
  --jomi-alert-accent: var(--jomi-color-secondary);
  --jomi-alert-bg: color-mix(in srgb, var(--jomi-color-secondary) 12%, #fff);
  --jomi-alert-border: color-mix(in srgb, var(--jomi-color-secondary) 45%, #fff);
}

/* Error: derived from ACCENT (orange-red) */
.jomi-alert.error {
  --jomi-alert-accent: var(--jomi-color-accent);
  --jomi-alert-bg: color-mix(in srgb, var(--jomi-color-accent) 10%, #fff);
  --jomi-alert-border: color-mix(in srgb, var(--jomi-color-accent) 45%, #fff);
}


