/* Geoproduct gabion calculator embed bundle. Scoped to #geoproduct-gabion-calculator. */
#geoproduct-gabion-calculator {
  /* Geoproduct brand primitives */
  --gp-ink: #2f4254;
  --gp-navy: #314354;
  --gp-blue: #2c72b0;
  --gp-blue-600: #2970b2;
  --gp-blue-700: #246db0;
  --gp-orange: #ff8300;
  --gp-orange-soft: #f58229;
  --gp-orange-deep: #e96f1f;
  --gp-ice: #f5feff;
  --gp-mist: #f9fcfd;
  --gp-line: #e3e7e8;
  --gp-muted: #707583;
  --gp-body: #484f56;
  --gp-white: #ffffff;
  --gp-success: #a0be47;
  --gp-danger: #d84040;
  --gp-danger-soft: #fff1f1;

  /* Typography */
  --font-sans: "Open Sans", "Helvetica Neue", Arial, sans-serif;
  --font-weight-regular: 400;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-size-xs: 12px;
  --font-size-sm: 13px;
  --font-size-body: 16px;
  --font-size-lg: 20px;
  --font-size-xl: 28px;
  --font-size-2xl: 36px;
  --font-size-display: 56px;
  --line-height-tight: 1.15;
  --line-height-title: 1.22;
  --line-height-body: 1.5;

  /* 8px spacing system */
  --space-0: 0;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 28px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* Radius */
  --radius-none: 0;
  --radius-technical: 6px;
  --radius-panel: 8px;
  --radius-control: 20px;
  --radius-round: 999px;

  /* Shadows */
  --shadow-none: none;
  --shadow-nav: 0 2px 8px rgb(47 66 84 / 18%);
  --shadow-panel: 0 10px 28px rgb(47 66 84 / 9%);
  --shadow-float: 0 18px 55px rgb(47 66 84 / 14%);
  --shadow-popover: 0 28px 70px rgb(47 66 84 / 24%);
  --shadow-control-hover: 0 10px 22px rgb(47 66 84 / 14%);
  --border-thin: 1px solid var(--color-line);
  --border-highlight: 1px solid var(--color-highlight-border);
  --border-primary: 1px solid var(--color-primary);
  --border-transparent: 1px solid var(--color-transparent);

  /* Motion */
  --motion-fast: 120ms ease-out;
  --motion-base: 180ms ease-out;
  --motion-emphasis: 220ms cubic-bezier(0.2, 0.8, 0.2, 1);

  /* Breakpoints */
  --breakpoint-sm: 640px;
  --breakpoint-md: 980px;
  --breakpoint-lg: 1180px;

  /* Semantic theme */
  --color-page: #f3f7fa;
  --color-surface: var(--gp-white);
  --color-surface-soft: var(--gp-ice);
  --color-text: var(--gp-ink);
  --color-body: var(--gp-body);
  --color-muted: var(--gp-muted);
  --color-line: var(--gp-line);
  --color-primary: var(--gp-orange);
  --color-primary-hover: var(--gp-orange-deep);
  --color-secondary: var(--gp-blue);
  --color-secondary-hover: var(--gp-blue-700);
  --color-focus: var(--gp-blue);
  --color-error: var(--gp-danger);
  --color-error-surface: var(--gp-danger-soft);
  --color-inverse: var(--gp-white);
  --color-tooltip: var(--gp-navy);
  --color-overlay: rgb(47 66 84 / 42%);
  --color-highlight-surface: rgb(44 114 176 / 10%);
  --color-highlight-border: rgb(44 114 176 / 28%);
  --color-focus-ring: rgb(44 114 176 / 16%);
  --color-active-ring: rgb(44 114 176 / 35%);
  --color-inverse-muted: rgb(255 255 255 / 72%);
  --color-transparent: transparent;
  --color-technical-band: var(--gp-navy);
  --color-technical-band-soft: #26394c;
  --color-orange-ring: rgb(255 131 0 / 22%);

  /* Component tokens */
  --page-min-width: 320px;
  --page-max-width: 960px;
  --page-gutter: var(--space-4);
  --calculator-panel-max-width: 845px;
  --calculator-result-max-width: 845px;
  --hero-max-width: 820px;
  --hero-title-max-size: 28px;
  --hero-padding-y: var(--space-8);
  --hero-padding-x: var(--space-16);
  --calculator-body-padding-y: var(--space-12);
  --calculator-shell-radius: 28px;
  --section-padding-y: var(--space-12);
  --panel-padding: var(--space-7);
  --control-height: 46px;
  --control-height-compact: 40px;
  --button-height: 46px;
  --button-padding-x: var(--space-5);
  --button-radius: var(--radius-control);
  --button-focus-ring-width: 3px;
  --field-radius: var(--radius-technical);
  --field-label-min-height: 22px;
  --help-size: 18px;
  --panel-radius: var(--radius-panel);
  --table-radius: var(--radius-technical);
  --table-divider-size: 1px;
  --table-label-min-width: 120px;
  --metric-min-height: 150px;
  --metric-min-height-mobile: 126px;
  --tooltip-width: 280px;
  --tooltip-arrow-size: 7px;
  --onboard-width: 300px;
  --onboard-overlay-blur: 2px;
  --onboard-arrow-size: var(--space-4);
  --z-overlay: 20;
  --z-active-target: 30;
  --z-popover: 40;
  --z-tooltip: 60;
}


