:root {
  --t4-light-1: #f1f5f9;
  --t4-light-2: #d7e3e3;
  --t4-light-3: #f8fafc;
  --t4-light-4: #fff;
  --border-color-1: #c3d5d5;
  --box-shadow: #dddfe2;
  --bg-1: #f2dede;
  --bg-2: #f5f5f5;
  --bg-3: #D5D8E1;
}

body.dark-active {
  --t4-light-1: rgba(225, 225, 225, 0.08);
  --t4-light-2: #000;
  --t4-light-3: rgba(225, 225, 225, 0.08);
  --t4-light-4: rgba(225, 225, 225, 0.09);
  --border-color-1: rgba(225, 225, 225, 0.2);
  --box-shadow: rgba(225, 225, 225, 0.14);
  --bg-1: #383d42;
  --bg-2: #1a1c1e;
  --bg-3: #2a2c2f;
}

/* HEADER */
.t4-header .header-block {
  padding-top: 12px;
  padding-bottom: 12px;
}

.navbar-brand {
  min-width: 266px;
}

@media (max-width: 576px) {
  .t4-offcanvas-toggle {
    color: #fff;
  }
  .t4-header-r .mod-finder .input-group {
    display: none;
  }
  .t4-header-r > * {
    margin-left: 0;
  }
  .ja-dark-mode {
    margin-left: 0.5rem;
  }
}

.t4-header .header-block .logo-img {
  max-height: 80px;
  width: auto;
}

/* Search */
.t4-header-r form {
  margin: 0;
}

.t4-header-r .mod-finder .input-group {
  margin-bottom: 0;
  gap: 0;
}

.t4-header-r .js-finder-search-query {
  border: 0;
  border-radius: 0;
  height: 40px;
  padding: 0 0.875rem;
  max-width: 160px !important;
}

.t4-header-r .mod-finder .input-group .btn {
  background: #000;
  border: 0;
  color: #fff;
  height: 40px;
  padding: 0 0.875rem;
}

/* --------------------------------------------
   MAIN MENU
   -------------------------------------------- */
.t4-megamenu .navbar-nav > li > a,
.t4-megamenu .navbar-nav > li > .nav-link {
  display: inline-flex;
  align-items: center;
  line-height: 0.7;
  font-size: 14px;
  /* Use lighter gold (#fdd3a1) for inactive links */
  color: #fdd3a1;
  text-decoration: none;
  border: 0;
  height: auto;
  transition: color 0.2s ease-in-out; /* smooth transition on hover */
}

/* Force top-level parent links to become white on hover */
.t4-megamenu .navbar-nav > li:hover > a,
.t4-megamenu .navbar-nav > li:hover > .nav-link {
  color: #fff !important; /* always white on hover */
}

/* The caret icon => also lighter gold (#fdd3a1) */
.t4-megamenu .navbar-nav > li > a .item-caret,
.t4-megamenu .navbar-nav > li > .nav-link .item-caret {
  display: inline-flex;
  align-items: center;
  margin-left: 6px; /* gap between text & caret */
  position: static;
  line-height: 1;
  height: auto;
}

.t4-megamenu .navbar-nav > li > a .item-caret::before,
.t4-megamenu .navbar-nav > li > .nav-link .item-caret::before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border: 4px solid transparent;
  /* Lighter gold caret */
  border-top-color: #fdd3a1 !important;
  vertical-align: middle; 
  transition: border-top-color 0.2s ease-in-out;
}

/* Active => lighter gold (#fdd3a1) */
.t4-megamenu .navbar-nav > li.active > a,
.t4-megamenu .navbar-nav > li.active > .nav-link {
  color: #fdd3a1 !important;
}
.t4-megamenu .navbar-nav > li.active > a .item-caret::before,
.t4-megamenu .navbar-nav > li.active > .nav-link .item-caret::before {
  border-top-color: #fdd3a1 !important;
}

/* (Optional) If you need a min-width on a specific menu ID */
.t4-navbar .nav-item[data-id="2245"] {
  min-width: 100px;
}

/* --------------------------------------------
   MEGA CAPTION
   --------------------------------------------
   Slightly larger size + extra top margin
   -------------------------------------------- */
