/* ═══════════════════════════════════════════════════════
   DUCKLINGS — Bootstrap 5 Compatibility Layer
   Maps Bootstrap classes → CanuckDUCK design tokens
   so existing module templates work without modification.
   ═══════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════
   LAYOUT UTILITIES
   ═══════════════════════════════════════════════════════ */

.container,
.container-fluid {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--space-lg);
  padding-right: var(--space-lg);
}
.container {
  max-width: 1140px;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin-left: calc(var(--space-lg) * -0.5);
  margin-right: calc(var(--space-lg) * -0.5);
}
.row > * {
  padding-left: calc(var(--space-lg) * 0.5);
  padding-right: calc(var(--space-lg) * 0.5);
  width: 100%;
}

/* Grid columns */
.col    { flex: 1 0 0%; }
.col-1  { flex: 0 0 auto; width: 8.333333%; }
.col-2  { flex: 0 0 auto; width: 16.666667%; }
.col-3  { flex: 0 0 auto; width: 25%; }
.col-4  { flex: 0 0 auto; width: 33.333333%; }
.col-5  { flex: 0 0 auto; width: 41.666667%; }
.col-6  { flex: 0 0 auto; width: 50%; }
.col-7  { flex: 0 0 auto; width: 58.333333%; }
.col-8  { flex: 0 0 auto; width: 66.666667%; }
.col-9  { flex: 0 0 auto; width: 75%; }
.col-10 { flex: 0 0 auto; width: 83.333333%; }
.col-11 { flex: 0 0 auto; width: 91.666667%; }
.col-12 { flex: 0 0 auto; width: 100%; }
.col-auto { flex: 0 0 auto; width: auto; }

/* Medium breakpoint columns */
@media (min-width: 768px) {
  .col-md-1  { flex: 0 0 auto; width: 8.333333%; }
  .col-md-2  { flex: 0 0 auto; width: 16.666667%; }
  .col-md-3  { flex: 0 0 auto; width: 25%; }
  .col-md-4  { flex: 0 0 auto; width: 33.333333%; }
  .col-md-5  { flex: 0 0 auto; width: 41.666667%; }
  .col-md-6  { flex: 0 0 auto; width: 50%; }
  .col-md-7  { flex: 0 0 auto; width: 58.333333%; }
  .col-md-8  { flex: 0 0 auto; width: 66.666667%; }
  .col-md-9  { flex: 0 0 auto; width: 75%; }
  .col-md-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-md-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-md-12 { flex: 0 0 auto; width: 100%; }
  .col-md-auto { flex: 0 0 auto; width: auto; }
}

/* Large breakpoint columns */
@media (min-width: 992px) {
  .col-lg-1  { flex: 0 0 auto; width: 8.333333%; }
  .col-lg-2  { flex: 0 0 auto; width: 16.666667%; }
  .col-lg-3  { flex: 0 0 auto; width: 25%; }
  .col-lg-4  { flex: 0 0 auto; width: 33.333333%; }
  .col-lg-5  { flex: 0 0 auto; width: 41.666667%; }
  .col-lg-6  { flex: 0 0 auto; width: 50%; }
  .col-lg-7  { flex: 0 0 auto; width: 58.333333%; }
  .col-lg-8  { flex: 0 0 auto; width: 66.666667%; }
  .col-lg-9  { flex: 0 0 auto; width: 75%; }
  .col-lg-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-lg-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-lg-12 { flex: 0 0 auto; width: 100%; }
  .col-lg-auto { flex: 0 0 auto; width: auto; }
}

/* XL breakpoint columns */
@media (min-width: 1200px) {
  .col-xl-1  { flex: 0 0 auto; width: 8.333333%; }
  .col-xl-2  { flex: 0 0 auto; width: 16.666667%; }
  .col-xl-3  { flex: 0 0 auto; width: 25%; }
  .col-xl-4  { flex: 0 0 auto; width: 33.333333%; }
  .col-xl-5  { flex: 0 0 auto; width: 41.666667%; }
  .col-xl-6  { flex: 0 0 auto; width: 50%; }
  .col-xl-7  { flex: 0 0 auto; width: 58.333333%; }
  .col-xl-8  { flex: 0 0 auto; width: 66.666667%; }
  .col-xl-9  { flex: 0 0 auto; width: 75%; }
  .col-xl-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-xl-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-xl-12 { flex: 0 0 auto; width: 100%; }
}

/* ═══════════════════════════════════════════════════════
   DISPLAY UTILITIES
   ═══════════════════════════════════════════════════════ */

.d-none          { display: none !important; }
.d-block         { display: block !important; }
.d-inline        { display: inline !important; }
.d-inline-block  { display: inline-block !important; }
.d-flex          { display: flex !important; }
.d-inline-flex   { display: inline-flex !important; }
.d-grid          { display: grid !important; }

@media (min-width: 576px) {
  .d-sm-none         { display: none !important; }
  .d-sm-block        { display: block !important; }
  .d-sm-flex         { display: flex !important; }
  .d-sm-inline-flex  { display: inline-flex !important; }
}
@media (min-width: 768px) {
  .d-md-none         { display: none !important; }
  .d-md-block        { display: block !important; }
  .d-md-flex         { display: flex !important; }
  .d-md-inline-flex  { display: inline-flex !important; }
}
@media (min-width: 992px) {
  .d-lg-none         { display: none !important; }
  .d-lg-block        { display: block !important; }
  .d-lg-flex         { display: flex !important; }
  .d-lg-inline-flex  { display: inline-flex !important; }
}

/* ═══════════════════════════════════════════════════════
   FLEXBOX UTILITIES
   ═══════════════════════════════════════════════════════ */

.flex-row            { flex-direction: row !important; }
.flex-column         { flex-direction: column !important; }
.flex-row-reverse    { flex-direction: row-reverse !important; }
.flex-column-reverse { flex-direction: column-reverse !important; }
.flex-wrap           { flex-wrap: wrap !important; }
.flex-nowrap         { flex-wrap: nowrap !important; }
.flex-fill           { flex: 1 1 auto !important; }
.flex-grow-0         { flex-grow: 0 !important; }
.flex-grow-1         { flex-grow: 1 !important; }
.flex-shrink-0       { flex-shrink: 0 !important; }
.flex-shrink-1       { flex-shrink: 1 !important; }

