
html { scrollbar-color: var(--pico-primary) var(--pico-background-color); }

html[data-font-size="system"],
html:not([data-font-size]) {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

html[data-font-size="large"] {
  font-size: 112.5%;
}

html[data-font-size="extra_large"] {
  font-size: 125%;
}

:host(:not([data-theme=dark])), :root:not([data-theme=dark]), [data-theme=light] {
--pico-icon-valid: none;
--pico-icon-invalid: none;
}

:root {
  --app-control-height: var(--pico-form-element-height, 2.625rem);
}

article > form {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  box-shadow: none;
}

.appearance-options {
  display: grid;
  gap: 10px;
  width: 100%;
}

.appearance-options--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.appearance-options--3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.appearance-options form {
  display: block;
  width: 100%;
  margin: 0;
}

.appearance-options form button {
  width: 100%;
  margin: 0;
}

[aria-label][data-balloon-pos]:after {
  z-index: 100;
}

i {
  color: var(--pico-primary);
}

button.green i,
button.red i,
button.orange i,
[role=button].green i,
[role=button].red i,
[role=button].orange i {
  color: currentColor;
}

article + div[role=group] form.button_to,
article + div[role=group] > button,
article + div[role=group] > a[role=button],
article ~ div[role=group] form.button_to,
article ~ div[role=group] > button,
article ~ div[role=group] > a[role=button],
article + div.grid form.button_to,
article + div.grid > button,
article + div.grid > a[role=button],
article footer nav[role=group] form.button_to,
article footer nav[role=group] > button,
article footer nav[role=group] > a[role=button],
article footer nav[role=group] > details,
article > header > button,
article > header > a[role=button] {
  margin-bottom: 0;
}

article + div[role=group] form.button_to button,
article + div[role=group] > button,
article + div[role=group] > a[role=button],
article ~ div[role=group] form.button_to button,
article ~ div[role=group] > button,
article ~ div[role=group] > a[role=button],
article + div.grid form.button_to button,
article + div.grid > button,
article + div.grid > a[role=button],
article footer nav[role=group] form.button_to button,
article footer nav[role=group] > button,
article footer nav[role=group] > a[role=button],
article footer nav[role=group] > details > summary[role=button],
article footer nav[role=group] > details.app-control-dropdown > summary[role=button],
details.app-control-dropdown > summary[role=button],
article > header > button,
article > header > a[role=button] {
  min-height: var(--app-control-height);
  height: var(--app-control-height);
  padding-block: 0;
  padding-inline: var(--pico-spacing);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  line-height: 1;
  box-sizing: border-box;
}

article footer nav[role=group] > details.app-control-dropdown,
details.app-control-dropdown {
  display: flex;
  align-items: stretch;
  height: var(--app-control-height);
  margin: 0;
  vertical-align: middle;
}

article footer nav[role=group] > details.app-control-dropdown > summary[role=button]::after,
details.app-control-dropdown > summary[role=button]::after {
  margin-top: 0;
}

article + div.grid > form,
article + div.grid > button,
article + div.grid > a[role=button] {
  width: 100%;
}

article + div.grid form.button_to button {
  width: 100%;
}

article + div[role=group] form.button_to,
article ~ div[role=group] form.button_to,
article + div.grid form.button_to {
  margin-bottom: 0;
  flex: 1 1 8rem;
}

article + div[role=group] form.button_to button,
article ~ div[role=group] form.button_to button,
article + div.grid form.button_to button {
  width: 100%;
}

article footer nav[role=group] {
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 0;
  align-items: stretch;
}

article footer nav[role=group] > form,
article footer nav[role=group] > button,
article footer nav[role=group] > a[role=button],
article footer nav[role=group] > details,
article footer nav[role=group] > details.app-control-dropdown {
  flex: 1 1 8rem;
  min-width: 0;
}

article footer nav[role=group] > a[role=button],
article footer nav[role=group] > button,
article footer nav[role=group] form.button_to button {
  width: 100%;
}

article footer nav[role=group] > details.app-control-dropdown > summary[role=button],
details.app-control-dropdown > summary[role=button] {
  margin: 0;
  width: 100%;
  flex: 1;
  text-align: center;
}

details:not(.app-control-dropdown) > summary[role=button] {
  width: 100%;
  text-align: left;
  margin-bottom: 0;
}

article > header {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  min-height: var(--app-control-height);
}

article > header > div:first-child {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1 1 0;
  min-width: 0;
  overflow: hidden;
}

article > header > div:first-child span,
article > header > div:first-child strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: var(--app-control-height);
}