#geoproduct-gabion-calculator .gp-calculator .ui-page-section {
  display: grid;
  gap: var(--space-8);
}


#geoproduct-gabion-calculator .gp-calculator .ui-card,
#geoproduct-gabion-calculator .gp-calculator .ui-calculator-card {
  background: var(--color-surface);
  border: 1px solid rgb(44 114 176 / 11%);
  border-radius: var(--panel-radius);
  box-shadow: 0 10px 26px rgb(47 66 84 / 5%), inset 0 1px 0 rgb(255 255 255 / 75%);
}


#geoproduct-gabion-calculator .gp-calculator .ui-form-section {
  display: grid;
  gap: var(--space-6);
  padding: var(--panel-padding);
}


#geoproduct-gabion-calculator .gp-calculator .ui-result-panel {
  display: block;
  overflow: hidden;
}


#geoproduct-gabion-calculator .gp-calculator .ui-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--button-height);
  padding: 0 var(--button-padding-x);
  border: var(--border-primary);
  border-radius: var(--button-radius);
  background: var(--color-primary);
  color: var(--color-inverse);
  font-family: var(--font-sans);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition:
    transform var(--motion-fast),
    box-shadow var(--motion-fast),
    background var(--motion-fast),
    border-color var(--motion-fast),
    color var(--motion-fast);
}


#geoproduct-gabion-calculator .gp-calculator .ui-button:hover {
  transform: translateY(-1px);
  background: var(--color-primary-hover);
  border-color: var(--color-primary-hover);
  box-shadow: var(--shadow-control-hover), 0 0 0 4px var(--color-orange-ring);
}


#geoproduct-gabion-calculator .gp-calculator .ui-button:active {
  transform: translateY(0);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .ui-button--primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-inverse);
}


#geoproduct-gabion-calculator .gp-calculator .ui-button--secondary {
  background: var(--color-surface);
  border-color: rgb(44 114 176 / 34%);
  color: var(--color-secondary);
}


#geoproduct-gabion-calculator .gp-calculator .ui-button--secondary:hover {
  transform: none;
  background: var(--color-highlight-surface);
  border-color: var(--color-secondary);
  color: var(--color-secondary-hover);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .ui-button--icon {
  width: var(--space-8);
  min-height: var(--space-8);
  padding: var(--space-0);
  border-color: var(--color-transparent);
  background: var(--color-transparent);
  color: var(--color-muted);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .ui-field {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
}


#geoproduct-gabion-calculator .gp-calculator .ui-field__label {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  min-height: var(--field-label-min-height);
  color: var(--color-text);
  font-weight: var(--font-weight-bold);
}


#geoproduct-gabion-calculator .gp-calculator .ui-field__hint {
  display: block;
  min-height: var(--space-5);
  color: var(--color-muted);
}


#geoproduct-gabion-calculator .gp-calculator .ui-input,
#geoproduct-gabion-calculator .gp-calculator .ui-select {
  width: 100%;
  height: var(--control-height);
  min-width: 0;
  padding: 0 var(--space-4);
  border: 1px solid rgb(44 114 176 / 16%);
  border-radius: var(--field-radius);
  background: var(--color-surface-soft);
  color: var(--color-text);
  font-family: var(--font-sans);
  outline: 0;
  transition:
    border-color var(--motion-base),
    box-shadow var(--motion-base),
    background var(--motion-base);
}


#geoproduct-gabion-calculator .gp-calculator .ui-input:focus,
#geoproduct-gabion-calculator .gp-calculator .ui-select:focus {
  border-color: var(--color-focus);
  background: var(--color-surface);
  box-shadow: 0 0 0 var(--button-focus-ring-width) var(--color-focus-ring);
}


#geoproduct-gabion-calculator .gp-calculator .ui-input:disabled,
#geoproduct-gabion-calculator .gp-calculator .ui-input[readonly] {
  background: #eef5f7;
  color: var(--color-muted);
}