.justify-content-start   { justify-content: flex-start !important; }
.justify-content-end     { justify-content: flex-end !important; }
.justify-content-center  { justify-content: center !important; }
.justify-content-between { justify-content: space-between !important; }
.justify-content-around  { justify-content: space-around !important; }
.justify-content-evenly  { justify-content: space-evenly !important; }

.align-items-start    { align-items: flex-start !important; }
.align-items-end      { align-items: flex-end !important; }
.align-items-center   { align-items: center !important; }
.align-items-baseline { align-items: baseline !important; }
.align-items-stretch  { align-items: stretch !important; }

.align-self-start   { align-self: flex-start !important; }
.align-self-end     { align-self: flex-end !important; }
.align-self-center  { align-self: center !important; }
.align-self-stretch { align-self: stretch !important; }

.order-0     { order: 0 !important; }
.order-1     { order: 1 !important; }
.order-2     { order: 2 !important; }
.order-3     { order: 3 !important; }
.order-first { order: -1 !important; }
.order-last  { order: 6 !important; }

/* ═══════════════════════════════════════════════════════
   SPACING UTILITIES (mapped to design tokens)
   0=0, 1=4px, 2=8px, 3=12px, 4=16px, 5=24px
   ═══════════════════════════════════════════════════════ */

/* Margins */
.m-0  { margin: 0 !important; }
.m-1  { margin: var(--space-xs) !important; }
.m-2  { margin: var(--space-sm) !important; }
.m-3  { margin: var(--space-md) !important; }
.m-4  { margin: var(--space-lg) !important; }
.m-5  { margin: var(--space-xl) !important; }
.m-auto { margin: auto !important; }

.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: var(--space-xs) !important; }
.mt-2 { margin-top: var(--space-sm) !important; }
.mt-3 { margin-top: var(--space-md) !important; }
.mt-4 { margin-top: var(--space-lg) !important; }
.mt-5 { margin-top: var(--space-xl) !important; }
.mt-auto { margin-top: auto !important; }

.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: var(--space-xs) !important; }
.mb-2 { margin-bottom: var(--space-sm) !important; }
.mb-3 { margin-bottom: var(--space-md) !important; }
.mb-4 { margin-bottom: var(--space-lg) !important; }
.mb-5 { margin-bottom: var(--space-xl) !important; }

.ms-0 { margin-left: 0 !important; }
.ms-1 { margin-left: var(--space-xs) !important; }
.ms-2 { margin-left: var(--space-sm) !important; }
.ms-3 { margin-left: var(--space-md) !important; }
.ms-4 { margin-left: var(--space-lg) !important; }
.ms-5 { margin-left: var(--space-xl) !important; }
.ms-auto { margin-left: auto !important; }

.me-0 { margin-right: 0 !important; }
.me-1 { margin-right: var(--space-xs) !important; }
.me-2 { margin-right: var(--space-sm) !important; }
.me-3 { margin-right: var(--space-md) !important; }
.me-4 { margin-right: var(--space-lg) !important; }
.me-5 { margin-right: var(--space-xl) !important; }
.me-auto { margin-right: auto !important; }

.mx-0 { margin-left: 0 !important; margin-right: 0 !important; }
.mx-1 { margin-left: var(--space-xs) !important; margin-right: var(--space-xs) !important; }
.mx-2 { margin-left: var(--space-sm) !important; margin-right: var(--space-sm) !important; }
.mx-3 { margin-left: var(--space-md) !important; margin-right: var(--space-md) !important; }
.mx-4 { margin-left: var(--space-lg) !important; margin-right: var(--space-lg) !important; }
.mx-5 { margin-left: var(--space-xl) !important; margin-right: var(--space-xl) !important; }
.mx-auto { margin-left: auto !important; margin-right: auto !important; }

.my-0 { margin-top: 0 !important; margin-bottom: 0 !important; }
.my-1 { margin-top: var(--space-xs) !important; margin-bottom: var(--space-xs) !important; }
.my-2 { margin-top: var(--space-sm) !important; margin-bottom: var(--space-sm) !important; }
.my-3 { margin-top: var(--space-md) !important; margin-bottom: var(--space-md) !important; }
.my-4 { margin-top: var(--space-lg) !important; margin-bottom: var(--space-lg) !important; }
.my-5 { margin-top: var(--space-xl) !important; margin-bottom: var(--space-xl) !important; }

/* Padding */
.p-0  { padding: 0 !important; }
.p-1  { padding: var(--space-xs) !important; }
.p-2  { padding: var(--space-sm) !important; }
.p-3  { padding: var(--space-md) !important; }
.p-4  { padding: var(--space-lg) !important; }
.p-5  { padding: var(--space-xl) !important; }

.pt-0 { padding-top: 0 !important; }
.pt-1 { padding-top: var(--space-xs) !important; }
.pt-2 { padding-top: var(--space-sm) !important; }
.pt-3 { padding-top: var(--space-md) !important; }
.pt-4 { padding-top: var(--space-lg) !important; }
.pt-5 { padding-top: var(--space-xl) !important; }

.pb-0 { padding-bottom: 0 !important; }
.pb-1 { padding-bottom: var(--space-xs) !important; }
.pb-2 { padding-bottom: var(--space-sm) !important; }
.pb-3 { padding-bottom: var(--space-md) !important; }
.pb-4 { padding-bottom: var(--space-lg) !important; }
.pb-5 { padding-bottom: var(--space-xl) !important; }

.ps-0 { padding-left: 0 !important; }
.ps-1 { padding-left: var(--space-xs) !important; }
.ps-2 { padding-left: var(--space-sm) !important; }
.ps-3 { padding-left: var(--space-md) !important; }
.ps-4 { padding-left: var(--space-lg) !important; }
.ps-5 { padding-left: var(--space-xl) !important; }

