trix-editor {
  border: 1px solid #bbb;
  border-radius: 3px;
  margin: 0;
  padding: 0.4em 0.6em;
  min-height: 5em;
  outline: none; }

trix-toolbar * {
  box-sizing: border-box; }

trix-toolbar .trix-button-row {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  overflow-x: auto; }

trix-toolbar .trix-button-group {
  display: flex;
  margin-bottom: 10px;
  border: 1px solid #bbb;
  border-top-color: #ccc;
  border-bottom-color: #888;
  border-radius: 3px; }
  trix-toolbar .trix-button-group:not(:first-child) {
    margin-left: 1.5vw; }
    @media (max-width: 768px) {
      trix-toolbar .trix-button-group:not(:first-child) {
        margin-left: 0; } }

trix-toolbar .trix-button-group-spacer {
  flex-grow: 1; }
  @media (max-width: 768px) {
    trix-toolbar .trix-button-group-spacer {
      display: none; } }

trix-toolbar .trix-button {
  position: relative;
  float: left;
  color: rgba(0, 0, 0, 0.6);
  font-size: 0.75em;
  font-weight: 600;
  white-space: nowrap;
  padding: 0 0.5em;
  margin: 0;
  outline: none;
  border: none;
  border-bottom: 1px solid #ddd;
  border-radius: 0;
  background: transparent; }
  trix-toolbar .trix-button:not(:first-child) {
    border-left: 1px solid #ccc; }
  trix-toolbar .trix-button.trix-active {
    background: #cbeefa;
    color: black; }
  trix-toolbar .trix-button:not(:disabled) {
    cursor: pointer; }
  trix-toolbar .trix-button:disabled {
    color: rgba(0, 0, 0, 0.125); }
  @media (max-width: 768px) {
    trix-toolbar .trix-button {
      letter-spacing: -0.01em;
      padding: 0 0.3em; } }

trix-toolbar .trix-button--icon {
  font-size: inherit;
  width: 2.6em;
  height: 1.6em;
  max-width: calc(0.8em + 4vw);
  text-indent: -9999px; }
  @media (max-width: 768px) {
    trix-toolbar .trix-button--icon {
      height: 2em;
      max-width: calc(0.8em + 3.5vw); } }
  trix-toolbar .trix-button--icon::before {
    display: inline-block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0.6;
    content: "";
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain; }
    @media (max-width: 768px) {
      trix-toolbar .trix-button--icon::before {
        right: 6%;
        left: 6%; } }
  trix-toolbar .trix-button--icon.trix-active::before {
    opacity: 1; }
  trix-toolbar .trix-button--icon:disabled::before {
    opacity: 0.125; }

trix-toolbar .trix-button--icon-attach::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M10.5%2018V7.5c0-2.25%203-2.25%203%200V18c0%204.125-6%204.125-6%200V7.5c0-6.375%209-6.375%209%200V18%22%20stroke%3D%22%23000%22%20stroke-width%3D%222%22%20stroke-miterlimit%3D%2210%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E");
  top: 8%;
  bottom: 4%; }

trix-toolbar .trix-button--icon-bold::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M6.522%2019.242a.5.5%200%200%201-.5-.5V5.35a.5.5%200%200%201%20.5-.5h5.783c1.347%200%202.46.345%203.24.982.783.64%201.216%201.562%201.216%202.683%200%201.13-.587%202.129-1.476%202.71a.35.35%200%200%200%20.049.613c1.259.56%202.101%201.742%202.101%203.22%200%201.282-.483%202.334-1.363%203.063-.876.726-2.132%201.12-3.66%201.12h-5.89ZM9.27%207.347v3.362h1.97c.766%200%201.347-.17%201.733-.464.38-.291.587-.716.587-1.27%200-.53-.183-.928-.513-1.198-.334-.273-.838-.43-1.505-.43H9.27Zm0%205.606v3.791h2.389c.832%200%201.448-.177%201.853-.497.399-.315.614-.786.614-1.423%200-.62-.22-1.077-.63-1.385-.418-.313-1.053-.486-1.905-.486H9.27Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-italic::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M9%205h6.5v2h-2.23l-2.31%2010H13v2H6v-2h2.461l2.306-10H9V5Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-link::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M18.948%205.258a4.337%204.337%200%200%200-6.108%200L11.217%206.87a.993.993%200%200%200%200%201.41c.392.39%201.027.39%201.418%200l1.623-1.613a2.323%202.323%200%200%201%203.271%200%202.29%202.29%200%200%201%200%203.251l-2.393%202.38a3.021%203.021%200%200%201-4.255%200l-.05-.049a1.007%201.007%200%200%200-1.418%200%20.993.993%200%200%200%200%201.41l.05.049a5.036%205.036%200%200%200%207.091%200l2.394-2.38a4.275%204.275%200%200%200%200-6.072Zm-13.683%2013.6a4.337%204.337%200%200%200%206.108%200l1.262-1.255a.993.993%200%200%200%200-1.41%201.007%201.007%200%200%200-1.418%200L9.954%2017.45a2.323%202.323%200%200%201-3.27%200%202.29%202.29%200%200%201%200-3.251l2.344-2.331a2.579%202.579%200%200%201%203.631%200c.392.39%201.027.39%201.419%200a.993.993%200%200%200%200-1.41%204.593%204.593%200%200%200-6.468%200l-2.345%202.33a4.275%204.275%200%200%200%200%206.072Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-strike::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M6%2014.986c.088%202.647%202.246%204.258%205.635%204.258%203.496%200%205.713-1.728%205.713-4.463%200-.275-.02-.536-.062-.781h-3.461c.398.293.573.654.573%201.123%200%201.035-1.074%201.787-2.646%201.787-1.563%200-2.773-.762-2.91-1.924H6ZM6.432%2010h3.763c-.632-.314-.914-.715-.914-1.273%200-1.045.977-1.739%202.432-1.739%201.475%200%202.52.723%202.617%201.914h2.764c-.05-2.548-2.11-4.238-5.39-4.238-3.145%200-5.392%201.719-5.392%204.316%200%20.363.04.703.12%201.02ZM4%2011a1%201%200%201%200%200%202h15a1%201%200%201%200%200-2H4Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-quote::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M4.581%208.471c.44-.5%201.056-.834%201.758-.995C8.074%207.17%209.201%207.822%2010%208.752c1.354%201.578%201.33%203.555.394%205.277-.941%201.731-2.788%203.163-4.988%203.56a.622.622%200%200%201-.653-.317c-.113-.205-.121-.49.16-.764.294-.286.567-.566.791-.835.222-.266.413-.54.524-.815.113-.28.156-.597.026-.908-.128-.303-.39-.524-.72-.69a3.02%203.02%200%200%201-1.674-2.7c0-.905.283-1.59.72-2.088Zm9.419%200c.44-.5%201.055-.834%201.758-.995%201.734-.306%202.862.346%203.66%201.276%201.355%201.578%201.33%203.555.395%205.277-.941%201.731-2.789%203.163-4.988%203.56a.622.622%200%200%201-.653-.317c-.113-.205-.122-.49.16-.764.294-.286.567-.566.791-.835.222-.266.412-.54.523-.815.114-.28.157-.597.026-.908-.127-.303-.39-.524-.72-.69a3.02%203.02%200%200%201-1.672-2.701c0-.905.283-1.59.72-2.088Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-heading-1::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M21.5%207.5v-3h-12v3H14v13h3v-13h4.5ZM9%2013.5h3.5v-3h-10v3H6v7h3v-7Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-code::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M3.293%2011.293a1%201%200%200%200%200%201.414l4%204a1%201%200%201%200%201.414-1.414L5.414%2012l3.293-3.293a1%201%200%200%200-1.414-1.414l-4%204Zm13.414%205.414%204-4a1%201%200%200%200%200-1.414l-4-4a1%201%200%201%200-1.414%201.414L18.586%2012l-3.293%203.293a1%201%200%200%200%201.414%201.414Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-bullet-list::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M5%207.5a1.5%201.5%200%201%200%200-3%201.5%201.5%200%200%200%200%203ZM8%206a1%201%200%200%201%201-1h11a1%201%200%201%201%200%202H9a1%201%200%200%201-1-1Zm1%205a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm0%206a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm-2.5-5a1.5%201.5%200%201%201-3%200%201.5%201.5%200%200%201%203%200ZM5%2019.5a1.5%201.5%200%201%200%200-3%201.5%201.5%200%200%200%200%203Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-number-list::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M3%204h2v4H4V5H3V4Zm5%202a1%201%200%200%201%201-1h11a1%201%200%201%201%200%202H9a1%201%200%200%201-1-1Zm1%205a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm0%206a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm-3.5-7H6v1l-1.5%202H6v1H3v-1l1.667-2H3v-1h2.5ZM3%2017v-1h3v4H3v-1h2v-.5H4v-1h1V17H3Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-undo::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M3%2014a1%201%200%200%200%201%201h6a1%201%200%201%200%200-2H6.257c2.247-2.764%205.151-3.668%207.579-3.264%202.589.432%204.739%202.356%205.174%205.405a1%201%200%200%200%201.98-.283c-.564-3.95-3.415-6.526-6.825-7.095C11.084%207.25%207.63%208.377%205%2011.39V8a1%201%200%200%200-2%200v6Zm2-1Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-redo::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M21%2014a1%201%200%200%201-1%201h-6a1%201%200%201%201%200-2h3.743c-2.247-2.764-5.151-3.668-7.579-3.264-2.589.432-4.739%202.356-5.174%205.405a1%201%200%200%201-1.98-.283c.564-3.95%203.415-6.526%206.826-7.095%203.08-.513%206.534.614%209.164%203.626V8a1%201%200%201%201%202%200v6Zm-2-1Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-decrease-nesting-level::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M5%206a1%201%200%200%201%201-1h12a1%201%200%201%201%200%202H6a1%201%200%200%201-1-1Zm4%205a1%201%200%201%200%200%202h9a1%201%200%201%200%200-2H9Zm-3%206a1%201%200%201%200%200%202h12a1%201%200%201%200%200-2H6Zm-3.707-5.707a1%201%200%200%200%200%201.414l2%202a1%201%200%201%200%201.414-1.414L4.414%2012l1.293-1.293a1%201%200%200%200-1.414-1.414l-2%202Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-button--icon-increase-nesting-level::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M5%206a1%201%200%200%201%201-1h12a1%201%200%201%201%200%202H6a1%201%200%200%201-1-1Zm4%205a1%201%200%201%200%200%202h9a1%201%200%201%200%200-2H9Zm-3%206a1%201%200%201%200%200%202h12a1%201%200%201%200%200-2H6Zm-2.293-2.293%202-2a1%201%200%200%200%200-1.414l-2-2a1%201%200%201%200-1.414%201.414L3.586%2012l-1.293%201.293a1%201%200%201%200%201.414%201.414Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E"); }

trix-toolbar .trix-dialogs {
  position: relative; }

trix-toolbar .trix-dialog {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  font-size: 0.75em;
  padding: 15px 10px;
  background: #fff;
  box-shadow: 0 0.3em 1em #ccc;
  border-top: 2px solid #888;
  border-radius: 5px;
  z-index: 5; }