#geoproduct-gabion-calculator .gp-calculator .ui-technical-table {
  display: grid;
  gap: var(--table-divider-size);
  margin: var(--space-4) 0 0;
  overflow: hidden;
  border: 0;
  border-radius: var(--radius-none);
}


#geoproduct-gabion-calculator .gp-calculator .ui-technical-table__row {
  display: grid;
  grid-template-columns: minmax(var(--table-label-min-width), 0.9fr) minmax(0, 1.1fr);
  gap: var(--space-4);
  padding: var(--space-4) 0;
  background: var(--color-surface);
  border-bottom: 1px solid rgb(44 114 176 / 9%);
}


#geoproduct-gabion-calculator .gp-calculator .ui-technical-table__row:last-child {
  border-bottom: 0;
}


#geoproduct-gabion-calculator .gp-calculator .ui-technical-table__label {
  color: var(--color-secondary);
  font-weight: var(--font-weight-bold);
}


#geoproduct-gabion-calculator .gp-calculator .ui-technical-table__value {
  margin: 0;
  color: var(--color-text);
  font-weight: var(--font-weight-bold);
  word-break: break-word;
}


#geoproduct-gabion-calculator .gp-calculator .ui-result-panel__header {
  display: grid;
  gap: var(--space-5);
}


#geoproduct-gabion-calculator .gp-calculator .ui-result-panel__summary {
  display: grid;
  gap: var(--space-1);
  padding: var(--space-5);
  background: var(--color-technical-band);
  border-radius: var(--radius-panel);
  color: var(--color-inverse);
  box-shadow: inset 4px 0 0 var(--color-primary);
}


#geoproduct-gabion-calculator .gp-calculator .ui-result-panel__metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5);
}


#geoproduct-gabion-calculator .gp-calculator, #geoproduct-gabion-calculator .gp-calculator * {
  box-sizing: border-box;
}


#geoproduct-gabion-calculator .gp-calculator {
  margin: 0;
  min-width: var(--page-min-width);
  background: transparent;
  color: var(--color-text);
  font-family: var(--font-sans);
  line-height: var(--line-height-body);
}


#geoproduct-gabion-calculator .gp-calculator button,
#geoproduct-gabion-calculator .gp-calculator input,
#geoproduct-gabion-calculator .gp-calculator select {
  font: inherit;
}


#geoproduct-gabion-calculator .gp-calculator .page {
  width: min(var(--page-max-width), calc(100% - (var(--page-gutter) * 2)));
  margin: 0 auto;
  padding: var(--section-padding-y) 0;
}


#geoproduct-gabion-calculator .gp-calculator .tdagro-membrane.ui-page-section {
  gap: 0;
  overflow: hidden;
  background: var(--color-surface);
  border: 1px solid rgb(44 114 176 / 12%);
  border-radius: var(--calculator-shell-radius);
  box-shadow: 0 14px 38px rgb(47 66 84 / 7%);
}


#geoproduct-gabion-calculator .gp-calculator .hero {
  position: relative;
  overflow: hidden;
  width: 100%;
  max-width: var(--page-max-width);
  margin-inline: auto;
  padding: var(--hero-padding-y) var(--hero-padding-x);
  background:
    linear-gradient(116deg, transparent 0 70%, rgb(255 131 0 / 92%) 70% 72%, transparent 72% 100%),
    linear-gradient(135deg, var(--color-technical-band) 0%, var(--color-technical-band-soft) 100%);
  border: 0;
  border-bottom: var(--border-thin);
  border-radius: var(--radius-none);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .hero::after {
  content: "";
  position: absolute;
  right: -96px;
  top: -132px;
  width: 300px;
  height: 300px;
  background: rgb(255 255 255 / 6%);
  clip-path: polygon(30% 0, 70% 0, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0 70%, 0 30%);
}


#geoproduct-gabion-calculator .gp-calculator .eyebrow {
  display: none;
  margin: 0 0 var(--space-2);
  color: var(--color-primary);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}


#geoproduct-gabion-calculator .gp-calculator h1,
#geoproduct-gabion-calculator .gp-calculator h2,
#geoproduct-gabion-calculator .gp-calculator h3,
#geoproduct-gabion-calculator .gp-calculator p {
  margin-top: 0;
}


#geoproduct-gabion-calculator .gp-calculator h1 {
  position: relative;
  z-index: 1;
  max-width: var(--hero-max-width);
  margin-bottom: var(--space-2);
  color: var(--color-inverse);
  font-size: clamp(26px, 2.25vw, var(--hero-title-max-size));
  line-height: var(--line-height-title);
}