.pe-0 { padding-right: 0 !important; }
.pe-1 { padding-right: var(--space-xs) !important; }
.pe-2 { padding-right: var(--space-sm) !important; }
.pe-3 { padding-right: var(--space-md) !important; }
.pe-4 { padding-right: var(--space-lg) !important; }
.pe-5 { padding-right: var(--space-xl) !important; }

.px-0 { padding-left: 0 !important; padding-right: 0 !important; }
.px-1 { padding-left: var(--space-xs) !important; padding-right: var(--space-xs) !important; }
.px-2 { padding-left: var(--space-sm) !important; padding-right: var(--space-sm) !important; }
.px-3 { padding-left: var(--space-md) !important; padding-right: var(--space-md) !important; }
.px-4 { padding-left: var(--space-lg) !important; padding-right: var(--space-lg) !important; }
.px-5 { padding-left: var(--space-xl) !important; padding-right: var(--space-xl) !important; }

.py-0 { padding-top: 0 !important; padding-bottom: 0 !important; }
.py-1 { padding-top: var(--space-xs) !important; padding-bottom: var(--space-xs) !important; }
.py-2 { padding-top: var(--space-sm) !important; padding-bottom: var(--space-sm) !important; }
.py-3 { padding-top: var(--space-md) !important; padding-bottom: var(--space-md) !important; }
.py-4 { padding-top: var(--space-lg) !important; padding-bottom: var(--space-lg) !important; }
.py-5 { padding-top: var(--space-xl) !important; padding-bottom: var(--space-xl) !important; }

/* Gap */
.gap-0 { gap: 0 !important; }
.gap-1 { gap: var(--space-xs) !important; }
.gap-2 { gap: var(--space-sm) !important; }
.gap-3 { gap: var(--space-md) !important; }
.gap-4 { gap: var(--space-lg) !important; }
.gap-5 { gap: var(--space-xl) !important; }

/* ═══════════════════════════════════════════════════════
   SIZING UTILITIES
   ═══════════════════════════════════════════════════════ */

.w-25  { width: 25% !important; }
.w-50  { width: 50% !important; }
.w-75  { width: 75% !important; }
.w-100 { width: 100% !important; }
.w-auto { width: auto !important; }
.h-25  { height: 25% !important; }
.h-50  { height: 50% !important; }
.h-75  { height: 75% !important; }
.h-100 { height: 100% !important; }
.h-auto { height: auto !important; }
.mw-100 { max-width: 100% !important; }
.mh-100 { max-height: 100% !important; }

/* ═══════════════════════════════════════════════════════
   TEXT UTILITIES
   ═══════════════════════════════════════════════════════ */

.text-start   { text-align: left !important; }
.text-end     { text-align: right !important; }
.text-center  { text-align: center !important; }

.text-primary   { color: var(--pond-green) !important; }
.text-secondary { color: var(--pond-slate) !important; }
.text-success   { color: var(--pond-agree) !important; }
.text-danger    { color: var(--pond-maple) !important; }
.text-warning   { color: var(--pond-duck) !important; }
.text-info      { color: var(--pond-info) !important; }
.text-muted     { color: var(--pond-mist) !important; }
.text-white     { color: var(--pond-white) !important; }
.text-dark      { color: var(--pond-ink) !important; }
.text-body      { color: var(--pond-charcoal) !important; }

