/*!******************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./node_modules/@puckeditor/core/dist/index.css ***!
  \******************************************************************************************************************************************************************************************************************************************************************************************/
@import "https://rsms.me/inter/inter.css";

/* styles/color.css */
:root {
  --puck-color-rose-01: #4a001c;
  --puck-color-rose-02: #670833;
  --puck-color-rose-03: #87114c;
  --puck-color-rose-04: #a81a66;
  --puck-color-rose-05: #bc5089;
  --puck-color-rose-06: #cc7ca5;
  --puck-color-rose-07: #d89aba;
  --puck-color-rose-08: #e3b8cf;
  --puck-color-rose-09: #efd6e3;
  --puck-color-rose-10: #f6eaf1;
  --puck-color-rose-11: #faf4f8;
  --puck-color-rose-12: #fef8fc;
  --puck-color-azure-01: #00175d;
  --puck-color-azure-02: #002c77;
  --puck-color-azure-03: #014292;
  --puck-color-azure-04: #0158ad;
  --puck-color-azure-05: #3479be;
  --puck-color-azure-06: #6499cf;
  --puck-color-azure-07: #88b0da;
  --puck-color-azure-08: #abc7e5;
  --puck-color-azure-09: #cfdff0;
  --puck-color-azure-10: #e7eef7;
  --puck-color-azure-11: #f3f6fb;
  --puck-color-azure-12: #f7faff;
  --puck-color-green-01: #002000;
  --puck-color-green-02: #043604;
  --puck-color-green-03: #084e08;
  --puck-color-green-04: #0c680c;
  --puck-color-green-05: #1d882f;
  --puck-color-green-06: #2faa53;
  --puck-color-green-07: #56c16f;
  --puck-color-green-08: #7dd78b;
  --puck-color-green-09: #b8e8bf;
  --puck-color-green-10: #ddf3e0;
  --puck-color-green-11: #eff8f0;
  --puck-color-green-12: #f3fcf4;
  --puck-color-yellow-01: #211000;
  --puck-color-yellow-02: #362700;
  --puck-color-yellow-03: #4c4000;
  --puck-color-yellow-04: #645a00;
  --puck-color-yellow-05: #877614;
  --puck-color-yellow-06: #ab9429;
  --puck-color-yellow-07: #bfac4e;
  --puck-color-yellow-08: #d4c474;
  --puck-color-yellow-09: #e6deb1;
  --puck-color-yellow-10: #f3efd9;
  --puck-color-yellow-11: #f9f7ed;
  --puck-color-yellow-12: #fcfaf0;
  --puck-color-red-01: #4c0000;
  --puck-color-red-02: #6a0a10;
  --puck-color-red-03: #8a1422;
  --puck-color-red-04: #ac1f35;
  --puck-color-red-05: #bf5366;
  --puck-color-red-06: #ce7e8e;
  --puck-color-red-07: #d99ca8;
  --puck-color-red-08: #e4b9c2;
  --puck-color-red-09: #efd7db;
  --puck-color-red-10: #f6eaec;
  --puck-color-red-11: #faf4f5;
  --puck-color-red-12: #fff9fa;
  --puck-color-grey-01: #181818;
  --puck-color-grey-02: #292929;
  --puck-color-grey-03: #404040;
  --puck-color-grey-04: #5a5a5a;
  --puck-color-grey-05: #767676;
  --puck-color-grey-06: #949494;
  --puck-color-grey-07: #ababab;
  --puck-color-grey-08: #c3c3c3;
  --puck-color-grey-09: #dcdcdc;
  --puck-color-grey-10: #efefef;
  --puck-color-grey-11: #f5f5f5;
  --puck-color-grey-12: #fafafa;
  --puck-color-black: #000000;
  --puck-color-white: #ffffff;
}

/* styles/typography.css */
:root {
  --puck-font-size-scale-base-unitless: 12;
  --puck-font-size-xxxs-unitless: 12;
  --puck-font-size-xxs-unitless: 14;
  --puck-font-size-xs-unitless: 16;
  --puck-font-size-s-unitless: 18;
  --puck-font-size-m-unitless: 21;
  --puck-font-size-l-unitless: 24;
  --puck-font-size-xl-unitless: 28;
  --puck-font-size-xxl-unitless: 36;
  --puck-font-size-xxxl-unitless: 48;
  --puck-font-size-xxxxl-unitless: 56;
  --puck-font-size-xxxs: calc(1rem * var(--puck-font-size-xxxs-unitless) / 16);
  --puck-font-size-xxs: calc(1rem * var(--puck-font-size-xxs-unitless) / 16);
  --puck-font-size-xs: calc(1rem * var(--puck-font-size-xs-unitless) / 16);
  --puck-font-size-s: calc(1rem * var(--puck-font-size-s-unitless) / 16);
  --puck-font-size-m: calc(1rem * var(--puck-font-size-m-unitless) / 16);
  --puck-font-size-l: calc(1rem * var(--puck-font-size-l-unitless) / 16);
  --puck-font-size-xl: calc(1rem * var(--puck-font-size-xl-unitless) / 16);
  --puck-font-size-xxl: calc(1rem * var(--puck-font-size-xxl-unitless) / 16);
  --puck-font-size-xxxl: calc(1rem * var(--puck-font-size-xxxl-unitless) / 16);
  --puck-font-size-xxxxl: calc( 1rem * var(--puck-font-size-xxxxl-unitless) / 16 );
  --puck-font-size-base: var(--puck-font-size-xs);
  --line-height-reset: 1;
  --line-height-xs: calc( var(--space-m-unitless) / var(--puck-font-size-m-unitless) );
  --line-height-s: calc( var(--space-m-unitless) / var(--puck-font-size-s-unitless) );
  --line-height-m: calc( var(--space-m-unitless) / var(--puck-font-size-xs-unitless) );
  --line-height-l: calc( var(--space-m-unitless) / var(--puck-font-size-xxs-unitless) );
  --line-height-xl: calc( var(--space-m-unitless) / var(--puck-font-size-scale-base-unitless) );
  --line-height-base: var(--line-height-m);
  --fallback-font-stack:
    -apple-system,
    BlinkMacSystemFont,
    Segoe UI,
    Helvetica Neue,
    sans-serif,
    Apple Color Emoji,
    Segoe UI Emoji,
    Segoe UI Symbol;
  --puck-font-family: Inter, var(--fallback-font-stack);
  --puck-font-family-monospaced:
    ui-monospace,
    "Cascadia Code",
    "Source Code Pro",
    Menlo,
    Consolas,
    "DejaVu Sans Mono",
    monospace;
}
@supports (font-variation-settings: normal) {
  :root {
    --puck-font-family: InterVariable, var(--fallback-font-stack);
  }
}

/* bundle/core.css */
#frame-root {
  height: 1px;
  min-height: 100vh;
}
[data-puck-entry] {
  position: relative;
  z-index: 0;
}

/* bundle/index.css */