article > header > button,
article > header > a[role=button] {
  flex: 0 0 auto;
  width: var(--app-control-height);
  min-width: var(--app-control-height);
  padding: 0;
  margin-left: 0.25rem;
}

[role=header_action_screen] {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.35rem;
}

[role=header_action_screen] nav small {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 0.15rem 0.35rem;
  line-height: 1.4;
}

[role=header_action_screen] nav small a {
  text-decoration: none;
  white-space: nowrap;
}

[role=header_action_screen] nav small a i {
  margin-right: 0.2rem;
}

.school-page-content {
  margin-top: calc(var(--pico-spacing) * 1.25);
}

.school-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--pico-spacing) * 0.5);
  margin-bottom: calc(var(--pico-spacing) * 1.25);
}

.invite-page .invite-filters > a[role=button]:not(.outline) i {
  color: currentColor;
}

.bloco-list-item footer nav[role=group] > .label.invite-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: var(--app-control-height);
  height: var(--app-control-height);
  margin: 0;
  flex: 1 1 8rem;
  min-width: 0;
  width: 100%;
  color: var(--pico-color);
  box-sizing: border-box;
  line-height: 1.2;
  font-size: small;
}

.bloco-list-item footer nav[role=group] > .label.invite-status.green,
.bloco-list-item footer nav[role=group] > .label.invite-status.yellow,
.bloco-list-item footer nav[role=group] > .label.invite-status.red {
  color: var(--pico-color);
}

section.select-search-field[data-invalid] > details > summary,
section.select-search-field.select-search-invalid > details > summary {
  border-color: var(--pico-primary);
  box-shadow: inset 0 0 0 1px var(--pico-primary);
}

section.select-search-field[data-invalid] > details > summary > label,
section.select-search-field.select-search-invalid > details > summary > label {
  color: var(--pico-primary);
  background: var(--pico-background-color);
}

section.select-search-field .select-search-error {
  display: none;
  color: var(--pico-primary);
  font-size: 0.85rem;
  margin-top: 0.35rem;
}

section.select-search-field[data-invalid] .select-search-error,
section.select-search-field.select-search-invalid .select-search-error {
  display: block;
}

.account-selector {
  font-size: 1.05rem;
}

.account-selector summary {
  font-size: 1.05rem;
}

.account-selector__menu {
  padding: calc(var(--pico-spacing) * 0.75);
  background-color: var(--pico-background-color);
  font-size: 1.05rem;
}

.account-selector__menu a {
  display: inline-block;
  line-height: 1.5;
}

.account-selector__menu hr {
  margin: calc(var(--pico-spacing) * 0.5) 0;
}

.school-page-tree {
  margin-top: calc(var(--pico-spacing) * 0.25);
  margin-bottom: calc(var(--pico-spacing) * 1);
}

.bloco-list {
  display: flex;
  flex-direction: column;
  gap: calc(var(--pico-spacing) * 0.75);
}