#geoproduct-gabion-calculator .gp-calculator .hero > p:not(.eyebrow),
#geoproduct-gabion-calculator .gp-calculator .result-header p,
#geoproduct-gabion-calculator .gp-calculator .note,
#geoproduct-gabion-calculator .gp-calculator small {
  color: var(--color-muted);
}


#geoproduct-gabion-calculator .gp-calculator .hero > p:not(.eyebrow) {
  position: relative;
  z-index: 1;
  max-width: var(--hero-max-width);
  margin-bottom: 0;
  color: rgb(255 255 255 / 82%);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}


#geoproduct-gabion-calculator .gp-calculator .calculator-grid {
  display: grid;
  gap: 0;
  padding: var(--calculator-body-padding-y) 0;
}


#geoproduct-gabion-calculator .gp-calculator .params {
  width: min(100%, var(--calculator-panel-max-width));
  margin-inline: auto;
  border-radius: var(--panel-radius);
  border-color: rgb(44 114 176 / 12%);
  box-shadow: 0 12px 32px rgb(47 66 84 / 5%), inset 0 2px 0 rgb(44 114 176 / 18%);
}


#geoproduct-gabion-calculator .gp-calculator .panel-head {
  display: flex;
  gap: var(--space-4);
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
}


#geoproduct-gabion-calculator .gp-calculator .panel-head h2,
#geoproduct-gabion-calculator .gp-calculator .result-header h2,
#geoproduct-gabion-calculator .gp-calculator .details h3 {
  margin: 0;
  color: var(--color-text);
}


#geoproduct-gabion-calculator .gp-calculator .panel-head h2::before,
#geoproduct-gabion-calculator .gp-calculator .result-header h2::before,
#geoproduct-gabion-calculator .gp-calculator .details h3::before {
  content: "";
  display: inline-block;
  width: var(--space-3);
  height: var(--space-3);
  margin-right: var(--space-2);
  background: var(--color-primary);
  clip-path: polygon(30% 0, 70% 0, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0 70%, 0 30%);
  vertical-align: 1px;
}


#geoproduct-gabion-calculator .gp-calculator .helper-toggle {
  min-height: var(--control-height-compact);
  padding-inline: var(--space-3);
  background: rgb(244 252 255 / 58%);
  border-color: rgb(44 114 176 / 18%);
  color: rgb(44 114 176 / 88%);
  box-shadow: var(--shadow-none);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  white-space: nowrap;
}


#geoproduct-gabion-calculator .gp-calculator .helper-toggle:hover,
#geoproduct-gabion-calculator .gp-calculator .helper-toggle:focus-visible {
  transform: none;
  background: var(--color-highlight-surface);
  border-color: rgb(44 114 176 / 42%);
  color: var(--color-secondary-hover);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .mode-hint {
  display: none;
  margin-bottom: var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: var(--color-highlight-surface);
  border: var(--border-highlight);
  border-radius: var(--radius-technical);
  color: var(--color-secondary-hover);
  font-size: var(--font-size-sm);
}


#geoproduct-gabion-calculator .gp-calculator .tdagro-membrane.show-help .mode-hint {
  display: block;
}


#geoproduct-gabion-calculator .gp-calculator .fields {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-5) var(--space-5);
}


#geoproduct-gabion-calculator .gp-calculator #field-quantity .ui-field__label {
  color: var(--color-text);
}


#geoproduct-gabion-calculator .gp-calculator #field-quantity input {
  border-color: rgb(255 131 0 / 38%);
  background: linear-gradient(90deg, rgb(255 131 0 / 8%) 0, var(--color-surface-soft) 18%, var(--color-surface-soft) 100%);
  box-shadow: inset 3px 0 0 rgb(255 131 0 / 72%);
}


#geoproduct-gabion-calculator .gp-calculator #field-quantity input:hover,
#geoproduct-gabion-calculator .gp-calculator #field-quantity input:focus {
  border-color: rgb(255 131 0 / 54%);
  box-shadow: inset 3px 0 0 rgb(255 131 0 / 86%), 0 0 0 3px rgb(255 131 0 / 10%);
}


#geoproduct-gabion-calculator .gp-calculator #field-quantity .help {
  border-color: rgb(255 131 0 / 34%);
  color: rgb(255 131 0 / 92%);
}


#geoproduct-gabion-calculator .gp-calculator .help {
  position: relative;
  display: inline-grid;
  place-items: center;
  flex: 0 0 var(--help-size);
  width: var(--help-size);
  height: var(--help-size);
  border: 1px solid rgb(44 114 176 / 20%);
  border-radius: var(--radius-round);
  color: rgb(44 114 176 / 72%);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  cursor: help;
  transition: transform var(--motion-emphasis), box-shadow var(--motion-emphasis), background var(--motion-base);
}