.t4-megamenu .mega-caption {
  text-transform: none;
  font-size: 14px; 
  margin-top: 2.5rem; /* bigger space above caption */
  bottom: 0;
  white-space: nowrap;
  color: #da4444 !important; /* red */
}

/* h3 Mega-col-title => underline in #da4444 */
.t4-megamenu .mega-col-title h3 {
  display: inline-block;
  margin-bottom: 0.5rem;
  padding-bottom: 1px;
  border-bottom: 1px solid #da4444;
  color: #da4444;
}

/* --------------------------------------------
   DROPDOWN MENUS
   -------------------------------------------- */
.t4-megamenu .dropdown-menu {
  background: #630000;
  padding: 0 1rem;
}

/* Red underline between dropdown items */
.t4-megamenu .dropdown-menu .nav-item {
  border-bottom: 1px solid #da4444;
}

/* Sub-menu items => gold by default (now lighter gold), lighter gold on hover */
.t4-megamenu .dropdown-menu .nav-link,
.t4-megamenu .dropdown-menu li > a,
.t4-megamenu .dropdown-menu li .dropdown-item {
  font-weight: 400;
  font-size: 15px;
  opacity: 0.8;
  transition: color 0.2s ease-in-out;
  color: #fdd3a1 !important;
}

.t4-megamenu .dropdown-menu .nav-link:hover,
.t4-megamenu .dropdown-menu li > a:hover,
.t4-megamenu .dropdown-menu li .dropdown-item:hover {
  color: #fdd3a1 !important; /* keep lighter gold on hover, or change if desired */
  opacity: 1;
}

/* Section Intro */
.sec-intro {
  background: var(--t4-light-1);
  padding: 2rem 0;
}

#t4-slideshow {
  background: var(--t4-light-2);
  border-bottom: 1px solid var(--border-color-1);
}
#t4-slideshow .ja-ss-wrap {
  position: relative;
}
#t4-slideshow .ja-ss-wrap:before,
#t4-slideshow .ja-ss-wrap:after {
  background: linear-gradient(
    to right,
    var(--t4-light-2) 0%,
    var(--t4-light-2) 60%,
    rgba(255, 255, 255, 0)
  );
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 200px;
  z-index: 50;
}
#t4-slideshow .ja-ss-wrap:after {
  background: linear-gradient(
    to left,
    var(--t4-light-2) 0%,
    var(--t4-light-2) 60%,
    rgba(255, 255, 255, 0)
  );
  left: auto;
  right: 0;
}
div.fl-slideshow .slide-media .slide-mask::before {
  background: linear-gradient(
    to right,
    var(--t4-light-2) 0%,
    rgba(215, 227, 227, 0)
  );
}
div.fl-slideshow .slide-media .slide-mask::after {
  background: linear-gradient(
    to left,
    var(--t4-light-2) 0%,
    rgba(215, 227, 227, 0)
  );
}
.ja-ss-item {
  height: 400px;
  text-align: center;
}
.ja-ss-item img {
  height: 100%;
  width: auto;
}
.ja-ss-btns {
  top: auto;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
}

/* Section 2 */
#t4-section-2 .item-inner {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
#t4-section-2 .item-inner h5 {
  font-size: 24px;
  margin-bottom: 1rem;
}
#t4-section-2 .item .item-image {
  border-radius: 8px;
  max-height: 260px;
  overflow: hidden;
}

/* Section 3 */
#t4-section-3 {
  background: var(--t4-light-3);
}
#t4-section-3 .item-inner {
  background: var(--t4-light-4);
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.08);
  border-radius: 6px;
  padding: 1rem;
}
#t4-section-3 .mod-title {
  font-size: 36px;
  font-weight: 600;
}