trix-toolbar .trix-input--dialog {
  font-size: inherit;
  font-weight: normal;
  padding: 0.5em 0.8em;
  margin: 0 10px 0 0;
  border-radius: 3px;
  border: 1px solid #bbb;
  background-color: #fff;
  box-shadow: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none; }
  trix-toolbar .trix-input--dialog.validate:invalid {
    box-shadow: #F00 0px 0px 1.5px 1px; }

trix-toolbar .trix-button--dialog {
  font-size: inherit;
  padding: 0.5em;
  border-bottom: none; }

trix-toolbar .trix-dialog--link {
  max-width: 600px; }

trix-toolbar .trix-dialog__link-fields {
  display: flex;
  align-items: baseline; }
  trix-toolbar .trix-dialog__link-fields .trix-input {
    flex: 1; }
  trix-toolbar .trix-dialog__link-fields .trix-button-group {
    flex: 0 0 content;
    margin: 0; }

trix-editor [data-trix-mutable]:not(.attachment__caption-editor) {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

trix-editor [data-trix-mutable]::-moz-selection,
trix-editor [data-trix-cursor-target]::-moz-selection, trix-editor [data-trix-mutable] ::-moz-selection {
  background: none; }

trix-editor [data-trix-mutable]::selection,
trix-editor [data-trix-cursor-target]::selection, trix-editor [data-trix-mutable] ::selection {
  background: none; }

trix-editor .attachment__caption-editor:focus[data-trix-mutable]::-moz-selection {
  background: highlight; }

trix-editor .attachment__caption-editor:focus[data-trix-mutable]::selection {
  background: highlight; }

trix-editor [data-trix-mutable].attachment.attachment--file {
  box-shadow: 0 0 0 2px highlight;
  border-color: transparent; }

trix-editor [data-trix-mutable].attachment img {
  box-shadow: 0 0 0 2px highlight; }

trix-editor .attachment {
  position: relative; }
  trix-editor .attachment:hover {
    cursor: default; }

trix-editor .attachment--preview .attachment__caption:hover {
  cursor: text; }

trix-editor .attachment__progress {
  position: absolute;
  z-index: 1;
  height: 20px;
  top: calc(50% - 10px);
  left: 5%;
  width: 90%;
  opacity: 0.9;
  transition: opacity 200ms ease-in; }
  trix-editor .attachment__progress[value="100"] {
    opacity: 0; }

trix-editor .attachment__caption-editor {
  display: inline-block;
  width: 100%;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
  color: inherit;
  text-align: center;
  vertical-align: top;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none; }

trix-editor .attachment__toolbar {
  position: absolute;
  z-index: 1;
  top: -0.9em;
  left: 0;
  width: 100%;
  text-align: center; }

trix-editor .trix-button-group {
  display: inline-flex; }

trix-editor .trix-button {
  position: relative;
  float: left;
  color: #666;
  white-space: nowrap;
  font-size: 80%;
  padding: 0 0.8em;
  margin: 0;
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent; }
  trix-editor .trix-button:not(:first-child) {
    border-left: 1px solid #ccc; }
  trix-editor .trix-button.trix-active {
    background: #cbeefa; }
  trix-editor .trix-button:not(:disabled) {
    cursor: pointer; }

trix-editor .trix-button--remove {
  text-indent: -9999px;
  display: inline-block;
  padding: 0;
  outline: none;
  width: 1.8em;
  height: 1.8em;
  line-height: 1.8em;
  border-radius: 50%;
  background-color: #fff;
  border: 2px solid highlight;
  box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.25); }
  trix-editor .trix-button--remove::before {
    display: inline-block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0.7;
    content: "";
    background-image: url("data:image/svg+xml,%3Csvg%20height%3D%2224%22%20width%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M19%206.41%2017.59%205%2012%2010.59%206.41%205%205%206.41%2010.59%2012%205%2017.59%206.41%2019%2012%2013.41%2017.59%2019%2019%2017.59%2013.41%2012z%22%2F%3E%3Cpath%20d%3D%22M0%200h24v24H0z%22%20fill%3D%22none%22%2F%3E%3C%2Fsvg%3E");
    background-position: center;
    background-repeat: no-repeat;
    background-size: 90%; }
  trix-editor .trix-button--remove:hover {
    border-color: #333; }
    trix-editor .trix-button--remove:hover::before {
      opacity: 1; }

trix-editor .attachment__metadata-container {
  position: relative; }

trix-editor .attachment__metadata {
  position: absolute;
  left: 50%;
  top: 2em;
  transform: translate(-50%, 0);
  max-width: 90%;
  padding: 0.1em 0.6em;
  font-size: 0.8em;
  color: #fff;
  background-color: rgba(0, 0, 0, 0.7);
  border-radius: 3px; }
  trix-editor .attachment__metadata .attachment__name {
    display: inline-block;
    max-width: 100%;
    vertical-align: bottom;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }
  trix-editor .attachment__metadata .attachment__size {
    margin-left: 0.2em;
    white-space: nowrap; }

.trix-content {
  line-height: 1.5;
  overflow-wrap: break-word;
  word-break: break-word; }
  .trix-content * {
    box-sizing: border-box;
    margin: 0;
    padding: 0; }
  .trix-content h1 {
    font-size: 1.2em;
    line-height: 1.2; }
  .trix-content blockquote {
    border: 0 solid #ccc;
    border-left-width: 0.3em;
    margin-left: 0.3em;
    padding-left: 0.6em; }
  .trix-content [dir=rtl] blockquote,
  .trix-content blockquote[dir=rtl] {
    border-width: 0;
    border-right-width: 0.3em;
    margin-right: 0.3em;
    padding-right: 0.6em; }
  .trix-content li {
    margin-left: 1em; }
  .trix-content [dir=rtl] li {
    margin-right: 1em; }
  .trix-content pre {
    display: inline-block;
    width: 100%;
    vertical-align: top;
    font-family: monospace;
    font-size: 0.9em;
    padding: 0.5em;
    white-space: pre;
    background-color: #eee;
    overflow-x: auto; }
  .trix-content img {
    max-width: 100%;
    height: auto; }
  .trix-content .attachment {
    display: inline-block;
    position: relative;
    max-width: 100%; }
    .trix-content .attachment a {
      color: inherit;
      text-decoration: none; }
      .trix-content .attachment a:hover, .trix-content .attachment a:visited:hover {
        color: inherit; }
  .trix-content .attachment__caption {
    text-align: center; }
    .trix-content .attachment__caption .attachment__name + .attachment__size::before {
      content: ' \2022 '; }
  .trix-content .attachment--preview {
    width: 100%;
    text-align: center; }
    .trix-content .attachment--preview .attachment__caption {
      color: #666;
      font-size: 0.9em;
      line-height: 1.2; }
  .trix-content .attachment--file {
    color: #333;
    line-height: 1;
    margin: 0 2px 2px 2px;
    padding: 0.4em 1em;
    border: 1px solid #bbb;
    border-radius: 5px; }
  .trix-content .attachment-gallery {
    display: flex;
    flex-wrap: wrap;
    position: relative; }
    .trix-content .attachment-gallery .attachment {
      flex: 1 0 33%;
      padding: 0 0.5em;
      max-width: 33%; }
    .trix-content .attachment-gallery.attachment-gallery--2 .attachment, .trix-content .attachment-gallery.attachment-gallery--4 .attachment {
      flex-basis: 50%;
      max-width: 50%; }
/*
 * Provides a drop-in pointer for the default Trix stylesheet that will format the toolbar and
 * the trix-editor content (whether displayed or under editing). Feel free to incorporate this
 * inclusion directly in any other asset bundle and remove this file.
 *

*/

/*
 * We need to override trix.css’s image gallery styles to accommodate the
 * <action-text-attachment> element we wrap around attachments. Otherwise,
 * images in galleries will be squished by the max-width: 33%; rule.
*/
.trix-content .attachment-gallery > action-text-attachment,
.trix-content .attachment-gallery > .attachment {
    flex: 1 0 33%;
    padding: 0 0.5em;
    max-width: 33%;
}

.trix-content .attachment-gallery.attachment-gallery--2 > action-text-attachment,
.trix-content .attachment-gallery.attachment-gallery--2 > .attachment, .trix-content .attachment-gallery.attachment-gallery--4 > action-text-attachment,
.trix-content .attachment-gallery.attachment-gallery--4 > .attachment {
    flex-basis: 50%;
    max-width: 50%;
}

.trix-content action-text-attachment .attachment {
    padding: 0 !important;
    max-width: 100% !important;
}

.trix-content ol li {
    list-style: decimal;
    margin-left: 1em;
}

.trix-content ul li {
    list-style: disc;
    margin-left: 1em;
}

.trix-editor {
    max-width: 100%;
    overflow: auto;
    overflow-wrap: break-word;
}

.trix-content {
    line-height: 1.5;
    overflow-wrap: break-word;
    word-break: break-word;
}
/*@import 'actiontext.css';*/
@import "./pagy.css";

@tailwind base;
@tailwind components;
@tailwind utilities;

html {
    font-size: 88%;
}

label {
    @apply block text-sm font-medium leading-6 text-gray-900;
}

dt {
    @apply text-sm font-medium text-gray-900;
}

dd {
    @apply mt-1 text-sm leading-6 text-gray-700 sm:col-span-2 sm:mt-0;
}

input[type="text"],
input[type="tel"],
input[type="email"],
input[type="date"],
input[type="time"],
input[type="number"],
input[type="password"],
select {
    @apply block w-full rounded-xl border border-gray-200 placeholder:text-gray-400 text-gray-900 py-2.5 px-3.5 focus:border-gray-400 focus:ring-0 sm:text-sm transition-colors duration-200;
}

input[type="checkbox"] {
    @apply h-4 w-4 rounded-md border-gray-300 text-gray-900 focus:ring-gray-900 transition-colors duration-200;
}

textarea {
    @apply block w-full rounded-xl border border-gray-200 placeholder:text-gray-400 text-gray-900 py-2.5 px-3.5 focus:border-gray-400 focus:ring-0 sm:text-sm transition-colors duration-200;
}

.alert-info {
    @apply p-4 mb-4 text-sm text-sky-700 rounded-xl bg-sky-50 border border-sky-100;
}

.alert-danger {
    @apply p-4 mb-4 text-sm text-red-700 rounded-xl bg-red-50 border border-red-100;
}

.alert-success {
    @apply p-4 mb-4 text-sm text-emerald-700 rounded-xl bg-emerald-50 border border-emerald-100;
}

.alert-warning {
    @apply p-4 mb-4 text-sm text-amber-700 rounded-xl bg-amber-50 border border-amber-100;
}

.alert-dark {
    @apply p-4 text-sm text-gray-700 rounded-xl bg-gray-50 border border-gray-100;
}


@layer components {
    /* Typography */
    .default-h1 {
        @apply text-2xl font-semibold text-gray-900;
    }

    .default-p {
        @apply mt-1 text-sm text-gray-500;
    }

    .default-dl-item {
        @apply px-4 py-6 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6;
    }

    /* Modern Card Components */
    .card {
        @apply bg-white rounded-2xl border border-gray-100 shadow-card;
    }

    .card.proc-calc-section,
    .card.clinical-hour-calc-section {
        @apply border border-slate-200 transition-[box-shadow,border-color] duration-150 ease-out;
        box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    }

    .card.proc-calc-section.is-proc-calc-section-active,
    .card.clinical-hour-calc-section.is-clinical-hour-calc-section-active {
        @apply border-slate-200;
        box-shadow: inset 3px 0 0 0 theme("colors.emerald.600"), 0 1px 2px 0 rgb(0 0 0 / 0.05);
    }

    .card.proc-calc-section .card-header,
    .card.clinical-hour-calc-section .card-header {
        @apply border-b-0 pb-0 mb-4;
    }

    .proc-calc-segmented {
        @apply grid w-full gap-2;
    }

    .proc-calc-segmented--cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .proc-calc-segmented--cols-4 {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .proc-calc-segment {
        @apply relative min-w-0 cursor-pointer;
    }

    .proc-calc-segment-face {
        @apply flex h-full min-h-[3.25rem] flex-col items-center justify-center gap-0.5 rounded-lg border border-slate-200 bg-slate-50 px-1.5 py-2 text-center transition-all duration-150;
    }

    .proc-calc-segment-label {
        @apply block w-full text-[11px] font-medium leading-tight text-slate-500;
    }

    .proc-calc-segment-multiplier {
        @apply text-xs font-bold tabular-nums leading-none text-slate-500;
    }

    .proc-calc-margin-slider {
        @apply min-w-0 flex-1 accent-emerald-600;
    }

    .proc-calc-margin-slider--high {
        @apply accent-amber-500;
    }

    .proc-calc-segment:hover .proc-calc-segment-face {
        @apply border-slate-300 bg-slate-100;
    }

    .proc-calc-segment--increase:hover .proc-calc-segment-face {
        @apply border-emerald-200 bg-emerald-50/90;
    }

    .proc-calc-segment--decrease:hover .proc-calc-segment-face {
        @apply border-slate-300 bg-slate-100;
    }

    .proc-calc-segment input:checked + .proc-calc-segment-face,
    .proc-calc-segment:has(input:checked) .proc-calc-segment-face {
        @apply border-2 border-emerald-500 bg-white shadow-md;
    }

    .proc-calc-segment input:checked + .proc-calc-segment-face .proc-calc-segment-label,
    .proc-calc-segment:has(input:checked) .proc-calc-segment-face .proc-calc-segment-label {
        @apply text-slate-900 font-semibold;
    }

    .proc-calc-segment input:checked + .proc-calc-segment-face .proc-calc-segment-multiplier,
    .proc-calc-segment:has(input:checked) .proc-calc-segment-face .proc-calc-segment-multiplier {
        @apply text-sm font-extrabold text-emerald-700;
    }

    .proc-calc-segment input:focus-visible + .proc-calc-segment-face {
        @apply ring-2 ring-emerald-500 ring-offset-1;
    }

    .card-header {
        @apply px-6 py-4 border-b border-gray-50;
    }

    .card-body {
        @apply p-6;
    }

    .patient-header-card .card-body {
        @apply p-8;
    }

    .card-footer {
        @apply px-6 py-4 border-t border-gray-50;
    }

    /* Stat cards with accent colors (like reference images) */
    .stat-card {
        @apply bg-white rounded-2xl p-5 border border-gray-100 shadow-card;
    }

    .stat-card-peach {
        @apply rounded-2xl p-5 bg-orange-50 border border-orange-100;
    }

    .stat-card-mint {
        @apply rounded-2xl p-5 bg-emerald-50 border border-emerald-100;
    }

    .stat-card-sky {
        @apply rounded-2xl p-5 bg-sky-50 border border-sky-100;
    }

    .stat-card-lavender {
        @apply rounded-2xl p-5 bg-violet-50 border border-violet-100;
    }

    /* Legacy components (keeping for compatibility) */
    .default-area {
        @apply bg-white p-6 rounded-2xl border border-gray-100 shadow-card;
    }

    .default-tab {
        @apply inline-flex items-center gap-1.5 border-b-2 border-transparent px-2.5 py-4 text-sm font-medium text-slate-500 rounded-t-lg transition-all hover:text-slate-800 data-[selected=true]:border-ow-600 data-[selected=true]:text-ow-700 data-[selected=true]:font-semibold;
    }

    .patient-tab {
        @apply text-slate-500 hover:text-slate-700 hover:bg-slate-50 data-[selected=true]:border-blue-600 data-[selected=true]:text-blue-600 data-[selected=true]:font-semibold data-[selected=true]:hover:bg-transparent;
    }

    .patient-tab .material-symbols-outlined {
        @apply text-slate-400 transition-colors;
    }

    .patient-tab:hover .material-symbols-outlined {
        @apply text-slate-600;
    }

    .patient-tab[data-selected="true"] .material-symbols-outlined {
        @apply text-blue-600;
    }

    .default-primary-btn {
        @apply float-right flex rounded-xl px-4 py-2.5 text-sm font-medium text-white bg-gray-900 hover:bg-gray-800 transition-colors duration-200 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-gray-900;
    }

    /* Button styles */
    .button-primary {
        @apply rounded-xl bg-gray-900 text-sm font-medium text-white shadow-sm px-4 py-2.5 hover:bg-gray-800 transition-colors duration-200 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-gray-900;
    }

    .button-secondary {
        @apply rounded-xl bg-white text-sm font-medium text-gray-700 shadow-sm border border-gray-200 px-4 py-2.5 hover:bg-gray-50 transition-colors duration-200;
    }

    .btn-primary {
        @apply rounded-xl bg-gray-900 text-sm font-medium text-white shadow-sm px-4 py-2.5 hover:bg-gray-800 transition-colors duration-200 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-gray-900;
    }

    .btn-secondary {
        @apply rounded-xl bg-white text-sm font-medium text-gray-700 shadow-sm border border-gray-200 px-4 py-2.5 hover:bg-gray-50 transition-colors duration-200 disabled:cursor-not-allowed disabled:border-slate-200 disabled:bg-slate-100 disabled:text-slate-400 disabled:shadow-none disabled:hover:bg-slate-100;
    }

    .btn-tertiary {
        @apply rounded-xl bg-gray-100 text-sm font-medium text-gray-700 shadow-sm px-4 py-2.5 hover:bg-gray-200 transition-colors duration-200;
    }

    .btn-success {
        @apply rounded-xl bg-emerald-600 text-sm font-medium text-white shadow-sm px-4 py-2.5 hover:bg-emerald-700 transition-colors duration-200;
    }

    .btn-danger {
        @apply rounded-xl bg-red-600 text-sm font-medium text-white shadow-sm px-4 py-2.5 hover:bg-red-700 transition-colors duration-200;
    }

    .ow-container {
        @apply rounded-2xl bg-white p-6 border border-gray-100 shadow-card;
    }

    /* Badge styles */
    .badge {
        @apply inline-flex items-center rounded-full px-2.5 py-0.5 text-xs font-medium;
    }

    .badge-gray {
        @apply bg-gray-100 text-gray-700;
    }

    .badge-success {
        @apply bg-emerald-50 text-emerald-700;
    }

    .badge-warning {
        @apply bg-amber-50 text-amber-700;
    }

    .badge-danger {
        @apply bg-red-50 text-red-700;
    }

    .badge-info {
        @apply bg-sky-50 text-sky-700;
    }
}

/* Tailwind Typograhy plugin */
.trix-editor {
    @apply prose max-w-none marker:text-black
}

.announcement-content .trix-content {
  @apply prose prose-slate max-w-none text-sm text-gray-700;
}

.announcement-content .trix-content > :first-child {
  @apply mt-0;
}

@keyframes crm-reminder-card-in {
  from {
    opacity: 0;
    transform: translateY(10px) scale(0.985);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.crm-reminder-card {
  animation: crm-reminder-card-in 420ms cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: var(--crm-reminder-delay, 0ms);
  will-change: transform, opacity;
}

@media (prefers-reduced-motion: reduce) {
  .crm-reminder-card {
    animation: none;
    opacity: 1;
    transform: none !important;
    will-change: auto;
  }
}

.announcement-content .trix-content > :last-child {
  @apply mb-0;
}

.announcement-content .trix-content a {
  @apply text-blue-600 no-underline transition-colors duration-200 hover:text-blue-700 hover:underline;
}

.announcement-content .trix-content ul {
  @apply list-disc pl-5;
}

.announcement-content .trix-content ol {
  @apply list-decimal pl-5;
}

.announcement-content .announcement-video-embed {
  @apply relative my-4 overflow-hidden rounded-2xl bg-black shadow-soft;
  aspect-ratio: 16 / 9;
}

.announcement-content .announcement-video-embed iframe {
  @apply absolute inset-0 h-full w-full border-0;
}

.ow-blog-body {
  margin: 0;
  min-height: 100vh;
  background: #fafafa;
  color: #0f172a;
  font-family: "Plus Jakarta Sans", Inter, sans-serif;
  letter-spacing: 0;
}

.ow-blog-header {
  position: sticky;
  top: 0;
  z-index: 30;
  border-bottom: 1px solid rgba(226, 232, 240, 0.8);
  background: rgba(250, 250, 250, 0.94);
  backdrop-filter: blur(16px);
}

.ow-blog-nav {
  display: flex;
  width: min(100% - 2rem, 72rem);
  min-height: 4.5rem;
  margin: 0 auto;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.ow-blog-brand,
.ow-blog-brand-logo {
  display: block;
}

.ow-blog-nav-actions,
.ow-blog-footer-links {
  display: flex;
  align-items: center;
  gap: 0.875rem;
}

.ow-blog-nav-link,
.ow-blog-footer a,
.ow-blog-back-link {
  color: #475569;
  font-size: 0.875rem;
  font-weight: 700;
  text-decoration: none;
  transition: color 160ms ease;
}

.ow-blog-nav-link:hover,
.ow-blog-footer a:hover,
.ow-blog-back-link:hover {
  color: #0f172a;
}

.ow-blog-nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #10b981;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 0.75rem 1.25rem;
  text-decoration: none;
  box-shadow: 0 14px 30px -18px rgba(16, 185, 129, 0.8);
  transition: background-color 180ms ease, transform 180ms ease;
}

.ow-blog-nav-cta:hover {
  background: #059669;
  transform: translateY(-1px);
}

.ow-blog-hero,
.ow-blog-shell,
.ow-blog-category-hero,
.ow-blog-article,
.ow-blog-footer {
  width: min(100% - 2rem, 72rem);
  margin-inline: auto;
}

.ow-blog-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(20rem, 0.72fr);
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: end;
  padding: clamp(4rem, 8vw, 7rem) 0 clamp(2rem, 5vw, 4rem);
}

.ow-blog-kicker,
.ow-blog-featured-label,
.ow-blog-preview-badge {
  color: #059669;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ow-blog-hero h1,
.ow-blog-category-hero h1,
.ow-blog-article-header h1 {
  margin: 0;
  color: #0f172a;
  font-family: "Plus Jakarta Sans", Inter, sans-serif;
  font-size: clamp(2.4rem, 6vw, 5.4rem);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: 0;
}

.ow-blog-hero-copy p:last-child,
.ow-blog-category-hero p {
  max-width: 42rem;
  margin-top: 1.5rem;
  color: #475569;
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.75;
}

.ow-blog-featured {
  display: block;
  border: 1px solid #d1fae5;
  border-radius: 1.5rem;
  background: #ecfdf5;
  padding: clamp(1.25rem, 3vw, 2rem);
  color: #064e3b;
  text-decoration: none;
  transition: transform 180ms ease, border-color 180ms ease;
}

.ow-blog-featured:hover {
  border-color: #10b981;
  transform: translateY(-2px);
}

.ow-blog-featured h2 {
  margin: 0.8rem 0 0;
  color: #0f172a;
  font-size: clamp(1.35rem, 2.5vw, 2rem);
  font-weight: 800;
  line-height: 1.1;
}

.ow-blog-featured p,
.ow-blog-card p,
.ow-blog-empty p,
.ow-blog-footer p {
  color: #475569;
  line-height: 1.7;
}

.ow-blog-read-more {
  display: inline-block;
  margin-top: 1.25rem;
  color: #047857;
  font-weight: 800;
}

.ow-blog-shell {
  padding-bottom: clamp(4rem, 8vw, 7rem);
}

.ow-blog-category-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 2rem;
}

.ow-blog-category-pill {
  display: inline-flex;
  width: max-content;
  align-items: center;
  border: 1px solid #d1fae5;
  border-radius: 999px;
  background: #fff;
  color: #047857;
  font-size: 0.8rem;
  font-weight: 800;
  padding: 0.45rem 0.8rem;
  text-decoration: none;
}

.ow-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.ow-blog-card {
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  background: #fff;
}

.ow-blog-card-media {
  display: block;
  aspect-ratio: 5 / 3;
  overflow: hidden;
  background: #ecfdf5;
}

.ow-blog-card-media img,
.ow-blog-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ow-blog-card-body {
  display: flex;
  min-height: 17rem;
  flex-direction: column;
  padding: 1.25rem;
}

.ow-blog-card-meta,
.ow-blog-post-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 700;
}

.ow-blog-card-meta a {
  color: #047857;
  text-decoration: none;
}

.ow-blog-card h2 {
  margin: 0.8rem 0 0;
  font-size: 1.2rem;
  font-weight: 800;
  line-height: 1.2;
}

.ow-blog-card h2 a,
.ow-blog-card-footer a {
  color: #0f172a;
  text-decoration: none;
}

.ow-blog-card-footer {
  display: flex;
  margin-top: auto;
  align-items: center;
  justify-content: space-between;
  color: #64748b;
  font-size: 0.85rem;
  font-weight: 800;
}

.ow-blog-category-hero {
  padding: clamp(3rem, 7vw, 6rem) 0 2rem;
}

.ow-blog-category-hero h1 {
  margin-top: 1rem;
}

.ow-blog-article {
  max-width: 52rem;
  padding: clamp(3rem, 7vw, 6rem) 0 clamp(4rem, 8vw, 7rem);
}

.ow-blog-article-header {
  display: grid;
  gap: 1rem;
}

.ow-blog-article-header h1 {
  font-size: clamp(2.3rem, 5vw, 4.2rem);
}

.ow-blog-cover {
  aspect-ratio: 16 / 9;
  margin: 2.5rem 0;
  overflow: hidden;
  border-radius: 1.25rem;
  background: #ecfdf5;
}

.ow-blog-article-body {
  color: #1e293b;
  font-size: 1.1rem;
  line-height: 1.85;
}

.ow-blog-article-body .trix-content > :first-child {
  margin-top: 0;
}

.ow-blog-article-body .trix-content h2,
.ow-blog-article-body .trix-content h3 {
  margin: 2.25rem 0 0.8rem;
  color: #0f172a;
  font-weight: 800;
  line-height: 1.15;
}

.ow-blog-article-body .trix-content h2 {
  font-size: 1.75rem;
}

.ow-blog-article-body .trix-content h3 {
  font-size: 1.35rem;
}

.ow-blog-article-body .trix-content p,
.ow-blog-article-body .trix-content div {
  margin: 1rem 0;
}

.ow-blog-article-body .trix-content a {
  color: #047857;
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.ow-blog-article-body .trix-content ul,
.ow-blog-article-body .trix-content ol {
  margin: 1.25rem 0;
  padding-left: 1.4rem;
}

.ow-blog-article-body .trix-content ul {
  list-style: disc;
}

.ow-blog-article-body .trix-content ol {
  list-style: decimal;
}

.ow-blog-video-embed {
  position: relative;
  aspect-ratio: 16 / 9;
  margin: 2rem 0;
  overflow: hidden;
  border-radius: 1.25rem;
  background: #020617;
}

.ow-blog-video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.ow-blog-video-link {
  display: inline-flex;
  margin: 1.5rem 0;
  color: #047857;
  font-weight: 700;
}

.ow-blog-article-cta,
.ow-blog-empty {
  display: flex;
  margin-top: 3rem;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  border-radius: 1.25rem;
  background: #ecfdf5;
  padding: 1.5rem;
}

.ow-blog-article-cta h2,
.ow-blog-empty h2 {
  margin: 0.25rem 0 0;
  color: #064e3b;
  font-size: 1.4rem;
  font-weight: 800;
}

.ow-blog-footer {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid #e2e8f0;
  padding: 2rem 0;
}

.ow-partner-body {
  margin: 0;
  min-height: 100vh;
  background: #fafafa;
  color: #0f172a;
  font-family: "Plus Jakarta Sans", Inter, sans-serif;
  letter-spacing: 0;
  overflow-x: hidden;
}

.ow-partner-header {
  position: sticky;
  top: 0;
  z-index: 30;
  border-bottom: 1px solid rgba(226, 232, 240, 0.8);
  background: rgba(250, 250, 250, 0.94);
  backdrop-filter: blur(16px);
}

.ow-partner-nav {
  display: flex;
  box-sizing: border-box;
  width: min(calc(100% - 2rem), 72rem);
  min-height: 4.5rem;
  margin: 0 auto;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.ow-partner-brand,
.ow-partner-brand-logo {
  display: block;
}

.ow-partner-nav-actions,
.ow-partner-footer-links,
.ow-partner-hero-actions,
.ow-partner-social-links {
  display: flex;
  align-items: center;
  gap: 0.875rem;
}

.ow-partner-nav-link,
.ow-partner-footer a,
.ow-partner-social-links a {
  color: #475569;
  font-size: 0.875rem;
  font-weight: 700;
  text-decoration: none;
  transition: color 160ms ease;
}

.ow-partner-nav-link:hover,
.ow-partner-footer a:hover,
.ow-partner-social-links a:hover {
  color: #0f172a;
}

.ow-partner-nav-cta,
.ow-partner-card-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #10b981;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 0.75rem 1.25rem;
  text-decoration: none;
  box-shadow: 0 14px 30px -18px rgba(16, 185, 129, 0.8);
  transition: background-color 180ms ease, transform 180ms ease;
}

.ow-partner-nav-cta:hover,
.ow-partner-card-cta:hover {
  background: #059669;
  transform: translateY(-1px);
}

.ow-partner-secondary-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #fff;
  color: #334155;
  font-size: 0.875rem;
  font-weight: 800;
  padding: 0.75rem 1.25rem;
  text-decoration: none;
  transition: border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.ow-partner-secondary-cta:hover {
  border-color: #10b981;
  color: #047857;
  transform: translateY(-1px);
}

.ow-partner-hero,
.ow-partner-shell,
.ow-partner-footer {
  box-sizing: border-box;
  width: min(calc(100% - 2rem), 72rem);
  margin-inline: auto;
}

.ow-partner-page {
  width: 100%;
}

.ow-partner-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(20rem, 0.72fr);
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: end;
  padding: clamp(4rem, 8vw, 7rem) 0 clamp(2rem, 5vw, 4rem);
}

.ow-partner-hero-copy,
.ow-partner-guide-card,
.ow-partner-profile-card,
.ow-partner-card-body,
.ow-partner-video-copy,
.ow-partner-panel,
.ow-partner-empty {
  min-width: 0;
}

.ow-partner-show-hero {
  align-items: start;
}

.ow-partner-kicker,
.ow-partner-card-label,
.ow-partner-featured-label {
  color: #059669;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ow-partner-hero h1 {
  max-width: 100%;
  margin: 0;
  color: #0f172a;
  font-family: "Plus Jakarta Sans", Inter, sans-serif;
  font-size: clamp(2.4rem, 6vw, 5.4rem);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: 0;
  overflow-wrap: break-word;
}

.ow-partner-show-hero h1 {
  font-size: clamp(2.3rem, 5vw, 4.2rem);
}

.ow-partner-hero-copy > p:last-of-type {
  max-width: 42rem;
  margin-top: 1.5rem;
  color: #475569;
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.75;
}

.ow-partner-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.5rem;
}

.ow-partner-tag-list span {
  display: inline-flex;
  width: max-content;
  align-items: center;
  border: 1px solid #d1fae5;
  border-radius: 999px;
  background: #fff;
  color: #047857;
  font-size: 0.8rem;
  font-weight: 800;
  padding: 0.45rem 0.8rem;
}

.ow-partner-hero-actions {
  flex-wrap: wrap;
  margin-top: 2rem;
}

.ow-partner-bonus {
  max-width: 42rem;
  margin-top: 1.25rem;
  border: 1px solid #a7f3d0;
  border-radius: 1rem;
  background: #ecfdf5;
  color: #065f46;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.65;
  padding: 1rem 1.1rem;
}

.ow-partner-guide-card,
.ow-partner-profile-card,
.ow-partner-panel,
.ow-partner-video-gallery,
.ow-partner-card,
.ow-partner-empty,
.ow-partner-quote {
  border: 1px solid #e2e8f0;
  border-radius: 1.25rem;
  background: #fff;
}

.ow-partner-guide-card,
.ow-partner-panel,
.ow-partner-empty,
.ow-partner-quote {
  padding: clamp(1.25rem, 3vw, 1.6rem);
}

.ow-partner-step-list {
  display: grid;
  gap: 0.9rem;
  margin: 1.25rem 0 0;
  padding: 0;
  list-style: none;
}

.ow-partner-reason-list {
  display: grid;
  gap: 1rem;
  margin-top: 1.35rem;
}

.ow-partner-reason-list article {
  border-top: 1px solid #e2e8f0;
  padding-top: 1rem;
}

.ow-partner-reason-list h3 {
  margin: 0;
  color: #0f172a;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.35;
}

.ow-partner-reason-list p {
  margin: 0.45rem 0 0;
  color: #475569;
  font-size: 0.94rem;
  line-height: 1.65;
}

.ow-partner-step-list li {
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
}

.ow-partner-step-list span {
  display: inline-flex;
  width: 1.75rem;
  height: 1.75rem;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #ecfdf5;
  color: #047857;
  font-size: 0.85rem;
  font-weight: 800;
}

.ow-partner-step-list p {
  margin: 0.15rem 0 0;
  color: #475569;
  line-height: 1.65;
}

.ow-partner-shell {
  padding-bottom: clamp(4rem, 8vw, 7rem);
}

.ow-partner-directory-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
}

.ow-partner-card {
  display: grid;
  grid-template-columns: minmax(10rem, 0.7fr) minmax(0, 1fr);
  overflow: hidden;
  transition: border-color 180ms ease, transform 180ms ease;
}

.ow-partner-card:hover {
  border-color: #10b981;
  transform: translateY(-2px);
}

.ow-partner-card-media {
  position: relative;
  display: flex;
  min-height: 17rem;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #ecfdf5;
  color: #047857;
  text-decoration: none;
}

.ow-partner-card-media img,
.ow-partner-profile-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ow-partner-card-media img {
  transition: transform 300ms ease;
}

.ow-partner-card:hover .ow-partner-card-media img {
  transform: scale(1.03);
}

.ow-partner-initials,
.ow-partner-profile-initials {
  color: #047857;
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 800;
}

.ow-partner-featured-label {
  position: absolute;
  top: 1rem;
  left: 1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.96);
  padding: 0.45rem 0.75rem;
}

.ow-partner-card-body {
  display: flex;
  min-height: 17rem;
  flex-direction: column;
  padding: 1.25rem;
}

.ow-partner-card-body .ow-partner-tag-list {
  margin-top: 0;
}

.ow-partner-card h2,
.ow-partner-profile-card h2,
.ow-partner-panel h2,
.ow-partner-video-copy h2,
.ow-partner-empty h2 {
  max-width: 100%;
  margin: 0.9rem 0 0;
  color: #0f172a;
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.15;
  overflow-wrap: break-word;
}

.ow-partner-card p,
.ow-partner-profile-card p,
.ow-partner-panel p,
.ow-partner-video-copy p,
.ow-partner-video-card p,
.ow-partner-empty p,
.ow-partner-footer p {
  color: #475569;
  line-height: 1.7;
}

.ow-partner-card-headline,
.ow-partner-profile-credential,
.ow-partner-video-title {
  color: #0f172a !important;
  font-weight: 800;
}

.ow-partner-card-footer {
  display: flex;
  margin-top: auto;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 1.25rem;
}

.ow-partner-card-cta {
  flex: 0 0 auto;
  padding: 0.65rem 1rem;
}

.ow-partner-proof-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 1.25rem;
}

.ow-partner-proof-grid div {
  border-radius: 1rem;
  background: #f8fafc;
  padding: 0.85rem 1rem;
}

.ow-partner-proof-grid dt {
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 700;
}

.ow-partner-proof-grid dd {
  margin: 0.2rem 0 0;
  color: #0f172a;
  font-size: 1rem;
  font-weight: 800;
}

.ow-partner-proof-grid-large {
  margin-top: 0;
}

.ow-partner-profile-card {
  overflow: hidden;
}

.ow-partner-profile-image,
.ow-partner-profile-initials {
  display: flex;
  height: 22rem;
  align-items: center;
  justify-content: center;
  background: #ecfdf5;
}

.ow-partner-profile-body {
  padding: 1.4rem;
}

.ow-partner-social-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1.15rem;
}