.text-decoration-none      { text-decoration: none !important; }
.text-decoration-underline { text-decoration: underline !important; }
.text-uppercase   { text-transform: uppercase !important; }
.text-lowercase   { text-transform: lowercase !important; }
.text-capitalize  { text-transform: capitalize !important; }
.text-nowrap      { white-space: nowrap !important; }
.text-truncate    { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.text-break       { word-wrap: break-word !important; word-break: break-word !important; }

.fw-light    { font-weight: 300 !important; }
.fw-normal   { font-weight: 400 !important; }
.fw-medium   { font-weight: 500 !important; }
.fw-semibold { font-weight: 600 !important; }
.fw-bold     { font-weight: 700 !important; }
.fw-bolder   { font-weight: 800 !important; }
.fst-italic  { font-style: italic !important; }
.fst-normal  { font-style: normal !important; }

.fs-1 { font-size: 2rem !important; }
.fs-2 { font-size: 1.5rem !important; }
.fs-3 { font-size: 1.25rem !important; }
.fs-4 { font-size: 1rem !important; }
.fs-5 { font-size: 0.875rem !important; }
.fs-6 { font-size: 0.75rem !important; }

.lh-1  { line-height: 1 !important; }
.lh-sm { line-height: 1.25 !important; }
.lh-base { line-height: 1.5 !important; }
.lh-lg { line-height: 2 !important; }

.small { font-size: 0.875em !important; }
.lead  { font-size: 1.125rem; font-weight: 400; line-height: 1.65; }

/* ═══════════════════════════════════════════════════════
   BACKGROUND UTILITIES
   ═══════════════════════════════════════════════════════ */

.bg-primary   { background-color: var(--pond-green) !important; }
.bg-secondary { background-color: var(--pond-slate) !important; }
.bg-success   { background-color: var(--pond-agree) !important; }
.bg-danger    { background-color: var(--pond-maple) !important; }
.bg-warning   { background-color: var(--pond-duck) !important; }
.bg-info      { background-color: var(--pond-info) !important; }
.bg-light     { background-color: var(--pond-frost) !important; }
.bg-dark      { background-color: var(--pond-ink) !important; }
.bg-white     { background-color: var(--pond-white) !important; }
.bg-body      { background-color: var(--pond-frost) !important; }
.bg-transparent { background-color: transparent !important; }

/* ═══════════════════════════════════════════════════════
   BORDER, RADIUS, SHADOW
   ═══════════════════════════════════════════════════════ */

.border         { border: 1px solid var(--pond-cloud) !important; }
.border-0       { border: 0 !important; }
.border-top     { border-top: 1px solid var(--pond-cloud) !important; }
.border-bottom  { border-bottom: 1px solid var(--pond-cloud) !important; }
.border-start   { border-left: 1px solid var(--pond-cloud) !important; }
.border-end     { border-right: 1px solid var(--pond-cloud) !important; }

.border-primary   { border-color: var(--pond-green) !important; }
.border-secondary { border-color: var(--pond-slate) !important; }
.border-success   { border-color: var(--pond-agree) !important; }
.border-danger    { border-color: var(--pond-maple) !important; }
.border-warning   { border-color: var(--pond-duck) !important; }
.border-info      { border-color: var(--pond-info) !important; }
.border-light     { border-color: var(--pond-cloud) !important; }
.border-dark      { border-color: var(--pond-ink) !important; }

/* Border widths */
.border-1 { border-width: 1px !important; }
.border-2 { border-width: 2px !important; }
.border-3 { border-width: 3px !important; }
.border-4 { border-width: 4px !important; }
.border-5 { border-width: 5px !important; }

/* Background opacity modifiers */
.bg-opacity-10 { --bs-bg-opacity: 0.1; }
.bg-opacity-25 { --bs-bg-opacity: 0.25; }
.bg-opacity-50 { --bs-bg-opacity: 0.5; }
.bg-opacity-75 { --bs-bg-opacity: 0.75; }
.bg-opacity-100 { --bs-bg-opacity: 1; }

.rounded     { border-radius: var(--radius-md) !important; }
.rounded-0   { border-radius: 0 !important; }
.rounded-1   { border-radius: var(--radius-sm) !important; }
.rounded-2   { border-radius: var(--radius-md) !important; }
.rounded-3   { border-radius: var(--radius-lg) !important; }
.rounded-circle { border-radius: 50% !important; }
.rounded-pill   { border-radius: 50rem !important; }

.shadow    { box-shadow: var(--shadow-md) !important; }
.shadow-sm { box-shadow: var(--shadow-sm) !important; }
.shadow-lg { box-shadow: var(--shadow-lg) !important; }
.shadow-none { box-shadow: none !important; }

/* ═══════════════════════════════════════════════════════
   POSITION & OVERFLOW
   ═══════════════════════════════════════════════════════ */

.position-static   { position: static !important; }
.position-relative { position: relative !important; }
.position-absolute { position: absolute !important; }
.position-fixed    { position: fixed !important; }
.position-sticky   { position: sticky !important; }

.top-0    { top: 0 !important; }
.bottom-0 { bottom: 0 !important; }
.start-0  { left: 0 !important; }
.end-0    { right: 0 !important; }

.overflow-auto    { overflow: auto !important; }
.overflow-hidden  { overflow: hidden !important; }
.overflow-visible { overflow: visible !important; }

.float-start { float: left !important; }
.float-end   { float: right !important; }
.float-none  { float: none !important; }
.clearfix::after { display: block; clear: both; content: ""; }

/* ═══════════════════════════════════════════════════════
   VISIBILITY & INTERACTION
   ═══════════════════════════════════════════════════════ */

.visible   { visibility: visible !important; }
.invisible { visibility: hidden !important; }
.opacity-0   { opacity: 0 !important; }
.opacity-25  { opacity: 0.25 !important; }
.opacity-50  { opacity: 0.5 !important; }
.opacity-75  { opacity: 0.75 !important; }
.opacity-100 { opacity: 1 !important; }
.pe-none  { pointer-events: none !important; }
.pe-auto  { pointer-events: auto !important; }
.user-select-none { user-select: none !important; }
.user-select-all  { user-select: all !important; }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Cards
   ═══════════════════════════════════════════════════════ */

.card {
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  word-wrap: break-word;
  transition: box-shadow var(--transition-normal);
}
.card:hover {
  box-shadow: var(--shadow-sm);
}
.card-body {
  flex: 1 1 auto;
  padding: var(--space-lg);
}
.card-header {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--pond-frost);
  background: var(--pond-snow);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  font-weight: 600;
}
.card-footer {
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--pond-frost);
  background: var(--pond-snow);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}
.card-title {
  margin-bottom: var(--space-sm);
  font-weight: 700;
  color: var(--pond-ink);
}
.card-subtitle {
  margin-top: calc(var(--space-xs) * -1);
  margin-bottom: var(--space-sm);
  color: var(--pond-mist);
}
.card-text:last-child {
  margin-bottom: 0;
}
.card-img-top {
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  width: 100%;
}

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Buttons
   ═══════════════════════════════════════════════════════ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-lg);
  font-size: 0.875rem;
  font-weight: 600;
  font-family: var(--font-body);
  line-height: 1.5;
  border: 1.5px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
  text-align: center;
  white-space: nowrap;
  vertical-align: middle;
  user-select: none;
}
.btn:hover { text-decoration: none; }
.btn:focus-visible { outline: 0; box-shadow: var(--shadow-focus); }
.btn:disabled, .btn.disabled { opacity: 0.65; pointer-events: none; }

.btn-primary {
  background: var(--pond-green);
  color: var(--pond-white);
  border-color: var(--pond-green);
}
.btn-primary:hover { background: var(--pond-green-mid); border-color: var(--pond-green-mid); }

.btn-secondary {
  background: var(--pond-slate);
  color: var(--pond-white);
  border-color: var(--pond-slate);
}
.btn-secondary:hover { background: var(--pond-charcoal); border-color: var(--pond-charcoal); }

.btn-success {
  background: var(--pond-agree);
  color: var(--pond-white);
  border-color: var(--pond-agree);
}
.btn-success:hover { background: var(--pond-green-light); border-color: var(--pond-green-light); }

.btn-danger {
  background: var(--pond-maple);
  color: var(--pond-white);
  border-color: var(--pond-maple);
}
.btn-danger:hover { background: var(--pond-maple-light); border-color: var(--pond-maple-light); }

.btn-warning {
  background: var(--pond-duck);
  color: var(--pond-white);
  border-color: var(--pond-duck);
}
.btn-warning:hover { background: var(--pond-duck-dark); border-color: var(--pond-duck-dark); }

.btn-info {
  background: var(--pond-info);
  color: var(--pond-white);
  border-color: var(--pond-info);
}
.btn-info:hover { opacity: 0.9; }