.bloco-list-item__content {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.bloco-list-item__image {
  flex-shrink: 0;
}

.bloco-list-item__info {
  font-size: small;
  flex: 1;
  min-width: 0;
}

.bloco-list-item__info strong {
  display: block;
  overflow-wrap: anywhere;
  margin-bottom: 0.25rem;
}

.bloco-list-item__meta {
  display: block;
  line-height: 1.4;
}

.discount-list-item__info {
  font-size: 1rem;
}

.discount-list-item__title {
  display: block;
  font-size: 1.1rem;
  margin-bottom: calc(var(--pico-spacing) * 0.5);
  overflow-wrap: anywhere;
}

.discount-list-item__line {
  margin: 0;
  line-height: 1.6;
  overflow-wrap: anywhere;
}

.discount-list-item .label {
  font-size: 0.9rem;
}

.tuition-control-summary {
  margin: 0;
  line-height: 1.5;
}

.tuition-charge-list-item__info {
  font-size: 1rem;
}

.tuition-charge-list-item__title {
  display: block;
  font-size: 1.1rem;
  margin-bottom: calc(var(--pico-spacing) * 0.35);
  overflow-wrap: anywhere;
}

.tuition-charge-list-item__line {
  margin: 0;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.tuition-charges-list {
  margin-top: calc(var(--pico-spacing) * 0.75);
}

.tuition-charges-paid {
  margin-bottom: calc(var(--pico-spacing) * 1);
}

.tuition-charge-card__footer {
  display: flex;
  flex-direction: column;
  gap: calc(var(--pico-spacing) * 0.85);
  align-items: stretch;
}

.tuition-charge-card__action-details {
  margin: 0;
}

.tuition-charge-card__action-details > summary[role=button] {
  width: 100%;
  margin: 0;
  text-align: left;
}

.tuition-charge-card__action-details .tuition-charge-card__form {
  margin-top: calc(var(--pico-spacing) * 0.65);
  padding-top: 0;
  border-top: none;
}

.tuition-charge-card__footer > .outline,
.tuition-charge-card__button-form,
.tuition-charge-card__footer button.outline {
  width: 100%;
  margin: 0;
}

.tuition-charge-card__button-form .outline {
  width: 100%;
}

.tuition-charge-card__form {
  display: flex;
  flex-direction: column;
  gap: calc(var(--pico-spacing) * 0.5);
  margin: 0;
}

.tuition-receipt-preview {
  margin: calc(var(--pico-spacing) * 0.5) 0;
  max-width: 20rem;
}

.tuition-receipt-preview__image {
  display: block;
  max-width: 100%;
  max-height: 240px;
  margin-bottom: calc(var(--pico-spacing) * 0.5);
  border-radius: var(--pico-border-radius);
}

.tuition-receipt-preview__pdf {
  display: block;
  width: 100%;
  min-height: 240px;
  margin-bottom: calc(var(--pico-spacing) * 0.5);
  border: 1px solid var(--pico-muted-border-color);
  border-radius: var(--pico-border-radius);
}

.tuition-receipt-upload__error {
  margin: calc(var(--pico-spacing) * 0.35) 0;
  font-size: 0.95rem;
}

.billing-filter-form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: calc(var(--pico-spacing) * 0.75);
  margin-bottom: calc(var(--pico-spacing) * 1.25);
}

.tuition-controls-filter {
  display: flex;
  flex-direction: column;
  gap: calc(var(--pico-spacing) * 0.5);
  margin: 0 0 calc(var(--pico-spacing) * 1.25);
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.tuition-controls-filter__row {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--pico-form-element-border-color);
  background: var(--pico-form-element-background-color);
  overflow: hidden;
}

.tuition-controls-filter__row input[type="text"],
.tuition-controls-filter__row input[type="search"] {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: var(--pico-form-element-spacing-vertical) var(--pico-form-element-spacing-horizontal);
  border: none;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

.tuition-controls-filter__row input[type="text"]:focus,
.tuition-controls-filter__row input[type="search"]:focus,
.tuition-controls-filter__row input[type="text"]:focus-visible,
.tuition-controls-filter__row input[type="search"]:focus-visible {
  outline: none;
  box-shadow: none;
  background: transparent;
}

.tuition-controls-filter__submit {
  flex: 0 0 var(--app-control-height);
  width: var(--app-control-height);
  min-width: var(--app-control-height);
  margin: 0;
  padding: 0;
  border: none;
  border-left: 1px solid var(--pico-primary-background);
  border-radius: 0;
  background: var(--pico-primary-background);
  color: var(--pico-primary-inverse);
}

.tuition-controls-filter__submit:hover {
  background: var(--pico-primary-hover);
  border-left-color: var(--pico-primary-hover);
  color: var(--pico-primary-inverse);
}

.tuition-controls-filter__submit:focus,
.tuition-controls-filter__submit:focus-visible {
  outline: none;
  box-shadow: none;
  background: var(--pico-primary-background);
  color: var(--pico-primary-inverse);
}

.tuition-controls-filter__submit i {
  color: currentColor;
}

.tuition-controls-filter select:not([multiple]):not([size]) {
  width: 100%;
  margin: 0;
  border-radius: 0;
  background-color: var(--pico-form-element-background-color);
}

.tuition-controls-filter select:not([multiple]):not([size]):focus,
.tuition-controls-filter select:not([multiple]):not([size]):focus-visible {
  outline: none;
  box-shadow: none;
  border-color: var(--pico-form-element-border-color);
}

.tuition-import-preview__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: calc(var(--pico-spacing) * 0.75);
}

.tuition-import-preview__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tuition-import-preview__row {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: calc(var(--pico-spacing) * 0.5) 0;
  border-bottom: 1px solid var(--pico-muted-border-color);
}

.tuition-import-preview__row:last-child {
  border-bottom: none;
}

.tuition-import-preview__row strong,
.tuition-import-preview__row span {
  overflow-wrap: anywhere;
}

.billing-filter-form label {
  margin-bottom: 0;
  flex: 1;
  min-width: 12rem;
}

.billing-filter-form input[type="month"] {
  margin-bottom: 0;
}

.billing-items-table-wrapper {
  overflow-x: auto;
  margin-bottom: calc(var(--pico-spacing) * 0.75);
}

.billing-items-table {
  margin-bottom: 0;
}

.billing-items-table__amount {
  text-align: right;
  white-space: nowrap;
}

.agreement-compare-form {
  margin-bottom: calc(var(--pico-spacing) * 1.25);
}

.agreement-compare-form label {
  margin-bottom: 0;
}

.agreement-compare-summary {
  margin-bottom: calc(var(--pico-spacing) * 1.25);
}

.agreement-compare-values {
  display: grid;
  gap: calc(var(--pico-spacing) * 0.75);
}

@media (min-width: 768px) {
  .agreement-compare-values {
    grid-template-columns: 1fr 1fr;
  }
}

.agreement-diff {
  font-family: var(--pico-font-family-monospace, monospace);
  font-size: 0.9rem;
  line-height: 1.5;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.agreement-diff__line {
  padding: 0.1rem 0.35rem;
  border-radius: 0.15rem;
}

.agreement-diff__line--unchanged {
  color: var(--pico-muted-color);
}

.agreement-diff__line--removed {
  background: color-mix(in srgb, var(--pico-del-color, #c62828) 12%, transparent);
}

.agreement-diff__line--removed del {
  text-decoration: line-through;
}

.agreement-diff__line--added {
  background: color-mix(in srgb, var(--pico-ins-color, #2e7d32) 12%, transparent);
}

.agreement-diff__line--added ins {
  text-decoration: none;
  font-weight: 600;
}

article:has(> footer) > .school-page-tree,
article:has(> footer) > .tree {
  margin-bottom: calc(var(--pico-spacing) * 1);
}

article:has(> .school-page-tree) > footer,
article:has(> .tree.school-page-tree) > footer {
  margin-top: calc(var(--pico-spacing) * 0.5);
  padding-top: calc(var(--pico-spacing) * 0.5);
}

small[role=breadcrumb] {
  display: inline-block;
  line-height: 1.2;
}

small[role=breadcrumb] a.breadcrumb-home {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  vertical-align: middle;
  flex-shrink: 0;
}

small[role=breadcrumb] a.breadcrumb-home svg {
  width: 20px;
  height: 20px;
  display: block;
}

article[role=classroom-summary] dl > dt,
article[role=course-cycle-summary] dl > dt,
article[role=course-summary] dl > dt,
article[role=school-summary] dl > dt,
article > dl > dt,
article[role=highlight] dl > dt {
  font-weight: 700;
}

article[role=classroom-summary] dl > dd,
article[role=course-cycle-summary] dl > dd,
article[role=course-summary] dl > dd,
article[role=school-summary] dl > dd,
article > dl > dd,
article[role=highlight] dl > dd {
  margin-bottom: calc(var(--pico-spacing) * 1.25);
  padding-bottom: calc(var(--pico-spacing) * 0.25);
  min-width: 0;
}

article[role=highlight] {
  margin-bottom: calc(var(--pico-spacing) * 0.75);
}

article[role=highlight] > footer {
  margin-top: calc(var(--pico-spacing) * 0.5);
  padding-top: 0;
}

article[role=classroom-list-item] {
  padding: calc(var(--pico-spacing) * 0.6) calc(var(--pico-spacing) * 0.75);
  margin-bottom: calc(var(--pico-spacing) * 0.5);
}

article[role=classroom-list-item] > footer {
  margin-top: calc(var(--pico-spacing) * 0.35);
  padding-top: calc(var(--pico-spacing) * 0.35);
  padding-bottom: 0;
}

article[role=classroom-list-item] > footer nav[role=group] {
  gap: 0.35rem;
  margin-bottom: 0;
}

article[role=classroom-list-item] dl {
  margin-bottom: 0;
}

article[role=classroom-list-item] dl > dt {
  font-weight: 700;
  font-size: 0.85rem;
  margin-bottom: 0.1rem;
}

article[role=classroom-list-item] dl > dd {
  font-size: 0.9rem;
  margin-bottom: calc(var(--pico-spacing) * 0.5);
  padding-bottom: 0;
}

article[role=classroom-list-item] dl > dd:last-of-type {
  margin-bottom: 0;
}

details > summary {
  padding-block: calc(var(--pico-spacing) * 0.5);
}

nav.address-actions,
nav.address-actions[role=group] {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  max-width: 100%;
  margin-top: calc(var(--pico-spacing) * 0.5);
  box-sizing: border-box;
}

nav.address-actions > a[role=button],
nav.address-actions[role=group] > a[role=button] {
  flex: 0 0 2.5rem;
  width: 2.5rem;
  height: 2.5rem;
  min-width: 2.5rem;
  min-height: 2.5rem;
  margin: 0;
  margin-inline-start: 0;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--pico-border-radius);
  box-sizing: border-box;
}

nav.address-actions > a[role=button] + a[role=button] {
  margin-inline-start: 0;
}

nav.address-actions > a[role=button] i {
  margin: 0;
  font-size: 1rem;
  line-height: 1;
}

.lesson-plan-form-actions {
  display: flex;
  flex-direction: column;
  gap: calc(var(--pico-spacing) * 0.75);
  margin-top: calc(var(--pico-spacing) * 0.5);
}

.lesson-plan-form-actions__add {
  display: flex;
  justify-content: flex-end;
}

.lesson-plan-form-actions__add > button {
  width: auto;
  flex: 0 0 auto;
  margin: 0;
}

.lesson-plan-form-actions__save {
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  margin-bottom: 0;
}

.lesson-plan-form-actions__save > button,
.lesson-plan-form-actions__save > input[type="submit"] {
  width: 100%;
  margin: 0;
  min-height: var(--app-control-height);
  height: var(--app-control-height);
  box-sizing: border-box;
}

[role=classroom-status],
[role=course-cycle-status] {
  margin-bottom: calc(var(--pico-spacing) * 0.75);
}

[role=classroom-status] [role=status],
[role=course-cycle-status] [role=status] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: var(--app-control-height);
  height: var(--app-control-height);
  margin: 0;
  padding: 0 var(--pico-spacing);
  box-sizing: border-box;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  border-radius: var(--pico-border-radius);
  border: 1px solid transparent;
}

[role=classroom-status] [role=status].yellow,
[role=course-cycle-status] [role=status].yellow {
  background: rgb(255 255 0 / 0.22);
  color: darkgoldenrod;
  border-color: rgb(184 134 11 / 0.45);
}

[role=classroom-status] [role=status].green,
[role=course-cycle-status] [role=status].green {
  background: rgb(0 128 0 / 0.18);
  color: green;
  border-color: rgb(0 100 0 / 0.45);
}

[role=classroom-status] [role=status].red,
[role=course-cycle-status] [role=status].red {
  background: rgb(255 0 0 / 0.14);
  color: darkred;
  border-color: rgb(139 0 0 / 0.4);
}

article > header > button,
article > header > a[role=button],
article > header > button.outline {
  margin-bottom: 0px;
}

form.button_to button {
  width: stretch;
  margin-bottom: 0;
}

form.form-plain,
article > form.form-plain {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  box-shadow: none;
}

article .grid > article form.button_to,
article .grid > article footer nav[role=group] form.button_to {
  background: transparent;
  border: none;
  padding: 0;
  margin-bottom: 0;
  box-shadow: none;
}

article .grid > article footer nav[role=group] form.button_to button {
  width: auto;
}

button.green, [role=button].green {
  background-color: green;
  color: white;
  border-color: darkgreen;
}
button.red, [role=button].red {
  background-color: red;
  color: white;
  border-color: darkred;
}

button.orange, [role=button].orange {
  background-color: orange;
  color: white;
  border-color: darkorange;
}

@media (max-width: 576px) {
  h1 {
    --pico-font-size: 1.25rem;
  }
  h2 {
    --pico-font-size: 1.125rem;
  }
  h3 {
    --pico-font-size: 1rem;
  }
  h4 {
    --pico-font-size: 0.875rem;
  }
  h5 {
    --pico-font-size: 0.75rem;
  }
  h6 {
    --pico-font-size: 0.625rem;
  }

  .grid {
    grid-row-gap: 0px;
    grid-column-gap: 0px;
  }

  article + div.grid {
    grid-template-columns: 1fr;
  }

  article footer nav[role=group] {
    flex-direction: row;
    justify-content: center;
  }

  .bloco-list-item footer nav[role=group] > a[role=button] {
    flex: 1 1 calc(50% - 0.25rem);
    max-width: 100%;
    white-space: normal;
    text-align: center;
    padding-inline: calc(var(--pico-spacing) * 0.5);
  }

  article + div[role=group]:not(article footer nav),
  article ~ div[role=group]:not(article footer nav),
  article + div.grid > form,
  article + div.grid > button,
  article + div.grid > a[role=button] {
    width: 100%;
  }

  div[role=group]:not(article footer nav) {
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
  }

  article + div[role=group] form.button_to,
  article ~ div[role=group] form.button_to,
  div[role=group]:not(article footer nav) > form,
  div[role=group]:not(article footer nav) > button,
  div[role=group]:not(article footer nav) > a[role=button],
  div[role=group]:not(article footer nav) > details {
    flex: 0 0 auto;
    width: 100%;
    margin: 0;
  }

  div[role=group]:not(article footer nav) form.button_to button {
    width: 100%;
    border-radius: var(--pico-border-radius);
  }

  div[role=group]:not(article footer nav) > button,
  div[role=group]:not(article footer nav) > a[role=button] {
    border-radius: var(--pico-border-radius);
  }

  .fluid-mobile {
    display: ruby;
  }

  .tuition-page .school-page-actions > a[role=button],
  .tuition-page .school-page-actions > button,
  .tuition-page .school-page-actions > input[type=submit] {
    width: 100%;
  }

  .invite-page .invite-filters > a[role=button] {
    flex: 0 0 var(--icon-action-size);
    width: var(--icon-action-size);
    min-width: var(--icon-action-size);
    height: var(--icon-action-size);
    min-height: var(--icon-action-size);
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .invite-page .invite-filters > a[role=button] .invite-filters__label {
    display: none;
  }

  .lesson-plan-form-actions__add > button {
    width: auto;
  }

  .lesson-plan-form-actions__save {
    grid-template-columns: 1fr 1fr;
  }
}

.financial-cashflow {
  margin-bottom: 1rem;
}

.financial-cashflow__received,
.financial-cashflow__receivable {
  display: grid;
  gap: 0.75rem;
}

.financial-cashflow__current-label {
  margin: 0;
  font-size: 0.9rem;
  color: var(--pico-muted-color);
}

.financial-cashflow__current-value {
  margin: 0;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--pico-primary);
}

.financial-cashflow__months-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.financial-cashflow__section-title {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 600;
}

.financial-cashflow__pending-value {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.1;
}

.financial-cashflow__pending-current {
  display: grid;
  gap: 0.25rem;
}

.financial-cashflow__month-card {
  display: grid;
  gap: 0.35rem;
  padding: 0.75rem;
  border: 1px solid var(--pico-muted-border-color);
  border-radius: var(--pico-border-radius);
  text-align: center;
}

.financial-cashflow__month-card-title {
  font-size: 1rem;
}

.financial-cashflow__month-card small {
  display: block;
  font-size: 0.95rem;
}

@media (max-width: 576px) {
  .financial-cashflow__section-title {
    font-size: 1.25rem;
  }

  .financial-cashflow__month-card small {
    font-size: 1rem;
  }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.blocos-catalog-page {
  margin-bottom: calc(var(--pico-spacing) * 2);
}

.blocos-catalog-page__subtitle {
  margin: calc(var(--pico-spacing) * 0.35) 0 calc(var(--pico-spacing) * 1.25);
  color: var(--pico-muted-color);
}

.blocos-catalog-page .search-toolbar[role="search"] {
  margin: 0 0 calc(var(--pico-spacing) * 1.75);
}

.blocos-catalog-list {
  display: flex;
  flex-direction: column;
  gap: calc(var(--pico-spacing) * 0.75);
}

.blocos-catalog-list__item {
  display: block;
}

article.blocos-catalog-card:not(:has(> form:first-child)) {
  --blocos-catalog-card-padding: calc(var(--pico-spacing) * 0.85);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0;
  overflow: hidden;
  border: 1px solid var(--pico-muted-border-color);
  border-radius: var(--pico-border-radius);
  background: var(--pico-card-background-color, var(--pico-background-color));
  transition: border-color 0.15s ease;
}

.blocos-catalog-card__stripe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  width: 100%;
  height: var(--blocos-catalog-card-padding);
  margin: 0;
  border-top-left-radius: calc(var(--pico-border-radius) - 1px);
  border-top-right-radius: calc(var(--pico-border-radius) - 1px);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

article.blocos-catalog-card:not(:has(> form:first-child)):hover {
  border-color: var(--pico-primary);
}

.blocos-catalog-card__row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: calc(var(--pico-spacing) * 0.75);
  align-items: start;
  padding: var(--blocos-catalog-card-padding);
  padding-bottom: 0;
}

.blocos-catalog-card:has(.blocos-catalog-card__stripe) .blocos-catalog-card__row {
  padding-top: calc(var(--blocos-catalog-card-padding) * 2);
}

.blocos-catalog-card__media {
  flex-shrink: 0;
}

.blocos-catalog-card__media img {
  border-radius: calc(var(--pico-border-radius) * 0.75);
  object-fit: cover;
}

.blocos-catalog-card__body {
  min-width: 0;
}

.blocos-catalog-card__header {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.6rem;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 0.35rem;
}

.blocos-catalog-card__title {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

.blocos-catalog-card__title-link {
  color: inherit;
  text-decoration: none;
}

.blocos-catalog-card__title-link:hover {
  color: var(--pico-primary);
}

.blocos-catalog-card__distance {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.15rem 0.5rem;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--pico-primary);
  background: color-mix(in srgb, var(--pico-primary) 12%, transparent);
  white-space: nowrap;
}

.blocos-catalog-card__badge {
  display: inline-block;
  margin-bottom: 0.35rem;
  padding: 0.1rem 0.45rem;
  border-radius: 999px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--pico-primary);
  border: 1px solid color-mix(in srgb, var(--pico-primary) 35%, transparent);
}

.blocos-catalog-card__description {
  margin: 0 0 0.45rem;
  font-size: 0.92rem;
  line-height: 1.45;
  color: var(--pico-color);
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.blocos-catalog-card__description p {
  margin: 0;
}

.blocos-catalog-card__description p + p {
  margin-top: 0.35rem;
}

.blocos-catalog-card__location,
.blocos-catalog-card__meta {
  margin: 0;
  font-size: 0.85rem;
  color: var(--pico-muted-color);
  line-height: 1.4;
}

.blocos-catalog-card__location {
  display: flex;
  align-items: flex-start;
  gap: 0.35rem;
  margin-bottom: 0.35rem;
}

.blocos-catalog-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.85rem;
}

.blocos-catalog-card__meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.blocos-catalog-card__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  width: 2rem;
  height: 2rem;
  color: var(--pico-muted-color);
  text-decoration: none;
}

article.blocos-catalog-card:not(:has(> form:first-child)) > footer.blocos-catalog-card__footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: calc(var(--pico-spacing) * 0.6);
  align-items: center;
  margin: calc(var(--pico-spacing) * 0.65) 0 0;
  padding: calc(var(--pico-spacing) * 0.5) var(--blocos-catalog-card-padding) var(--blocos-catalog-card-padding);
  border-top: 1px solid var(--pico-muted-border-color);
  background: transparent;
  --icon-action-size: 3.25rem;
  --icon-action-font-size: 1.2rem;
}

.blocos-catalog-card__footer form {
  margin: 0;
}

.blocos-catalog-empty {
  text-align: center;
  padding: calc(var(--pico-spacing) * 2) calc(var(--pico-spacing) * 1);
  border: 1px dashed var(--pico-muted-border-color);
  border-radius: var(--pico-border-radius);
}

.blocos-catalog-empty__icon {
  font-size: 2rem;
  color: var(--pico-primary);
  margin-bottom: 0.75rem;
}

.blocos-catalog-empty h2 {
  margin-bottom: 0.5rem;
}

.blocos-catalog-empty p {
  margin-bottom: 1rem;
  color: var(--pico-muted-color);
}

.blocos-catalog-empty__actions {
  display: flex;
  flex-wrap: wrap;
  gap: calc(var(--pico-spacing) * 0.5);
  justify-content: center;
}

@media (max-width: 40rem) {
  .blocos-catalog-card__row {
    grid-template-columns: auto 1fr;
  }

  .blocos-catalog-card__chevron {
    display: none;
  }

  .blocos-catalog-empty__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .blocos-catalog-empty__actions > a,
  .blocos-catalog-empty__actions > button {
    width: 100%;
  }
}