.ow-partner-social-pills a {
  border-radius: 999px;
  background: #f8fafc;
  color: #475569;
  font-size: 0.78rem;
  font-weight: 800;
  padding: 0.45rem 0.75rem;
  text-decoration: none;
}

.ow-partner-social-pills a:hover {
  background: #ecfdf5;
  color: #047857;
}

.ow-partner-video-gallery {
  overflow: hidden;
  margin-bottom: 1.25rem;
}

.ow-partner-video-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.45fr);
}

.ow-partner-video-frame {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #020617;
}

.ow-partner-video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.ow-partner-video-main > .ow-partner-video-frame {
  margin: 0.75rem;
  border-radius: 1rem;
}

.ow-partner-video-copy {
  border-left: 1px solid #e2e8f0;
  padding: 1.5rem;
}

.ow-partner-video-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  border-top: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 1rem;
}

.ow-partner-video-card {
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  background: #fff;
}

.ow-partner-video-card-body {
  padding: 1rem;
}

.ow-partner-video-card h3 {
  margin: 0;
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 800;
}

.ow-partner-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 1.25rem;
}

.ow-partner-content-stack {
  display: grid;
  gap: 1.25rem;
}

.ow-partner-soft-list {
  display: grid;
  gap: 0.75rem;
  margin: 1.25rem 0 0;
  padding: 0;
  list-style: none;
}

.ow-partner-soft-list li {
  border-radius: 1rem;
  background: #f8fafc;
  color: #334155;
  line-height: 1.7;
  padding: 0.85rem 1rem;
}

.ow-partner-quote {
  color: #334155;
  font-size: 1.05rem;
  line-height: 1.8;
}

.ow-partner-quote footer {
  margin-top: 1rem;
  color: #64748b;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ow-partner-disclosure {
  border: 1px solid #e2e8f0;
  border-radius: 1rem;
  background: rgba(255, 255, 255, 0.74);
  color: #64748b;
  font-size: 0.85rem;
  line-height: 1.65;
  padding: 1rem;
}

.ow-partner-empty {
  max-width: 42rem;
  background: #ecfdf5;
}

.ow-partner-footer {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-top: 1px solid #e2e8f0;
  padding: 2rem 0;
}

@media (max-width: 900px) {
  .ow-blog-hero,
  .ow-blog-grid,
  .ow-partner-hero,
  .ow-partner-directory-grid,
  .ow-partner-card,
  .ow-partner-video-main,
  .ow-partner-content-grid {
    grid-template-columns: 1fr;
  }

  .ow-blog-card-body,
  .ow-partner-card-body {
    min-height: auto;
  }

  .ow-partner-video-copy {
    border-top: 1px solid #e2e8f0;
    border-left: 0;
  }
}

@media (max-width: 640px) {
  .ow-partner-nav,
  .ow-partner-hero,
  .ow-partner-shell,
  .ow-partner-footer {
    width: 100%;
    max-width: 100%;
    padding-right: 1rem;
    padding-left: 1rem;
  }

  .ow-blog-nav,
  .ow-blog-footer,
  .ow-blog-article-cta,
  .ow-partner-nav,
  .ow-partner-footer {
    align-items: flex-start;
    flex-direction: column;
  }

  .ow-blog-nav-actions,
  .ow-partner-hero-actions,
  .ow-partner-card-footer {
    width: 100%;
    flex-wrap: wrap;
  }

  .ow-partner-nav-actions {
    display: grid;
    width: 100%;
    max-width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
  }

  .ow-partner-nav-link {
    min-width: 0;
  }

  .ow-partner-nav-cta {
    grid-column: 1 / -1;
  }

  .ow-partner-nav-cta,
  .ow-partner-secondary-cta,
  .ow-partner-card-cta {
    box-sizing: border-box;
    width: 100%;
  }

  .ow-partner-video-grid,
  .ow-partner-proof-grid {
    grid-template-columns: 1fr;
  }

  .ow-partner-hero h1 {
    max-width: 12ch;
    font-size: clamp(2rem, 8vw, 2.25rem);
    line-height: 1.08;
  }

  .ow-partner-empty h2 {
    max-width: 18ch;
  }

  .ow-partner-hero-copy > p:last-of-type,
  .ow-partner-empty p {
    max-width: 32ch;
  }
}

/* Progress Editor - Toolbar, área de texto com bg-slate-50 quando vazia */
.progress-editor-container trix-toolbar {
  @apply bg-slate-50/80 border-b border-slate-200 p-2;
}

.progress-editor-container trix-toolbar .trix-button-group {
  @apply border-0;
}

.progress-editor-container trix-toolbar .trix-button {
  @apply hover:bg-slate-100 rounded;
}

.progress-editor-container .progress-editor-input {
  @apply bg-slate-50 transition-colors duration-200;
}

.progress-editor-container:focus-within .progress-editor-input {
  @apply bg-white;
}

/* Active Storage Direct Upload progress (Rails Guides-inspired)
   These styles power the elements inserted by file_upload_controller.js:
   .direct-upload, .direct-upload__progress, and state modifiers.
   See: https://guides.rubyonrails.org/active_storage_overview.html#direct-uploads
*/
.direct-upload {
  position: relative;
  display: inline-block;
  padding: 0.25rem 0.5rem;           /* 4px 8px */
  margin: 0 0.25rem 0.25rem 0;       /* right/bottom gap between tags */
  border: 1px solid rgba(0,0,0,0.2);
  border-radius: 0.375rem;           /* 6px */
  background: #ffffff;
  color: #111827;                    /* gray-900 */
  font-size: 0.75rem;                /* text-xs */
  line-height: 1rem;                 /* leading-4 */
}

.direct-upload__progress {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 0%;
  background: #16a34a;               /* green-600 */
  opacity: 0.2;
  transition: width 120ms ease-out;
  border-radius: 0.375rem;           /* match container rounding */
}

.direct-upload--pending .direct-upload__progress {
  display: none;                     /* hide bar until upload starts */
}

.direct-upload--uploading {
  border-color: rgba(22, 163, 74, 0.5);  /* green-600 @ 50% */
}

.direct-upload--error {
  border-color: #dc2626;             /* red-600 */
  color: #991b1b;                    /* red-800 */
}

.direct-upload--complete {
  border-color: #16a34a;             /* green-600 */
}

/* TomSelect Custom Styles - Matching Form Design */
.ts-wrapper {
  @apply w-full;
}

.ts-wrapper.single .ts-control {
  @apply w-full rounded-lg border border-slate-200 bg-slate-50/50 pl-3 pr-8 py-2 text-sm text-slate-700 transition-all;
  background-image: none;
  box-shadow: none;
  min-height: 38px; /* Consistent height whether empty or with item */
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  overflow: hidden;
}

/* Chevron Down Icon - Visual Affordance */
.ts-wrapper.single .ts-control::after {
  content: '';
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
  transition: transform 0.2s ease;
}

/* Rotate chevron when open */
.ts-wrapper.single.dropdown-active .ts-control::after {
  transform: translateY(-50%) rotate(180deg);
}

.ts-wrapper.single .ts-control:hover {
  @apply border-slate-300;
}

.ts-wrapper.single.focus .ts-control,
.ts-wrapper.single .ts-control:focus {
  @apply border-ow-500 bg-white ring-2 ring-ow-500/10;
  box-shadow: none;
}

.ts-wrapper .ts-control > input {
  @apply text-sm text-slate-700 placeholder-slate-400;
}

.ts-wrapper .ts-control > input::placeholder {
  @apply text-slate-400;
}