/* Footer */
#t4-footnav-1 {
  padding-top: 6rem;
  padding-bottom: 4rem;
}
@media (max-width: 576px) {
  #t4-footnav-1 {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .footnav .t4-module.module {
    padding-bottom: 20px;
  }
}
#t4-footnav-2 {
  padding-top: 1rem;
  padding-bottom: 6rem;
}
#t4-footnav-1 .module-ct,
#t4-footnav-2 .module-ct {
  color: #f6e7e7;
}
.footnav {
  font-size: 15px;
}
.footnav .btn {
  background: rgba(0, 0, 0, 0.8);
  color: rgba(255, 255, 255, 0.8);
  padding: 12px 16px;
}
.footnav .btn:hover,
.footnav .btn:focus,
.footnav .btn:active {
  color: #fff;
}
.footnav .contact-list {
  padding: 0 0 0 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.footnav .module-title {
  font-weight: 600;
  font-size: 1rem;
  margin-bottom: 1.25rem;
}
.footnav .nav .nav-link {
  color: #fff;
  font-weight: 400;
  opacity: 0.8;
}
.footnav .nav .nav-link:hover,
.footnav .nav .nav-link:focus,
.footnav .nav .nav-link:active {
  opacity: 1;
  text-decoration: underline;
}

/* Fixed: Conflict bootstrap */
.fade:not(.show) {
  opacity: 1;
}
.panel-default > .panel-heading {
  color: #333333;
  background-color: #f5f5f5;
  border-color: #dddddd;
}
.table > thead > tr > td.danger,
.table > tbody > tr > td.danger,
.table > tfoot > tr > td.danger,
.table > thead > tr > th.danger,
.table > tbody > tr > th.danger,
.table > tfoot > tr > th.danger,
.table > thead > tr.danger > td,
.table > tbody > tr.danger > td,
.table > tfoot > tr.danger > td,
.table > thead > tr.danger > th,
.table > tbody > tr.danger > th,
.table > tfoot > tr.danger > th {
  background-color: var(--bg-1);
}
.btn-lg,
.btn-group-lg > .btn,
.blog-list .item-readmore .btn-group-lg > a {
  font-size: 0.875rem;
}
.t4-module .nav > li.active > a,
.t4-card .nav > li.active > a,
.moduletable .nav > li.active > a,
.module_menu .nav > li.active > a,
.t4-module .nav li a,
.t4-card .nav li a,
.moduletable .nav li a,
.module_menu .nav li a {
  font-weight: 400;
}

/* Contact map spacing */
.contact-map {
  margin: 30px 0;
}

/* EB + RSEPro Event Styling */
div.eb-search-bar-container {
  background-color: var(--bg-2);
}
div.eb-columns-layout-container .eb-event-wrapper {
  background-color: var(--t4-light-4);
  border: 1px solid var(--border-color-1);
  box-shadow: 0 1px 8px 5px var(--box-shadow);
}
li.rs_event_detail {
  background: var(--bg-2) !important;
  box-shadow: 2px 1px 2px var(--box-shadow);
}
li.rsepro-month-year {
  background: var(--bg-3) !important;
  box-shadow: 2px 1px 2px var(--box-shadow);
}
.rsepro-filter-container #rsepro-navbar {
  background: var(--bg-2) !important;
}
.rsepro-filter-container #rsepro-navbar ul li a {
  color: var(--headings-color);
}

/* Content Layout */
.t4-content-inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100vh;
}

/* Slideshow Text Colour */
.fl-slideshow .slide-ct .slide-sub-heading,
.fl-slideshow .slide-ct .slide-heading {
  color: #fff;
}
.fl-slideshow .slide-ct .slide-actions a:hover {
  background: var(--color-primary);
  color: #fff;
}
div.fl-slideshow .owl-dots .owl-dot span {
  opacity: 1;
  background: #fff;
}
div.owl-carousel .owl-dots .owl-dot.active span {
  background-color: #630000 !important;
}

/* Titles & column headings in Megamenu => lighter gold */
.t4-megamenu .t4-module .module-title span,
.t4-megamenu .mega-col-nav .mega-col-title span,
.t4-megamenu .mega-col-module .mega-col-title span {
  color: #fdd3a1 !important;
}

/* --------------------------------------------
   PRIMARY BUTTON (clicked/focus state)
   --------------------------------------------
   Lighter red (#da4444)
*/
.btn-primary:active,
.btn-primary:focus,
.btn-primary.show,
.show > .btn-primary.dropdown-toggle {
  background-color: #da4444 !important;
  border-color: #da4444 !important;
}