.btn-light {
  background: var(--pond-frost);
  color: var(--pond-ink);
  border-color: var(--pond-cloud);
}
.btn-light:hover { background: var(--pond-cloud); }

.btn-dark {
  background: var(--pond-ink);
  color: var(--pond-white);
  border-color: var(--pond-ink);
}
.btn-dark:hover { background: var(--pond-charcoal); }

.btn-link {
  background: transparent;
  color: var(--pond-green-mid);
  border-color: transparent;
  text-decoration: underline;
  font-weight: 400;
}
.btn-link:hover { color: var(--pond-duck); }

/* Outline variants */
.btn-outline-primary {
  background: transparent;
  color: var(--pond-green);
  border-color: var(--pond-green);
}
.btn-outline-primary:hover { background: var(--pond-green); color: var(--pond-white); }

.btn-outline-secondary {
  background: transparent;
  color: var(--pond-slate);
  border-color: var(--pond-slate);
}
.btn-outline-secondary:hover { background: var(--pond-slate); color: var(--pond-white); }

.btn-outline-success {
  background: transparent;
  color: var(--pond-agree);
  border-color: var(--pond-agree);
}
.btn-outline-success:hover { background: var(--pond-agree); color: var(--pond-white); }

.btn-outline-danger {
  background: transparent;
  color: var(--pond-maple);
  border-color: var(--pond-maple);
}
.btn-outline-danger:hover { background: var(--pond-maple); color: var(--pond-white); }

.btn-outline-warning {
  background: transparent;
  color: var(--pond-duck-dark);
  border-color: var(--pond-duck);
}
.btn-outline-warning:hover { background: var(--pond-duck); color: var(--pond-white); }

.btn-outline-info {
  background: transparent;
  color: var(--pond-info);
  border-color: var(--pond-info);
}
.btn-outline-info:hover { background: var(--pond-info); color: var(--pond-white); }

/* Button sizes */
.btn-sm {
  padding: 3px var(--space-sm);
  font-size: 0.75rem;
  border-radius: var(--radius-sm);
}
.btn-lg {
  padding: var(--space-md) var(--space-xl);
  font-size: 1rem;
  border-radius: var(--radius-lg);
}
.btn-block { display: block; width: 100%; }
.btn-group { display: inline-flex; }
.btn-group > .btn { border-radius: 0; }
.btn-group > .btn:first-child { border-radius: var(--radius-md) 0 0 var(--radius-md); }
.btn-group > .btn:last-child { border-radius: 0 var(--radius-md) var(--radius-md) 0; }
.btn-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5em;
  height: 1.5em;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: var(--radius-sm);
  opacity: 0.5;
  cursor: pointer;
  font-size: 1rem;
}
.btn-close::before { content: "\00d7"; }
.btn-close:hover { opacity: 1; }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Badges
   ═══════════════════════════════════════════════════════ */

.badge {
  display: inline-flex;
  align-items: center;
  padding: 3px var(--space-sm);
  font-size: 0.6875rem;
  font-weight: 700;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  line-height: 1;
}
.badge.bg-primary   { background: var(--pond-green) !important; color: var(--pond-white); }
.badge.bg-secondary { background: var(--pond-slate) !important; color: var(--pond-white); }
.badge.bg-success   { background: var(--pond-agree) !important; color: var(--pond-white); }
.badge.bg-danger    { background: var(--pond-maple) !important; color: var(--pond-white); }
.badge.bg-warning   { background: var(--pond-duck) !important; color: var(--pond-white); }
.badge.bg-info      { background: var(--pond-info) !important; color: var(--pond-white); }
.badge.bg-light     { background: var(--pond-frost) !important; color: var(--pond-ink); }
.badge.bg-dark      { background: var(--pond-ink) !important; color: var(--pond-white); }
.badge.rounded-pill { border-radius: 50rem; }

/* Bootstrap 4 badge-variant backward compat */
.badge-primary   { background: var(--pond-green); color: var(--pond-white); }
.badge-secondary { background: var(--pond-slate); color: var(--pond-white); }
.badge-success   { background: var(--pond-agree); color: var(--pond-white); }
.badge-danger    { background: var(--pond-maple); color: var(--pond-white); }
.badge-warning   { background: var(--pond-duck); color: var(--pond-white); }
.badge-info      { background: var(--pond-info); color: var(--pond-white); }
.badge-light     { background: var(--pond-frost); color: var(--pond-ink); }
.badge-dark      { background: var(--pond-ink); color: var(--pond-white); }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Alerts
   ═══════════════════════════════════════════════════════ */

.alert {
  position: relative;
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-lg);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  line-height: 1.5;
}
.alert-primary   { background: rgba(27,67,50,0.06); color: var(--pond-green);  border-color: rgba(27,67,50,0.15); }
.alert-secondary { background: rgba(74,74,94,0.06); color: var(--pond-slate);  border-color: rgba(74,74,94,0.15); }
.alert-success   { background: var(--pond-green-pale); color: var(--pond-green);  border-color: rgba(45,106,79,0.2); }
.alert-danger    { background: rgba(196,30,58,0.06); color: var(--pond-maple); border-color: rgba(196,30,58,0.15); }
.alert-warning   { background: rgba(212,160,23,0.08); color: var(--pond-duck-dark); border-color: rgba(212,160,23,0.2); }
.alert-info      { background: rgba(27,107,147,0.06); color: var(--pond-info);  border-color: rgba(27,107,147,0.15); }
.alert-light     { background: var(--pond-frost); color: var(--pond-slate); border-color: var(--pond-cloud); }
.alert-dark      { background: rgba(26,26,46,0.06); color: var(--pond-ink); border-color: rgba(26,26,46,0.15); }
.alert-dismissible { padding-right: 3rem; }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Progress
   ═══════════════════════════════════════════════════════ */