#geoproduct-gabion-calculator .gp-calculator .help[data-tip]::after {
  content: attr(data-tip);
  position: absolute;
  left: 50%;
  bottom: 130%;
  z-index: var(--z-tooltip);
  width: max-content;
  max-width: var(--tooltip-width);
  padding: var(--space-3) var(--space-4);
  transform: translateX(-50%) translateY(4px);
  background: var(--color-technical-band);
  border-radius: var(--radius-panel);
  box-shadow: var(--shadow-float);
  color: var(--color-inverse);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  opacity: 0;
  pointer-events: none;
  white-space: normal;
  transition: opacity var(--motion-base), transform var(--motion-emphasis);
}


#geoproduct-gabion-calculator .gp-calculator .help[data-tip]::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 116%;
  z-index: var(--z-tooltip);
  border: var(--tooltip-arrow-size) solid var(--color-transparent);
  border-top-color: var(--color-tooltip);
  opacity: 0;
  transform: translateX(-50%);
  transition: opacity var(--motion-fast);
}


#geoproduct-gabion-calculator .gp-calculator .help:hover,
#geoproduct-gabion-calculator .gp-calculator .help:focus-visible {
  transform: none;
  background: var(--color-highlight-surface);
  color: var(--color-primary);
  box-shadow: 0 4px 10px rgb(47 66 84 / 7%);
}


#geoproduct-gabion-calculator .gp-calculator .help:hover::after,
#geoproduct-gabion-calculator .gp-calculator .help:focus-visible::after {
  opacity: 1;
  transform: translateX(-50%) translateY(-2px);
}


#geoproduct-gabion-calculator .gp-calculator .help:hover::before,
#geoproduct-gabion-calculator .gp-calculator .help:focus-visible::before {
  opacity: 1;
}


#geoproduct-gabion-calculator .gp-calculator .field.td-bad input,
#geoproduct-gabion-calculator .gp-calculator .field.td-bad select {
  border-color: var(--color-error);
  background: var(--color-error-surface);
}


#geoproduct-gabion-calculator .gp-calculator .field.td-warning:not(.td-bad) input,
#geoproduct-gabion-calculator .gp-calculator .field.td-warning:not(.td-bad) select {
  border-color: rgb(255 131 0 / 34%);
  background: rgb(255 250 244 / 68%);
}


#geoproduct-gabion-calculator .gp-calculator .td-error {
  color: var(--color-error);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
}


#geoproduct-gabion-calculator .gp-calculator .td-warning-message {
  color: var(--color-primary-hover);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
}


#geoproduct-gabion-calculator .gp-calculator .ghost {
  /* Backward-compatible alias for secondary buttons. */
}


#geoproduct-gabion-calculator .gp-calculator .form-actions-section {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid rgb(44 114 176 / 10%);
}


#geoproduct-gabion-calculator .gp-calculator .actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}


#geoproduct-gabion-calculator .gp-calculator #calcBtn {
  min-width: 152px;
  box-shadow: 0 10px 22px rgb(255 131 0 / 18%);
}


#geoproduct-gabion-calculator .gp-calculator #resetBtn {
  border-color: rgb(44 114 176 / 18%);
  background: var(--color-transparent);
  color: var(--color-muted);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator #resetBtn:hover,
#geoproduct-gabion-calculator .gp-calculator #resetBtn:focus-visible {
  transform: none;
  border-color: rgb(44 114 176 / 42%);
  background: var(--color-highlight-surface);
  color: var(--color-secondary);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px dashed rgb(44 114 176 / 10%);
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__header {
  display: flex;
  gap: var(--space-2);
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--space-2);
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__title {
  display: block;
  margin-bottom: var(--space-2);
  color: var(--color-muted);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.02em;
  text-transform: uppercase;
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__title--main {
  margin-bottom: 0;
  color: var(--color-muted);
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__selected,
#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__note {
  color: var(--color-muted);
  font-size: 11px;
  font-weight: var(--font-weight-semibold);
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__selected {
  text-align: right;
}


#geoproduct-gabion-calculator .gp-calculator .preset-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-bottom: var(--space-2);
  padding: var(--space-1);
  border: 1px solid rgb(44 114 176 / 14%);
  border-radius: var(--radius-technical);
  background: rgb(244 252 255 / 54%);
}


#geoproduct-gabion-calculator .gp-calculator .preset-tab {
  min-height: 26px;
  padding: 0 var(--space-2);
  border-color: var(--color-transparent);
  border-radius: var(--radius-technical);
  background: var(--color-transparent);
  color: rgb(44 114 176 / 76%);
  box-shadow: var(--shadow-none);
  font-size: 11px;
  font-weight: var(--font-weight-bold);
  line-height: 1;
}