/* --------------------------------------------
   TABLE STYLING (Light vs. Dark mode)
   -------------------------------------------- */

/* Basic Table Setup */
.table {
  border-collapse: collapse;
  width: 100%;
}

/* Table borders + cell padding (light mode) */
.table th,
.table td {
  border: 1px solid #ccc; /* changed from 2px to 1px */
  padding: 8px;
  text-align: left;
}

/* Dark mode: more prominent borders + background + text colour */
body.dark-active .table th,
body.dark-active .table td {
  border: 1px solid #555; /* changed from 2px to 1px */
}
body.dark-active .table {
  background-color: #1a1c1e; 
  color: #eaeaea;
}

/* Alternating Row Shading (light mode) */
.table tbody tr:nth-child(odd) {
  background-color: #f9f9f9;
}
.table tbody tr:nth-child(even) {
  background-color: #fff;
}

/* Alternating Row Shading (dark mode) */
body.dark-active .table tbody tr:nth-child(odd) {
  background-color: #2a2c2f;
}
body.dark-active .table tbody tr:nth-child(even) {
  background-color: #1f2123;
}

/* Table Headers */
.table th {
  background-color: #d9534f; /* Light mode header background */
  color: white;
}
body.dark-active .table th {
  background-color: #444; /* Dark mode header background */
  color: #f1f5f9;
}

/*
 * RSForm! Pro Width Fix
 *
 * This targets elements inside any container with an ID starting with "rsform_"
 * and forces them to take up the full width of their parent column.
 * The "!important" is necessary to override the template's restrictive style.
 */
div[id^="rsform_"] .form-control,
div[id^="rsform_"] input[type="text"],
div[id^="rsform_"] input[type="email"],
div[id^="rsform_"] input[type="tel"],
div[id^="rsform_"] select {
  width: 100% !important;
  max-width: 100% !important;
}
/* What to Wear — component styles (global) */
.wtw-container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