.progress {
  display: flex;
  height: 0.75rem;
  overflow: hidden;
  background: var(--pond-cloud);
  border-radius: var(--radius-md);
  font-size: 0.625rem;
}
.progress-bar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  color: var(--pond-white);
  text-align: center;
  white-space: nowrap;
  background: var(--pond-green);
  border-radius: var(--radius-md);
  transition: width 0.6s var(--ease-out);
}
.progress-bar.bg-success { background: var(--pond-agree) !important; }
.progress-bar.bg-danger  { background: var(--pond-maple) !important; }
.progress-bar.bg-warning { background: var(--pond-duck) !important; }
.progress-bar.bg-info    { background: var(--pond-info) !important; }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Tables
   ═══════════════════════════════════════════════════════ */

.table {
  width: 100%;
  margin-bottom: var(--space-lg);
  color: var(--pond-charcoal);
  border-collapse: collapse;
  font-size: 0.875rem;
}
.table th,
.table td {
  padding: var(--space-sm) var(--space-md);
  vertical-align: top;
  border-top: 1px solid var(--pond-cloud);
}
.table thead th {
  vertical-align: bottom;
  border-bottom: 2px solid var(--pond-cloud);
  font-weight: 700;
  color: var(--pond-ink);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.table tbody + tbody {
  border-top: 2px solid var(--pond-cloud);
}
.table-striped tbody tr:nth-of-type(odd) {
  background: var(--pond-snow);
}
.table-bordered {
  border: 1px solid var(--pond-cloud);
}
.table-bordered th,
.table-bordered td {
  border: 1px solid var(--pond-cloud);
}
.table-hover tbody tr:hover {
  background: var(--pond-frost);
}
.table-sm th,
.table-sm td {
  padding: var(--space-xs) var(--space-sm);
}
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ═══════════════════════════════════════════════════════
   COMPONENTS — List Group
   ═══════════════════════════════════════════════════════ */

.list-group {
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  border-radius: var(--radius-md);
}
.list-group-item {
  position: relative;
  display: block;
  padding: var(--space-sm) var(--space-lg);
  color: var(--pond-charcoal);
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  text-decoration: none;
}
.list-group-item:first-child { border-radius: var(--radius-md) var(--radius-md) 0 0; }
.list-group-item:last-child { border-radius: 0 0 var(--radius-md) var(--radius-md); }
.list-group-item + .list-group-item { border-top-width: 0; }
.list-group-item.active {
  background: var(--pond-green);
  color: var(--pond-white);
  border-color: var(--pond-green);
}
.list-group-item-action:hover {
  background: var(--pond-frost);
  color: var(--pond-ink);
}
.list-group-flush .list-group-item {
  border-left: 0;
  border-right: 0;
  border-radius: 0;
}

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Nav / Tabs / Pills
   ═══════════════════════════════════════════════════════ */

.nav {
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.nav-link {
  display: block;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--pond-slate);
  text-decoration: none;
  transition: color var(--transition-fast), background var(--transition-fast);
  border-radius: var(--radius-md);
}
.nav-link:hover { color: var(--pond-green); }
.nav-link.active { color: var(--pond-green); font-weight: 700; }
.nav-link.disabled { color: var(--pond-mist); pointer-events: none; }

.nav-tabs {
  border-bottom: 2px solid var(--pond-cloud);
}
.nav-tabs .nav-link {
  border: none;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  margin-bottom: -2px;
  padding: var(--space-sm) var(--space-lg);
}
.nav-tabs .nav-link.active {
  color: var(--pond-green);
  border-bottom-color: var(--pond-green);
  font-weight: 700;
}
.nav-tabs .nav-link:hover {
  border-bottom-color: var(--pond-mist);
}

.nav-pills .nav-link {
  border-radius: var(--radius-md);
}
.nav-pills .nav-link.active {
  background: var(--pond-green);
  color: var(--pond-white);
}

.tab-content > .tab-pane { display: none; }
.tab-content > .active { display: block; }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Modal
   ═══════════════════════════════════════════════════════ */

.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1055;
  display: none;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
}
.modal.show { display: block; }
.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1050;
  width: 100vw;
  height: 100vh;
  background: rgba(0,0,0,0.5);
}
.modal-backdrop.show { opacity: 1; }
.modal-dialog {
  position: relative;
  width: auto;
  margin: var(--space-xl) auto;
  max-width: 500px;
  pointer-events: none;
}
.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  pointer-events: auto;
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  outline: 0;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg);
  border-bottom: 1px solid var(--pond-frost);
}
.modal-title {
  margin: 0;
  font-weight: 700;
  font-size: 1.125rem;
}
.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: var(--space-lg);
}
.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  border-top: 1px solid var(--pond-frost);
}
.modal-dialog-centered {
  display: flex;
  align-items: center;
  min-height: calc(100% - var(--space-xl) * 2);
}

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Forms
   ═══════════════════════════════════════════════════════ */

.form-control {
  display: block;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--pond-ink);
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  font-family: var(--font-body);
  appearance: none;
}
.form-control:focus {
  border-color: var(--pond-green-mid);
  box-shadow: var(--shadow-focus);
  outline: 0;
}
.form-control::placeholder { color: var(--pond-mist); }
.form-control:disabled,
.form-control[readonly] { background: var(--pond-frost); opacity: 1; }
.form-control-sm { padding: var(--space-xs) var(--space-sm); font-size: 0.8125rem; }
.form-control-lg { padding: var(--space-md) var(--space-lg); font-size: 1rem; }

textarea.form-control { min-height: 80px; resize: vertical; }

.form-label {
  display: inline-block;
  margin-bottom: var(--space-xs);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pond-ink);
}

.form-select {
  display: block;
  width: 100%;
  padding: var(--space-sm) var(--space-2xl) var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--pond-ink);
  background-color: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast);
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%234A4A5E' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right var(--space-md) center;
  background-size: 16px 12px;
}
.form-select:focus {
  border-color: var(--pond-green-mid);
  box-shadow: var(--shadow-focus);
  outline: 0;
}

.form-group {
  margin-bottom: var(--space-lg);
}