#geoproduct-gabion-calculator .gp-calculator .preset-tab:hover,
#geoproduct-gabion-calculator .gp-calculator .preset-tab:focus-visible {
  transform: none;
  background: rgb(255 255 255 / 84%);
  border-color: rgb(44 114 176 / 16%);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .preset-tab.is-active {
  background: var(--color-surface);
  border-color: rgb(44 114 176 / 20%);
  color: var(--color-secondary);
  box-shadow: 0 4px 12px rgb(47 66 84 / 6%);
}


#geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__note {
  display: block;
  margin-bottom: var(--space-2);
}


#geoproduct-gabion-calculator .gp-calculator .quick-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}


#geoproduct-gabion-calculator .gp-calculator .preset-group[hidden],
#geoproduct-gabion-calculator .gp-calculator .preset-group.is-hidden {
  display: none !important;
}


#geoproduct-gabion-calculator .gp-calculator .quick {
  position: relative;
  min-height: 26px;
  padding: 0 10px;
  border-color: rgb(44 114 176 / 18%);
  border-radius: var(--radius-technical);
  background: rgb(255 255 255 / 72%);
  color: rgb(44 114 176 / 88%);
  box-shadow: var(--shadow-none);
  font-size: 11px;
  font-weight: var(--font-weight-bold);
  line-height: 1;
}


#geoproduct-gabion-calculator .gp-calculator .quick:hover,
#geoproduct-gabion-calculator .gp-calculator .quick:focus-visible {
  transform: none;
  border-color: rgb(44 114 176 / 34%);
  background: rgb(44 114 176 / 7%);
  color: var(--color-secondary-hover);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .quick.is-active {
  padding-left: 12px;
  border-color: rgb(44 114 176 / 42%);
  background: rgb(244 252 255 / 90%);
  color: var(--color-secondary-hover);
  box-shadow: inset 3px 0 0 rgb(255 131 0 / 78%);
}


#geoproduct-gabion-calculator .gp-calculator .results.ui-result-panel {
  width: min(100%, var(--calculator-result-max-width));
  margin-inline: auto;
  margin-top: var(--space-6);
  padding: var(--space-8);
  border-top: 1px solid rgb(44 114 176 / 10%);
  border-radius: var(--panel-radius);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
  box-shadow: 0 16px 42px rgb(47 66 84 / 6%), inset 0 2px 0 rgb(44 114 176 / 14%);
}


#geoproduct-gabion-calculator .gp-calculator .result-header,
#geoproduct-gabion-calculator .gp-calculator .metrics,
#geoproduct-gabion-calculator .gp-calculator .note {
  grid-column: 1 / -1;
}


#geoproduct-gabion-calculator .gp-calculator .result-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-5);
  padding: var(--space-6) var(--space-7);
  border: 1px solid rgb(44 114 176 / 10%);
  border-radius: var(--panel-radius);
  background: linear-gradient(90deg, var(--color-surface) 0%, var(--color-surface-soft) 100%);
  box-shadow: 0 10px 28px rgb(47 66 84 / 4%), inset 3px 0 0 rgb(44 114 176 / 20%);
}


#geoproduct-gabion-calculator .gp-calculator .result-header p {
  max-width: 510px;
  margin-bottom: 0;
  color: var(--color-body);
}


#geoproduct-gabion-calculator .gp-calculator .cost-card {
  min-width: 250px;
}


#geoproduct-gabion-calculator .gp-calculator .cost-card span {
  display: block;
  color: var(--color-inverse-muted);
  font-size: var(--font-size-sm);
  text-transform: uppercase;
}


#geoproduct-gabion-calculator .gp-calculator .cost-card strong {
  display: block;
  margin-top: var(--space-2);
  color: var(--color-primary);
  font-size: var(--font-size-2xl);
  line-height: 1;
}


#geoproduct-gabion-calculator .gp-calculator .metric {
  min-height: var(--metric-min-height);
  position: relative;
  overflow: hidden;
  padding: var(--space-6);
  border-color: rgb(44 114 176 / 10%);
  box-shadow: 0 9px 24px rgb(47 66 84 / 4%), inset 0 1px 0 rgb(255 255 255 / 86%);
}


#geoproduct-gabion-calculator .gp-calculator .metric::after {
  content: "";
  position: absolute;
  top: calc(var(--space-8) * -1);
  right: calc(var(--space-8) * -1);
  z-index: 0;
  width: 84px;
  height: 84px;
  background: rgb(44 114 176 / 4%);
  clip-path: polygon(30% 0, 70% 0, 100% 30%, 100% 70%, 70% 100%, 30% 100%, 0 70%, 0 30%);
}