/* Hero */
.wtw-hero {
    background: var(--t4-light-3, #f8fafc);
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 14px;
    padding: 1.5rem 1.25rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 16px var(--box-shadow, rgba(0,0,0,0.08));
    text-align: center;
}
.wtw-hero h1 {
    font-size: 1.9rem;
    font-weight: 700;
    margin: 0 0 .35rem;
    color: #374151;
}
.wtw-hero p { margin: 0; color: #4b5563; }

/* Layout */
.wtw-layout { display: flex; gap: 1.25rem; }
@media (max-width: 991.98px) { .wtw-layout { flex-direction: column; } }

/* Side navigation */
.wtw-sidenav {
    flex: 0 0 260px;
    position: sticky;
    top: 1rem;
    align-self: flex-start;
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 12px;
    background: var(--t4-light-4, #fff);
    box-shadow: 0 2px 12px var(--box-shadow, rgba(0,0,0,0.06));
    padding: .75rem;
    height: max-content;
}
.wtw-sidenav h3 {
    font-size: 1rem;
    font-weight: 700;
    color: #374151;
    margin: .25rem .5rem .5rem;
    letter-spacing: .02em;
}
.wtw-nav { display: flex; flex-direction: column; gap: .25rem; margin: 0; padding: 0; list-style: none; }
.wtw-nav a {
    display: block;
    padding: .6rem .75rem;
    border-radius: 8px;
    text-decoration: none;
    color: #374151;
    font-weight: 600;
    border: 1px solid transparent;
    transition: all .2s ease;
}
.wtw-nav a:hover,
.wtw-nav a:focus {
    background: var(--t4-light-3, #f8fafc);
    border-color: var(--border-color-1, #e2e8f0);
    outline: none;
}
.wtw-nav a.is-active {
    background: linear-gradient(135deg, #7a1a1a, #a52a2a);
    color: #fff;
    border-color: transparent;
}
@media (max-width: 991.98px) {
    .wtw-sidenav { position: static; padding: .5rem; }
    .wtw-sidenav h3 { margin-left: .25rem; }
    .wtw-nav { flex-direction: row; overflow-x: auto; padding-bottom: .25rem; }
    .wtw-nav a {
        white-space: nowrap;
        border: 1px solid var(--border-color-1, #e2e8f0);
        background: var(--t4-light-4, #fff);
        margin-right: .5rem;
    }
    .wtw-nav a.is-active {
        background: linear-gradient(135deg, #7a1a1a, #a52a2a);
        color: #fff;
        border-color: transparent;
    }
}

/* Content column */
.wtw-content { flex: 1 1 auto; min-width: 0; }

/* Cards */
.wtw-card {
    background: var(--t4-light-4, #fff);
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 12px;
    box-shadow: 0 4px 16px var(--box-shadow, rgba(0,0,0,0.08));
    padding: 1.25rem 1.25rem 1rem;
    margin-bottom: 1rem;
}
.wtw-card-header { display: flex; align-items: center; gap: .6rem; margin-bottom: .75rem; }
.wtw-pill {
    display: inline-block;
    font-size: .8rem;
    font-weight: 800;
    letter-spacing: .06em;
    color: #fff;
    background: #7a1a1a;
    border-radius: 999px;
    padding: .3rem .6rem;
    text-transform: uppercase;
}
.wtw-pill--gold { background: #C99E70; }
.wtw-card h2 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
    color: #374151;
    letter-spacing: .01em;
}
.wtw-sub { color: #4b5563; margin: .2rem 0 1rem; }

/* Grids and panels */
.wtw-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
@media (max-width: 767.98px) { .wtw-grid { grid-template-columns: 1fr; } }
.wtw-panel {
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 10px;
    padding: 1rem;
    background: var(--t4-light-3, #f8fafc);
}
.wtw-panel h3 { margin: 0 0 .5rem; font-size: 1.05rem; font-weight: 700; color: #374151; }

/* Lists */
.wtw-list { list-style: none; margin: 0; padding: 0; }
.wtw-list li {
    position: relative;
    padding-left: 1.35rem;
    margin-bottom: .6rem;
    color: #4b5563;
    line-height: 1.5;
}
.wtw-list li::before {
    content: '✔';
    position: absolute;
    left: 0;
    color: #059669;
    font-weight: 800;
    transform: translateY(1px);
}

/* Images */
.wtw-images {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.wtw-images img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 10px;
    box-shadow: 0 4px 12px var(--box-shadow, rgba(0,0,0,.08));
    border: 1px solid var(--border-color-1, #e2e8f0);
}
@media (max-width: 575.98px) { .wtw-images { grid-template-columns: 1fr; } }

/* Callout */
.wtw-callout {
    display: grid;
    grid-template-columns: 1.4fr .9fr;
    gap: 1rem;
    align-items: center;
    margin-top: 1rem;
    border: 1px solid var(--border-color-1, #e2e8f0);
    background: var(--t4-light-3, #f8fafc);
    border-left: 6px solid #C99E70;
    border-radius: 12px;
    padding: 1rem;
}
.wtw-callout h3 { margin: 0 0 .5rem; font-size: 1.15rem; font-weight: 800; color: #374151; }
.wtw-callout p { margin: 0 0 .75rem; color: #4b5563; }
.wtw-callout img {
    width: 100%;
    height: auto;
    border-radius: 10px;
    border: 1px solid var(--border-color-1, #e2e8f0);
    box-shadow: 0 4px 12px var(--box-shadow, rgba(0,0,0,.08));
}
@media (max-width: 767.98px) { .wtw-callout { grid-template-columns: 1fr; } }

/* CTAs */
.wtw-ctas { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: .5rem; }
.wtw-btn {
    display: inline-block;
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-decoration: none;
    padding: .7rem 1.1rem;
    border-radius: 999px;
    transition: all .2s ease;
    border: 2px solid transparent;
}
.wtw-btn--primary {
    background: linear-gradient(135deg, #7a1a1a, #a52a2a);
    color: #fff;
}
.wtw-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(122,26,26,.35); }
.wtw-btn--gold {
    background: linear-gradient(135deg, #C99E70, #B8935F);
    color: #fff;
    border-color: #fdd3a1;
    box-shadow: 0 2px 8px rgba(201,158,112,.25);
}
.wtw-btn--gold:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(201,158,112,.35); }

/* Anchor offset (optional to keep page-specific) */
.wtw-section { scroll-margin-top: 90px; }

/* Dark mode overrides */
body.dark-active .wtw-hero h1 { color: #f1f5f9; }
body.dark-active .wtw-hero p { color: rgba(241,245,249,.85); }
body.dark-active .wtw-sidenav h3,
body.dark-active .wtw-nav a { color: #f1f5f9; }
body.dark-active .wtw-card,
body.dark-active .wtw-panel { background: var(--t4-light-4, rgba(225,225,225,.09)); }
body.dark-active .wtw-card h2 { color: #f1f5f9; }
body.dark-active .wtw-sub,
body.dark-active .wtw-list li { color: rgba(241,245,249,.9); }
body.dark-active .wtw-callout h3 { color: #f1f5f9; }
body.dark-active .wtw-callout p { color: rgba(241,245,249,.9); }
/* What to Wear — Left side menu layout */
.wtw-container {
    max-width: 1100px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

/* Intro card (hero) */
.wtw-hero {
    background: var(--t4-light-3, #f8fafc);
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 14px;
    padding: 1.5rem 1.25rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 16px var(--box-shadow, rgba(0,0,0,0.08));
    text-align: center;
}
.wtw-hero h1 {
    font-size: 1.9rem;
    font-weight: 700;
    margin: 0 0 .35rem;
    color: #374151;
}
.wtw-hero p { margin: 0; color: #4b5563; }
body.dark-active .wtw-hero h1 { color: #f1f5f9; }
body.dark-active .wtw-hero p { color: rgba(241,245,249,.85); }

/* Main two-column layout */
.wtw-layout { display: flex; gap: 1.25rem; }
@media (max-width: 991.98px) { .wtw-layout { flex-direction: column; } }
.wtw-content { flex: 1 1 auto; min-width: 0; }

/* Left sidenav / chips */
.wtw-sidenav {
    flex: 0 0 260px;
    position: sticky;
    top: 1rem;
    align-self: flex-start;
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 12px;
    background: var(--t4-light-4, #fff);
    box-shadow: 0 2px 12px var(--box-shadow, rgba(0,0,0,0.06));
    padding: .75rem;
    height: max-content;
}
.wtw-sidenav h3 {
    font-size: 1rem;
    font-weight: 700;
    color: #374151;
    margin: .25rem .5rem .5rem;
    letter-spacing: .02em;
}
.wtw-nav { display: flex; flex-direction: column; gap: .25rem; list-style: none; padding: 0; margin: 0; }
.wtw-nav a {
    display: block;
    padding: .6rem .75rem;
    border-radius: 8px;
    text-decoration: none;
    color: #374151;
    font-weight: 600;
    border: 1px solid transparent;
    transition: all .2s ease;
}
.wtw-nav a:hover,
.wtw-nav a:focus {
    background: var(--t4-light-3, #f8fafc);
    border-color: var(--border-color-1, #e2e8f0);
    outline: none;
}
.wtw-nav a.is-active {
    background: linear-gradient(135deg, #7a1a1a, #a52a2a);
    color: #fff;
    border-color: transparent;
}
@media (max-width: 991.98px) {
    .wtw-sidenav { position: static; padding: .5rem; }
    .wtw-nav { flex-direction: row; overflow-x: auto; padding-bottom: .25rem; }
    .wtw-nav a {
        white-space: nowrap;
        border: 1px solid var(--border-color-1, #e2e8f0);
        background: var(--t4-light-4, #fff);
        margin-right: .5rem;
    }
    .wtw-nav a.is-active { border-color: transparent; }
}
body.dark-active .wtw-sidenav h3,
body.dark-active .wtw-nav a { color: #f1f5f9; }

/* Cards and content blocks */
.wtw-card {
    background: var(--t4-light-4, #fff);
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 12px;
    box-shadow: 0 4px 16px var(--box-shadow, rgba(0,0,0,0.08));
    padding: 1.25rem 1.25rem 1rem;
    margin-bottom: 1rem;
}
.wtw-card-header { display: flex; align-items: center; gap: .6rem; margin-bottom: .75rem; }
.wtw-pill {
    display: inline-block;
    font-size: .8rem;
    font-weight: 800;
    letter-spacing: .06em;
    color: #fff;
    background: #7a1a1a;
    border-radius: 999px;
    padding: .3rem .6rem;
    text-transform: uppercase;
}
.wtw-pill--gold { background: #C99E70; }
.wtw-card h2 {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 800;
    color: #374151;
    letter-spacing: .01em;
}
.wtw-sub { color: #4b5563; margin: .2rem 0 1rem; }
body.dark-active .wtw-card h2 { color: #f1f5f9; }
body.dark-active .wtw-sub { color: rgba(241,245,249,.9); }

/* Grid + panels */
.wtw-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 1rem; }
@media (max-width: 767.98px) { .wtw-grid { grid-template-columns: 1fr; } }
.wtw-panel {
    border: 1px solid var(--border-color-1, #e2e8f0);
    border-radius: 10px;
    padding: 1rem;
    background: var(--t4-light-3, #f8fafc);
}
.wtw-panel h3 { margin: 0 0 .5rem; font-size: 1.05rem; font-weight: 700; color: #374151; }
body.dark-active .wtw-panel { background: var(--t4-light-4, rgba(225,225,225,.09)); }
body.dark-active .wtw-panel h3 { color: #f1f5f9; }

/* Lists */
.wtw-list { list-style: none; margin: 0; padding: 0; }
.wtw-list li {
    position: relative;
    padding-left: 1.35rem;
    margin-bottom: .6rem;
    color: #4b5563;
    line-height: 1.5;
}
.wtw-list li::before {
    content: '✔';
    position: absolute;
    left: 0;
    color: #059669;
    font-weight: 800;
    transform: translateY(1px);
}
body.dark-active .wtw-list li { color: rgba(241,245,249,.9); }

/* Images */
.wtw-images {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.wtw-images img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 10px;
    box-shadow: 0 4px 12px var(--box-shadow, rgba(0,0,0,.08));
    border: 1px solid var(--border-color-1, #e2e8f0);
}
@media (max-width: 575.98px) { .wtw-images { grid-template-columns: 1fr; } }

/* Callout + CTAs */
.wtw-callout {
    display: grid;
    grid-template-columns: 1.4fr .9fr;
    gap: 1rem;
    align-items: center;
    margin-top: 1rem;
    border: 1px solid var(--border-color-1, #e2e8f0);
    background: var(--t4-light-3, #f8fafc);
    border-left: 6px solid #C99E70;
    border-radius: 12px;
    padding: 1rem;
}
@media (max-width: 767.98px) { .wtw-callout { grid-template-columns: 1fr; } }
.wtw-callout h3 { margin: 0 0 .5rem; font-size: 1.15rem; font-weight: 800; color: #374151; }
.wtw-callout p { margin: 0 0 .75rem; color: #4b5563; }
.wtw-ctas { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: .5rem; }
.wtw-btn {
    display: inline-block;
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .04em;
    text-decoration: none;
    padding: .7rem 1.1rem;
    border-radius: 999px;
    transition: all .2s ease;
    border: 2px solid transparent;
}
.wtw-btn--primary {
    background: linear-gradient(135deg, #7a1a1a, #a52a2a);
    color: #fff;
}
.wtw-btn--primary:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(122,26,26,.35); }
.wtw-btn--gold {
    background: linear-gradient(135deg, #C99E70, #B8935F);
    color: #fff;
    border-color: #fdd3a1;
    box-shadow: 0 2px 8px rgba(201,158,112,.25);
}
.wtw-btn--gold:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(201,158,112,.35); }

/* Anchor offset so headings aren’t hidden under sticky headers */
.wtw-section { scroll-margin-top: 90px; }

/* Dark mode extras */
body.dark-active .wtw-card h2 { color: #f1f5f9; }
body.dark-active .wtw-callout { background: var(--t4-light-4, rgba(225,225,225,.09)); }
body.dark-active .wtw-callout h3 { color: #f1f5f9; }
body.dark-active .wtw-callout p { color: rgba(241,245,249,.9); }