.form-check {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding-left: 0;
  margin-bottom: var(--space-sm);
  min-height: 1.5rem;
}
.form-check-input {
  width: 1em;
  height: 1em;
  margin: 0;
  vertical-align: middle;
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-sm);
  appearance: none;
  background: var(--pond-white);
  cursor: pointer;
  flex-shrink: 0;
}
.form-check-input[type="radio"] { border-radius: 50%; }
.form-check-input:checked {
  background-color: var(--pond-green);
  border-color: var(--pond-green);
}
.form-check-label {
  font-size: 0.875rem;
  color: var(--pond-charcoal);
  cursor: pointer;
}

.form-text {
  display: block;
  margin-top: var(--space-xs);
  font-size: 0.75rem;
  color: var(--pond-mist);
}

.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%;
}
.input-group > .form-control,
.input-group > .form-select {
  position: relative;
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
}
.input-group > .form-control:not(:first-child),
.input-group > .form-select:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.input-group > .form-control:not(:last-child),
.input-group > .form-select:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group-text {
  display: flex;
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  color: var(--pond-slate);
  background: var(--pond-frost);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  white-space: nowrap;
}

.form-floating { position: relative; }
.form-floating > .form-control { height: calc(3.5rem + 2px); padding: 1rem var(--space-md); }
.form-floating > label {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  padding: 1rem var(--space-md);
  pointer-events: none;
  border: 1px solid transparent;
  transform-origin: 0 0;
  transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out;
  color: var(--pond-mist);
}
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label {
  opacity: 0.65;
  transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}

.is-invalid .form-control,
.form-control.is-invalid {
  border-color: var(--pond-maple);
}
.invalid-feedback {
  display: none;
  width: 100%;
  margin-top: var(--space-xs);
  font-size: 0.75rem;
  color: var(--pond-maple);
}
.is-invalid ~ .invalid-feedback,
.was-validated :invalid ~ .invalid-feedback { display: block; }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Breadcrumb
   ═══════════════════════════════════════════════════════ */

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin-bottom: var(--space-lg);
  list-style: none;
  font-size: 0.8125rem;
}
.breadcrumb-item + .breadcrumb-item::before {
  content: "/";
  padding: 0 var(--space-sm);
  color: var(--pond-mist);
}
.breadcrumb-item a { color: var(--pond-green-mid); }
.breadcrumb-item.active { color: var(--pond-mist); }

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Pagination
   ═══════════════════════════════════════════════════════ */

.pagination {
  display: flex;
  padding-left: 0;
  list-style: none;
  gap: var(--space-xs);
}
.page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  padding: 0 var(--space-sm);
  font-size: 0.8125rem;
  color: var(--pond-slate);
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: all var(--transition-fast);
}
.page-link:hover {
  background: var(--pond-frost);
  color: var(--pond-green);
  border-color: var(--pond-green-mid);
}
.page-item.active .page-link {
  background: var(--pond-green);
  color: var(--pond-white);
  border-color: var(--pond-green);
}
.page-item.disabled .page-link {
  color: var(--pond-mist);
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Spinner
   ═══════════════════════════════════════════════════════ */

.spinner-border {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  vertical-align: text-bottom;
  border: 0.25em solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spinner-border 0.75s linear infinite;
}
.spinner-border-sm { width: 1rem; height: 1rem; border-width: 0.2em; }
@keyframes spinner-border {
  to { transform: rotate(360deg); }
}

/* ═══════════════════════════════════════════════════════
   COMPONENTS — Accordion
   ═══════════════════════════════════════════════════════ */

.accordion-item {
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
}
.accordion-item:first-of-type { border-radius: var(--radius-md) var(--radius-md) 0 0; }
.accordion-item:last-of-type { border-radius: 0 0 var(--radius-md) var(--radius-md); }
.accordion-item + .accordion-item { border-top: 0; }
.accordion-header { margin-bottom: 0; }
.accordion-button {
  display: flex;
  align-items: center;
  width: 100%;
  padding: var(--space-md) var(--space-lg);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--pond-ink);
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
}
.accordion-button:not(.collapsed) { color: var(--pond-green); background: var(--pond-snow); }
.accordion-body { padding: var(--space-lg); }

/* ═══════════════════════════════════════════════════════
   LISTS
   ═══════════════════════════════════════════════════════ */

.list-unstyled { list-style: none; padding-left: 0; }
.list-inline { list-style: none; padding-left: 0; }
.list-inline-item { display: inline-block; }
.list-inline-item:not(:last-child) { margin-right: var(--space-sm); }

/* ═══════════════════════════════════════════════════════
   IMAGES & FIGURES
   ═══════════════════════════════════════════════════════ */

.img-fluid { max-width: 100%; height: auto; }
.img-thumbnail {
  padding: var(--space-xs);
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  max-width: 100%;
  height: auto;
}
.figure { display: inline-block; }
.figure-img { margin-bottom: var(--space-sm); line-height: 1; }
.figure-caption { font-size: 0.875em; color: var(--pond-mist); }

/* ═══════════════════════════════════════════════════════
   COLLAPSE / SHOW helpers (no JS behavior, just visibility)
   ═══════════════════════════════════════════════════════ */

.collapse:not(.show) { display: none; }
.collapse.show { display: block; }
.collapsing { height: 0; overflow: hidden; transition: height 0.35s ease; }
.fade:not(.show) { opacity: 0; }
.fade.show { opacity: 1; }

/* ═══════════════════════════════════════════════════════
   TOOLTIP / POPOVER stubs (visual only, no JS behavior)
   ═══════════════════════════════════════════════════════ */

.tooltip { position: absolute; z-index: 1080; }
.popover { position: absolute; z-index: 1070; }

/* ═══════════════════════════════════════════════════════
   DISPLAY HEADINGS (Bootstrap .display-*)
   ═══════════════════════════════════════════════════════ */

.display-1 { font-size: 5rem !important; font-weight: 300 !important; line-height: 1.2 !important; }
.display-2 { font-size: 4.5rem !important; font-weight: 300 !important; line-height: 1.2 !important; }
.display-3 { font-size: 4rem !important; font-weight: 300 !important; line-height: 1.2 !important; }
.display-4 { font-size: 3.5rem !important; font-weight: 300 !important; line-height: 1.2 !important; }
.display-5 { font-size: 3rem !important; font-weight: 300 !important; line-height: 1.2 !important; }
.display-6 { font-size: 2.5rem !important; font-weight: 300 !important; line-height: 1.2 !important; }