#geoproduct-gabion-calculator .gp-calculator .metric span {
  display: block;
  position: relative;
  z-index: 1;
  color: rgb(44 114 176 / 88%);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}


#geoproduct-gabion-calculator .gp-calculator .metric strong {
  display: block;
  position: relative;
  z-index: 1;
  margin-top: var(--space-3);
  color: var(--gp-orange);
  font-size: var(--font-size-xl);
  line-height: 1;
}


#geoproduct-gabion-calculator .gp-calculator .metric small {
  display: block;
  position: relative;
  z-index: 1;
  margin-top: var(--space-3);
  color: rgb(72 79 86 / 86%);
  line-height: 1.45;
}


#geoproduct-gabion-calculator .gp-calculator .metric.accent {
  background: linear-gradient(180deg, rgb(244 252 255 / 86%), var(--color-surface));
  border-color: rgb(44 114 176 / 11%);
  box-shadow: 0 10px 26px rgb(47 66 84 / 5%), inset 3px 0 0 rgb(255 131 0 / 62%);
}


#geoproduct-gabion-calculator .gp-calculator .details {
  padding: var(--space-7);
  background: var(--color-surface);
  border: 1px solid rgb(44 114 176 / 10%);
  border-radius: var(--panel-radius);
  box-shadow: 0 10px 26px rgb(47 66 84 / 4%), inset 2px 0 0 rgb(44 114 176 / 12%);
}


#geoproduct-gabion-calculator .gp-calculator .details:nth-of-type(1) {
  padding-right: var(--space-7);
}


#geoproduct-gabion-calculator .gp-calculator .details:nth-of-type(2) {
  padding-left: var(--space-7);
}


#geoproduct-gabion-calculator .gp-calculator .note {
  margin: 0;
  padding: var(--space-5);
  border: 1px solid rgb(44 114 176 / 10%);
  background: rgb(244 252 255 / 58%);
  border-radius: var(--radius-panel);
  color: var(--color-body);
  box-shadow: inset 2px 0 0 rgb(255 131 0 / 42%);
}


#geoproduct-gabion-calculator .gp-calculator .onboard-overlay {
  position: absolute;
  inset: 0;
  z-index: 20;
  background: transparent;
  backdrop-filter: none;
  pointer-events: none;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-pop {
  position: fixed;
  left: -9999px;
  top: -9999px;
  z-index: 120;
  visibility: hidden;
  width: min(var(--onboard-width), calc(100% - (var(--space-4) * 2)));
  padding: var(--space-5);
  background: var(--color-surface);
  border: var(--border-thin);
  border-radius: var(--radius-panel);
  box-shadow: var(--shadow-popover);
  border-top: 3px solid var(--color-primary);
}


#geoproduct-gabion-calculator .gp-calculator .onboard-arrow {
  position: absolute;
  top: calc(var(--space-2) * -1);
  left: var(--space-8);
  width: var(--onboard-arrow-size);
  height: var(--onboard-arrow-size);
  background: var(--color-surface);
  border-top: var(--border-thin);
  border-left: var(--border-thin);
  transform: rotate(45deg);
}


#geoproduct-gabion-calculator .gp-calculator .onboard-close {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  display: grid;
  place-items: center;
  width: 28px;
  min-height: 28px;
  padding: 0;
  background: var(--color-transparent);
  border: 0;
  color: var(--color-muted);
  box-shadow: var(--shadow-none);
  font-size: 20px;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-close:hover {
  transform: none;
  background: var(--color-transparent);
  border-color: var(--color-transparent);
  color: var(--color-muted);
  box-shadow: var(--shadow-none);
}


#geoproduct-gabion-calculator .gp-calculator .onboard-step {
  display: block;
  margin-bottom: var(--space-2);
  color: var(--color-secondary);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  text-transform: uppercase;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-pop h2 {
  margin-bottom: var(--space-2);
  font-size: 16px;
  line-height: 1.25;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-pop p {
  margin-bottom: var(--space-4);
  color: var(--color-body);
  font-size: 14px;
  line-height: 1.45;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: space-between;
  min-width: 0;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-actions button {
  flex: 1 1 0;
  min-width: 0;
  min-height: 38px;
  padding-inline: var(--space-3);
  font-size: 14px;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-actions #onboardSkip {
  flex: 1.35 1 0;
}


#geoproduct-gabion-calculator .gp-calculator .onboard-active {
  position: relative;
  z-index: 80;
  background: var(--color-surface);
  pointer-events: auto;
  outline: var(--button-focus-ring-width) solid var(--color-active-ring);
  outline-offset: var(--space-1);
  border-radius: var(--radius-panel);
  box-shadow:
    0 0 0 9999px rgb(47 66 84 / 34%),
    0 16px 40px rgb(47 66 84 / 16%);
}

#geoproduct-gabion-calculator .gp-calculator .onboard-active input,
#geoproduct-gabion-calculator .gp-calculator .onboard-active select,
#geoproduct-gabion-calculator .gp-calculator .onboard-active .ui-input,
#geoproduct-gabion-calculator .gp-calculator .onboard-active .ui-select {
  position: relative;
  z-index: 1;
  background: var(--color-surface);
  border-color: rgb(44 114 176 / 50%);
  box-shadow:
    0 0 0 3px rgb(44 114 176 / 14%),
    0 8px 22px rgb(47 66 84 / 12%);
}