.ts-wrapper.single .ts-control > .item {
  @apply text-sm text-slate-700;
  max-width: calc(100% - 1.5rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Hide the input caret when not focused */
.ts-wrapper.single:not(.focus) .ts-control > input {
  opacity: 0;
  position: absolute;
  left: -10000px;
}

/* Always hide input when there's a selected item to prevent height expansion */
.ts-wrapper.single.has-items .ts-control > input {
  position: absolute !important;
  left: -10000px !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Dropdown Styles - Premium Look */
.ts-dropdown {
  @apply mt-2 rounded-xl border border-slate-200 bg-white overflow-hidden;
  box-shadow: 0 10px 40px -10px rgba(0, 0, 0, 0.15), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
}

.ts-dropdown .ts-dropdown-content {
  @apply max-h-64 overflow-y-auto py-1;
}

.ts-dropdown .option {
  @apply px-3 py-2.5 text-sm text-slate-700 cursor-pointer transition-all duration-150;
}

.ts-dropdown .option:hover,
.ts-dropdown .option.active {
  @apply bg-ow-50 text-ow-700;
}

.ts-dropdown .option.selected {
  @apply bg-ow-100 text-ow-800 font-medium;
}

/* No results message */
.ts-dropdown .no-results {
  @apply px-3 py-3 text-sm text-slate-400 text-center;
}

/* Scrollbar styling for dropdown */
.ts-dropdown .ts-dropdown-content::-webkit-scrollbar {
  width: 6px;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-track {
  @apply bg-transparent;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb {
  @apply bg-slate-200 rounded-full;
}

.ts-dropdown .ts-dropdown-content::-webkit-scrollbar-thumb:hover {
  @apply bg-slate-300;
}

/* DateRangePicker: emphasize "Aplicar" action like active quick filter */
.daterangepicker .drp-buttons button.applyBtn.btn {
  @apply inline-flex h-10 items-center justify-center rounded-md border border-blue-600 bg-blue-600 px-4 text-sm font-medium text-white transition-colors;
}

.daterangepicker .drp-buttons button.applyBtn.btn:hover {
  @apply border-blue-700 bg-blue-700 text-white;
}

.daterangepicker .drp-buttons button.applyBtn.btn:focus-visible {
  @apply outline-none ring-2 ring-blue-500 ring-offset-1;
}

.daterangepicker .drp-buttons button.applyBtn.btn:disabled {
  @apply cursor-not-allowed opacity-50;
}

@layer utilities {
  .no-scrollbar::-webkit-scrollbar {
    display: none;
  }
  .no-scrollbar {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
}
/* FullCalendar base styles extracted from vendor/javascript/fullcalendar-global.js. */
:root{--fc-small-font-size:.85em;--fc-page-bg-color:#fff;--fc-neutral-bg-color:hsla(0,0%,82%,.3);--fc-neutral-text-color:grey;--fc-border-color:#ddd;--fc-button-text-color:#fff;--fc-button-bg-color:#2c3e50;--fc-button-border-color:#2c3e50;--fc-button-hover-bg-color:#1e2b37;--fc-button-hover-border-color:#1a252f;--fc-button-active-bg-color:#1a252f;--fc-button-active-border-color:#151e27;--fc-event-bg-color:#3788d8;--fc-event-border-color:#3788d8;--fc-event-text-color:#fff;--fc-event-selected-overlay-color:rgba(0,0,0,.25);--fc-more-link-bg-color:#d0d0d0;--fc-more-link-text-color:inherit;--fc-event-resizer-thickness:8px;--fc-event-resizer-dot-total-width:8px;--fc-event-resizer-dot-border-width:1px;--fc-non-business-color:hsla(0,0%,84%,.3);--fc-bg-event-color:#8fdf82;--fc-bg-event-opacity:0.3;--fc-highlight-color:rgba(188,232,241,.3);--fc-today-bg-color:rgba(255,220,40,.15);--fc-now-indicator-color:red}.fc-not-allowed,.fc-not-allowed .fc-event{cursor:not-allowed}.fc{display:flex;flex-direction:column;font-size:1em}.fc,.fc *,.fc :after,.fc :before{box-sizing:border-box}.fc table{border-collapse:collapse;border-spacing:0;font-size:1em}.fc th{text-align:center}.fc td,.fc th{padding:0;vertical-align:top}.fc a[data-navlink]{cursor:pointer}.fc a[data-navlink]:hover{text-decoration:underline}.fc-direction-ltr{direction:ltr;text-align:left}.fc-direction-rtl{direction:rtl;text-align:right}.fc-theme-standard td,.fc-theme-standard th{border:1px solid var(--fc-border-color)}.fc-liquid-hack td,.fc-liquid-hack th{position:relative}@font-face{font-family:fcicons;font-style:normal;font-weight:400;src:url("data:application/x-font-ttf;charset=utf-8;base64,AAEAAAALAIAAAwAwT1MvMg8SBfAAAAC8AAAAYGNtYXAXVtKNAAABHAAAAFRnYXNwAAAAEAAAAXAAAAAIZ2x5ZgYydxIAAAF4AAAFNGhlYWQUJ7cIAAAGrAAAADZoaGVhB20DzAAABuQAAAAkaG10eCIABhQAAAcIAAAALGxvY2ED4AU6AAAHNAAAABhtYXhwAA8AjAAAB0wAAAAgbmFtZXsr690AAAdsAAABhnBvc3QAAwAAAAAI9AAAACAAAwPAAZAABQAAApkCzAAAAI8CmQLMAAAB6wAzAQkAAAAAAAAAAAAAAAAAAAABEAAAAAAAAAAAAAAAAAAAAABAAADpBgPA/8AAQAPAAEAAAAABAAAAAAAAAAAAAAAgAAAAAAADAAAAAwAAABwAAQADAAAAHAADAAEAAAAcAAQAOAAAAAoACAACAAIAAQAg6Qb//f//AAAAAAAg6QD//f//AAH/4xcEAAMAAQAAAAAAAAAAAAAAAQAB//8ADwABAAAAAAAAAAAAAgAANzkBAAAAAAEAAAAAAAAAAAACAAA3OQEAAAAAAQAAAAAAAAAAAAIAADc5AQAAAAABAWIAjQKeAskAEwAAJSc3NjQnJiIHAQYUFwEWMjc2NCcCnuLiDQ0MJAz/AA0NAQAMJAwNDcni4gwjDQwM/wANIwz/AA0NDCMNAAAAAQFiAI0CngLJABMAACUBNjQnASYiBwYUHwEHBhQXFjI3AZ4BAA0N/wAMJAwNDeLiDQ0MJAyNAQAMIw0BAAwMDSMM4uINIwwNDQAAAAIA4gC3Ax4CngATACcAACUnNzY0JyYiDwEGFB8BFjI3NjQnISc3NjQnJiIPAQYUHwEWMjc2NCcB87e3DQ0MIw3VDQ3VDSMMDQ0BK7e3DQ0MJAzVDQ3VDCQMDQ3zuLcMJAwNDdUNIwzWDAwNIwy4twwkDA0N1Q0jDNYMDA0jDAAAAgDiALcDHgKeABMAJwAAJTc2NC8BJiIHBhQfAQcGFBcWMjchNzY0LwEmIgcGFB8BBwYUFxYyNwJJ1Q0N1Q0jDA0Nt7cNDQwjDf7V1Q0N1QwkDA0Nt7cNDQwkDLfWDCMN1Q0NDCQMt7gMIw0MDNYMIw3VDQ0MJAy3uAwjDQwMAAADAFUAAAOrA1UAMwBoAHcAABMiBgcOAQcOAQcOARURFBYXHgEXHgEXHgEzITI2Nz4BNz4BNz4BNRE0JicuAScuAScuASMFITIWFx4BFx4BFx4BFREUBgcOAQcOAQcOASMhIiYnLgEnLgEnLgE1ETQ2Nz4BNz4BNz4BMxMhMjY1NCYjISIGFRQWM9UNGAwLFQkJDgUFBQUFBQ4JCRULDBgNAlYNGAwLFQkJDgUFBQUFBQ4JCRULDBgN/aoCVgQIBAQHAwMFAQIBAQIBBQMDBwQECAT9qgQIBAQHAwMFAQIBAQIBBQMDBwQECASAAVYRGRkR/qoRGRkRA1UFBAUOCQkVDAsZDf2rDRkLDBUJCA4FBQUFBQUOCQgVDAsZDQJVDRkLDBUJCQ4FBAVVAgECBQMCBwQECAX9qwQJAwQHAwMFAQICAgIBBQMDBwQDCQQCVQUIBAQHAgMFAgEC/oAZEhEZGRESGQAAAAADAFUAAAOrA1UAMwBoAIkAABMiBgcOAQcOAQcOARURFBYXHgEXHgEXHgEzITI2Nz4BNz4BNz4BNRE0JicuAScuAScuASMFITIWFx4BFx4BFx4BFREUBgcOAQcOAQcOASMhIiYnLgEnLgEnLgE1ETQ2Nz4BNz4BNz4BMxMzFRQWMzI2PQEzMjY1NCYrATU0JiMiBh0BIyIGFRQWM9UNGAwLFQkJDgUFBQUFBQ4JCRULDBgNAlYNGAwLFQkJDgUFBQUFBQ4JCRULDBgN/aoCVgQIBAQHAwMFAQIBAQIBBQMDBwQECAT9qgQIBAQHAwMFAQIBAQIBBQMDBwQECASAgBkSEhmAERkZEYAZEhIZgBEZGREDVQUEBQ4JCRUMCxkN/asNGQsMFQkIDgUFBQUFBQ4JCBUMCxkNAlUNGQsMFQkJDgUEBVUCAQIFAwIHBAQIBf2rBAkDBAcDAwUBAgICAgEFAwMHBAMJBAJVBQgEBAcCAwUCAQL+gIASGRkSgBkSERmAEhkZEoAZERIZAAABAOIAjQMeAskAIAAAExcHBhQXFjI/ARcWMjc2NC8BNzY0JyYiDwEnJiIHBhQX4uLiDQ0MJAzi4gwkDA0N4uINDQwkDOLiDCQMDQ0CjeLiDSMMDQ3h4Q0NDCMN4uIMIw0MDOLiDAwNIwwAAAABAAAAAQAAa5n0y18PPPUACwQAAAAAANivOVsAAAAA2K85WwAAAAADqwNVAAAACAACAAAAAAAAAAEAAAPA/8AAAAQAAAAAAAOrAAEAAAAAAAAAAAAAAAAAAAALBAAAAAAAAAAAAAAAAgAAAAQAAWIEAAFiBAAA4gQAAOIEAABVBAAAVQQAAOIAAAAAAAoAFAAeAEQAagCqAOoBngJkApoAAQAAAAsAigADAAAAAAACAAAAAAAAAAAAAAAAAAAAAAAAAA4ArgABAAAAAAABAAcAAAABAAAAAAACAAcAYAABAAAAAAADAAcANgABAAAAAAAEAAcAdQABAAAAAAAFAAsAFQABAAAAAAAGAAcASwABAAAAAAAKABoAigADAAEECQABAA4ABwADAAEECQACAA4AZwADAAEECQADAA4APQADAAEECQAEAA4AfAADAAEECQAFABYAIAADAAEECQAGAA4AUgADAAEECQAKADQApGZjaWNvbnMAZgBjAGkAYwBvAG4Ac1ZlcnNpb24gMS4wAFYAZQByAHMAaQBvAG4AIAAxAC4AMGZjaWNvbnMAZgBjAGkAYwBvAG4Ac2ZjaWNvbnMAZgBjAGkAYwBvAG4Ac1JlZ3VsYXIAUgBlAGcAdQBsAGEAcmZjaWNvbnMAZgBjAGkAYwBvAG4Ac0ZvbnQgZ2VuZXJhdGVkIGJ5IEljb01vb24uAEYAbwBuAHQAIABnAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAEkAYwBvAE0AbwBvAG4ALgAAAAMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=") format("truetype")}.fc-icon{speak:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:inline-block;font-family:fcicons!important;font-style:normal;font-variant:normal;font-weight:400;height:1em;line-height:1;text-align:center;text-transform:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:1em}.fc-icon-chevron-left:before{content:"\e900"}.fc-icon-chevron-right:before{content:"\e901"}.fc-icon-chevrons-left:before{content:"\e902"}.fc-icon-chevrons-right:before{content:"\e903"}.fc-icon-minus-square:before{content:"\e904"}.fc-icon-plus-square:before{content:"\e905"}.fc-icon-x:before{content:"\e906"}.fc .fc-button{border-radius:0;font-family:inherit;font-size:inherit;line-height:inherit;margin:0;overflow:visible;text-transform:none}.fc .fc-button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}.fc .fc-button{-webkit-appearance:button}.fc .fc-button:not(:disabled){cursor:pointer}.fc .fc-button{background-color:transparent;border:1px solid transparent;border-radius:.25em;display:inline-block;font-size:1em;font-weight:400;line-height:1.5;padding:.4em .65em;text-align:center;-webkit-user-select:none;-moz-user-select:none;user-select:none;vertical-align:middle}.fc .fc-button:hover{text-decoration:none}.fc .fc-button:focus{box-shadow:0 0 0 .2rem rgba(44,62,80,.25);outline:0}.fc .fc-button:disabled{opacity:.65}.fc .fc-button-primary{background-color:var(--fc-button-bg-color);border-color:var(--fc-button-border-color);color:var(--fc-button-text-color)}.fc .fc-button-primary:hover{background-color:var(--fc-button-hover-bg-color);border-color:var(--fc-button-hover-border-color);color:var(--fc-button-text-color)}.fc .fc-button-primary:disabled{background-color:var(--fc-button-bg-color);border-color:var(--fc-button-border-color);color:var(--fc-button-text-color)}.fc .fc-button-primary:focus{box-shadow:0 0 0 .2rem rgba(76,91,106,.5)}.fc .fc-button-primary:not(:disabled).fc-button-active,.fc .fc-button-primary:not(:disabled):active{background-color:var(--fc-button-active-bg-color);border-color:var(--fc-button-active-border-color);color:var(--fc-button-text-color)}.fc .fc-button-primary:not(:disabled).fc-button-active:focus,.fc .fc-button-primary:not(:disabled):active:focus{box-shadow:0 0 0 .2rem rgba(76,91,106,.5)}.fc .fc-button .fc-icon{font-size:1.5em;vertical-align:middle}.fc .fc-button-group{display:inline-flex;position:relative;vertical-align:middle}.fc .fc-button-group>.fc-button{flex:1 1 auto;position:relative}.fc .fc-button-group>.fc-button.fc-button-active,.fc .fc-button-group>.fc-button:active,.fc .fc-button-group>.fc-button:focus,.fc .fc-button-group>.fc-button:hover{z-index:1}.fc-direction-ltr .fc-button-group>.fc-button:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0;margin-left:-1px}.fc-direction-ltr .fc-button-group>.fc-button:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.fc-direction-rtl .fc-button-group>.fc-button:not(:first-child){border-bottom-right-radius:0;border-top-right-radius:0;margin-right:-1px}.fc-direction-rtl .fc-button-group>.fc-button:not(:last-child){border-bottom-left-radius:0;border-top-left-radius:0}.fc .fc-toolbar{align-items:center;display:flex;justify-content:space-between}.fc .fc-toolbar.fc-header-toolbar{margin-bottom:1.5em}.fc .fc-toolbar.fc-footer-toolbar{margin-top:1.5em}.fc .fc-toolbar-title{font-size:1.75em;margin:0}.fc-direction-ltr .fc-toolbar>*>:not(:first-child){margin-left:.75em}.fc-direction-rtl .fc-toolbar>*>:not(:first-child){margin-right:.75em}.fc-direction-rtl .fc-toolbar-ltr{flex-direction:row-reverse}.fc .fc-scroller{-webkit-overflow-scrolling:touch;position:relative}.fc .fc-scroller-liquid{height:100%}.fc .fc-scroller-liquid-absolute{bottom:0;left:0;position:absolute;right:0;top:0}.fc .fc-scroller-harness{direction:ltr;overflow:hidden;position:relative}.fc .fc-scroller-harness-liquid{height:100%}.fc-direction-rtl .fc-scroller-harness>.fc-scroller{direction:rtl}.fc-theme-standard .fc-scrollgrid{border:1px solid var(--fc-border-color)}.fc .fc-scrollgrid,.fc .fc-scrollgrid table{table-layout:fixed;width:100%}.fc .fc-scrollgrid table{border-left-style:hidden;border-right-style:hidden;border-top-style:hidden}.fc .fc-scrollgrid{border-bottom-width:0;border-collapse:separate;border-right-width:0}.fc .fc-scrollgrid-liquid{height:100%}.fc .fc-scrollgrid-section,.fc .fc-scrollgrid-section table,.fc .fc-scrollgrid-section>td{height:1px}.fc .fc-scrollgrid-section-liquid>td{height:100%}.fc .fc-scrollgrid-section>*{border-left-width:0;border-top-width:0}.fc .fc-scrollgrid-section-footer>*,.fc .fc-scrollgrid-section-header>*{border-bottom-width:0}.fc .fc-scrollgrid-section-body table,.fc .fc-scrollgrid-section-footer table{border-bottom-style:hidden}.fc .fc-scrollgrid-section-sticky>*{background:var(--fc-page-bg-color);position:sticky;z-index:3}.fc .fc-scrollgrid-section-header.fc-scrollgrid-section-sticky>*{top:0}.fc .fc-scrollgrid-section-footer.fc-scrollgrid-section-sticky>*{bottom:0}.fc .fc-scrollgrid-sticky-shim{height:1px;margin-bottom:-1px}.fc-sticky{position:sticky}.fc .fc-view-harness{flex-grow:1;position:relative}.fc .fc-view-harness-active>.fc-view{bottom:0;left:0;position:absolute;right:0;top:0}.fc .fc-col-header-cell-cushion{display:inline-block;padding:2px 4px}.fc .fc-bg-event,.fc .fc-highlight,.fc .fc-non-business{bottom:0;left:0;position:absolute;right:0;top:0}.fc .fc-non-business{background:var(--fc-non-business-color)}.fc .fc-bg-event{background:var(--fc-bg-event-color);opacity:var(--fc-bg-event-opacity)}.fc .fc-bg-event .fc-event-title{font-size:var(--fc-small-font-size);font-style:italic;margin:.5em}.fc .fc-highlight{background:var(--fc-highlight-color)}.fc .fc-cell-shaded,.fc .fc-day-disabled{background:var(--fc-neutral-bg-color)}a.fc-event,a.fc-event:hover{text-decoration:none}.fc-event.fc-event-draggable,.fc-event[href]{cursor:pointer}.fc-event .fc-event-main{position:relative;z-index:2}.fc-event-dragging:not(.fc-event-selected){opacity:.75}.fc-event-dragging.fc-event-selected{box-shadow:0 2px 7px rgba(0,0,0,.3)}.fc-event .fc-event-resizer{display:none;position:absolute;z-index:4}.fc-event-selected .fc-event-resizer,.fc-event:hover .fc-event-resizer{display:block}.fc-event-selected .fc-event-resizer{background:var(--fc-page-bg-color);border-color:inherit;border-radius:calc(var(--fc-event-resizer-dot-total-width)/2);border-style:solid;border-width:var(--fc-event-resizer-dot-border-width);height:var(--fc-event-resizer-dot-total-width);width:var(--fc-event-resizer-dot-total-width)}.fc-event-selected .fc-event-resizer:before{bottom:-20px;content:"";left:-20px;position:absolute;right:-20px;top:-20px}.fc-event-selected,.fc-event:focus{box-shadow:0 2px 5px rgba(0,0,0,.2)}.fc-event-selected:before,.fc-event:focus:before{bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:3}.fc-event-selected:after,.fc-event:focus:after{background:var(--fc-event-selected-overlay-color);bottom:-1px;content:"";left:-1px;position:absolute;right:-1px;top:-1px;z-index:1}.fc-h-event{background-color:var(--fc-event-bg-color);border:1px solid var(--fc-event-border-color);display:block}.fc-h-event .fc-event-main{color:var(--fc-event-text-color)}.fc-h-event .fc-event-main-frame{display:flex}.fc-h-event .fc-event-time{max-width:100%;overflow:hidden}.fc-h-event .fc-event-title-container{flex-grow:1;flex-shrink:1;min-width:0}.fc-h-event .fc-event-title{display:inline-block;left:0;max-width:100%;overflow:hidden;right:0;vertical-align:top}.fc-h-event.fc-event-selected:before{bottom:-10px;top:-10px}.fc-direction-ltr .fc-daygrid-block-event:not(.fc-event-start),.fc-direction-rtl .fc-daygrid-block-event:not(.fc-event-end){border-bottom-left-radius:0;border-left-width:0;border-top-left-radius:0}.fc-direction-ltr .fc-daygrid-block-event:not(.fc-event-end),.fc-direction-rtl .fc-daygrid-block-event:not(.fc-event-start){border-bottom-right-radius:0;border-right-width:0;border-top-right-radius:0}.fc-h-event:not(.fc-event-selected) .fc-event-resizer{bottom:0;top:0;width:var(--fc-event-resizer-thickness)}.fc-direction-ltr .fc-h-event:not(.fc-event-selected) .fc-event-resizer-start,.fc-direction-rtl .fc-h-event:not(.fc-event-selected) .fc-event-resizer-end{cursor:w-resize;left:calc(var(--fc-event-resizer-thickness)*-.5)}.fc-direction-ltr .fc-h-event:not(.fc-event-selected) .fc-event-resizer-end,.fc-direction-rtl .fc-h-event:not(.fc-event-selected) .fc-event-resizer-start{cursor:e-resize;right:calc(var(--fc-event-resizer-thickness)*-.5)}.fc-h-event.fc-event-selected .fc-event-resizer{margin-top:calc(var(--fc-event-resizer-dot-total-width)*-.5);top:50%}.fc-direction-ltr .fc-h-event.fc-event-selected .fc-event-resizer-start,.fc-direction-rtl .fc-h-event.fc-event-selected .fc-event-resizer-end{left:calc(var(--fc-event-resizer-dot-total-width)*-.5)}.fc-direction-ltr .fc-h-event.fc-event-selected .fc-event-resizer-end,.fc-direction-rtl .fc-h-event.fc-event-selected .fc-event-resizer-start{right:calc(var(--fc-event-resizer-dot-total-width)*-.5)}.fc .fc-popover{box-shadow:0 2px 6px rgba(0,0,0,.15);position:absolute;z-index:9999}.fc .fc-popover-header{align-items:center;display:flex;flex-direction:row;justify-content:space-between;padding:3px 4px}.fc .fc-popover-title{margin:0 2px}.fc .fc-popover-close{cursor:pointer;font-size:1.1em;opacity:.65}.fc-theme-standard .fc-popover{background:var(--fc-page-bg-color);border:1px solid var(--fc-border-color)}.fc-theme-standard .fc-popover-header{background:var(--fc-neutral-bg-color)}

:root{--fc-daygrid-event-dot-width:8px}.fc-daygrid-day-events:after,.fc-daygrid-day-events:before,.fc-daygrid-day-frame:after,.fc-daygrid-day-frame:before,.fc-daygrid-event-harness:after,.fc-daygrid-event-harness:before{clear:both;content:"";display:table}.fc .fc-daygrid-body{position:relative;z-index:1}.fc .fc-daygrid-day.fc-day-today{background-color:var(--fc-today-bg-color)}.fc .fc-daygrid-day-frame{min-height:100%;position:relative}.fc .fc-daygrid-day-top{display:flex;flex-direction:row-reverse}.fc .fc-day-other .fc-daygrid-day-top{opacity:.3}.fc .fc-daygrid-day-number{padding:4px;position:relative;z-index:4}.fc .fc-daygrid-month-start{font-size:1.1em;font-weight:700}.fc .fc-daygrid-day-events{margin-top:1px}.fc .fc-daygrid-body-balanced .fc-daygrid-day-events{left:0;position:absolute;right:0}.fc .fc-daygrid-body-unbalanced .fc-daygrid-day-events{min-height:2em;position:relative}.fc .fc-daygrid-body-natural .fc-daygrid-day-events{margin-bottom:1em}.fc .fc-daygrid-event-harness{position:relative}.fc .fc-daygrid-event-harness-abs{left:0;position:absolute;right:0;top:0}.fc .fc-daygrid-bg-harness{bottom:0;position:absolute;top:0}.fc .fc-daygrid-day-bg .fc-non-business{z-index:1}.fc .fc-daygrid-day-bg .fc-bg-event{z-index:2}.fc .fc-daygrid-day-bg .fc-highlight{z-index:3}.fc .fc-daygrid-event{margin-top:1px;z-index:6}.fc .fc-daygrid-event.fc-event-mirror{z-index:7}.fc .fc-daygrid-day-bottom{font-size:.85em;margin:0 2px}.fc .fc-daygrid-day-bottom:after,.fc .fc-daygrid-day-bottom:before{clear:both;content:"";display:table}.fc .fc-daygrid-more-link{border-radius:3px;cursor:pointer;line-height:1;margin-top:1px;max-width:100%;overflow:hidden;padding:2px;position:relative;white-space:nowrap;z-index:4}.fc .fc-daygrid-more-link:hover{background-color:rgba(0,0,0,.1)}.fc .fc-daygrid-week-number{background-color:var(--fc-neutral-bg-color);color:var(--fc-neutral-text-color);min-width:1.5em;padding:2px;position:absolute;text-align:center;top:0;z-index:5}.fc .fc-more-popover .fc-popover-body{min-width:220px;padding:10px}.fc-direction-ltr .fc-daygrid-event.fc-event-start,.fc-direction-rtl .fc-daygrid-event.fc-event-end{margin-left:2px}.fc-direction-ltr .fc-daygrid-event.fc-event-end,.fc-direction-rtl .fc-daygrid-event.fc-event-start{margin-right:2px}.fc-direction-ltr .fc-daygrid-more-link{float:left}.fc-direction-ltr .fc-daygrid-week-number{border-radius:0 0 3px 0;left:0}.fc-direction-rtl .fc-daygrid-more-link{float:right}.fc-direction-rtl .fc-daygrid-week-number{border-radius:0 0 0 3px;right:0}.fc-liquid-hack .fc-daygrid-day-frame{position:static}.fc-daygrid-event{border-radius:3px;font-size:var(--fc-small-font-size);position:relative;white-space:nowrap}.fc-daygrid-block-event .fc-event-time{font-weight:700}.fc-daygrid-block-event .fc-event-time,.fc-daygrid-block-event .fc-event-title{padding:1px}.fc-daygrid-dot-event{align-items:center;display:flex;padding:2px 0}.fc-daygrid-dot-event .fc-event-title{flex-grow:1;flex-shrink:1;font-weight:700;min-width:0;overflow:hidden}.fc-daygrid-dot-event.fc-event-mirror,.fc-daygrid-dot-event:hover{background:rgba(0,0,0,.1)}.fc-daygrid-dot-event.fc-event-selected:before{bottom:-10px;top:-10px}.fc-daygrid-event-dot{border:calc(var(--fc-daygrid-event-dot-width)/2) solid var(--fc-event-border-color);border-radius:calc(var(--fc-daygrid-event-dot-width)/2);box-sizing:content-box;height:0;margin:0 4px;width:0}.fc-direction-ltr .fc-daygrid-event .fc-event-time{margin-right:3px}.fc-direction-rtl .fc-daygrid-event .fc-event-time{margin-left:3px}

.fc-v-event{background-color:var(--fc-event-bg-color);border:1px solid var(--fc-event-border-color);display:block}.fc-v-event .fc-event-main{color:var(--fc-event-text-color);height:100%}.fc-v-event .fc-event-main-frame{display:flex;flex-direction:column;height:100%}.fc-v-event .fc-event-time{flex-grow:0;flex-shrink:0;max-height:100%;overflow:hidden}.fc-v-event .fc-event-title-container{flex-grow:1;flex-shrink:1;min-height:0}.fc-v-event .fc-event-title{bottom:0;max-height:100%;overflow:hidden;top:0}.fc-v-event:not(.fc-event-start){border-top-left-radius:0;border-top-right-radius:0;border-top-width:0}.fc-v-event:not(.fc-event-end){border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-width:0}.fc-v-event.fc-event-selected:before{left:-10px;right:-10px}.fc-v-event .fc-event-resizer-start{cursor:n-resize}.fc-v-event .fc-event-resizer-end{cursor:s-resize}.fc-v-event:not(.fc-event-selected) .fc-event-resizer{height:var(--fc-event-resizer-thickness);left:0;right:0}.fc-v-event:not(.fc-event-selected) .fc-event-resizer-start{top:calc(var(--fc-event-resizer-thickness)/-2)}.fc-v-event:not(.fc-event-selected) .fc-event-resizer-end{bottom:calc(var(--fc-event-resizer-thickness)/-2)}.fc-v-event.fc-event-selected .fc-event-resizer{left:50%;margin-left:calc(var(--fc-event-resizer-dot-total-width)/-2)}.fc-v-event.fc-event-selected .fc-event-resizer-start{top:calc(var(--fc-event-resizer-dot-total-width)/-2)}.fc-v-event.fc-event-selected .fc-event-resizer-end{bottom:calc(var(--fc-event-resizer-dot-total-width)/-2)}.fc .fc-timegrid .fc-daygrid-body{z-index:2}.fc .fc-timegrid-divider{padding:0 0 2px}.fc .fc-timegrid-body{min-height:100%;position:relative;z-index:1}.fc .fc-timegrid-axis-chunk{position:relative}.fc .fc-timegrid-axis-chunk>table,.fc .fc-timegrid-slots{position:relative;z-index:1}.fc .fc-timegrid-slot{border-bottom:0;height:1.5em}.fc .fc-timegrid-slot:empty:before{content:"\00a0"}.fc .fc-timegrid-slot-minor{border-top-style:dotted}.fc .fc-timegrid-slot-label-cushion{display:inline-block;white-space:nowrap}.fc .fc-timegrid-slot-label{vertical-align:middle}.fc .fc-timegrid-axis-cushion,.fc .fc-timegrid-slot-label-cushion{padding:0 4px}.fc .fc-timegrid-axis-frame-liquid{height:100%}.fc .fc-timegrid-axis-frame{align-items:center;display:flex;justify-content:flex-end;overflow:hidden}.fc .fc-timegrid-axis-cushion{flex-shrink:0;max-width:60px}.fc-direction-ltr .fc-timegrid-slot-label-frame{text-align:right}.fc-direction-rtl .fc-timegrid-slot-label-frame{text-align:left}.fc-liquid-hack .fc-timegrid-axis-frame-liquid{bottom:0;height:auto;left:0;position:absolute;right:0;top:0}.fc .fc-timegrid-col.fc-day-today{background-color:var(--fc-today-bg-color)}.fc .fc-timegrid-col-frame{min-height:100%;position:relative}.fc-media-screen.fc-liquid-hack .fc-timegrid-col-frame{bottom:0;height:auto;left:0;position:absolute;right:0;top:0}.fc-media-screen .fc-timegrid-cols{bottom:0;left:0;position:absolute;right:0;top:0}.fc-media-screen .fc-timegrid-cols>table{height:100%}.fc-media-screen .fc-timegrid-col-bg,.fc-media-screen .fc-timegrid-col-events,.fc-media-screen .fc-timegrid-now-indicator-container{left:0;position:absolute;right:0;top:0}.fc .fc-timegrid-col-bg{z-index:2}.fc .fc-timegrid-col-bg .fc-non-business{z-index:1}.fc .fc-timegrid-col-bg .fc-bg-event{z-index:2}.fc .fc-timegrid-col-bg .fc-highlight{z-index:3}.fc .fc-timegrid-bg-harness{left:0;position:absolute;right:0}.fc .fc-timegrid-col-events{z-index:3}.fc .fc-timegrid-now-indicator-container{bottom:0;overflow:hidden}.fc-direction-ltr .fc-timegrid-col-events{margin:0 2.5% 0 2px}.fc-direction-rtl .fc-timegrid-col-events{margin:0 2px 0 2.5%}.fc-timegrid-event-harness{position:absolute}.fc-timegrid-event-harness>.fc-timegrid-event{bottom:0;left:0;position:absolute;right:0;top:0}.fc-timegrid-event-harness-inset .fc-timegrid-event,.fc-timegrid-event.fc-event-mirror,.fc-timegrid-more-link{box-shadow:0 0 0 1px var(--fc-page-bg-color)}.fc-timegrid-event,.fc-timegrid-more-link{border-radius:3px;font-size:var(--fc-small-font-size)}.fc-timegrid-event{margin-bottom:1px}.fc-timegrid-event .fc-event-main{padding:1px 1px 0}.fc-timegrid-event .fc-event-time{font-size:var(--fc-small-font-size);margin-bottom:1px;white-space:nowrap}.fc-timegrid-event-short .fc-event-main-frame{flex-direction:row;overflow:hidden}.fc-timegrid-event-short .fc-event-time:after{content:"\00a0-\00a0"}.fc-timegrid-event-short .fc-event-title{font-size:var(--fc-small-font-size)}.fc-timegrid-more-link{background:var(--fc-more-link-bg-color);color:var(--fc-more-link-text-color);cursor:pointer;margin-bottom:1px;position:absolute;z-index:9999}.fc-timegrid-more-link-inner{padding:3px 2px;top:0}.fc-direction-ltr .fc-timegrid-more-link{right:0}.fc-direction-rtl .fc-timegrid-more-link{left:0}.fc .fc-timegrid-now-indicator-line{border-color:var(--fc-now-indicator-color);border-style:solid;border-width:1px 0 0;left:0;position:absolute;right:0;z-index:4}.fc .fc-timegrid-now-indicator-arrow{border-color:var(--fc-now-indicator-color);border-style:solid;margin-top:-5px;position:absolute;z-index:4}.fc-direction-ltr .fc-timegrid-now-indicator-arrow{border-bottom-color:transparent;border-top-color:transparent;border-width:5px 0 5px 6px;left:0}.fc-direction-rtl .fc-timegrid-now-indicator-arrow{border-bottom-color:transparent;border-top-color:transparent;border-width:5px 6px 5px 0;right:0}
.madmin-partner-source-page {
  --partner-form-bg: #f8fafc;
  --partner-form-panel: #ffffff;
  --partner-form-soft: #f1f5f9;
  --partner-form-line: #e2e8f0;
  --partner-form-line-strong: #cbd5e1;
  --partner-form-ink: #0f172a;
  --partner-form-muted: #64748b;
  --partner-form-accent: #047857;
  --partner-form-accent-soft: #ecfdf5;
  --partner-form-amber: #b45309;

  min-height: 100vh;
  box-sizing: border-box;
  background: var(--partner-form-bg);
  color: var(--partner-form-ink);
  padding: 1.5rem;
}

.madmin-partner-source-page *,
.madmin-partner-source-page *::before,
.madmin-partner-source-page *::after {
  box-sizing: border-box;
}

.madmin-partner-source-page a {
  color: inherit;
}

.madmin-partner-source-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1rem;
  max-width: 1440px;
  margin: 0 auto 1.25rem;
  border-bottom: 1px solid var(--partner-form-line);
  padding-bottom: 1rem;
}

.madmin-partner-source-header p,
.madmin-partner-source-section__heading p,
.madmin-partner-source-preview__card p {
  margin: 0;
  color: var(--partner-form-amber);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

.madmin-partner-source-header h1 {
  margin: 0.35rem 0 0;
  color: #020617;
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.05;
}

.madmin-partner-source-header span {
  display: block;
  max-width: 48rem;
  margin-top: 0.65rem;
  color: var(--partner-form-muted);
  font-size: 1rem;
  line-height: 1.6;
}

.madmin-partner-source-secondary-link,
.madmin-partner-source-cancel {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--partner-form-line);
  border-radius: 999px;
  background: var(--partner-form-panel);
  color: #334155;
  font-size: 0.875rem;
  font-weight: 700;
  padding: 0.625rem 0.9rem;
  text-decoration: none;
}

.madmin-partner-source-secondary-link:hover,
.madmin-partner-source-cancel:hover {
  border-color: var(--partner-form-accent);
  color: var(--partner-form-accent);
}

.madmin-partner-source-form {
  max-width: 1440px;
  margin: 0 auto;
}

.madmin-partner-source-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 1rem;
  align-items: start;
}

.madmin-partner-source-main {
  display: grid;
  gap: 1rem;
}

.madmin-partner-source-section,
.madmin-partner-source-preview,
.madmin-partner-source-errors {
  border: 1px solid var(--partner-form-line);
  border-radius: 1rem;
  background: var(--partner-form-panel);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04);
}

.madmin-partner-source-section {
  padding: 1.25rem;
}

.madmin-partner-source-section__heading {
  margin-bottom: 1rem;
}

.madmin-partner-source-section__heading h2,
.madmin-partner-source-preview__card h2 {
  margin: 0.25rem 0 0;
  color: #020617;
  font-size: 1.125rem;
  font-weight: 800;
  letter-spacing: 0;
}

.madmin-partner-source-section__heading span {
  display: block;
  margin-top: 0.35rem;
  color: var(--partner-form-muted);
  font-size: 0.875rem;
  line-height: 1.55;
}

.madmin-partner-source-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.madmin-partner-source-field {
  display: grid;
  gap: 0.4rem;
  align-content: start;
}

.madmin-partner-source-field--wide {
  grid-column: 1 / -1;
}

.madmin-partner-source-field--small {
  max-width: 18rem;
  margin-top: 1rem;
}

.madmin-partner-source-field label,
.madmin-partner-source-repeatable label span {
  color: #1e293b;
  font-size: 0.875rem;
  font-weight: 800;
}

.madmin-partner-source-field small,
.madmin-partner-source-toggle small {
  color: var(--partner-form-muted);
  font-size: 0.75rem;
  line-height: 1.45;
}

.madmin-partner-source-input {
  width: 100%;
  min-height: 2.75rem;
  border: 1px solid var(--partner-form-line-strong);
  border-radius: 0.75rem;
  background: #ffffff;
  color: var(--partner-form-ink);
  font: inherit;
  padding: 0.7rem 0.85rem;
}

textarea.madmin-partner-source-input {
  min-height: 6rem;
  resize: vertical;
}

.madmin-partner-source-input::placeholder {
  color: #94a3b8;
}

.madmin-partner-source-input:focus {
  border-color: var(--partner-form-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--partner-form-accent), transparent 82%);
  outline: none;
}

.madmin-partner-source-toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.madmin-partner-source-toggle {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  border: 1px solid var(--partner-form-line);
  border-radius: 0.875rem;
  background: var(--partner-form-soft);
  padding: 0.85rem;
}

.madmin-partner-source-toggle input {
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.15rem;
  accent-color: var(--partner-form-accent);
}

.madmin-partner-source-toggle strong {
  display: block;
  color: #0f172a;
  font-size: 0.875rem;
}

.madmin-partner-source-toggle small {
  display: block;
  margin-top: 0.2rem;
}

.madmin-partner-source-repeatable {
  display: grid;
  gap: 0.75rem;
  border-top: 1px solid var(--partner-form-line);
  padding-top: 1rem;
}

.madmin-partner-source-repeatable + .madmin-partner-source-repeatable {
  margin-top: 1rem;
}

.madmin-partner-source-repeatable__heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.madmin-partner-source-repeatable__heading h3 {
  margin: 0;
  color: #0f172a;
  font-size: 0.95rem;
  font-weight: 800;
}

.madmin-partner-source-repeatable__hint {
  margin: -0.25rem 0 0;
  color: var(--partner-form-muted);
  font-size: 0.8125rem;
  line-height: 1.45;
}

.madmin-partner-source-repeatable__heading button,
.madmin-partner-source-remove-row {
  border: 1px solid var(--partner-form-line);
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
  cursor: pointer;
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 800;
  padding: 0.5rem 0.75rem;
}

.madmin-partner-source-repeatable__heading button {
  border-color: color-mix(in srgb, var(--partner-form-accent), white 50%);
  background: var(--partner-form-accent-soft);
  color: var(--partner-form-accent);
}

.madmin-partner-source-repeatable__rows {
  display: grid;
  gap: 0.75rem;
}

.madmin-partner-source-repeatable__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  gap: 0.75rem;
  align-items: end;
  border: 1px solid var(--partner-form-line);
  border-radius: 0.875rem;
  background: #f8fafc;
  padding: 0.85rem;
}

.madmin-partner-source-repeatable__row--single {
  grid-template-columns: minmax(0, 1fr) auto;
}

.madmin-partner-source-repeatable__row label {
  display: grid;
  gap: 0.35rem;
}

.madmin-partner-source-repeatable__wide {
  grid-column: 1 / -2;
}

.madmin-partner-source-remove-row:hover {
  border-color: #fda4af;
  color: #be123c;
}

.madmin-partner-source-section--details {
  padding: 0;
}

.madmin-partner-source-section--details summary {
  cursor: pointer;
  color: #0f172a;
  font-size: 1rem;
  font-weight: 800;
  padding: 1.25rem;
}

.madmin-partner-source-section--details[open] {
  padding: 0 1.25rem 1.25rem;
}

.madmin-partner-source-section--details[open] summary {
  margin-inline: -1.25rem;
}

.madmin-partner-source-preview {
  position: sticky;
  top: 1rem;
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

.madmin-partner-source-preview__card {
  border: 1px solid var(--partner-form-line);
  border-radius: 0.875rem;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  padding: 1rem;
}

.madmin-partner-source-preview__card > span {
  display: inline-flex;
  margin-top: 0.5rem;
  border-radius: 999px;
  background: var(--partner-form-accent-soft);
  color: var(--partner-form-accent);
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.25rem 0.55rem;
}

.madmin-partner-source-preview__card strong {
  display: block;
  margin-top: 1rem;
  color: #0f172a;
  font-size: 0.95rem;
  line-height: 1.35;
}

.madmin-partner-source-preview__card small {
  display: block;
  margin-top: 0.4rem;
  color: var(--partner-form-muted);
  font-size: 0.8125rem;
  line-height: 1.5;
}

.madmin-partner-source-preview__status {
  display: grid;
  gap: 0.75rem;
  margin: 0;
}

.madmin-partner-source-preview__status div {
  display: grid;
  gap: 0.2rem;
}

.madmin-partner-source-preview__status dt {
  color: var(--partner-form-muted);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}

.madmin-partner-source-preview__status dd {
  margin: 0;
  color: #0f172a;
  font-size: 0.875rem;
  font-weight: 700;
  overflow-wrap: anywhere;
}

.madmin-partner-source-actions {
  display: grid;
  gap: 0.6rem;
}

.madmin-partner-source-submit {
  border: 1px solid var(--partner-form-accent);
  border-radius: 999px;
  background: var(--partner-form-accent);
  color: #ffffff;
  cursor: pointer;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 800;
  padding: 0.75rem 1rem;
}

.madmin-partner-source-submit:hover {
  background: #065f46;
}

.madmin-partner-source-cancel {
  width: 100%;
}

.madmin-partner-source-errors {
  margin-bottom: 1rem;
  border-color: #fecdd3;
  background: #fff1f2;
  color: #9f1239;
  padding: 1rem;
}

.madmin-partner-source-errors strong {
  display: block;
}

.madmin-partner-source-errors ul {
  margin: 0.5rem 0 0;
  padding-left: 1.25rem;
}

@media (max-width: 1180px) {
  .madmin-partner-source-layout {
    grid-template-columns: 1fr;
  }

  .madmin-partner-source-preview {
    position: static;
  }
}

@media (max-width: 760px) {
  .madmin-partner-source-page {
    padding: 1rem;
  }

  .madmin-partner-source-header,
  .madmin-partner-source-repeatable__heading {
    align-items: stretch;
    flex-direction: column;
  }

  .madmin-partner-source-grid,
  .madmin-partner-source-toggle-grid,
  .madmin-partner-source-repeatable__row,
  .madmin-partner-source-repeatable__row--single {
    grid-template-columns: 1fr;
  }

  .madmin-partner-source-repeatable__wide {
    grid-column: auto;
  }
}
.madmin-sales-queue {
  --sales-queue-bg: #f8fafc;
  --sales-queue-card: #ffffff;
  --sales-queue-panel: #f1f5f9;
  --sales-queue-line: #e2e8f0;
  --sales-queue-line-strong: #cbd5e1;
  --sales-queue-ink: #0f172a;
  --sales-queue-muted: #64748b;
  --sales-queue-soft: #f8fafc;
  --sales-queue-accent: #047857;

  min-height: 100vh;
  box-sizing: border-box;
  background: var(--sales-queue-bg);
  color: var(--sales-queue-ink);
  padding: 1.5rem;
}

.madmin-sales-queue *,
.madmin-sales-queue *::before,
.madmin-sales-queue *::after {
  box-sizing: border-box;
}

.madmin-sales-queue a {
  color: inherit;
  text-decoration: none;
}

.madmin-sales-queue a:hover {
  color: var(--sales-queue-accent);
  text-decoration: underline;
}

.madmin-sales-queue__header,
.madmin-sales-queue__summary,
.madmin-sales-queue__board-wrap,
.madmin-sales-queue__reports {
  max-width: 1540px;
  margin-inline: auto;
}

.madmin-sales-queue__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
  border-bottom: 1px solid var(--sales-queue-line);
  padding-bottom: 1.25rem;
}

.madmin-sales-queue__intro {
  max-width: 48rem;
}

.madmin-sales-queue__kicker {
  margin: 0;
  color: #b45309;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

.madmin-sales-queue__header h1 {
  margin: 0.5rem 0 0;
  color: #020617;
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.05;
}

.madmin-sales-queue__intro p:last-child,
.madmin-sales-queue__report-heading p:last-child {
  margin: 0.75rem 0 0;
  color: var(--sales-queue-muted);
  font-size: 1rem;
  line-height: 1.6;
}

.madmin-sales-queue__generated {
  flex: 0 0 auto;
  min-width: 10rem;
  border: 1px solid var(--sales-queue-line);
  border-radius: 0.75rem;
  background: var(--sales-queue-card);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04);
  padding: 0.875rem 1rem;
  text-align: right;
}

.madmin-sales-queue__generated span {
  display: block;
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.madmin-sales-queue__generated strong {
  display: block;
  margin-top: 0.25rem;
  color: var(--sales-queue-ink);
  font-size: 0.875rem;
}

.madmin-sales-queue__toggle {
  display: inline-block;
  margin-top: 0.625rem;
  color: var(--sales-queue-accent);
  font-size: 0.75rem;
  font-weight: 700;
}

.madmin-sales-queue__summary {
  margin-top: 1rem;
}

.madmin-sales-queue__summary-list {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.5rem;
}

.madmin-sales-queue-summary {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 0.5rem;
  border: 1px solid var(--sales-queue-line);
  border-radius: 999px;
  background: var(--sales-queue-card);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04);
  padding: 0.5rem 0.75rem;
}

.madmin-sales-queue-summary__dot {
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 999px;
  background: #94a3b8;
}

.madmin-sales-queue-summary__dot--payment-recovery { background: #fb7185; }
.madmin-sales-queue-summary__dot--paid-won { background: #14b8a6; }
.madmin-sales-queue-summary__dot--demo { background: #38bdf8; }
.madmin-sales-queue-summary__dot--sales-follow-up { background: #34d399; }
.madmin-sales-queue-summary__dot--trial-ending { background: #f59e0b; }
.madmin-sales-queue-summary__dot--activation-rescue { background: #818cf8; }
.madmin-sales-queue-summary__dot--expansion { background: #a78bfa; }
.madmin-sales-queue-summary__dot--monitor { background: #94a3b8; }

.madmin-sales-queue-summary__title {
  color: #475569;
  font-size: 0.75rem;
  font-weight: 700;
}

.madmin-sales-queue-summary__count {
  display: inline-flex;
  min-width: 1.5rem;
  justify-content: center;
  border-radius: 999px;
  background: #f1f5f9;
  color: var(--sales-queue-ink);
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.125rem 0.5rem;
}

.madmin-sales-queue__board-wrap {
  margin-top: 0.5rem;
}

.madmin-sales-queue__board-scroll {
  overflow-x: auto;
  padding: 0.25rem 0 1rem;
}

.madmin-sales-queue__board {
  display: flex;
  align-items: stretch;
  gap: 1rem;
  min-width: max-content;
}

.madmin-sales-queue-column {
  display: flex;
  flex: 0 0 340px;
  width: 340px;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid var(--sales-queue-line);
  border-top: 4px solid #94a3b8;
  border-radius: 0.875rem;
  background: color-mix(in srgb, var(--sales-queue-panel), white 28%);
  box-shadow: 0 10px 24px rgb(15 23 42 / 0.07);
}

.madmin-sales-queue-column--payment-recovery { border-top-color: #fb7185; }
.madmin-sales-queue-column--paid-won { border-top-color: #14b8a6; }
.madmin-sales-queue-column--demo { border-top-color: #38bdf8; }
.madmin-sales-queue-column--sales-follow-up { border-top-color: #34d399; }
.madmin-sales-queue-column--trial-ending { border-top-color: #f59e0b; }
.madmin-sales-queue-column--activation-rescue { border-top-color: #818cf8; }
.madmin-sales-queue-column--expansion { border-top-color: #a78bfa; }
.madmin-sales-queue-column--monitor { border-top-color: #94a3b8; }

.madmin-sales-queue-column__header {
  border-bottom: 1px solid var(--sales-queue-line);
  padding: 1rem;
}

.madmin-sales-queue-column__heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.madmin-sales-queue-column__heading > div {
  min-width: 0;
}

.madmin-sales-queue-column__heading p {
  margin: 0;
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.madmin-sales-queue-column__heading h2 {
  overflow: hidden;
  margin: 0.25rem 0 0;
  color: #020617;
  font-size: 0.9375rem;
  font-weight: 800;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.madmin-sales-queue-column__heading small {
  display: block;
  margin-top: 0.375rem;
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  line-height: 1.45;
}

.madmin-sales-queue-column__heading > span {
  display: inline-flex;
  flex: 0 0 auto;
  min-width: 2rem;
  justify-content: center;
  border: 1px solid var(--sales-queue-line);
  border-radius: 999px;
  background: var(--sales-queue-card);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04);
  color: #334155;
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.25rem 0.625rem;
}

.madmin-sales-queue-column__cards {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-height: 440px;
  padding: 1rem;
}

.madmin-sales-queue-column__empty {
  border: 1px dashed var(--sales-queue-line-strong);
  border-radius: 0.75rem;
  background: rgb(255 255 255 / 0.74);
  padding: 2rem 1rem;
  text-align: center;
}

.madmin-sales-queue-column__empty p,
.madmin-sales-queue-report-empty {
  margin: 0;
  color: var(--sales-queue-ink);
  font-size: 0.875rem;
  font-weight: 700;
}

.madmin-sales-queue-column__empty small {
  display: block;
  margin-top: 0.375rem;
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  line-height: 1.45;
}

.madmin-sales-queue-card {
  border: 1px solid var(--sales-queue-line);
  border-radius: 0.75rem;
  background: var(--sales-queue-card);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04);
  padding: 1rem;
}

.madmin-sales-queue-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.madmin-sales-queue-card__header > div {
  min-width: 0;
}

.madmin-sales-queue-card__header p {
  margin: 0;
  color: #94a3b8;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.madmin-sales-queue-card__header h3 {
  overflow: hidden;
  margin: 0.25rem 0 0;
  color: #020617;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.madmin-sales-queue-card__header small {
  display: block;
  overflow: hidden;
  margin-top: 0.25rem;
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.madmin-sales-queue-card__header > span {
  display: inline-flex;
  flex: 0 0 auto;
  border-radius: 999px;
  background: #f1f5f9;
  color: #334155;
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.25rem 0.625rem;
}

.madmin-sales-queue-card__scores {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.5rem;
  margin: 1rem 0 0;
  text-align: center;
}

.madmin-sales-queue-card__scores div {
  border: 1px solid #f1f5f9;
  border-radius: 0.625rem;
  background: #f8fafc;
  padding: 0.5rem;
}

.madmin-sales-queue-card__scores dt {
  color: var(--sales-queue-muted);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.madmin-sales-queue-card__scores dd {
  margin: 0.25rem 0 0;
  color: var(--sales-queue-ink);
  font-size: 0.875rem;
  font-weight: 800;
}

.madmin-sales-queue-card__details {
  display: grid;
  gap: 0.5rem;
  margin: 1rem 0 0;
  font-size: 0.875rem;
}

.madmin-sales-queue-card__details div {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.madmin-sales-queue-card__details dt {
  flex: 0 0 auto;
  color: var(--sales-queue-muted);
}

.madmin-sales-queue-card__details dd {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
  text-align: right;
  color: #334155;
  font-weight: 700;
}

.madmin-sales-queue-card__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  border-top: 1px solid var(--sales-queue-line);
  margin-top: 1rem;
  padding-top: 0.875rem;
}

.madmin-sales-queue-card__actions span {
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  font-weight: 700;
}

.madmin-sales-queue-card__button {
  border: 0;
  border-radius: 0.5rem;
  background: var(--sales-queue-accent);
  color: #fff;
  cursor: pointer;
  font: inherit;
  font-size: 0.75rem;
  font-weight: 800;
  padding: 0.5rem 0.75rem;
}

.madmin-sales-queue-card__button--secondary {
  background: #e2e8f0;
  color: #334155;
}

.madmin-sales-queue__reports {
  margin-top: 2rem;
  border-top: 1px solid var(--sales-queue-line);
  padding-top: 1.5rem;
}

.madmin-sales-queue__report-heading h2,
.madmin-sales-queue-report-card__heading h2 {
  margin: 0.25rem 0 0;
  color: #020617;
  font-size: 1.125rem;
  font-weight: 800;
}

.madmin-sales-queue__report-grid {
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

.madmin-sales-queue-report-card {
  border: 1px solid var(--sales-queue-line);
  border-radius: 0.875rem;
  background: var(--sales-queue-card);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04);
  padding: 1.25rem;
}

.madmin-sales-queue-report-card__heading {
  margin-bottom: 1rem;
}

.madmin-sales-queue-report-empty {
  border: 1px dashed var(--sales-queue-line);
  border-radius: 0.75rem;
  background: var(--sales-queue-soft);
  color: var(--sales-queue-muted);
  padding: 1rem;
}

.madmin-sales-queue-table-wrap {
  overflow-x: auto;
}

.madmin-sales-queue-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  font-size: 0.875rem;
}

.madmin-sales-queue-table--affiliate {
  min-width: 620px;
}

.madmin-sales-queue-table--influencer {
  min-width: 880px;
}

.madmin-sales-queue-table th,
.madmin-sales-queue-table td {
  border-bottom: 1px solid #f1f5f9;
  padding: 0.75rem 1rem;
  white-space: nowrap;
}

.madmin-sales-queue-table th:first-child,
.madmin-sales-queue-table td:first-child {
  padding-left: 0;
}

.madmin-sales-queue-table th:last-child,
.madmin-sales-queue-table td:last-child {
  padding-right: 0;
}

.madmin-sales-queue-table th {
  color: var(--sales-queue-muted);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.madmin-sales-queue-table td {
  color: #475569;
}

.madmin-sales-queue-table td strong {
  color: var(--sales-queue-ink);
}

.madmin-sales-queue-table tbody tr:last-child td {
  border-bottom: 0;
}

@media (min-width: 1280px) {
  .madmin-sales-queue__report-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 840px) {
  .madmin-sales-queue {
    padding: 1rem;
  }

  .madmin-sales-queue__header {
    align-items: stretch;
    flex-direction: column;
  }

  .madmin-sales-queue__generated {
    text-align: left;
  }
}
.madmin-user-show {
  --madmin-user-bg: #f8fafc;
  --madmin-user-card: #ffffff;
  --madmin-user-panel: #f1f5f9;
  --madmin-user-line: #e2e8f0;
  --madmin-user-line-strong: #cbd5e1;
  --madmin-user-ink: #0f172a;
  --madmin-user-muted: #64748b;
  --madmin-user-accent: #047857;
  --madmin-user-accent-dark: #065f46;
  --madmin-user-warning: #b45309;
  --madmin-user-danger: #b91c1c;

  min-height: 100vh;
  box-sizing: border-box;
  background: var(--madmin-user-bg);
  color: var(--madmin-user-ink);
  padding: 1.5rem;
}

.madmin-user-show *,
.madmin-user-show *::before,
.madmin-user-show *::after {
  box-sizing: border-box;
}

.madmin-user-show a {
  color: inherit;
}

.madmin-user-header,
.madmin-user-status-strip,
.madmin-user-invitation-share,
.madmin-user-admin-actions,
.madmin-user-grid {
  max-width: 1540px;
  margin-inline: auto;
}

.madmin-user-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  border-bottom: 1px solid var(--madmin-user-line);
  padding-bottom: 1.25rem;
}

.madmin-user-title-block {
  min-width: 0;
}

.madmin-user-kicker {
  margin: 0;
  color: var(--madmin-user-warning);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

.madmin-user-title {
  margin: 0.45rem 0 0;
  color: #020617;
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.05;
  overflow-wrap: anywhere;
}

.madmin-user-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.madmin-user-meta span {
  border: 1px solid var(--madmin-user-line);
  border-radius: 999px;
  background: var(--madmin-user-card);
  color: var(--madmin-user-muted);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.2;
  padding: 0.4rem 0.65rem;
}

.madmin-user-actions {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: flex-end;
  max-width: 32rem;
}

.madmin-user-actions form,
.madmin-user-admin-actions form {
  margin: 0;
}

.madmin-user-action {
  display: inline-flex;
  min-height: 2.75rem;
  align-items: center;
  justify-content: center;
  border-radius: 0.625rem;
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.2;
  padding: 0.75rem 1rem;
  text-decoration: none;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}

.madmin-user-action:hover {
  text-decoration: none;
}

.madmin-user-show .madmin-user-action--primary {
  min-width: 12rem;
  border: 1px solid var(--madmin-user-accent-dark);
  background: var(--madmin-user-accent);
  color: #ffffff;
}

.madmin-user-show .madmin-user-action--primary:hover {
  background: var(--madmin-user-accent-dark);
  color: #ffffff;
}

.madmin-user-action--secondary {
  border: 1px solid var(--madmin-user-line-strong);
  background: var(--madmin-user-card);
  color: var(--madmin-user-ink);
  cursor: pointer;
}

.madmin-user-action--secondary:hover {
  border-color: var(--madmin-user-muted);
  background: var(--madmin-user-panel);
}

.madmin-user-action--warning {
  border: 1px solid #f59e0b;
  background: #fffbeb;
  color: #92400e;
  cursor: pointer;
}

.madmin-user-action--warning:hover {
  border-color: #d97706;
  background: #fef3c7;
}

.madmin-user-action--danger {
  border: 1px solid #fca5a5;
  background: #fef2f2;
  color: #991b1b;
  cursor: pointer;
}

.madmin-user-action--danger:hover {
  border-color: #ef4444;
  background: #fee2e2;
}

.madmin-user-action--disabled {
  border: 1px solid var(--madmin-user-line);
  background: var(--madmin-user-panel);
  color: var(--madmin-user-muted);
  cursor: not-allowed;
}

.madmin-user-support-note {
  max-width: 20rem;
  margin: 0;
  border: 1px solid #f59e0b;
  border-radius: 0.625rem;
  background: #fffbeb;
  color: #92400e;
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.35;
  padding: 0.75rem 0.9rem;
}

.madmin-user-admin-actions {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid var(--madmin-user-line);
  border-radius: 0.875rem;
  background: var(--madmin-user-card);
  margin-top: 1rem;
  padding: 1rem;
}

.madmin-user-admin-actions__heading h2 {
  margin: 0;
  color: var(--madmin-user-ink);
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.2;
}

.madmin-user-admin-actions__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: flex-end;
}

.madmin-user-status-strip {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
  overflow-x: auto;
  padding-bottom: 0.25rem;
}

.madmin-user-status-card {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: baseline;
  gap: 0.45rem;
  border: 1px solid var(--madmin-user-line);
  border-radius: 999px;
  background: var(--madmin-user-card);
  padding: 0.5rem 0.75rem;
}

.madmin-user-status-card span,
.madmin-user-fields dt,
.madmin-user-toggles dt,
.madmin-user-activity-grid dt {
  color: var(--madmin-user-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.2;
  text-transform: uppercase;
}

.madmin-user-status-card strong {
  color: var(--madmin-user-ink);
  font-size: 0.82rem;
  font-weight: 800;
  line-height: 1.2;
}

.madmin-user-status-card.is-positive {
  border-color: #86efac;
  background: #ecfdf5;
}

.madmin-user-status-card.is-warning {
  border-color: #fcd34d;
  background: #fffbeb;
}

.madmin-user-status-card.is-danger {
  border-color: #fca5a5;
  background: #fef2f2;
}

.madmin-user-status-card.is-muted {
  border-color: var(--madmin-user-line);
  background: var(--madmin-user-panel);
}

.madmin-user-invitation-share {
  border: 1px solid #86efac;
  border-radius: 0.75rem;
  background: #ecfdf5;
  margin-top: 1rem;
  padding: 1rem;
}

.madmin-user-invitation-share p {
  margin: 0 0 0.6rem;
  color: #065f46;
  font-size: 0.8rem;
  font-weight: 800;
}

.madmin-user-invitation-share div {
  display: flex;
  gap: 0.5rem;
}

.madmin-user-invitation-share input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid #86efac;
  border-radius: 0.5rem;
  background: #ffffff;
  color: var(--madmin-user-ink);
  padding: 0.55rem 0.7rem;
}

.madmin-user-invitation-share button,
.madmin-user-invitation-share a {
  border: 1px solid #065f46;
  border-radius: 0.5rem;
  background: #065f46;
  color: #ffffff;
  font-size: 0.8rem;
  font-weight: 800;
  padding: 0.55rem 0.75rem;
  text-decoration: none;
}

.madmin-user-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 1rem;
  margin-top: 1.25rem;
}

.madmin-user-section {
  overflow: hidden;
  border: 1px solid var(--madmin-user-line);
  border-radius: 0.875rem;
  background: var(--madmin-user-card);
}

.madmin-user-section--identity,
.madmin-user-section--command {
  border-color: var(--madmin-user-line-strong);
}

.madmin-user-section--wide {
  grid-column: 1 / -1;
}

.madmin-user-section__heading {
  border-bottom: 1px solid var(--madmin-user-line);
  background: var(--madmin-user-panel);
  padding: 0.85rem 1rem;
}

.madmin-user-section__heading h2 {
  margin: 0;
  color: var(--madmin-user-ink);
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.2;
}

.madmin-user-fields,
.madmin-user-toggles,
.madmin-user-activity-grid {
  margin: 0;
  padding: 0;
}

.madmin-user-fields > div,
.madmin-user-activity-grid > div {
  display: grid;
  grid-template-columns: minmax(8rem, 0.34fr) minmax(0, 1fr);
  gap: 1rem;
  border-top: 1px solid var(--madmin-user-line);
  padding: 0.72rem 1rem;
}

.madmin-user-fields > div:first-child,
.madmin-user-activity-grid > div:first-child {
  border-top: 0;
}

.madmin-user-fields dd,
.madmin-user-toggles dd,
.madmin-user-activity-grid dd {
  margin: 0;
  min-width: 0;
  color: var(--madmin-user-ink);
  font-size: 0.92rem;
  font-weight: 650;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.madmin-user-fields a {
  color: var(--madmin-user-accent-dark);
  font-weight: 800;
}

.madmin-user-fields a:hover {
  color: var(--madmin-user-accent);
}

.madmin-user-toggles {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.5rem;
  padding: 1rem;
}

.madmin-user-toggles > div {
  border: 1px solid var(--madmin-user-line);
  border-radius: 0.625rem;
  background: #ffffff;
  padding: 0.7rem;
}

.madmin-user-toggles > div.is-positive {
  border-color: #86efac;
  background: #ecfdf5;
}

.madmin-user-toggles > div.is-danger {
  border-color: #fca5a5;
  background: #fef2f2;
}

.madmin-user-toggles > div.is-muted {
  background: var(--madmin-user-panel);
}

.madmin-user-toggles dd {
  margin-top: 0.25rem;
  font-size: 0.95rem;
  font-weight: 800;
}

.madmin-user-activity-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.madmin-user-empty {
  max-width: 1540px;
  border: 1px solid var(--madmin-user-line);
  border-radius: 0.75rem;
  background: var(--madmin-user-card);
  color: var(--madmin-user-muted);
  margin: 0 auto;
  padding: 1rem;
}

@media (max-width: 1080px) {
  .madmin-user-header,
  .madmin-user-grid {
    grid-template-columns: 1fr;
  }

  .madmin-user-header {
    flex-direction: column;
  }

  .madmin-user-actions {
    justify-content: flex-start;
  }

  .madmin-user-admin-actions {
    flex-direction: column;
  }

  .madmin-user-admin-actions__list {
    justify-content: flex-start;
  }

  .madmin-user-activity-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .madmin-user-show {
    padding: 1rem;
  }

  .madmin-user-actions {
    order: -1;
    width: 100%;
  }

  .madmin-user-action {
    width: 100%;
  }

  .madmin-user-admin-actions__list,
  .madmin-user-admin-actions form {
    width: 100%;
  }

  .madmin-user-title {
    font-size: 1.85rem;
  }

  .madmin-user-toggles,
  .madmin-user-activity-grid {
    grid-template-columns: 1fr;
  }

  .madmin-user-fields > div,
  .madmin-user-activity-grid > div {
    grid-template-columns: 1fr;
    gap: 0.3rem;
  }

  .madmin-user-invitation-share div {
    flex-direction: column;
  }
}
.pagy {
    display: flex;
    font-family: sans-serif;
    font-size: 0.875rem;
    line-height: 1.25rem;
    font-weight: 600;
    color: #6b7280;
}
.pagy > :not([hidden]) ~ :not([hidden]) {
    --space-reverse: 0;
    margin-right: calc(0.25rem * var(--space-reverse));
    margin-left: calc(0.25rem * calc(1 - var(--space-reverse)));
}
.pagy a:not(.gap) {
    display: block;
    text-decoration: none;
    border-radius: 0.5rem;
    background-color: #e5e7eb;
    padding: 0.25rem 0.75rem;
    color: inherit;
}
.pagy a:not(.gap):hover {
    background-color: #d1d5db;
}
.pagy a:not(.gap):not([href]) { /* disabled links */
    cursor: default;
    background-color: #f3f4f6;
    color: #d1d5db;
}
.pagy a:not(.gap).current {
    background-color: #9ca3af;
    color: white;
}
.pagy label {
    white-space: nowrap;
    display: inline-block;
    border-radius: 0.5rem;
    background-color: #e5e7eb;
    padding: 0.125rem 0.75rem;
}
.pagy label input {
    line-height: 1.5rem;
    border-radius: 0.375rem;
    border-style: none;
    background-color: #f3f4f6;
}
/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
 * vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS
 * files in this directory. Styles in this file should be added after the last require_* statement.
 * It is generally better to create a new file per style scope.
 *


 */

.slim-select {
    z-index: 1000;
}

.trial-onboarding-safe-area {
    padding-bottom: calc(30rem + env(safe-area-inset-bottom, 0px)) !important;
    scroll-padding-bottom: calc(30rem + env(safe-area-inset-bottom, 0px));
}

/*FULLCALENDAR */
.fc .fc-toolbar-title {
    font-size: 1.25rem !important;
    margin: 0;
    font-weight: 500;
    padding: 20px 0 0 0; /* Remove left padding to keep title centered */
}

.fc-timegrid-slot {
    line-height: 2em;
    border-color: #e2e8f0 !important; /* slate-200 - more visible grid lines */
}

.fc .fc-button {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
}

.fc-day-today {
    background-color: #dbeafe !important; /* blue-100 - more visible */
}

/* Add left border to today's column for emphasis */
.fc .fc-timegrid-col.fc-day-today {
    border-left: 3px solid #3b82f6 !important; /* blue-500 */
}

/* Today's header - make it stand out */
.fc .fc-col-header-cell.fc-day-today {
    background-color: #dbeafe !important;
}

.fc .fc-col-header-cell.fc-day-today a {
    color: #1d4ed8 !important; /* blue-700 */
    font-weight: 700 !important;
}

.fc-timegrid-slot-minor {
    border-top-style: none !important;
}

.fc-day-other {
    background: #FAFAFB;
}

.fc .fc-button .fc-icon {
    font-size: 0.875rem !important;
}

a.fc-col-header-cell-cushion {
    font-size: 1.2em !important;
    line-height: 3rem !important;
    font-weight: 600 !important;
}

.fc .fc-daygrid-day-top {
    flex-direction: inherit !important;
    padding: 5px !important;
    font-size: .75em !important;
    color: #6b7280 !important;
}

.fc .fc-button-primary:disabled {
    background-color: #eeeeee !important;
    color: black !important;
    border-color: #eeeeee !important;
    /*font-size: 0.875rem !important;*/
    /*line-height: 1.25rem !important;*/
    text-transform: capitalize !important;
}


.fc-button {
    background-color: #2563eb !important;
    color: whitesmoke !important;
    border-color: transparent !important;
}

/* Grid lines - more visible */
.fc .fc-timegrid-col,
.fc .fc-timegrid-axis {
    border-color: #e2e8f0 !important; /* slate-200 */
}

.fc-scrollgrid,
.fc-scrollgrid td,
.fc-scrollgrid th {
    border-color: #e2e8f0 !important; /* slate-200 */
}

/* Time column - fixed background */
.fc .fc-timegrid-axis {
    background-color: #f8fafc !important; /* slate-50 */
}

.fc .fc-timegrid-axis.fc-scrollgrid-shrink {
    color: #64748b;
}

.fc .fc-timegrid-divider {
    border-color: #cbd5e1 !important;
}

.fc .fc-timegrid-all-day {
    background-color: #f8fafc !important;
}

.fc .fc-timegrid-axis-cushion,
.fc .fc-timegrid-slot-label-cushion {
    color: #475569; /* slate-600 - darker for better visibility */
    font-size: 0.75rem;
    font-weight: 500; /* add medium weight */
}

/* Now indicator styling - Google Calendar style: thin line + dot */
.fc .fc-timegrid-now-indicator-line {
    border-color: #dc2626 !important; /* red-600 - high visibility */
    border-width: 1px !important; /* thin line */
}

/* Replace arrow with circular dot */
.fc .fc-timegrid-now-indicator-arrow {
    border: none !important;
    width: 10px !important;
    height: 10px !important;
    background-color: #dc2626 !important;
    border-radius: 9999px !important;
    margin-top: -5px !important; /* center on the line */
}

[data-dashboard-event-active="true"] {
    background-color: rgba(254, 242, 242, 0.82);
    border-color: rgba(220, 38, 38, 0.28);
    box-shadow: 0 12px 30px -24px rgba(220, 38, 38, 0.58), inset 3px 0 0 rgba(220, 38, 38, 0.68);
}

/* Hover affordance on empty slots - highlight + "+" icon */
.fc-timegrid-slot:hover {
    background-color: rgba(59, 130, 246, 0.05) !important; /* blue-500 with low opacity */
    cursor: pointer;
    transition: background-color 0.2s ease;
}

/* Add "+" icon on hover using a pseudo-element on the slot lane */
.fc-timegrid-col:hover .fc-timegrid-col-frame::after {
    content: '+';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 2rem;
    font-weight: 300;
    color: rgba(59, 130, 246, 0.3);
    pointer-events: none;
    z-index: 1;
}

/* Event cards styling - preserve left border for pastel + border pattern */
.fc-event {
    border-top: none !important;
    border-right: none !important;
    border-bottom: none !important;
    /* border-left is set via eventDidMount in JS */
    box-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05) !important;
}

.fc-timegrid-event {
    border-radius: 4px !important;
}

.fc-timegrid-event .fc-event-main {
    padding: 4px 6px !important;
}

.fc-timegrid-event .fc-event-title {
    font-size: 0.75rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.fc .ow-appointment-content {
    display: grid;
    gap: 2px;
    min-width: 0;
    width: 100%;
    line-height: 1.15;
    color: inherit;
}

.fc .ow-appointment-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: inherit;
    font-size: 0.75rem;
    font-weight: 700;
}

.fc .ow-appointment-online-icon {
    display: inline-flex;
    width: 12px;
    height: 12px;
    margin-right: 4px;
    vertical-align: -2px;
    color: inherit;
}

.fc .ow-appointment-online-icon svg {
    width: 12px;
    height: 12px;
}

.fc .ow-appointment-time {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: inherit;
    font-size: 9px;
    font-weight: 700;
}

.fc .ow-online-booking-request-event {
    background-color: #fff7ed !important;
    color: #9a3412 !important;
    border-radius: 4px !important;
}

.fc .ow-agenda-block-event {
    --agenda-block-background-color: #f8fafc;
    --agenda-block-stripe-color: #e2e8f0;
    --agenda-block-text-color: #334155;
    background-color: var(--agenda-block-background-color) !important;
    background-image: repeating-linear-gradient(
        -45deg,
        var(--agenda-block-background-color) 0,
        var(--agenda-block-background-color) 8px,
        var(--agenda-block-stripe-color) 8px,
        var(--agenda-block-stripe-color) 12px
    ) !important;
    color: var(--agenda-block-text-color) !important;
    border-radius: 4px !important;
}

.fc .ow-agenda-block-clinic {
    --agenda-block-background-color: #fff7f7;
    --agenda-block-stripe-color: #fecaca;
    --agenda-block-text-color: #7f1d1d;
}

.fc .ow-agenda-block-dentist {
    --agenda-block-background-color: #f8fbff;
    --agenda-block-stripe-color: #bfdbfe;
    --agenda-block-text-color: #172554;
}

.fc .ow-agenda-block-content {
    display: grid;
    gap: 2px;
    min-width: 0;
    position: relative;
    width: 100%;
    line-height: 1.15;
}

.ow-office-preview {
    color: #334155;
    line-height: 1.7;
}

.ow-office-preview h1,
.ow-office-preview h2,
.ow-office-preview h3,
.ow-office-preview h4 {
    color: #0f172a;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 0.75rem;
}

.ow-office-preview h1 {
    font-size: 1.875rem;
}

.ow-office-preview h2 {
    font-size: 1.5rem;
}

.ow-office-preview h3 {
    font-size: 1.25rem;
}

.ow-office-preview p,
.ow-office-preview ul,
.ow-office-preview ol {
    margin: 0 0 1rem;
}

.ow-office-preview ul,
.ow-office-preview ol {
    padding-left: 1.25rem;
}

.ow-office-preview li + li {
    margin-top: 0.35rem;
}

.ow-office-preview table {
    width: 100%;
    border-collapse: collapse;
    border-radius: 1rem;
    overflow: hidden;
}

.ow-office-preview tr:nth-child(even) td {
    background-color: #f8fafc;
}

.ow-office-preview td,
.ow-office-preview th {
    border: 1px solid #e2e8f0;
}

.fc .ow-agenda-block-content-recurring {
    padding-right: 18px;
}

.fc .ow-agenda-block-scope {
    display: inline;
    width: auto;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    background: none;
    border: 0;
    color: inherit;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0;
    padding: 0;
}

.fc .ow-agenda-block-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: inherit;
    font-size: 0.72rem;
    font-weight: 800;
}

.fc .ow-agenda-block-meta {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 4px;
    color: inherit;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 0;
}

.fc .ow-agenda-block-recurring-icon {
    align-items: center;
    color: inherit;
    display: inline-flex;
    height: 14px;
    justify-content: center;
    position: absolute;
    right: 0;
    top: 0;
    width: 14px;
}

.fc .ow-agenda-block-recurring-icon svg {
    height: 14px;
    width: 14px;
}

.fc .ow-agenda-block-event .fc-event-main {
    color: inherit !important;
    background-color: transparent !important;
    padding: 4px 6px 4px 8px !important;
}

.fc .ow-agenda-block-event .fc-event-title {
    font-weight: 800 !important;
    letter-spacing: 0 !important;
}

.fc .ow-agenda-block-event .fc-event-time {
    color: inherit !important;
}

/* FullCalendar - Mobile (Agenda daily view with week strip) */
@media (max-width: 767px) {
    .fc .fc-toolbar {
        display: none !important;
    }
    /* Remove internal day header in daily view - saves ~20% screen */
    [data-calendar-view="day"] .fc .fc-col-header {
        display: none !important;
    }
    /* Weekly view on small screens: compact day headers */
    [data-calendar-view="week"] .fc .fc-col-header-cell-cushion {
        font-size: 0.7rem !important;
        padding: 4px 2px !important;
    }
    .fc .fc-timegrid-slot-label {
        width: 60px !important;
        min-width: 60px !important;
    }
    .fc .fc-timegrid-axis {
        width: 60px !important;
        min-width: 60px !important;
    }
    /* Event card: full width in daily view, no truncation - show full patient name */
    [data-calendar-view="day"] .fc .fc-timegrid-event {
        width: 100% !important;
        max-width: none !important;
    }
    [data-calendar-view="day"] .fc .fc-timegrid-event .fc-event-main {
        width: 100% !important;
        padding: 6px 8px !important;
    }
    [data-calendar-view="day"] .fc .fc-timegrid-event .fc-event-title {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: unset !important;
        word-break: break-word !important;
        line-height: 1.3 !important;
        font-size: 0.8rem !important;
    }
    [data-calendar-view="day"] .fc .ow-appointment-title,
    [data-calendar-view="day"] .fc .ow-appointment-time {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: unset !important;
        word-break: break-word !important;
    }
    [data-calendar-view="day"] .fc .ow-appointment-title {
        font-size: 0.8rem !important;
        line-height: 1.3 !important;
    }
    /* Weekly view on small screens: compact event cards */
    [data-calendar-view="week"] .fc .fc-timegrid-event .fc-event-title {
        font-size: 0.65rem !important;
        line-height: 1.2 !important;
    }
    [data-calendar-view="week"] .fc .ow-appointment-title {
        font-size: 0.65rem !important;
        line-height: 1.2 !important;
    }
}

/* Event hover tooltip */
.ow-event-tooltip {
    position: fixed;
    z-index: 10000;
    width: 20rem;
    max-width: calc(100vw - 20px);
    pointer-events: none;
    transform-origin: top left;
    animation: ow-tooltip-fade-in 100ms ease-out;
}

.ow-tooltip-content {
    box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
}

.ow-tooltip-status-badge {
    display: inline-flex;
    align-items: center;
    line-height: 1;
}

@keyframes ow-tooltip-fade-in {
    from {
        opacity: 0;
        transform: scale(0.96);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

/*END OF FULLCALENDAR*/
#notes-trix.trix-content {
    max-height: 300px !important;
    height: 200px !important;
    margin-top: 6px;
    overflow-y: auto;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
    padding: 12px;
    background-color: #FFFBEB;
}

.bg-paper {
    background-color: #fffcf9;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'%3E%3Cpath fill='%23a4c2ea' fill-opacity='0.25' d='M1 3h1v1H1V3zm2-2h1v1H3V1z'%3E%3C/path%3E%3C/svg%3E");
}

.bg2-paper {
    background-color: #fffddc;
    background-image: url("data:image/svg+xml,%3Csvg width='6' height='6' viewBox='0 0 6 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23000000' fill-opacity='0.05' fill-rule='evenodd'%3E%3Cpath d='M5 0h1L0 6V5zM6 5v1H5z'/%3E%3C/g%3E%3C/svg%3E");
}

.hover-bg-navbar:hover {
    background-color: #5E8EF4;
}

.active-path {
    background-color: #5E8EF4;
}

/* https://stackoverflow.com/questions/38663578/how-to-hide-autofill-safari-icon-in-input-field/39885072#39885072 */
/*noinspection CssInvalidPseudoSelector*/
input::-webkit-contacts-auto-fill-button {
    visibility: hidden;
    display: none !important;
    pointer-events: none;
    position: absolute;
    right: 0;
}


.legend {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 4px;
    max-width: 1000px;
    margin-top: 1em;
}
.legend-item {
    display: flex;
    align-items: center;
}
.legend-color {
    width: 20px;
    height: 20px;
    margin-right: 8px;
}

.unread-announcements:before {
    border-radius: 50%;
    background-clip: padding-box;
    /* Assuming $red variable resolves to red */
    background: red;
    content: '';
    display: inline-block;
    height: 8px;
    width: 8px;
    margin-right: 6px;
}

/* Link de agendamento settings */
.ow-booking-shell {
    --ow-ink: #0f172a;
    --ow-muted: #64748b;
    --ow-line: #e2e8f0;
    --ow-panel: #f8fafc;
    --ow-card: #ffffff;
    --ow-accent: #2563eb;
    --ow-accent-strong: #1d4ed8;
    --ow-accent-soft: #dbeafe;
    --ow-warm: #eff6ff;
    max-width: 1180px;
    margin: 0 auto;
    color: var(--ow-ink);
}

.ow-booking-shell,
.ow-booking-form {
    display: grid;
    gap: 24px;
}

.ow-form-error-summary {
    border: 1px solid #fecaca;
    border-radius: 8px;
    background: #fef2f2;
    padding: 14px 16px;
    color: #991b1b;
}

.ow-form-error-summary strong {
    display: block;
    font-size: 0.95rem;
    font-weight: 800;
}

.ow-form-error-summary p {
    margin: 4px 0 0;
    color: #b91c1c;
    font-size: 0.875rem;
}

.ow-form-error-summary ul {
    margin: 8px 0 0;
    padding-left: 18px;
    font-size: 0.875rem;
}

.ow-booking-heading {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
}

.ow-booking-heading h1 {
    margin: 0;
    font-size: 1.875rem;
    line-height: 1.2;
    font-weight: 750;
}

.ow-booking-heading p,
.ow-section-heading p,
.ow-booking-status-panel p,
.ow-onboarding-copy p,
.ow-template-builder p {
    margin: 6px 0 0;
    color: var(--ow-muted);
    font-size: 0.925rem;
    line-height: 1.55;
}

.ow-eyebrow,
.ow-section-kicker {
    margin: 0;
    color: #2563eb;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ow-booking-status-panel,
.ow-booking-onboarding,
.ow-template-builder {
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: var(--ow-panel);
}

.ow-booking-status-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
    gap: 24px;
    align-items: start;
    padding: 22px;
}

.ow-booking-status-panel h2,
.ow-onboarding-copy h2,
.ow-section-heading h2 {
    margin: 4px 0 0;
    font-size: 1.15rem;
    line-height: 1.3;
    font-weight: 750;
}

.ow-link-box {
    display: grid;
    gap: 14px;
    min-width: 0;
}

.ow-link-box form {
    display: contents;
}

.ow-link-publish-control {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.ow-link-publish-control .ow-toggle-row {
    gap: 8px;
}

.ow-link-toggle-copy {
    display: grid;
    gap: 1px;
}

.ow-link-toggle-copy strong {
    color: var(--ow-ink);
    font-size: 0.84rem;
    font-weight: 800;
    line-height: 1.15;
}

.ow-link-toggle-copy small {
    color: var(--ow-muted);
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1.2;
}

.ow-link-help {
    margin: 8px 0 0;
    color: var(--ow-muted);
    font-size: 0.82rem;
    line-height: 1.45;
}

.ow-link-url-panel {
    display: grid;
    gap: 7px;
}

.ow-link-url-panel label {
    color: #334155;
    font-size: 0.76rem;
    font-weight: 800;
}

.ow-link-box input:not(.ow-toggle-input):not([type="hidden"]),
.ow-select-field,
.ow-unit-input input,
.ow-template-times input,
.ow-window-row input[type="time"] {
    width: 100%;
    min-height: 42px;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
    color: var(--ow-ink);
    font-size: 0.92rem;
    outline: none;
}

.ow-link-box input:not(.ow-toggle-input):not([type="hidden"]) {
    padding: 0 12px;
    color: #475569;
}

.ow-link-url-panel input {
    min-height: 46px;
    background: #f8fafc;
    font-size: 0.9rem;
}

.ow-link-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 10px;
}

.ow-link-actions form {
    display: contents;
}

.ow-status-pill {
    display: inline-flex;
    min-height: 32px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0 12px;
    font-size: 0.76rem;
    font-weight: 800;
}

.ow-status-pill.is-active {
    background: var(--ow-accent-soft);
    color: var(--ow-accent-strong);
}

.ow-status-pill.is-paused {
    background: #eef2f7;
    color: #526172;
}

.ow-booking-onboarding {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: 24px;
    align-items: stretch;
    padding: 24px;
    background: linear-gradient(120deg, #f8fafc 0%, #eff6ff 100%);
}

.ow-onboarding-copy {
    display: grid;
    align-content: start;
    gap: 16px;
}

.ow-onboarding-benefits {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ow-onboarding-benefits span {
    border: 1px solid rgba(37, 99, 235, 0.18);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    padding: 7px 10px;
    color: #334155;
    font-size: 0.8rem;
    font-weight: 700;
}

.ow-onboarding-video {
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(37, 99, 235, 0.14);
    border-radius: 8px;
    background: #e2e8f0;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.ow-onboarding-video iframe {
    display: block;
}

.ow-booking-panel {
    display: grid;
    gap: 16px;
}

.ow-section-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
}

.ow-section-heading p {
    max-width: 520px;
    text-align: right;
}

.ow-setting-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    align-items: stretch;
}

.ow-setting-card,
.ow-check-card,
.ow-day-row {
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: var(--ow-card);
}

.ow-setting-card {
    display: grid;
    min-height: 126px;
    align-content: space-between;
    gap: 16px;
    padding: 16px;
}

.ow-setting-card-wide {
    grid-column: span 2;
}

.ow-setting-card-toggle {
    background: #f8fafc;
}

.ow-field-label {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: #334155;
    font-size: 0.86rem;
    font-weight: 800;
}

.ow-field-label label {
    margin: 0;
}

.ow-info-tip {
    position: relative;
    z-index: 1;
    display: inline-flex;
    flex: none;
}

.ow-info-tip:hover,
.ow-info-tip:focus-within {
    z-index: 80;
}

.ow-info-tip-button {
    display: grid;
    width: 26px;
    height: 26px;
    place-items: center;
    border: 1px solid rgba(37, 99, 235, 0.22);
    border-radius: 999px;
    background: #ffffff;
    color: var(--ow-accent);
}

.ow-info-tip-button svg {
    width: 18px;
    height: 18px;
}

.ow-info-tooltip {
    position: absolute;
    right: 0;
    bottom: calc(100% + 8px);
    z-index: 90;
    width: min(260px, 70vw);
    transform: translateY(3px);
    border-radius: 8px;
    background: #0f172a;
    color: #f8fafc;
    padding: 10px 12px;
    font-size: 0.78rem;
    font-weight: 600;
    line-height: 1.4;
    opacity: 0;
    pointer-events: none;
    transition: opacity 140ms ease, transform 140ms ease;
}

.ow-advanced-setting-copy .ow-info-tooltip {
    right: auto;
    left: 0;
}

.ow-info-tip--breakdown .ow-info-tooltip {
    width: min(20rem, calc(100vw - 1.5rem));
    font-weight: 500;
}

.ow-info-tip:hover .ow-info-tooltip,
.ow-info-tip-button:focus-visible + .ow-info-tooltip {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.ow-toggle-row,
.ow-day-toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #334155;
    font-size: 0.9rem;
    font-weight: 750;
}

.ow-toggle-input,
.ow-day-toggle input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
}

.ow-toggle-track,
.ow-day-toggle span {
    position: relative;
    width: 44px;
    height: 24px;
    flex: none;
    border-radius: 999px;
    background: #cbd5e1;
    transition: background-color 160ms ease;
}

.ow-toggle-track::after,
.ow-day-toggle span::after {
    content: "";
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: #ffffff;
    box-shadow: 0 2px 6px rgba(15, 23, 42, 0.18);
    transition: transform 160ms ease;
}

.ow-toggle-input:checked + .ow-toggle-track,
.ow-day-toggle input:checked + span {
    background: var(--ow-accent);
}

.ow-toggle-input:checked + .ow-toggle-track::after,
.ow-day-toggle input:checked + span::after {
    transform: translateX(20px);
}

.ow-mode-options {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.ow-mode-card {
    display: grid;
    min-height: 88px;
    cursor: pointer;
    gap: 5px;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    padding: 12px;
    color: #475569;
    transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}

.ow-mode-card strong {
    color: var(--ow-ink);
    font-size: 0.92rem;
}

.ow-mode-card span {
    color: var(--ow-muted);
    font-size: 0.8rem;
    line-height: 1.35;
}

.ow-mode-card:has(input:checked) {
    border-color: rgba(37, 99, 235, 0.5);
    background: var(--ow-accent-soft);
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.18);
}

.ow-unit-input {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    overflow: hidden;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
}

.ow-unit-input input {
    min-height: 44px;
    border: 0;
    border-radius: 0;
    padding: 0 12px;
}

.ow-unit-input span {
    display: inline-grid;
    min-width: 74px;
    place-items: center;
    border-left: 1px solid var(--ow-line);
    background: #f8fafc;
    color: #64748b;
    font-size: 0.78rem;
    font-weight: 800;
}

.ow-select-field {
    min-height: 44px;
    padding: 0 12px;
}

.ow-professional-panel {
    gap: 12px;
}

.ow-professional-panel .ow-section-heading {
    align-items: start;
}

.ow-professional-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.ow-check-card {
    display: grid;
    gap: 12px;
    padding: 14px;
    color: #334155;
    transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease;
}

.ow-check-card-header,
.ow-check-card-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
}

.ow-check-card-header {
    justify-content: space-between;
}

.ow-check-card-toggle {
    min-width: 0;
    color: #334155;
    font-size: 0.9rem;
    font-weight: 750;
}

.ow-check-card-header small {
    color: #64748b;
    font-size: 0.76rem;
    font-weight: 700;
}

.ow-check-card-fields {
    display: grid;
    gap: 10px;
}

.ow-check-card-field {
    display: grid;
    gap: 6px;
}

.ow-check-card-field label {
    color: #475569;
    font-size: 0.76rem;
    font-weight: 800;
}

.ow-check-card-field input,
.ow-check-card-textarea {
    width: 100%;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
    color: var(--ow-ink);
    font-size: 0.9rem;
    outline: none;
}

.ow-check-card-field input {
    min-height: 40px;
    padding: 0 12px;
}

.ow-check-card-textarea {
    min-height: 96px;
    padding: 10px 12px;
    resize: vertical;
}

.ow-check-card-hint {
    margin: 0;
    color: #64748b;
    font-size: 0.78rem;
    line-height: 1.45;
}

.ow-check-card input[type="checkbox"],
.ow-template-days input {
    width: 16px;
    height: 16px;
    accent-color: var(--ow-accent);
}

.ow-check-card:has(input:checked) {
    border-color: rgba(37, 99, 235, 0.36);
    background: #f8fbff;
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.08);
}

.ow-empty-note {
    grid-column: 1 / -1;
    margin: 0;
    border: 1px dashed var(--ow-line);
    border-radius: 8px;
    padding: 18px;
    color: var(--ow-muted);
    font-size: 0.9rem;
}

.ow-advanced-stack {
    display: grid;
    gap: 10px;
}

.ow-advanced-section {
    overflow: visible;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
}

.ow-advanced-section summary {
    display: flex;
    min-height: 64px;
    cursor: pointer;
    list-style: none;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 16px;
    transition: background-color 150ms ease;
}

.ow-advanced-section summary::-webkit-details-marker {
    display: none;
}

.ow-advanced-section summary:hover {
    background: #f8fafc;
}

.ow-advanced-section summary span {
    display: grid;
    gap: 3px;
}

.ow-advanced-section summary strong {
    color: #0f172a;
    font-size: 0.95rem;
    font-weight: 800;
}

.ow-advanced-section summary small {
    color: #64748b;
    font-size: 0.82rem;
    line-height: 1.35;
}

.ow-advanced-section summary svg {
    width: 20px;
    height: 20px;
    flex: none;
    color: #94a3b8;
    transition: transform 150ms ease, color 150ms ease;
}

.ow-advanced-section[open] summary {
    border-bottom: 1px solid var(--ow-line);
    background: #f8fafc;
}

.ow-advanced-section[open] summary svg {
    transform: rotate(180deg);
    color: var(--ow-accent);
}

.ow-advanced-content {
    display: grid;
    gap: 18px;
    padding: 16px;
}

.ow-advanced-list {
    display: grid;
    overflow: visible;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
}

.ow-advanced-setting {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(150px, 190px);
    gap: 18px;
    align-items: center;
    border-bottom: 1px solid var(--ow-line);
    padding: 14px 16px;
}

.ow-advanced-setting:hover,
.ow-advanced-setting:focus-within {
    z-index: 10;
}

.ow-advanced-setting:last-child {
    border-bottom: 0;
}

.ow-advanced-setting.is-invalid {
    background: #fff7f7;
    box-shadow: inset 3px 0 0 #ef4444;
}

.ow-advanced-setting.is-invalid input,
.ow-advanced-setting.is-invalid select {
    border-color: #ef4444;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.12);
}

.ow-advanced-setting-copy {
    display: grid;
    gap: 4px;
}

.ow-advanced-setting-copy .ow-field-label {
    justify-content: flex-start;
}

.ow-advanced-setting-copy p {
    margin: 0;
    color: var(--ow-muted);
    font-size: 0.82rem;
    line-height: 1.4;
}

.ow-advanced-setting .ow-unit-input {
    width: 100%;
}

.ow-setting-grid-compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ow-subsection-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 16px;
    border-top: 1px solid var(--ow-line);
    padding-top: 16px;
}

.ow-subsection-heading strong {
    color: #0f172a;
    font-size: 0.95rem;
    font-weight: 800;
}

.ow-subsection-heading span {
    max-width: 520px;
    color: var(--ow-muted);
    font-size: 0.86rem;
    line-height: 1.45;
    text-align: right;
}

.ow-template-builder {
    display: grid;
    grid-template-columns: minmax(170px, 0.28fr) minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    padding: 12px;
}

.ow-template-builder strong {
    display: block;
    font-size: 0.92rem;
}

.ow-template-builder p {
    font-size: 0.82rem;
    line-height: 1.4;
}

.ow-template-main {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.ow-template-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: space-between;
}

.ow-template-days,
.ow-preset-row,
.ow-template-times,
.ow-day-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.ow-template-days label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border: 1px solid var(--ow-line);
    border-radius: 999px;
    background: #ffffff;
    padding: 5px 8px;
    color: #475569;
    font-size: 0.75rem;
    font-weight: 800;
}

.ow-preset-button,
.ow-primary-button,
.ow-secondary-button,
.ow-quiet-button,
.ow-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    font-weight: 800;
    transition: background-color 150ms ease, border-color 150ms ease, transform 150ms ease;
}

.ow-preset-button {
    min-height: 30px;
    border: 1px solid rgba(37, 99, 235, 0.22);
    background: #ffffff;
    color: #1d4ed8;
    padding: 0 9px;
    font-size: 0.74rem;
}

.ow-primary-button {
    min-height: 38px;
    border: 1px solid var(--ow-accent);
    background: var(--ow-accent);
    color: #ffffff;
    padding: 0 14px;
    font-size: 0.82rem;
}

.ow-secondary-button,
.ow-quiet-button {
    min-height: 34px;
    border: 1px solid var(--ow-line);
    background: #ffffff;
    color: #334155;
    padding: 0 11px;
    font-size: 0.78rem;
}

.ow-icon-button {
    width: 30px;
    height: 30px;
    border: 1px solid var(--ow-line);
    background: #ffffff;
    color: #64716d;
}

.ow-icon-button svg {
    width: 16px;
    height: 16px;
}

.ow-primary-button:hover,
.ow-secondary-button:hover,
.ow-quiet-button:hover,
.ow-preset-button:hover,
.ow-icon-button:hover {
    transform: translateY(-1px);
}

.ow-primary-button:hover {
    background: var(--ow-accent-strong);
    border-color: var(--ow-accent-strong);
}

.ow-quiet-button:hover,
.ow-secondary-button:hover,
.ow-preset-button:hover,
.ow-icon-button:hover {
    background: #f8fafc;
}

.ow-template-times {
    justify-content: flex-start;
    flex-wrap: nowrap;
}

.ow-template-times input,
.ow-window-row input[type="time"] {
    box-sizing: border-box;
    width: 104px;
    height: 40px;
    min-height: 40px;
    border-color: #d8dee8;
    background: #f8fafc;
    padding: 0 12px;
    color: #0f172a;
    font-family: inherit;
    font-size: 0.92rem;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.2;
}

.ow-template-times input::-webkit-date-and-time-value,
.ow-window-row input[type="time"]::-webkit-date-and-time-value {
    min-height: 1.2em;
    text-align: left;
}

.ow-template-times input::-webkit-datetime-edit,
.ow-window-row input[type="time"]::-webkit-datetime-edit,
.ow-template-times input::-webkit-datetime-edit-fields-wrapper,
.ow-window-row input[type="time"]::-webkit-datetime-edit-fields-wrapper {
    display: flex;
    height: 100%;
    align-items: center;
    padding: 0;
}

.ow-template-times span,
.ow-window-row span {
    color: var(--ow-muted);
    font-size: 0.76rem;
    font-weight: 700;
}

.ow-week-planner {
    display: grid;
    overflow: visible;
    background: #ffffff;
    gap: 2px;
}

.ow-hours-header,
.ow-day-row {
    display: grid;
    grid-template-columns: minmax(150px, 170px) fit-content(620px) max-content;
    column-gap: 6px;
}

.ow-hours-header {
    align-items: end;
    padding: 0 10px 6px;
    color: #0f172a;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.ow-day-row {
    row-gap: 6px;
    align-items: center;
    border: 0;
    border-bottom: 0;
    border-radius: 0;
    padding: 5px 10px;
}

.ow-day-name {
    display: flex;
    min-height: 36px;
    align-items: center;
}

.ow-day-name strong {
    color: #1f2937;
    font-size: 0.9rem;
    font-weight: 600;
}

.ow-day-state-input {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
}

.ow-day-actions {
    justify-content: flex-start;
    flex-wrap: nowrap;
    min-height: 36px;
}

.ow-window-list {
    display: flex;
    min-height: 36px;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.ow-day-row.is-empty .ow-window-list::before {
    content: "Sem horários";
    display: block;
    color: var(--ow-muted);
    font-size: 0.8rem;
    font-weight: 600;
}

.ow-window-row {
    display: flex;
    gap: 6px;
    align-items: center;
}

.ow-copy-menu {
    position: relative;
}

.ow-copy-menu summary {
    cursor: pointer;
    list-style: none;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
    padding: 7px 10px;
    color: #334155;
    font-size: 0.78rem;
    font-weight: 800;
}

.ow-copy-menu summary::-webkit-details-marker {
    display: none;
}

.ow-copy-menu > div {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    z-index: 30;
    display: grid;
    min-width: 230px;
    gap: 8px;
    border: 1px solid var(--ow-line);
    border-radius: 8px;
    background: #ffffff;
    padding: 12px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.14);
}

.ow-copy-menu label {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #334155;
    font-size: 0.84rem;
    font-weight: 700;
}

.ow-copy-all-button {
    display: inline-flex;
    min-height: 30px;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border: 0;
    background: transparent;
    color: var(--ow-accent);
    padding: 0 2px;
    font-size: 0.8rem;
    font-weight: 800;
}

.ow-copy-all-button svg {
    width: 18px;
    height: 18px;
}

.ow-link-copy-button {
    min-width: 104px;
}

.ow-form-actions {
    display: flex;
    justify-content: flex-end;
    padding-bottom: 24px;
}

.ow-link-box input:not(.ow-toggle-input):not([type="hidden"]):focus,
.ow-select-field:focus,
.ow-unit-input:focus-within,
.ow-template-times input:focus,
.ow-window-row input[type="time"]:focus,
.ow-info-tip-button:focus-visible,
.ow-preset-button:focus-visible,
.ow-primary-button:focus-visible,
.ow-secondary-button:focus-visible,
.ow-quiet-button:focus-visible,
.ow-icon-button:focus-visible,
.ow-copy-all-button:focus-visible,
.ow-copy-menu summary:focus-visible {
    outline: 3px solid rgba(37, 99, 235, 0.18);
    outline-offset: 2px;
}

.ow-advanced-section summary:focus-visible {
    outline: 3px solid rgba(37, 99, 235, 0.18);
    outline-offset: -3px;
}

@media (max-width: 1100px) {
    .ow-setting-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ow-setting-grid-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ow-template-builder,
    .ow-template-actions {
        grid-template-columns: 1fr;
    }

    .ow-template-times {
        justify-content: flex-start;
        flex-wrap: wrap;
    }
}

@media (max-width: 760px) {
    .ow-booking-status-panel,
    .ow-booking-onboarding,
    .ow-template-builder,
    .ow-link-box {
        grid-template-columns: 1fr;
    }

    .ow-section-heading {
        display: grid;
    }

    .ow-section-heading p {
        text-align: left;
    }

    .ow-link-actions {
        justify-content: stretch;
    }

    .ow-link-actions .ow-secondary-button,
    .ow-link-actions .ow-quiet-button {
        flex: 1 1 140px;
    }

    .ow-setting-grid,
    .ow-setting-grid-compact,
    .ow-professional-grid {
        grid-template-columns: 1fr;
    }

    .ow-setting-card-wide {
        grid-column: auto;
    }

    .ow-advanced-setting {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .ow-subsection-heading {
        display: grid;
    }

    .ow-subsection-heading span {
        text-align: left;
    }

    .ow-day-actions,
    .ow-template-times {
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .ow-day-row {
        grid-template-columns: 1fr;
        gap: 10px;
    }

    .ow-hours-header {
        display: none;
    }

    .ow-window-row {
        width: 100%;
    }

    .ow-window-row input[type="time"] {
        flex: 1 1 92px;
    }

    .ow-copy-menu > div {
        left: 0;
        right: auto;
    }
}

/* Public online booking calendar */
.ow-public-booking-page {
    min-height: 100vh;
    background: #f7f9fc;
    color: #0f172a;
    padding: 40px 18px;
}

.ow-public-booking-shell {
    display: grid;
    max-width: 1080px;
    margin: 0 auto;
    gap: 24px;
}

.ow-public-booking-header {
    max-width: 680px;
}

.ow-public-booking-header p,
.ow-public-pane-kicker {
    margin: 0;
    color: #2563eb;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ow-public-booking-header h1 {
    margin: 8px 0 0;
    color: #0f172a;
    font-size: clamp(2rem, 4vw, 3.25rem);
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1.05;
}

.ow-public-booking-header span {
    display: block;
    margin-top: 12px;
    color: #64748b;
    font-size: 1rem;
    line-height: 1.6;
}

.ow-public-error {
    border: 1px solid #fecaca;
    border-radius: 8px;
    background: #fef2f2;
    padding: 14px 16px;
    color: #991b1b;
    font-size: 0.9rem;
    font-weight: 700;
}

.ow-public-error span {
    display: block;
    margin-top: 4px;
    color: #b91c1c;
}

.ow-public-location {
    display: grid;
    grid-template-columns: minmax(340px, 1.35fr) minmax(0, 1fr);
    gap: 22px;
    align-items: stretch;
    max-width: 900px;
    border: 1px solid #dbe3ee;
    border-radius: 10px;
    background: #ffffff;
    padding: 14px;
    box-shadow: 0 16px 40px rgba(15, 23, 42, 0.05);
}

.ow-public-location-map {
    display: grid;
    min-height: 82px;
    place-items: center;
    overflow: hidden;
    border-radius: 8px;
    background:
        linear-gradient(90deg, rgba(148, 163, 184, 0.22) 1px, transparent 1px),
        linear-gradient(0deg, rgba(148, 163, 184, 0.2) 1px, transparent 1px),
        #f1f5f9;
    background-size: 18px 18px;
    color: #2563eb;
}

.ow-public-location-map svg {
    width: 34px;
    height: 34px;
    filter: drop-shadow(0 8px 16px rgba(37, 99, 235, 0.16));
}

.ow-public-location-map--interactive {
    min-height: 230px;
    background: #e2e8f0;
}

.ow-public-location-leaflet {
    width: 100%;
    height: 100%;
    min-height: 230px;
    border-radius: inherit;
}

.ow-public-location-leaflet[data-map-unavailable="true"] {
    display: grid;
    place-items: center;
}

.ow-public-location-leaflet[data-map-unavailable="true"]::before {
    content: "Mapa indisponível";
    color: #475569;
    font-size: 0.82rem;
    font-weight: 800;
}

.ow-public-location-leaflet .leaflet-control-attribution {
    font-size: 0.62rem;
}

.ow-public-location-body p {
    margin: 0 0 6px;
    color: #2563eb;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.ow-public-location address {
    display: grid;
    gap: 2px;
    color: #0f172a;
    font-size: 0.94rem;
    font-style: normal;
    font-weight: 700;
    line-height: 1.45;
}

.ow-public-location-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    color: #2563eb;
    font-size: 0.86rem;
    font-weight: 800;
    text-decoration: none;
}

.ow-public-location-link svg {
    width: 18px;
    height: 18px;
}

.ow-public-location-link:hover {
    color: #1d4ed8;
}

.ow-public-success-location {
    max-width: 900px;
    margin: 32px auto 0;
}

.ow-public-success-location .ow-public-location {
    width: 100%;
    margin: 0 auto;
}

.ow-public-location--contact-only {
    grid-template-columns: minmax(0, 1fr);
}

.ow-public-location-body {
    display: grid;
    align-content: start;
}

.ow-public-contact-block {
    display: grid;
    gap: 10px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid #e2e8f0;
}

.ow-public-contact-label {
    color: #64748b;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.ow-public-contact-number {
    color: #0f172a;
    font-size: 1.08rem;
    font-weight: 800;
}

.ow-public-contact-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.ow-public-contact-link {
    display: inline-flex;
    min-height: 40px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #eff6ff;
    color: #1d4ed8;
    padding: 0 14px;
    font-size: 0.84rem;
    font-weight: 800;
    text-decoration: none;
    transition: background-color 150ms ease, color 150ms ease;
}

.ow-public-contact-link:hover {
    background: #dbeafe;
    color: #1d4ed8;
}

.ow-public-contact-link--whatsapp {
    background: #ecfdf5;
    color: #047857;
}

.ow-public-contact-link--whatsapp:hover {
    background: #d1fae5;
    color: #047857;
}

.ow-public-booking-card {
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    background: #ffffff;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.06);
}

.ow-public-booking-form {
    display: grid;
    gap: 22px;
    padding: 24px;
}

.ow-public-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.ow-public-label {
    display: block;
    margin-bottom: 7px;
    color: #334155;
    font-size: 0.84rem;
    font-weight: 800;
}

.ow-public-field {
    width: 100%;
    min-height: 44px;
    border: 1px solid #dbe3ee;
    border-radius: 8px;
    background: #ffffff;
    color: #0f172a;
    font-size: 0.95rem;
    outline: none;
    padding: 0 12px;
}

textarea.ow-public-field {
    min-height: 92px;
    padding: 11px 12px;
    resize: vertical;
}

.ow-public-field:focus {
    border-color: #2563eb;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.14);
}

.ow-public-professional-profile {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: start;
    border: 1px solid #dbe3ee;
    border-radius: 10px;
    background: #f8fafc;
    padding: 18px;
}

.ow-public-professional-profile-avatar {
    width: 72px;
    height: 72px;
    overflow: hidden;
    border-radius: 18px;
    background: #e2e8f0;
}

.ow-public-professional-profile-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ow-public-professional-profile-body {
    min-width: 0;
}

.ow-public-professional-profile-body h2 {
    margin: 6px 0 0;
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 800;
}

.ow-public-professional-profile-position {
    display: inline-flex;
    margin-top: 8px;
    color: #1d4ed8;
    font-size: 0.84rem;
    font-weight: 800;
}

.ow-public-professional-profile-bio {
    margin: 10px 0 0;
    color: #475569;
    font-size: 0.9rem;
    line-height: 1.6;
    white-space: pre-line;
}

.ow-public-professional-profile[hidden],
.ow-public-professional-profile-avatar[hidden],
.ow-public-professional-profile-position[hidden],
.ow-public-professional-profile-bio[hidden] {
    display: none !important;
}

.ow-public-scheduler {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.78fr);
    gap: 34px;
    align-items: start;
    padding: 8px 0 4px;
}

.ow-public-calendar-pane,
.ow-public-slots-pane {
    min-width: 0;
}

.ow-public-slots-pane {
    min-height: 100%;
    border-left: 1px solid #e2e8f0;
    padding-left: 34px;
}

.ow-public-calendar-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.ow-public-calendar-toolbar h2,
.ow-public-slots-pane h2 {
    margin: 0;
    color: #0f172a;
    font-size: 1rem;
    font-weight: 800;
}

.ow-public-calendar-nav {
    display: inline-flex;
    gap: 8px;
}

.ow-public-calendar-nav button {
    display: inline-grid;
    width: 34px;
    height: 34px;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: #f1f5f9;
    color: #64748b;
    transition: background-color 150ms ease, color 150ms ease;
}

.ow-public-calendar-nav button:hover:not(:disabled) {
    background: #e2e8f0;
    color: #0f172a;
}

.ow-public-calendar-nav button:disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

.ow-public-calendar-nav svg {
    width: 20px;
    height: 20px;
}

.ow-public-weekdays,
.ow-public-calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
}

.ow-public-weekdays {
    margin-top: 28px;
    color: #64748b;
    font-size: 0.72rem;
    font-weight: 800;
    text-align: center;
}

.ow-public-calendar-grid {
    margin-top: 8px;
    font-size: 0.92rem;
}

.ow-public-calendar-cell {
    border-top: 1px solid #e5e7eb;
    padding: 8px 0;
}

.ow-public-calendar-cell:nth-child(-n + 7) {
    border-top: 0;
}

.ow-public-calendar-day {
    display: grid;
    width: 36px;
    height: 36px;
    margin: 0 auto;
    place-items: center;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: #0f172a;
    font-weight: 700;
    transition: background-color 150ms ease, color 150ms ease, transform 150ms ease;
}

.ow-public-calendar-day:hover:not(:disabled) {
    background: #eef2f7;
    transform: translateY(-1px);
}

.ow-public-calendar-day[data-selected="true"] {
    background: #0f172a;
    color: #ffffff;
}

.ow-public-calendar-day[data-today="true"]:not([data-selected="true"]) {
    color: #2563eb;
}

.ow-public-calendar-day:disabled {
    cursor: not-allowed;
    color: #cbd5e1;
}

.ow-public-calendar-day[data-outside-month="true"] {
    color: #d7dee8;
}

.ow-public-calendar-status,
.ow-public-slot-status,
.ow-public-calendar-empty,
.ow-public-slot-empty {
    margin: 14px 0 0;
    color: #64748b;
    font-size: 0.86rem;
    line-height: 1.5;
}

.ow-public-calendar-empty {
    grid-column: 1 / -1;
    border: 1px dashed #dbe3ee;
    border-radius: 8px;
    padding: 24px;
    text-align: center;
}

.ow-public-slots-pane h2 {
    margin-top: 6px;
    text-transform: none;
}

.ow-public-periods {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 20px;
}

.ow-public-period-button {
    min-height: 36px;
    border: 1px solid #dbe3ee;
    border-radius: 999px;
    background: #ffffff;
    color: #334155;
    padding: 0 14px;
    font-size: 0.85rem;
    font-weight: 800;
    transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease;
}

.ow-public-period-button:hover {
    background: #f8fafc;
}

.ow-public-period-button[aria-pressed="true"] {
    border-color: #0f172a;
    background: #0f172a;
    color: #ffffff;
}

.ow-public-slot-list {
    display: grid;
    gap: 8px;
    margin-top: 16px;
}

.ow-public-slot-card {
    display: flex;
    min-height: 54px;
    cursor: pointer;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    border-radius: 10px;
    padding: 8px 12px 8px 16px;
    color: #475569;
    transition: background-color 150ms ease, color 150ms ease, box-shadow 150ms ease;
}

.ow-public-slot-card:hover {
    background: #f1f5f9;
}

.ow-public-slot-card:has(input:checked) {
    background: #eff6ff;
    color: #1d4ed8;
    box-shadow: inset 0 0 0 1px rgba(37, 99, 235, 0.32);
}

.ow-public-slot-time {
    color: inherit;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0;
}

.ow-public-slot-radio {
    width: 18px;
    height: 18px;
    flex: none;
    accent-color: #2563eb;
}

.ow-public-show-more-slots {
    min-height: 42px;
    border: 1px solid #dbe3ee;
    border-radius: 10px;
    background: #ffffff;
    color: #334155;
    font-size: 0.86rem;
    font-weight: 800;
    transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease;
}

.ow-public-show-more-slots:hover {
    border-color: #cbd5e1;
    background: #f8fafc;
    color: #1e293b;
}

.ow-public-slot-status.is-error {
    color: #b91c1c;
    font-weight: 800;
}

.ow-public-submit {
    width: 100%;
    min-height: 48px;
    border: 0;
    border-radius: 8px;
    background: #2563eb;
    color: #ffffff;
    font-size: 0.95rem;
    font-weight: 800;
    transition: background-color 150ms ease, transform 150ms ease;
}

.ow-public-submit:hover {
    background: #1d4ed8;
    transform: translateY(-1px);
}

.ow-public-powered-by {
    display: flex;
    justify-content: center;
    margin: 20px auto 0;
    color: #64748b;
    font-size: 0.82rem;
}

.ow-public-powered-by a {
    color: inherit;
    text-decoration: none;
    transition: color 150ms ease;
}

.ow-public-powered-by a:hover {
    color: #2563eb;
}

.ow-public-powered-by strong {
    color: #1e408a;
    font-weight: 800;
}

.ow-public-calendar-day:focus-visible,
.ow-public-calendar-nav button:focus-visible,
.ow-public-period-button:focus-visible,
.ow-public-slot-radio:focus-visible,
.ow-public-show-more-slots:focus-visible,
.ow-public-submit:focus-visible,
.ow-public-contact-link:focus-visible,
.ow-public-location-link:focus-visible,
.ow-public-powered-by a:focus-visible {
    outline: 3px solid rgba(37, 99, 235, 0.2);
    outline-offset: 3px;
}

@media (max-width: 860px) {
    .ow-public-booking-page {
        padding: 28px 14px;
    }

    .ow-public-booking-form {
        padding: 18px;
    }

    .ow-public-form-grid,
    .ow-public-professional-profile,
    .ow-public-scheduler {
        grid-template-columns: 1fr;
    }

    .ow-public-scheduler {
        gap: 26px;
    }

    .ow-public-professional-profile-avatar {
        width: 64px;
        height: 64px;
    }

    .ow-public-slots-pane {
        border-top: 1px solid #e2e8f0;
        border-left: 0;
        padding-top: 24px;
        padding-left: 0;
    }

    .ow-public-location {
        grid-template-columns: 1fr;
    }

    .ow-public-location-map {
        min-height: 76px;
    }

    .ow-public-location-map--interactive,
    .ow-public-location-leaflet {
        min-height: 220px;
    }

    .ow-public-calendar-day {
        width: 34px;
        height: 34px;
    }
}