/* ═══════════════════════════════════════════════════════
   GRID GUTTERS (Bootstrap .g-*, .gx-*, .gy-*)
   ═══════════════════════════════════════════════════════ */

.g-0 { --bs-gutter-x: 0; --bs-gutter-y: 0; }
.g-1 { --bs-gutter-x: var(--space-xs); --bs-gutter-y: var(--space-xs); }
.g-2 { --bs-gutter-x: var(--space-sm); --bs-gutter-y: var(--space-sm); }
.g-3 { --bs-gutter-x: var(--space-md); --bs-gutter-y: var(--space-md); }
.g-4 { --bs-gutter-x: var(--space-lg); --bs-gutter-y: var(--space-lg); }
.g-5 { --bs-gutter-x: var(--space-xl); --bs-gutter-y: var(--space-xl); }

.gx-0 { --bs-gutter-x: 0; }
.gx-1 { --bs-gutter-x: var(--space-xs); }
.gx-2 { --bs-gutter-x: var(--space-sm); }
.gx-3 { --bs-gutter-x: var(--space-md); }
.gx-4 { --bs-gutter-x: var(--space-lg); }
.gx-5 { --bs-gutter-x: var(--space-xl); }

.gy-0 { --bs-gutter-y: 0; }
.gy-1 { --bs-gutter-y: var(--space-xs); }
.gy-2 { --bs-gutter-y: var(--space-sm); }
.gy-3 { --bs-gutter-y: var(--space-md); }
.gy-4 { --bs-gutter-y: var(--space-lg); }
.gy-5 { --bs-gutter-y: var(--space-xl); }

/* Apply gutter vars to row children */
.row[class*="g-"] { margin-left: calc(var(--bs-gutter-x, var(--space-lg)) * -0.5); margin-right: calc(var(--bs-gutter-x, var(--space-lg)) * -0.5); }
.row[class*="g-"] > * { padding-left: calc(var(--bs-gutter-x, var(--space-lg)) * 0.5); padding-right: calc(var(--bs-gutter-x, var(--space-lg)) * 0.5); }
.row[class*="g-"] > * { margin-top: var(--bs-gutter-y, 0); }

/* ═══════════════════════════════════════════════════════
   ADDITIONAL BUTTON UTILITIES
   ═══════════════════════════════════════════════════════ */

.btn-block { display: block !important; width: 100% !important; }

/* ═══════════════════════════════════════════════════════
   DRUPAL FORM ELEMENT STYLING
   These are Drupal core classes (not Bootstrap) but need
   styling since stable9 provides only minimal CSS.
   ═══════════════════════════════════════════════════════ */

.form-item {
  margin-bottom: var(--space-lg);
}

.form-item label,
.form-item .form-required {
  display: inline-block;
  margin-bottom: var(--space-xs);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pond-ink);
}

.form-item .description {
  margin-top: var(--space-xs);
  font-size: 0.75rem;
  color: var(--pond-mist);
}

/* Text inputs, textareas, selects from Drupal */
.form-text,
.form-email,
.form-url,
.form-tel,
.form-number,
.form-search,
.form-date,
.form-file,
input[type="text"].form-text,
input[type="email"].form-email,
input[type="password"],
textarea.form-textarea {
  display: block;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--pond-ink);
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  font-family: var(--font-body);
}

.form-text:focus,
.form-email:focus,
.form-url:focus,
.form-tel:focus,
.form-number:focus,
textarea.form-textarea:focus,
input[type="password"]:focus {
  border-color: var(--pond-green-mid);
  box-shadow: var(--shadow-focus);
  outline: 0;
}

textarea.form-textarea {
  min-height: 120px;
  resize: vertical;
}

/* Drupal select */
select {
  display: block;
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  font-size: 0.875rem;
  color: var(--pond-ink);
  background: var(--pond-white);
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
}

/* Submit buttons (Drupal core) */
.form-submit,
input[type="submit"],
button[type="submit"]:not(.visually-hidden):not(.ducklings-search__submit) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-sm) var(--space-xl);
  font-size: 0.875rem;
  font-weight: 600;
  font-family: var(--font-body);
  color: var(--pond-white);
  background: var(--pond-green);
  border: 1.5px solid var(--pond-green);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--transition-fast);
  text-decoration: none;
}

.form-submit:hover,
input[type="submit"]:hover {
  background: var(--pond-green-mid);
  border-color: var(--pond-green-mid);
}

/* Drupal fieldsets */
fieldset {
  border: 1px solid var(--pond-cloud);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}

fieldset legend {
  font-weight: 700;
  font-size: 0.875rem;
  color: var(--pond-ink);
  padding: 0 var(--space-sm);
}

/* Form actions container */
.form-actions {
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--pond-frost);
  display: flex;
  gap: var(--space-sm);
}

/* Drupal messages */
.messages {
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-lg);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
}
.messages--status {
  background: var(--pond-green-pale);
  color: var(--pond-green);
  border-color: rgba(45,106,79,0.2);
}
.messages--warning {
  background: rgba(212,160,23,0.08);
  color: var(--pond-duck-dark);
  border-color: rgba(212,160,23,0.2);
}
.messages--error {
  background: rgba(196,30,58,0.06);
  color: var(--pond-maple);
  border-color: rgba(196,30,58,0.15);
}

/* ═══════════════════════════════════════════════════════
   FOOTER STYLING
   ═══════════════════════════════════════════════════════ */

.ducklings-footer {
  padding: var(--space-md) var(--space-xl);
  border-top: 1px solid var(--pond-cloud);
  background: var(--pond-white);
  font-size: 0.75rem;
  color: var(--pond-mist);
}
.ducklings-footer ul {
  list-style: none;
  display: flex;
  gap: var(--space-lg);
  padding: 0;
  margin: 0;
}
.ducklings-footer a {
  color: var(--pond-mist);
  transition: color var(--transition-fast);
}
.ducklings-footer a:hover {
  color: var(--pond-green-mid);
}