#geoproduct-gabion-calculator .gp-calculator .onboard-active input:focus,
#geoproduct-gabion-calculator .gp-calculator .onboard-active select:focus,
#geoproduct-gabion-calculator .gp-calculator .onboard-active .ui-input:focus,
#geoproduct-gabion-calculator .gp-calculator .onboard-active .ui-select:focus {
  background: var(--color-surface);
  border-color: var(--color-secondary);
  box-shadow:
    0 0 0 3px rgb(44 114 176 / 22%),
    0 10px 26px rgb(47 66 84 / 16%);
}


@media (max-width: 860px) {

  #geoproduct-gabion-calculator .gp-calculator .fields {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }


  #geoproduct-gabion-calculator .gp-calculator .metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }


  #geoproduct-gabion-calculator .gp-calculator .results.ui-result-panel {
    grid-template-columns: 1fr;
  }


  #geoproduct-gabion-calculator .gp-calculator .details:nth-of-type(1),
#geoproduct-gabion-calculator .gp-calculator .details:nth-of-type(2) {
    padding-inline: var(--space-8);
  }


}


@media (max-width: 640px) {

  #geoproduct-gabion-calculator .gp-calculator .page {
    width: min(100% - var(--space-5), var(--breakpoint-lg));
    padding: var(--space-6) 0;
  }


  #geoproduct-gabion-calculator .gp-calculator .hero {
    padding: var(--space-4);
  }


  #geoproduct-gabion-calculator .gp-calculator .hero h1 {
    font-size: var(--space-6);
  }


  #geoproduct-gabion-calculator .gp-calculator .calculator-grid {
    padding: var(--space-6) 0;
  }


  #geoproduct-gabion-calculator .gp-calculator .params,
#geoproduct-gabion-calculator .gp-calculator .result-header,
#geoproduct-gabion-calculator .gp-calculator .details {
    padding-inline: var(--space-4);
  }


  #geoproduct-gabion-calculator .gp-calculator .params {
    width: calc(100% - (var(--space-4) * 2));
  }


  #geoproduct-gabion-calculator .gp-calculator .results.ui-result-panel {
    width: calc(100% - (var(--space-4) * 2));
    padding: var(--space-4);
  }


  #geoproduct-gabion-calculator .gp-calculator .result-header {
    grid-template-columns: 1fr;
  }


  #geoproduct-gabion-calculator .gp-calculator .cost-card {
    min-width: 0;
  }


  #geoproduct-gabion-calculator .gp-calculator .panel-head,
#geoproduct-gabion-calculator .gp-calculator .actions {
    align-items: stretch;
    flex-direction: column;
  }


  #geoproduct-gabion-calculator .gp-calculator .form-actions-section {
    margin-top: var(--space-6);
    padding-top: var(--space-5);
  }


  #geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__header {
    align-items: flex-start;
    flex-direction: column;
  }


  #geoproduct-gabion-calculator .gp-calculator .preset-shortcuts__selected {
    text-align: left;
  }


  #geoproduct-gabion-calculator .gp-calculator .preset-tabs {
    display: flex;
  }


  #geoproduct-gabion-calculator .gp-calculator .fields,
#geoproduct-gabion-calculator .gp-calculator .metrics,
#geoproduct-gabion-calculator .gp-calculator dl div {
    grid-template-columns: 1fr;
  }


  #geoproduct-gabion-calculator .gp-calculator .details:nth-of-type(1),
#geoproduct-gabion-calculator .gp-calculator .details:nth-of-type(2) {
    padding-inline: var(--space-4);
  }


  #geoproduct-gabion-calculator .gp-calculator .helper-toggle,
#geoproduct-gabion-calculator .gp-calculator .actions button,
#geoproduct-gabion-calculator .gp-calculator .onboard-actions button {
    width: 100%;
  }


  #geoproduct-gabion-calculator .gp-calculator .onboard-actions {
    flex-direction: column;
  }


  #geoproduct-gabion-calculator .gp-calculator .metric {
    min-height: var(--metric-min-height-mobile);
  }


}