/* css-module:/home/runner/work/puck/puck/packages/core/components/ActionBar/styles.module.css/#css-module-data */
._ActionBar_1nmyk_1 {
  align-items: center;
  cursor: default;
  display: flex;
  width: auto;
  padding: 4px;
  -webkit-padding-start: 0;
          padding-inline-start: 0;
  -webkit-padding-end: 0;
          padding-inline-end: 0;
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
  border-radius: 8px;
  background: var(--puck-color-grey-01);
  color: var(--puck-color-white);
  font-family: var(--puck-font-family);
  min-height: 26px;
}
._ActionBar-label_1nmyk_18 {
  color: var(--puck-color-grey-08);
  font-size: var(--puck-font-size-xxxs);
  font-weight: 500;
  -webkit-padding-start: 8px;
          padding-inline-start: 8px;
  -webkit-padding-end: 8px;
          padding-inline-end: 8px;
  -webkit-margin-start: 4px;
          margin-inline-start: 4px;
  -webkit-margin-end: 4px;
          margin-inline-end: 4px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._ActionBarAction_1nmyk_30 + ._ActionBar-label_1nmyk_18 {
  -webkit-padding-start: 0;
          padding-inline-start: 0;
}
._ActionBar-label_1nmyk_18 + ._ActionBarAction_1nmyk_30 {
  -webkit-margin-start: -4px;
          margin-inline-start: -4px;
}
._ActionBar-group_1nmyk_38 {
  align-items: center;
  -webkit-border-start: 0.5px solid var(--puck-color-grey-05);
          border-inline-start: 0.5px solid var(--puck-color-grey-05);
  display: flex;
  height: 100%;
  -webkit-padding-start: 4px;
          padding-inline-start: 4px;
  -webkit-padding-end: 4px;
          padding-inline-end: 4px;
}
._ActionBar-group_1nmyk_38:first-of-type {
  -webkit-border-start: 0;
          border-inline-start: 0;
}
._ActionBar-group_1nmyk_38:empty {
  display: none;
}
._ActionBarAction_1nmyk_30 {
  background: transparent;
  border: none;
  color: var(--puck-color-grey-08);
  cursor: pointer;
  padding: 6px;
  -webkit-margin-start: 4px;
          margin-inline-start: 4px;
  -webkit-margin-end: 4px;
          margin-inline-end: 4px;
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 50ms ease-in;
}
._ActionBarAction--disabled_1nmyk_71 {
  cursor: auto;
  color: var(--puck-color-grey-06);
}
._ActionBarAction_1nmyk_30 svg {
  max-width: none !important;
}
._ActionBarAction_1nmyk_30:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: -2px;
}
@media (hover: hover) and (pointer: fine) {
  ._ActionBarAction_1nmyk_30:hover:not(._ActionBarAction--disabled_1nmyk_71) {
    color: var(--puck-color-azure-06);
    transition: none;
  }
}
._ActionBarAction_1nmyk_30:active:not(._ActionBarAction--disabled_1nmyk_71),
._ActionBarAction--active_1nmyk_93 {
  color: var(--puck-color-azure-07);
  transition: none;
}
._ActionBar-group_1nmyk_38 * {
  margin: 0;
}
._ActionBar-separator_1nmyk_102 {
  background: var(--puck-color-grey-05);
  margin-inline: 4px;
  width: 0.5px;
  height: 100%;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/AutoField/styles.module.css/#css-module-data */
._InputWrapper_bsxfo_1 + ._InputWrapper_bsxfo_1 {
  margin-top: 12px;
}
._Input-label_bsxfo_5 {
  align-items: center;
  color: var(--puck-color-grey-04);
  display: flex;
  padding-bottom: 12px;
  font-size: var(--puck-font-size-xxs);
  font-weight: 600;
}
._Input-labelIcon_bsxfo_14 {
  color: var(--puck-color-grey-07);
  display: flex;
  -webkit-margin-end: 4px;
          margin-inline-end: 4px;
  -webkit-padding-start: 4px;
          padding-inline-start: 4px;
}
._Input-disabledIcon_bsxfo_21 {
  color: var(--puck-color-grey-05);
  -webkit-margin-start: auto;
          margin-inline-start: auto;
}
._Input-input_bsxfo_26 {
  background: var(--puck-color-white);
  border-width: 1px;
  border-style: solid;
  border-color: var(--puck-color-grey-09);
  border-radius: 4px;
  box-sizing: border-box;
  font-family: inherit;
  font-size: 16px;
  padding: 12px 15px;
  transition: border-color 50ms ease-in;
  width: 100%;
  max-width: 100%;
}
@media (min-width: 458px) {
  ._Input-input_bsxfo_26 {
    font-size: 14px;
  }
}
select._Input-input_bsxfo_26 {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100' fill='%23c3c3c3'><polygon points='0,0 100,0 50,50'/></svg>") no-repeat;
  background-size: 12px;
  background-position: calc(100% - 12px) calc(50% + 3px);
  background-repeat: no-repeat;
  background-color: var(--puck-color-white);
  cursor: pointer;
}
select._Input-input_bsxfo_26:dir(rtl) {
  background-position: 12px calc(50% + 3px);
}
@media (hover: hover) and (pointer: fine) {
  ._Input_bsxfo_1:has(> input):hover ._Input-input_bsxfo_26:not([readonly]),
  ._Input_bsxfo_1:has(> textarea):hover ._Input-input_bsxfo_26:not([readonly]) {
    border-color: var(--puck-color-grey-05);
    transition: none;
  }
  ._Input_bsxfo_1:has(> select):hover ._Input-input_bsxfo_26:not([disabled]) {
    background-color: var(--puck-color-azure-12);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100' fill='%235a5a5a'><polygon points='0,0 100,0 50,50'/></svg>");
    border-color: var(--puck-color-grey-05);
    transition: none;
  }
}
._Input-input_bsxfo_26:focus {
  border-color: var(--puck-color-grey-05);
  outline: 2px solid var(--puck-color-azure-05);
  transition: none;
}
._Input--readOnly_bsxfo_82 > ._Input-input_bsxfo_26,
._Input--readOnly_bsxfo_82 > select._Input-input_bsxfo_26 {
  background-color: var(--puck-color-grey-11);
  border-color: var(--puck-color-grey-09);
  color: var(--puck-color-grey-04);
  cursor: default;
  opacity: 1;
  outline: 0;
  transition: none;
}
._Input-radioGroupItems_bsxfo_93 {
  display: flex;
  border: 1px solid var(--puck-color-grey-09);
  border-radius: 4px;
  flex-wrap: wrap;
}
._Input-radio_bsxfo_93 {
  -webkit-border-end: 1px solid var(--puck-color-grey-09);
          border-inline-end: 1px solid var(--puck-color-grey-09);
  flex-grow: 1;
}
._Input-radio_bsxfo_93:first-of-type {
  border-bottom-left-radius: 4px;
  border-top-left-radius: 4px;
}
._Input-radio_bsxfo_93:first-of-type ._Input-radioInner_bsxfo_110 {
  border-bottom-left-radius: 3px;
  border-top-left-radius: 3px;
}
._Input-radio_bsxfo_93:last-of-type {
  border-bottom-right-radius: 4px;
  -webkit-border-end: 0;
          border-inline-end: 0;
  border-top-right-radius: 4px;
}
._Input-radio_bsxfo_93:last-of-type ._Input-radioInner_bsxfo_110 {
  border-bottom-right-radius: 3px;
  border-top-right-radius: 3px;
}
._Input-radioInner_bsxfo_110 {
  background-color: var(--puck-color-white);
  color: var(--puck-color-grey-04);
  cursor: pointer;
  font-size: var(--puck-font-size-xxxs);
  padding: 8px 12px;
  text-align: center;
  transition: background-color 50ms ease-in;
}
._Input-radio_bsxfo_93:has(:focus-visible) {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
  position: relative;
}
@media (hover: hover) and (pointer: fine) {
  ._Input-radioInner_bsxfo_110:hover {
    background-color: var(--puck-color-azure-12);
    transition: none;
  }
}
._Input--readOnly_bsxfo_82 ._Input-radioInner_bsxfo_110 {
  background-color: var(--puck-color-white);
  color: var(--puck-color-grey-04);
  cursor: default;
}
._Input-radio_bsxfo_93 ._Input-radioInput_bsxfo_155:checked ~ ._Input-radioInner_bsxfo_110 {
  background-color: var(--puck-color-azure-11);
  color: var(--puck-color-azure-04);
  font-weight: 500;
}
._Input--readOnly_bsxfo_82 ._Input-radioInput_bsxfo_155:checked ~ ._Input-radioInner_bsxfo_110 {
  background-color: var(--puck-color-grey-11);
  color: var(--puck-color-grey-04);
}
._Input-radio_bsxfo_93 ._Input-radioInput_bsxfo_155 {
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
          clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}
textarea._Input-input_bsxfo_26 {
  margin-bottom: -4px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/AutoField/fields/ArrayField/styles.module.css/#css-module-data */
._ArrayField_1vaho_5 {
  display: flex;
  flex-direction: column;
  background: var(--puck-color-azure-11);
  border: 1px solid var(--puck-color-grey-09);
  border-radius: 4px;
}
._ArrayField--isDraggingFrom_1vaho_13 {
  background-color: var(--puck-color-azure-11);
  overflow: hidden;
}
._ArrayField-addButton_1vaho_18 {
  background-color: var(--puck-color-white);
  border: none;
  border-radius: 3px;
  display: flex;
  color: var(--puck-color-azure-05);
  justify-content: center;
  cursor: pointer;
  width: 100%;
  margin: 0;
  padding: 14px;
  text-align: left;
  transition: background-color 50ms ease-in;
}
._ArrayField--hasItems_1vaho_33 > ._ArrayField-addButton_1vaho_18 {
  border-top: 1px solid var(--puck-color-grey-09);
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
._ArrayField-addButton_1vaho_18:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
  position: relative;
}
@media (hover: hover) and (pointer: fine) {
  ._ArrayField_1vaho_5:not(._ArrayField--isDraggingFrom_1vaho_13) > ._ArrayField-addButton_1vaho_18:hover {
    background: var(--puck-color-azure-12);
    color: var(--puck-color-azure-04);
    transition: none;
  }
}
._ArrayField_1vaho_5:not(._ArrayField--isDraggingFrom_1vaho_13) > ._ArrayField-addButton_1vaho_18:active {
  background: var(--puck-color-azure-11);
  color: var(--puck-color-azure-04);
  transition: none;
}
._ArrayField-inner_1vaho_59 {
  margin-top: -1px;
}
._ArrayFieldItem_1vaho_67 {
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  display: block;
  position: relative;
}
._ArrayFieldItem_1vaho_67 {
  border-top: 1px solid var(--puck-color-grey-09);
}
._ArrayFieldItem--isDragging_1vaho_78 {
  border-top: transparent;
}
._ArrayFieldItem--isExpanded_1vaho_82::before {
  display: none;
}
._ArrayFieldItem--isExpanded_1vaho_82 {
  border-bottom: 0;
  outline-offset: 0px !important;
  outline: 1px solid var(--puck-color-azure-07) !important;
  z-index: 2;
}
._ArrayFieldItem--isDragging_1vaho_78 {
  outline: 2px var(--puck-color-azure-09) solid !important;
}
._ArrayFieldItem--isDragging_1vaho_78 ._ArrayFieldItem-summary_1vaho_97:active {
  background-color: var(--puck-color-white);
}
._ArrayFieldItem_1vaho_67 + ._ArrayFieldItem_1vaho_67 {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
._ArrayFieldItem-summary_1vaho_97 {
  background: var(--puck-color-white);
  color: var(--puck-color-grey-04);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 2px;
  justify-content: space-between;
  font-size: var(--puck-font-size-xxs);
  list-style: none;
  padding: 12px 15px;
  position: relative;
  overflow: hidden;
  transition: background-color 50ms ease-in;
}
._ArrayFieldItem--noFields_1vaho_122 > ._ArrayFieldItem-summary_1vaho_97 {
  cursor: -webkit-grab;
  cursor: grab;
}
._ArrayFieldItem_1vaho_67:first-of-type > ._ArrayFieldItem-summary_1vaho_97 {
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
}
._ArrayField--addDisabled_1vaho_131 > ._ArrayField-inner_1vaho_59 > ._ArrayFieldItem_1vaho_67:last-of-type:not(._ArrayFieldItem--isExpanded_1vaho_82) > ._ArrayFieldItem-summary_1vaho_97 {
  border-bottom-left-radius: 3px;
  border-bottom-right-radius: 3px;
}
._ArrayField--addDisabled_1vaho_131 > ._ArrayField-inner_1vaho_59 > ._ArrayFieldItem--isExpanded_1vaho_82:last-of-type {
  border-bottom-left-radius: 3px;
  border-bottom-right-radius: 3px;
}
._ArrayFieldItem-summary_1vaho_97:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  ._ArrayFieldItem-summary_1vaho_97:hover {
    background-color: var(--puck-color-azure-12);
    transition: none;
  }
}
._ArrayFieldItem-summary_1vaho_97:active {
  background-color: var(--puck-color-azure-11);
  transition: none;
}
._ArrayFieldItem--isExpanded_1vaho_82 > ._ArrayFieldItem-summary_1vaho_97 {
  background: var(--puck-color-azure-11);
  color: var(--puck-color-azure-04);
  font-weight: 600;
  transition: none;
}
._ArrayFieldItem-body_1vaho_170 {
  background: var(--puck-color-white);
  display: none;
}
._ArrayFieldItem--isExpanded_1vaho_82 > ._ArrayFieldItem-body_1vaho_170 {
  display: block;
}
._ArrayFieldItem-fieldset_1vaho_179 {
  border: none;
  border-top: 1px solid var(--puck-color-grey-09);
  margin: 0;
  min-width: 0;
  padding: 16px 15px;
}
._ArrayFieldItem-rhs_1vaho_187 {
  display: flex;
  gap: 4px;
  align-items: center;
}
._ArrayFieldItem-actions_1vaho_193 {
  color: var(--puck-color-grey-04);
  display: flex;
  gap: 4px;
  opacity: 0;
}
._ArrayFieldItem-summary_1vaho_97:focus-within > ._ArrayFieldItem-rhs_1vaho_187 > ._ArrayFieldItem-actions_1vaho_193,
._ArrayFieldItem-summary_1vaho_97:hover > ._ArrayFieldItem-rhs_1vaho_187 > ._ArrayFieldItem-actions_1vaho_193 {
  opacity: 1;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/IconButton/IconButton.module.css/#css-module-data */
._IconButton_ffob9_1 {
  align-items: center;
  background: transparent;
  border: none;
  border-radius: 4px;
  color: currentColor;
  display: flex;
  font-family: var(--puck-font-family);
  justify-content: center;
  padding: 4px;
  transition: background-color 50ms ease-in, color 50ms ease-in;
}
._IconButton--active_ffob9_14 {
  color: var(--puck-color-azure-04);
}
._IconButton_ffob9_1:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: -2px;
}
@media (hover: hover) and (pointer: fine) {
  ._IconButton_ffob9_1:hover:not(._IconButton--disabled_ffob9_24) {
    background: var(--puck-color-grey-10);
    color: var(--puck-color-azure-04);
    cursor: pointer;
    transition: none;
  }
}
._IconButton_ffob9_1:active {
  background: var(--puck-color-azure-11);
  transition: none;
}
._IconButton-title_ffob9_37 {
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
          clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}
._IconButton--disabled_ffob9_24 {
  color: var(--puck-color-grey-07);
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Loader/styles.module.css/#css-module-data */
@keyframes _loader-animation_nacdm_1 {
  0% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(180deg) scale(0.8);
  }
  100% {
    transform: rotate(360deg) scale(1);
  }
}
._Loader_nacdm_13 {
  background: transparent;
  border-radius: 100%;
  border: 2px solid currentColor;
  border-bottom-color: transparent;
  display: inline-block;
  animation: _loader-animation_nacdm_1 1s 0s infinite linear;
  animation-fill-mode: both;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/DragIcon/styles.module.css/#css-module-data */
._DragIcon_17p8x_1 {
  color: var(--puck-color-grey-05);
  cursor: -webkit-grab;
  cursor: grab;
  padding: 4px;
  border-radius: 4px;
}
._DragIcon--disabled_17p8x_8 {
  cursor: no-drop;
}
@media (hover: hover) and (pointer: fine) {
  ._DragIcon_17p8x_1:not(._DragIcon--disabled_17p8x_8):hover {
    color: var(--puck-color-azure-05);
    background-color: var(--puck-color-azure-12);
  }
}

/* components/Sortable/styles.css */
[data-dnd-placeholder] * {
  opacity: 0 !important;
}
[data-dnd-placeholder] {
  background: var(--puck-color-azure-09) !important;
  border: none !important;
  color: #00000000 !important;
  opacity: 0.3 !important;
  outline: none !important;
  transition: none !important;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/ExternalInput/styles.module.css/#css-module-data */
._ExternalInput-actions_91ls0_1 {
  display: flex;
}
._ExternalInput-button_91ls0_5 {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  background-color: var(--puck-color-white);
  border: 1px solid var(--puck-color-grey-09);
  border-radius: 4px;
  color: var(--puck-color-azure-04);
  padding: 12px 16px;
  font-weight: 500;
  white-space: nowrap;
  text-overflow: ellipsis;
  transition: background-color 50ms ease-in;
  position: relative;
  overflow: hidden;
  flex-grow: 1;
}
._ExternalInput--dataSelected_91ls0_24 ._ExternalInput-button_91ls0_5 {
  color: var(--puck-color-grey-03);
  display: block;
  border-top-right-radius: 0px;
  border-bottom-right-radius: 0px;
}
._ExternalInput--readOnly_91ls0_31 ._ExternalInput-button_91ls0_5 {
  background-color: var(--puck-color-grey-11);
}
._ExternalInput-detachButton_91ls0_35 {
  border: 1px solid var(--puck-color-grey-09);
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
  background-color: var(--puck-color-grey-12);
  color: var(--puck-color-grey-05);
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  position: relative;
  transition: background-color 50ms ease-in, color 50ms ease-in;
  -webkit-margin-start: -1px;
          margin-inline-start: -1px;
}
._ExternalInput-button_91ls0_5:focus-visible,
._ExternalInput-detachButton_91ls0_35:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
  z-index: 1;
}
@media (hover: hover) and (pointer: fine) {
  ._ExternalInput_91ls0_1:not(._ExternalInput--readOnly_91ls0_31) ._ExternalInput-button_91ls0_5:hover,
  ._ExternalInput_91ls0_1:not(._ExternalInput--readOnly_91ls0_31) ._ExternalInput-detachButton_91ls0_35:hover {
    background: var(--puck-color-azure-12);
    transition: none;
  }
  ._ExternalInput_91ls0_1:not(._ExternalInput--readOnly_91ls0_31) ._ExternalInput-detachButton_91ls0_35:hover {
    color: var(--puck-color-azure-04);
  }
}
._ExternalInput_91ls0_1:not(._ExternalInput--readOnly_91ls0_31) ._ExternalInput-button_91ls0_5:active,
._ExternalInput_91ls0_1:not(._ExternalInput--readOnly_91ls0_31) ._ExternalInput-detachButton_91ls0_35:active {
  background: var(--puck-color-azure-11);
  transition: none;
}
._ExternalInputModal_91ls0_79 {
  color: var(--puck-color-black);
  display: grid;
  grid-template-rows: min-content minmax(128px, 100%) min-content;
  grid-template-columns: 100%;
  position: relative;
  min-height: 50dvh;
  max-height: 90dvh;
}
._ExternalInputModal-grid_91ls0_89 {
  display: flex;
  flex-direction: column;
}
@media (min-width: 458px) {
  ._ExternalInputModal-grid_91ls0_89 {
    display: grid;
    grid-template-columns: 100%;
  }
  ._ExternalInputModal--filtersToggled_91ls0_100 ._ExternalInputModal-grid_91ls0_89 {
    grid-template-columns: 25% 75%;
  }
}
._ExternalInputModal-filters_91ls0_105 {
  border-bottom: 1px solid var(--puck-color-grey-09);
}
._ExternalInputModal--filtersToggled_91ls0_100 ._ExternalInputModal-filters_91ls0_105 {
  display: none;
}
@media (min-width: 458px) {
  ._ExternalInputModal-filters_91ls0_105 {
    -webkit-border-end: 1px solid var(--puck-color-grey-09);
            border-inline-end: 1px solid var(--puck-color-grey-09);
    display: none;
  }
  ._ExternalInputModal--filtersToggled_91ls0_100 ._ExternalInputModal-filters_91ls0_105 {
    display: block;
  }
}
._ExternalInputModal-masthead_91ls0_124 {
  background-color: var(--puck-color-grey-12);
  border-bottom: 1px solid var(--puck-color-grey-09);
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  padding: 24px;
}
._ExternalInputModal-tableWrapper_91ls0_133 {
  position: relative;
  overflow-x: auto;
  overflow-y: auto;
  flex-grow: 1;
}
._ExternalInputModal-table_91ls0_133 {
  border-collapse: unset;
  border-spacing: 0px;
  color: var(--puck-color-grey-02);
  position: relative;
  z-index: 0;
  min-width: 100%;
}
._ExternalInputModal-thead_91ls0_149 {
  background-color: var(--puck-color-white);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 1;
}
._ExternalInputModal-th_91ls0_149 {
  border-bottom: 1px solid var(--puck-color-grey-09);
  color: var(--puck-color-grey-04);
  font-weight: 500;
  font-size: 14px;
  padding: 16px 24px;
}
._ExternalInputModal-td_91ls0_164 {
  border-bottom: 1px solid var(--puck-color-grey-10);
  padding: 16px 24px;
}
._ExternalInputModal-tr_91ls0_169 ._ExternalInputModal-td_91ls0_164:first-of-type {
  font-weight: 500;
  width: 1%;
  white-space: nowrap;
}
@media (hover: hover) and (pointer: fine) {
  ._ExternalInputModal-tbody_91ls0_176 ._ExternalInputModal-tr_91ls0_169:hover {
    background: var(--puck-color-azure-12);
    color: var(--puck-color-azure-04);
    cursor: pointer;
    position: relative;
    -webkit-margin-start: -5px;
            margin-inline-start: -5px;
  }
  ._ExternalInputModal-tbody_91ls0_176 ._ExternalInputModal-tr_91ls0_169:hover ._ExternalInputModal-td_91ls0_164:first-of-type {
    -webkit-border-start: 4px solid var(--puck-color-azure-04);
            border-inline-start: 4px solid var(--puck-color-azure-04);
    -webkit-padding-start: 20px;
            padding-inline-start: 20px;
  }
}
._ExternalInputModal-tbody_91ls0_176 ._ExternalInputModal-tr_91ls0_169:last-of-type ._ExternalInputModal-td_91ls0_164 {
  border-bottom: none;
}
._ExternalInputModal-tableWrapper_91ls0_133 {
  display: none;
}
._ExternalInputModal--hasData_91ls0_202 ._ExternalInputModal-tableWrapper_91ls0_133 {
  display: block;
}
._ExternalInputModal-loadingBanner_91ls0_206 {
  display: none;
  background-color: color-mix(in srgb, var(--puck-color-white) 90%, transparent);
  padding: 64px;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
._ExternalInputModal--isLoading_91ls0_223 ._ExternalInputModal-loadingBanner_91ls0_206 {
  display: flex;
}
._ExternalInputModal-searchForm_91ls0_227 {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  flex-grow: 1;
}
@media (min-width: 458px) {
  ._ExternalInputModal-searchForm_91ls0_227 {
    flex-wrap: nowrap;
  }
}
._ExternalInputModal-search_91ls0_227 {
  display: flex;
  background: var(--puck-color-white);
  border-width: 1px;
  border-style: solid;
  border-color: var(--puck-color-grey-09);
  border-radius: 4px;
  flex-grow: 1;
  transition: border-color 50ms ease-in;
}
._ExternalInputModal-search_91ls0_227:focus-within {
  border-color: var(--puck-color-grey-05);
  outline: 2px solid var(--puck-color-azure-05);
  transition: none;
}
@media (hover: hover) and (pointer: fine) {
  ._ExternalInputModal-search_91ls0_227:hover {
    border-color: var(--puck-color-grey-05);
    transition: none;
  }
}
._ExternalInputModal-searchIcon_91ls0_264 {
  align-items: center;
  background: var(--puck-color-grey-12);
  border-bottom-left-radius: 4px;
  border-top-left-radius: 4px;
  -webkit-border-end: 1px solid var(--puck-color-grey-09);
          border-inline-end: 1px solid var(--puck-color-grey-09);
  color: var(--puck-color-grey-07);
  display: flex;
  justify-content: center;
  padding: 12px 15px;
  transition: color 50ms ease-in;
}
._ExternalInputModal-search_91ls0_227:focus-within ._ExternalInputModal-searchIcon_91ls0_264 {
  color: var(--puck-color-grey-04);
  transition: none;
}
@media (hover: hover) and (pointer: fine) {
  ._ExternalInputModal-search_91ls0_227:hover ._ExternalInputModal-searchIcon_91ls0_264 {
    color: var(--puck-color-grey-04);
    transition: none;
  }
}
._ExternalInputModal-searchIconText_91ls0_289 {
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
          clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}
._ExternalInputModal-searchInput_91ls0_299 {
  border: none;
  border-radius: 4px;
  background: var(--puck-color-white);
  font-family: inherit;
  font-size: 14px;
  padding: 12px 15px;
  width: 100%;
}
._ExternalInputModal-searchInput_91ls0_299:focus {
  outline: 0;
}
._ExternalInputModal-searchActions_91ls0_313 {
  display: flex;
  gap: 8px;
  height: 44px;
  width: 100%;
}
@media (min-width: 458px) {
  ._ExternalInputModal-searchActions_91ls0_313 {
    width: auto;
  }
}
._ExternalInputModal-searchActionIcon_91ls0_326 {
  align-self: center;
}
._ExternalInputModal-footerContainer_91ls0_330 {
  background-color: var(--puck-color-grey-12);
  border-top: 1px solid var(--puck-color-grey-09);
  color: var(--puck-color-grey-04);
  padding: 16px;
}
._ExternalInputModal-footer_91ls0_330 {
  font-weight: 500;
  font-size: 14px;
  text-align: right;
}
._ExternalInputModal-field_91ls0_343 {
  color: var(--puck-color-grey-04);
  margin: 16px;
  margin-bottom: 12px;
  display: block;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Modal/styles.module.css/#css-module-data */
._Modal_ikbaj_1 {
  background: color-mix(in srgb, var(--puck-color-black) 75%, transparent);
  display: none;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 1;
  padding: 32px;
}
._Modal--isOpen_ikbaj_15 {
  display: flex;
}
._Modal-inner_ikbaj_19 {
  width: 100%;
  max-width: 1024px;
  border-radius: 8px;
  overflow: hidden;
  background: var(--puck-color-white);
  display: flex;
  flex-direction: column;
  max-height: 90dvh;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Heading/styles.module.css/#css-module-data */
._Heading_qxrry_1 {
  display: block;
  color: var(--puck-color-black);
  font-weight: 700;
  margin: 0;
}
._Heading_qxrry_1 b {
  font-weight: 700;
}
._Heading--xxxxl_qxrry_12 {
  font-size: var(--puck-font-size-xxxxl);
  letter-spacing: 0.08ch;
  font-weight: 800;
}
._Heading--xxxl_qxrry_18 {
  font-size: var(--puck-font-size-xxxl);
}
._Heading--xxl_qxrry_22 {
  font-size: var(--puck-font-size-xxl);
}
._Heading--xl_qxrry_26 {
  font-size: var(--puck-font-size-xl);
}
._Heading--l_qxrry_30 {
  font-size: var(--puck-font-size-l);
}
._Heading--m_qxrry_34 {
  font-size: var(--puck-font-size-m);
}
._Heading--s_qxrry_38 {
  font-size: var(--puck-font-size-s);
}
._Heading--xs_qxrry_42 {
  font-size: var(--puck-font-size-xs);
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Button/Button.module.css/#css-module-data */
._Button_10byl_1 {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: 1px solid transparent;
  border-radius: 4px;
  color: var(--puck-color-white);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  letter-spacing: 0.05ch;
  font-family: var(--puck-font-family);
  font-size: 14px;
  font-weight: 400;
  box-sizing: border-box;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: background-color 50ms ease-in;
  cursor: pointer;
  white-space: nowrap;
  margin: 0;
}
._Button_10byl_1:hover,
._Button_10byl_1:active {
  transition: none;
}
._Button--medium_10byl_29 {
  min-height: 34px;
  padding-bottom: 7px;
  -webkit-padding-start: 19px;
          padding-inline-start: 19px;
  -webkit-padding-end: 19px;
          padding-inline-end: 19px;
  padding-top: 7px;
}
._Button--large_10byl_37 {
  padding-bottom: 11px;
  -webkit-padding-start: 19px;
          padding-inline-start: 19px;
  -webkit-padding-end: 19px;
          padding-inline-end: 19px;
  padding-top: 11px;
}
._Button-icon_10byl_44 {
  margin-top: 2px;
}
._Button--primary_10byl_48 {
  background: var(--puck-color-azure-04);
}
._Button_10byl_1:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  ._Button--primary_10byl_48:hover {
    background-color: var(--puck-color-azure-03);
  }
}
._Button--primary_10byl_48:active {
  background-color: var(--puck-color-azure-02);
}
._Button--secondary_10byl_67 {
  border: 1px solid currentColor;
  color: currentColor;
}
@media (hover: hover) and (pointer: fine) {
  ._Button--secondary_10byl_67:hover {
    background-color: var(--puck-color-azure-12);
    color: var(--puck-color-black);
  }
}
._Button--secondary_10byl_67:active {
  background-color: var(--puck-color-azure-11);
  color: var(--puck-color-black);
}
._Button--flush_10byl_84 {
  border-radius: 0;
}
._Button--disabled_10byl_88,
._Button--disabled_10byl_88:hover {
  background-color: var(--puck-color-grey-07);
  color: var(--puck-color-grey-03);
  cursor: not-allowed;
}
._Button--fullWidth_10byl_95 {
  justify-content: center;
  width: 100%;
}
._Button-spinner_10byl_100 {
  -webkit-padding-start: 8px;
          padding-inline-start: 8px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/RichTextMenu/styles.module.css/#css-module-data */
._RichTextMenu_k97eh_1 {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
}
._RichTextMenu--form_k97eh_7 {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
  padding: 6px 6px;
  background-color: var(--puck-color-grey-12);
  position: relative;
  scrollbar-width: none;
  overflow-x: auto;
}
._RichTextMenu-group_k97eh_17 {
  display: flex;
  align-items: space-between;
  flex-direction: row;
  flex-wrap: nowrap;
  padding-inline: 6px;
  gap: 2px;
  position: relative;
}
._RichTextMenu-group_k97eh_17:first-of-type {
  padding-left: 0;
}
._RichTextMenu-group_k97eh_17:last-of-type {
  padding-right: 0;
}
._RichTextMenu--inline_k97eh_35 ._RichTextMenu-group_k97eh_17 {
  color: var(--puck-color-grey-08);
  gap: 0px;
  flex-wrap: nowrap;
}
._RichTextMenu-group_k97eh_17 + ._RichTextMenu-group_k97eh_17 {
  border-left: 1px solid var(--puck-color-grey-10);
}
._RichTextMenu--inline_k97eh_35 ._RichTextMenu-group_k97eh_17 + ._RichTextMenu-group_k97eh_17 {
  border-left: 0.5px solid var(--puck-color-grey-05);
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/RichTextMenu/components/Control/styles.module.css/#css-module-data */
._Control_1aveu_1 .lucide {
  height: 18px;
  width: 18px;
}
._Control--inline_1aveu_6 .lucide {
  height: 16px;
  width: 16px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Select/styles.module.css/#css-module-data */
._Select_xjbef_1 {
  position: relative;
  z-index: 1;
}
._Select-button_xjbef_6 {
  align-items: center;
  background: transparent;
  border: none;
  border-radius: 4px;
  display: flex;
  justify-content: center;
  gap: 0px;
  height: 100%;
  padding: 4px;
  padding-right: 2px;
}
._Select--hasOptions_xjbef_19 ._Select-button_xjbef_6 {
  color: currentColor;
}
._Select--hasOptions_xjbef_19:not(._Select--disabled_xjbef_23) ._Select-button_xjbef_6 {
  cursor: pointer;
}
._Select-buttonIcon_xjbef_27 {
  align-items: center;
  display: flex;
  justify-content: center;
}
._Select--standalone_xjbef_33 ._Select-buttonIcon_xjbef_27 .lucide {
  height: 18px;
  width: 18px;
}
._Select--actionBar_xjbef_38 ._Select-buttonIcon_xjbef_27 .lucide {
  height: 16px;
  width: 16px;
}
._Select--hasOptions_xjbef_19:not(._Select--disabled_xjbef_23) ._Select-button_xjbef_6:hover,
._Select--hasValue_xjbef_44 ._Select-button_xjbef_6 {
  background: var(--puck-color-grey-10);
  color: var(--puck-color-azure-04);
}
._Select--disabled_xjbef_23 ._Select-button_xjbef_6 {
  color: var(--puck-color-grey-07);
}
._Select--actionBar_xjbef_38 {
  &._Select--hasOptions_xjbef_19 ._Select-button_xjbef_6:hover,
  &._Select--hasValue_xjbef_44 ._Select-button_xjbef_6 {
    background: none;
    color: var(--puck-color-azure-07);
  }
}
._Select-items_xjbef_61 {
  background: white;
  border: 1px solid var(--puck-color-grey-09);
  border-radius: 8px;
  margin: 10px 8px;
  margin-left: 0;
  padding: 4px;
  z-index: 2;
  list-style: none;
}
._SelectItem_xjbef_72 {
  background: transparent;
  border-radius: 4px;
  border: none;
  color: var(--puck-color-grey-04);
  cursor: pointer;
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: var(--puck-font-size-xxs);
  margin: 0;
  padding: 8px 12px;
  width: 100%;
}
._SelectItem--isSelected_xjbef_87 {
  background: var(--puck-color-azure-11);
  color: var(--puck-color-azure-04);
  font-weight: 500;
}
._SelectItem--isSelected_xjbef_87 ._SelectItem-icon_xjbef_93 {
  color: var(--puck-color-azure-04);
}
._SelectItem_xjbef_72:hover {
  background: var(--puck-color-azure-11);
  color: var(--puck-color-azure-04);
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/RichTextEditor/styles.module.css/#css-module-data */
._RichTextEditor_z25h4_1 .ProseMirror {
  white-space: pre-wrap;
  word-wrap: break-word;
  cursor: text;
  outline: none;
  position: relative;
}
._RichTextEditor_z25h4_1 .rich-text * {
  white-space: pre-wrap;
  -moz-user-select: auto;
       user-select: auto;
  -webkit-user-select: auto;
}
._RichTextEditor_z25h4_1 .rich-text blockquote {
  margin: 1em 0;
  padding: 0 1em;
  border-left: 4px solid var(--puck-color-grey-09);
}
._RichTextEditor_z25h4_1 .rich-text code {
  background-color: var(--puck-color-grey-11);
  padding: 4px 8px;
  border-radius: 4px;
}
._RichTextEditor_z25h4_1 .rich-text p:empty::before {
  content: "\a0";
}
._RichTextEditor_z25h4_1 .rich-text pre code {
  display: block;
  padding: 8px 12px;
}
._RichTextEditor_z25h4_1 .rich-text > *:first-child,
._RichTextEditor_z25h4_1 .ProseMirror > *:first-child,
._RichTextEditor_z25h4_1 .rich-text * p:first-of-type {
  margin-top: 0;
}
._RichTextEditor_z25h4_1 .rich-text > *:last-child,
._RichTextEditor_z25h4_1 .ProseMirror > *:last-child,
._RichTextEditor_z25h4_1 .rich-text * p:last-of-type {
  margin-bottom: 0;
}
._RichTextEditor--editor_z25h4_50 {
  background: var(--puck-color-white);
  border-width: 1px;
  border-style: solid;
  border-color: var(--puck-color-grey-09);
  border-radius: 4px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  font-family: inherit;
  font-size: var(--puck-font-size-xxs);
  resize: vertical;
  text-align: initial;
  transition: border-color 50ms ease-in;
  width: 100%;
  max-width: 100%;
  min-height: 128px;
}
._RichTextEditor--editor_z25h4_50 .rich-text {
  flex-grow: 1;
}
._RichTextEditor--editor_z25h4_50 .rich-text:not(:has(.ProseMirror)),
._RichTextEditor--editor_z25h4_50 .rich-text .ProseMirror {
  height: 100%;
  padding: 12px 15px;
}
._RichTextEditor--editor_z25h4_50 .rich-text ul,
._RichTextEditor--editor_z25h4_50 .rich-text ol {
  padding-left: 24px;
}
._RichTextEditor--editor_z25h4_50 .rich-text li {
  line-height: 1.5;
}
._RichTextEditor--editor_z25h4_50 .rich-text p {
  margin-block: 12px;
}
._RichTextEditor--editor_z25h4_50 .rich-text ul {
  list-style: disc;
}
._RichTextEditor--editor_z25h4_50 .rich-text ol {
  list-style: decimal;
}
._RichTextEditor--editor_z25h4_50:focus-within {
  border-color: var(--puck-color-grey-05);
  outline: 2px solid var(--puck-color-azure-05);
  transition: none;
}
._RichTextEditor--editor_z25h4_50._RichTextEditor--disabled_z25h4_107 {
  background: var(--puck-color-grey-11);
}
._RichTextEditor_z25h4_1:not(:focus-within):not(._RichTextEditor--isActive_z25h4_111) .ProseMirror ::selection {
  background-color: transparent;
}
._RichTextEditor-menu_z25h4_117 {
  border-bottom: 1px solid var(--puck-color-grey-10);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 1;
}
._RichTextEditor--disabled_z25h4_107 ._RichTextEditor-menu_z25h4_117 {
  border-bottom: 1px solid var(--puck-color-grey-09);
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/AutoField/fields/ObjectField/styles.module.css/#css-module-data */
._ObjectField_1ua3y_5 {
  display: flex;
  flex-direction: column;
  background-color: var(--puck-color-white);
  border: 1px solid var(--puck-color-grey-09);
  border-radius: 4px;
}
._ObjectField-fieldset_1ua3y_13 {
  border: none;
  margin: 0;
  min-width: 0;
  padding: 16px 15px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Drawer/styles.module.css/#css-module-data */
._Drawer_pl7z0_1 {
  display: flex;
  flex-direction: column;
  font-family: var(--puck-font-family);
  gap: 12px;
}
._Drawer-draggable_pl7z0_8 {
  position: relative;
}
._Drawer-draggableBg_pl7z0_12 {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  pointer-events: none;
  z-index: -1;
}
._DrawerItem-draggable_pl7z0_22 {
  background: var(--puck-color-white);
  cursor: -webkit-grab;
  cursor: grab;
  padding: 12px;
  display: flex;
  border: 1px var(--puck-color-grey-09) solid;
  border-radius: 4px;
  font-size: var(--puck-font-size-xxs);
  justify-content: space-between;
  align-items: center;
  transition: background-color 50ms ease-in, color 50ms ease-in;
}
._DrawerItem--disabled_pl7z0_35 ._DrawerItem-draggable_pl7z0_22 {
  background: var(--puck-color-grey-11);
  color: var(--puck-color-grey-05);
  cursor: not-allowed;
}
._DrawerItem_pl7z0_22:focus-visible {
  outline: 0;
}
._Drawer_pl7z0_1:not(._Drawer--isDraggingFrom_pl7z0_45) ._DrawerItem_pl7z0_22:focus-visible ._DrawerItem-draggable_pl7z0_22 {
  border-radius: 4px;
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  ._Drawer_pl7z0_1:not(._Drawer--isDraggingFrom_pl7z0_45) ._DrawerItem_pl7z0_22:not(._DrawerItem--disabled_pl7z0_35) ._DrawerItem-draggable_pl7z0_22:hover {
    background-color: var(--puck-color-azure-12);
    color: var(--puck-color-azure-04);
    transition: none;
  }
}
._DrawerItem-name_pl7z0_63 {
  overflow-x: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/DraggableComponent/styles.module.css/#css-module-data */
._DraggableComponent_1vaqy_1 {
  position: absolute;
  pointer-events: none;
  --overlay-background: color-mix( in srgb, var(--puck-color-azure-08) 30%, transparent );
}
._DraggableComponent-overlayWrapper_1vaqy_12 {
  height: 100%;
  width: 100%;
  top: 0;
  position: absolute;
  pointer-events: none;
  box-sizing: border-box;
  z-index: 1;
}
._DraggableComponent-overlay_1vaqy_12 {
  cursor: pointer;
  height: 100%;
  outline: 2px var(--puck-color-azure-09) solid;
  outline-offset: -2px;
  width: 100%;
}
._DraggableComponent_1vaqy_1:focus-visible > ._DraggableComponent-overlayWrapper_1vaqy_12 {
  outline: 1px solid var(--puck-color-azure-05);
}
._DraggableComponent-loadingOverlay_1vaqy_34 {
  background: var(--puck-color-white);
  color: var(--puck-color-grey-03);
  border-radius: 4px;
  display: flex;
  padding: 8px;
  top: 8px;
  right: 8px;
  position: absolute;
  z-index: 1;
  pointer-events: all;
  box-sizing: border-box;
  opacity: 0.8;
  z-index: 1;
}
._DraggableComponent--hover_1vaqy_50 > ._DraggableComponent-overlayWrapper_1vaqy_12 > ._DraggableComponent-overlay_1vaqy_12 {
  background: var(--overlay-background);
  outline: 2px var(--puck-color-azure-09) solid;
}
._DraggableComponent--isSelected_1vaqy_57 > ._DraggableComponent-overlayWrapper_1vaqy_12 > ._DraggableComponent-overlay_1vaqy_12 {
  outline-color: var(--puck-color-azure-07);
}
._DraggableComponent_1vaqy_1:has(._DraggableComponent--hover_1vaqy_50 > ._DraggableComponent-overlayWrapper_1vaqy_12) > ._DraggableComponent-overlayWrapper_1vaqy_12 {
  display: none;
}
._DraggableComponent-actionsOverlay_1vaqy_71 {
  position: -webkit-sticky;
  position: sticky;
  opacity: 0;
  pointer-events: none;
  z-index: 2;
}
._DraggableComponent--isSelected_1vaqy_57 ._DraggableComponent-actionsOverlay_1vaqy_71 {
  opacity: 1;
  pointer-events: auto;
}
._DraggableComponent-actions_1vaqy_71 {
  position: absolute;
  width: auto;
  cursor: -webkit-grab;
  cursor: grab;
  display: flex;
  box-sizing: border-box;
  transform-origin: right top;
  min-height: 36px;
}

/* components/DraggableComponent/styles.css */
[data-puck-component] * {
  pointer-events: none;
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
}
[data-puck-component] {
  cursor: -webkit-grab;
  cursor: grab;
  pointer-events: auto !important;
  -moz-user-select: none;
       user-select: none;
  -webkit-user-select: none;
}
[data-puck-dropzone] {
  pointer-events: auto !important;
}
[data-puck-disabled] {
  cursor: pointer;
}
[data-dnd-placeholder] {
  background: var(--puck-color-azure-06) !important;
  border: none !important;
  color: #00000000 !important;
  opacity: 0.3 !important;
  outline: none !important;
  transition: none !important;
}
[data-dnd-placeholder] *,
[data-dnd-placeholder]::after,
[data-dnd-placeholder]::before {
  opacity: 0 !important;
}
[data-dnd-dragging][data-puck-component] {
  pointer-events: none !important;
  outline: 2px var(--puck-color-azure-09) solid !important;
  outline-offset: -2px !important;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/DropZone/styles.module.css/#css-module-data */
._DropZone_1i2sv_1 {
  --resize-animation-ms: 150ms;
  position: relative;
  height: 100%;
  min-height: var(--min-empty-height);
  outline-offset: -2px;
  width: 100%;
}
._DropZone--hasChildren_1i2sv_11 {
  min-height: 0;
}
._DropZone_1i2sv_1:empty {
  min-height: var(--min-empty-height);
}
[data-puck-entry]:not([data-puck-dragging]) ._DropZone_1i2sv_1 {
  transition: min-height var(--resize-animation-ms) ease-in;
}
._DropZone--isAreaSelected_1i2sv_24,
._DropZone--hoveringOverArea_1i2sv_25:not(._DropZone--isRootZone_1i2sv_25) {
  background: color-mix(in srgb, var(--puck-color-azure-09) 30%, transparent);
  outline: 2px dashed var(--puck-color-azure-08);
}
._DropZone_1i2sv_1:empty {
  background: color-mix(in srgb, var(--puck-color-azure-09) 30%, transparent);
  outline: 2px dashed var(--puck-color-azure-08);
}
._DropZone--isDestination_1i2sv_35 {
  outline: 2px dashed var(--puck-color-azure-04) !important;
}
._DropZone--isDestination_1i2sv_35:not(._DropZone--isRootZone_1i2sv_25) {
  background: color-mix(in srgb, var(--puck-color-azure-09) 30%, transparent) !important;
}
._DropZone-item_1i2sv_47 {
  position: relative;
}
._DropZone-hitbox_1i2sv_51 {
  position: absolute;
  bottom: -12px;
  height: 24px;
  width: 100%;
  z-index: 1;
}
[data-puck-dragging] ._DropZone--isEnabled_1i2sv_59 {
  outline: 2px dashed var(--puck-color-azure-06);
}
._DropZone_1i2sv_1 > *:not([data-puck-component]) {
  opacity: 0;
}
body:has(._DropZone--isAnimating_1i2sv_68:empty) [data-puck-overlay] {
  opacity: 0 !important;
}

/* lib/overlay-portal/styles.css */
[data-puck-overlay-portal],
[data-puck-overlay-portal] * {
  pointer-events: auto !important;
}
[data-puck-overlay-portal]:hover {
  outline: 2px var(--puck-color-azure-09) dashed;
  outline-offset: 2px;
}
[data-puck-overlay-portal]:focus-within {
  outline: 2px var(--puck-color-azure-07) dashed;
  outline-offset: 2px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/InlineTextField/styles.module.css/#css-module-data */
._InlineTextField_104qp_1 {
  cursor: text;
  display: inline-block;
  white-space: pre-wrap;
  text-decoration: inherit;
}
[data-dnd-dragging] ._InlineTextField_104qp_1 {
  cursor: none;
  caret-color: transparent;
}
[data-dnd-dragging] ._InlineTextField_104qp_1::selection {
  display: none;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Fields/styles.module.css/#css-module-data */
._PuckFields_10bh7_1 {
  position: relative;
  font-family: var(--puck-font-family);
}
._PuckFields--isLoading_10bh7_6 {
  min-height: 48px;
}
._PuckFields-loadingOverlay_10bh7_10 {
  background: var(--puck-color-white);
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  height: 100%;
  width: 100%;
  top: 0px;
  position: absolute;
  z-index: 1;
  pointer-events: all;
  box-sizing: border-box;
  opacity: 0.8;
}
._PuckFields-loadingOverlayInner_10bh7_25 {
  display: flex;
  padding: 16px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}
._PuckFields-field_10bh7_32 * {
  box-sizing: border-box;
}
._PuckFields--wrapFields_10bh7_36 ._PuckFields-field_10bh7_32 {
  color: var(--puck-color-grey-04);
  padding: 16px;
  padding-bottom: 12px;
  display: block;
}
._PuckFields--wrapFields_10bh7_36 ._PuckFields-field_10bh7_32 + ._PuckFields-field_10bh7_32 {
  border-top: 1px solid var(--puck-color-grey-09);
  margin-top: 8px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/ComponentList/styles.module.css/#css-module-data */
._ComponentList_1rrlt_1 {
  max-width: 100%;
}
._ComponentList--isExpanded_1rrlt_5 + ._ComponentList_1rrlt_1 {
  margin-top: 12px;
}
._ComponentList-content_1rrlt_9 {
  display: none;
}
._ComponentList--isExpanded_1rrlt_5 > ._ComponentList-content_1rrlt_9 {
  display: block;
}
._ComponentList-title_1rrlt_17 {
  background-color: transparent;
  border: 0;
  color: var(--puck-color-grey-05);
  cursor: pointer;
  display: flex;
  font: inherit;
  font-size: var(--puck-font-size-xxxs);
  list-style: none;
  margin-bottom: 6px;
  padding: 8px;
  text-transform: uppercase;
  transition: background-color 50ms ease-in, color 50ms ease-in;
  gap: 4px;
  border-radius: 4px;
  width: 100%;
}
._ComponentList-title_1rrlt_17:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  ._ComponentList-title_1rrlt_17:hover {
    background-color: var(--puck-color-azure-11);
    color: var(--puck-color-azure-04);
    transition: none;
  }
}
._ComponentList-title_1rrlt_17:active {
  background-color: var(--puck-color-azure-10);
  transition: none;
}
._ComponentList-titleIcon_1rrlt_53 {
  -webkit-margin-start: auto;
          margin-inline-start: auto;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Preview/styles.module.css/#css-module-data */
._PuckPreview_z2rgu_1 {
  position: relative;
  height: 100%;
}
._PuckPreview-frame_z2rgu_6 {
  border: none;
  height: 100%;
  width: 100%;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/LayerTree/styles.module.css/#css-module-data */
._LayerTree_7rx04_1 {
  color: var(--puck-color-grey-03);
  font-family: var(--puck-font-family);
  font-size: var(--puck-font-size-xxs);
  margin: 0;
  position: relative;
  list-style: none;
  padding: 0;
}
._LayerTree-zoneTitle_7rx04_11 {
  color: var(--puck-color-grey-05);
  font-size: var(--puck-font-size-xxxs);
  text-transform: uppercase;
}
._LayerTree-helper_7rx04_17 {
  text-align: center;
  color: var(--puck-color-grey-07);
  margin: 8px 4px;
}
._Layer_7rx04_1 {
  position: relative;
  border: 1px solid transparent;
  border-radius: 4px;
}
._Layer-inner_7rx04_29 {
  border: 1px solid transparent;
  border-radius: 4px;
  transition: color 50ms ease-in;
}
._Layer--containsZone_7rx04_35 > ._Layer-inner_7rx04_29 {
  -webkit-padding-start: 0;
          padding-inline-start: 0;
}
._Layer-clickable_7rx04_39 {
  align-items: center;
  background: none;
  border: 0;
  border-radius: 4px;
  color: inherit;
  cursor: pointer;
  display: flex;
  font: inherit;
  -webkit-padding-start: 12px;
          padding-inline-start: 12px;
  -webkit-padding-end: 4px;
          padding-inline-end: 4px;
  width: 100%;
}
._Layer-clickable_7rx04_39:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
  position: relative;
  z-index: 1;
}
@media (hover: hover) and (pointer: fine) {
  ._Layer_7rx04_1:not(._Layer--isSelected_7rx04_61) > ._Layer-inner_7rx04_29:hover {
    border-color: var(--puck-color-azure-10);
    background: var(--puck-color-azure-11);
    color: var(--puck-color-azure-04);
    transition: none;
  }
}
._Layer--isSelected_7rx04_61 {
  border-color: var(--puck-color-azure-08);
}
._Layer--isSelected_7rx04_61 > ._Layer-inner_7rx04_29 {
  background: var(--puck-color-azure-10);
}
._Layer--isSelected_7rx04_61 > ._Layer-inner_7rx04_29 > ._Layer-clickable_7rx04_39 > ._Layer-chevron_7rx04_77,
._Layer--childIsSelected_7rx04_78 > ._Layer-inner_7rx04_29 > ._Layer-clickable_7rx04_39 > ._Layer-chevron_7rx04_77 {
  transform: scaleY(-1);
}
._Layer-zones_7rx04_82 {
  display: none;
  -webkit-margin-start: 12px;
          margin-inline-start: 12px;
}
._Layer--isSelected_7rx04_61 > ._Layer-zones_7rx04_82,
._Layer--childIsSelected_7rx04_78 > ._Layer-zones_7rx04_82 {
  display: block;
}
._Layer-zones_7rx04_82 > ._LayerTree_7rx04_1 {
  -webkit-margin-start: 12px;
          margin-inline-start: 12px;
}
._Layer-title_7rx04_96,
._LayerTree-zoneTitle_7rx04_11 {
  display: flex;
  gap: 8px;
  align-items: center;
  margin: 8px 4px;
  overflow-x: hidden;
}
._Layer-name_7rx04_105 {
  overflow-x: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._Layer-icon_7rx04_111 {
  color: var(--puck-color-rose-07);
  margin-top: 4px;
}
._Layer-zoneIcon_7rx04_116 {
  color: var(--puck-color-grey-08);
  margin-top: 4px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Layout/styles.module.css/#css-module-data */
._Puck_1dd16_19 {
  --puck-space-px: 16px;
  font-family: var(--puck-font-family);
  overflow-x: hidden;
}
@media (min-width: 766px) {
  ._Puck_1dd16_19 {
    overflow-x: auto;
  }
}
._Puck-portal_1dd16_31 {
  position: relative;
  z-index: 2;
}
._PuckLayout_1dd16_36 {
  height: 100dvh;
}
._PuckLayout-inner_1dd16_40 {
  --puck-frame-width: auto;
  --puck-side-nav-width: min-content;
  --puck-side-bar-width: 0px;
  --puck-left-side-bar-width: var( --puck-user-left-side-bar-width, var(--puck-side-bar-width) );
  --puck-right-side-bar-width: var( --puck-user-right-side-bar-width, var(--puck-side-bar-width) );
  background-color: var(--puck-color-grey-12);
  display: grid;
  grid-template-areas: "header" "editor" "left" "right" "sidenav";
  grid-template-columns: var(--puck-frame-width);
  grid-template-rows: min-content auto 0 0 var(--puck-side-nav-width);
  height: 100%;
  position: relative;
  transition: grid-template-rows 150ms ease-in;
  z-index: 0;
  overflow: hidden;
}
@media (min-width: 638px) {
  ._PuckLayout-inner_1dd16_40 {
    --puck-side-nav-width: 68px;
    grid-template-areas: "header header header header" "sidenav left editor right";
    grid-template-columns: var(--puck-side-nav-width) 0 var(--puck-frame-width) 0;
    grid-template-rows: min-content auto;
  }
  ._Puck--hidePlugins_1dd16_72 ._PuckLayout-inner_1dd16_40 {
    --puck-side-nav-width: 0;
  }
}
._PuckLayout--mounted_1dd16_77 ._PuckLayout-inner_1dd16_40 {
  --puck-side-bar-width: 186px;
}
._PuckLayout--mobilePanelHeightToggle_1dd16_81._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-inner_1dd16_40 {
  grid-template-rows: 0 auto 30% 0 var(--puck-side-nav-width);
}
._PuckLayout--mobilePanelHeightToggle_1dd16_81._PuckLayout--leftSideBarVisible_1dd16_81._PuckLayout--isExpanded_1dd16_87 ._PuckLayout-inner_1dd16_40 {
  grid-template-rows: 0 auto 55% 0 var(--puck-side-nav-width);
}
@media (min-width: 638px) {
  ._PuckLayout--mobilePanelHeightToggle_1dd16_81._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-inner_1dd16_40 {
    grid-template-columns: var(--puck-side-nav-width) var(--puck-left-side-bar-width) var( --puck-frame-width ) 0;
    grid-template-rows: min-content auto;
  }
}
._PuckLayout--mobilePanelHeightMinContent_1dd16_105._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-inner_1dd16_40,
._PuckLayout--mobilePanelHeightMinContent_1dd16_105._PuckLayout--leftSideBarVisible_1dd16_81._PuckLayout--isExpanded_1dd16_87 ._PuckLayout-inner_1dd16_40 {
  grid-template-rows: 0 auto min-content 0 var(--puck-side-nav-width);
}
@media (min-width: 638px) {
  ._PuckLayout--mobilePanelHeightToggle_1dd16_81._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-inner_1dd16_40,
  ._PuckLayout--mobilePanelHeightToggle_1dd16_81._PuckLayout--leftSideBarVisible_1dd16_81._PuckLayout--isExpanded_1dd16_87 ._PuckLayout-inner_1dd16_40,
  ._PuckLayout--mobilePanelHeightMinContent_1dd16_105._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-inner_1dd16_40,
  ._PuckLayout--mobilePanelHeightMinContent_1dd16_105._PuckLayout--leftSideBarVisible_1dd16_81._PuckLayout--isExpanded_1dd16_87 ._PuckLayout-inner_1dd16_40 {
    grid-template-columns: var(--puck-side-nav-width) var(--puck-left-side-bar-width) var( --puck-frame-width ) 0;
    grid-template-rows: min-content auto;
  }
}
@media (min-width: 638px) {
  ._PuckLayout--rightSideBarVisible_1dd16_132 ._PuckLayout-inner_1dd16_40 {
    grid-template-columns: var(--puck-side-nav-width) 0 var(--puck-frame-width) var(--puck-right-side-bar-width);
  }
}
@media (min-width: 638px) {
  ._PuckLayout--leftSideBarVisible_1dd16_81._PuckLayout--rightSideBarVisible_1dd16_132 ._PuckLayout-inner_1dd16_40 {
    grid-template-columns: var(--puck-side-nav-width) var(--puck-left-side-bar-width) var( --puck-frame-width ) var(--puck-right-side-bar-width);
  }
}
@media (min-width: 458px) {
  ._PuckLayout-mounted_1dd16_151 ._PuckLayout-inner_1dd16_40 {
    --puck-frame-width: minmax(266px, auto);
  }
}
@media (min-width: 638px) {
  ._PuckLayout_1dd16_36 ._PuckLayout-inner_1dd16_40 {
    --puck-side-bar-width: minmax(186px, 250px);
  }
}
@media (min-width: 766px) {
  ._PuckLayout_1dd16_36 ._PuckLayout-inner_1dd16_40 {
    --puck-frame-width: auto;
  }
}
@media (min-width: 990px) {
  ._PuckLayout_1dd16_36 ._PuckLayout-inner_1dd16_40 {
    --puck-side-bar-width: 256px;
  }
}
@media (min-width: 1198px) {
  ._PuckLayout_1dd16_36 ._PuckLayout-inner_1dd16_40 {
    --puck-side-bar-width: 274px;
  }
}
@media (min-width: 1398px) {
  ._PuckLayout_1dd16_36 ._PuckLayout-inner_1dd16_40 {
    --puck-side-bar-width: 290px;
  }
}
@media (min-width: 1598px) {
  ._PuckLayout_1dd16_36 ._PuckLayout-inner_1dd16_40 {
    --puck-side-bar-width: 320px;
  }
}
._PuckLayout-nav_1dd16_192 {
  border-top: 1px solid var(--puck-color-grey-09);
  background-color: var(--puck-color-grey-12);
  grid-area: sidenav;
  overflow: hidden;
  width: 100%;
}
@media (min-width: 638px) {
  ._PuckLayout-nav_1dd16_192 {
    border-top: 0;
    border-right: 1px solid var(--puck-color-grey-09);
    box-sizing: border-box;
  }
}
._PuckLayout-header_1dd16_208 {
  grid-area: header;
}
._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-header_1dd16_208 {
  overflow: hidden;
}
@media (min-width: 638px) {
  ._PuckLayout--leftSideBarVisible_1dd16_81 ._PuckLayout-header_1dd16_208 {
    overflow: auto;
  }
}
._PuckPluginTab_1dd16_222 {
  display: none;
  flex-grow: 1;
  max-height: 100%;
}
._PuckPluginTab--visible_1dd16_228 {
  display: flex;
  flex-direction: column;
}
._PuckPluginTab-body_1dd16_233 {
  flex-grow: 1;
  max-height: 100%;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/MenuBar/styles.module.css/#css-module-data */
._MenuBar_8pf8c_1 {
  background-color: var(--puck-color-white);
  border-bottom: 1px solid var(--puck-color-grey-09);
  display: none;
  left: 0;
  margin-top: 1px;
  padding: 8px 16px;
  position: absolute;
  right: 0;
  top: 100%;
  z-index: 2;
}
._MenuBar--menuOpen_8pf8c_14 {
  display: block;
}
@media (min-width: 638px) {
  ._MenuBar_8pf8c_1 {
    border: none;
    display: block;
    margin-top: 0;
    overflow-y: visible;
    padding: 0;
    position: static;
  }
}
._MenuBar-inner_8pf8c_29 {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  justify-content: flex-end;
}
@media (min-width: 638px) {
  ._MenuBar-inner_8pf8c_29 {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
  }
}
._MenuBar-history_8pf8c_45 {
  display: flex;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Header/styles.module.css/#css-module-data */
._PuckHeader_63pti_1 {
  background: var(--puck-color-white);
  border-bottom: 1px solid var(--puck-color-grey-09);
  color: var(--puck-color-black);
  grid-area: header;
  position: relative;
  max-width: 100vw;
}
@media (min-width: 638px) {
  ._PuckHeader_63pti_1 {
    padding-left: 67px;
  }
  ._PuckHeader--hidePlugins_63pti_15 {
    padding-left: 0;
  }
}
._PuckHeader-inner_63pti_20 {
  align-items: end;
  display: grid;
  grid-gap: var(--puck-space-px);
  gap: var(--puck-space-px);
  grid-template-areas: "left middle right";
  grid-template-columns: 1fr auto 1fr;
  grid-template-rows: auto;
  padding: var(--puck-space-px);
}
@media (min-width: 638px) {
  ._PuckHeader-inner_63pti_20 {
    border-left: 1px solid var(--puck-color-grey-09);
  }
  ._PuckHeader--hidePlugins_63pti_15 ._PuckHeader-inner_63pti_20 {
    border-left: none;
  }
}
._PuckHeader-toggle_63pti_40 {
  color: var(--puck-color-grey-05);
  display: flex;
  -webkit-margin-start: -4px;
          margin-inline-start: -4px;
  padding-top: 2px;
}
._PuckHeader--rightSideBarVisible_63pti_47 ._PuckHeader-rightSideBarToggle_63pti_47,
._PuckHeader--leftSideBarVisible_63pti_48 ._PuckHeader-leftSideBarToggle_63pti_48 {
  color: var(--puck-color-black);
}
._PuckHeader-rightSideBarToggle_63pti_47,
._PuckHeader-leftSideBarToggle_63pti_48 {
  display: none;
}
@media (min-width: 638px) {
  ._PuckHeader-rightSideBarToggle_63pti_47,
  ._PuckHeader-leftSideBarToggle_63pti_48 {
    display: block;
  }
}
._PuckHeader-title_63pti_64 {
  align-self: center;
}
._PuckHeader-path_63pti_68 {
  font-family: var(--puck-font-family-monospaced);
  font-size: var(--puck-font-size-xxs);
  font-weight: normal;
  word-break: break-all;
}
._PuckHeader-tools_63pti_75 {
  display: flex;
  gap: 16px;
  justify-content: flex-end;
}
._PuckHeader-menuButton_63pti_81 {
  color: var(--puck-color-grey-05);
  -webkit-margin-start: -4px;
          margin-inline-start: -4px;
}
._PuckHeader--menuOpen_63pti_86 ._PuckHeader-menuButton_63pti_81 {
  color: var(--puck-color-black);
}
@media (min-width: 638px) {
  ._PuckHeader-menuButton_63pti_81 {
    display: none;
  }
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/SidebarSection/styles.module.css/#css-module-data */
._SidebarSection_5otpt_1 {
  display: flex;
  position: relative;
  flex-direction: column;
  color: var(--puck-color-black);
}
._SidebarSection_5otpt_1:last-of-type {
  flex-grow: 1;
}
._SidebarSection-title_5otpt_12 {
  background: var(--puck-color-white);
  padding: 16px;
  border-bottom: 1px solid var(--puck-color-grey-09);
  border-top: 1px solid var(--puck-color-grey-09);
  overflow-x: auto;
}
._SidebarSection--noBorderTop_5otpt_20 > ._SidebarSection-title_5otpt_12 {
  border-top: 0px;
}
._SidebarSection-content_5otpt_24:last-child {
  padding-bottom: 4px;
}
._SidebarSection_5otpt_1:last-of-type ._SidebarSection-content_5otpt_24 {
  border-bottom: none;
  flex-grow: 1;
}
._SidebarSection-breadcrumbLabel_5otpt_33 {
  background: none;
  border: 0;
  border-radius: 2px;
  color: var(--puck-color-azure-04);
  cursor: pointer;
  font: inherit;
  flex-shrink: 0;
  padding: 0;
  transition: color 50ms ease-in;
}
._SidebarSection-breadcrumbLabel_5otpt_33:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  ._SidebarSection-breadcrumbLabel_5otpt_33:hover {
    color: var(--puck-color-azure-03);
    transition: none;
  }
}
._SidebarSection-breadcrumbLabel_5otpt_33:active {
  color: var(--puck-color-azure-02);
  transition: none;
}
._SidebarSection-breadcrumbs_5otpt_62 {
  align-items: center;
  display: flex;
  gap: 4px;
}
._SidebarSection-breadcrumb_5otpt_33 {
  align-items: center;
  display: flex;
  gap: 4px;
}
._SidebarSection-heading_5otpt_74 {
  -webkit-padding-end: 16px;
          padding-inline-end: 16px;
}
._SidebarSection-loadingOverlay_5otpt_78 {
  background: var(--puck-color-white);
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
  top: 0;
  position: absolute;
  z-index: 1;
  pointer-events: all;
  box-sizing: border-box;
  opacity: 0.8;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Breadcrumbs/styles.module.css/#css-module-data */
._Breadcrumbs_1c9yh_1 {
  align-items: center;
  display: flex;
  gap: 4px;
}
._Breadcrumbs-breadcrumbLabel_1c9yh_7 {
  background: none;
  border: 0;
  border-radius: 2px;
  color: var(--puck-color-azure-04);
  cursor: pointer;
  font: inherit;
  flex-shrink: 0;
  padding: 0;
  transition: color 50ms ease-in;
}
._Breadcrumbs-breadcrumbLabel_1c9yh_7:focus-visible {
  outline: 2px solid var(--puck-color-azure-05);
  outline-offset: 2px;
}
@media (hover: hover) and (pointer: fine) {
  ._Breadcrumbs-breadcrumbLabel_1c9yh_7:hover {
    color: var(--puck-color-azure-03);
    transition: none;
  }
}
._Breadcrumbs-breadcrumbLabel_1c9yh_7:active {
  color: var(--puck-color-azure-02);
  transition: none;
}
._Breadcrumbs-breadcrumb_1c9yh_7 {
  align-items: center;
  display: flex;
  gap: 4px;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/ViewportControls/styles.module.css/#css-module-data */
._ViewportControls_e3unb_1 {
  position: relative;
}
._ViewportControls--fullScreen_e3unb_5 {
  border-radius: 32px;
  display: flex;
  position: absolute;
  bottom: 12px;
  right: 12px;
  overflow: hidden;
}
._ViewportControls-toggleButton_e3unb_14 {
  display: none;
}
._ViewportControls--fullScreen_e3unb_5 ._ViewportControls-toggleButton_e3unb_14 {
  align-items: center;
  background-color: var(--puck-color-grey-02);
  border: 1px solid var(--puck-color-grey-04);
  border-radius: 30px;
  cursor: pointer;
  color: var(--puck-color-grey-11);
  display: flex;
  justify-content: center;
  width: 42px;
  height: 42px;
  z-index: 1;
}
._ViewportControls--fullScreen_e3unb_5 ._ViewportControls-toggleButton_e3unb_14:hover {
  background-color: var(--puck-color-grey-02);
  border: 1px solid var(--puck-color-azure-04);
  color: var(--puck-color-azure-07);
}
._ViewportControls--isExpanded_e3unb_38 ._ViewportControls-toggleButton_e3unb_14 {
  background-color: var(--puck-color-grey-03);
}
._ViewportControls-actions_e3unb_42 {
  display: flex;
}
._ViewportControls-actionsInner_e3unb_46 {
  display: flex;
  box-sizing: border-box;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  z-index: 0;
  overflow: hidden;
}
._ViewportControls--fullScreen_e3unb_5 ._ViewportControls-actionsInner_e3unb_46 {
  background: var(--puck-color-grey-11);
  border: 1px solid var(--puck-color-grey-09);
  border-radius: 30px;
  margin-left: none;
  margin-right: none;
  padding-right: 42px;
}
._ViewportControls--fullScreen_e3unb_5 ._ViewportControls-actionsInner_e3unb_46 {
  transform: translateX(100%);
  transition: transform 150ms ease-in-out;
}
._ViewportControls--fullScreen_e3unb_5._ViewportControls--isExpanded_e3unb_38 ._ViewportControls-actionsInner_e3unb_46 {
  transform: translateX(42px);
}
._ViewportControls-divider_e3unb_75 {
  -webkit-border-end: 1px solid var(--puck-color-grey-09);
          border-inline-end: 1px solid var(--puck-color-grey-09);
  margin-bottom: 8px;
  margin-top: 8px;
}
._ViewportControls-zoomSelect_e3unb_81 {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100' fill='%23c3c3c3'><polygon points='0,0 100,0 50,50'/></svg>") no-repeat;
  background-size: 10px;
  background-position: calc(100% - 12px) calc(50% + 3px);
  background-repeat: no-repeat;
  border: 0;
  font-size: var(--puck-font-size-xxxs);
  padding: 0;
  padding-left: 8px;
  width: 96px;
}
._ViewportControls--fullScreen_e3unb_5 ._ViewportControls-zoom_e3unb_81 {
  display: none;
}
@media (min-width: 638px) {
  ._ViewportControls-zoom_e3unb_81,
  ._ViewportControls--fullScreen_e3unb_5 ._ViewportControls-zoom_e3unb_81 {
    display: flex;
    justify-content: center;
  }
}
._ViewportControls-zoomSelect_e3unb_81:dir(rtl) {
  background-position: 12px calc(50% + 3px);
}
._ViewportButton-inner_e3unb_111 {
  align-items: center;
  display: flex;
  justify-content: center;
  height: 32px;
  width: 32px;
}
._ViewportButton--isActive_e3unb_119 ._ViewportButton-inner_e3unb_111 {
  color: var(--puck-color-azure-04);
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Canvas/styles.module.css/#css-module-data */
._PuckCanvas_t6s9b_1 {
  background: var(--puck-color-grey-11);
  display: flex;
  grid-area: editor;
  flex-direction: column;
  padding: var(--puck-space-px);
  position: relative;
  overflow: auto;
}
@media (min-width: 1198px) {
  ._PuckCanvas_t6s9b_1 {
    padding: calc(var(--puck-space-px) * 1.5);
    padding-top: calc(var(--puck-space-px) * 0.5);
  }
  ._PuckCanvas_t6s9b_1:not(._PuckCanvas_t6s9b_1:has(._PuckCanvas-controls_t6s9b_17)) {
    padding-top: calc(var(--puck-space-px) * 1.5);
  }
}
._PuckCanvas--fullScreen_t6s9b_22 {
  padding: 0;
  overflow: hidden;
}
@media (min-width: 1198px) {
  ._PuckCanvas--fullScreen_t6s9b_22 {
    padding: 0;
  }
}
._PuckCanvas-inner_t6s9b_33 {
  display: flex;
  height: 100%;
  justify-content: center;
  min-width: 288px;
  position: relative;
  width: 100%;
}
._PuckCanvas-root_t6s9b_42 {
  background: white;
  outline: 1px solid var(--puck-color-grey-09);
  box-sizing: content-box;
  min-width: 321px;
  position: absolute;
  pointer-events: none;
  transform-origin: top;
  top: 0;
  bottom: 0;
  opacity: 0;
}
@media (min-width: 1198px) {
  ._PuckCanvas-root_t6s9b_42 {
    min-width: unset;
  }
}
@media (prefers-reduced-motion: reduce) {
  ._PuckCanvas-root_t6s9b_42 {
    transition: none !important;
  }
}
._PuckCanvas--ready_t6s9b_67 ._PuckCanvas-root_t6s9b_42 {
  pointer-events: unset;
  opacity: 1;
}
._PuckCanvas-loader_t6s9b_72 {
  align-items: center;
  color: var(--puck-color-grey-06);
  display: flex;
  height: 100%;
  justify-content: center;
  transition: opacity 250ms ease-out;
  opacity: 0;
}
._PuckCanvas--showLoader_t6s9b_82 ._PuckCanvas-loader_t6s9b_72 {
  opacity: 1;
}
._PuckCanvas--showLoader_t6s9b_82._PuckCanvas--ready_t6s9b_67 ._PuckCanvas-loader_t6s9b_72 {
  opacity: 0;
  height: 0;
  transition: none;
}
._PuckCanvas-controls_t6s9b_17 {
  padding-bottom: calc(var(--puck-space-px) * 0.5);
}
._PuckCanvas--fullScreen_t6s9b_22 ._PuckCanvas-controls_t6s9b_17 {
  padding-bottom: 0;
  z-index: 1;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/ResizeHandle/styles.module.css/#css-module-data */
@media (min-width: 766px) {
  ._ResizeHandle_144bf_2 {
    position: absolute;
    width: 5px;
    height: 100%;
    cursor: col-resize;
    z-index: 10;
    background: transparent;
    top: 0;
  }
  ._ResizeHandle_144bf_2:hover {
    background: rgba(0, 0, 0, 0.1);
  }
  ._ResizeHandle--left_144bf_16 {
    right: -3px;
  }
  ._ResizeHandle--right_144bf_20 {
    left: -3px;
  }
}

/* components/Puck/components/ResizeHandle/styles.css */
[data-resize-overlay] {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 9999;
  cursor: col-resize;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Sidebar/styles.module.css/#css-module-data */
._Sidebar_o396p_1 {
  -webkit-border-before: 1px solid var(--puck-color-grey-09);
          border-block-start: 1px solid var(--puck-color-grey-09);
  position: relative;
  display: none;
  flex-direction: column;
  overflow-y: auto;
}
._Sidebar--isVisible_o396p_9 {
  display: flex;
}
._Sidebar--left_o396p_13 {
  background: var(--puck-color-grey-12);
  grid-area: left;
}
@media (min-width: 766px) {
  ._Sidebar--left_o396p_13 {
    -webkit-border-before: 0;
            border-block-start: 0;
    -webkit-border-end: 1px solid var(--puck-color-grey-09);
            border-inline-end: 1px solid var(--puck-color-grey-09);
  }
}
._Sidebar--right_o396p_25 {
  background: var(--puck-color-white);
  grid-area: right;
}
@media (min-width: 766px) {
  ._Sidebar--right_o396p_25 {
    -webkit-border-before: 0;
            border-block-start: 0;
    -webkit-border-start: 1px solid var(--puck-color-grey-09);
            border-inline-start: 1px solid var(--puck-color-grey-09);
  }
}
._Sidebar-resizeHandle_o396p_37 {
  position: absolute;
  height: 100%;
}
._Sidebar--left_o396p_13 + ._Sidebar-resizeHandle_o396p_37 {
  grid-area: left;
  justify-self: end;
}
._Sidebar--right_o396p_25 + ._Sidebar-resizeHandle_o396p_37 {
  grid-area: right;
  justify-self: start;
}

/* css-module:/home/runner/work/puck/puck/packages/core/components/Puck/components/Nav/styles.module.css/#css-module-data */
._Nav_1tvxq_1 {
  display: flex;
}
._Nav-list_1tvxq_5 {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-x: auto;
  gap: 8px;
}
@media (min-width: 638px) {
  ._Nav-list_1tvxq_5 {
    padding-top: 32px;
    flex-direction: column;
    gap: 16px;
    width: 100%;
  }
}
._Nav-mobileActions_1tvxq_23 {
  align-items: center;
  display: flex;
  justify-content: center;
  -webkit-margin-start: auto;
          margin-inline-start: auto;
  padding: 4px 16px;
  -webkit-border-start: 1px solid var(--puck-color-grey-09);
          border-inline-start: 1px solid var(--puck-color-grey-09);
}
@media (min-width: 638px) {
  ._Nav-mobileActions_1tvxq_23 {
    display: none;
  }
}
._NavItem-link_1tvxq_38 {
  text-align: center;
  align-items: center;
  color: var(--puck-color-grey-03);
  display: flex;
  gap: 8px;
  text-decoration: none;
  cursor: pointer;
  border-radius: 4px;
  padding: 8px 4px;
  width: 64px;
  box-sizing: border-box;
}
@media (min-width: 638px) {
  ._NavItem-link_1tvxq_38 {
    width: auto;
  }
}
._NavItem_1tvxq_38:first-of-type {
  padding-left: 16px;
}
._NavItem_1tvxq_38:last-of-type {
  padding-right: 16px;
}
@media (min-width: 638px) {
  ._NavItem_1tvxq_38:first-of-type,
  ._NavItem_1tvxq_38:last-of-type {
    padding: 0;
  }
}
._NavItem-link_1tvxq_38 {
  border-top: 4px solid transparent;
  border-bottom: 4px solid transparent;
  border-radius: 0;
  flex-direction: column;
  font-size: var(--puck-font-size-xxxs);
}
@media (min-width: 638px) {
  ._NavItem-link_1tvxq_38 {
    border: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
  }
}
._NavItem-linkIcon_1tvxq_89 {
  height: 24px;
  width: 24px;
}
._NavItem--active_1tvxq_94 > ._NavItem-link_1tvxq_38 {
  background-color: var(--puck-color-azure-10);
  color: var(--puck-color-azure-04);
  font-weight: 600;
}
._NavItem--active_1tvxq_94 > ._NavItem-link_1tvxq_38 {
  background-color: transparent;
  border-top-color: var(--puck-color-azure-04);
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  font-weight: 600;
}
@media (min-width: 638px) {
  ._NavItem--active_1tvxq_94 > ._NavItem-link_1tvxq_38 {
    border-top-color: transparent;
    border-right-color: var(--puck-color-azure-04);
  }
}
._NavItem_1tvxq_38:not(._NavItem--active_1tvxq_94) > ._NavItem-link_1tvxq_38:hover {
  background-color: var(--puck-color-azure-11);
  color: var(--puck-color-azure-04);
}
@media (min-width: 638px) {
  ._NavItem--mobileOnly_1tvxq_121 {
    display: none;
  }
}
._NavItem--desktopOnly_1tvxq_126 {
  display: none;
}
@media (min-width: 638px) {
  ._NavItem--desktopOnly_1tvxq_126 {
    display: block;
  }
}

/* css-module:/home/runner/work/puck/puck/packages/core/plugins/blocks/styles.module.css/#css-module-data */
._BlocksPlugin_1ey1i_1 {
  padding: 16px;
  height: 100%;
  overflow-y: auto;
  box-sizing: border-box;
}

/* css-module:/home/runner/work/puck/puck/packages/core/plugins/outline/styles.module.css/#css-module-data */
._OutlinePlugin_q92j6_1 {
  padding: 16px;
  height: 100%;
  overflow-y: auto;
  box-sizing: border-box;
}

/* css-module:/home/runner/work/puck/puck/packages/core/plugins/fields/styles.module.css/#css-module-data */
._FieldsPlugin_nd930_1 {
  background: white;
  height: 100%;
  overflow-y: auto;
}
._FieldsPlugin-header_nd930_7 {
  border-bottom: 1px solid var(--puck-color-grey-09);
  font-weight: 600;
  padding-bottom: 8px;
  padding-left: 16px;
  padding-right: 16px;
  padding-top: 8px;
}
@media (min-width: 638px) {
  ._FieldsPlugin-header_nd930_7 {
    padding: 16px;
  }
}

/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
:root {
  --radius: 0.625rem;
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 6px;

  --brand: #ec6820;
  --brand-hover: #c95511;
  --brand-soft: #fff0e8;
  --brand-foreground: #ffffff;

  --background: #ffffff;
  --foreground: #1d1d1f;

  --surface: #f5f5f7;
  --surface-muted: #eeeeef;
  --surface-elevated: #fbfbfd;

  --text-primary: #1d1d1f;
  --text-secondary: #3a3a3c;
  --text-muted: #6e6e73;
  --text-inverse: #ffffff;

  --border: rgba(60, 60, 67, 0.18);
  --input: rgba(60, 60, 67, 0.16);
  --ring: #ec6820;

  --primary: var(--brand);
  --primary-foreground: var(--brand-foreground);

  --secondary: #e8e8ed;
  --secondary-foreground: var(--text-primary);

  --muted: var(--text-muted);
  --muted-surface: #e8e8ed;
  --muted-foreground: var(--text-muted);

  --accent: var(--brand-soft);
  --accent-foreground: var(--brand);

  --card: var(--surface-elevated);
  --card-foreground: var(--text-primary);

  --popover: #ffffff;
  --popover-foreground: var(--text-primary);

  --destructive: #d92d20;
  --destructive-foreground: #ffffff;

  --color-primary: var(--brand);
  --color-primary-hover: var(--brand-hover);
  --color-brand-soft: var(--brand-soft);
  --color-background: var(--background);
  --color-surface: var(--surface-elevated);
  --color-surface-muted: var(--surface-muted);
  --color-text-primary: var(--text-primary);
  --color-text-secondary: var(--text-secondary);
  --color-text-muted: var(--text-muted);
  --color-border: var(--border);

  --ink: var(--text-primary);
  --line: var(--border);
  --accent-strong: var(--brand-hover);
  --blue: var(--text-secondary);
  --danger: var(--destructive);
  --danger-soft: #fff0ee;
  --warning: #a45f07;
  --warning-soft: #fff6df;
  --success: #147d45;
  --success-soft: #eaf8ef;
  --neutral-soft: var(--surface-muted);
  --shadow: 0 10px 28px rgba(29, 29, 31, 0.07);
}

* {
  box-sizing: border-box;
}

html {
  width: 100%;
  height: 100%;
  background: var(--background);
}

body {
  width: 100%;
  height: 100%;
  margin: 0;
  color: var(--ink);
  background: var(--background);
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
}

.font-inter {
  font-family:
    Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
}

.font-roboto {
  font-family:
    Roboto, Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
}

.text-title {
  margin: 0;
  line-height: 1.12;
  letter-spacing: 0;
  transition: color 0.2s ease;
}

.text-heading-1 {
  font-size: 3.25rem;
  font-weight: 650;
}

.text-heading-2 {
  font-size: 2.5rem;
  font-weight: 650;
}

.text-heading-3 {
  font-size: 2rem;
  font-weight: 650;
}

.text-heading-4 {
  font-size: 1.75rem;
  font-weight: 650;
}

.text-heading-5 {
  font-size: 1.5rem;
  font-weight: 650;
}

.text-heading-6 {
  font-size: 1.25rem;
  font-weight: 650;
}

.text-heading-7 {
  font-size: 1.125rem;
  font-weight: 650;
}

.text-heading-8 {
  font-size: 1rem;
  font-weight: 650;
}

.text-paragraph {
  margin: 0;
  transition: color 0.2s ease;
}

.text-body {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
}

.text-topic {
  font-size: 0.875rem;
  font-weight: 650;
  line-height: 1.35;
}

.text-color-white {
  color: var(--text-inverse);
}

.text-color-primary {
  color: var(--text-primary);
}

.text-color-secondary {
  color: var(--text-secondary);
}

.text-color-muted {
  color: var(--text-muted);
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  border: 0;
  cursor: pointer;
}

button:disabled {
  cursor: not-allowed;
  opacity: 0.58;
}

input,
select,
textarea {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 8px 12px;
  color: var(--color-text-primary);
  background: var(--color-surface);
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

textarea {
  min-height: 96px;
  resize: vertical;
}

input[type="file"] {
  padding: 8px;
}

input:hover,
select:hover,
textarea:hover {
  border-color: #cbd5e1;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(236, 104, 32, 0.14);
}

input::placeholder,
textarea::placeholder {
  color: #94a3b8;
}

select {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 44px;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--color-text-secondary) 50%),
    linear-gradient(135deg, var(--color-text-secondary) 50%, transparent 50%);
  background-position:
    calc(100% - 20px) 50%,
    calc(100% - 14px) 50%;
  background-size:
    6px 6px,
    6px 6px;
  background-repeat: no-repeat;
}

select::-ms-expand {
  display: none;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  box-shadow: 0 0 0 1000px var(--color-surface) inset !important;
  -webkit-text-fill-color: var(--color-text-primary) !important;
}

.field,
.inline-field,
.compact-select {
  position: relative;
}

.field:has(> select)::before,
.inline-field:has(> select)::before,
.compact-select:has(> select)::before {
  content: "";
  position: absolute;
  right: 36px;
  bottom: 8px;
  width: 1px;
  height: 24px;
  background: var(--color-border);
  pointer-events: none;
}

.field:has(> select)::after,
.inline-field:has(> select)::after,
.compact-select:has(> select)::after {
  content: "";
  position: absolute;
  display: none;
  right: 16px;
  bottom: 19px;
  width: 7px;
  height: 7px;
  border-right: 2px solid var(--color-text-secondary);
  border-bottom: 2px solid var(--color-text-secondary);
  transform: rotate(45deg);
  pointer-events: none;
  opacity: 0.9;
  transition: border-color 0.2s ease;
}

.field:has(> select:hover)::after,
.field:has(> select:focus)::after,
.inline-field:has(> select:hover)::after,
.inline-field:has(> select:focus)::after,
.compact-select:has(> select:hover)::after,
.compact-select:has(> select:focus)::after {
  border-color: var(--color-primary);
}

.loading-screen {
  min-height: 100dvh;
  display: grid;
  place-items: center;
  color: var(--muted);
}

.auth-shell {
  width: 100vw;
  height: 100dvh;
  min-height: 100dvh;
  margin: 0;
  display: grid;
  grid-template-columns: minmax(0, 65fr) minmax(320px, 35fr);
  grid-gap: 0;
  gap: 0;
  align-items: stretch;
  justify-content: stretch;
  padding: 0;
  overflow: hidden;
}

.brand-panel,
.auth-panel,
.workspace,
.form-panel,
.list-panel,
.admin-panel {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--card);
  box-shadow: var(--shadow);
}

.brand-panel {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100dvh;
  padding: clamp(28px, 5vw, 64px);
  color: #ffffff;
  border-color: var(--accent);
  border-width: 0;
  border-radius: 0;
  background: var(--brand);
  box-shadow: none;
  overflow: hidden;
}

.brand-panel::before {
  content: "";
  position: absolute;
  inset: 8%;
  background: url("/logo-dark.png") center / min(58vw, 760px) no-repeat;
  opacity: 0.1;
  transform: rotate(-8deg);
  pointer-events: none;
}

.brand-panel > * {
  position: relative;
  z-index: 1;
}

.brand-panel-top {
  display: flex;
  align-items: center;
  gap: 14px;
}

.brand-panel-top strong {
  display: block;
  margin-top: 3px;
  color: #ffffff;
  font-size: 0.98rem;
}

.brand-mark {
  width: 52px;
  height: 52px;
  flex: 0 0 52px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: var(--radius-md);
  color: #ffffff;
  font-weight: 800;
  background: rgba(255, 255, 255, 0.12);
}

.brand-panel h1 {
  max-width: 360px;
  margin: 0 0 12px;
  font-size: 2.2rem;
  line-height: 1.05;
  letter-spacing: 0;
}

.brand-logo {
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.14);
  overflow: hidden;
}

.brand-logo img {
  max-width: 46px;
  max-height: 46px;
  object-fit: contain;
}

.brand-panel p {
  max-width: 340px;
  margin: 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 0.98rem;
  line-height: 1.55;
}

.brand-panel .eyebrow {
  color: rgba(255, 255, 255, 0.78);
}

.admin-context-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.auth-topic-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  min-height: 104px;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 14px;
  padding: 16px;
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 38px rgba(52, 20, 0, 0.12);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}

.auth-topic-icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  color: var(--brand);
  background: var(--brand-soft);
}

.auth-topic-copy {
  min-width: 0;
  display: grid;
  grid-gap: 5px;
  gap: 5px;
}

.auth-topic-copy span {
  color: var(--text-muted);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.auth-topic-copy strong {
  color: var(--text-primary);
  font-size: 0.98rem;
  line-height: 1.2;
}

.auth-topic-badge {
  align-self: start;
  min-width: 34px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #0f7a52;
  background: #dff8ee;
  font-size: 0.72rem;
  font-weight: 850;
}

.auth-topic-card-purple .auth-topic-badge {
  color: #5e44d5;
  background: #eee9ff;
}

.auth-topic-card-green .auth-topic-badge {
  color: #0f7a52;
  background: #dff8ee;
}

.auth-panel {
  align-self: center;
  width: 100%;
  max-width: 412px;
  min-height: auto;
  justify-self: center;
  padding: 36px;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}

.auth-header {
  display: grid;
  justify-items: start;
  margin-bottom: 20px;
}

.auth-logo {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  overflow: hidden;
}

.auth-logo img {
  max-width: 42px;
  max-height: 42px;
  object-fit: contain;
}

.auth-header h2 {
  margin: 4px 0 8px;
  font-size: 1.55rem;
  letter-spacing: 0;
}

.auth-header p {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.field {
  display: grid;
  grid-gap: 7px;
  gap: 7px;
}

.field span,
.eyebrow {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.eyebrow {
  display: block;
  margin-bottom: 6px;
}

.form-stack {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.input-action-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.input-action-wrap input {
  padding-right: 44px;
}

.field-icon-button {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  background: transparent;
}

.field-icon-button:hover {
  color: var(--color-primary);
  background: var(--color-brand-soft);
}

.segmented-control,
.tabbar {
  display: flex;
  gap: 4px;
  height: 40px;
  padding: 3px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: #343438;
}

.segmented-control {
  margin: 18px 0;
}

.segmented-control button,
.tabbar button {
  flex: 1 1;
  min-height: 0;
  height: 32px;
  border-radius: var(--radius-md);
  color: rgba(255, 255, 255, 0.72);
  background: transparent;
  font-weight: 700;
  padding: 0 10px;
}

.segmented-control .selected,
.tabbar .selected {
  color: #ffffff;
  background: var(--brand);
  box-shadow: none;
}

.primary-action,
.ghost-action,
.danger-action {
  min-height: 40px;
  border-radius: var(--radius-md);
  padding: 8px 14px;
  font-weight: 800;
  white-space: nowrap;
  border: 1px solid transparent;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.primary-action {
  color: #ffffff;
  background: var(--brand);
  border-color: var(--brand);
}

.primary-action:hover {
  color: #ffffff;
  background: var(--brand-hover);
  border-color: var(--brand-hover);
  transform: translateY(-1px);
}

.ghost-action {
  border: 1px solid var(--line);
  color: var(--ink);
  background: var(--surface);
}

.ghost-action:hover {
  border-color: #b7c4d3;
  background: #f8fafc;
}

.danger-action {
  color: var(--danger);
  background: var(--danger-soft);
  border-color: transparent;
}

.danger-action:hover {
  background: #ffe3df;
}

.icon-action,
.icon-only-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.icon-only-action {
  width: 40px;
  min-width: 40px;
  padding: 0;
}

.feedback {
  margin: 14px 0;
  border-radius: 8px;
  padding: 12px 14px;
  font-weight: 700;
  line-height: 1.45;
}

.feedback.success {
  color: var(--success);
  background: var(--success-soft);
}

.feedback.error {
  color: var(--danger);
  background: var(--danger-soft);
}

.feedback.info {
  color: var(--blue);
  background: #f2f2f3;
}

.dashboard-shell {
  width: min(1440px, calc(100% - 48px));
  margin: 0 auto;
  padding: 18px 0 56px;
}

.topbar {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  min-height: 64px;
  border: 0;
  border-radius: 0;
  padding: 0 0 14px;
  background: transparent;
  box-shadow: none;
}

.topbar-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 260px;
}

.topbar-logo {
  position: relative;
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  display: block;
  object-fit: contain;
  overflow: hidden;
}

.topbar-divider {
  width: 1px;
  height: 32px;
  background: rgba(60, 60, 67, 0.12);
}

.topbar-company-logo {
  position: absolute;
  left: 50%;
  top: 50%;
  max-width: 148px;
  max-height: 44px;
  object-fit: contain;
  transform: translate(-50%, -50%);
}

.topbar h1,
.section-heading h2,
.section-heading h3 {
  margin: 3px 0 0;
  letter-spacing: 0;
}

.topbar h1 {
  font-size: 2rem;
}

.topbar-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.user-initials-chip {
  width: 38px;
  height: 38px;
  display: inline-flex;
  flex: 0 0 38px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 77, 0, 0.22);
  border-radius: 50%;
  color: var(--brand);
  background: var(--brand-soft);
  font-size: 0.82rem;
  font-weight: 850;
}

.user-name-chip {
  min-height: 38px;
  max-width: min(280px, 48vw);
  display: inline-flex;
  flex: 0 1 auto;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 0 14px;
  color: var(--brand);
  background: rgba(255, 77, 0, 0.14);
  font-size: 0.84rem;
  font-weight: 850;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.user-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 260px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 8px 10px;
  background: var(--card);
}

.user-chip-avatar {
  width: 36px;
  height: 36px;
  display: inline-flex;
  flex: 0 0 36px;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  color: var(--brand);
  background: var(--brand-soft);
  font-size: 0.82rem;
  font-weight: 850;
}

.user-chip-content {
  min-width: 0;
  display: grid;
  grid-gap: 1px;
  gap: 1px;
}

.user-chip-content strong,
.user-chip-content small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.company-readonly {
  display: grid;
  min-width: 220px;
  grid-gap: 3px;
  gap: 3px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 12px;
  background: var(--surface);
}

.company-readonly span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.company-readonly strong {
  overflow-wrap: anywhere;
}

.user-chip span,
.user-chip small,
.api-base,
.row-main strong,
.row-main small,
.row-meta span,
.audit-line span,
.audit-line small {
  overflow-wrap: anywhere;
}

.user-chip span {
  font-weight: 800;
}

.user-chip small {
  color: var(--muted);
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
  margin-bottom: 16px;
}

.summary-grid article {
  min-height: 98px;
  display: grid;
  align-content: space-between;
  border: 1px solid transparent;
  border-radius: 8px;
  padding: 16px;
  background: var(--surface);
  box-shadow: none;
}

.summary-grid article:first-child {
  color: #ffffff;
  background: var(--brand);
}

.summary-grid article:first-child span {
  color: rgba(255, 255, 255, 0.78);
}

.summary-grid span {
  color: var(--muted);
  font-weight: 700;
}

.summary-grid strong {
  font-size: 1.7rem;
  letter-spacing: 0;
}

.summary-grid .api-base {
  font-size: 1rem;
}

.summary-text {
  font-size: 1rem;
}

.tabbar {
  max-width: 560px;
  margin-bottom: 16px;
}

.dashboard-tabs {
  position: relative;
  display: flex;
  min-height: 48px;
  align-items: center;
  gap: 1px;
  margin: 10px 0 20px;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
}

.dashboard-tabs::-webkit-scrollbar {
  display: none;
}

.dashboard-tabs-indicator {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  background: var(--brand);
  transition: width 0.3s ease, transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}

.dashboard-tabs button {
  position: relative;
  flex: 0 0 auto;
  height: 48px;
  padding: 0 18px;
  color: var(--text-muted);
  background: transparent;
  font-size: 0.9rem;
  font-weight: 650;
  transition: color 0.2s ease;
}

.dashboard-tabs button:hover,
.dashboard-tabs button.selected {
  color: var(--text-primary);
}

.compact-select {
  display: grid;
  min-width: 220px;
  grid-gap: 4px;
  gap: 4px;
}

.compact-select span,
.inline-field span,
.check-field span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.compact-select select {
  min-height: 42px;
  background-color: var(--surface);
  background-image:
    linear-gradient(45deg, transparent 50%, var(--color-text-secondary) 50%),
    linear-gradient(135deg, var(--color-text-secondary) 50%, transparent 50%);
  background-position:
    calc(100% - 20px) 50%,
    calc(100% - 14px) 50%;
  background-size:
    6px 6px,
    6px 6px;
  background-repeat: no-repeat;
}

.workspace {
  padding: 0;
  border: 0;
  background: #ffffff;
  box-shadow: none;
}

.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.section-heading.compact {
  margin-bottom: 14px;
}

.split-workspace {
  display: grid;
  grid-template-columns: minmax(300px, 0.55fr) minmax(0, 1fr);
  grid-gap: 16px;
  gap: 16px;
  border: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.reader-workspace {
  display: block;
}

.form-panel,
.list-panel,
.admin-panel {
  padding: 20px;
  border-color: transparent;
  background: var(--surface);
  box-shadow: none;
}

.form-panel {
  display: grid;
  align-content: start;
  grid-gap: 14px;
  gap: 14px;
}

.form-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.form-actions .primary-action {
  flex: 1 1 180px;
}

.data-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.compact-list {
  gap: 8px;
}

.data-row {
  display: grid;
  grid-template-columns: minmax(240px, 1.3fr) minmax(190px, 0.9fr) auto auto;
  align-items: center;
  grid-gap: 14px;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #ffffff;
}

.company-row {
  grid-template-columns: minmax(220px, 1.2fr) minmax(220px, 1fr) auto;
}

.company-row-logo {
  width: 58px;
  height: 38px;
  object-fit: contain;
}

.company-logo-preview {
  display: grid;
  place-items: center;
  min-height: 96px;
  border: 1px dashed #c5d0dc;
  border-radius: 8px;
  padding: 12px;
  background: #fbfcfe;
}

.company-logo-preview img {
  max-width: 220px;
  max-height: 72px;
  object-fit: contain;
}

.admin-session-row {
  grid-template-columns: minmax(240px, 1.1fr) minmax(190px, 0.85fr) auto minmax(240px, auto);
}

.compact-row {
  grid-template-columns: minmax(240px, 1.2fr) minmax(220px, 1fr) auto;
}

.user-row {
  grid-template-columns:
    minmax(220px, 1.1fr)
    minmax(140px, 0.6fr)
    minmax(140px, 0.6fr)
    auto
    auto;
}

.module-row {
  grid-template-columns: minmax(220px, 1fr) minmax(240px, 1fr) auto auto;
}

.permission-snapshot {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fbfcfe;
  color: var(--muted);
}

.permission-snapshot strong {
  color: var(--ink);
}

.contract-index-row {
  grid-template-columns: minmax(240px, 1.1fr) minmax(220px, 0.9fr) auto auto;
}

.folder-row {
  grid-template-columns: minmax(220px, 1fr) auto;
}

.file-row {
  grid-template-columns: minmax(220px, 1fr) auto auto;
}

.clickable-row {
  cursor: pointer;
}

.clickable-row:hover {
  border-color: #b7c4d3;
  background: #f8fafc;
}

.selected-row {
  border-color: var(--blue);
  background: #f2f2f3;
}

.request-row {
  grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) minmax(150px, auto);
}

.reimbursement-row,
.contract-row,
.control-row {
  grid-template-columns: minmax(240px, 1.15fr) minmax(190px, 0.8fr) auto;
}

.control-row {
  align-items: start;
}

.row-main,
.row-meta {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.row-main strong {
  font-size: 0.98rem;
}

.row-main small,
.row-meta,
.audit-line small {
  color: var(--muted);
  font-size: 0.88rem;
}

.row-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.inline-field {
  display: grid;
  grid-gap: 5px;
  gap: 5px;
}

.inline-field select {
  min-height: 38px;
}

.check-field {
  display: flex;
  align-items: center;
  gap: 9px;
}

.check-field input {
  width: 18px;
  min-height: 18px;
}

.central-workspace {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  border: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}

.central-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.65fr) minmax(0, 1fr);
  grid-gap: 16px;
  gap: 16px;
}

.inline-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 8px;
  gap: 8px;
}

.inline-form {
  display: grid;
  grid-template-columns: minmax(180px, 0.8fr) minmax(180px, 1fr) minmax(180px, 1fr) auto;
  grid-gap: 10px;
  gap: 10px;
  align-items: center;
  margin-bottom: 16px;
}

.inline-form input,
.inline-form select {
  min-height: 42px;
}

.ghost-upload {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 14px;
  background: var(--surface);
  color: var(--ink);
  font-weight: 800;
  cursor: pointer;
}

.ghost-upload input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.evidence-list {
  grid-column: 1 / -1;
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  padding-top: 4px;
}

.response-form,
.audit-thread {
  grid-column: 1 / -1;
}

.response-form,
.discussion-form {
  grid-template-columns: minmax(220px, 1fr) auto;
}

.audit-thread {
  display: grid;
  grid-gap: 5px;
  gap: 5px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
  color: var(--muted);
}

.evidence-item {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(180px, auto);
  grid-gap: 10px;
  gap: 10px;
  align-items: center;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}

.evidence-item div:first-child {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
}

.evidence-item small {
  color: var(--muted);
}

.ghost-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 14px;
  color: var(--ink);
  background: var(--surface);
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
}

.ghost-link:hover {
  border-color: #b7c4d3;
  background: #f8fafc;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 0.78rem;
  font-weight: 800;
  white-space: nowrap;
}

.status-pill.good {
  color: var(--success);
  background: var(--success-soft);
}

.status-pill.warning {
  color: var(--warning);
  background: var(--warning-soft);
}

.status-pill.danger {
  color: var(--danger);
  background: var(--danger-soft);
}

.status-pill.neutral {
  color: #485668;
  background: var(--neutral-soft);
}

.empty-state {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  border: 1px dashed #c5d0dc;
  border-radius: 8px;
  padding: 18px;
  color: var(--muted);
  background: #fbfcfe;
}

.empty-state strong {
  color: var(--ink);
}

.admin-workspace {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.contract-workspace {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.contract-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.contract-filters {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(180px, 0.35fr);
  grid-gap: 10px;
  gap: 10px;
  width: min(100%, 720px);
}

.contract-form {
  max-width: 920px;
}

.contract-details-grid {
  display: grid;
  grid-template-columns: minmax(280px, 0.42fr) minmax(0, 1fr);
  grid-gap: 16px;
  gap: 16px;
}

.contract-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}

.contract-title h3 {
  margin: 0;
  font-size: 1.45rem;
}

.detail-list {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 12px;
  gap: 12px;
  margin: 0;
}

.detail-list div {
  border-bottom: 1px solid var(--line);
  padding-bottom: 10px;
}

.detail-list dt {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
}

.detail-list dd {
  margin: 4px 0 0;
  color: var(--ink);
  font-weight: 750;
}

.detail-copy {
  margin: 18px 0 0;
  color: var(--muted);
  line-height: 1.6;
}

.full-upload {
  width: 100%;
  margin-bottom: 12px;
}

.contract-preview {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  margin-bottom: 14px;
}

.contract-preview > strong {
  color: var(--ink);
}

.contract-preview iframe {
  width: 100%;
  min-height: 720px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
}

.overview-workspace,
.modules-workspace,
.files-workspace {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-gap: 16px;
  gap: 16px;
}

.admin-panel {
  box-shadow: none;
}

.full-width {
  box-shadow: none;
}

.flat-panel {
  box-shadow: none;
}

.module-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.metric-tile {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  min-height: 112px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: #fbfcfe;
}

.metric-tile span,
.metric-tile small {
  color: var(--muted);
  font-weight: 700;
}

.metric-tile strong {
  font-size: 2rem;
}

.overview-columns {
  display: grid;
  grid-template-columns: minmax(0, 0.75fr) minmax(0, 1fr);
  grid-gap: 16px;
  gap: 16px;
}

.chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.module-chip {
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 8px 12px;
  color: var(--ink);
  background: #f8fafc;
  font-weight: 800;
}

.dashboard-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.dashboard-card {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  min-height: 142px;
  border: 1px solid rgba(23, 32, 42, 0.08);
  border-radius: 12px;
  padding: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.92)),
    #ffffff;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.04);
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.dashboard-card:hover {
  border-color: rgba(255, 77, 0, 0.22);
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
}

.dashboard-card-header {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-gap: 10px;
  gap: 10px;
  align-items: start;
}

.dashboard-card-icon {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  color: var(--brand);
  background: rgba(255, 77, 0, 0.1);
}

.dashboard-card-title {
  min-width: 0;
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.dashboard-card-title strong {
  color: var(--text-primary);
  font-size: 1rem;
  line-height: 1.25;
}

.dashboard-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.dashboard-card-status {
  padding-top: 1px;
}

.dashboard-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.dashboard-card-meta span {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(23, 32, 42, 0.08);
  border-radius: 999px;
  padding: 0 9px;
  color: var(--text-muted);
  background: #f8fafc;
  font-size: 0.78rem;
  font-weight: 760;
}

.card-heading-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}

.audit-feed {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

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

.audit-line {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  grid-gap: 10px;
  gap: 10px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
  background: #fbfcfe;
}

.audit-line div {
  display: grid;
  grid-gap: 3px;
  gap: 3px;
}

.audit-line strong {
  font-size: 0.95rem;
}

.home-workspace,
.home-builder-workspace {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.puck-home-canvas {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.puck-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  grid-gap: 18px;
  gap: 18px;
  min-height: 240px;
  border-radius: var(--radius-md);
  padding: 28px;
  color: #ffffff;
  background: #1f3e4e;
}

.puck-hero.tone-orange {
  background: linear-gradient(135deg, #d85500, #1f3e4e);
}

.puck-hero.tone-blue {
  background: linear-gradient(135deg, #2c68b1, #173447);
}

.puck-hero.tone-green {
  background: linear-gradient(135deg, #147d45, #1d3b38);
}

.puck-eyebrow {
  display: block;
  margin: 0 0 8px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
  opacity: 0.82;
}

.puck-hero h2 {
  max-width: 820px;
  margin: 0;
  font-size: 3.25rem;
  line-height: 1;
  letter-spacing: 0;
}

.puck-hero p:not(.puck-eyebrow) {
  max-width: 760px;
  margin: 14px 0 0;
  color: rgba(255, 255, 255, 0.84);
  font-size: 1.05rem;
  line-height: 1.55;
}

.puck-home-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  border-radius: var(--radius-md);
  padding: 12px 16px;
  color: var(--ink);
  background: #ffffff;
  font-weight: 850;
  text-decoration: none;
  white-space: nowrap;
}

.puck-home-section,
.puck-notice {
  border: 0;
  border-radius: 0;
  padding: 0;
  background: transparent;
}

.puck-home-section h3,
.puck-notice h3 {
  margin: 0;
  font-size: 1.25rem;
  letter-spacing: 0;
}

.puck-section-heading {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  margin-bottom: 14px;
}

.puck-section-heading p,
.puck-notice p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.puck-metric-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
  margin-top: 14px;
}

.puck-metric {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  background: var(--surface);
}

.puck-metric span {
  color: var(--muted);
  font-weight: 800;
}

.puck-metric strong {
  font-size: 1.55rem;
}

.puck-link-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.puck-link-tile {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  min-height: 120px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  color: var(--ink);
  background: var(--surface);
  text-decoration: none;
}

.puck-link-tile:hover {
  border-color: #b7c4d3;
  background: #f8fafc;
}

.puck-link-tile span {
  color: var(--muted);
  line-height: 1.45;
}

.powerbi-embed {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.powerbi-embed.expanded {
  margin-inline: -8px;
}

.powerbi-embed iframe {
  width: 100%;
  min-height: 320px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
}

.powerbi-placeholder {
  display: grid;
  place-items: center;
  grid-gap: 6px;
  gap: 6px;
  min-height: 320px;
  border: 1px dashed #c5d0dc;
  border-radius: 8px;
  padding: 18px;
  color: var(--muted);
  background: var(--surface);
  text-align: center;
}

.powerbi-placeholder strong {
  color: var(--ink);
}

.puck-image-block {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.puck-image-block.align-left figure,
.puck-image-block.align-left .puck-image-placeholder {
  justify-self: stretch;
}

.puck-image-block.align-center figure,
.puck-image-block.align-center .puck-image-placeholder {
  justify-self: stretch;
}

.puck-image-block.align-right figure,
.puck-image-block.align-right .puck-image-placeholder {
  justify-self: stretch;
}

.puck-image-block figure {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  margin: 0;
  max-width: 100%;
  width: -moz-fit-content;
  width: fit-content;
}

.puck-image-block img {
  display: block;
  max-width: 100%;
  border: 0;
  border-radius: 0;
  background: var(--surface);
}

.puck-image-block figcaption {
  color: var(--muted);
  font-size: 0.9rem;
  text-align: center;
}

.puck-image-placeholder {
  display: grid;
  place-items: center;
  grid-gap: 6px;
  gap: 6px;
  max-width: 100%;
  border: 1px dashed #c5d0dc;
  border-radius: 8px;
  padding: 18px;
  color: var(--muted);
  background: var(--surface);
  text-align: center;
}

.puck-image-placeholder strong {
  color: var(--ink);
}

.puck-upload-field {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.puck-upload-field textarea {
  min-height: 92px;
  width: 100%;
  resize: vertical;
}

.puck-upload-field label {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 9px 12px;
  background: var(--surface);
  color: var(--ink);
  font-weight: 800;
  cursor: pointer;
}

.puck-upload-field input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.puck-notice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.puck-notice.warning {
  border-color: #f0d08d;
  background: var(--warning-soft);
}

.puck-notice.success {
  border-color: #b6e2c8;
  background: var(--success-soft);
}

.puck-notice a {
  color: var(--blue);
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
}

.home-builder-toolbar {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(220px, 0.45fr) auto;
  align-items: end;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
  background: #fbfcfe;
}

.puck-editor-shell {
  overflow: hidden;
  min-height: 680px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
}

.workspace,
.form-panel,
.list-panel,
.admin-panel,
.summary-grid article,
.data-row,
.metric-tile,
.dashboard-card,
.audit-line,
.empty-state,
.company-logo-preview,
.permission-snapshot,
.puck-metric,
.puck-link-tile,
.powerbi-embed iframe,
.powerbi-placeholder,
.puck-image-placeholder,
.home-builder-toolbar,
.puck-editor-shell,
.contract-preview iframe {
  border-radius: var(--radius-md);
}

.workspace,
.form-panel,
.list-panel,
.admin-panel {
  box-shadow: none;
}

.workspace {
  border: 0;
  background: transparent;
}

.data-row,
.metric-tile,
.dashboard-card,
.audit-line,
.summary-grid article,
.puck-metric,
.puck-link-tile {
  background: var(--card);
  border-color: var(--border);
}

.dashboard-card-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: center;
  margin-top: auto;
}

.dashboard-card-actions > * {
  width: 100%;
}

.dashboard-open-link {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid rgba(255, 77, 0, 0.18);
  border-radius: 9px;
  padding: 0 14px;
  color: var(--brand);
  background: rgba(255, 77, 0, 0.08);
  font-weight: 850;
  text-decoration: none;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    transform 160ms ease;
}

.dashboard-open-link:hover {
  border-color: rgba(255, 77, 0, 0.28);
  background: rgba(255, 77, 0, 0.13);
  transform: translateY(-1px);
}

.dashboard-collection .pagination-bar {
  margin-top: 2px;
  border-top: 1px solid rgba(23, 32, 42, 0.08);
  border-radius: 0 0 10px 10px;
  padding-top: 14px;
}

.admin-alert-row {
  grid-template-columns: minmax(220px, 1fr) auto auto;
}

.admin-session-row {
  position: relative;
  padding-top: 42px;
}

.admin-session-row > .status-pill {
  position: absolute;
  top: 12px;
  right: 12px;
}

.stepper {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 6px;
  gap: 6px;
  min-height: 40px;
  padding: 4px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-muted);
}

.stepper button {
  min-height: 32px;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  background: transparent;
  font-weight: 800;
}

.stepper button.selected {
  color: var(--brand);
  background: var(--brand-soft);
}

.step-actions .primary-action,
.step-actions .ghost-action {
  flex: 1 1 140px;
}

.inline-upload {
  min-width: 220px;
}

.upload-krl {
  width: 100%;
  display: block;
  cursor: pointer;
}

.upload-krl.is-disabled {
  cursor: not-allowed;
  opacity: 0.58;
}

.input-krl-label {
  display: block;
  margin-bottom: 6px;
  color: var(--color-text-primary);
}

.upload-krl-box {
  width: 100%;
  min-height: 72px;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-lg);
  background: #f8fafc;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 18px;
  transition: border-color 0.2s ease, background 0.2s ease;
}

.upload-krl-box:hover {
  border-color: var(--color-primary);
  background: var(--brand-soft);
}

.upload-krl-info {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.upload-krl-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-md);
  background: var(--brand-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-primary);
  flex-shrink: 0;
}

.upload-krl-text {
  min-width: 0;
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.upload-krl-text strong {
  display: block;
  color: var(--color-text-primary);
  font-size: 14px;
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.upload-krl-text span {
  display: block;
  color: var(--color-text-secondary);
  font-size: 13px;
}

.upload-krl-action {
  min-height: 40px;
  padding: 0 18px;
  border-radius: var(--radius-md);
  background: var(--color-primary);
  color: #ffffff;
  font-size: 14px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

.upload-krl input[type="file"] {
  display: none !important;
}

.puck-editor-shell .Puck {
  --puck-color-azure-04: var(--brand);
  --puck-color-azure-05: var(--brand-hover);
  --puck-color-azure-10: var(--brand-soft);
  --puck-color-azure-11: #fff7ed;
  --puck-color-grey-12: var(--background);
  --puck-color-grey-11: var(--surface-muted);
  --puck-color-grey-09: var(--border);
  --puck-color-grey-03: var(--text-primary);
}

.file-explorer {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px;
  background: #ffffff;
}

.explorer-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 8px 10px;
  background: var(--surface);
}

.explorer-path {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  font-size: 0.88rem;
}

.explorer-path-item {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.explorer-path button {
  min-height: 30px;
  border-radius: var(--radius-sm);
  padding: 4px 8px;
  color: var(--text-primary);
  background: #ffffff;
  font-weight: 750;
}

.explorer-path button:hover {
  background: var(--brand-soft);
  color: var(--brand);
}

.explorer-search {
  position: relative;
  flex: 1 1 320px;
  max-width: 460px;
  min-width: 220px;
  color: var(--text-muted);
}

.explorer-search svg {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}

.explorer-search input {
  min-height: 36px;
  padding: 7px 40px 7px 36px;
  background: #ffffff;
}

.explorer-search-clear {
  position: absolute;
  right: 6px;
  top: 50%;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  background: transparent;
  transform: translateY(-50%);
}

.explorer-search-clear:hover {
  color: var(--brand);
  background: var(--brand-soft);
}

.explorer-path strong {
  min-width: 0;
  overflow: hidden;
  color: var(--text-primary);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.explorer-count {
  flex: 0 0 auto;
  color: var(--text-muted);
  font-size: 0.84rem;
  font-weight: 700;
}

.explorer-count-live + .explorer-count {
  display: none;
}

.explorer-layout {
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  grid-gap: 14px;
  gap: 14px;
}

.explorer-pane {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 16px;
  background: #ffffff;
}

.explorer-pane-single {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.explorer-item-list {
  display: grid;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: #ffffff;
}

.explorer-item-head,
.explorer-item-row {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 160px 170px 96px 124px;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  width: 100%;
  padding: 9px 12px;
}

.explorer-item-head {
  color: var(--text-muted);
  background: var(--surface);
  font-size: 0.76rem;
  font-weight: 850;
  text-transform: uppercase;
}

.explorer-item-row {
  min-height: 50px;
  border-top: 1px solid var(--border);
  color: var(--text-secondary);
  font-size: 0.88rem;
  text-align: left;
}

.explorer-folder-row {
  cursor: pointer;
}

.explorer-folder-row:hover,
.explorer-document-row:hover {
  background: #f8fbff;
}

.explorer-item-name {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--text-primary);
}

.explorer-item-name svg {
  flex: 0 0 auto;
  color: #64748b;
}

.explorer-folder-row .explorer-item-name svg {
  color: #d9a21d;
}

.explorer-item-name > span {
  min-width: 0;
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.explorer-item-name strong,
.explorer-item-name small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.explorer-item-name strong {
  font-size: 0.9rem;
}

.explorer-item-name small {
  color: var(--text-muted);
  font-size: 0.76rem;
}

.folder-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

.folder-tile {
  min-height: 112px;
  display: grid;
  align-content: center;
  justify-items: center;
  grid-gap: 10px;
  gap: 10px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: 14px 10px;
  color: #d9a21d;
  background: transparent;
  text-align: center;
  transition: background 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}

.folder-tile:hover,
.folder-tile.selected {
  border-color: #bcd5f4;
  background: #eef6ff;
}

.folder-tile.selected {
  box-shadow: inset 0 0 0 1px #78aee8;
}

.folder-tile span {
  min-width: 0;
  display: grid;
  grid-gap: 3px;
  gap: 3px;
  color: var(--text-primary);
}

.folder-tile strong,
.folder-tile small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.folder-tile strong {
  font-size: 0.9rem;
}

.folder-tile small {
  color: var(--text-muted);
  font-size: 0.76rem;
}

.windows-empty {
  min-height: 180px;
  display: grid;
  align-content: center;
  justify-items: center;
  grid-gap: 8px;
  gap: 8px;
  border: 1px dashed #cdd7e3;
  border-radius: var(--radius-md);
  padding: 24px;
  color: var(--text-muted);
  background: #fbfcfe;
  text-align: center;
}

.windows-empty svg {
  color: #d9a21d;
}

.windows-empty strong {
  color: var(--text-primary);
  font-size: 1rem;
}

.windows-empty span {
  max-width: 420px;
  line-height: 1.45;
}

.explorer-file-list {
  display: grid;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.explorer-file-head,
.explorer-file-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 120px 160px 132px;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  padding: 10px 12px;
}

.explorer-file-head {
  color: var(--text-muted);
  background: var(--surface);
  font-size: 0.78rem;
  font-weight: 850;
  text-transform: uppercase;
}

.explorer-file-row {
  min-height: 58px;
  border-top: 1px solid var(--border);
  color: var(--text-secondary);
}

.explorer-file-row:hover {
  background: #f8fbff;
}

.explorer-file-name {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--text-primary);
}

.explorer-file-name svg {
  flex: 0 0 auto;
  color: #64748b;
}

.explorer-file-name span {
  min-width: 0;
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.explorer-file-name strong,
.explorer-file-name small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.explorer-file-name small {
  color: var(--text-muted);
  font-size: 0.78rem;
}

.explorer-file-actions {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
}

.paginated-collection {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.pagination-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
  color: var(--text-muted);
  font-size: 0.84rem;
  font-weight: 700;
}

.pagination-bar > span {
  margin-right: auto;
}

.pagination-bar label {
  display: flex;
  align-items: center;
  gap: 8px;
}

.pagination-bar label span {
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 850;
  text-transform: uppercase;
}

.pagination-bar select {
  width: auto;
  min-width: 76px;
  min-height: 34px;
  padding-top: 5px;
  padding-bottom: 5px;
}

.pagination-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.pagination-actions strong {
  min-width: 52px;
  color: var(--text-primary);
  text-align: center;
}

@media (max-width: 1100px) {
  .split-workspace,
  .admin-grid,
  .contract-details-grid,
  .contract-filters,
  .central-grid,
  .inline-form,
  .evidence-item,
  .grid-feed,
  .overview-columns,
  .trial-form-section,
  .puck-hero,
  .home-builder-toolbar,
  .explorer-layout,
  .explorer-file-head,
  .explorer-file-row,
  .explorer-item-head,
  .explorer-item-row {
    grid-template-columns: 1fr;
  }

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

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

  .module-grid,
  .dashboard-card-grid,
  .puck-metric-row,
  .puck-link-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .data-row,
  .company-row,
  .admin-session-row,
  .compact-row,
  .user-row,
  .module-row,
  .contract-index-row,
  .folder-row,
  .file-row,
  .request-row,
  .reimbursement-row,
  .contract-row,
  .control-row {
    grid-template-columns: 1fr;
  }

  .row-actions {
    justify-content: flex-start;
  }

  .explorer-file-head,
  .explorer-item-head {
    display: none;
  }

  .explorer-file-row,
  .explorer-item-row {
    align-items: start;
  }

  .explorer-file-actions {
    justify-content: flex-start;
  }

  .pagination-bar {
    align-items: stretch;
    flex-direction: column;
  }

  .pagination-bar > span {
    margin-right: 0;
  }

  .pagination-actions {
    justify-content: space-between;
  }
}

@media (max-width: 720px) {
  .auth-shell {
    display: grid;
    grid-template-columns: 1fr;
    padding: 0;
    overflow: auto;
  }

  .auth-shell .brand-panel {
    display: none;
  }

  .auth-shell .auth-panel {
    min-height: 100dvh;
    display: grid;
    align-content: center;
    justify-self: center;
    padding: 24px 18px;
  }

  .brand-panel,
  .form-panel,
  .list-panel,
  .admin-panel {
    padding: 18px;
  }

  .brand-panel h1 {
    font-size: 2rem;
  }

  .text-heading-1 {
    font-size: 2.25rem;
  }

  .text-heading-2 {
    font-size: 1.9rem;
  }

  .dashboard-shell {
    width: min(100% - 24px, 1440px);
    padding-top: 12px;
  }

  .topbar,
  .section-heading {
    align-items: stretch;
    flex-direction: column;
  }

  .topbar-actions,
  .row-actions {
    justify-content: stretch;
  }

  .topbar-actions > *,
  .row-actions > *,
  .section-heading > button {
    width: 100%;
  }

  .topbar-actions > .icon-only-action {
    width: 40px;
    flex: 0 0 40px;
  }

  .topbar-actions > .user-initials-chip {
    width: 38px;
    flex: 0 0 38px;
  }

  .topbar-actions > .user-name-chip {
    width: auto;
    flex: 0 0 auto;
  }

  .summary-grid {
    grid-template-columns: 1fr;
  }

  .inline-grid,
  .check-grid {
    grid-template-columns: 1fr;
  }

  .module-grid,
  .dashboard-card-grid,
  .puck-metric-row,
  .puck-link-grid {
    grid-template-columns: 1fr;
  }

  .puck-hero,
  .puck-notice {
    padding: 18px;
  }

  .puck-hero h2 {
    font-size: 2.15rem;
  }

  .puck-notice {
    align-items: stretch;
    flex-direction: column;
  }

  .tabbar {
    max-width: none;
  }

  .wide-tabbar {
    display: flex;
    overflow-x: auto;
  }

  .wide-tabbar button {
    width: auto;
  }

  .upload-krl-box {
    align-items: flex-start;
    flex-direction: column;
  }

  .upload-krl-action {
    width: 100%;
    justify-content: center;
  }
}

/* Corporate portal shell */
:root {
  --brand: #c5521a;
  --brand-hover: #9f4012;
  --brand-soft: #fff4ed;
  --background: #f4f6f8;
  --surface: #f8fafc;
  --surface-muted: #eef2f6;
  --surface-elevated: #ffffff;
  --text-primary: #17202a;
  --text-secondary: #465464;
  --text-muted: #748193;
  --border: rgba(23, 32, 42, 0.12);
  --line: var(--border);
  --card: #ffffff;
  --shadow: 0 1px 2px rgba(15, 23, 42, 0.06), 0 12px 28px rgba(15, 23, 42, 0.05);
}

body {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(244, 246, 248, 0.96) 220px),
    var(--background);
}

.dashboard-shell {
  width: 100%;
  min-height: 100dvh;
  display: grid;
  grid-template-columns: 292px minmax(0, 1fr);
  grid-gap: 0;
  gap: 0;
  margin: 0;
  padding: 0;
  background: var(--background);
}

.app-sidebar {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  height: 100dvh;
  display: flex;
  flex-direction: column;
  gap: 18px;
  border-right: 1px solid var(--border);
  padding: 20px 16px;
  background: #ffffff;
  overflow-y: auto;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  padding: 0 4px 12px;
  border-bottom: 1px solid var(--border);
}

.sidebar-logo {
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.sidebar-brand div,
.sidebar-company div,
.sidebar-nav button span,
.topbar-title {
  min-width: 0;
}

.sidebar-brand strong,
.sidebar-company strong,
.topbar-title h1 {
  color: var(--text-primary);
}

.sidebar-brand strong {
  display: block;
  font-size: 0.98rem;
  line-height: 1.2;
}

.sidebar-brand span,
.sidebar-company span,
.sidebar-nav-group > span {
  color: var(--text-muted);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.sidebar-nav {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
  padding-bottom: 16px;
}

.sidebar-nav-group {
  display: grid;
  grid-gap: 5px;
  gap: 5px;
}

.sidebar-nav-group > span {
  padding: 0 8px 3px;
}

.sidebar-nav button {
  width: 100%;
  min-height: 48px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  grid-gap: 8px;
  gap: 8px;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: 6px 8px;
  color: var(--text-secondary);
  background: transparent;
  text-align: left;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.sidebar-nav button svg {
  justify-self: center;
  color: currentColor;
}

.sidebar-nav button strong,
.sidebar-nav button small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-nav button strong {
  color: inherit;
  font-size: 0.91rem;
  line-height: 1.18;
}

.sidebar-nav button small {
  margin-top: 2px;
  color: var(--text-muted);
  font-size: 0.74rem;
}

.sidebar-nav button:hover {
  border-color: var(--border);
  color: var(--text-primary);
  background: var(--surface);
}

.sidebar-nav button.selected {
  border-color: rgba(197, 82, 26, 0.22);
  color: var(--brand);
  background: var(--brand-soft);
}

.app-main {
  min-width: 0;
  display: grid;
  align-content: start;
  grid-gap: 16px;
  gap: 16px;
  padding: 22px clamp(18px, 3vw, 34px) 48px;
}

.topbar {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 20;
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid var(--border);
  padding: 0 0 14px;
  background: linear-gradient(180deg, var(--background) 72%, rgba(244, 246, 248, 0));
  -webkit-backdrop-filter: blur(12px);
          backdrop-filter: blur(12px);
}

.topbar-company-logo-center {
  position: absolute;
  left: 50%;
  top: 42%;
  width: min(160px, 22vw);
  max-height: 46px;
  object-fit: contain;
  transform: translate(-50%, -50%);
}

.topbar-title {
  display: grid;
  grid-gap: 2px;
  gap: 2px;
}

.topbar-title h1 {
  margin: 0;
  font-size: 1.45rem;
  line-height: 1.2;
  letter-spacing: 0;
}

.topbar-actions {
  gap: 10px;
}

.compact-user-chip {
  min-width: 210px;
  max-width: 280px;
  background: #ffffff;
}

.summary-grid {
  grid-template-columns: minmax(220px, 1.25fr) repeat(3, minmax(140px, 0.6fr));
  gap: 10px;
  margin: 0;
}

.summary-grid article {
  min-height: 82px;
  align-content: center;
  gap: 8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px;
  background: #ffffff;
}

.summary-grid article:first-child {
  color: var(--text-primary);
  background: #ffffff;
}

.summary-grid article:first-child span {
  color: var(--text-muted);
}

.summary-grid strong {
  font-size: 1.35rem;
  line-height: 1.1;
}

.summary-grid .summary-text,
.summary-grid .api-base {
  font-size: 0.96rem;
}

.content-stage {
  min-width: 0;
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.workspace,
.overview-workspace,
.modules-workspace,
.files-workspace,
.admin-workspace,
.contract-workspace,
.home-workspace,
.home-builder-workspace,
.central-workspace {
  gap: 16px;
}

.trial-landing {
  min-height: 100dvh;
  background:
    radial-gradient(circle at 12% 8%, rgba(255, 77, 0, 0.12), transparent 34%),
    linear-gradient(135deg, #fffaf7 0%, #f8fafc 48%, #ffffff 100%);
}

.trial-hero {
  min-height: 420px;
  display: grid;
  align-items: center;
  padding: clamp(36px, 8vw, 96px);
}

.trial-hero > div,
.trial-form-section {
  width: min(1120px, calc(100% - 40px));
  margin: 0 auto;
}

.trial-hero h1 {
  max-width: 780px;
  margin: 8px 0 14px;
  font-size: clamp(2.6rem, 6vw, 5rem);
  line-height: 0.98;
}

.trial-hero p {
  max-width: 620px;
  font-size: 1.08rem;
}

.trial-hero-action {
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 24px;
}

.trial-benefits {
  width: min(1120px, calc(100% - 40px));
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
  margin: 0 auto;
}

.trial-benefits article {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px;
  background: #ffffff;
}

.trial-benefits article span {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  color: var(--brand);
  background: rgba(255, 77, 0, 0.1);
}

.trial-form-section {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(320px, 1fr);
  grid-gap: 24px;
  gap: 24px;
  align-items: start;
  padding: 56px 0 72px;
}

.trial-request-form {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.trial-request-form textarea {
  min-height: 110px;
  resize: vertical;
}

.trial-row {
  grid-template-columns: minmax(0, 1fr) auto auto;
}

.trial-manual-form {
  gap: 16px;
}

.trial-manual-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.trial-manual-message {
  grid-column: span 2;
}

.trial-manual-message textarea {
  min-height: 88px;
}

.input-with-icon {
  position: relative;
  display: flex;
  align-items: center;
}

.input-with-icon svg {
  position: absolute;
  left: 12px;
  color: var(--color-primary);
}

.input-with-icon input {
  padding-left: 38px;
}

.field small {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 600;
}

.form-panel,
.list-panel,
.admin-panel {
  border-color: var(--border);
  border-radius: var(--radius-md);
  padding: 18px;
  background: #ffffff;
}

.flat-panel {
  border: 1px solid var(--border);
}

.section-heading {
  margin-bottom: 14px;
}

.section-heading h2,
.section-heading h3 {
  color: var(--text-primary);
}

.section-heading h2 {
  font-size: 1.18rem;
}

.section-heading h3 {
  font-size: 1rem;
}

.data-list {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.data-row,
.audit-line,
.dashboard-card,
.metric-tile,
.puck-metric,
.puck-link-tile {
  border-color: var(--border);
  border-radius: var(--radius-md);
  background: #ffffff;
}

.data-row {
  min-height: 62px;
  padding: 12px 14px;
}

.clickable-row {
  cursor: pointer;
}

.clickable-row:hover,
.selected-row {
  border-color: rgba(197, 82, 26, 0.26);
  background: var(--brand-soft);
}

.primary-action,
.ghost-action,
.danger-action,
.ghost-link,
.ghost-upload,
.upload-krl-action {
  border-radius: var(--radius-md);
  min-height: 38px;
  font-size: 0.86rem;
}

.primary-action {
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.24) inset;
}

.primary-action:hover {
  transform: none;
}

.status-pill {
  min-height: 26px;
  border-radius: 999px;
  font-size: 0.73rem;
}

input,
select,
textarea {
  min-height: 38px;
  background-color: #ffffff;
}

.puck-hero {
  min-height: 170px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 22px;
  color: var(--text-primary);
  background: #ffffff;
}

.puck-hero.tone-orange,
.puck-hero.tone-blue,
.puck-hero.tone-green {
  background: #ffffff;
}

.puck-hero p:not(.puck-eyebrow) {
  color: var(--text-secondary);
  font-size: 0.98rem;
}

.puck-hero h2 {
  font-size: 1.75rem;
  line-height: 1.12;
}

.puck-eyebrow {
  color: var(--brand);
  opacity: 1;
}

.puck-home-action {
  border: 1px solid var(--border);
  color: var(--text-primary);
  background: var(--surface);
}

.puck-notice {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px;
  background: #ffffff;
}

.auth-shell {
  background: #ffffff;
}

.brand-panel {
  background: #1f2933;
}

.brand-panel::before {
  opacity: 0.06;
}

.auth-topic-card {
  border-radius: var(--radius-md);
  box-shadow: none;
}

@media (max-width: 1180px) {
  .dashboard-shell {
    grid-template-columns: 248px minmax(0, 1fr);
  }

  .sidebar-nav button {
    grid-template-columns: 30px minmax(0, 1fr);
  }

  .compact-user-chip {
    min-width: 0;
  }

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

@media (max-width: 860px) {
  .dashboard-shell {
    display: block;
  }

  .app-sidebar {
    position: relative;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid var(--border);
    padding: 14px;
  }

  .sidebar-nav {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
  }

  .sidebar-nav-group {
    min-width: auto;
    display: flex;
    flex: 0 0 auto;
    gap: 8px;
  }

  .sidebar-nav-group > span,
  .sidebar-nav button small {
    display: none;
  }

  .sidebar-nav button {
    min-width: 132px;
    min-height: 42px;
    grid-template-columns: 28px minmax(0, 1fr);
    background: var(--surface);
  }

  .app-main {
    padding: 16px 14px 34px;
  }

  .topbar {
    position: relative;
    align-items: stretch;
    flex-direction: column;
    background: transparent;
  }

  .topbar-company-logo-center {
    position: static;
    order: -1;
    align-self: center;
    width: min(150px, 42vw);
    transform: none;
  }

  .topbar-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 620px) {
  .trial-benefits {
    grid-template-columns: 1fr;
  }

  .trial-manual-grid {
    grid-template-columns: 1fr;
  }

  .trial-manual-message {
    grid-column: auto;
  }

  .trial-row {
    grid-template-columns: 1fr;
  }

  .summary-grid,
  .admin-grid,
  .split-workspace,
  .overview-columns,
  .module-grid,
  .dashboard-card-grid,
  .puck-metric-row,
  .puck-link-grid {
    grid-template-columns: 1fr;
  }

  .topbar-actions > .compact-select,
  .topbar-actions > .compact-user-chip {
    width: 100%;
    max-width: none;
  }

.topbar-actions > .icon-only-action {
  width: 40px;
  flex: 0 0 40px;
}
}

/* Premium authentication experience */
.auth-shell-premium {
  grid-template-columns: minmax(0, 58fr) minmax(420px, 42fr);
  background:
    radial-gradient(circle at 18% 12%, rgba(236, 104, 32, 0.09), transparent 32%),
    linear-gradient(135deg, #fffaf7 0%, #f6f8fb 48%, #ffffff 100%);
}

.brand-panel-premium {
  justify-content: stretch;
  gap: clamp(24px, 4vw, 48px);
  padding: clamp(32px, 4.8vw, 72px);
  color: var(--text-primary);
  background:
    linear-gradient(140deg, rgba(255, 255, 255, 0.94), rgba(255, 246, 241, 0.82) 48%, rgba(245, 247, 250, 0.98)),
    var(--surface-elevated);
  border-right: 1px solid rgba(23, 32, 42, 0.08);
}

.brand-panel-premium::before {
  inset: auto -12% -24% 42%;
  width: min(42vw, 620px);
  height: min(42vw, 620px);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(236, 104, 32, 0.13), transparent 64%);
  opacity: 1;
  transform: none;
}

.brand-panel-premium::after {
  content: "";
  position: absolute;
  inset: 13% auto auto 8%;
  width: 220px;
  height: 220px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(197, 82, 26, 0.1), transparent 68%);
  pointer-events: none;
}

.brand-panel-premium .brand-panel-top {
  z-index: 2;
}

.brand-panel-premium .brand-panel-top strong {
  color: var(--text-primary);
  font-size: 1.02rem;
}

.brand-panel-premium .eyebrow {
  color: var(--text-muted);
}

.brand-panel-premium .brand-logo {
  width: 48px;
  height: 48px;
  flex-basis: 48px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 10px 28px rgba(23, 32, 42, 0.08);
}

.brand-panel-premium .brand-logo img {
  max-width: 32px;
  max-height: 32px;
}

.portal-badge {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid rgba(236, 104, 32, 0.18);
  border-radius: 999px;
  padding: 0 12px;
  color: var(--brand);
  background: rgba(255, 240, 232, 0.72);
  font-size: 0.76rem;
  font-weight: 850;
}

.brand-editorial {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  align-content: center;
  grid-gap: clamp(22px, 3.2vw, 40px);
  gap: clamp(22px, 3.2vw, 40px);
  flex: 1 1;
}

.brand-panel-premium .brand-panel-copy {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
}

.brand-panel-premium .brand-panel-copy h1 {
  max-width: none;
  margin: 0;
  color: var(--text-primary);
  font-size: clamp(2rem, 3.15vw, 3.55rem);
  font-weight: 720;
  line-height: 1.04;
}

.brand-panel-premium .brand-panel-copy p {
  max-width: none;
  color: var(--text-secondary);
  font-size: clamp(1rem, 1.3vw, 1.12rem);
}

.dashboard-preview-shell {
  position: relative;
  width: 100%;
  perspective: 1500px;
}

.dashboard-preview-shell::before {
  content: "";
  position: absolute;
  inset: 18% 0 -7% 11%;
  border-radius: 28px;
  background: rgba(236, 104, 32, 0.12);
  filter: blur(36px);
}

.dashboard-preview {
  position: relative;
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  min-height: 320px;
  overflow: hidden;
  border: 1px solid rgba(23, 32, 42, 0.1);
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 30px 70px rgba(23, 32, 42, 0.14), 0 2px 8px rgba(23, 32, 42, 0.06);
  transform: rotateX(2deg) rotateY(-4deg) rotateZ(0.35deg);
  transform-origin: center;
}

.dashboard-preview aside {
  display: grid;
  align-content: start;
  grid-gap: 12px;
  gap: 12px;
  border-right: 1px solid var(--border);
  padding: 18px 14px;
  background: #fbfcfd;
}

.preview-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.preview-brand img {
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.preview-brand i,
.preview-nav,
.dashboard-preview header i,
.dashboard-preview header strong,
.preview-summary strong,
.preview-summary i,
.preview-chart span,
.preview-chart i,
.preview-modules span {
  display: block;
  border-radius: 999px;
  background: var(--surface-muted);
}

.preview-brand i {
  width: 42px;
  height: 8px;
}

.preview-nav {
  width: 100%;
  height: 34px;
  border-radius: 8px;
}

.preview-nav.active {
  background: var(--brand-soft);
  box-shadow: inset 3px 0 0 var(--brand);
}

.preview-nav.short {
  width: 72%;
}

.dashboard-preview section {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
  align-content: start;
  padding: 20px;
  background:
    linear-gradient(180deg, rgba(248, 250, 252, 0.7), rgba(255, 255, 255, 0)),
    #ffffff;
}

.dashboard-preview header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
}

.dashboard-preview header span {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.dashboard-preview header i:first-child {
  width: 136px;
  height: 10px;
}

.dashboard-preview header i:last-child {
  width: 92px;
  height: 28px;
  border-radius: 8px;
  background: var(--brand-soft);
}

.dashboard-preview header strong {
  width: 122px;
  height: 38px;
  border-radius: 10px;
  background: #ffffff;
  border: 1px solid var(--border);
}

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

.preview-summary span {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px;
  background: #ffffff;
}

.preview-summary strong {
  width: 42px;
  height: 18px;
  background: var(--brand);
}

.preview-summary i {
  width: 88%;
  height: 8px;
}

.preview-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  grid-gap: 12px;
  gap: 12px;
}

.preview-chart,
.preview-modules {
  min-height: 172px;
  display: grid;
  align-content: end;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  background: #ffffff;
}

.preview-chart span {
  align-self: start;
  width: 110px;
  height: 10px;
}

.preview-chart i {
  height: 8px;
}

.preview-chart i:nth-child(2) {
  width: 62%;
  background: rgba(236, 104, 32, 0.72);
}

.preview-chart i:nth-child(3) {
  width: 82%;
}

.preview-chart i:nth-child(4) {
  width: 48%;
}

.preview-modules {
  align-content: start;
}

.preview-modules span {
  height: 38px;
  border-radius: 10px;
  background: var(--surface);
}

.preview-modules span:first-child {
  background: var(--brand-soft);
}

.auth-carousel {
  position: relative;
  z-index: 2;
  min-height: 146px;
  overflow: hidden;
}

.auth-carousel-slide {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) minmax(120px, 0.35fr);
  align-items: center;
  grid-gap: 14px;
  gap: 14px;
  border: 1px solid rgba(23, 32, 42, 0.1);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 42px rgba(23, 32, 42, 0.08);
  opacity: 0;
  transform: translateY(14px);
  animation: authSlide 12s infinite;
}

.auth-carousel-slide:nth-child(2) {
  animation-delay: 4s;
}

.auth-carousel-slide:nth-child(3) {
  animation-delay: 8s;
}

.auth-carousel-icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  color: var(--brand);
  background: var(--brand-soft);
}

.auth-carousel-slide strong,
.auth-carousel-slide small {
  display: block;
}

.auth-carousel-slide strong {
  margin-bottom: 5px;
  color: var(--text-primary);
  font-size: 1rem;
}

.auth-carousel-slide small {
  color: var(--text-secondary);
  line-height: 1.45;
}

.auth-carousel-preview {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.auth-carousel-preview span {
  height: 9px;
  border-radius: 999px;
  background: var(--surface-muted);
}

.auth-carousel-preview span:first-child {
  width: 72%;
  background: var(--brand);
}

.auth-carousel-preview span:nth-child(2) {
  width: 94%;
}

.auth-carousel-preview span:nth-child(3) {
  width: 58%;
}

.auth-carousel-dots {
  position: absolute;
  left: 18px;
  bottom: 14px;
  display: flex;
  gap: 5px;
}

.auth-carousel-dots i {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(116, 129, 147, 0.32);
}

.auth-carousel-dots i.active {
  width: 18px;
  background: var(--brand);
}

.auth-panel-premium {
  display: grid;
  align-content: center;
  grid-gap: 20px;
  gap: 20px;
  max-width: none;
  min-height: 100dvh;
  padding: clamp(28px, 5vw, 72px);
  background: rgba(255, 255, 255, 0.82);
}

.auth-card-premium {
  width: min(100%, 420px);
  justify-self: center;
  display: grid;
  grid-gap: 20px;
  gap: 20px;
}

.auth-panel-premium .auth-header {
  margin-bottom: 0;
}

.auth-panel-premium .auth-logo {
  width: 46px;
  height: 46px;
  margin-bottom: 20px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(23, 32, 42, 0.08);
}

.auth-panel-premium .auth-logo img {
  max-width: 30px;
  max-height: 30px;
}

.auth-panel-premium .auth-header h2 {
  margin: 4px 0 10px;
  color: var(--text-primary);
  font-size: clamp(1.85rem, 3vw, 2.35rem);
  font-weight: 720;
  line-height: 1.08;
}

.auth-panel-premium .auth-header p {
  max-width: 360px;
  color: var(--text-muted);
}

.auth-mode-control {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 4px;
  gap: 4px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 4px;
  background: var(--surface);
}

.auth-mode-control button,
.auth-mode-control span {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  border-radius: 9px;
  color: var(--text-muted);
  font-size: 0.83rem;
  font-weight: 780;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.auth-mode-control button {
  border: 0;
}

.auth-mode-control .selected {
  color: var(--text-primary);
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(23, 32, 42, 0.08);
}

.auth-form-premium {
  gap: 18px;
}

.auth-form-premium .field {
  gap: 8px;
}

.auth-form-premium .field span {
  color: var(--text-secondary);
  font-size: 0.78rem;
  font-weight: 780;
}

.auth-form-premium input {
  min-height: 50px;
  border-color: rgba(23, 32, 42, 0.14);
  border-radius: 12px;
  padding: 0 14px;
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(23, 32, 42, 0.04);
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.auth-form-premium .input-action-wrap input {
  padding-right: 46px;
}

.auth-form-premium input:hover {
  border-color: rgba(23, 32, 42, 0.24);
  background: #fffefe;
}

.auth-form-premium input:focus {
  border-color: rgba(236, 104, 32, 0.58);
  box-shadow: 0 0 0 4px rgba(236, 104, 32, 0.1), 0 1px 2px rgba(23, 32, 42, 0.05);
}

.auth-form-premium .field-icon-button {
  right: 7px;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  color: var(--text-muted);
}

.auth-form-premium .field-icon-button:hover {
  color: var(--brand);
  background: var(--brand-soft);
}

.auth-submit {
  min-height: 50px;
  border-radius: 12px;
  font-size: 0.95rem;
  font-weight: 820;
  box-shadow: 0 12px 24px rgba(197, 82, 26, 0.16);
}

.auth-submit:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 16px 28px rgba(197, 82, 26, 0.2);
}

.auth-security-note,
.auth-panel-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  font-size: 0.8rem;
}

.auth-security-note {
  border-top: 1px solid var(--border);
  padding-top: 14px;
}

.auth-security-note svg {
  color: var(--success);
}

.auth-panel-footer {
  justify-content: center;
  align-self: end;
  flex-wrap: wrap;
}

.auth-panel-footer span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

@keyframes authSlide {
  0%,
  7% {
    opacity: 0;
    transform: translateY(14px);
  }
  12%,
  31% {
    opacity: 1;
    transform: translateY(0);
  }
  38%,
  100% {
    opacity: 0;
    transform: translateY(-14px);
  }
}

@media (max-width: 1180px) {
  .auth-shell-premium {
    grid-template-columns: minmax(0, 54fr) minmax(390px, 46fr);
  }

  .brand-editorial {
    grid-template-columns: 1fr;
    align-content: center;
  }

  .dashboard-preview-shell {
    max-width: 560px;
  }

  .dashboard-preview {
    min-height: 300px;
  }
}

@media (max-height: 760px) and (min-width: 721px) {
  .brand-panel-premium {
    gap: 18px;
    padding: clamp(28px, 4.8vh, 40px) clamp(42px, 5vw, 66px);
  }

  .brand-editorial {
    align-content: start;
    gap: 18px;
  }

  .brand-panel-premium .brand-panel-copy {
    gap: 10px;
  }

  .brand-panel-premium .brand-panel-copy h1 {
    font-size: clamp(2rem, 3vw, 2.7rem);
    line-height: 1.02;
  }

  .brand-panel-premium .brand-panel-copy p {
    font-size: 0.98rem;
    line-height: 1.45;
  }

  .dashboard-preview {
    grid-template-columns: 94px minmax(0, 1fr);
    min-height: 260px;
  }

  .dashboard-preview aside {
    gap: 10px;
    padding: 16px 12px;
  }

  .preview-nav {
    height: 30px;
  }

  .dashboard-preview section {
    gap: 14px;
    padding: 16px;
  }

  .preview-summary span {
    gap: 9px;
    padding: 11px;
  }

  .preview-grid {
    gap: 10px;
  }

  .preview-chart,
  .preview-modules {
    min-height: 130px;
    gap: 9px;
    padding: 13px;
  }

  .preview-modules span {
    height: 30px;
  }

  .auth-carousel {
    min-height: 112px;
    flex: 0 0 112px;
  }

  .auth-carousel-slide {
    grid-template-columns: auto minmax(0, 1fr) minmax(92px, 0.28fr);
    gap: 12px;
    padding: 14px;
  }

  .auth-carousel-icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
  }
}

@media (max-width: 720px) {
  .auth-shell-premium {
    grid-template-columns: 1fr;
    min-height: 100dvh;
    overflow: auto;
  }

  .auth-shell-premium .brand-panel-premium {
    display: none;
  }

  .auth-panel-premium {
    min-height: 100dvh;
    padding: 28px 20px;
    background:
      radial-gradient(circle at 18% 8%, rgba(236, 104, 32, 0.1), transparent 38%),
      #ffffff;
  }

  .auth-card-premium {
    width: 100%;
  }

  .auth-panel-premium .auth-header h2 {
    font-size: 2rem;
  }

  .auth-panel-footer {
    align-self: auto;
  }
}

.ux-landing {
  --ux-primary: #ff4d00;
  --ux-primary-hover: #d94400;
  --ux-foreground: #060606;
  --ux-background: #ffffff;
  --ux-muted: #747474;
  --ux-border: #e8e8e8;
  --ux-gray-light: #f4f4f4;
  width: 100%;
  min-height: 100vh;
  overflow-x: hidden;
  color: var(--ux-foreground);
  background: var(--ux-background);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

.ux-landing * {
  letter-spacing: 0;
}

.ux-container {
  width: min(100% - 32px, 1180px);
  margin: 0 auto;
}

.ux-appbar {
  position: fixed;
  inset: 0 0 auto;
  z-index: 50;
  display: flex;
  justify-content: center;
  background: transparent;
}

.ux-appbar-inner {
  height: 72px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  grid-gap: 24px;
  gap: 24px;
}

.ux-menu-button,
.ux-access-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  text-decoration: none;
}

.ux-menu-button {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}

.ux-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.ux-logo img {
  width: auto;
  height: 40px;
  object-fit: contain;
}

.ux-access-button {
  justify-self: end;
  min-height: 40px;
  border-radius: 999px;
  padding: 0 18px;
  color: #ffffff;
  background: var(--ux-primary);
  font-size: 0.82rem;
  font-weight: 800;
  transition: background 0.18s ease, transform 0.18s ease;
}

.ux-access-button:hover {
  background: var(--ux-primary-hover);
  transform: translateY(-1px);
}

.ux-access-button-light {
  justify-self: start;
  margin-top: 18px;
}

.ux-hero {
  position: relative;
  min-height: 912px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #060606 url("/ux-landing/hero-bg-pattern.svg") center top / cover no-repeat;
}

.ux-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(6, 6, 6, 0.92), rgba(6, 6, 6, 0.72) 48%, rgba(6, 6, 6, 0.5)),
    linear-gradient(180deg, rgba(6, 6, 6, 0.08), rgba(6, 6, 6, 0.35));
}

.ux-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 0.9fr);
  align-items: center;
  grid-gap: 64px;
  gap: 64px;
  padding-top: 96px;
}

.ux-hero-copy,
.ux-stack,
.ux-form-copy,
.ux-dark-section article {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ux-stamp {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  align-items: center;
  border-radius: 999px;
  padding: 7px 12px;
  color: var(--ux-primary);
  background: rgba(255, 77, 0, 0.11);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.ux-hero h1,
.ux-section h2,
.ux-form-copy h2,
.ux-dark-section h2 {
  margin: 0;
  font-weight: 860;
  line-height: 0.96;
}

.ux-hero h1 {
  max-width: 760px;
  color: #ffffff;
  font-size: clamp(3.4rem, 7vw, 6.9rem);
}

.ux-hero h1 span {
  color: var(--ux-primary);
}

.ux-hero p {
  max-width: 700px;
  margin: 16px 0 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(1rem, 1.45vw, 1.25rem);
  line-height: 1.65;
}

.ux-quick-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.ux-quick-links a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  padding: 10px 14px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.06);
  text-decoration: none;
  font-size: 0.86rem;
  font-weight: 700;
}

.ux-hero-cards {
  position: relative;
  min-height: 610px;
}

.ux-floating-card {
  position: absolute;
  border: 1px solid rgba(8, 8, 8, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.24);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
}

.ux-focus-card {
  top: 32px;
  left: 0;
  z-index: 3;
  width: min(100%, 360px);
  padding: 24px;
}

.ux-card-icon {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  color: var(--ux-primary);
  background: rgba(255, 77, 0, 0.12);
}

.ux-focus-card h2,
.ux-validation-card h3,
.ux-approval-card h3,
.ux-intel-card strong {
  margin: 14px 0 8px;
  color: var(--ux-foreground);
  font-size: 1.18rem;
  line-height: 1.15;
}

.ux-focus-card p,
.ux-validation-card p,
.ux-intel-card p,
.ux-approval-card p {
  margin: 0;
  color: var(--ux-muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.ux-mini-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 10px;
  gap: 10px;
  margin-top: 18px;
}

.ux-mini-grid span {
  border-radius: 12px;
  padding: 12px;
  color: var(--ux-muted);
  background: var(--ux-gray-light);
  font-size: 0.78rem;
}

.ux-mini-grid strong {
  display: block;
  margin-top: 4px;
  color: var(--ux-foreground);
  font-size: 0.98rem;
}

.ux-validation-card {
  top: 210px;
  right: 0;
  z-index: 2;
  width: min(100%, 330px);
  padding: 22px;
}

.ux-card-eyebrow,
.ux-intel-card > div span,
.ux-benefit-card span {
  color: var(--ux-primary);
  font-size: 0.68rem;
  font-weight: 900;
  text-transform: uppercase;
}

.ux-validation-card > div,
.ux-intel-card > div,
.ux-approval-card {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ux-validation-card svg,
.ux-intel-card svg {
  color: var(--ux-primary);
}

.ux-validation-card h3 {
  margin: 0;
}

.ux-progress {
  height: 8px;
  overflow: hidden;
  margin-top: 18px;
  border-radius: 999px;
  background: #eceff2;
}

.ux-progress span {
  display: block;
  width: 72%;
  height: 100%;
  border-radius: inherit;
  background: var(--ux-primary);
}

.ux-intel-card {
  right: 52px;
  bottom: 56px;
  z-index: 4;
  width: 250px;
  padding: 20px;
}

.ux-intel-card > div {
  justify-content: space-between;
}

.ux-intel-card strong {
  display: block;
  margin: 18px 0 4px;
  color: var(--ux-primary);
  font-size: 3.4rem;
}

.ux-bars {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: end;
  grid-gap: 8px;
  gap: 8px;
  height: 72px;
  margin-top: 18px;
}

.ux-bars span {
  border-radius: 999px 999px 4px 4px;
  background: rgba(255, 77, 0, 0.18);
}

.ux-bars span:nth-child(1) { height: 42%; }
.ux-bars span:nth-child(2) { height: 76%; background: var(--ux-primary); }
.ux-bars span:nth-child(3) { height: 54%; }
.ux-bars span:nth-child(4) { height: 88%; background: var(--ux-primary); }
.ux-bars span:nth-child(5) { height: 64%; }

.ux-approval-card {
  left: 40px;
  bottom: 72px;
  z-index: 5;
  width: min(100%, 320px);
  padding: 18px;
}

.ux-approval-card svg {
  flex: 0 0 auto;
  color: #18a058;
}

.ux-approval-card h3 {
  margin: 0 0 4px;
}

.ux-dashboard-preview {
  position: absolute;
  inset: 96px 52px auto auto;
  width: 330px;
  height: 360px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.08);
  opacity: 0.45;
}

.ux-dashboard-preview div {
  position: absolute;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.16);
}

.ux-dashboard-preview div:nth-child(1) {
  inset: 28px 28px auto;
  height: 48px;
}

.ux-dashboard-preview div:nth-child(2) {
  left: 28px;
  right: 28px;
  bottom: 34px;
  height: 120px;
}

.ux-dashboard-preview div:nth-child(3) {
  left: 28px;
  top: 100px;
  width: 130px;
  height: 92px;
}

.ux-dashboard-preview svg {
  position: absolute;
  right: 44px;
  top: 124px;
  color: rgba(255, 77, 0, 0.8);
}

.ux-section,
.ux-form-section,
.ux-dark-section {
  position: relative;
  display: flex;
  width: 100%;
  justify-content: center;
}

.ux-section {
  padding: 72px 0;
}

.ux-section-header {
  display: flex;
  max-width: 860px;
  flex-direction: column;
  gap: 10px;
}

.ux-section h2,
.ux-form-copy h2,
.ux-dark-section h2 {
  font-size: clamp(2.25rem, 4.5vw, 4.65rem);
}

.ux-section-header p,
.ux-form-copy li,
.ux-dark-section p {
  max-width: 720px;
  margin: 0;
  color: var(--ux-muted);
  font-size: 1rem;
  line-height: 1.7;
}

.ux-pillar-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 20px;
  gap: 20px;
}

.ux-pillar-card,
.ux-access-card {
  border-radius: 14px;
  background: var(--ux-foreground);
  padding: 24px;
}

.ux-pillar-card svg {
  color: var(--ux-primary);
}

.ux-pillar-card h3,
.ux-access-card h3,
.ux-benefit-card h3,
.ux-step h3 {
  margin: 12px 0 8px;
  font-size: 1.18rem;
  line-height: 1.2;
}

.ux-pillar-card h3,
.ux-access-card span {
  color: var(--ux-primary);
}

.ux-pillar-card p,
.ux-access-card p,
.ux-benefit-card p,
.ux-step p {
  margin: 0;
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.92rem;
  line-height: 1.65;
}

.ux-form-section {
  border-top: 2px solid var(--ux-border);
  padding: 60px 0;
}

.ux-form-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(420px, 1fr);
  align-items: start;
  grid-gap: 56px;
  gap: 56px;
}

.ux-form-copy ul {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.ux-form-copy li {
  position: relative;
  padding-left: 16px;
}

.ux-form-copy li::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--ux-muted);
}

.ux-request-form {
  display: grid;
  grid-gap: 16px;
  gap: 16px;
  width: 100%;
  border: 1px solid var(--ux-border);
  border-radius: 16px;
  padding: 24px;
  background: #ffffff;
}

.ux-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.ux-field {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.ux-field span {
  color: #565656;
  font-size: 0.74rem;
  font-weight: 900;
  text-transform: uppercase;
}

.ux-field input,
.ux-field textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid #d7d7d7;
  border-radius: 10px;
  padding: 0 14px;
  color: var(--ux-foreground);
  background: #ffffff;
  font: inherit;
  outline: none;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.ux-field textarea {
  min-height: 108px;
  padding-top: 12px;
  resize: vertical;
}

.ux-field input:focus,
.ux-field textarea:focus {
  border-color: rgba(255, 77, 0, 0.62);
  box-shadow: 0 0 0 4px rgba(255, 77, 0, 0.1);
}

.ux-submit {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border: 0;
  border-radius: 10px;
  color: #ffffff;
  background: var(--ux-primary);
  font-size: 0.95rem;
  font-weight: 900;
  cursor: pointer;
}

.ux-submit:disabled {
  cursor: wait;
  opacity: 0.72;
}

.ux-dark-section {
  overflow: hidden;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  padding: 72px 0;
  color: #ffffff;
  background: #060606;
}

.ux-audience-section,
.ux-benefits-section {
  background-image:
    linear-gradient(rgba(6, 6, 6, 0.84), rgba(6, 6, 6, 0.84)),
    url("/ux-landing/mockup.svg");
  background-position: center;
  background-size: cover;
}

.ux-audience-grid,
.ux-benefits-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr);
  grid-gap: 56px;
  gap: 56px;
  align-items: start;
}

.ux-dark-section h2 {
  color: #ffffff;
}

.ux-dark-section p {
  color: rgba(255, 255, 255, 0.78);
}

.ux-audience-list {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.ux-audience-list div {
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  padding: 18px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.03);
  font-weight: 700;
}

.ux-access-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 20px;
  gap: 20px;
}

.ux-access-card span {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255, 77, 0, 0.16);
  font-weight: 900;
}

.ux-benefits-grid {
  align-items: center;
}

.ux-benefits-cards {
  position: relative;
  min-height: 560px;
}

.ux-benefit-card {
  position: absolute;
  width: 250px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 20px;
  background: rgba(20, 20, 20, 0.9);
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.28);
}

.ux-benefit-card:nth-child(1) {
  left: 0;
  top: 0;
  transform: rotate(-4deg);
}

.ux-benefit-card:nth-child(2) {
  right: 0;
  top: 58px;
  transform: rotate(3deg);
}

.ux-benefit-card:nth-child(3) {
  left: 28px;
  bottom: 104px;
  transform: rotate(2deg);
}

.ux-benefit-card:nth-child(4) {
  right: 16px;
  bottom: 0;
  transform: rotate(-3deg);
}

.ux-benefit-card > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.ux-benefit-card i {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--ux-primary);
}

.ux-steps-section {
  border-bottom: 1px solid var(--ux-border);
}

.ux-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 24px;
  gap: 24px;
}

.ux-step-line {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}

.ux-step-line span {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #ffffff;
  background: var(--ux-primary);
  font-size: 0.78rem;
  font-weight: 900;
}

.ux-step-line i {
  height: 4px;
  flex: 1 1;
  border-radius: 999px;
  background: var(--ux-primary);
}

.ux-step h3 {
  color: var(--ux-foreground);
}

.ux-step p {
  color: var(--ux-muted);
}

.ux-footer {
  padding: 34px 0 24px;
  color: #ffffff;
  background: #060606;
}

.ux-footer-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  grid-gap: 28px;
  gap: 28px;
  padding-bottom: 28px;
}

.ux-footer-grid > *,
.ux-footer-doc {
  display: flex;
  flex-direction: column;
  gap: 8px;
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  font-size: 0.9rem;
  line-height: 1.55;
}

.ux-footer-grid span {
  color: #ffffff;
  font-weight: 900;
}

.ux-footer-grid a {
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
}

.ux-footer-doc strong,
.ux-footer-bottom strong {
  color: var(--ux-primary);
}

.ux-footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 20px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.9rem;
}

.ux-footer p {
  margin: 0;
}

@media (max-width: 1020px) {
  .ux-hero {
    min-height: auto;
    padding: 112px 0 72px;
  }

  .ux-hero-grid,
  .ux-form-grid,
  .ux-audience-grid,
  .ux-benefits-grid {
    grid-template-columns: 1fr;
  }

  .ux-hero-cards {
    min-height: 640px;
  }

  .ux-pillar-grid,
  .ux-steps-grid {
    grid-template-columns: 1fr;
  }

  .ux-benefits-cards {
    display: grid;
    min-height: auto;
    grid-gap: 14px;
    gap: 14px;
  }

  .ux-benefit-card,
  .ux-benefit-card:nth-child(n) {
    position: static;
    width: 100%;
    transform: none;
  }
}

@media (max-width: 720px) {
  .ux-container {
    width: min(100% - 24px, 1180px);
  }

  .ux-appbar-inner {
    grid-template-columns: 1fr auto 1fr;
  }

  .ux-access-button {
    display: none;
  }

  .ux-access-button-light {
    display: inline-flex;
  }

  .ux-logo img {
    height: 34px;
  }

  .ux-hero h1 {
    font-size: clamp(3rem, 17vw, 4.6rem);
  }

  .ux-hero-cards {
    display: grid;
    min-height: auto;
    grid-gap: 14px;
    gap: 14px;
  }

  .ux-floating-card,
  .ux-focus-card,
  .ux-validation-card,
  .ux-intel-card,
  .ux-approval-card {
    position: static;
    width: 100%;
  }

  .ux-dashboard-preview {
    display: none;
  }

  .ux-section,
  .ux-form-section,
  .ux-dark-section {
    padding: 54px 0;
  }

  .ux-field-grid,
  .ux-access-grid,
  .ux-footer-grid {
    grid-template-columns: 1fr;
  }

  .ux-footer-bottom {
    flex-direction: column;
  }
}

/* /degustacao visual parity with UX Experience landing */
.ux-landing {
  font-family: Arial, Helvetica, sans-serif;
  color: #070707;
  background: #ffffff;
}

.ux-container {
  width: 80%;
  max-width: 1300px;
}

.ux-appbar {
  pointer-events: none;
}

.ux-appbar-inner {
  height: 72px;
  pointer-events: auto;
}

.ux-menu-button {
  justify-self: start;
  color: #ff4d00;
  background: transparent;
  -webkit-backdrop-filter: none;
          backdrop-filter: none;
}

.ux-menu-button svg {
  width: 24px;
  height: 24px;
  stroke-width: 2;
}

.ux-logo img {
  height: 40px;
}

.ux-access-button {
  min-height: 45px;
  border-radius: 999px;
  padding: 0 22px;
  font-size: 0.94rem;
  font-weight: 800;
}

.ux-hero {
  min-height: 100vh;
  align-items: center;
  padding: 112px 0 80px;
  background: #ffffff;
}

.ux-hero::after {
  display: none;
}

.ux-hero-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
  gap: 40px;
  align-items: stretch;
  padding-top: 0;
}

.ux-hero-copy {
  min-height: auto;
  justify-content: space-between;
  gap: 24px;
}

.ux-hero-copy h1,
.ux-hero h1 {
  max-width: 650px;
  color: #050505;
  font-size: 3.25rem;
  font-weight: 700;
  line-height: 1.12;
}

.ux-hero h1 span {
  color: #ff4d00;
}

.ux-hero p {
  max-width: 576px;
  margin-top: 8px;
  color: #777777;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.55;
}

.ux-hero-links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 14px;
  gap: 14px;
}

.ux-hero-links a {
  position: relative;
  min-height: 132px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  border: 1px solid #dddddd;
  border-radius: 10px;
  padding: 16px 44px 16px 16px;
  color: #050505;
  background: #ffffff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
  text-decoration: none;
}

.ux-hero-links strong {
  margin-bottom: 8px;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.05;
}

.ux-hero-links span {
  color: #555555;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.5;
}

.ux-hero-links svg {
  position: absolute;
  right: 20px;
  bottom: 19px;
  color: #4f4f4f;
  transform: rotate(45deg);
}

.ux-hero-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: minmax(0, auto);
  grid-gap: 16px;
  gap: 16px;
  min-height: 0;
  margin-top: 0;
  filter: drop-shadow(0 44px 52px rgba(0, 0, 0, 0.12));
}

.ux-floating-card {
  position: static;
  border: 1px solid #e5e5e5;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 20px 70px rgba(10, 10, 10, 0.1);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
}

.ux-focus-card {
  width: auto;
  min-height: 0;
  padding: 20px;
}

.ux-card-corner {
  position: static;
  display: flex;
  justify-content: flex-end;
  margin-bottom: 20px;
  color: #ff4d00;
}

.ux-focus-card h2,
.ux-validation-card h3 {
  margin: 0 0 6px;
  color: #070707;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.05;
}

.ux-focus-card p,
.ux-validation-card p,
.ux-intel-card p {
  color: #595959;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}

.ux-mini-grid {
  gap: 12px;
  margin-top: 20px;
}

.ux-mini-grid span {
  border-radius: 9px;
  padding: 8px;
  color: #555555;
  background: #d5d5d7;
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1.18;
}

.ux-mini-grid strong {
  margin-top: 4px;
  color: #111111;
  font-size: 0.75rem;
  font-weight: 700;
}

.ux-validation-card {
  width: auto;
  min-height: 0;
  padding: 20px;
}

.ux-card-eyebrow,
.ux-intel-card > div span,
.ux-benefit-card span {
  color: #ff4d00;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.16em;
}

.ux-validation-card > div {
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
}

.ux-validation-card svg,
.ux-intel-card svg {
  flex: 0 0 auto;
  color: #ff4d00;
}

.ux-status-progress {
  margin-top: 12px;
  border-radius: 18px;
  padding: 12px;
  background: #f5f5f7;
}

.ux-status-progress > div:first-child {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: #555555;
  font-size: 0.68rem;
  font-weight: 700;
}

.ux-status-progress strong {
  color: #555555;
  font-size: 0.68rem;
}

.ux-progress {
  height: 8px;
  margin-top: 8px;
  background: #d2d2d7;
}

.ux-progress span {
  width: 72%;
  background: #ff4d00;
}

.ux-intel-card {
  grid-column: 1 / -1;
  width: auto;
  min-height: 0;
  padding: 20px;
}

.ux-intel-card > div {
  justify-content: space-between;
}

.ux-intel-card strong {
  margin: 16px 0 4px;
  color: #070707;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1;
}

.ux-intel-card strong small {
  color: #a0a0a0;
  font-size: 1.25rem;
}

.ux-intel-card p {
  margin-bottom: 24px;
}

.ux-bars {
  height: 80px;
  grid-template-columns: repeat(10, 1fr);
  gap: 8px;
  align-items: end;
  border-radius: 16px;
  padding: 12px 16px;
  background: rgba(134, 134, 139, 0.2);
}

.ux-bars span {
  border-radius: 8px 8px 3px 3px;
  background: #ff4d00;
}

.ux-bars span:nth-child(1) { height: 19%; }
.ux-bars span:nth-child(2) { height: 27%; }
.ux-bars span:nth-child(3) { height: 34%; }
.ux-bars span:nth-child(4) { height: 42%; }
.ux-bars span:nth-child(5) { height: 50%; }
.ux-bars span:nth-child(6) { height: 64%; }
.ux-bars span:nth-child(7) { height: 76%; }
.ux-bars span:nth-child(8) { height: 84%; }
.ux-bars span:nth-child(9) { height: 78%; }
.ux-bars span:nth-child(10) { height: 70%; }

.ux-section {
  padding: 72px 0;
}

.ux-section-header {
  max-width: 1284px;
  gap: 8px;
}

.ux-stamp {
  border-radius: 24px 8px 24px 8px;
  padding: 4px 16px;
  color: #ffffff;
  background: #ff4d00;
  font-size: 0.875rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  line-height: 1;
  margin-bottom: 8px;
}

.ux-section h2,
.ux-form-copy h2,
.ux-dark-section h2 {
  max-width: 1220px;
  color: #050505;
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1.12;
}

.ux-pillar-grid {
  gap: 20px;
}

.ux-pillar-card {
  min-height: 212px;
  border-radius: 12px;
  padding: 20px;
  background: #050505;
}

.ux-pillar-card h3 {
  margin-top: 18px;
  color: #ff4d00;
  font-size: 1.25rem;
  font-weight: 700;
}

.ux-pillar-card p {
  color: #ffffff;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}

.ux-form-section {
  border-top: 1px solid #d9d9d9;
  padding: 60px 0;
}

.ux-form-grid {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 40px;
}

.ux-form-copy h2 {
  max-width: 440px;
}

.ux-request-form {
  border: 0;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}

.ux-field-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 20px;
}

.ux-field-grid .ux-field:first-child,
.ux-field-grid .ux-field:nth-child(2) {
  grid-column: 1 / -1;
}

.ux-field span {
  color: #050505;
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: none;
}

.ux-field input,
.ux-field textarea {
  min-height: 46px;
  border-color: #dddddd;
  border-radius: 999px;
  padding: 0 16px;
  color: #050505;
  font-size: 1rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.ux-field textarea {
  border-radius: 18px;
  padding-top: 14px;
}

.ux-submit {
  width: -moz-fit-content;
  width: fit-content;
  min-height: 46px;
  border-radius: 999px;
  padding: 0 22px;
}

.ux-dark-section {
  min-height: auto;
  padding: 64px 0 96px;
  background-color: #050505;
  background-image:
    linear-gradient(rgba(5, 5, 5, 0.82), rgba(5, 5, 5, 0.82)),
    url("/ux-landing/mockup.svg");
}

.ux-dark-section h2 {
  color: #ffffff;
  font-size: 2.5rem;
  line-height: 1.08;
}

.ux-dark-section p {
  max-width: 690px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}

.ux-audience-grid,
.ux-benefits-grid {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 40px;
}

.ux-audience-list {
  gap: 20px;
}

.ux-audience-list div {
  min-height: 78px;
  display: flex;
  align-items: center;
  border-radius: 8px;
  padding: 20px 26px;
  background: rgba(255, 255, 255, 0.02);
  font-size: 0.875rem;
  font-weight: 600;
}

.ux-access-grid {
  gap: 20px;
}

.ux-access-card {
  min-height: 222px;
  border-radius: 8px;
  padding: 24px;
  background: #050505;
}

.ux-access-card span {
  width: 40px;
  height: 40px;
  color: #ff4d00;
  background: rgba(255, 77, 0, 0.22);
  font-size: 1.25rem;
}

.ux-access-card h3 {
  margin-top: 18px;
  color: #ffffff;
  font-size: 1.25rem;
  font-weight: 700;
}

.ux-access-card p {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}

.ux-benefits-section {
  min-height: auto;
  display: flex;
  align-items: center;
}

.ux-benefits-cards {
  min-height: 620px;
}

.ux-benefit-card {
  width: 250px;
  border-radius: 8px;
  padding: 20px;
  background: rgba(25, 25, 28, 0.94);
}

.ux-benefit-card:nth-child(1) {
  left: 14px;
  top: 56px;
}

.ux-benefit-card:nth-child(2) {
  right: 0;
  top: 110px;
}

.ux-benefit-card:nth-child(3) {
  left: 28px;
  bottom: 130px;
}

.ux-benefit-card:nth-child(4) {
  right: 18px;
  bottom: 0;
}

.ux-benefit-card h3 {
  color: #ffffff;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.2;
}

.ux-benefit-card p {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.875rem;
  font-weight: 500;
}

.ux-steps-section {
  min-height: 612px;
  padding-top: 96px;
}

.ux-steps-section .ux-section-header {
  max-width: 1030px;
}

.ux-steps-section .ux-section-header p {
  max-width: 1040px;
  color: #777777;
  font-size: 1rem;
  font-weight: 500;
}

.ux-steps-grid {
  margin-top: 34px;
  gap: 30px;
}

.ux-step-line span {
  width: 36px;
  height: 36px;
  color: #828a98;
  background: #f1f1f3;
  font-size: 0.9rem;
}

.ux-step:nth-child(2) .ux-step-line span {
  color: #ffffff;
  background: #ff4d00;
}

.ux-step-line i {
  height: 4px;
  background: #f1f1f3;
}

.ux-step h3 {
  color: #8a8a8a;
  font-size: 1.125rem;
  font-weight: 700;
}

.ux-step:nth-child(2) h3 {
  color: #050505;
}

.ux-step p {
  display: none;
}

.ux-footer {
  padding: 42px 0 54px;
}

.ux-footer-grid {
  grid-template-columns: 1.25fr 0.9fr 0.9fr;
}

.ux-footer-grid > *,
.ux-footer-doc {
  color: #ffffff;
  font-size: 0.96rem;
  font-weight: 700;
}

.ux-footer-grid span {
  font-size: 1.16rem;
}

.ux-footer-grid a {
  color: #ffffff;
}

.ux-footer-bottom {
  border: 0;
  padding-top: 36px;
  color: #ffffff;
  font-size: 0.94rem;
  font-weight: 800;
}

@media (max-width: 1020px) {
  .ux-appbar-inner {
    height: 112px;
  }

  .ux-hero {
    padding: 0 0 64px;
  }

  .ux-hero-grid {
    grid-template-columns: 1fr;
    padding-top: 150px;
  }

  .ux-hero-copy {
    min-height: auto;
    gap: 42px;
  }

  .ux-hero-cards {
    display: grid;
    min-height: auto;
    grid-gap: 16px;
    gap: 16px;
    filter: none;
  }

  .ux-floating-card,
  .ux-focus-card,
  .ux-validation-card,
  .ux-intel-card {
    position: static;
    width: 100%;
  }

  .ux-form-grid,
  .ux-audience-grid,
  .ux-benefits-grid {
    grid-template-columns: 1fr;
  }

  .ux-benefits-cards {
    min-height: auto;
  }

  .ux-benefit-card:nth-child(n) {
    position: static;
    width: 100%;
    transform: none;
  }
}

@media (max-width: 720px) {
  .ux-container {
    width: min(100% - 24px, 1284px);
  }

  .ux-access-button {
    display: inline-flex;
    min-height: 40px;
    padding: 0 14px;
    font-size: 0.86rem;
  }

  .ux-hero h1 {
    font-size: clamp(2.45rem, 11vw, 3.5rem);
  }

  .ux-hero-links,
  .ux-field-grid,
  .ux-access-grid,
  .ux-steps-grid,
  .ux-footer-grid {
    grid-template-columns: 1fr;
  }
}

