/**
* Template Name: eNno
* Template URL: https://bootstrapmade.com/enno-free-simple-bootstrap-template/
* Updated: Aug 07 2024 with Bootstrap v5.3.3
* Author: BootstrapMade.com
* License: https://bootstrapmade.com/license/
*/

/*--------------------------------------------------------------
# Font & Color Variables
# Help: https://bootstrapmade.com/color-system/
--------------------------------------------------------------*/
/* Fonts */
:root {
  --default-font: "Roboto", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --heading-font: "Raleway", sans-serif;
  --nav-font: "Ubuntu", sans-serif;
  --font-size: 12px;
  --brand-ink: #17231d;
  --brand-muted: #637067;
  --brand-bg: #f3f6f1;
  --brand-panel: #ffffff;
  --brand-green: #0f3d2e;
  --brand-green-2: #175942;
  --brand-gold: #c99b42;
  --brand-border: rgba(23, 35, 29, .09);
  --brand-shadow: 0 16px 42px rgba(19, 43, 32, .08);
  --brand-shadow-strong: 0 24px 60px rgba(19, 43, 32, .14);
  --brand-radius: 8px;
}

/* Global Colors - The following color variables are used throughout the website. Updating them here will change the color scheme of the entire website */
:root {
  --background-color: #ffffff;
  /* Background color for the entire website, including individual sections */
  --default-color: #3f4f46;
  /* Default color used for the majority of the text content across the entire website */
  --heading-color: #17231d;
  /* Color for headings, subheadings and title throughout the website */
  --accent-color: #0f3d2e;
  /* Accent color that represents your brand on the website. It's used for buttons, links, and other elements that need to stand out */
  --surface-color: #ffffff;
  /* The surface color is used as a background of boxed elements within sections, such as cards, icon boxes, or other elements that require a visual separation from the global background. */
  --contrast-color: #ffffff;
  /* Contrast color for text, ensuring readability against backgrounds of accent, heading, or default colors. */
}

/* Nav Menu Colors - The following color variables are used specifically for the navigation menu. They are separate from the global colors to allow for more customization options */
:root {
  --nav-color: #33443a;
  /* The default color of the main navmenu links */
  --nav-hover-color: #0f3d2e;
  /* Applied to main navmenu links when they are hovered over or active */
  --nav-mobile-background-color: #ffffff;
  /* Used as the background color for mobile navigation menu */
  --nav-dropdown-background-color: #ffffff;
  /* Used as the background color for dropdown items that appear when hovering over primary navigation items */
  --nav-dropdown-color: #33443a;
  /* Used for navigation links of the dropdown items in the navigation menu. */
  --nav-dropdown-hover-color: #0f3d2e;
  /* Similar to --nav-hover-color, this color is applied to dropdown navigation links when they are hovered over. */
}

html {
  color-scheme: light;
}

html[data-theme="light"] {
  color-scheme: light;
  --background-color: #ffffff;
  --default-color: #3f4f46;
  --heading-color: #17231d;
  --accent-color: #0f3d2e;
  --surface-color: #ffffff;
  --contrast-color: #ffffff;
  --nav-color: #33443a;
  --nav-hover-color: #0f3d2e;
  --nav-mobile-background-color: #ffffff;
  --nav-dropdown-background-color: #ffffff;
  --nav-dropdown-color: #33443a;
  --nav-dropdown-hover-color: #0f3d2e;
  --brand-ink: #17231d;
  --brand-muted: #637067;
  --brand-bg: #f3f6f1;
  --brand-panel: #ffffff;
  --brand-surface: #ffffff;
  --brand-surface-soft: #f3f7f4;
  --brand-green: #0f3d2e;
  --brand-green-2: #175942;
  --brand-green-deep: #0b3d2e;
  --brand-gold: #c99b42;
  --brand-border: rgba(23, 35, 29, .09);
  --brand-shadow: 0 16px 42px rgba(19, 43, 32, .08);
  --brand-shadow-strong: 0 24px 60px rgba(19, 43, 32, .14);
  --bs-body-bg: #ffffff;
  --bs-body-color: #3f4f46;
  --bs-heading-color: #17231d;
  --bs-border-color: #dde5df;
}

html[data-theme="dark"] {
  color-scheme: dark;
  --background-color: #071f18;
  --default-color: #d7e2dc;
  --heading-color: #f8f6f0;
  --accent-color: #d7b96d;
  --surface-color: #0d2d23;
  --contrast-color: #071f18;
  --nav-color: #eef5ef;
  --nav-hover-color: #d7b96d;
  --nav-mobile-background-color: #0d2d23;
  --nav-dropdown-background-color: #0d2d23;
  --nav-dropdown-color: #eef5ef;
  --nav-dropdown-hover-color: #d7b96d;
  --brand-ink: #f8f6f0;
  --brand-muted: #b9c8c0;
  --brand-bg: #071f18;
  --brand-panel: #0d2d23;
  --brand-surface: #0d2d23;
  --brand-surface-soft: #123a2d;
  --brand-green: #7fd5b1;
  --brand-green-2: #9fe4c6;
  --brand-green-deep: #0b3d2e;
  --brand-gold: #d7b96d;
  --brand-border: rgba(248, 246, 240, .16);
  --brand-shadow: 0 16px 42px rgba(0, 0, 0, .24);
  --brand-shadow-strong: 0 24px 60px rgba(0, 0, 0, .34);
  --bs-body-bg: #071f18;
  --bs-body-color: #d7e2dc;
  --bs-heading-color: #f8f6f0;
  --bs-border-color: rgba(248, 246, 240, .16);
}

html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select,
html[data-theme="light"] button {
  color-scheme: light;
}

html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select,
html[data-theme="dark"] button {
  color-scheme: dark;
}

.navbar .nav-dropdown-toggle {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}

.navbar .nav-dropdown-toggle::after {
  display: none !important;
  content: none !important;
}

.navbar .nav-dropdown-icon {
  font-size: .75rem;
  line-height: 1;
  transition: transform .2s ease;
}

.navbar .hs-mega-menu-opened>.nav-dropdown-toggle .nav-dropdown-icon,
.navbar .nav-dropdown-toggle[aria-expanded="true"] .nav-dropdown-icon {
  transform: rotate(180deg);
}

/* Color Presets - These classes override global colors when applied to any section or element, providing reuse of the sam color scheme. */

.light-background {
  --background-color: #f3f6f1;
  --surface-color: #ffffff;
}

.dark-background {
  --background-color: #060606;
  --default-color: #ffffff;
  --heading-color: #ffffff;
  --surface-color: #252525;
  --contrast-color: #ffffff;
}

.accent-background {
  --background-color: #0f3d2e;
  --default-color: #ffffff;
  --heading-color: #ffffff;
  --surface-color: #175942;
  --contrast-color: #ffffff;
}

/* Smooth scroll */
:root {
  scroll-behavior: smooth;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

/*--------------------------------------------------------------
# General Styling & Shared Classes
--------------------------------------------------------------*/
body {
  color: var(--default-color);
  background-color: var(--background-color);
  font-family: var(--default-font);
  font-size: var(--font-size);
}

a {
  color: var(--accent-color);
  text-decoration: none;
  transition: 0.3s;
}

a:hover {
  color: color-mix(in srgb, var(--accent-color), transparent 25%);
  text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--heading-color);
  font-family: var(--heading-font);
}

/* PHP Email Form Messages
------------------------------*/
.php-email-form .error-message {
  display: none;
  background: #df1529;
  color: #ffffff;
  text-align: left;
  padding: 15px;
  margin-bottom: 24px;
  font-weight: 600;
}

.php-email-form .sent-message {
  display: none;
  color: #ffffff;
  background: #059652;
  text-align: center;
  padding: 15px;
  margin-bottom: 24px;
  font-weight: 600;
}

.php-email-form .loading {
  display: none;
  background: var(--surface-color);
  text-align: center;
  padding: 15px;
  margin-bottom: 24px;
}

.php-email-form .loading:before {
  content: "";
  display: inline-block;
  border-radius: 50%;
  width: 24px;
  height: 24px;
  margin: 0 10px -6px 0;
  border: 3px solid var(--accent-color);
  border-top-color: var(--surface-color);
  animation: php-email-form-loading 1s linear infinite;
}

@keyframes php-email-form-loading {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/* Pulsating Play Button
------------------------------*/
.pulsating-play-btn {
  width: 94px;
  height: 94px;
  background: radial-gradient(var(--accent-color) 50%, color-mix(in srgb, var(--accent-color), transparent 75%) 52%);
  border-radius: 50%;
  display: block;
  position: relative;
  overflow: hidden;
}

.pulsating-play-btn:before {
  content: "";
  position: absolute;
  width: 120px;
  height: 120px;
  animation-delay: 0s;
  animation: pulsate-play-btn 2s;
  animation-direction: forwards;
  animation-iteration-count: infinite;
  animation-timing-function: steps;
  opacity: 1;
  border-radius: 50%;
  border: 5px solid color-mix(in srgb, var(--accent-color), transparent 30%);
  top: -15%;
  left: -15%;
  background: rgba(198, 16, 0, 0);
}

.pulsating-play-btn:after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-40%) translateY(-50%);
  width: 0;
  height: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 15px solid #fff;
  z-index: 100;
  transition: all 400ms cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

.pulsating-play-btn:hover:before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-40%) translateY(-50%);
  width: 0;
  height: 0;
  border: none;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 15px solid #fff;
  z-index: 200;
  animation: none;
  border-radius: 0;
}

.pulsating-play-btn:hover:after {
  border-left: 15px solid var(--accent-color);
  transform: scale(20);
}

@keyframes pulsate-play-btn {
  0% {
    transform: scale(0.6, 0.6);
    opacity: 1;
  }

  100% {
    transform: scale(1, 1);
    opacity: 0;
  }
}

/*--------------------------------------------------------------
# Global Header
--------------------------------------------------------------*/
.header {
  color: var(--default-color);
  background-color: var(--background-color);
  padding: 15px 0;
  transition: all 0.5s;
  z-index: 997;
}

.header .logo {
  line-height: 1;
}

.header .logo img {
  max-height: 64px;
  margin-right: 8px;
}

.header .logo h1 {
  font-size: 2rem;
  margin: 0;
  font-weight: 700;
  color: var(--heading-color);
}

.header .btn-getstarted,
.header .btn-getstarted:focus {
  color: var(--contrast-color);
  background: var(--accent-color);
  font-size: 1em;
  padding: 8px 25px;
  margin: 0 0 0 30px;
  border-radius: 50px;
  transition: 0.3s;
}

.header .btn-getstarted:hover,
.header .btn-getstarted:focus:hover {
  color: var(--contrast-color);
  background: color-mix(in srgb, var(--accent-color), transparent 15%);
}

@media (max-width: 1200px) {
  .header .logo {
    order: 1;
  }

  .header .btn-getstarted {
    order: 2;
    margin: 0 15px 0 0;
    padding: 6px 15px;
  }

  .header .navmenu {
    order: 3;
  }
}

.scrolled .header {
  box-shadow: 0px 0 18px rgba(0, 0, 0, 0.1);
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/
/* Navmenu - Desktop */
@media (min-width: 1200px) {
  .navmenu {
    padding: 0;
  }

  .navmenu ul {
    margin: 0;
    padding: 0;
    display: flex;
    list-style: none;
    align-items: center;
  }

  .navmenu li {
    position: relative;
  }

  .navmenu a,
  .navmenu a:focus {
    color: var(--nav-color);
    padding: 18px 15px;
    font-size: 16px;
    font-family: var(--nav-font);
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: space-between;
    white-space: nowrap;
    transition: 0.3s;
  }

  .navmenu a i,
  .navmenu a:focus i {
    font-size: 12px;
    line-height: 0;
    margin-left: 5px;
    transition: 0.3s;
  }

  .navmenu li:last-child a {
    padding-right: 0;
  }

  .navmenu li:hover>a,
  .navmenu .active,
  .navmenu .active:focus {
    color: var(--nav-hover-color);
  }

  .navmenu .dropdown ul {
    margin: 0;
    padding: 10px 0;
    background: var(--nav-dropdown-background-color);
    display: block;
    position: absolute;
    visibility: hidden;
    left: 14px;
    top: 130%;
    opacity: 0;
    transition: 0.3s;
    border-radius: 4px;
    z-index: 99;
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1);
  }

  .navmenu .dropdown ul li {
    min-width: 200px;
  }

  .navmenu .dropdown ul a {
    padding: 10px 20px;
    font-size: 15px;
    text-transform: none;
    color: var(--nav-dropdown-color);
  }

  .navmenu .dropdown ul a i {
    font-size: 12px;
  }

  .navmenu .dropdown ul a:hover,
  .navmenu .dropdown ul .active:hover,
  .navmenu .dropdown ul li:hover>a {
    color: var(--nav-dropdown-hover-color);
  }

  .navmenu .dropdown:hover>ul {
    opacity: 1;
    top: 100%;
    visibility: visible;
  }

  .navmenu .dropdown .dropdown ul {
    top: 0;
    left: -90%;
    visibility: hidden;
  }

  .navmenu .dropdown .dropdown:hover>ul {
    opacity: 1;
    top: 0;
    left: -100%;
    visibility: visible;
  }
}

/* Navmenu - Mobile */
@media (max-width: 1199px) {
  .mobile-nav-toggle {
    color: var(--nav-color);
    font-size: 28px;
    line-height: 0;
    margin-right: 10px;
    cursor: pointer;
    transition: color 0.3s;
  }

  .navmenu {
    padding: 0;
    z-index: 9997;
  }

  .navmenu ul {
    display: none;
    list-style: none;
    position: absolute;
    inset: 60px 20px 20px 20px;
    padding: 10px 0;
    margin: 0;
    border-radius: 6px;
    background-color: var(--nav-mobile-background-color);
    overflow-y: auto;
    transition: 0.3s;
    z-index: 9998;
    box-shadow: 0px 0px 30px rgba(0, 0, 0, 0.1);
  }

  .navmenu a,
  .navmenu a:focus {
    color: var(--nav-dropdown-color);
    padding: 10px 20px;
    font-family: var(--nav-font);
    font-size: 17px;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: space-between;
    white-space: nowrap;
    transition: 0.3s;
  }

  .navmenu a i,
  .navmenu a:focus i {
    font-size: 12px;
    line-height: 0;
    margin-left: 5px;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: 0.3s;
    background-color: color-mix(in srgb, var(--accent-color), transparent 90%);
  }

  .navmenu a i:hover,
  .navmenu a:focus i:hover {
    background-color: var(--accent-color);
    color: var(--contrast-color);
  }

  .navmenu a:hover,
  .navmenu .active,
  .navmenu .active:focus {
    color: var(--nav-dropdown-hover-color);
  }

  .navmenu .active i,
  .navmenu .active:focus i {
    background-color: var(--accent-color);
    color: var(--contrast-color);
    transform: rotate(180deg);
  }

  .navmenu .dropdown ul {
    position: static;
    display: none;
    z-index: 99;
    padding: 10px 0;
    margin: 10px 20px;
    background-color: var(--nav-dropdown-background-color);
    border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
    box-shadow: none;
    transition: all 0.5s ease-in-out;
  }

  .navmenu .dropdown ul ul {
    background-color: rgba(33, 37, 41, 0.1);
  }

  .navmenu .dropdown>.dropdown-active {
    display: block;
    background-color: rgba(33, 37, 41, 0.03);
  }

  .mobile-nav-active {
    overflow: hidden;
  }

  .mobile-nav-active .mobile-nav-toggle {
    color: #fff;
    position: absolute;
    font-size: 32px;
    top: 15px;
    right: 15px;
    margin-right: 0;
    z-index: 9999;
  }

  .mobile-nav-active .navmenu {
    position: fixed;
    overflow: hidden;
    inset: 0;
    background: rgba(33, 37, 41, 0.8);
    transition: 0.3s;
  }

  .mobile-nav-active .navmenu>ul {
    display: block;
  }
}

/*--------------------------------------------------------------
# Global Footer
--------------------------------------------------------------*/
.footer {
  color: var(--default-color);
  background-color: var(--background-color);
  font-size: 14px;
  position: relative;
}

.footer .footer-newsletter {
  background-color: color-mix(in srgb, var(--default-color), transparent 97%);
  padding: 50px 0;
}

.footer .footer-newsletter h4 {
  font-size: 24px;
}

.footer .footer-newsletter .newsletter-form {
  margin-top: 30px;
  margin-bottom: 15px;
  padding: 6px 8px;
  position: relative;
  border-radius: 4px;
  background-color: var(--surface-color);
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
  box-shadow: 0px 2px 25px rgba(0, 0, 0, 0.1);
  display: flex;
  transition: 0.3s;
  border-radius: 50px;
}

.footer .footer-newsletter .newsletter-form:focus-within {
  border-color: var(--accent-color);
}

.footer .footer-newsletter .newsletter-form input[type=email] {
  border: 0;
  padding: 4px;
  width: 100%;
  background-color: var(--surface-color);
  color: var(--default-color);
}

.footer .footer-newsletter .newsletter-form input[type=email]:focus-visible {
  outline: none;
}

.footer .footer-newsletter .newsletter-form input[type=submit] {
  border: 0;
  font-size: 16px;
  padding: 0 20px;
  margin: -7px -8px -7px 0;
  background: var(--accent-color);
  color: var(--contrast-color);
  transition: 0.3s;
  border-radius: 50px;
}

.footer .footer-newsletter .newsletter-form input[type=submit]:hover {
  background: color-mix(in srgb, var(--accent-color), transparent 20%);
}

.footer .footer-top {
  padding-top: 50px;
}

.footer .social-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 50%);
  font-size: 16px;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  margin-right: 10px;
  transition: 0.3s;
}

.footer .social-links a:hover {
  color: var(--accent-color);
  border-color: var(--accent-color);
}

.footer h4 {
  font-size: 16px;
  font-weight: bold;
  position: relative;
  padding-bottom: 12px;
}

.footer .footer-links {
  margin-bottom: 30px;
}

.footer .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer .footer-links ul i {
  margin-right: 3px;
  font-size: 12px;
  line-height: 0;
  color: var(--accent-color);
}

.footer .footer-links ul li {
  padding: 10px 0;
  display: flex;
  align-items: center;
}

.footer .footer-links ul li:first-child {
  padding-top: 0;
}

.footer .footer-links ul a {
  display: inline-block;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  line-height: 1;
}

.footer .footer-links ul a:hover {
  color: var(--accent-color);
}

.footer .footer-about a {
  color: var(--heading-color);
  font-size: 24px;
  font-weight: 600;
  font-family: var(--heading-font);
}

.footer .footer-contact p {
  margin-bottom: 5px;
}

.footer .copyright {
  padding: 25px 0;
  border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
}

.footer .copyright p {
  margin-bottom: 0;
}

.footer .credits {
  margin-top: 6px;
  font-size: 13px;
}

/*--------------------------------------------------------------
# Preloader
--------------------------------------------------------------*/
#preloader {
  position: fixed;
  inset: 0;
  z-index: 999999;
  overflow: hidden;
  background: var(--background-color);
  transition: all 0.6s ease-out;
}

#preloader:before {
  content: "";
  position: fixed;
  top: calc(50% - 30px);
  left: calc(50% - 30px);
  border: 6px solid #ffffff;
  border-color: var(--accent-color) transparent var(--accent-color) transparent;
  border-radius: 50%;
  width: 60px;
  height: 60px;
  animation: animate-preloader 1.5s linear infinite;
}

@keyframes animate-preloader {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/*--------------------------------------------------------------
# Scroll Top Button
--------------------------------------------------------------*/
.scroll-top {
  position: fixed;
  visibility: hidden;
  opacity: 0;
  right: 15px;
  bottom: -15px;
  z-index: 99999;
  background-color: var(--accent-color);
  width: 44px;
  height: 44px;
  border-radius: 50px;
  transition: all 0.4s;
}

.scroll-top i {
  font-size: 24px;
  color: var(--contrast-color);
  line-height: 0;
}

.scroll-top:hover {
  background-color: color-mix(in srgb, var(--accent-color), transparent 20%);
  color: var(--contrast-color);
}

.scroll-top.active {
  visibility: visible;
  opacity: 1;
  bottom: 15px;
}

/*--------------------------------------------------------------
# Disable aos animation delay on mobile devices
--------------------------------------------------------------*/
@media screen and (max-width: 768px) {
  [data-aos-delay] {
    transition-delay: 0 !important;
  }
}

/*--------------------------------------------------------------
# Global Page Titles & Breadcrumbs
--------------------------------------------------------------*/
.page-title {
  --background-color: color-mix(in srgb, var(--default-color), transparent 96%);
  color: var(--default-color);
  background-color: var(--background-color);
  padding: 25px 0;
  position: relative;
}

.page-title h1 {
  font-size: 24px;
  font-weight: 700;
}

.page-title .breadcrumbs ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  font-weight: 400;
}

.page-title .breadcrumbs ol li+li {
  padding-left: 10px;
}

.page-title .breadcrumbs ol li+li::before {
  content: "/";
  display: inline-block;
  padding-right: 10px;
  color: color-mix(in srgb, var(--default-color), transparent 70%);
}

/*--------------------------------------------------------------
# Global Sections
--------------------------------------------------------------*/
section,
.section {
  color: var(--default-color);
  background-color: var(--background-color);
  padding: 60px 0;
  scroll-margin-top: 100px;
  overflow: clip;
}

@media (max-width: 1199px) {

  section,
  .section {
    scroll-margin-top: 66px;
  }
}

/*--------------------------------------------------------------
# Global Section Titles
--------------------------------------------------------------*/
.section-title {
  text-align: center;
  padding: 30px 0;
  margin-bottom: 30px;
  position: relative;
}

.section-title h2 {
  font-size: 32px;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 20px;
  padding-bottom: 0;
  position: relative;
  z-index: 2;
}

.section-title span {
  position: absolute;
  top: 4px;
  color: color-mix(in srgb, var(--heading-color), transparent 95%);
  left: 0;
  right: 0;
  z-index: 1;
  font-weight: 700;
  font-size: 52px;
  text-transform: uppercase;
  line-height: 1;
}

.section-title p {
  margin-bottom: 0;
  position: relative;
  z-index: 2;
  font-size: var(--font-size);
}

@media (max-width: 575px) {
  .section-title h2 {
    font-size: 28px;
    margin-bottom: 15px;
  }

  .section-title span {
    font-size: 38px;
  }
}

/*--------------------------------------------------------------
# Hero Section
--------------------------------------------------------------*/
.hero {
  width: 100%;
  min-height: 70vh;
  position: relative;
  padding: 0 0 60px 0;
  display: flex;
  align-items: center;
}

.hero h1 {
  margin: 0;
  font-size: 2em;
  font-weight: 700;
  line-height: 56px;
}

.hero p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  margin: 5px 0 30px 0;
  font-size: 32px;
  font-weight: 400;
}

.hero .btn-get-started {
  color: var(--contrast-color);
  background: var(--accent-color);
  font-family: var(--heading-font);
  font-weight: 400;
  font-size: 15px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 10px 28px 12px 28px;
  border-radius: 50px;
  transition: 0.5s;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
}

.hero .btn-get-started:hover {
  color: var(--contrast-color);
  background: color-mix(in srgb, var(--accent-color), transparent 15%);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.1);
}

.hero .btn-watch-video {
  font-size: 16px;
  transition: 0.5s;
  margin-left: 25px;
  color: var(--default-color);
  font-weight: 600;
}

.hero .btn-watch-video i {
  color: var(--accent-color);
  font-size: 32px;
  transition: 0.3s;
  line-height: 0;
  margin-right: 8px;
}

.hero .btn-watch-video:hover {
  color: var(--accent-color);
}

.hero .btn-watch-video:hover i {
  color: color-mix(in srgb, var(--accent-color), transparent 15%);
}

.hero .animated {
  animation: up-down 2s ease-in-out infinite alternate-reverse both;
}

@media (max-width: 640px) {
  .hero h1 {
    font-size: 28px;
    line-height: 36px;
  }

  .hero p {
    font-size: 18px;
    line-height: 24px;
    margin-bottom: 30px;
  }

  .hero .btn-get-started,
  .hero .btn-watch-video {
    font-size: 13px;
  }
}

@keyframes up-down {
  0% {
    transform: translateY(10px);
  }

  100% {
    transform: translateY(-10px);
  }
}

/*--------------------------------------------------------------
# Featured Services Section
--------------------------------------------------------------*/
.featured-services {
  --surface-color: color-mix(in srgb, var(--default-color), transparent 96%);
  padding-top: 0;
}

.featured-services .service-item {
  background-color: var(--surface-color);
  padding: 50px 30px;
  transition: all ease-in-out 0.4s;
  height: 100%;
}

.featured-services .service-item .icon {
  margin-bottom: 10px;
}

.featured-services .service-item .icon i {
  color: var(--accent-color);
  font-size: 36px;
  transition: 0.3s;
}

.featured-services .service-item h4 {
  font-weight: 700;
  margin-bottom: 15px;
  font-size: 20px;
}

.featured-services .service-item h4 a {
  color: var(--heading-color);
  transition: ease-in-out 0.3s;
}

.featured-services .service-item p {
  line-height: 24px;
  font-size: 14px;
  margin-bottom: 0;
}

.featured-services .service-item:hover {
  transform: translateY(-10px);
}

.featured-services .service-item:hover h4 a {
  color: var(--accent-color);
}

/*--------------------------------------------------------------
# About Section
--------------------------------------------------------------*/
.about .content h3 {
  font-size: 1.5rem;
  font-weight: 700;
}

.about .content ul {
  list-style: none;
  padding: 0;
}

.about .content ul li {
  padding: 10px 0 0 0;
  display: flex;
}

.about .content ul i {
  color: var(--accent-color);
  margin-right: 0.5rem;
  line-height: 1.2;
  font-size: 1.25rem;
}

.about .content p:last-child {
  margin-bottom: 0;
  font-size: var(--font-size);
}

.about .pulsating-play-btn {
  position: absolute;
  left: calc(50% - 47px);
  top: calc(50% - 47px);
}

/*--------------------------------------------------------------
# Stats Section
--------------------------------------------------------------*/
.stats {
  padding-top: 0;
  background-color: var(#f9f9f9);
}

.stats .stats-item {
  padding: 30px;
  width: 100%;
}

.stats .stats-item span {
  font-size: 48px;
  display: block;
  color: var(--accent-color);
  font-weight: 700;
}

.stats .stats-item p {
  color: color-mix(in srgb, var(--default-color), transparent 40%);
  padding: 0;
  margin: 0;
  font-family: var(--heading-font);
  font-size: 15px;
  font-weight: 600;
}

/*--------------------------------------------------------------
# Services Section
--------------------------------------------------------------*/
.services .service-item {
  background-color: var(--surface-color);
  text-align: center;
  border: 1px solid color-mix(in srgb, var(--default-color), transparent 85%);
  padding: 80px 20px;
  transition: border ease-in-out 0.3s;
  height: 100%;
}

.services .service-item .icon {
  margin: 0 auto;
  width: 64px;
  height: 64px;
  background: var(--accent-color);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  transition: 0.3s;
}

.services .service-item .icon i {
  color: var(--contrast-color);
  font-size: 28px;
  transition: ease-in-out 0.3s;
}

.services .service-item h3 {
  font-weight: 700;
  margin: 10px 0 15px 0;
  font-size: 22px;
  transition: 0.3s;
}

.services .service-item p {
  line-height: 24px;
  font-size: 14px;
  margin-bottom: 0;
}

.services .service-item:hover {
  border-color: var(--accent-color);
}

.services .service-item:hover h3 {
  color: var(--accent-color);
}

/*--------------------------------------------------------------
# Portfolio Section
--------------------------------------------------------------*/
.portfolio .portfolio-filters {
  padding: 0;
  margin: 0 auto 20px auto;
  list-style: none;
  text-align: center;
}

.portfolio .portfolio-filters li {
  cursor: pointer;
  display: inline-block;
  padding: 0;
  font-size: 16px;
  font-weight: 600;
  margin: 0 10px;
  line-height: 1;
  text-transform: uppercase;
  margin-bottom: 5px;
  transition: all 0.3s ease-in-out;
}

.portfolio .portfolio-filters li:hover,
.portfolio .portfolio-filters li.filter-active {
  color: var(--accent-color);
}

.portfolio .portfolio-filters li:first-child {
  margin-left: 0;
}

.portfolio .portfolio-filters li:last-child {
  margin-right: 0;
}

@media (max-width: 575px) {
  .portfolio .portfolio-filters li {
    font-size: 14px;
    margin: 0 5px;
  }
}

.portfolio .portfolio-item {
  position: relative;
}

.portfolio .portfolio-item .portfolio-info {
  background-color: color-mix(in srgb, var(--surface-color), transparent 10%);
  opacity: 0;
  position: absolute;
  left: 30px;
  right: 30px;
  bottom: 0;
  z-index: 3;
  transition: all ease-in-out 0.3s;
  padding: 15px;
}

.portfolio .portfolio-item .portfolio-info h4 {
  font-size: 18px;
  font-weight: 600;
  padding-right: 50px;
}

.portfolio .portfolio-item .portfolio-info p {
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  font-size: 14px;
  margin-bottom: 0;
  padding-right: 50px;
}

.portfolio .portfolio-item .portfolio-info .preview-link,
.portfolio .portfolio-item .portfolio-info .details-link {
  position: absolute;
  right: 24px;
  font-size: 24px;
  top: calc(50% - 14px);
  color: color-mix(in srgb, var(--default-color), transparent 30%);
  transition: 0.3s;
  line-height: 0;
}

.portfolio .portfolio-item .portfolio-info .preview-link:hover,
.portfolio .portfolio-item .portfolio-info .details-link:hover {
  color: var(--accent-color);
}

.portfolio .portfolio-item .portfolio-info .details-link {
  right: 14px;
  font-size: 28px;
}

.portfolio .portfolio-item:hover .portfolio-info {
  opacity: 1;
  bottom: 20px;
}

/*--------------------------------------------------------------
# masyayikh Section
--------------------------------------------------------------*/
.masyayikh {
  background-image: url(../img/topography.png);
}

.masyayikh .masyayikh-carousel,
.masyayikh .masyayikh-slider {
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.masyayikh .masyaikh-item {
  box-sizing: content-box;
  min-height: 320px;
  align-items: center;
  text-align: center;
  margin: auto;
}

.masyayikh .masyaikh-item .masyaikh-img {

  width: 250px;
  border-radius: 50%;
  position: relative;
  z-index: 2;
  border: 6px solid var(--background-color);
}


.masyayikh .masyaikh-item h3 {
  display: inline-block;
  font-size: 18px;
  font-weight: bold;
  margin: 10px auto 8px;
  padding-bottom: .45rem;
  border-bottom: 2px solid color-mix(in srgb, var(--accent-color), transparent 45%);
  line-height: 1.35;
  /* margin: 10px 0 5px 45px; */
}

.masyayikh .masyaikh-item h4 {
  font-size: 14px;
  font-weight: 400;
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  /* margin: 0 0 0 45px; */
}


.masyayikh .masyaikh-item p {
  font-style: italic;
  margin: 0 15px 0 15px;
  padding: 20px 20px 60px 20px;
  background: color-mix(in srgb, var(--default-color), transparent 97%);
  position: relative;
  border-radius: 6px;
  position: relative;
  z-index: 1;
}

.masyayikh .swiper-wrapper {
  height: auto;
}

.masyayikh .swiper-pagination {
  margin-top: 20px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  line-height: 1;
}

.masyayikh .swiper-pagination .swiper-pagination-bullet {
  display: block !important;
  width: 10px !important;
  height: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 50% !important;
  background: color-mix(in srgb, var(--accent-color), transparent 65%) !important;
  opacity: 1;
  transform: none !important;
}

.masyayikh .swiper-pagination .swiper-pagination-bullet-active {
  background: var(--accent-color) !important;
}

.masyayikh .swiper-pagination .swiper-pagination-bullet::before,
.masyayikh .swiper-pagination .swiper-pagination-bullet::after {
  display: none !important;
  content: none !important;
}

@media (max-width: 575.98px) {
  .masyayikh .swiper-pagination {
    gap: 7px;
    margin-top: 16px;
  }

  .masyayikh .swiper-pagination .swiper-pagination-bullet {
    width: 9px !important;
    height: 9px !important;
  }
}

/*--------------------------------------------------------------
# Call To Action Section
--------------------------------------------------------------*/
.call-to-action {
  padding: 80px 0;
  position: relative;
  clip-path: inset(0);
}

.call-to-action img {
  position: fixed;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.call-to-action:before {
  content: "";
  background: color-mix(in srgb, var(--background-color), transparent 50%);
  position: absolute;
  inset: 0;
  z-index: 2;
}

.call-to-action .container {
  position: relative;
  z-index: 3;
}

.call-to-action h3 {
  font-size: 28px;
  font-weight: 700;
  color: var(--default-color);
}

.call-to-action p {
  color: var(--default-color);
}

.call-to-action .cta-btn {
  font-family: var(--heading-font);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 1px;
  display: inline-block;
  padding: 12px 40px;
  border-radius: 50px;
  transition: 0.5s;
  margin: 10px;
  border: 2px solid var(--contrast-color);
  color: var(--contrast-color);
}

.call-to-action .cta-btn:hover {
  background: color-mix(in srgb, var(--accent-color) 90%, white 15%);
}

/*--------------------------------------------------------------
# Team Section
--------------------------------------------------------------*/
.team .member {
  position: relative;
}

.team .member .pic {
  overflow: hidden;
  margin-bottom: 50px;
}

.team .member .member-info {
  background-color: var(--surface-color);
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
  position: absolute;
  bottom: -50px;
  left: 20px;
  right: 20px;
  padding: 20px 15px;
  overflow: hidden;
  transition: 0.5s;
}

.team .member h4 {
  font-weight: 700;
  margin-bottom: 10px;
  font-size: 16px;
  position: relative;
  padding-bottom: 10px;
}

.team .member h4::after {
  content: "";
  position: absolute;
  display: block;
  width: 50px;
  height: 1px;
  background: color-mix(in srgb, var(--default-color), transparent 60%);
  bottom: 0;
  left: 0;
}

.team .member span {
  font-style: italic;
  display: block;
  font-size: 13px;
}

.team .member .social {
  position: absolute;
  right: 15px;
  bottom: 15px;
}

.team .member .social a {
  transition: color 0.3s;
  color: color-mix(in srgb, var(--default-color), transparent 70%);
}

.team .member .social a:hover {
  color: var(--accent-color);
}

.team .member .social i {
  font-size: 16px;
  margin: 0 2px;
}

/*--------------------------------------------------------------
# Contact Section
--------------------------------------------------------------*/
.contact .info-wrap {
  background-color: var(--surface-color);
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
  padding: 30px;
}

@media (max-width: 575px) {
  .contact .info-wrap {
    padding: 20px;
  }
}

.contact .info-item {
  margin-bottom: 40px;
}

.contact .info-item i {
  font-size: 20px;
  color: var(--accent-color);
  background: color-mix(in srgb, var(--accent-color), transparent 92%);
  width: 44px;
  height: 44px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50px;
  transition: all 0.3s ease-in-out;
  margin-right: 15px;
}

.contact .info-item h3 {
  padding: 0;
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 5px;
}

.contact .info-item p {
  padding: 0;
  margin-bottom: 0;
  font-size: 14px;
}

.contact .info-item:hover i {
  background: var(--accent-color);
  color: var(--contrast-color);
}

.contact .php-email-form {
  background-color: var(--surface-color);
  height: 100%;
  padding: 30px;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
}

@media (max-width: 575px) {
  .contact .php-email-form {
    padding: 20px;
  }
}

.contact .php-email-form input[type=text],
.contact .php-email-form input[type=email],
.contact .php-email-form textarea {
  font-size: 14px;
  padding: 10px 15px;
  box-shadow: none;
  border-radius: 0;
  color: var(--default-color);
  background-color: var(--surface-color);
  border-color: color-mix(in srgb, var(--default-color), transparent 80%);
}

.contact .php-email-form input[type=text]:focus,
.contact .php-email-form input[type=email]:focus,
.contact .php-email-form textarea:focus {
  border-color: var(--accent-color);
}

.contact .php-email-form input[type=text]::placeholder,
.contact .php-email-form input[type=email]::placeholder,
.contact .php-email-form textarea::placeholder {
  color: color-mix(in srgb, var(--default-color), transparent 70%);
}

.contact .php-email-form button[type=submit] {
  color: var(--contrast-color);
  background: var(--accent-color);
  border: 0;
  padding: 10px 30px;
  transition: 0.4s;
  border-radius: 50px;
}

.contact .php-email-form button[type=submit]:hover {
  background: color-mix(in srgb, var(--accent-color), transparent 25%);
}

/*--------------------------------------------------------------
# Portfolio Details Section
--------------------------------------------------------------*/
.portfolio-details .portfolio-details-slider img {
  width: 100%;
}

.portfolio-details .portfolio-details-slider .swiper-pagination {
  margin-top: 20px;
  position: relative;
}

.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: color-mix(in srgb, var(--default-color), transparent 85%);
  opacity: 1;
}

.portfolio-details .portfolio-details-slider .swiper-pagination .swiper-pagination-bullet-active {
  background-color: var(--accent-color);
}

.portfolio-details .portfolio-info {
  background-color: var(--surface-color);
  padding: 30px;
  box-shadow: 0px 0 30px rgba(0, 0, 0, 0.1);
}

.portfolio-details .portfolio-info h3 {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid color-mix(in srgb, var(--default-color), transparent 85%);
}

.portfolio-details .portfolio-info ul {
  list-style: none;
  padding: 0;
  font-size: 15px;
}

.portfolio-details .portfolio-info ul li+li {
  margin-top: 10px;
}

.portfolio-details .portfolio-description {
  padding-top: 30px;
}

.portfolio-details .portfolio-description h2 {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 20px;
}

.portfolio-details .portfolio-description p {
  padding: 0;
  color: color-mix(in srgb, var(--default-color), transparent 30%);
}

/*--------------------------------------------------------------
# Service Details Section
--------------------------------------------------------------*/
.service-details .service-box {
  background-color: var(--surface-color);
  padding: 20px;
  box-shadow: 0px 2px 20px rgba(0, 0, 0, 0.1);
}

.service-details .service-box+.service-box {
  margin-top: 30px;
}

.service-details .service-box h4 {
  font-size: 20px;
  font-weight: 700;
  border-bottom: 2px solid color-mix(in srgb, var(--default-color), transparent 92%);
  padding-bottom: 15px;
  margin-bottom: 15px;
}

.service-details .services-list {
  background-color: var(--surface-color);
}

.service-details .services-list a {
  color: color-mix(in srgb, var(--default-color), transparent 20%);
  background-color: color-mix(in srgb, var(--default-color), transparent 96%);
  display: flex;
  align-items: center;
  padding: 12px 15px;
  margin-top: 15px;
  transition: 0.3s;
}

.service-details .services-list a:first-child {
  margin-top: 0;
}

.service-details .services-list a i {
  font-size: 16px;
  margin-right: 8px;
  color: var(--accent-color);
}

.service-details .services-list a.active {
  color: var(--contrast-color);
  background-color: var(--accent-color);
}

.service-details .services-list a.active i {
  color: var(--contrast-color);
}

.service-details .services-list a:hover {
  background-color: color-mix(in srgb, var(--accent-color), transparent 95%);
  color: var(--accent-color);
}

.service-details .download-catalog a {
  color: var(--default-color);
  display: flex;
  align-items: center;
  padding: 10px 0;
  transition: 0.3s;
  border-top: 1px solid color-mix(in srgb, var(--default-color), transparent 90%);
}

.service-details .download-catalog a:first-child {
  border-top: 0;
  padding-top: 0;
}

.service-details .download-catalog a:last-child {
  padding-bottom: 0;
}

.service-details .download-catalog a i {
  font-size: 24px;
  margin-right: 8px;
  color: var(--accent-color);
}

.service-details .download-catalog a:hover {
  color: var(--accent-color);
}

.service-details .help-box {
  background-color: var(--accent-color);
  color: var(--contrast-color);
  margin-top: 30px;
  padding: 30px 15px;
}

.service-details .help-box .help-icon {
  font-size: 48px;
}

.service-details .help-box h4,
.service-details .help-box a {
  color: var(--contrast-color);
}

.service-details .services-img {
  margin-bottom: 20px;
}

.service-details h3 {
  font-size: 26px;
  font-weight: 700;
}

.service-details p {
  font-size: 15px;
}

.service-details ul {
  list-style: none;
  padding: 0;
  font-size: 15px;
}

.service-details ul li {
  padding: 5px 0;
  display: flex;
  align-items: center;
}

.service-details ul i {
  font-size: 20px;
  margin-right: 8px;
  color: var(--accent-color);
}

/*--------------------------------------------------------------
# Starter Section Section
--------------------------------------------------------------*/
.starter-section {
  /* Add your styles here */
}


/* ================================================================= */
/* Featured-icon */
.icon .featured-icon {
  width: 60px;
  color: var(--accent-color);
  margin-bottom: 20px;
  display: inline-block;
}

.article-content blockquote {
  margin: 1.5rem 0;
  padding: 1rem 1.25rem;
  border-left: 4px solid #103f2f;
  background: #f4f8f6;
  color: #273b33;
}

.article-content h2,
.article-content h3,
.article-content h4 {
  margin-top: 2rem;
  margin-bottom: 1rem;
  color: #10231d;
}

.article-content p,
.article-content ul,
.article-content ol,
.article-content blockquote {
  margin-bottom: 1.25rem;
}

.article-content a {
  color: #0f8f61;
  text-decoration: underline;
  text-underline-offset: .2em;
}

.activity-reaction {
  padding: 1.5rem;
  background: #f6faf8;
  border: 1px solid rgba(16, 63, 47, .12);
  border-radius: .75rem;
  scroll-margin-top: calc(var(--public-navbar-offset, 96px) + 1.5rem);
}

.activity-reaction-thanks {
  align-self: flex-start;
  padding: .75rem 1rem;
  color: #103f2f;
  background: #e8f5ef;
  border-radius: .5rem;
  font-weight: 600;
}

.activity-reaction-flash {
  margin-bottom: 1rem;
  padding: .85rem 1rem;
  border-radius: .75rem;
  font-weight: 800;
  line-height: 1.45;
}

.activity-reaction-flash.is-success {
  color: #0f4a37;
  background: rgba(27, 150, 91, .1);
  border: 1px solid rgba(27, 150, 91, .18);
}

.activity-reaction-flash.is-error {
  color: #8f2f24;
  background: rgba(180, 65, 48, .1);
  border: 1px solid rgba(180, 65, 48, .18);
}

.activity-reaction-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-top: 1.5rem;
}

.activity-reaction-button {
  display: grid;
  gap: .15rem;
  justify-items: center;
  padding: 1rem .75rem;
  color: #1f2937;
  background: #fff;
  border: 1px solid rgba(16, 63, 47, .14);
  border-radius: .75rem;
  box-shadow: 0 .5rem 1.25rem rgba(16, 63, 47, .05);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.activity-reaction-button:hover:not(:disabled),
.activity-reaction-button:focus:not(:disabled),
.activity-reaction-button.is-selected {
  transform: translateY(-2px);
  border-color: #103f2f;
  box-shadow: 0 .75rem 1.5rem rgba(16, 63, 47, .12);
}

.activity-reaction-button:disabled {
  cursor: not-allowed;
  opacity: .72;
}

.activity-reaction-emoji {
  font-size: 2rem;
  line-height: 1;
}

.activity-reaction-label {
  font-weight: 700;
}

.activity-reaction-point {
  color: #677788;
  font-size: .8125rem;
}

.activity-feed-swiper-main {
  height: auto;
}

.activity-feed-swiper-main .swiper-wrapper,
.activity-feed-swiper-main .swiper-slide {
  align-items: stretch;
  height: auto;
}

.activity-feed-main {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: .75rem;
  background: #f4f8f6;
  aspect-ratio: 16 / 9;
  min-height: 18rem;
  max-height: 34rem;
}

.activity-feed-main img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
}

.activity-feed-badge {
  position: absolute;
  top: 1rem;
  left: 1rem;
  padding: .4rem .75rem;
  color: #103f2f;
  background: rgba(255, 255, 255, .9);
  border-radius: 999px;
  font-size: .8125rem;
  font-weight: 700;
  box-shadow: 0 .5rem 1rem rgba(16, 63, 47, .12);
}

.activity-feed-swiper-thumbs .swiper-slide {
  height: auto;
  cursor: pointer;
}

.activity-feed-swiper-thumbs .swiper-slide strong {
  color: #10231d;
}

.activity-feed-swiper-thumbs .swiper-slide span {
  color: #677788;
}

.homepage-gallery-strip {
  width: 100%;
  height: clamp(144px, 12vw, 200px);
  overflow: hidden;
}

.homepage-gallery-track {
  display: flex;
  flex-flow: row nowrap;
  align-items: stretch;
  width: max-content;
  height: 100%;
  gap: clamp(6px, .42vw, 8px);
  will-change: transform;
}

.homepage-gallery-group {
  display: flex;
  flex: 0 0 auto;
  flex-flow: row nowrap;
  align-items: stretch;
  height: 100%;
  gap: clamp(6px, .42vw, 8px);
}

.homepage-gallery-item {
  width: auto;
  height: 100%;
  flex: 0 0 auto;
  margin: 0;
  overflow: hidden;
  background: #eef3f1;
}

.homepage-gallery-track img {
  display: block;
  width: auto;
  height: 100%;
  object-fit: contain;
  transition: transform .25s ease, filter .25s ease;
}

.homepage-gallery-track img.gallery-orientation-landscape,
.homepage-gallery-track img.gallery-orientation-square {
  object-fit: cover;
}

.homepage-gallery-track img.gallery-orientation-portrait {
  object-fit: contain;
}

.homepage-gallery-link {
  display: block;
  height: 100%;
  cursor: zoom-in;
}

.homepage-gallery-link:hover img,
.homepage-gallery-link:focus img {
  transform: scale(1.04);
  filter: brightness(.92);
}

.floating-social {
  position: fixed;
  right: 2rem;
  bottom: 2rem;
  z-index: 997;
}

.go-to {
  right: 6rem !important;
  bottom: 2rem !important;
}

.floating-social-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  color: var(--brand-green);
  background: #e7efe9;
  border: 0;
  border-radius: .5rem;
  box-shadow: 0 .75rem 1.5rem rgba(16, 63, 47, .14);
  transition: transform .18s ease, background-color .18s ease, color .18s ease;
}

.floating-social-toggle:hover,
.floating-social-toggle:focus,
.floating-social.is-open .floating-social-toggle {
  color: #fff;
  background: var(--brand-green);
  transform: translateY(-2px);
}

.floating-social-menu {
  position: absolute;
  right: 0;
  bottom: calc(100% + .75rem);
  display: grid;
  gap: .45rem;
  min-width: 12rem;
  padding: .55rem;
  background: #fff;
  border: 1px solid rgba(16, 63, 47, .08);
  border-radius: .75rem;
  box-shadow: 0 1rem 2rem rgba(16, 63, 47, .16);
  opacity: 0;
  transform: translateY(.5rem) scale(.98);
  pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}

.floating-social.is-open .floating-social-menu {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.floating-social-link {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .65rem .75rem;
  color: #1f2937;
  border-radius: .5rem;
  font-weight: 600;
}

.floating-social-link:hover,
.floating-social-link:focus {
  color: var(--brand-green);
  background: #edf8f2;
}

.floating-social-link i {
  color: var(--brand-green);
  font-size: 1.1rem;
}

.homepage-gallery-track-right {
  animation: homepage-gallery-to-right 45s linear infinite;
}

.homepage-gallery-track-left {
  animation: homepage-gallery-to-left 45s linear infinite;
}

@keyframes homepage-gallery-to-right {
  from {
    transform: translateX(-33.3333%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes homepage-gallery-to-left {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-33.3333%);
  }
}

@media (min-width: 992px) {
  .activity-feed-main {
    aspect-ratio: 16 / 7;
  }
}

@media (max-width: 767.98px) {
  .activity-feed-main {
    min-height: 14rem;
  }

  .homepage-gallery-strip {
    height: 144px;
  }

  .floating-social-toggle {
    width: 3rem;
    height: 3rem;
  }

  .floating-social {
    right: 1rem;
    bottom: 1rem;
  }

  .floating-social-menu {
    right: -4rem;
    min-width: min(14rem, calc(100vw - 2rem));
  }

  .go-to {
    right: 4.75rem !important;
    bottom: 1rem !important;
    width: 3rem !important;
    height: 3rem !important;
  }
}

@media (min-width: 768px) {
  .activity-reaction-options {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/*--------------------------------------------------------------
# Public Design System - MDQH NW
--------------------------------------------------------------*/
body {
  color: var(--default-color);
  background:
    linear-gradient(180deg, rgba(243, 246, 241, .55), rgba(255, 255, 255, 0) 18rem),
    var(--background-color);
}

.public-site .mdq-repeat-aos-item {
  opacity: 0 !important;
}

.public-site .mdq-repeat-aos-item.aos-animate {
  opacity: 1 !important;
  transform: none !important;
}

.public-site .mdq-repeat-aos-item.mdq-aos-scroll-down:not(.aos-animate) {
  transform: translate3d(0, 10px, 0) !important;
}

.public-site .mdq-repeat-aos-item.mdq-aos-scroll-up:not(.aos-animate) {
  transform: translate3d(0, -10px, 0) !important;
}

.public-site .mdq-stagger>* {
  transition-delay: var(--mdq-stagger-delay, 0ms);
}

.public-site .mdq-delay-1 {
  transition-delay: 70ms;
}

.public-site .mdq-delay-2 {
  transition-delay: 140ms;
}

.public-site .mdq-delay-3 {
  transition-delay: 210ms;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--brand-ink);
  letter-spacing: 0;
}

.text-primary,
.link,
.link-pointer,
.navbar .nav-link:hover,
.navbar .nav-link:focus {
  color: var(--brand-green) !important;
}

.text-body,
.text-body-secondary {
  color: var(--brand-muted) !important;
}

.bg-light,
.bg-soft-primary {
  background-color: var(--brand-bg) !important;
}

.bg-gradient-green,
.accent-background {
  background:
    linear-gradient(135deg, rgba(15, 61, 46, .98), rgba(23, 89, 66, .94)),
    radial-gradient(circle at 88% 15%, rgba(201, 155, 66, .34), transparent 30%) !important;
  color: #fff;
}

.bg-gradient-green h1,
.bg-gradient-green h2,
.bg-gradient-green h3,
.bg-gradient-green p,
.accent-background h1,
.accent-background h2,
.accent-background h3,
.accent-background p {
  color: #fff;
}

.btn {
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0;
}

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--brand-green);
  --bs-btn-border-color: var(--brand-green);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--brand-green-2);
  --bs-btn-hover-border-color: var(--brand-green-2);
  --bs-btn-active-bg: #0b2b22;
  --bs-btn-active-border-color: #0b2b22;
  box-shadow: 0 .8rem 1.6rem rgba(15, 61, 46, .18);
}

.btn-primary:hover,
.btn-primary:focus {
  box-shadow: 0 1rem 2rem rgba(15, 61, 46, .24);
}

.btn-soft-light {
  color: var(--brand-green) !important;
  background: rgba(255, 255, 255, .92) !important;
  border-color: rgba(255, 255, 255, .72) !important;
}

.btn-soft-light:hover,
.btn-soft-light:focus {
  color: #fff !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

.btn-soft-secondary {
  color: var(--brand-green) !important;
  background: #e7efe9 !important;
  border-color: rgba(15, 61, 46, .08) !important;
}

.btn-soft-secondary:hover,
.btn-soft-secondary:focus {
  color: #fff !important;
  background: var(--brand-green) !important;
  border-color: var(--brand-green) !important;
}

.card,
.table-responsive.bg-white,
.activity-reaction,
.floating-social-menu {
  border: 1px solid var(--brand-border) !important;
  border-radius: var(--brand-radius) !important;
  box-shadow: var(--brand-shadow) !important;
}

.card {
  overflow: hidden;
}

.card-img-top {
  background: var(--brand-bg);
}

.badge.bg-soft-primary,
.badge.text-bg-light,
.badge.bg-light {
  color: var(--brand-green) !important;
  background: #e7efe9 !important;
  border: 1px solid rgba(15, 61, 46, .08);
}

.table {
  color: var(--brand-ink);
}

.table> :not(caption)>*>* {
  border-color: rgba(23, 35, 29, .08);
}

.table thead th,
.table th {
  color: var(--brand-ink);
}

.form-control,
.form-select {
  border-color: var(--brand-border);
  border-radius: var(--brand-radius);
}

.form-control:focus,
.form-select:focus {
  border-color: rgba(15, 61, 46, .44);
  box-shadow: 0 0 0 .2rem rgba(15, 61, 46, .12);
}

#header.navbar {
  position: fixed !important;
  top: 0 !important;
  right: 0;
  left: 50%;
  z-index: 2147483000 !important;
  width: 100%;
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto;
  background: rgba(255, 255, 255, .94);
  border-bottom: 1px solid var(--brand-border);
  box-shadow: 0 12px 34px rgba(19, 43, 32, .055);
  backdrop-filter: blur(16px);
  transform: none !important;
}

#header.public-navbar.navbar-scrolled,
#header.public-navbar.navbar-fixed-on-scroll,
#header.public-navbar.navbar-moved-up,
#header.public-navbar.navbar-faded,
#header.public-navbar.navbar-invisible {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  left: 0 !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

#header.public-navbar {
  padding-block: .48rem;
}

#header .navbar-nav-wrap {
  display: flex;
  align-items: center;
  width: 100%;
  gap: 1rem;
}

.public-navbar-brand {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  min-width: 0;
  flex: 1 1 auto;
  max-width: min(30rem, calc(100% - 4rem));
  margin-right: auto;
}

.public-navbar-logo-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.9rem;
  height: 2.9rem;
  flex: 0 0 auto;
}

#header .navbar-brand-logo {
  max-height: 2.75rem;
}

.public-navbar-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.public-navbar-brand-mark {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.public-navbar-brand-svg {
  display: block;
  width: auto;
  height: 2.35rem;
  max-width: min(17rem, 44vw);
}

.public-navbar-brand-svg-dark {
  display: none;
}

html[data-theme="dark"] .public-navbar-brand-svg-light {
  display: none;
}

html[data-theme="dark"] .public-navbar-brand-svg-dark {
  display: block;
}

.public-navbar-nav {
  position: relative;
  align-items: center;
  gap: .18rem;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}

#header .navbar-nav .nav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .32rem;
  color: var(--brand-ink);
  border-radius: 999px;
  font-size: .92rem;
  font-weight: 750;
  line-height: 1;
  padding: .62rem .86rem;
  min-height: 2.15rem;
  white-space: nowrap;
}

#header .navbar-nav .nav-link.active,
#header .navbar-nav .nav-link[aria-expanded="true"],
#header .navbar-nav .nav-link:hover,
#header .navbar-nav .nav-link:focus {
  color: var(--brand-green) !important;
  background: rgba(231, 239, 233, .95);
  box-shadow: 0 .55rem 1.45rem rgba(19, 43, 32, .08);
}

.public-navbar-cta-item {
  margin-left: .45rem;
}

.public-navbar-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.35rem;
  padding: .6rem 1.15rem;
  border-radius: 999px;
  font-size: .92rem;
  line-height: 1;
  white-space: nowrap;
  box-shadow: 0 .65rem 1.5rem rgba(15, 61, 46, .14);
}

.public-navbar-cta i {
  display: none !important;
}

.public-navbar-theme-item {
  display: flex;
  align-items: center;
  margin-left: .35rem;
}

.mdq-theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .46rem;
  min-height: 2.34rem;
  padding: .52rem .78rem .52rem .56rem;
  color: var(--brand-ink);
  background: color-mix(in srgb, var(--brand-panel), transparent 4%);
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  box-shadow: 0 .45rem 1.25rem rgba(17, 42, 34, .055);
  font: inherit;
  font-size: .82rem;
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
  transition:
    color var(--brand-motion-base) var(--brand-ease),
    background-color var(--brand-motion-base) var(--brand-ease),
    border-color var(--brand-motion-base) var(--brand-ease),
    transform var(--brand-motion-base) var(--brand-ease),
    box-shadow var(--brand-motion-base) var(--brand-ease);
}

.mdq-theme-toggle:hover,
.mdq-theme-toggle:focus-visible {
  color: var(--brand-green-deep);
  background: color-mix(in srgb, var(--brand-gold), #fff 86%);
  border-color: color-mix(in srgb, var(--brand-gold), transparent 20%);
  box-shadow: 0 .65rem 1.35rem rgba(17, 42, 34, .09);
  transform: translateY(-1px);
}

.mdq-theme-toggle:focus-visible {
  outline: 0;
  box-shadow: var(--brand-focus-ring);
}

.mdq-theme-toggle-icon {
  display: inline-grid;
  place-items: center;
  width: 1.45rem;
  height: 1.45rem;
  flex: 0 0 auto;
  color: var(--brand-green-deep);
  background: color-mix(in srgb, var(--brand-green), transparent 90%);
  border: 1px solid color-mix(in srgb, var(--brand-green), transparent 82%);
  border-radius: 50%;
  font-size: .83rem;
  line-height: 1;
}

.mdq-theme-toggle-icon[hidden] {
  display: none !important;
}

html[data-theme="light"] [data-theme-toggle-icon-dark],
html[data-theme="dark"] [data-theme-toggle-icon-light] {
  display: none !important;
}

html[data-theme="dark"] .mdq-theme-toggle {
  color: #f8f6f0;
  background: rgba(248, 246, 240, .08);
  border-color: rgba(248, 246, 240, .18);
  box-shadow: none;
}

html[data-theme="dark"] .mdq-theme-toggle:hover,
html[data-theme="dark"] .mdq-theme-toggle:focus-visible {
  color: #fff;
  background: rgba(201, 164, 92, .18);
  border-color: rgba(201, 164, 92, .48);
}

html[data-theme="dark"] .mdq-theme-toggle-icon {
  color: #d7b96d;
  background: rgba(201, 164, 92, .12);
  border-color: rgba(201, 164, 92, .26);
}

#header .dropdown-menu,
#header .hs-mega-menu {
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow-strong);
}

#header .hs-has-mega-menu {
  position: relative;
}

#header .hs-has-mega-menu:not(.public-navbar-more) {
  position: static;
}

#header .hs-has-mega-menu>.hs-mega-menu {
  display: none;
}

#header .hs-has-mega-menu.mdq-mega-menu-opened>.hs-mega-menu {
  display: block;
}

@media (min-width: 1200px) {
  #header .hs-has-mega-menu>.hs-mega-menu {
    position: absolute;
    top: calc(100% + .22rem);
    left: 0;
    z-index: 1050;
  }

  #header .hs-has-mega-menu>.public-navbar-mega-menu {
    position: fixed;
    top: calc(var(--public-navbar-offset, 72px) + .05rem);
    width: min(50rem, calc(100vw - 2rem));
    min-width: min(50rem, calc(100vw - 2rem)) !important;
    max-width: min(50rem, calc(100vw - 2rem));
    left: 50vw !important;
    padding: .55rem;
    transform: translateX(-50%) !important;
  }

  #header .hs-has-mega-menu>.hs-mega-menu.hs-position-right {
    right: 0;
    left: auto;
  }

  #header .public-navbar-more>.hs-mega-menu.hs-position-right {
    min-width: 14rem !important;
    width: auto;
    transform: none;
  }
}

@media (max-width: 1199.98px) {
  #header .hs-has-mega-menu>.hs-mega-menu {
    position: static;
    width: 100%;
    min-width: 100% !important;
    margin-top: .5rem;
    transform: none;
  }
}

#header .public-navbar-more-menu {
  padding: .45rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(247, 250, 248, .96));
  border-color: rgba(15, 61, 46, .1);
  border-radius: 14px;
}

#header .public-navbar-more-menu .navbar-dropdown-menu-inner {
  display: grid;
  gap: .18rem;
  padding: .2rem;
}

#header .dropdown-item {
  color: var(--brand-ink);
  border-radius: 6px;
  font-weight: 600;
}

#header .public-navbar-more-menu .dropdown-item {
  display: flex;
  align-items: center;
  min-height: 2.35rem;
  padding: .58rem .75rem;
  border-radius: 10px;
  font-size: .92rem;
}

#header .dropdown-item:hover,
#header .dropdown-item:focus {
  color: var(--brand-green);
  background: var(--brand-bg);
}

#header .dropdown-item.active {
  color: var(--brand-green);
  background: rgba(231, 239, 233, .95);
}

#header .dropdown-header {
  color: var(--brand-muted);
  font-weight: 800;
}

#header .public-navbar-more-menu .dropdown-header {
  padding: .45rem .75rem .3rem;
  color: color-mix(in srgb, var(--brand-green), var(--brand-muted) 34%);
  font-size: .68rem;
  letter-spacing: .1em;
}

.public-nav-feature {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-height: 15.25rem;
  padding: 1.45rem;
  background:
    linear-gradient(180deg, rgba(243, 246, 241, .9), rgba(255, 255, 255, .88)),
    #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
}

.public-nav-feature-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.55rem;
  margin-bottom: .9rem;
  color: var(--brand-green);
  background: #e7efe9;
  border-radius: var(--brand-radius);
  font-size: 1.2rem;
}

.public-navbar-mega-menu .navbar-dropdown-menu-inner {
  display: grid;
  gap: .58rem;
  padding: 1.25rem 1.45rem;
}

.public-navbar-mega-menu .dropdown-header {
  padding: 0 0 .35rem;
  font-size: .93rem;
  letter-spacing: 0;
  text-transform: none;
}

#header .public-navbar-mega-menu .dropdown-item {
  display: flex;
  align-items: center;
  min-height: 2.38rem;
  padding: .52rem .6rem;
  border-radius: 8px;
}

.public-nav-feature-link {
  font-weight: 750;
}

.public-nav-download {
  display: block;
  height: 100%;
  padding: 1.05rem;
  background: rgba(255, 255, 255, .72);
  border: 1px solid rgba(15, 61, 46, .09);
  border-radius: var(--brand-radius);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.public-nav-download:hover,
.public-nav-download:focus {
  transform: translateY(-2px);
  background: #fff;
  border-color: rgba(15, 61, 46, .22);
}

.hero-overlay .hero-image {
  position: relative;
  overflow: hidden;
}

.hero-overlay .hero-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(11, 43, 34, .84), rgba(15, 61, 46, .46), rgba(15, 61, 46, .12)),
    radial-gradient(circle at 80% 20%, rgba(201, 155, 66, .24), transparent 30%);
}

.hero-overlay .hero-image>.container {
  position: relative;
  z-index: 1;
}

.activity-feed-main,
.homepage-gallery-item,
.homepage-gallery-img,
.article-content img,
.img-fluid.rounded-3,
.rounded-3 {
  border-radius: var(--brand-radius) !important;
}

.activity-feed-main {
  box-shadow: var(--brand-shadow);
}

.activity-feed-badge {
  color: var(--brand-green);
  border: 1px solid rgba(15, 61, 46, .08);
}

.activity-reaction {
  background: var(--brand-bg);
}

.activity-reaction-thanks {
  color: var(--brand-green);
  background: #e7efe9;
  border-radius: var(--brand-radius);
}

.activity-reaction-button {
  border-color: rgba(15, 61, 46, .12);
  border-radius: var(--brand-radius);
}

.activity-reaction-button:hover:not(:disabled),
.activity-reaction-button:focus:not(:disabled),
.activity-reaction-button.is-selected {
  border-color: var(--brand-green);
  box-shadow: 0 .75rem 1.5rem rgba(15, 61, 46, .14);
}

.article-content {
  color: #2e3e35;
}

.article-content a {
  color: var(--brand-green);
}

footer.bg-dark {
  background:
    radial-gradient(circle at 18% 0%, rgba(201, 155, 66, .16), transparent 24rem),
    linear-gradient(145deg, #123f30 0%, #08271f 52%, #061f19 100%) !important;
  border-top: 3px solid var(--brand-gold);
}

.public-footer {
  position: relative;
  overflow: hidden;
  padding-block: clamp(3rem, 5vw, 4.75rem) 1.35rem;
}

.public-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .025) 1px, transparent 1px),
    radial-gradient(circle at 12% 8%, rgba(201, 155, 66, .18), transparent 25%),
    radial-gradient(circle at 88% 18%, rgba(255, 255, 255, .08), transparent 28%);
  background-size: 56px 56px, 56px 56px, auto, auto;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, .88), rgba(0, 0, 0, .5));
  pointer-events: none;
}

.public-footer>.container {
  position: relative;
  z-index: 1;
}

.public-footer-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-bottom: clamp(1.5rem, 3vw, 2.4rem);
  border-bottom: 1px solid rgba(255, 255, 255, .12);
}

.public-footer-brand {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2vw, 1.35rem);
  max-width: 52rem;
}

.public-footer-brand img {
  width: 5.25rem;
  height: 5.25rem;
  flex: 0 0 auto;
  padding: .55rem;
  object-fit: contain;
  background: rgba(255, 255, 255, .96);
  border: 1px solid rgba(255, 255, 255, .56);
  border-radius: 16px;
  box-shadow: 0 18px 38px rgba(0, 0, 0, .18);
}

.public-footer-kicker {
  display: block;
  margin-bottom: .25rem;
  color: #ffe2a4;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-footer h2 {
  margin-bottom: .35rem;
  color: #ffffff;
  font-size: clamp(2.2rem, 4vw, 4rem);
  font-weight: 800;
  line-height: 1;
  text-shadow: 0 1px 18px rgba(0, 0, 0, .22);
}

.public-footer .public-footer-brand h2,
.public-footer .public-footer-brand p {
  color: #ffffff !important;
}

.public-footer p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, .9);
  max-width: 50rem;
}

.public-footer .btn-soft-light {
  min-width: max-content;
  color: #0f3d2e;
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(255, 255, 255, .7);
  box-shadow: 0 16px 36px rgba(0, 0, 0, .18);
}

.public-footer .btn-soft-light:hover,
.public-footer .btn-soft-light:focus {
  color: #ffffff;
  background: var(--brand-gold);
  border-color: rgba(255, 226, 164, .8);
}

.public-footer-main {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(16rem, .85fr) minmax(16rem, .85fr);
  gap: clamp(1rem, 2vw, 1.35rem);
  padding-block: clamp(1.35rem, 3vw, 2rem);
}

.public-footer-panel {
  min-height: 100%;
  padding: clamp(1.1rem, 2vw, 1.35rem);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .09), rgba(255, 255, 255, .045));
  border: 1px solid rgba(255, 255, 255, .13);
  border-radius: 14px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06);
  backdrop-filter: blur(10px);
}

.public-footer-panel .text-cap {
  display: block;
  margin-bottom: .85rem;
}

.public-footer-contact li,
.public-footer-links,
.public-footer-social {
  display: grid;
  gap: .7rem;
}

.public-footer-contact li {
  grid-template-columns: 1.55rem minmax(0, 1fr);
  align-items: start;
  color: rgba(255, 255, 255, .9);
  line-height: 1.55;
}

.public-footer-contact i,
.public-footer-social i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #ffe2a4;
  line-height: 1.4;
}

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

.public-footer-links a,
.public-footer-social a {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  color: rgba(255, 255, 255, .9);
  font-weight: 700;
  line-height: 1.35;
}

.public-footer-links a:hover,
.public-footer-links a:focus,
.public-footer-social a:hover,
.public-footer-social a:focus {
  color: #ffe2a4;
  transform: translateX(2px);
}

.public-footer-social a {
  align-items: center;
  gap: .55rem;
}

.public-footer-empty {
  color: rgba(255, 255, 255, .72) !important;
  font-size: .95rem;
  line-height: 1.6;
}

.public-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(255, 255, 255, .12);
}

.public-footer-bottom p {
  color: rgba(255, 255, 255, .78);
  font-size: .95rem;
}

footer .text-white-70,
footer .link-light-75 {
  color: rgba(255, 255, 255, .9) !important;
}

footer .text-cap {
  color: #ffe2a4 !important;
  font-weight: 800;
}

.floating-social-toggle,
.go-to {
  color: #fff !important;
  background: var(--brand-green) !important;
  border-radius: var(--brand-radius) !important;
  box-shadow: 0 .75rem 1.5rem rgba(15, 61, 46, .18) !important;
}

.floating-social-toggle:hover,
.floating-social-toggle:focus,
.floating-social.is-open .floating-social-toggle,
.go-to:hover {
  background: var(--brand-gold) !important;
  color: #fff !important;
}

.floating-social-link:hover,
.floating-social-link:focus {
  color: var(--brand-green);
  background: var(--brand-bg);
}

.floating-social-link i {
  color: var(--brand-green);
}

@media (max-width: 991.98px) {
  #header.navbar {
    background: rgba(255, 255, 255, .96);
  }

  #header .navbar-collapse {
    flex-basis: 100%;
    margin-top: .75rem;
    padding: .75rem;
    background: #fff;
    border: 1px solid var(--brand-border);
    border-radius: var(--brand-radius);
    box-shadow: var(--brand-shadow);
  }

  .public-navbar-nav {
    align-items: stretch;
    gap: .35rem;
    padding: 0;
    background: transparent;
    border: 0;
    border-radius: 0;
  }

  .public-navbar-brand {
    max-width: calc(100% - 4.25rem);
  }

  #header .navbar-nav .nav-link,
  .public-navbar-cta {
    justify-content: flex-start;
    width: 100%;
    min-height: 2.45rem;
  }

  .public-navbar-cta-item {
    margin-left: 0;
    margin-top: .25rem;
  }

  #header .public-navbar-more-menu {
    width: 100%;
    min-width: 0 !important;
    margin-top: .35rem;
    box-shadow: none;
  }

  .public-footer-hero,
  .public-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  .public-footer .btn-soft-light {
    width: 100%;
  }

  .public-footer-main {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .public-navbar-logo-wrap {
    width: 2.85rem;
    height: 2.85rem;
  }

  .public-navbar-brand-svg {
    height: 2.25rem;
    max-width: min(18rem, 54vw);
  }

  .navbar-nav-wrap {
    gap: .65rem;
  }

  .public-footer-brand {
    align-items: flex-start;
    flex-direction: column;
  }

  .public-footer-brand img {
    width: 4.5rem;
    height: 4.5rem;
  }

  .public-footer-links {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 399.98px) {
  .public-navbar-brand {
    gap: .75rem;
    max-width: calc(100% - 3.65rem);
  }

  .public-navbar-logo-wrap {
    width: 2.55rem;
    height: 2.55rem;
  }

  .public-navbar-brand-svg {
    height: 2rem;
    max-width: min(13rem, 52vw);
  }
}

/*--------------------------------------------------------------
# Public Pages - Stage 4
--------------------------------------------------------------*/
.public-section {
  padding-block: clamp(4rem, 7vw, 6.5rem);
}

.public-section-heading {
  max-width: 48rem;
}

.public-section-heading.text-center,
.public-page-heading {
  margin-inline: auto;
}

.public-section-kicker {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-bottom: .75rem;
  color: var(--brand-gold);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-section-kicker::before {
  content: "";
  width: 1.7rem;
  height: 2px;
  background: currentColor;
}

.public-section-heading.text-center .public-section-kicker::after,
.public-page-heading .public-section-kicker::after {
  content: "";
  width: 1.7rem;
  height: 2px;
  background: currentColor;
}

.public-section-heading.text-center .public-section-kicker::before,
.public-page-heading .public-section-kicker::before {
  display: none;
}

.public-page-heading {
  max-width: 46rem;
}

.public-page-heading h1,
.public-section-heading h2 {
  font-weight: 800;
}

.public-hero {
  position: relative;
  overflow: hidden;
  padding-block: clamp(4rem, 8vw, 7rem);
  background:
    radial-gradient(circle at 8% 20%, rgba(201, 155, 66, .14), transparent 28%),
    linear-gradient(180deg, rgba(243, 246, 241, .78), rgba(255, 255, 255, .92));
}

.public-hero::after {
  content: "";
  position: absolute;
  inset: auto -10% -32% 55%;
  height: 28rem;
  background: radial-gradient(circle, rgba(15, 61, 46, .12), transparent 68%);
  pointer-events: none;
}

.public-hero>.container {
  position: relative;
  z-index: 1;
}

.public-hero-copy h1 {
  margin-bottom: 1rem !important;
  color: var(--brand-ink) !important;
  font-weight: 800;
}

.public-hero-copy h2 {
  color: var(--brand-green);
  font-size: clamp(1.35rem, 2.5vw, 2rem);
  font-weight: 800;
}

.public-hero-copy p {
  margin-top: 1rem;
  color: var(--brand-muted);
  font-size: 1.08rem;
}

.public-hero-mini-stats {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
}

.public-hero-mini-stats span {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 3rem;
  padding: .55rem .8rem;
  color: var(--brand-muted);
  background: rgba(255, 255, 255, .86);
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: 0 .8rem 1.5rem rgba(15, 61, 46, .07);
}

.public-hero-mini-stats strong {
  color: var(--brand-green);
  font-size: 1.35rem;
}

.public-hero-media {
  isolation: isolate;
}

.public-hero-image {
  overflow: hidden;
  border: 1px solid rgba(15, 61, 46, .1);
  border-radius: 8px;
  box-shadow: var(--brand-shadow-strong);
}

.public-hero-image img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.public-hero-quote {
  position: absolute;
  top: 2rem;
  left: -2rem;
  width: min(20rem, 82%);
  padding: .8rem .95rem;
  background: rgba(255, 255, 255, .94);
  border: 1px solid var(--brand-border);
  border-radius: 8px;
  box-shadow: var(--brand-shadow);
}

.public-hero-quote .avatar {
  width: 2.45rem;
  height: 2.45rem;
  overflow: hidden;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, .82);
}

.public-hero-quote .avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.public-feature-strip {
  padding-block: 3rem;
}

.public-feature-card {
  height: 100%;
  padding: 1.35rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-feature-card img {
  width: 3.5rem !important;
  height: 3.5rem;
  padding: .7rem;
  background: var(--brand-bg);
  border-radius: var(--brand-radius);
}

.public-feature-card h5 {
  font-weight: 800;
}

.public-about-section {
  padding-block: 4rem;
}

.public-stats-section {
  background: linear-gradient(180deg, #fff, rgba(243, 246, 241, .72));
}

.public-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.public-stat-card {
  min-height: 11rem;
  padding: 1.25rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-stat-card h4 {
  color: var(--brand-green);
  font-weight: 800;
}

.public-masyayikh-section .section-title p {
  max-width: 42rem;
  margin-inline: auto;
}

.public-gallery-section {
  padding-block: 4rem 2rem;
  background: #fff;
}

.public-cta-band {
  padding-block: 3rem;
}

.public-contact-panel,
.public-map-section iframe {
  overflow: hidden;
  border: 1px solid var(--brand-border) !important;
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-page-hero .public-section-kicker {
  color: #ffe2a4;
}

.public-page-hero .hero-image {
  padding-top: clamp(3rem, 7vw, 5rem);
}

.public-page-hero .text-primary {
  color: #ffe2a4 !important;
}

.public-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.5rem;
}

.registration-logo-row {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  padding: .75rem 1rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.registration-logo-row img {
  height: 4.5rem;
  width: auto;
  object-fit: contain;
}

.registration-intro-card {
  display: grid;
  grid-template-columns: minmax(9rem, auto) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: start;
  padding: clamp(1.25rem, 4vw, 2.5rem);
  background:
    linear-gradient(135deg, rgba(15, 61, 46, .06), rgba(201, 155, 66, .08)),
    #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.registration-notice-card {
  position: relative;
  overflow: hidden;
  padding: clamp(1.5rem, 5vw, 3rem);
  background:
    linear-gradient(180deg, rgba(227, 247, 238, .72), rgba(255, 255, 255, .95) 28%),
    #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow-strong);
}

.registration-document {
  max-width: 58rem;
  margin-inline: auto;
  padding: clamp(1.5rem, 5vw, 3.25rem);
  background:
    linear-gradient(180deg, rgba(227, 247, 238, .62), rgba(255, 255, 255, .96) 24%),
    #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow-strong);
}

.registration-document-content {
  color: #25352f;
  font-size: 1.075rem;
  line-height: 1.78;
}

.registration-document-content h1,
.registration-document-content h2,
.registration-document-content h3,
.registration-document-content h4,
.registration-document-content h5,
.registration-document-content h6 {
  color: var(--brand-ink);
}

.registration-document-content h1 {
  font-size: clamp(2rem, 5vw, 3rem);
  text-align: center;
}

.registration-document-content table {
  width: 100%;
  margin: 1.5rem 0;
  border-collapse: collapse;
  overflow: hidden;
  border: 1px solid rgba(15, 61, 46, .15);
  border-radius: var(--brand-radius);
}

.registration-document-content th,
.registration-document-content td {
  padding: .75rem .9rem;
  border: 1px solid rgba(15, 61, 46, .12);
  vertical-align: top;
}

.registration-document-content th {
  color: #fff;
  background: #0f946b;
}

.registration-document-content img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 1rem auto;
  object-fit: contain;
}

.registration-document-content pre {
  overflow: auto;
  padding: 1rem;
  color: #e5e7eb;
  background: #10231d;
  border-radius: var(--brand-radius);
}

.public-article-content table {
  width: 100%;
  margin: 1.5rem 0;
  border-collapse: collapse;
  overflow: hidden;
  border: 1px solid rgba(15, 61, 46, .14);
  border-radius: var(--brand-radius);
}

.public-article-content th,
.public-article-content td {
  padding: .75rem .9rem;
  border: 1px solid rgba(15, 61, 46, .12);
  vertical-align: top;
}

.public-article-content th {
  color: #fff;
  background: #0f946b;
}

.public-article-content img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 1rem auto;
  object-fit: contain;
}

.public-article-content iframe[src*="youtube.com"],
.public-article-content iframe[src*="youtube-nocookie.com"],
.public-article-content iframe[src*="player.vimeo.com"],
.public-article-content iframe[src*="tiktok.com"],
.public-article-content iframe[src*="instagram.com"],
.public-article-content iframe[src*="facebook.com"],
.public-article-content video {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  margin: 1.5rem auto;
  border: 0;
  border-radius: var(--brand-radius);
  box-shadow: 0 1rem 2.5rem rgba(16, 35, 29, .14);
}

.public-article-content iframe[src*="youtube.com"],
.public-article-content iframe[src*="youtube-nocookie.com"],
.public-article-content iframe[src*="player.vimeo.com"],
.public-article-content iframe[src*="facebook.com"],
.public-article-content video {
  aspect-ratio: 16 / 9;
}

.public-article-content iframe[src*="tiktok.com"],
.public-article-content iframe[src*="instagram.com"] {
  min-height: clamp(520px, 78vw, 760px);
  background: #fff;
}

.public-article-content figure:has(iframe[src*="youtube.com"]),
.public-article-content figure:has(iframe[src*="youtube-nocookie.com"]),
.public-article-content figure:has(iframe[src*="player.vimeo.com"]),
.public-article-content figure:has(iframe[src*="tiktok.com"]),
.public-article-content figure:has(iframe[src*="instagram.com"]),
.public-article-content figure:has(iframe[src*="facebook.com"]) {
  margin: 1.75rem 0;
}

.public-article-content pre {
  overflow: auto;
  padding: 1rem;
  color: #e5e7eb;
  background: #10231d;
  border-radius: var(--brand-radius);
}

.registration-notice-card::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 9rem;
  pointer-events: none;
  background: linear-gradient(0deg, rgba(15, 61, 46, .08), transparent);
}

.registration-notice-header,
.registration-notice-body,
.registration-notice-closing,
.registration-notice-signature,
.registration-notice-deputies {
  position: relative;
  z-index: 1;
}

.registration-notice-header {
  display: grid;
  justify-items: center;
  gap: 1.25rem;
  margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
}

.registration-notice-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 11rem;
  padding: .65rem 2.25rem;
  color: #fff;
  background: var(--brand-green);
  border: 2px solid rgba(201, 155, 66, .75);
  border-radius: 999px;
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  box-shadow: 0 .75rem 1.4rem rgba(15, 61, 46, .18);
}

.registration-notice-body {
  max-width: 58rem;
  margin-inline: auto;
  color: #25352f;
  font-size: 1.075rem;
  line-height: 1.75;
}

.registration-notice-body h2 {
  margin-bottom: 1.25rem;
  color: var(--brand-ink);
  font-size: clamp(1.9rem, 4vw, 2.8rem);
  line-height: 1.12;
  text-align: center;
}

.registration-notice-opening {
  font-weight: 700;
}

.registration-requirements {
  margin-top: 1.4rem;
  padding-left: 1rem;
  border-left: 4px solid rgba(15, 61, 46, .18);
}

.registration-requirements h3 {
  margin-top: 0;
  margin-bottom: .75rem;
  font-size: 1.15rem;
}

.registration-requirements ol {
  margin-bottom: 0;
  padding-left: 1.25rem;
}

.registration-intro-card .registration-logo-row {
  position: sticky;
  top: 6.5rem;
}

.registration-intro-copy {
  max-width: 52rem;
}

.registration-intro-copy h2 {
  margin-bottom: 1rem;
  color: var(--brand-ink);
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.12;
}

.registration-intro-content {
  color: #293b34;
  font-size: 1.075rem;
  line-height: 1.85;
  text-align: left;
}

.registration-intro-content> :last-child,
.registration-location-text> :last-child {
  margin-bottom: 0;
}

.registration-intro-content ul,
.registration-intro-content ol {
  padding-left: 1.35rem;
}

.registration-intro-content li+li {
  margin-top: .45rem;
}

.registration-total-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding: 1rem 1.25rem;
  color: #fff;
  background:
    linear-gradient(135deg, var(--brand-green), var(--brand-green-2));
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.registration-total-card span {
  color: rgba(255, 255, 255, .74);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.registration-total-card strong {
  font-size: clamp(1.8rem, 4vw, 2.65rem);
}

.registration-fee-table {
  overflow: hidden;
}

.registration-notice-fee-table {
  border: 1px solid rgba(15, 61, 46, .12);
}

.registration-notice-fee-table thead th {
  color: #fff;
  background: #0f946b;
  font-size: 1rem;
  letter-spacing: .03em;
  text-transform: uppercase;
}

.registration-notice-fee-table tbody td,
.registration-notice-fee-table tbody th {
  color: #0f7658;
  font-size: 1.05rem;
  font-weight: 800;
  vertical-align: middle;
}

.registration-notice-fee-table tbody td:first-child {
  width: 5rem;
  text-align: center;
}

.registration-fee-total-row th,
.registration-fee-total-row td {
  color: #fff !important;
  background: #0f946b !important;
  font-size: 1.15rem !important;
}

.registration-location-note {
  display: flex;
  gap: .9rem;
  align-items: flex-start;
  padding: 1rem 1.15rem;
}

.registration-location-note i {
  flex: 0 0 auto;
  margin-top: .15rem;
  color: var(--brand-gold);
  font-size: 1.25rem;
}

.registration-location-text {
  margin-top: .25rem;
  line-height: 1.75;
}

.registration-location-text p {
  margin-bottom: .6rem;
}

.registration-notice-closing,
.registration-notice-signature,
.registration-notice-deputies {
  max-width: 58rem;
  margin-inline: auto;
  color: #25352f;
  font-size: 1.04rem;
  line-height: 1.75;
}

.registration-notice-closing {
  margin-top: 2rem;
}

.registration-notice-signature {
  margin-top: 1.75rem;
  padding-block: 1rem;
  text-align: center;
}

.registration-signature-image {
  display: flex;
  justify-content: center;
  margin: .5rem auto .75rem;
}

.registration-signature-image img {
  display: block;
  max-width: min(22rem, 100%);
  max-height: 8rem;
  object-fit: contain;
}

.registration-notice-deputies {
  margin-top: .75rem;
}

.registration-notice-deputies ol {
  padding-left: 1.25rem;
}

.registration-masyayikh-section {
  scroll-margin-top: 6rem;
}

.registration-masyayikh-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 18.5rem));
  justify-content: center;
  gap: clamp(1rem, 2vw, 1.5rem);
}

.registration-masyayikh-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: .85rem;
  max-width: 44rem;
  margin-inline: auto;
}

.registration-masyaikh-card {
  display: grid;
  grid-template-columns: 3.25rem minmax(0, 1fr);
  align-items: center;
  gap: .85rem;
  min-height: 100%;
  padding: .78rem 1.05rem .78rem .78rem;
  overflow: visible;
  background: rgba(255, 255, 255, .96);
  border: 1px solid rgba(16, 35, 29, .08);
  border-radius: 999px;
  box-shadow: 0 14px 34px rgba(19, 43, 32, .1);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.registration-masyaikh-card:hover,
.registration-masyaikh-card:focus-within {
  transform: translateY(-3px);
  border-color: rgba(15, 61, 46, .18);
  box-shadow: 0 18px 42px rgba(19, 43, 32, .12);
}

.registration-masyaikh-card img {
  width: 3.25rem;
  height: 3.25rem;
  object-fit: cover;
  object-position: top center;
  border: 4px solid rgba(237, 243, 238, .95);
  border-radius: 50%;
  margin-bottom: 0;
  background: #eef5ef;
}

.registration-masyaikh-card div {
  padding: 0 .8rem;
}

.registration-masyaikh-card h3 {
  min-width: 0;
  margin-bottom: 0;
  color: var(--brand-ink);
  display: -webkit-box;
  overflow: hidden;
  font-size: clamp(.9rem, 1.05vw, 1rem);
  line-height: 1.32;
  font-weight: 800;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.registration-masyaikh-card p {
  margin-bottom: 0;
  color: var(--brand-muted);
  font-size: .88rem;
  line-height: 1.55;
}

.registration-action-panel {
  height: 100%;
  padding: 1.25rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.registration-action-panel h3 {
  margin-bottom: 1rem;
  font-weight: 800;
}

.registration-contact-list {
  display: grid;
  gap: .75rem;
}

.registration-contact-list a,
.registration-download-card {
  display: flex;
  gap: .8rem;
  height: 100%;
  padding: 1rem;
  color: var(--brand-ink);
  background: var(--brand-bg);
  border: 1px solid rgba(15, 61, 46, .08);
  border-radius: var(--brand-radius);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.registration-contact-list a:hover,
.registration-contact-list a:focus,
.registration-download-card:hover,
.registration-download-card:focus {
  transform: translateY(-2px);
  background: #fff;
  box-shadow: 0 .8rem 1.5rem rgba(15, 61, 46, .11);
}

.registration-contact-list i,
.registration-download-card i {
  color: var(--brand-gold);
  font-size: 1.25rem;
}

.registration-contact-list span {
  display: grid;
  gap: .1rem;
}

.registration-download-card {
  flex-direction: column;
}

.registration-empty-note {
  padding: 1rem;
  color: var(--brand-muted);
  background: var(--brand-bg);
  border: 1px dashed rgba(15, 61, 46, .18);
  border-radius: var(--brand-radius);
}

.public-map-empty {
  padding: clamp(2rem, 6vw, 4rem);
  background:
    linear-gradient(135deg, rgba(15, 61, 46, .06), rgba(201, 155, 66, .08)),
    #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-map-empty i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: .85rem;
  color: var(--brand-gold);
  background: rgba(201, 155, 66, .12);
  border-radius: 50%;
  font-size: 1.35rem;
}

@media (max-width: 767.98px) {
  .registration-masyayikh-grid {
    grid-template-columns: repeat(2, minmax(0, 16rem));
    justify-content: center;
    gap: .75rem;
  }

  .registration-masyayikh-list {
    grid-template-columns: 1fr;
    max-width: 32rem;
  }

  .registration-masyaikh-card div {
    padding: 0 .7rem;
  }

  .registration-masyaikh-card h3 {
    font-size: .88rem;
  }

  .registration-masyaikh-card p {
    font-size: .84rem;
  }

  .registration-intro-card {
    grid-template-columns: 1fr;
    gap: 1.25rem;
    padding: 1.1rem;
  }

  .registration-notice-card {
    padding: 1.1rem;
  }

  .registration-document {
    padding: 1.1rem;
  }

  .registration-notice-badge {
    min-width: 9rem;
    padding-inline: 1.4rem;
    font-size: .95rem;
  }

  .registration-intro-card .registration-logo-row {
    position: static;
    justify-self: start;
  }

  .registration-logo-row {
    gap: .7rem;
    padding: .65rem .75rem;
  }

  .registration-logo-row img {
    height: 3.25rem;
  }

  .registration-intro-content {
    font-size: 1rem;
  }

  .registration-notice-body,
  .registration-notice-closing,
  .registration-notice-signature,
  .registration-notice-deputies {
    font-size: .98rem;
  }

  .registration-notice-fee-table thead th,
  .registration-notice-fee-table tbody td,
  .registration-notice-fee-table tbody th {
    font-size: .9rem;
  }

  .registration-notice-fee-table tbody td:first-child {
    width: 3.25rem;
  }

  .registration-total-card {
    align-items: flex-start;
    flex-direction: column;
  }
}

.public-filter-card .form-label {
  color: var(--brand-ink);
  font-weight: 800;
}

.public-filter-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .6rem;
  align-items: center;
}

.public-filter-submit,
.public-filter-reset {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.65rem;
  padding-inline: 1.4rem;
  white-space: nowrap;
}

.public-filter-reset {
  color: var(--brand-green);
  font-weight: 800;
  background: rgba(15, 61, 46, .08);
  border: 1px solid rgba(15, 61, 46, .16);
  box-shadow: none;
}

.public-filter-reset:hover,
.public-filter-reset:focus {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-post-card {
  transition:
    transform var(--brand-motion-base, 260ms) var(--brand-ease, cubic-bezier(.22, 1, .36, 1)),
    box-shadow var(--brand-motion-base, 260ms) var(--brand-ease, cubic-bezier(.22, 1, .36, 1));
}

.public-post-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--brand-shadow-strong) !important;
}

.public-post-card h2 a {
  color: var(--brand-ink);
}

.public-post-card h2 a:hover,
.public-post-card h2 a:focus {
  color: var(--brand-green);
}

.public-post-image {
  display: block;
  overflow: hidden;
  background: var(--brand-bg);
}

.public-post-image img,
.public-related-card .card-img-top {
  display: block;
  width: 100%;
  height: 14.5rem;
  object-fit: cover;
  transition: transform .25s ease;
}

.public-post-card:hover .public-post-image img {
  transform: scale(1.04);
}

.public-read-more {
  font-weight: 800;
}

.public-empty-state {
  padding: 3rem 1rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-empty-state i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.5rem;
  height: 3.5rem;
  margin-bottom: 1rem;
  color: var(--brand-green);
  background: var(--brand-bg);
  border-radius: var(--brand-radius);
  font-size: 1.4rem;
}

.public-back-link {
  display: inline-flex !important;
  align-items: center;
  gap: .35rem;
  font-weight: 800;
}

.public-article-header {
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--brand-border);
}

.public-article-header h1 {
  font-weight: 800;
}

.public-site .public-article-header h1 {
  max-width: 14ch;
  margin: .45rem 0 .95rem;
  color: var(--brand-ink);
  font-size: clamp(2.3rem, 4.6vw, 3.55rem);
  line-height: 1.08;
  letter-spacing: 0;
  text-wrap: balance;
}

.public-site .public-article-byline {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-top: .65rem;
  color: var(--brand-muted);
}

.public-site .public-article-byline img,
.public-site .public-article-byline-initial {
  width: 2.65rem;
  height: 2.65rem;
  border-radius: 50%;
  flex: 0 0 2.65rem;
}

.public-site .public-article-byline img {
  object-fit: cover;
  background: rgba(13, 91, 66, .08);
}

.public-site .public-article-byline-initial {
  display: inline-grid;
  place-items: center;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .1);
  font-weight: 900;
}

.public-site .public-article-byline div {
  display: grid;
  gap: .16rem;
  min-width: 0;
}

.public-site .public-article-author {
  color: var(--brand-green);
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.25;
  text-decoration: none;
}

.public-site .public-article-author:hover {
  color: var(--brand-ink);
}

.public-site .public-article-byline time {
  color: var(--brand-muted);
  font-size: .9rem;
  font-weight: 700;
}

.public-article-cover {
  width: 100%;
  max-height: 34rem;
  object-fit: cover;
}

.public-site .public-article-media {
  margin: 0 0 2rem;
}

.public-site .public-article-media img {
  display: block;
  width: 100%;
  border-radius: 8px;
  box-shadow: 0 18px 44px rgba(17, 42, 34, .12);
}

.public-site .public-article-media figcaption {
  display: block;
  margin-top: .72rem;
  padding-bottom: .72rem;
  color: var(--brand-muted);
  border-bottom: 1px solid rgba(17, 42, 34, .08);
  font-size: .82rem;
  line-height: 1.5;
}

.public-site .public-article-media figcaption strong {
  display: block;
  margin-top: .12rem;
  color: var(--brand-ink);
  font-weight: 850;
}

.public-article-content {
  padding: 1.5rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-related-card .card-img-top {
  height: 11.25rem;
}

.public-schedule-page {
  background:
    radial-gradient(circle at 0 0, rgba(201, 155, 66, .12), transparent 28%),
    linear-gradient(180deg, rgba(15, 61, 46, .04), transparent 24%);
}

.public-schedule-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  justify-content: center;
  margin-bottom: 1.5rem;
}

.public-schedule-tabs button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.8rem;
  padding: .7rem 1rem;
  color: var(--brand-green);
  font-weight: 800;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: 0 .6rem 1.4rem rgba(15, 61, 46, .07);
}

.public-schedule-tabs button.active {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-schedule-panel {
  padding: clamp(1rem, 3vw, 1.5rem);
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-schedule-panel+.public-schedule-panel {
  margin-top: 1.5rem;
}

.public-schedule-panel-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.public-schedule-panel-header h2 {
  margin-bottom: .25rem;
  color: var(--brand-ink);
  font-weight: 900;
}

.public-schedule-panel-header p {
  max-width: 52rem;
  margin-bottom: 0;
  color: var(--brand-muted);
}

.schedule-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
}

.public-schedule-table,
.public-class-detail-table {
  min-width: 40rem;
}

.public-schedule-table thead th,
.public-class-grid thead th,
.public-class-detail-table thead th {
  color: var(--brand-green);
  background: var(--brand-bg);
}

.public-schedule-table th,
.public-schedule-table td,
.public-class-detail-table th,
.public-class-detail-table td {
  padding: .9rem 1rem;
}

.public-schedule-empty {
  padding: 1.5rem;
  color: var(--brand-muted);
  text-align: center;
}

.public-class-schedule-stack {
  display: grid;
  gap: 1.25rem;
}

.public-class-section {
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  background: #fff;
  overflow: hidden;
}

.public-class-section-header {
  padding: 1rem 1.25rem .75rem;
  border-bottom: 1px solid var(--brand-border);
}

.public-class-section-header h3 {
  margin-bottom: 0;
  color: var(--brand-ink);
  font-weight: 900;
}

.public-class-picker {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  padding: 1rem 1.25rem;
  background: #fbfcfa;
  border-bottom: 1px solid var(--brand-border);
}

.public-class-picker button {
  min-height: 2.35rem;
  padding: .45rem .85rem;
  color: var(--brand-green);
  font-weight: 800;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: 8px;
}

.public-class-picker button.active {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-class-panels {
  padding: 1.25rem;
}

.public-class-panel {
  display: grid;
  gap: 1rem;
}

.public-class-day {
  overflow: hidden;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  background: #fff;
}

.public-class-day h3,
.public-class-day h4 {
  margin: 0;
  padding: .85rem 1rem;
  color: #fff;
  background: linear-gradient(135deg, var(--brand-green), var(--brand-green-2));
  font-weight: 900;
  font-size: 1rem;
}

.public-class-groups {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}

.public-class-group {
  min-width: 0;
}

.public-class-group+.public-class-group {
  border-left: 1px solid var(--brand-border);
}

.public-class-group-title {
  padding: .65rem 1rem;
  color: var(--brand-ink);
  background: rgba(201, 155, 66, .18);
  font-weight: 900;
  text-align: center;
}

.public-class-grid {
  min-width: 36rem;
  table-layout: fixed;
}

.public-class-grid th,
.public-class-grid td {
  min-width: 4rem;
  padding: .55rem .45rem;
  text-align: center;
  vertical-align: middle;
}

.public-class-grid tbody th {
  color: var(--brand-green);
  background: #fbfcfa;
  font-weight: 900;
}

.public-class-grid td {
  color: var(--brand-ink);
  font-weight: 800;
}

.public-code-card {
  height: 100%;
  padding: 1.25rem;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  background: var(--brand-bg);
}

.public-code-card h3 {
  margin-bottom: 1rem;
  font-weight: 900;
}

.public-code-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .5rem;
}

.public-code-list-teachers {
  grid-template-columns: 1fr;
  max-height: 32rem;
  overflow: auto;
  padding-right: .25rem;
}

.public-code-list span {
  display: flex;
  gap: .55rem;
  align-items: flex-start;
  padding: .55rem .65rem;
  color: var(--brand-ink);
  background: #fff;
  border: 1px solid rgba(15, 61, 46, .08);
  border-radius: 8px;
}

.public-code-list strong {
  flex: 0 0 auto;
  min-width: 1.8rem;
  color: var(--brand-green);
}

@media (max-width: 991.98px) {
  .public-hero-quote {
    left: 1rem;
  }

  .public-stat-grid {
    grid-template-columns: 1fr 1fr;
  }

  .public-class-groups {
    grid-template-columns: 1fr;
  }

  .public-class-group+.public-class-group {
    border-top: 1px solid var(--brand-border);
    border-left: 0;
  }

  .public-schedule-panel-header {
    align-items: stretch;
    flex-direction: column;
  }

  .public-filter-actions {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 575.98px) {
  .public-section {
    padding-block: 3rem;
  }

  .public-hero {
    padding-block: 3rem;
  }

  .public-hero-mini-stats,
  .public-hero-actions,
  .registration-total-card {
    align-items: stretch;
    flex-direction: column;
  }

  .public-stat-grid {
    grid-template-columns: 1fr;
  }

  .public-article-content {
    padding: 1rem;
  }

  .public-schedule-tabs {
    display: grid;
    grid-template-columns: 1fr;
  }

  .public-code-list {
    grid-template-columns: 1fr;
  }

  .public-filter-actions {
    grid-template-columns: 1fr;
  }
}

/*--------------------------------------------------------------
# Phase 5 - Public Visual Upgrade
--------------------------------------------------------------*/
:root {
  --brand-ease: cubic-bezier(.22, 1, .36, 1);
  --brand-ease-reveal: cubic-bezier(.16, 1, .3, 1);
  --brand-motion-fast: 150ms;
  --brand-motion-base: 260ms;
  --brand-motion-reveal: 1040ms;
  --brand-motion-slow: 920ms;
  --brand-motion-distance: 12px;
  --brand-shadow-hover: 0 18px 44px rgba(19, 43, 32, .12);
  --brand-focus-ring: 0 0 0 .22rem rgba(201, 155, 66, .28);
}

body.public-site {
  color-scheme: light;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.public-site ::selection {
  color: #10231d;
  background: rgba(201, 155, 66, .34);
}

.public-site .btn,
.public-site .card,
.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .public-nav-download,
.public-site .public-contact-panel,
.public-site .registration-intro-card,
.public-site .registration-notice-card,
.public-site .registration-document,
.public-site .registration-masyaikh-card,
.public-site .public-code-card,
.public-site .public-class-day,
.public-site .floating-social-toggle,
.public-site .floating-social-link {
  transition:
    transform var(--brand-motion-base) var(--brand-ease),
    box-shadow var(--brand-motion-base) var(--brand-ease),
    border-color var(--brand-motion-base) var(--brand-ease),
    background-color var(--brand-motion-base) var(--brand-ease),
    color var(--brand-motion-base) var(--brand-ease);
}

.public-site a:focus-visible,
.public-site button:focus-visible,
.public-site .btn:focus-visible,
.public-site .form-control:focus-visible,
.public-site .form-select:focus-visible {
  outline: 0;
  box-shadow: var(--brand-focus-ring);
}

.public-site #header.public-navbar {
  transition:
    box-shadow var(--brand-motion-base) var(--brand-ease),
    background-color var(--brand-motion-base) var(--brand-ease),
    border-color var(--brand-motion-base) var(--brand-ease);
}

.public-site.scrolled #header.public-navbar,
.public-site .scrolled #header.public-navbar {
  padding-block: .48rem;
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 14px 38px rgba(19, 43, 32, .1);
}

.public-site .public-hero {
  background:
    linear-gradient(115deg, rgba(243, 246, 241, .96), rgba(255, 255, 255, .88) 52%, rgba(231, 239, 233, .82)),
    linear-gradient(180deg, rgba(15, 61, 46, .035), transparent 42%);
}

.public-site .public-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(15, 61, 46, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 61, 46, .035) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, .62), transparent 72%);
  pointer-events: none;
}

.public-site .public-hero-image {
  transform: translateZ(0);
  transition:
    transform 420ms var(--brand-ease),
    box-shadow 420ms var(--brand-ease);
}

.public-site .public-hero-quote {
  backdrop-filter: blur(14px);
}

.public-site .public-section-heading h2,
.public-site .public-page-heading h1,
.public-site .public-hero-copy h1 {
  line-height: 1.06;
}

.public-site .public-section-heading p,
.public-site .public-page-heading p,
.public-site .public-hero-copy p {
  line-height: 1.72;
}

@media (hover: hover) {
  .public-site .btn:hover {
    transform: translateY(-2px);
  }

  .public-site .public-feature-card:hover,
  .public-site .public-stat-card:hover,
  .public-site .registration-masyaikh-card:hover,
  .public-site .public-code-card:hover,
  .public-site .card:hover {
    transform: translateY(-3px);
    box-shadow: var(--brand-shadow-hover) !important;
    border-color: rgba(15, 61, 46, .18) !important;
  }

  .public-site .public-hero-media:hover .public-hero-image {
    transform: translateY(-3px);
    box-shadow: 0 24px 58px rgba(19, 43, 32, .16);
  }

  .public-site .public-nav-download:hover,
  .public-site .floating-social-link:hover {
    transform: translateY(-2px);
  }
}

.public-site.mdq-motion-ready .mdq-reveal:not(.mdq-inview) {
  opacity: 0 !important;
  transform: translateY(var(--brand-motion-distance)) scale(.992) !important;
}

.public-site.mdq-motion-ready .mdq-reveal {
  transition:
    opacity var(--brand-motion-reveal) var(--brand-ease-reveal),
    transform var(--brand-motion-reveal) var(--brand-ease-reveal);
  will-change: opacity, transform;
}

.public-site.mdq-motion-ready .mdq-reveal.mdq-inview {
  opacity: 1 !important;
  transform: none !important;
}

.public-site.mdq-motion-ready .mdq-reveal:nth-child(2) {
  transition-delay: 60ms;
}

.public-site.mdq-motion-ready .mdq-reveal:nth-child(3) {
  transition-delay: 110ms;
}

.public-site.mdq-motion-ready .mdq-reveal:nth-child(4) {
  transition-delay: 150ms;
}

/*--------------------------------------------------------------
# Fase 3 - Visual Design System Refresh
--------------------------------------------------------------*/
:root {
  --default-font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --heading-font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --nav-font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --brand-ink: #10231d;
  --brand-muted: #5c6b63;
  --brand-soft: #edf3ee;
  --brand-bg: #f6f8f5;
  --brand-panel: #ffffff;
  --brand-panel-soft: #fbfcfa;
  --brand-green: #0d3a2c;
  --brand-green-2: #1f6048;
  --brand-gold: #bf923c;
  --brand-cool: #6d8791;
  --brand-border: rgba(16, 35, 29, .09);
  --brand-border-strong: rgba(16, 35, 29, .14);
  --brand-shadow: 0 10px 26px rgba(19, 43, 32, .055);
  --brand-shadow-strong: 0 18px 44px rgba(19, 43, 32, .1);
  --brand-shadow-hover: 0 16px 38px rgba(19, 43, 32, .095);
  --brand-radius: 8px;
  --brand-radius-sm: 6px;
  --brand-radius-lg: 10px;
  --brand-section-space: clamp(4rem, 6.5vw, 6.5rem);
  --brand-page-title: clamp(2.25rem, 4.6vw, 4.25rem);
  --brand-section-title: clamp(1.75rem, 3vw, 2.8rem);
  --brand-card-title: clamp(1.08rem, 1.35vw, 1.35rem);
  --brand-body-lg: clamp(1rem, 1.2vw, 1.12rem);
  --brand-caption: .84rem;
}

body.public-site {
  --public-navbar-offset: 4.75rem;
  padding-top: 0 !important;
  color: var(--brand-muted);
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .96), rgba(255, 255, 255, 0) 28rem),
    var(--background-color);
  font-family: var(--default-font);
  font-size: 16px;
  line-height: 1.68;
  overflow-x: hidden;
}

.public-site #content {
  overflow-x: clip;
  padding-top: var(--public-navbar-offset);
}

.public-site #content:has(> .public-hero:first-child),
.public-site #content:has(> .public-page-hero:first-child) {
  padding-top: 0;
}

.public-site #content.home-page,
.public-site #content.registration-page {
  padding-top: 0 !important;
}

.public-site #content.home-page>.public-home-hero:first-child,
.public-site #content.registration-page>.public-registration-hero:first-child {
  margin-top: 0 !important;
}

.public-site #content.registration-page>.public-registration-hero:first-child .hero-image {
  padding-top: 0 !important;
}

.public-site h1,
.public-site h2,
.public-site h3,
.public-site h4,
.public-site h5,
.public-site h6 {
  color: var(--brand-ink);
  font-family: var(--heading-font);
  font-weight: 760;
  letter-spacing: 0;
}

.public-site h1 {
  font-size: var(--brand-page-title);
  line-height: 1.02;
}

.public-site h2 {
  font-size: var(--brand-section-title);
  line-height: 1.08;
}

.public-site h3 {
  font-size: clamp(1.25rem, 2vw, 1.7rem);
  line-height: 1.18;
}

.public-site p {
  color: var(--brand-muted);
}

.public-site .lead,
.public-site .public-page-heading p,
.public-site .public-section-heading p {
  color: var(--brand-muted) !important;
  font-size: var(--brand-body-lg);
  line-height: 1.72;
}

.public-site small,
.public-site figcaption,
.public-site .small {
  font-size: var(--brand-caption);
  line-height: 1.55;
}

.public-site .public-section,
.public-site .content-space-1,
.public-site .content-space-2 {
  padding-block: var(--brand-section-space);
}

.public-site .public-section-heading,
.public-site .public-page-heading {
  max-width: 54rem;
}

.public-site .public-section-kicker {
  color: var(--brand-gold);
  font-size: .72rem;
  letter-spacing: .11em;
}

.public-site .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  padding: .82rem 1.18rem;
  border-radius: 999px;
  font-weight: 780;
  line-height: 1.1;
}

.public-site .btn-primary {
  background: var(--brand-green);
  border-color: transparent;
  box-shadow: 0 10px 22px rgba(13, 58, 44, .15);
}

.public-site .btn-primary:hover,
.public-site .btn-primary:focus {
  background: var(--brand-green-2);
  box-shadow: 0 12px 26px rgba(13, 58, 44, .2);
}

.public-site .btn-soft-secondary {
  color: var(--brand-green) !important;
  background: rgba(237, 243, 238, .92) !important;
  border-color: rgba(13, 58, 44, .1) !important;
}

.public-site .btn-soft-light {
  color: var(--brand-green) !important;
  background: rgba(255, 255, 255, .9) !important;
  border-color: rgba(255, 255, 255, .62) !important;
  box-shadow: 0 10px 22px rgba(9, 31, 24, .11);
}

.public-site .card,
.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .registration-masyaikh-card,
.public-site .registration-action-panel,
.public-site .public-schedule-panel,
.public-site .public-class-section,
.public-site .public-post-card,
.public-site .public-empty-state,
.public-site .public-article-content,
.public-site .public-map-empty {
  background: rgba(255, 255, 255, .94);
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
}

.public-site .card,
.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .registration-masyaikh-card,
.public-site .registration-action-panel,
.public-site .public-schedule-panel,
.public-site .public-class-section,
.public-site .public-post-card,
.public-site .public-empty-state,
.public-site .public-map-empty {
  box-shadow: 0 8px 24px rgba(19, 43, 32, .052);
}

.public-site .card-title,
.public-site .public-post-card h2,
.public-site .public-post-card h3 {
  font-size: var(--brand-card-title);
  line-height: 1.22;
}

.public-site .badge,
.public-site .public-section-kicker,
.public-site .dropdown-header {
  font-weight: 850;
}

.public-site .badge {
  min-height: 1.65rem;
  padding: .34rem .58rem;
  border: 1px solid rgba(16, 35, 29, .08);
  border-radius: var(--brand-radius-sm);
  letter-spacing: 0;
}

.public-site .table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--brand-ink);
  font-size: .95rem;
}

.public-site .table thead th {
  color: var(--brand-muted);
  background: rgba(246, 248, 245, .78);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.public-site .form-control,
.public-site .form-select {
  min-height: 2.9rem;
  border-radius: var(--brand-radius);
}

.public-site .card,
.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .registration-masyaikh-card,
.public-site .public-post-card {
  overflow: hidden;
}

.public-site .public-hero {
  min-height: min(760px, calc(100vh - 5rem));
  display: grid;
  align-items: center;
  background:
    linear-gradient(100deg, rgba(247, 250, 247, .96) 0%, rgba(247, 250, 247, .9) 42%, rgba(247, 250, 247, .62) 72%),
    url("../img/backgrounds/modern-hero-masjid-anjani.jpg") center right / cover no-repeat;
}

.public-site .public-hero::before {
  background:
    linear-gradient(rgba(13, 58, 44, .04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(13, 58, 44, .035) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: linear-gradient(90deg, rgba(0, 0, 0, .72), transparent 78%);
}

.public-site .public-hero-copy {
  max-width: 43rem;
  min-width: 0;
}

.public-site .public-hero-copy h1 {
  max-width: 11ch;
  margin-bottom: 1rem !important;
}

.public-site .public-hero-copy h2 {
  max-width: 25ch;
  color: var(--brand-green);
  font-size: clamp(1.25rem, 2.2vw, 2rem);
}

.public-site .public-hero-copy p {
  max-width: 42rem;
  font-size: clamp(1rem, 1.35vw, 1.15rem);
}

.public-site .public-hero-image {
  border-color: rgba(255, 255, 255, .55);
  box-shadow: 0 28px 70px rgba(17, 42, 32, .18);
}

.public-site .public-hero-image img {
  aspect-ratio: 5 / 4;
}

.public-site .public-hero-quote,
.public-site .public-hero-mini-stats span {
  background: rgba(255, 255, 255, .82);
  backdrop-filter: blur(16px);
}

.public-site .public-feature-strip {
  padding-block: clamp(2.25rem, 4vw, 3.5rem);
}

.public-site .public-feature-card,
.public-site .public-stat-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(251, 252, 250, .94));
}

.public-site .public-feature-card {
  padding: clamp(1.15rem, 2.2vw, 1.65rem);
}

.public-site .public-feature-card img {
  background:
    linear-gradient(135deg, rgba(13, 58, 44, .08), rgba(191, 146, 60, .12));
}

.public-site .public-stats-section {
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .96), rgba(246, 248, 245, .72)),
    url("../img/backgrounds/modern-section-majelis-thullab.jpg") center / cover no-repeat;
}

.public-site .public-gallery-section {
  background:
    linear-gradient(180deg, #fff, rgba(237, 243, 238, .56));
}

.public-site .homepage-gallery-strip,
.public-site .homepage-gallery-item {
  border-radius: var(--brand-radius);
}

.public-site .public-cta-band {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background:
    linear-gradient(105deg, rgba(13, 58, 44, .96), rgba(24, 80, 60, .9)),
    url("../img/backgrounds/modern-section-halaqah-kitabs.jpg") center / cover no-repeat !important;
}

.public-site .public-cta-band::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(6, 26, 19, .74), rgba(6, 26, 19, .18));
}

.public-site .public-page-hero .hero-image,
.public-site .public-registration-hero .hero-image {
  min-height: min(640px, 72vh);
  background:
    linear-gradient(90deg, rgba(9, 31, 24, .86), rgba(13, 58, 44, .5), rgba(13, 58, 44, .16)),
    url("../img/backgrounds/modern-section-haul-stage.jpg") center / cover no-repeat;
}

.public-site .public-page-hero h1,
.public-site .public-page-hero h2,
.public-site .public-page-hero h3 {
  text-wrap: balance;
}

.public-site .registration-notice-card,
.public-site .registration-document {
  background:
    linear-gradient(180deg, #fff, rgba(251, 252, 250, .96));
}

.public-site .registration-fee-section {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .95), #fff) !important;
}

.public-site .registration-contact-list a,
.public-site .registration-download-card,
.public-site .public-class-picker button,
.public-site .public-schedule-tabs button {
  border-radius: var(--brand-radius);
}

.public-site .public-schedule-page,
.public-site .public-listing-page {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .92), rgba(255, 255, 255, .98));
}

.public-site .public-filter-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(251, 252, 250, .94));
}

.public-site .public-post-image img,
.public-site .public-article-cover,
.public-site .registration-masyaikh-card img,
.public-site .masyaikh-img {
  filter: saturate(.96) contrast(1.02);
}

.public-site .public-map-section iframe {
  min-height: clamp(340px, 46vw, 500px);
}

@media (max-width: 991.98px) {
  .public-site .public-hero {
    min-height: auto;
    background:
      linear-gradient(180deg, rgba(247, 250, 247, .96), rgba(247, 250, 247, .92)),
      url("../img/backgrounds/modern-hero-masjid-anjani.jpg") center / cover no-repeat;
  }

  .public-site .public-page-hero .hero-image,
  .public-site .public-registration-hero .hero-image {
    min-height: 34rem;
  }
}

@media (max-width: 767.98px) {
  body.public-site {
    font-size: 15px;
  }

  .public-site .public-section,
  .public-site .content-space-1,
  .public-site .content-space-2 {
    padding-block: clamp(3rem, 10vw, 4.25rem);
  }

  .public-site .public-hero {
    padding-block: 3.25rem;
  }

  .public-site .public-hero>.container {
    max-width: 100%;
    padding-inline: 1rem;
  }

  .public-site .public-hero .row {
    --bs-gutter-x: 1.25rem;
  }

  .public-site .public-hero .row>* {
    max-width: 100%;
    min-width: 0;
  }

  .public-site .public-hero-copy {
    width: min(100%, 22rem);
    max-width: 22rem;
  }

  .public-site .public-hero-copy h1 {
    max-width: 12ch;
  }

  .public-site .public-hero-copy p {
    width: 100%;
    max-width: 100%;
    overflow-wrap: break-word;
  }

  .public-site .btn {
    width: 100%;
  }

  .public-site .public-hero-actions,
  .public-site .d-grid.d-sm-flex {
    gap: .6rem !important;
  }

  .public-site .public-hero-mini-stats span {
    flex: 1 1 100%;
    min-width: 0;
  }

  .public-site .public-page-hero .hero-image>.container {
    max-width: 100%;
    padding-inline: 1rem;
  }

  .public-site .public-page-hero h1 {
    max-width: calc(100vw - 2rem);
    font-size: clamp(2.05rem, 9vw, 2.45rem);
    line-height: 1.05;
    overflow-wrap: anywhere;
  }

  .public-site .public-page-hero h2,
  .public-site .public-page-hero h3 {
    max-width: calc(100vw - 2rem);
    font-size: clamp(1.15rem, 5.8vw, 1.45rem);
    line-height: 1.18;
    overflow-wrap: anywhere;
  }
}

/*--------------------------------------------------------------
# Fase 4 - Homepage Redesign
--------------------------------------------------------------*/
.public-site .public-home-hero {
  position: relative;
  isolation: isolate;
  min-height: auto;
  padding-block: clamp(2.75rem, 5vw, 4.5rem);
  background:
    linear-gradient(90deg, rgba(246, 248, 245, .98) 0%, rgba(246, 248, 245, .91) 41%, rgba(246, 248, 245, .56) 72%),
    linear-gradient(180deg, rgba(13, 58, 44, .07), transparent 38%),
    url("../img/backgrounds/modern-hero-masjid-anjani.jpg") center right / cover no-repeat;
}

.public-site .public-home-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 34%;
  z-index: -1;
  background: linear-gradient(180deg, rgba(246, 248, 245, 0), var(--brand-bg));
  pointer-events: none;
}

.public-site .public-home-hero-container {
  position: relative;
  z-index: 1;
}

.public-site .public-home-hero .row {
  min-height: 0;
}

.public-site .public-home-hero .public-hero-copy {
  padding-block: clamp(1rem, 4vw, 2.5rem);
}

.public-site .public-home-hero .public-section-kicker {
  display: inline-flex;
  align-items: center;
  gap: .72rem;
  width: fit-content;
  margin-bottom: 1.15rem;
  padding: 0;
  color: var(--brand-gold);
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.public-site .public-home-hero .public-section-kicker::before {
  display: inline-block;
  width: 2rem;
  height: 1px;
  background: currentColor;
}

.public-site .public-home-hero .public-section-kicker::after {
  display: none;
}

.public-site .public-home-hero .public-hero-copy h1 {
  max-width: 12ch;
  color: var(--brand-ink) !important;
  text-wrap: balance;
}

.public-site .public-home-hero .public-hero-copy h2 {
  margin-bottom: 1.1rem;
}

.public-site .public-home-hero .public-hero-media {
  max-width: 42.25rem;
  margin-inline-start: auto;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.public-site .public-home-hero .public-hero-image {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .66);
  border-radius: 8px;
  box-shadow: 0 26px 72px rgba(17, 42, 32, .14);
}

.public-site .public-home-hero .public-hero-image img {
  aspect-ratio: 1 / 1;
  min-height: 0;
  object-fit: cover;
  object-position: center bottom;
}

.public-site .public-home-hero .public-hero-quote {
  top: clamp(2rem, 5vw, 2.65rem);
  right: auto;
  bottom: auto;
  left: clamp(-2.5rem, -3vw, -1.15rem);
  width: auto;
  max-width: min(28rem, calc(100% - 1rem));
  padding: .72rem 1.2rem .72rem .82rem;
  border: 1px solid rgba(255, 255, 255, .68);
  border-radius: 999px;
  background: rgba(255, 255, 255, .9);
  box-shadow: 0 18px 44px rgba(17, 42, 32, .16);
}

.public-site .public-home-hero .public-hero-quote .fs-5 {
  font-size: .9rem !important;
  line-height: 1.25;
}

.public-site .public-home-hero .public-hero-quote .fs-6 {
  margin-top: .15rem;
  color: var(--brand-muted);
  font-size: .82rem !important;
  line-height: 1.35;
}

.public-site .public-home-hero .public-hero-mini-stats {
  max-width: 35rem;
}

.public-site .public-home-hero .public-hero-mini-stats span {
  border: 1px solid rgba(13, 58, 44, .12);
}

.public-site .public-activity-feed-section {
  position: relative;
  overflow: hidden;
  padding-block: clamp(4rem, 7vw, 6rem);
  background:
    linear-gradient(180deg, var(--brand-bg), #fff 62%);
}

.public-site .public-activity-feed-section .public-section-heading {
  max-width: 42rem;
  margin-inline: auto;
  text-align: center;
}

.public-site .public-activity-feed-section .public-section-kicker {
  justify-content: center;
}

.public-site .public-activity-layout {
  position: relative;
  min-width: 0;
  width: min(100vw, 118rem);
  max-width: none;
  margin-inline: 50%;
  transform: translateX(-50%);
  padding: 0;
  overflow: visible;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.public-site .activity-feed-swiper-main,
.public-site .activity-feed-swiper-thumbs {
  min-width: 0;
}

.public-site .activity-feed-swiper-main {
  overflow: visible;
  margin-bottom: 0 !important;
  padding: .15rem 0 2.35rem;
  border-radius: 0;
}

.public-site .activity-feed-swiper-main .swiper-wrapper {
  align-items: stretch;
}

.public-site .activity-feed-swiper-main .swiper-slide {
  height: auto;
  opacity: .34;
  filter: brightness(.68) saturate(.88);
  transition:
    opacity 420ms var(--brand-ease),
    transform 420ms var(--brand-ease),
    filter 420ms var(--brand-ease);
}

.public-site .activity-feed-swiper-main .swiper-slide-prev,
.public-site .activity-feed-swiper-main .swiper-slide-next {
  z-index: 2;
  opacity: .78;
  filter: brightness(.74) saturate(.94);
}

.public-site .activity-feed-swiper-main .swiper-slide-active {
  z-index: 3;
  opacity: 1;
  filter: none;
}

.public-site .activity-feed-main {
  height: 100%;
  min-height: 0;
  overflow: hidden;
  text-decoration: none;
  background: var(--brand-ink);
  border: 1px solid rgba(16, 35, 29, .1);
  border-radius: 8px;
  box-shadow: 0 26px 70px rgba(17, 42, 32, .16);
}

.public-site .activity-feed-main::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(7, 29, 21, 0) 32%, rgba(4, 13, 11, .78) 100%);
  pointer-events: none;
}

.public-site .activity-feed-main img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 7.5;
  object-fit: cover;
  border-radius: 8px;
  transition: transform 420ms var(--brand-ease), filter 420ms var(--brand-ease);
}

.public-site .activity-feed-caption {
  position: absolute;
  right: clamp(1rem, 3vw, 1.65rem);
  bottom: clamp(1rem, 3vw, 1.45rem);
  left: clamp(1rem, 3vw, 1.65rem);
  z-index: 2;
  padding: 0;
  background: transparent;
}

.public-site .activity-feed-caption h3 {
  margin-bottom: .35rem;
  color: #fff;
  font-size: clamp(1.35rem, 2.6vw, 2rem);
  line-height: 1.16;
  text-shadow: 0 10px 28px rgba(0, 0, 0, .22);
}

.public-site .activity-feed-caption p {
  max-width: 36rem;
  margin-bottom: 0;
  color: rgba(255, 255, 255, .76);
  font-size: clamp(.9rem, 1.3vw, 1.05rem);
  line-height: 1.48;
}

.public-site .activity-carousel-nav {
  position: absolute;
  top: 45%;
  z-index: 4;
  display: inline-grid;
  width: 3rem;
  height: 3rem;
  place-items: center;
  color: var(--brand-green);
  background: rgba(255, 255, 255, .9);
  border: 1px solid rgba(16, 35, 29, .12);
  border-radius: 50%;
  box-shadow: 0 14px 34px rgba(17, 42, 32, .16);
  backdrop-filter: blur(8px);
  transform: translateY(-50%);
  transition:
    color 180ms var(--brand-ease),
    background-color 180ms var(--brand-ease),
    transform 180ms var(--brand-ease);
}

.public-site .activity-carousel-prev {
  left: clamp(.75rem, 7vw, 6rem);
}

.public-site .activity-carousel-next {
  right: clamp(.75rem, 7vw, 6rem);
}

.public-site .activity-carousel-nav:hover,
.public-site .activity-carousel-nav:focus {
  color: #fff;
  background: rgba(13, 58, 44, .86);
  transform: translateY(-50%) scale(1.04);
}

.public-site .activity-carousel-pagination {
  position: absolute;
  bottom: .45rem !important;
  left: 50%;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .34rem;
  width: auto;
  min-height: 1.65rem;
  padding: .28rem .45rem;
  background: rgba(255, 255, 255, .78);
  border: 1px solid rgba(16, 35, 29, .1);
  border-radius: 999px;
  box-shadow: 0 16px 40px rgba(17, 42, 32, .12);
  backdrop-filter: blur(12px);
  transform: translateX(-50%);
  pointer-events: none;
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: .6rem;
  height: .6rem;
  margin: 0 !important;
  overflow: hidden;
  background: rgba(13, 58, 44, .22);
  border: 1px solid rgba(13, 58, 44, .14);
  border-radius: 999px;
  opacity: 1;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .48);
  pointer-events: auto;
  transition:
    width 280ms var(--brand-ease),
    height 280ms var(--brand-ease),
    background-color 220ms var(--brand-ease),
    border-color 220ms var(--brand-ease),
    box-shadow 220ms var(--brand-ease),
    transform 220ms var(--brand-ease);
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet::before {
  content: "";
  position: absolute;
  inset: 2px;
  background: rgba(255, 255, 255, .5);
  border-radius: inherit;
  opacity: 0;
  transform: scale(.5);
  transition: opacity 220ms var(--brand-ease), transform 220ms var(--brand-ease);
}

.public-site .activity-carousel-dot-index {
  position: relative;
  z-index: 2;
  width: 0;
  overflow: hidden;
  color: #fff;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1;
  opacity: 0;
  transform: translateY(1px);
  transition: width 240ms var(--brand-ease), opacity 180ms var(--brand-ease);
}

.public-site .activity-carousel-dot-glow {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(203, 160, 71, .95), rgba(13, 58, 44, .96));
  opacity: 0;
  transform: translateX(-100%);
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet-active {
  width: 2.05rem;
  height: .95rem;
  background: var(--brand-green);
  border-color: rgba(13, 58, 44, .36);
  box-shadow: 0 8px 18px rgba(13, 58, 44, .2);
  transform: translateY(-1px);
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet-active .activity-carousel-dot-index {
  width: .9rem;
  opacity: 1;
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet-active .activity-carousel-dot-glow {
  opacity: 1;
  animation: activityDotProgress 5200ms linear both;
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet:hover,
.public-site .activity-carousel-pagination .swiper-pagination-bullet:focus-visible {
  background: rgba(13, 58, 44, .46);
  border-color: rgba(13, 58, 44, .36);
  transform: translateY(-1px) scale(1.08);
}

.public-site .activity-carousel-pagination .swiper-pagination-bullet:hover::before,
.public-site .activity-carousel-pagination .swiper-pagination-bullet:focus-visible::before {
  opacity: 1;
  transform: scale(1);
}

@keyframes activityDotProgress {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

.public-site .activity-feed-badge {
  top: .8rem;
  left: .8rem;
  z-index: 2;
  right: auto;
  color: var(--brand-green);
  background: rgba(255, 255, 255, .88);
  border: 1px solid rgba(255, 255, 255, .72);
  backdrop-filter: blur(12px);
}

.public-site .activity-feed-swiper-thumbs {
  height: auto;
}

.public-site .activity-feed-swiper-thumbs .swiper-wrapper {
  align-items: stretch;
}

.public-site .activity-feed-swiper-thumbs .swiper-slide {
  height: auto;
  padding: 1.15rem;
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(16, 35, 29, .1);
  border-radius: 8px;
  box-shadow: var(--brand-shadow);
}

.public-site .activity-feed-swiper-thumbs .swiper-slide strong {
  color: var(--brand-ink);
  font-size: 1.02rem;
}

.public-site .public-feature-strip {
  padding-block: clamp(2.5rem, 5vw, 4rem);
  background: #fff;
}

.public-site .public-feature-grid {
  row-gap: 1rem;
}

.public-site .public-feature-card {
  height: 100%;
  text-align: left !important;
}

.public-site .public-feature-card img {
  width: 4.35rem !important;
  height: 4.35rem;
  padding: .85rem;
  object-fit: contain;
  border-radius: 999px;
}

.public-site .public-feature-card p {
  margin-bottom: 0;
}

.public-site .public-about-section {
  background:
    linear-gradient(180deg, #fff, rgba(237, 243, 238, .5));
}

.public-site .public-about-media {
  padding: clamp(1rem, 3vw, 1.5rem);
}

.public-site .public-about-media>img {
  width: min(78%, 29rem) !important;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 8px 8px 28px 8px !important;
  box-shadow: var(--brand-shadow-strong);
}

.public-site .public-about-media .position-absolute img {
  width: min(15rem, 44vw) !important;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border: 6px solid #fff;
  border-radius: 8px !important;
}

.public-site .public-about-media>img {
  position: relative;
  z-index: 1;
}

.public-site .public-about-media .public-about-overlay {
  z-index: 2;
}

.public-site .public-about-media .public-about-overlay img {
  width: min(18rem, 42vw) !important;
  height: auto;
  max-height: none;
  aspect-ratio: auto;
  object-fit: contain;
  background: transparent;
  border: 0;
}

.public-site .public-about-media .public-about-dots {
  width: 10rem !important;
  z-index: 0 !important;
  pointer-events: none;
}

.public-site .public-about-media .public-about-dots img {
  width: 100% !important;
  aspect-ratio: auto;
  object-fit: contain;
  border: 0;
  border-radius: 0 !important;
  box-shadow: none;
}

.public-site .public-about-copy {
  max-width: 42rem;
}

.public-site .public-about-copy h3 {
  font-size: clamp(1.55rem, 2.4vw, 2.25rem);
}

.public-site .public-about-copy .list-checked-item {
  margin-bottom: .75rem;
}

.public-site .public-founder-section {
  position: relative;
  isolation: isolate;
  color: rgba(255, 255, 255, .78);
  background:
    linear-gradient(110deg, rgba(7, 29, 21, .96), rgba(13, 58, 44, .88)),
    url("../img/backgrounds/modern-section-thullabat-pengajian.jpg") center / cover no-repeat;
}

.public-site .public-founder-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(7, 29, 21, .2), rgba(7, 29, 21, .76));
}

.public-site .public-founder-section img {
  border-radius: 8px;
  box-shadow: 0 28px 70px rgba(0, 0, 0, .32);
}

.public-site .public-founder-section .blockquote {
  color: #fff;
  font-size: clamp(1.28rem, 2.2vw, 2rem);
  line-height: 1.45;
}

.public-site .public-founder-section .blockquote-footer {
  color: rgba(255, 255, 255, .92);
}

.public-site .public-founder-section .blockquote-footer-source {
  color: rgba(255, 255, 255, .66);
}

.public-site .public-vision-section {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .95), #fff);
}

.public-site .public-vision-section .position-relative {
  margin-bottom: 0 !important;
}

.public-site .public-vision-section figure {
  opacity: .18;
}

.public-site .public-vision-card {
  height: 100%;
  padding: clamp(1.35rem, 3vw, 2rem);
  background: rgba(255, 255, 255, .92);
  border: 1px solid rgba(16, 35, 29, .1);
  border-radius: 8px;
  box-shadow: var(--brand-shadow);
}

.public-site .public-mission-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(246, 248, 245, .96));
}

.public-site .public-vision-card h2 {
  margin-bottom: 1rem;
}

.public-site .public-vision-card .list-checked-item {
  margin-bottom: .7rem;
}

.public-site .public-amid-section {
  background:
    linear-gradient(100deg, #fff 0%, rgba(237, 243, 238, .72) 100%);
}

.public-site .public-amid-media img {
  width: 100%;
  min-height: 16rem;
  object-fit: cover;
  box-shadow: var(--brand-shadow);
}

.public-site .public-amid-media .col-3 img {
  min-height: 22rem;
}

.public-site .public-amid-copy {
  padding: clamp(1.35rem, 3vw, 2.2rem);
  background: rgba(255, 255, 255, .86);
  border: 1px solid rgba(16, 35, 29, .1);
  border-radius: 8px;
  box-shadow: var(--brand-shadow);
}

.public-site .public-amid-copy h3 {
  font-size: clamp(1.45rem, 2.6vw, 2.25rem);
}

.public-site .public-stats-section {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  color: rgba(255, 255, 255, .76);
  background:
    linear-gradient(100deg, rgba(7, 29, 21, .93), rgba(13, 58, 44, .72)),
    url("../img/backgrounds/modern-section-majelis-thullab.jpg") center / cover no-repeat;
}

.public-site .public-stats-section .public-section-kicker {
  color: rgba(235, 198, 126, .94);
}

.public-site .public-stats-section h2,
.public-site .public-stats-section h4 {
  color: #fff;
}

.public-site .public-stats-section .public-stat-card h4 sub,
.public-site .public-stats-section .public-stat-card h4 i,
.public-site .public-stats-section .public-stat-card h4 .h3,
.public-site .public-stats-section .public-stat-card h4 .text-primary {
  color: inherit !important;
}

.public-site .public-stats-section p {
  color: rgba(255, 255, 255, .72);
}

.public-site .public-stats-section .public-section-heading p {
  color: #fff !important;
}

.public-site .public-stats-section .public-stat-card {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .16);
  box-shadow: 0 16px 38px rgba(0, 0, 0, .16);
  backdrop-filter: blur(12px);
}

.public-site .public-masyayikh-section {
  background:
    linear-gradient(180deg, #fff, rgba(246, 248, 245, .92));
}

.public-site .public-masyayikh-section .swiper {
  overflow: hidden;
  padding: 1rem 1.25rem 3.25rem;
}

.public-site .public-masyayikh-section .swiper-slide {
  height: auto;
  padding-block: .25rem .7rem;
}

.public-site .public-masyayikh-section .swiper-wrapper {
  padding-bottom: 1.15rem;
}

.public-site .public-masyayikh-section .masyaikh-item {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100%;
  min-height: 0;
  max-width: 18.5rem;
  margin-inline: auto;
  padding: .62rem .62rem 1rem;
  text-align: left;
  background: rgba(255, 255, 255, .96);
  border: 1px solid rgba(16, 35, 29, .08);
  border-radius: 24px;
  box-shadow: 0 14px 34px rgba(19, 43, 32, .09);
  overflow: hidden;
}

.public-site .public-masyayikh-section .swiper-pagination {
  position: relative;
  inset: auto;
  margin-top: 1rem;
}

.public-site .public-masyayikh-section .masyaikh-img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 4.75;
  object-fit: cover;
  object-position: top center;
  border: 0;
  border-radius: 19px;
  margin-bottom: .9rem;
  background: rgba(237, 243, 238, .9);
}

.public-site .public-masyayikh-section .masyaikh-item h3 {
  display: block;
  margin: 0 .8rem .3rem;
  padding: 0;
  color: var(--brand-ink);
  border: 0;
  font-size: clamp(.94rem, 1.05vw, 1.04rem);
  font-weight: 800;
  line-height: 1.28;
}

.public-site .public-masyayikh-section .masyaikh-item h4 {
  margin: 0 .8rem;
  color: var(--brand-muted);
  font-size: .88rem;
  font-weight: 520;
  line-height: 1.55;
}

.public-site .public-gallery-section {
  padding-block: clamp(4rem, 8vw, 7rem);
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .92), #fff 72%);
}

.public-site .homepage-gallery-strip {
  width: 100% !important;
  height: clamp(150px, 13vw, 220px) !important;
  overflow: hidden !important;
}

.public-site .homepage-gallery-track {
  display: flex !important;
  flex-flow: row nowrap !important;
  align-items: stretch !important;
  width: max-content !important;
  max-width: none !important;
  height: 100% !important;
  gap: 10px !important;
  will-change: transform;
}

.public-site .homepage-gallery-group {
  display: flex !important;
  flex: 0 0 auto !important;
  flex-flow: row nowrap !important;
  align-items: stretch !important;
  height: 100% !important;
  gap: 10px !important;
}

.public-site .homepage-gallery-item {
  display: block !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: none !important;
  height: 100% !important;
  margin: 0 !important;
  overflow: hidden !important;
  background: #e8efea !important;
  border: 1px solid rgba(16, 35, 29, .08);
  box-shadow: var(--brand-shadow);
}

.public-site .homepage-gallery-link {
  display: block !important;
  height: 100% !important;
  cursor: zoom-in !important;
}

.public-site .homepage-gallery-img {
  display: block !important;
  width: auto !important;
  max-width: none !important;
  height: 100% !important;
  max-height: 220px !important;
  object-fit: contain !important;
  transition: transform 300ms var(--brand-ease), filter 300ms var(--brand-ease) !important;
}

.public-site .homepage-gallery-img.gallery-orientation-landscape,
.public-site .homepage-gallery-img.gallery-orientation-square {
  object-fit: cover !important;
}

.public-site .homepage-gallery-img.gallery-orientation-portrait {
  object-fit: contain !important;
}

.public-site .homepage-gallery-track-right {
  animation: homepage-gallery-to-right var(--motion-marquee, 42s) linear infinite !important;
}

.public-site .homepage-gallery-track-left {
  animation: homepage-gallery-to-left var(--motion-marquee, 42s) linear infinite !important;
}

.public-site .public-cta-band {
  min-height: 24rem;
  display: grid;
  align-items: center;
}

.public-site .public-cta-band h2 {
  color: #fff;
  font-size: clamp(2rem, 4vw, 3.6rem);
}

.public-site .public-cta-band p {
  color: rgba(255, 255, 255, .78);
}

.public-site .public-contact-section {
  background:
    linear-gradient(180deg, #fff, rgba(237, 243, 238, .56));
}

.public-site .public-contact-panel {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  padding: clamp(1rem, 3vw, 1.5rem);
}

.public-site .public-contact-panel .info-item {
  min-width: 0;
  height: 100%;
  padding: 1.2rem;
  background: rgba(246, 248, 245, .74);
  border: 1px solid rgba(16, 35, 29, .08);
  border-radius: 8px;
}

.public-site .public-contact-panel .info-item i {
  width: 2.7rem;
  height: 2.7rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--brand-green);
  background: rgba(13, 58, 44, .08);
  border-radius: 999px;
}

.public-site .public-contact-panel iframe,
.public-site .public-contact-panel .public-map-empty {
  grid-column: 1 / -1;
  overflow: hidden;
  border-radius: 8px;
}

@media (hover: hover) {

  .public-site .activity-feed-main:hover img,
  .public-site .activity-feed-main:focus img,
  .public-site .homepage-gallery-link:hover .homepage-gallery-img,
  .public-site .homepage-gallery-link:focus .homepage-gallery-img {
    transform: scale(1.025);
    filter: brightness(.96) saturate(.98);
  }

  .public-site .homepage-gallery-strip:hover .homepage-gallery-track,
  .public-site .homepage-gallery-strip:focus-within .homepage-gallery-track {
    animation-play-state: paused !important;
  }
}

@media (max-width: 991.98px) {
  .public-site .public-home-hero {
    min-height: auto;
    padding-block: clamp(3.75rem, 10vw, 5.5rem);
    background:
      linear-gradient(180deg, rgba(246, 248, 245, .97), rgba(246, 248, 245, .9)),
      url("../img/backgrounds/modern-hero-masjid-anjani.jpg") center / cover no-repeat;
  }

  .public-site .public-home-hero .row {
    min-height: 0;
  }

  .public-site .public-home-hero .public-hero-media {
    margin-inline: auto;
  }

  .public-site .public-activity-layout {
    width: auto;
    max-width: 100%;
    overflow: hidden;
    margin-inline: calc(var(--bs-gutter-x) * -.5);
    transform: none;
    padding-inline: calc(var(--bs-gutter-x) * .5);
    padding-block: .35rem 0;
  }

  .public-site .activity-feed-main {
    min-height: 0;
  }

  .public-site .activity-feed-main img {
    aspect-ratio: 16 / 9.2;
  }

  .public-site .activity-carousel-prev {
    left: 1rem;
  }

  .public-site .activity-carousel-next {
    right: 1rem;
  }

  .public-site .public-contact-panel {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 767.98px) {
  .public-site .public-home-hero {
    max-width: 100vw;
    overflow: hidden;
  }

  .public-site .public-home-hero>.container {
    width: 100%;
    max-width: 100%;
    padding-inline: 1rem !important;
  }

  .public-site .public-home-hero .public-hero-copy {
    width: 100%;
    max-width: min(100%, 21rem);
  }

  .public-site .public-home-hero .public-hero-copy h1 {
    max-width: 12ch;
    font-size: clamp(2.35rem, 13vw, 3.25rem);
  }

  .public-site .public-home-hero .public-hero-copy p {
    max-width: 21rem;
    overflow-wrap: break-word;
  }

  .public-site .public-home-hero .row {
    --bs-gutter-x: 0;
    margin-inline: 0;
  }

  .public-site .public-home-hero .row>* {
    width: 100%;
    max-width: 100%;
    padding-inline: 0;
  }

  .public-site .public-home-hero .d-grid {
    width: 100%;
    max-width: min(100%, 21rem);
  }

  .public-site .public-home-hero .btn {
    max-width: 100%;
    white-space: normal;
  }

  .public-site .public-home-hero .public-hero-image img {
    min-height: 20rem;
  }

  .public-site .public-home-hero .public-hero-quote {
    position: relative !important;
    left: auto;
    right: auto;
    bottom: auto;
    max-width: none;
    margin-top: .85rem;
  }

  .public-site .activity-feed-swiper-thumbs .swiper-slide {
    padding: 1rem;
  }

  .public-site .public-activity-feed-section {
    padding-block: 3.25rem;
  }

  .public-site .public-activity-feed-section .row {
    margin-bottom: 2rem !important;
  }

  .public-site .activity-feed-swiper-main {
    padding-bottom: 2rem;
  }

  .public-site .activity-feed-main img {
    aspect-ratio: 4 / 3.35;
  }

  .public-site .activity-feed-caption {
    right: .9rem;
    bottom: .9rem;
    left: .9rem;
  }

  .public-site .activity-feed-caption p {
    display: none;
  }

  .public-site .activity-carousel-nav {
    width: 2.35rem;
    height: 2.35rem;
    top: 46%;
  }

  .public-site .public-about-media {
    padding: 0;
  }

  .public-site .public-about-media>img {
    width: 100% !important;
    aspect-ratio: 4 / 4.7;
  }

  .public-site .public-about-media .position-absolute {
    position: relative !important;
    inset: auto !important;
    margin: .85rem 0 0 !important;
  }

  .public-site .public-about-media .position-absolute img {
    width: 100% !important;
    max-height: 12rem;
  }

  .public-site .public-about-media .public-about-overlay {
    position: absolute !important;
    inset: auto 1rem -2rem auto !important;
    margin: 0 !important;
  }

  .public-site .public-about-media .public-about-overlay img {
    width: min(9.5rem, 38vw) !important;
    max-height: none;
  }

  .public-site .public-about-media .public-about-dots {
    position: absolute !important;
    inset: auto auto -1.85rem .25rem !important;
    width: 7rem !important;
    margin: 0 !important;
  }

  .public-site .public-about-media .public-about-dots img {
    width: 100% !important;
    max-height: none;
  }

  .public-site .public-founder-section .blockquote {
    font-size: 1.18rem;
  }

  .public-site .public-amid-media {
    margin-inline: 0 !important;
  }

  .public-site .public-amid-media img,
  .public-site .public-amid-media .col-3 img {
    min-height: 11rem;
  }

  .public-site .homepage-gallery-strip {
    height: 146px !important;
  }

  .public-site .homepage-gallery-img {
    max-height: 146px !important;
  }

  .public-site .public-cta-band {
    min-height: 20rem;
  }
}

/*--------------------------------------------------------------
# Fase 5 - Pendaftaran Redesign
--------------------------------------------------------------*/
.public-site .registration-page {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .96), rgba(255, 255, 255, 0) 32rem),
    #fff;
}

.public-site .public-registration-hero .hero-image {
  min-height: 0;
  padding-top: clamp(4rem, 7vw, 6rem);
  background:
    linear-gradient(90deg, rgba(7, 29, 21, .9), rgba(13, 58, 44, .62) 52%, rgba(13, 58, 44, .14)),
    var(--registration-hero-image, url("../img/backgrounds/modern-section-haul-stage.jpg")) center / cover no-repeat;
}

.public-site .public-registration-hero .hero-image>.container {
  min-height: clamp(31rem, 48vw, 38rem) !important;
  padding-block: clamp(3.5rem, 7vw, 5rem) !important;
}

.public-site .registration-hero-card {
  max-width: 56rem;
  padding: clamp(1.25rem, 3vw, 2rem);
  background: linear-gradient(135deg, rgba(7, 29, 21, .68), rgba(13, 58, 44, .34));
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 8px;
  box-shadow: 0 28px 72px rgba(0, 0, 0, .22);
  backdrop-filter: blur(10px);
}

.public-site .registration-hero-card .public-section-kicker {
  color: rgba(255, 226, 164, .96);
}

.public-site .registration-hero-card h1 {
  max-width: 11ch;
  margin-bottom: 1rem;
  color: #fff !important;
  text-wrap: balance;
}

.public-site .registration-hero-card h2 {
  max-width: 26ch;
  margin-bottom: .4rem;
  color: #fff !important;
  font-size: clamp(1.35rem, 2.7vw, 2rem);
}

.public-site .registration-hero-card h3 {
  max-width: 42rem;
  color: rgba(255, 255, 255, .78) !important;
  font-size: clamp(1rem, 1.7vw, 1.3rem);
  font-weight: 680;
}

.public-site .registration-hero-facts {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1.45rem;
}

.public-site .registration-hero-facts span {
  display: inline-flex;
  align-items: baseline;
  gap: .45rem;
  min-height: 3rem;
  padding: .62rem .85rem;
  color: rgba(255, 255, 255, .72);
  background: rgba(255, 255, 255, .11);
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 8px;
}

.public-site .registration-hero-facts strong {
  color: #fff;
  font-size: 1.22rem;
}

.public-site .registration-flow-nav {
  position: sticky;
  top: 0;
  z-index: 60;
  padding-block: .8rem;
  background: rgba(255, 255, 255, .9);
  border-bottom: 1px solid rgba(16, 35, 29, .08);
  box-shadow: 0 12px 34px rgba(19, 43, 32, .08);
  backdrop-filter: blur(16px);
}

.public-site .registration-flow-list {
  display: flex;
  gap: .55rem;
  overflow-x: auto;
  padding-bottom: .05rem;
  scrollbar-width: none;
}

.public-site .registration-flow-list::-webkit-scrollbar {
  display: none;
}

.public-site .registration-flow-list a {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 2.5rem;
  padding: .62rem .85rem;
  color: var(--brand-green);
  background: rgba(237, 243, 238, .7);
  border: 1px solid rgba(13, 58, 44, .1);
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 760;
}

.public-site .registration-intro-section {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .86), #fff);
}

.public-site .registration-notice-card,
.public-site .registration-document {
  border-color: rgba(16, 35, 29, .12);
  box-shadow: 0 22px 58px rgba(19, 43, 32, .1);
}

.public-site .registration-notice-card {
  background:
    linear-gradient(180deg, rgba(237, 243, 238, .84), rgba(255, 255, 255, .98) 24%),
    #fff;
}

.public-site .registration-notice-body,
.public-site .registration-document-content,
.public-site .registration-notice-closing,
.public-site .registration-notice-signature,
.public-site .registration-notice-deputies {
  color: #2e4038;
}

.public-site .registration-notice-body h2 {
  text-wrap: balance;
}

.public-site .registration-requirements {
  padding: 1rem 1.15rem;
  background: rgba(237, 243, 238, .55);
  border: 1px solid rgba(13, 58, 44, .1);
  border-left: 4px solid rgba(191, 146, 60, .72);
  border-radius: 8px;
}

.public-site .registration-fee-section {
  background:
    linear-gradient(180deg, #fff, rgba(246, 248, 245, .9)) !important;
}

.public-site .registration-fee-section .col-lg-9 {
  width: min(100%, 62rem);
}

.public-site .registration-notice-fee-table {
  overflow: hidden;
  border: 1px solid rgba(16, 35, 29, .12);
  border-radius: 8px;
  box-shadow: var(--brand-shadow);
}

.public-site .registration-notice-fee-table thead th {
  background: var(--brand-green);
}

.public-site .registration-notice-fee-table tbody td,
.public-site .registration-notice-fee-table tbody th {
  color: var(--brand-green);
}

.public-site .registration-fee-total-row th,
.public-site .registration-fee-total-row td {
  background: var(--brand-green) !important;
}

.public-site .registration-total-card {
  border: 1px solid rgba(255, 255, 255, .28);
  box-shadow: 0 16px 40px rgba(13, 58, 44, .16);
}

.public-site .registration-location-note {
  color: var(--brand-ink);
  background: rgba(255, 255, 255, .82);
  border: 1px solid rgba(191, 146, 60, .22);
  border-radius: 8px;
}

.public-site .registration-masyayikh-section {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .92), #fff 70%);
}

.public-site .registration-masyayikh-grid {
  grid-template-columns: repeat(3, minmax(0, 18.5rem));
  justify-content: center;
  gap: clamp(1rem, 2vw, 1.5rem);
}

.public-site .registration-masyayikh-list {
  grid-template-columns: 1fr;
  max-width: 44rem;
}

.public-site .registration-masyaikh-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(251, 252, 250, .94));
}

.public-site .registration-masyaikh-card img {
  aspect-ratio: 1 / 1;
}

.public-site .registration-contact-section {
  background:
    linear-gradient(110deg, rgba(7, 29, 21, .95), rgba(13, 58, 44, .82)),
    url("../img/backgrounds/modern-section-halaqah-kitabs.jpg") center / cover no-repeat;
}

.public-site .registration-contact-section .public-section-kicker {
  color: rgba(235, 198, 126, .94);
}

.public-site .registration-contact-section h2,
.public-site .registration-contact-section .registration-action-panel h3 {
  color: #fff;
}

.public-site .registration-contact-section .public-section-heading p {
  color: rgba(255, 255, 255, .72);
}

.public-site .registration-contact-section .registration-action-panel {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .16);
  box-shadow: 0 18px 48px rgba(0, 0, 0, .2);
  backdrop-filter: blur(12px);
}

.public-site .registration-contact-section .registration-contact-list a,
.public-site .registration-contact-section .registration-download-card,
.public-site .registration-contact-section .registration-empty-note {
  color: #fff;
  background: rgba(255, 255, 255, .11);
  border-color: rgba(255, 255, 255, .14);
}

.public-site .registration-contact-section .registration-contact-list a strong,
.public-site .registration-contact-section .registration-download-card .text-dark,
.public-site .registration-contact-section .registration-download-card .link {
  color: #fff !important;
}

.public-site .registration-contact-section .registration-download-card p,
.public-site .registration-contact-section .registration-empty-note {
  color: rgba(255, 255, 255, .74) !important;
}

.public-site .registration-map-section {
  background:
    linear-gradient(180deg, #fff, rgba(246, 248, 245, .82));
}

.public-site .registration-map-section iframe {
  display: block;
  overflow: hidden;
  border: 1px solid rgba(16, 35, 29, .1) !important;
  border-radius: 8px;
  box-shadow: var(--brand-shadow-strong);
}

@media (hover: hover) {

  .public-site .registration-flow-list a:hover,
  .public-site .registration-flow-list a:focus {
    transform: translateY(-1px);
    background: #fff;
    box-shadow: 0 10px 24px rgba(13, 58, 44, .1);
  }

  .public-site .registration-contact-section .registration-contact-list a:hover,
  .public-site .registration-contact-section .registration-contact-list a:focus,
  .public-site .registration-contact-section .registration-download-card:hover,
  .public-site .registration-contact-section .registration-download-card:focus {
    background: rgba(255, 255, 255, .18);
    box-shadow: 0 14px 36px rgba(0, 0, 0, .18);
  }
}

@media (max-width: 991.98px) {
  .public-site .public-registration-hero .hero-image {
    min-height: 0;
    background:
      linear-gradient(180deg, rgba(7, 29, 21, .88), rgba(13, 58, 44, .52)),
      var(--registration-hero-image, url("../img/backgrounds/modern-section-haul-stage.jpg")) center / cover no-repeat;
  }

  .public-site .public-registration-hero .hero-image>.container {
    min-height: 34rem !important;
  }

  .public-site .registration-masyayikh-grid {
    grid-template-columns: repeat(2, minmax(0, 16rem));
    justify-content: center;
  }

  .public-site .registration-masyayikh-list {
    grid-template-columns: 1fr;
    max-width: 32rem;
  }
}

@media (max-width: 767.98px) {
  .public-site .registration-flow-nav {
    position: relative;
    top: auto;
  }

  .public-site .registration-hero-card {
    width: min(100%, 18rem) !important;
    max-width: calc(100vw - 2rem);
    margin-inline: auto;
    padding: 1rem;
    overflow: hidden;
    box-sizing: border-box;
  }

  .public-site .public-registration-hero .hero-image>.container {
    max-width: 100%;
    padding-inline: 1rem !important;
  }

  .public-site .registration-hero-card h1 {
    max-width: 100%;
    font-size: clamp(2.05rem, 9vw, 2.5rem);
  }

  .public-site .registration-hero-card h2,
  .public-site .registration-hero-card h3 {
    max-width: 100%;
  }

  .public-site .registration-hero-facts span {
    flex: 1 1 100%;
    max-width: 100%;
    min-width: 0;
    flex-wrap: wrap;
    box-sizing: border-box;
  }

  .public-site .registration-hero-card .public-hero-actions,
  .public-site .registration-hero-card .btn {
    width: 100%;
    max-width: 100%;
  }

  .public-site .registration-flow-list {
    margin-inline: -1rem;
    padding-inline: 1rem;
  }

  .public-site .registration-total-card {
    align-items: flex-start;
    flex-direction: column;
  }

  .public-site .registration-masyayikh-grid {
    grid-template-columns: repeat(2, minmax(0, 16rem));
    justify-content: center;
  }

  .public-site .registration-masyayikh-list {
    grid-template-columns: 1fr;
    max-width: 32rem;
  }

  .public-site .registration-contact-section .registration-download-card .fs-4 {
    font-size: 1rem !important;
  }
}

/*--------------------------------------------------------------
# Fase 6 - Optional Cinematic Enhancement
--------------------------------------------------------------*/
.public-site.mdq-cinema-enabled {
  scroll-behavior: smooth;
}

.public-site.mdq-cinema-enabled #header.public-navbar {
  transform: none !important;
  will-change: box-shadow, background-color;
}

.public-site.mdq-cinema-enabled.mdq-scroll-down #header.public-navbar {
  transform: none !important;
}

.public-site.mdq-cinema-enabled.mdq-scroll-up #header.public-navbar,
.public-site.mdq-cinema-enabled.mdq-scroll-resting #header.public-navbar {
  transform: none !important;
}

.public-site.mdq-cinema-enabled .mdq-cinema-section {
  opacity: .965;
  transform: translateY(10px);
  filter: saturate(.96);
  transition:
    opacity 900ms var(--brand-ease-reveal),
    transform 900ms var(--brand-ease-reveal),
    filter 900ms var(--brand-ease-reveal);
  will-change: opacity, transform, filter;
}

.public-site.mdq-cinema-enabled .mdq-cinema-section.mdq-cinema-visible {
  opacity: 1;
  transform: none;
  filter: saturate(1);
}

.public-site.mdq-cinema-enabled .public-home-hero,
.public-site.mdq-cinema-enabled .public-registration-hero,
.public-site.mdq-cinema-enabled .public-founder-section,
.public-site.mdq-cinema-enabled .public-stats-section,
.public-site.mdq-cinema-enabled .registration-contact-section,
.public-site.mdq-cinema-enabled .public-cta-band {
  background-attachment: fixed;
}

.public-site.mdq-cinema-enabled .homepage-gallery-track {
  animation-duration: 52s !important;
}

.public-site.mdq-cinema-enabled .homepage-gallery-strip:hover .homepage-gallery-track,
.public-site.mdq-cinema-enabled .homepage-gallery-strip:focus-within .homepage-gallery-track,
.public-site.mdq-cinema-enabled .js-swiper-autoplay:hover .swiper-wrapper,
.public-site.mdq-cinema-enabled .js-swiper-autoplay:focus-within .swiper-wrapper {
  animation-play-state: paused !important;
}

@media (max-width: 991.98px) {
  .public-site.mdq-cinema-enabled {
    scroll-behavior: auto;
  }

  .public-site.mdq-cinema-enabled .mdq-cinema-section {
    opacity: 1;
    transform: none;
    filter: none;
  }

  .public-site.mdq-cinema-enabled .public-home-hero,
  .public-site.mdq-cinema-enabled .public-registration-hero,
  .public-site.mdq-cinema-enabled .public-founder-section,
  .public-site.mdq-cinema-enabled .public-stats-section,
  .public-site.mdq-cinema-enabled .registration-contact-section,
  .public-site.mdq-cinema-enabled .public-cta-band {
    background-attachment: scroll;
  }
}

/*--------------------------------------------------------------
# Dewan Masyaikh Detail Page
--------------------------------------------------------------*/
.public-site .public-masyayikh-page {
  position: relative;
  padding-top: clamp(3rem, 5vw, 5.5rem);
  background:
    radial-gradient(circle at 14% 3rem, rgba(201, 155, 66, .1), transparent 18rem),
    linear-gradient(180deg, rgba(246, 248, 245, .92), rgba(255, 255, 255, 0) 22rem);
}

.public-site .public-masyayikh-page .public-page-heading {
  margin-inline: auto;
}

.public-site .public-masyayikh-page .public-page-heading p {
  max-width: 48rem;
  margin-inline: auto;
}

.public-site .public-masyayikh-directory {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 1.8vw, 1.35rem);
  max-width: 68rem;
  margin-inline: auto;
}

.public-site .public-masyayikh-profile-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(10.5rem, 13rem) minmax(0, 1fr);
  gap: clamp(1rem, 2vw, 1.45rem);
  padding: clamp(.95rem, 2vw, 1.25rem);
  overflow: visible;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .99), rgba(251, 252, 250, .97));
  border: 1px solid rgba(16, 35, 29, .09);
  border-radius: 14px;
  box-shadow: 0 18px 44px rgba(19, 43, 32, .08);
  transition:
    transform var(--brand-motion-base) var(--brand-ease),
    box-shadow var(--brand-motion-base) var(--brand-ease),
    border-color var(--brand-motion-base) var(--brand-ease);
}

.public-site .public-masyayikh-profile-card::before {
  content: "";
  position: absolute;
  inset: .85rem auto .85rem 0;
  width: 3px;
  background: linear-gradient(180deg, var(--brand-gold), rgba(15, 61, 46, .2));
  border-radius: 999px;
  opacity: .8;
}

.public-site .public-masyayikh-profile-card:hover,
.public-site .public-masyayikh-profile-card:focus-within {
  transform: translateY(-2px);
  border-color: rgba(15, 61, 46, .18);
  box-shadow: 0 24px 58px rgba(19, 43, 32, .12);
}

.public-site .public-masyayikh-profile-media {
  min-height: 15.5rem;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(237, 243, 238, .92), rgba(255, 255, 255, .9)),
    #edf3ee;
  border: 1px solid rgba(15, 61, 46, .08);
  border-radius: 12px;
}

.public-site .public-masyayikh-profile-media img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 15.5rem;
  object-fit: cover;
  object-position: top center;
}

.public-site .public-masyayikh-profile-body {
  min-width: 0;
  padding-block: .1rem;
}

.public-site .public-masyayikh-profile-heading {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}

.public-site .public-masyayikh-profile-category {
  display: inline-flex;
  width: fit-content;
  margin-bottom: .5rem;
  padding: .28rem .58rem;
  color: var(--brand-green);
  background: rgba(231, 239, 233, .9);
  border: 1px solid rgba(15, 61, 46, .08);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.public-site .public-masyayikh-profile-heading h2 {
  margin-bottom: .38rem;
  color: var(--brand-ink);
  font-size: clamp(1.18rem, 1.55vw, 1.55rem);
  line-height: 1.16;
}

.public-site .public-masyayikh-profile-heading p {
  margin-bottom: 0;
  color: var(--brand-muted);
  font-weight: 700;
}

.public-site .public-masyayikh-profile-heading p span {
  margin-right: .45rem;
  color: var(--brand-gold);
  font-size: .78rem;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.public-site .public-masyayikh-profile-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
  margin: 0 0 .85rem;
}

.public-site .public-masyayikh-profile-details div,
.public-site .public-masyayikh-profile-note {
  padding: .75rem .85rem;
  background: rgba(246, 248, 245, .72);
  border: 1px solid rgba(16, 35, 29, .07);
  border-radius: 10px;
}

.public-site .public-masyayikh-profile-details dt,
.public-site .public-masyayikh-profile-note h3 {
  margin-bottom: .28rem;
  color: var(--brand-gold);
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.public-site .public-masyayikh-profile-details dd {
  margin-bottom: 0;
  color: var(--brand-ink);
  font-size: .95rem;
  font-weight: 640;
  line-height: 1.5;
}

.public-site .public-masyayikh-profile-details a {
  color: var(--brand-green);
  text-decoration: none;
}

.public-site .public-masyayikh-profile-note {
  margin-top: .65rem;
}

.public-site .public-masyayikh-profile-note p,
.public-site .public-masyayikh-profile-note ul {
  margin-bottom: 0;
  color: var(--brand-muted);
  font-size: .95rem;
  line-height: 1.62;
}

.public-site .public-masyayikh-profile-note ul {
  padding-left: 1.1rem;
}

.public-site .public-masyayikh-profile-note li+li {
  margin-top: .25rem;
}

@media (max-width: 991.98px) {
  .public-site .public-masyayikh-profile-card {
    grid-template-columns: minmax(8.5rem, 11rem) minmax(0, 1fr);
  }

  .public-site .public-masyayikh-profile-media,
  .public-site .public-masyayikh-profile-media img {
    min-height: 13.5rem;
  }

  .public-site .public-masyayikh-profile-details {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 575.98px) {
  .public-site .public-masyayikh-profile-card {
    grid-template-columns: 1fr;
  }

  .public-site .public-masyayikh-profile-card::before {
    inset: 0 .9rem auto .9rem;
    width: auto;
    height: 3px;
  }

  .public-site .public-masyayikh-profile-media,
  .public-site .public-masyayikh-profile-media img {
    min-height: 17rem;
  }
}

.public-site .public-activity-listing-layout {
  display: grid;
  grid-template-columns: clamp(18rem, 18vw, 22rem) minmax(0, 1fr);
  gap: clamp(1.6rem, 3vw, 2.75rem);
  align-items: start;
  overflow: visible;
  width: min(calc(100% - clamp(6rem, 16vw, 18rem)), 88rem);
  margin-inline: auto;
}

.public-site .public-activity-listing-aside,
.public-site .public-activity-listing-main,
.public-site .public-activity-mobile-search {
  min-width: 0;
}

.public-site .public-activity-mobile-search {
  display: none;
}

.public-site .public-activity-listing-main {
  width: min(100%, 72rem);
}

.public-site .public-activity-detail-layout {
  display: grid;
  grid-template-columns: clamp(18rem, 18vw, 22rem) minmax(0, 54rem);
  gap: clamp(1.6rem, 3vw, 2.75rem);
  align-items: start;
  overflow: visible;
  width: min(calc(100% - clamp(6rem, 16vw, 18rem)), 76rem);
  margin-inline: auto;
}

.public-site .public-activity-detail-aside,
.public-site .public-activity-detail-main {
  min-width: 0;
}

.public-site .public-activity-detail-main {
  width: 100%;
}

.public-site .public-activity-listing-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1.35rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(17, 42, 34, .08);
}

.public-site .public-activity-listing-toolbar h2 {
  margin: .28rem 0 .36rem;
  color: var(--brand-ink);
  font-size: clamp(1.45rem, 2.4vw, 2.1rem);
  line-height: 1.1;
}

.public-site .public-activity-listing-toolbar p {
  margin-bottom: 0;
  color: var(--brand-muted);
  font-weight: 650;
}

.public-site .public-active-filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .45rem;
  max-width: 24rem;
}

.public-site .public-active-filters span,
.public-site .public-active-filters a {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: .38rem .72rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  text-decoration: none;
}

.public-site .public-active-filters span {
  color: var(--brand-green);
  background: rgba(13, 91, 66, .08);
  border: 1px solid rgba(13, 91, 66, .12);
}

.public-site .public-active-filters a {
  color: #8a6219;
  background: rgba(194, 143, 45, .11);
  border: 1px solid rgba(194, 143, 45, .18);
}

.public-site .public-post-grid-with-aside {
  --activity-card-radius: 10px;
}

.public-site .public-post-grid-with-aside>[class*="col-"] {
  display: flex;
}

.public-site .public-post-grid-with-aside .public-post-card {
  width: 100%;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(17, 42, 34, .1) !important;
  border-radius: var(--activity-card-radius);
  box-shadow: 0 18px 42px rgba(17, 42, 34, .07) !important;
}

.public-site .public-post-grid-with-aside .public-post-image,
.public-site .public-post-grid-with-aside .public-post-image img {
  height: clamp(11.5rem, 15vw, 14rem);
}

.public-site .public-post-grid-with-aside .public-post-image img {
  object-fit: cover;
}

.public-site .public-post-grid-with-aside .card-body {
  padding: clamp(1.05rem, 2vw, 1.35rem);
}

.public-site .public-post-grid-with-aside .card-body>.d-flex:first-child {
  min-height: 1.9rem;
  margin-bottom: .6rem !important;
}

.public-site .public-post-grid-with-aside .card-body>.d-flex:first-child .text-primary {
  color: var(--brand-green) !important;
  font-size: .9rem;
  font-weight: 750;
}

.public-site .public-post-grid-with-aside .badge {
  border-radius: 8px;
  font-weight: 750;
}

.public-site .public-post-grid-with-aside .public-post-card h2 {
  margin: 0 0 .65rem;
  font-size: clamp(1.18rem, 1.45vw, 1.55rem);
  font-weight: 900;
  line-height: 1.16;
  letter-spacing: 0;
}

.public-site .public-post-grid-with-aside .public-post-card h2 a {
  display: -webkit-box;
  overflow: hidden;
  text-decoration: none;
  overflow-wrap: anywhere;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.public-site .public-post-grid-with-aside .public-post-card p {
  display: -webkit-box;
  margin-bottom: .95rem;
  overflow: hidden;
  color: var(--brand-muted) !important;
  font-size: .98rem;
  line-height: 1.6;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.public-site .public-post-grid-with-aside .public-post-card .badge.bg-light {
  max-width: 100%;
  padding: .38rem .58rem;
  color: var(--brand-ink) !important;
  background: rgba(246, 248, 245, .92) !important;
  border: 1px solid rgba(17, 42, 34, .08);
  overflow: hidden;
  text-overflow: ellipsis;
}

.public-site .public-post-grid-with-aside .public-read-more {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  width: fit-content;
  margin-top: auto;
  color: var(--brand-green);
  font-size: .92rem;
  font-weight: 900;
  text-decoration: none;
}

.public-site .public-post-grid-with-aside .public-read-more::after {
  content: "\F138";
  font-family: "bootstrap-icons";
  font-size: .85rem;
  line-height: 1;
  transition: transform .2s ease;
}

.public-site .public-post-grid-with-aside .public-read-more:hover::after {
  transform: translateX(3px);
}

.public-site .activity-aside {
  position: sticky;
  top: 6.4rem;
  display: grid;
  gap: .9rem;
  min-width: 0;
}

.public-site .activity-aside-panel {
  padding: 1rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(250, 252, 249, .94));
  border: 1px solid rgba(17, 42, 34, .1);
  border-radius: 8px;
  box-shadow: 0 18px 42px rgba(17, 42, 34, .07);
  min-width: 0;
}

.public-site .activity-aside-nav-panel {
  padding-block: .82rem;
}

.public-site .public-article-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 1.05rem;
  row-gap: .62rem;
  margin-top: 1.15rem;
  padding: .9rem 0;
  border-top: 1px solid rgba(17, 42, 34, .1);
  border-bottom: 1px solid rgba(17, 42, 34, .1);
}

.public-site .public-article-summary-item {
  position: relative;
  display: inline-flex;
  align-items: baseline;
  gap: .38rem;
  min-width: 0;
  color: var(--brand-muted);
}

.public-site .public-article-summary-item:not(:last-child)::after {
  content: "";
  width: 1px;
  height: .9rem;
  margin-left: 1.05rem;
  background: rgba(17, 42, 34, .16);
}

.public-site .public-article-summary-item>span {
  color: var(--brand-muted);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.public-site .public-article-summary strong,
.public-site .public-article-summary a {
  color: var(--brand-ink);
  font-size: .92rem;
  font-weight: 850;
  line-height: 1.35;
  text-decoration: none;
}

.public-site .public-article-summary a:hover {
  color: var(--brand-green);
}

.public-site .public-article-read-also {
  display: grid;
  gap: .25rem;
  margin: 1.6rem 0;
  padding: .9rem 1rem;
  background: linear-gradient(135deg, rgba(13, 91, 66, .06), rgba(194, 143, 45, .08));
  border-left: 4px solid var(--brand-gold);
  border-radius: 8px;
}

.public-site .public-article-read-also span {
  color: var(--brand-gold);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.public-site .public-article-read-also a {
  color: var(--brand-ink);
  font-size: 1rem;
  font-weight: 850;
  line-height: 1.4;
  text-decoration: none;
}

.public-site .public-article-read-also a:hover {
  color: var(--brand-green);
}

.public-site .public-article-tags {
  display: grid;
  gap: .75rem;
  margin: 1.6rem 0 0;
  padding-top: 1rem;
  border-top: 1px solid rgba(17, 42, 34, .1);
}

.public-site .public-article-tags h2 {
  margin: 0;
  color: var(--brand-ink);
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.25;
}

.public-site .public-article-tags div {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
}

.public-site .public-article-tags a {
  display: inline-flex;
  align-items: center;
  min-height: 2rem;
  padding: .38rem .72rem;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .08);
  border: 1px solid rgba(13, 91, 66, .12);
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 850;
  line-height: 1;
  text-decoration: none;
}

.public-site .public-article-tags a:hover {
  color: #fff;
  background: var(--brand-green);
}

.public-site .activity-aside-kicker {
  margin-bottom: .28rem;
  color: var(--brand-gold);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .activity-aside-title {
  margin-bottom: .8rem;
  color: var(--brand-ink);
  font-size: 1rem;
  line-height: 1.22;
}

.public-site .activity-aside-back {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: var(--brand-green);
  font-size: .86rem;
  font-weight: 850;
  text-decoration: none;
}

.public-site .activity-aside-back:hover {
  color: var(--brand-ink);
}

.public-site .activity-aside-meta {
  display: grid;
  gap: .52rem;
  margin: 0;
}

.public-site .activity-aside-meta div {
  display: grid;
  grid-template-columns: minmax(5.3rem, .82fr) minmax(0, 1fr);
  gap: .55rem;
  align-items: start;
  padding: .55rem 0;
  border-bottom: 1px solid rgba(17, 42, 34, .08);
}

.public-site .activity-aside-meta div:last-child {
  border-bottom: 0;
}

.public-site .activity-aside-meta dt {
  color: var(--brand-muted);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.public-site .activity-aside-meta dd {
  margin-bottom: 0;
  color: var(--brand-ink);
  font-size: .84rem;
  font-weight: 850;
  line-height: 1.45;
}

.public-site .activity-aside-meta a {
  color: var(--brand-green);
  text-decoration: none;
}

.public-site .activity-aside-subtitle {
  margin: .9rem 0 .5rem;
  color: var(--brand-muted);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.public-site .activity-aside-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: .55rem;
}

.public-site .activity-aside-search .form-control {
  min-height: 2.65rem;
  border-radius: 8px;
}

.public-site .activity-aside-search .btn {
  display: inline-flex;
  justify-content: center;
  gap: .45rem;
  width: 100%;
  min-height: 2.55rem;
  border-radius: 8px;
  font-weight: 850;
}

.public-site .activity-aside-reset,
.public-site .activity-aside-rss-link,
.public-site .activity-aside-editor-link {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-top: .75rem;
  color: var(--brand-green);
  font-size: .86rem;
  font-weight: 850;
  text-decoration: none;
}

.public-site .activity-aside-category-list,
.public-site .activity-aside-post-list,
.public-site .activity-aside-contributor-list {
  display: grid;
  gap: .48rem;
  margin: 0;
  padding: 0;
}

.public-site .activity-aside-category-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .7rem;
  padding: .58rem .66rem;
  color: var(--brand-ink);
  background: rgba(246, 248, 245, .72);
  border: 1px solid transparent;
  border-radius: 8px;
  font-size: .86rem;
  font-weight: 800;
  text-decoration: none;
  overflow-wrap: anywhere;
}

.public-site .activity-aside-category-list a strong {
  color: var(--brand-green);
  font-size: .78rem;
}

.public-site .activity-aside-category-list a.is-active,
.public-site .activity-aside-category-list a:hover {
  color: var(--brand-green);
  background: rgba(13, 91, 66, .08);
  border-color: rgba(13, 91, 66, .12);
}

.public-site .activity-aside-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: .42rem;
}

.public-site .activity-aside-tag-list a {
  display: inline-flex;
  align-items: center;
  min-height: 1.9rem;
  padding: .34rem .62rem;
  color: var(--brand-ink);
  background: rgba(246, 248, 245, .86);
  border: 1px solid rgba(17, 42, 34, .08);
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  text-decoration: none;
}

.public-site .activity-aside-tag-list a.is-active,
.public-site .activity-aside-tag-list a:hover {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-site .activity-aside-post-link {
  display: grid;
  gap: .55rem;
  padding: .8rem 0;
  color: inherit;
  border-bottom: 1px solid rgba(17, 42, 34, .08);
  text-decoration: none;
}

.public-site .activity-aside-post-link:last-child {
  border-bottom: 0;
}

.public-site .activity-aside-post-thumb {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: rgba(13, 91, 66, .08);
  border: 1px solid rgba(17, 42, 34, .08);
  border-radius: 10px;
}

.public-site .activity-aside-post-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .22s ease;
}

.public-site .activity-aside-post-thumb-empty {
  display: inline-grid;
  place-items: center;
  color: var(--brand-green);
  font-size: 1.8rem;
  font-weight: 900;
}

.public-site .activity-aside-post-body {
  display: grid;
  gap: .2rem;
  min-width: 0;
}

.public-site .activity-aside-post-date,
.public-site .activity-aside-post-category {
  color: var(--brand-gold);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.public-site .activity-aside-post-title {
  display: -webkit-box;
  overflow: hidden;
  color: var(--brand-ink);
  font-size: .9rem;
  font-weight: 850;
  line-height: 1.35;
  overflow-wrap: anywhere;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.public-site .activity-aside-post-link:hover .activity-aside-post-title {
  color: var(--brand-green);
}

.public-site .activity-aside-post-link:hover .activity-aside-post-thumb img {
  transform: scale(1.05);
}

.public-site .activity-aside-toc {
  display: grid;
  gap: .35rem;
}

.public-site .activity-aside-toc a {
  display: block;
  padding: .38rem .55rem;
  color: var(--brand-ink);
  border-left: 3px solid rgba(13, 91, 66, .16);
  border-radius: 0 8px 8px 0;
  font-size: .84rem;
  font-weight: 800;
  line-height: 1.35;
  text-decoration: none;
}

.public-site .activity-aside-toc a.is-level-3 {
  margin-left: .7rem;
  color: var(--brand-muted);
  font-size: .8rem;
}

.public-site .activity-aside-toc a:hover {
  color: var(--brand-green);
  background: rgba(13, 91, 66, .07);
}

.public-site .activity-aside-author {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .75rem;
  align-items: start;
}

.public-site .activity-aside-author img,
.public-site .activity-aside-author>span {
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 999px;
}

.public-site .activity-aside-author img {
  object-fit: cover;
}

.public-site .activity-aside-author>span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .1);
  font-weight: 900;
}

.public-site .activity-aside-author strong {
  display: block;
  color: var(--brand-ink);
  font-size: .92rem;
  line-height: 1.3;
}

.public-site .activity-aside-author p {
  display: -webkit-box;
  overflow: hidden;
  margin: .25rem 0 .35rem;
  color: var(--brand-muted);
  font-size: .82rem;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.public-site .activity-aside-author a {
  color: var(--brand-green);
  font-size: .8rem;
  font-weight: 850;
  text-decoration: none;
}

.public-site .activity-aside-contributor-list {
  list-style: none;
}

.public-site .activity-aside-contributor-list li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .56rem;
  align-items: center;
  padding: .5rem .55rem;
  background: rgba(246, 248, 245, .74);
  border-radius: 8px;
}

.public-site .activity-aside-rank {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.55rem;
  height: 1.55rem;
  color: #fff;
  background: var(--brand-green);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 900;
}

.public-site .activity-aside-contributor-name {
  min-width: 0;
  color: var(--brand-ink);
  font-size: .84rem;
  font-weight: 850;
  overflow-wrap: anywhere;
}

.public-site .activity-aside-contributor-name a {
  color: inherit;
  text-decoration: none;
}

.public-site .activity-aside-contributor-name a:hover {
  color: var(--brand-green);
}

.public-site .activity-aside-contributor-value {
  color: var(--brand-muted);
  font-size: .76rem;
  font-weight: 850;
  white-space: nowrap;
}

.public-site .activity-aside-share {
  display: grid;
  grid-template-columns: 1fr;
  gap: .5rem;
}

.public-site .activity-share-label {
  color: var(--brand-muted);
  font-size: .88rem;
  font-weight: 750;
  line-height: 1;
}

.public-site .activity-aside-share-button {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: .55rem;
  min-height: 2.55rem;
  padding: .52rem .68rem;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .08);
  border: 1px solid rgba(13, 91, 66, .12);
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 850;
  text-decoration: none;
  line-height: 1.15;
  text-align: left;
  white-space: nowrap;
}

.public-site .activity-aside-share-button i,
.public-site .activity-aside-share-button .activity-share-svg-icon {
  display: inline-grid;
  place-items: center;
  flex: 0 0 1.55rem;
  width: 1.55rem;
  height: 1.55rem;
  color: #fff;
  fill: currentColor;
  background: var(--brand-green);
  border-radius: 7px;
  font-size: .92rem;
}

.public-site .activity-aside-share-button .activity-share-svg-icon {
  padding: .32rem;
}

.public-site .activity-aside-share-button span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
}

.public-site .activity-aside-share-button:focus-visible,
.public-site .activity-aside-category-list a:focus-visible,
.public-site .activity-aside-tag-list a:focus-visible,
.public-site .activity-aside-post-link:focus-visible,
.public-site .activity-aside-editor-link:focus-visible,
.public-site .activity-aside-rss-link:focus-visible,
.public-site .activity-aside-back:focus-visible {
  outline: 3px solid rgba(194, 143, 45, .34);
  outline-offset: 3px;
}

.public-site .activity-aside-share-button:hover {
  color: #fff;
  background: var(--brand-green);
}

.public-site .activity-aside-share-button:hover i,
.public-site .activity-aside-share-button:hover .activity-share-svg-icon,
.public-site .activity-aside-share-button.is-copied i,
.public-site .activity-aside-share-button.is-copied .activity-share-svg-icon {
  color: var(--brand-green);
  background: #fff;
}

.public-site .activity-aside-share-button.is-copied {
  color: #fff;
  background: #168a58;
  border-color: #168a58;
}

.public-site .public-article-share {
  display: inline-grid;
  grid-template-columns: auto repeat(6, 2.25rem);
  align-items: center;
  gap: .42rem;
  margin-top: 1.15rem;
}

.public-site .public-article-share .activity-share-label {
  align-self: center;
  margin-right: .1rem;
}

.public-site .public-article-share .activity-aside-share-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  min-width: 2.25rem;
  height: 2.25rem;
  min-height: 2.25rem;
  padding: 0;
  border-radius: 50%;
  color: #fff;
  background: var(--brand-green);
  border-color: transparent;
  box-shadow: 0 8px 18px rgba(17, 42, 34, .11);
}

.public-site .public-article-share .activity-aside-share-button:nth-of-type(2) {
  background: #365899;
}

.public-site .public-article-share .activity-aside-share-button:nth-of-type(3) {
  background: #050505;
}

.public-site .public-article-share .activity-aside-share-button:nth-of-type(4) {
  background: #101010;
}

.public-site .public-article-share .activity-aside-share-button:nth-of-type(5) {
  background: linear-gradient(135deg, #f58529, #dd2a7b 48%, #515bd4);
}

.public-site .public-article-share .activity-aside-share-button:nth-of-type(6) {
  background: #8b8f91;
}

.public-site .public-article-share .activity-aside-share-button i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  color: currentColor;
  background: transparent;
  border-radius: 0;
  font-size: .94rem;
  line-height: 1;
  text-align: center;
}

.public-site .public-article-share .activity-aside-share-button i::before {
  display: block;
  margin: 0;
  line-height: 1;
  vertical-align: 0;
}

.public-site .public-article-share .activity-share-svg-icon {
  display: block;
  flex: 0 0 1rem;
  width: 1rem;
  height: 1rem;
  padding: 0;
  fill: currentColor;
  background: transparent;
  border-radius: 0;
}

.public-site .public-article-share .activity-share-threads-svg {
  width: 1.08rem;
  height: 1.08rem;
}

.public-site .public-article-share .activity-aside-share-button span:not(.activity-share-label) {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

.public-site .public-article-share .activity-aside-share-button:hover,
.public-site .public-article-share .activity-aside-share-button.is-copied {
  color: #fff;
  background: var(--brand-ink);
  transform: translateY(-1px);
}

.public-site .public-article-share .activity-aside-share-button:hover i,
.public-site .public-article-share .activity-aside-share-button.is-copied i {
  color: currentColor;
  background: transparent;
}

.public-site .public-article-share-end {
  margin: 2rem 0 0;
  padding: 1rem 0;
  border-top: 1px solid rgba(17, 42, 34, .1);
  border-bottom: 1px solid rgba(17, 42, 34, .1);
}

.public-site .public-article-share-end .public-article-share {
  margin-top: 0;
}

.public-site .activity-aside-empty {
  margin-bottom: 0;
  color: var(--brand-muted);
  font-size: .86rem;
}

@media (max-width: 1199.98px) {
  .public-site .public-activity-listing-layout {
    grid-template-columns: minmax(15.5rem, 17.5rem) minmax(0, 1fr);
    width: min(calc(100% - 2rem), 72rem);
  }

  .public-site .public-activity-detail-layout {
    grid-template-columns: minmax(15.5rem, 17.5rem) minmax(0, 1fr);
    width: min(calc(100% - 2rem), 72rem);
  }
}

@media (max-width: 991.98px) {

  .public-site .public-activity-listing-layout,
  .public-site .public-activity-detail-layout {
    grid-template-columns: 1fr;
    width: min(calc(100% - 2rem), 54rem);
  }

  .public-site .public-activity-detail-main {
    order: 1;
  }

  .public-site .public-activity-detail-aside {
    order: 2;
  }

  .public-site .public-activity-mobile-search {
    display: block;
    order: 1;
  }

  .public-site .public-activity-listing-main {
    order: 2;
  }

  .public-site .public-activity-listing-aside {
    order: 3;
  }

  .public-site .public-activity-listing-aside .activity-aside-search-panel {
    display: none;
  }

  .public-site .activity-aside {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .public-site .public-activity-detail-main {
    max-width: 54rem;
    margin-inline: auto;
  }
}

@media (max-width: 767.98px) {

  .public-site .public-article-page,
  .public-site .public-listing-page {
    padding-inline: .9rem;
  }

  .public-site .public-activity-listing-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .public-site .public-active-filters {
    justify-content: flex-start;
    max-width: none;
  }

  .public-site .activity-aside {
    grid-template-columns: 1fr;
  }

  .public-site .activity-aside-share {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .public-site .public-article-share {
    grid-template-columns: auto repeat(6, 2.65rem);
  }

  .public-site .activity-aside-share:not(.public-article-share) .activity-aside-share-button {
    justify-content: center;
    gap: .35rem;
    min-height: 2.75rem;
    padding-inline: .42rem;
    text-align: center;
    white-space: normal;
  }

  .public-site .activity-aside-share:not(.public-article-share) .activity-aside-share-button i {
    flex-basis: 1.35rem;
    width: 1.35rem;
    height: 1.35rem;
    font-size: .82rem;
  }

  .public-site .activity-aside-share:not(.public-article-share) .activity-aside-share-button .activity-share-svg-icon {
    flex-basis: 1.35rem;
    width: 1.35rem;
    height: 1.35rem;
    padding: .28rem;
  }

  .public-site .activity-aside-meta div {
    grid-template-columns: 1fr;
    gap: .2rem;
  }

  .public-site .public-article-header h1 {
    font-size: clamp(2rem, 9vw, 2.75rem);
    overflow-wrap: anywhere;
  }

  .public-site .public-article-content {
    padding: 1.05rem;
    font-size: 1rem !important;
    line-height: 1.72 !important;
  }

  .public-site .activity-reaction-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 420px) {
  .public-site .activity-aside-panel {
    padding: .85rem;
  }

  .public-site .public-article-summary {
    align-items: flex-start;
    gap: .55rem;
    padding-block: .75rem;
  }

  .public-site .public-article-summary-item {
    width: 100%;
    justify-content: space-between;
    gap: .75rem;
  }

  .public-site .public-article-summary-item:not(:last-child)::after {
    display: none;
  }

  .public-site .activity-aside-share:not(.public-article-share) .activity-aside-share-button {
    min-height: 2.45rem;
    padding-inline: .32rem;
    font-size: .72rem;
  }

  .public-site .activity-aside-share:not(.public-article-share) .activity-aside-share-button i {
    font-size: .95rem;
  }

  .public-site .activity-aside-share:not(.public-article-share) .activity-aside-share-button .activity-share-svg-icon {
    width: 1.35rem;
    height: 1.35rem;
  }

  .public-site .public-article-share {
    grid-template-columns: auto repeat(6, 2.05rem);
    gap: .28rem;
  }

  .public-site .public-article-share .activity-aside-share-button {
    width: 2.05rem;
    min-width: 2.05rem;
    height: 2.05rem;
    min-height: 2.05rem;
    font-size: .82rem;
  }

  .public-site .activity-reaction-options {
    grid-template-columns: 1fr;
  }
}

/* Fase M2 - Public Editorial Polish */
.public-site .public-page-heading,
.public-site .public-section-heading {
  max-width: 58rem;
}

.public-site .public-page-heading h1,
.public-site .public-section-heading h2 {
  max-width: 15ch;
  margin-inline: auto;
  letter-spacing: 0;
  text-wrap: balance;
}

.public-site .public-page-heading p,
.public-site .public-section-heading p {
  max-width: 43rem;
  margin-inline: auto;
  color: var(--brand-muted);
  font-weight: 550;
  line-height: 1.7;
}

.public-site .public-listing-page .public-page-heading {
  margin-bottom: clamp(2.2rem, 5vw, 4rem) !important;
}

.public-site .public-listing-page .public-page-heading h1 {
  max-width: 13ch;
  font-size: clamp(2.45rem, 5vw, 4.4rem);
  line-height: .98;
}

.public-site .public-post-grid-with-aside {
  row-gap: 1.55rem !important;
}

.public-site .public-post-grid-with-aside .public-post-card {
  box-shadow: 0 16px 38px rgba(17, 42, 34, .055) !important;
  transition: border-color .22s ease, box-shadow .22s ease, transform .22s ease;
}

.public-site .public-post-grid-with-aside .public-post-card:hover {
  border-color: rgba(13, 91, 66, .2) !important;
  box-shadow: 0 22px 46px rgba(17, 42, 34, .085) !important;
  transform: translateY(-2px);
}

.public-site .public-post-grid-with-aside .public-post-card h2 {
  font-size: clamp(1.08rem, 1.22vw, 1.36rem);
  line-height: 1.2;
}

.public-site .public-post-grid-with-aside .public-post-card p {
  font-size: .94rem;
  line-height: 1.58;
}

.public-site .public-post-grid-with-aside .public-post-card .d-flex.flex-wrap.gap-1 {
  gap: .32rem !important;
}

.public-site .public-post-grid-with-aside .public-post-card .badge.bg-light {
  padding: .3rem .48rem;
  font-size: .72rem;
}

.public-site .activity-aside-panel {
  background: rgba(255, 255, 255, .96);
  box-shadow: 0 14px 34px rgba(17, 42, 34, .052);
}

.public-site .activity-aside-category-list a,
.public-site .activity-aside-contributor-list li {
  background: rgba(248, 250, 247, .82);
}

.public-site .activity-aside-post-link {
  padding: .9rem 0;
}

.public-site .activity-aside-post-thumb {
  border-radius: 8px;
}

.public-site .activity-aside-post-title {
  font-size: .94rem;
  line-height: 1.36;
}

.public-site .public-article-header {
  max-width: 54rem;
  margin-bottom: 1.35rem !important;
  padding-bottom: 1.2rem;
  border-bottom-color: rgba(17, 42, 34, .1);
}

.public-site .public-article-header h1 {
  max-width: 20ch;
  margin-top: .55rem;
  margin-bottom: 1rem;
  font-size: clamp(1.9rem, 2.7vw, 2.65rem);
  line-height: 1.12;
}

.public-site .public-article-byline {
  margin-top: 0;
  margin-bottom: .85rem;
}

.public-site .public-article-byline img,
.public-site .public-article-byline-initial {
  width: 2.9rem;
  height: 2.9rem;
  flex-basis: 2.9rem;
}

.public-site .public-article-byline time {
  font-size: .92rem;
  font-weight: 650;
}

.public-site .public-article-share {
  width: fit-content;
  grid-template-columns: auto repeat(6, 2.15rem);
  gap: .36rem;
  margin-top: .4rem;
}

.public-site .public-article-share .activity-aside-share-button {
  width: 2.15rem;
  min-width: 2.15rem;
  height: 2.15rem;
  min-height: 2.15rem;
  box-shadow: none;
}

.public-site .public-article-media {
  margin: 0 0 2.05rem;
}

.public-site .public-article-media img {
  border-radius: 8px;
  box-shadow: none;
}

.public-site .public-article-media figcaption {
  display: grid;
  gap: .18rem;
  margin-top: .65rem;
  padding-bottom: .8rem;
  border-bottom: 1px solid rgba(17, 42, 34, .1);
}

.public-site .public-article-caption {
  color: var(--brand-muted);
  font-size: .86rem;
  line-height: 1.55;
}

.public-site .public-article-credit {
  color: rgba(17, 42, 34, .78);
  font-size: .75rem;
  font-weight: 850;
  letter-spacing: .02em;
}

.public-site .public-article-content {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  color: rgba(17, 42, 34, .86);
  font-size: clamp(1.02rem, 1.15vw, 1.12rem) !important;
  line-height: 1.82 !important;
}

.public-site .public-article-content> :first-child {
  margin-top: 0;
}

.public-site .public-article-content h2,
.public-site .public-article-content h3 {
  margin-top: 2rem;
  color: var(--brand-ink);
  line-height: 1.22;
}

.public-site .public-article-read-also {
  margin: 1.8rem 0;
  background: rgba(246, 248, 245, .86);
  border-left-color: var(--brand-gold);
}

.public-site .public-article-tags {
  margin-top: 2.1rem;
}

.public-site .public-article-tags a,
.public-site .activity-aside-tag-list a {
  border-radius: 8px;
}

.public-site .public-article-share-end {
  margin-top: 2rem;
}

.public-site .public-masyayikh-section {
  background: linear-gradient(180deg, rgba(246, 248, 245, .64), #fff 45%, rgba(246, 248, 245, .45));
}

.public-site .public-masyayikh-section .masyaikh-item {
  box-shadow: 0 16px 38px rgba(17, 42, 34, .06);
}

.public-site .public-masyayikh-section .masyaikh-img {
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.public-site .public-masyayikh-section .masyaikh-item h3,
.public-site .public-masyayikh-profile-heading h2 {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.public-site .public-gallery-section {
  background: #fff;
}

.public-site .homepage-gallery-item {
  background: #fff;
  border-color: rgba(17, 42, 34, .08);
  box-shadow: 0 12px 28px rgba(17, 42, 34, .055);
}

.public-site .homepage-gallery-img {
  filter: saturate(.96) contrast(1.01);
}

.public-site .registration-document,
.public-site .registration-notice-card,
.public-site .registration-masyaikh-card,
.public-site .registration-action-panel {
  box-shadow: 0 14px 34px rgba(17, 42, 34, .055);
}

.public-site .registration-flow-nav {
  background: rgba(255, 255, 255, .92);
  border-block: 1px solid rgba(17, 42, 34, .08);
}

.public-site .registration-notice-fee-table {
  box-shadow: none !important;
  border: 1px solid rgba(17, 42, 34, .09);
}

@media (max-width: 767.98px) {

  .public-site .public-listing-page .public-page-heading h1,
  .public-site .public-article-header h1 {
    max-width: 16ch;
    font-size: clamp(1.6rem, 7.4vw, 2.1rem);
  }

  .public-site .public-article-share {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .34rem;
  }

  .public-site .public-article-share .activity-share-label {
    flex: 0 0 100%;
    margin-bottom: .1rem;
  }

  .public-site .public-article-share .activity-aside-share-button {
    width: 2.25rem;
    min-width: 2.25rem;
    height: 2.25rem;
    min-height: 2.25rem;
  }

  .public-site .public-article-content {
    padding: 0;
  }
}

@media (max-width: 420px) {
  .public-site .public-article-share {
    gap: .3rem;
  }

  .public-site .public-article-share .activity-aside-share-button {
    width: 2.1rem;
    min-width: 2.1rem;
    height: 2.1rem;
    min-height: 2.1rem;
  }
}

/* Fase M3 - Navigation & Mobile Experience */
.public-site #header.public-navbar,
.public-site.scrolled #header.public-navbar {
  background: #fff;
  border-bottom-color: rgba(17, 42, 34, .08);
  box-shadow: 0 8px 24px rgba(17, 42, 34, .05);
  backdrop-filter: none;
}

.public-site #header .navbar-toggler {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.55rem;
  height: 2.55rem;
  padding: 0;
  color: var(--brand-green);
  background: #fff;
  border: 1px solid rgba(17, 42, 34, .1);
  border-radius: 8px;
  box-shadow: none;
}

.public-site #header .navbar-toggler:focus {
  box-shadow: var(--brand-focus-ring);
}

.public-site #header .navbar-nav .nav-link {
  position: relative;
  background: transparent;
  box-shadow: none;
  transition:
    color var(--brand-motion-base) var(--brand-ease),
    background-color var(--brand-motion-base) var(--brand-ease);
}

.public-site #header .navbar-nav .nav-link.active,
.public-site #header .navbar-nav .nav-link[aria-expanded="true"],
.public-site #header .navbar-nav .nav-link:hover,
.public-site #header .navbar-nav .nav-link:focus {
  color: var(--brand-green) !important;
  background: rgba(13, 91, 66, .075);
  box-shadow: none;
}

.public-site #header .navbar-nav .nav-dropdown-toggle::after {
  content: "" !important;
  display: inline-block !important;
  width: .36rem;
  height: .36rem;
  margin-left: .18rem;
  border: solid currentColor;
  border-width: 0 1.5px 1.5px 0;
  transform: translateY(-1px) rotate(45deg);
  transition: transform var(--brand-motion-base) var(--brand-ease);
}

.public-site #header .hs-has-mega-menu.mdq-mega-menu-opened>.nav-dropdown-toggle::after,
.public-site #header .nav-dropdown-toggle[aria-expanded="true"]::after {
  transform: translateY(2px) rotate(225deg);
}

.public-site .public-navbar-cta {
  background: var(--brand-green);
  border-color: var(--brand-green);
  box-shadow: 0 8px 20px rgba(13, 58, 44, .16);
}

.public-site .public-navbar-cta:hover,
.public-site .public-navbar-cta:focus {
  background: #0a3025;
  border-color: #0a3025;
  box-shadow: 0 10px 24px rgba(13, 58, 44, .18);
}

@media (min-width: 1200px) {
  .public-site #header.navbar-expand-xl .navbar-toggler {
    display: none;
  }

  .public-site #header .hs-has-mega-menu>.public-navbar-mega-menu {
    top: calc(var(--public-navbar-offset, 72px) - .02rem);
    padding: .52rem;
    background: #fff;
    border-color: rgba(17, 42, 34, .1);
    box-shadow: 0 20px 48px rgba(17, 42, 34, .11);
  }

  .public-site #header .hs-has-mega-menu>.public-navbar-mega-menu::before {
    content: "";
    position: absolute;
    inset: -1rem 0 auto;
    height: 1rem;
  }

  .public-site #header .public-navbar-more>.hs-mega-menu.hs-position-right {
    top: calc(100% + .28rem);
    right: 0;
    left: auto !important;
  }
}

@media (max-width: 1199.98px) {
  .public-site #header.public-navbar {
    padding-block: .42rem;
  }

  .public-site #header .navbar-nav-wrap {
    flex-wrap: wrap;
    gap: .6rem;
  }

  .public-site #header .navbar-collapse {
    flex-basis: 100%;
    width: 100%;
    max-width: min(32rem, 100%);
    max-height: min(74vh, 36rem);
    overflow-y: auto;
    overscroll-behavior: contain;
    margin-top: .45rem;
    margin-left: auto;
    padding: .75rem;
    background: #fff;
    border: 1px solid rgba(17, 42, 34, .1);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(17, 42, 34, .08);
  }

  .public-site #header .navbar-sticky-top-scroller {
    display: block;
    width: 100%;
  }

  .public-site .public-navbar-nav {
    display: grid;
    grid-template-columns: 1fr;
    gap: .35rem;
    width: 100%;
  }

  .public-site #header .navbar-sticky-top-scroller,
  .public-site .public-navbar-nav>.nav-item {
    width: 100%;
  }

  .public-site .public-navbar-theme-item {
    margin-left: 0;
    padding-top: .2rem;
  }

  .public-site .public-theme-toggle {
    width: 100%;
    justify-content: flex-start;
    min-height: 2.7rem;
    padding: .64rem .82rem;
    border-radius: 8px;
    font-size: .94rem;
  }

  .public-site .public-theme-toggle .mdq-theme-toggle-label {
    flex: 1 1 auto;
    text-align: left;
  }

  .public-site #header .navbar-nav .nav-link,
  .public-site .public-navbar-cta {
    justify-content: space-between;
    min-height: 2.7rem;
    padding: .72rem .82rem;
    border-radius: 8px;
    font-size: .94rem;
    text-align: left;
  }

  .public-site #header .navbar-nav .nav-link.active,
  .public-site #header .navbar-nav .nav-link[aria-expanded="true"] {
    background: rgba(13, 91, 66, .08);
  }

  .public-site #header .hs-has-mega-menu>.hs-mega-menu,
  .public-site #header .public-navbar-more-menu {
    position: static;
    width: 100%;
    min-width: 0 !important;
    max-width: 100%;
    margin-top: .35rem;
    padding: .5rem;
    transform: none !important;
    background: rgba(248, 250, 247, .9);
    border: 1px solid rgba(17, 42, 34, .08);
    border-radius: 8px;
    box-shadow: none;
  }

  .public-site #header .public-navbar-mega-menu .row {
    display: block;
    margin: 0;
  }

  .public-site #header .public-navbar-mega-menu [class*="col-"] {
    width: 100%;
    max-width: none;
    padding: 0;
  }

  .public-site #header .public-navbar-mega-menu .d-lg-block {
    display: none !important;
  }

  .public-site .public-navbar-mega-menu .navbar-dropdown-menu-inner,
  .public-site #header .public-navbar-more-menu .navbar-dropdown-menu-inner {
    gap: .25rem;
    padding: .35rem;
  }

  .public-site #header .public-navbar-mega-menu .dropdown-item,
  .public-site #header .public-navbar-more-menu .dropdown-item {
    min-height: 2.45rem;
    padding: .62rem .72rem;
    border-radius: 8px;
  }

  .public-site .public-nav-feature,
  .public-site .public-nav-download {
    box-shadow: none;
  }

  .public-site .public-navbar-cta-item {
    margin: .2rem 0 0;
  }
}

@media (max-width: 575.98px) {
  .public-site .public-navbar-logo-wrap {
    width: 2.55rem;
    height: 2.55rem;
  }

  .public-site #header .navbar-brand-logo {
    max-height: 2.5rem;
  }

  .public-site .public-navbar-brand-svg {
    height: 2rem;
    max-width: min(14rem, 52vw);
  }

  .public-site #header .navbar-collapse {
    max-height: calc(100vh - var(--public-navbar-offset, 4.5rem) - .75rem);
  }
}

/* Fase M4 - Media & Image Quality System */
.public-site .public-post-image,
.public-site .public-editor-activity-image,
.public-site .activity-aside-post-thumb,
.public-site .public-article-media,
.public-site .public-masyayikh-profile-media,
.public-site .homepage-gallery-link,
.public-site .registration-masyaikh-card {
  background:
    linear-gradient(135deg, rgba(13, 91, 66, .08), rgba(194, 143, 45, .08)),
    #f6f8f5;
}

.public-site .public-post-image,
.public-site .public-editor-activity-image,
.public-site .activity-aside-post-thumb {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 10;
}

.public-site .public-post-grid-with-aside .public-post-image,
.public-site .public-editor-activity-list .public-editor-activity-image {
  height: auto;
  min-height: 0;
  aspect-ratio: 16 / 10;
}

.public-site .public-post-image img,
.public-site .public-editor-activity-image img,
.public-site .activity-aside-post-thumb img,
.public-site .public-article-cover,
.public-site .homepage-gallery-img,
.public-site .masyaikh-img,
.public-site .public-masyayikh-profile-media img,
.public-site .registration-masyaikh-card img,
.public-site .public-editor-profile-avatar img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background-color: #f6f8f5;
}

.public-site .public-post-grid-with-aside .public-post-image img,
.public-site .public-editor-activity-list .public-editor-activity-image img {
  height: 100%;
}

.public-site .public-post-image img,
.public-site .public-editor-activity-image img,
.public-site .activity-aside-post-thumb img,
.public-site .homepage-gallery-img {
  object-position: center;
}

.public-site .public-article-cover {
  aspect-ratio: 16 / 9;
  max-height: none;
  object-position: center;
}

.public-site .public-article-media {
  overflow: hidden;
}

.public-site .public-article-media figcaption {
  background: #fff;
}

.public-site .activity-aside-post-thumb {
  aspect-ratio: 16 / 9;
}

.public-site .public-editor-activity-image {
  min-height: 8.5rem;
  border-radius: 8px;
}

.public-site .public-masyayikh-section .masyaikh-img,
.public-site .public-masyayikh-profile-media,
.public-site .public-masyayikh-profile-media img,
.public-site .registration-masyaikh-card img {
  aspect-ratio: 4 / 5;
  object-position: center top;
}

.public-site .registration-masyaikh-card img {
  width: 100%;
  height: auto;
  min-height: 13.5rem;
}

.public-site .homepage-gallery-link,
.public-site .homepage-gallery-img.gallery-orientation-landscape,
.public-site .homepage-gallery-img.gallery-orientation-square {
  aspect-ratio: 16 / 9;
}

.public-site .homepage-gallery-img.gallery-orientation-portrait {
  aspect-ratio: 3 / 4;
  object-position: center top;
}

.public-site .public-editor-profile-avatar,
.public-site .public-editor-profile-avatar img,
.public-site .public-editor-profile-avatar span {
  aspect-ratio: 1;
}

.public-site img[src$="placeholder-avatar.svg"] {
  object-fit: contain;
  padding: 12%;
  background:
    linear-gradient(135deg, rgba(13, 91, 66, .08), rgba(194, 143, 45, .08)),
    #f6f8f5;
}

@media (max-width: 767.98px) {
  .public-site .public-article-cover {
    aspect-ratio: 4 / 3;
  }

  .public-site .public-post-image,
  .public-site .public-editor-activity-image {
    aspect-ratio: 16 / 9;
  }
}

/* Fase M5 - Motion & Interaction Refinement */
body.public-site {
  --brand-motion-fast: 130ms;
  --brand-motion-base: 220ms;
  --brand-motion-reveal: 880ms;
  --brand-motion-slow: 760ms;
  --brand-motion-distance: 8px;
  --brand-ease: cubic-bezier(.2, .8, .2, 1);
  --brand-ease-reveal: cubic-bezier(.16, 1, .3, 1);
}

.public-site .mdq-repeat-aos-item {
  transition-duration: var(--brand-motion-reveal);
  transition-timing-function: var(--brand-ease-reveal);
}

.public-site .mdq-repeat-aos-item.mdq-aos-scroll-down:not(.aos-animate) {
  transform: translate3d(0, var(--brand-motion-distance), 0);
}

.public-site .mdq-repeat-aos-item.mdq-aos-scroll-up:not(.aos-animate) {
  transform: translate3d(0, calc(var(--brand-motion-distance) * -1), 0);
}

.public-site .hs-mega-menu {
  opacity: 0;
  transform: translateY(6px);
  transform-origin: top center;
  transition:
    opacity var(--brand-motion-base) var(--brand-ease),
    transform var(--brand-motion-base) var(--brand-ease),
    visibility var(--brand-motion-base) var(--brand-ease);
}

.public-site .hs-has-mega-menu.mdq-mega-menu-opened>.hs-mega-menu {
  opacity: 1;
  transform: translateY(0);
}

.public-site .public-post-card,
.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .public-masyayikh-profile-card,
.public-site .public-editor-card,
.public-site .registration-masyaikh-card,
.public-site .public-code-card,
.public-site .public-class-day,
.public-site .activity-aside-panel {
  transition:
    transform var(--brand-motion-base) var(--brand-ease),
    box-shadow var(--brand-motion-base) var(--brand-ease),
    border-color var(--brand-motion-base) var(--brand-ease),
    background-color var(--brand-motion-base) var(--brand-ease);
}

@media (hover: hover) {

  .public-site .btn:hover,
  .public-site .public-nav-download:hover,
  .public-site .floating-social-link:hover,
  .public-site .registration-flow-list a:hover,
  .public-site .public-article-share .activity-aside-share-button:hover {
    transform: translateY(-1px);
  }

  .public-site .public-feature-card:hover,
  .public-site .public-stat-card:hover,
  .public-site .registration-masyaikh-card:hover,
  .public-site .public-code-card:hover,
  .public-site .public-class-day:hover,
  .public-site .public-editor-card:hover,
  .public-site .public-masyayikh-profile-card:hover,
  .public-site .public-post-grid-with-aside .public-post-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 12px 30px rgba(17, 42, 34, .075) !important;
  }

  .public-site .public-hero-media:hover .public-hero-image {
    transform: translateY(-1px);
    box-shadow: 0 18px 42px rgba(19, 43, 32, .12);
  }

  .public-site .public-post-card:hover .public-post-image img,
  .public-site .activity-aside-post-link:hover .activity-aside-post-thumb img,
  .public-site .public-editor-activity:hover .public-editor-activity-image img,
  .public-site .homepage-gallery-link:hover .homepage-gallery-img {
    transform: scale(1.018);
  }

  .public-site .activity-carousel-nav:hover,
  .public-site .activity-carousel-nav:focus-visible {
    transform: translateY(-50%) scale(1.015);
  }

  .public-site .activity-carousel-pagination .swiper-pagination-bullet:hover,
  .public-site .activity-carousel-pagination .swiper-pagination-bullet:focus-visible {
    transform: translateY(-1px) scale(1.04);
  }
}

.public-site.mdq-cinema-enabled .mdq-cinema-section {
  opacity: 1;
  transform: translateY(6px);
  filter: none;
  transition:
    opacity var(--brand-motion-slow) var(--brand-ease-reveal),
    transform var(--brand-motion-slow) var(--brand-ease-reveal);
  will-change: opacity, transform;
}

.public-site.mdq-cinema-enabled .mdq-cinema-section.mdq-cinema-visible {
  opacity: 1;
  transform: none;
}

.public-site.mdq-cinema-enabled .homepage-gallery-track {
  animation-duration: 62s !important;
}

@media (max-width: 1199.98px) {
  .public-site.mdq-cinema-enabled .mdq-cinema-section {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}

@media (prefers-color-scheme: dark) and (min-width: 999999px) {
  body.public-site {
    color-scheme: dark;
    --background-color: #07110d;
    --default-color: #c9d8d0;
    --heading-color: #eff8f2;
    --surface-color: #10231d;
    --brand-ink: #eff8f2;
    --brand-muted: #a8b8af;
    --brand-bg: #0c1b15;
    --brand-panel: #10231d;
    --brand-border: rgba(231, 239, 233, .12);
    --brand-shadow: 0 18px 46px rgba(0, 0, 0, .28);
    --brand-shadow-strong: 0 28px 72px rgba(0, 0, 0, .34);
    background:
      linear-gradient(180deg, rgba(15, 61, 46, .3), transparent 22rem),
      var(--background-color);
  }

  .public-site .text-dark {
    color: var(--brand-ink) !important;
  }

  .public-site .text-body,
  .public-site .text-body-secondary {
    color: var(--brand-muted) !important;
  }

  .public-site #header.public-navbar,
  .public-site.scrolled #header.public-navbar {
    background: rgba(9, 26, 19, .86);
    border-color: var(--brand-border);
  }

  .public-site #header .navbar-nav .nav-link {
    color: var(--brand-ink);
  }

  .public-site #header .dropdown-header {
    color: var(--brand-muted);
  }

  .public-site #header .dropdown-menu,
  .public-site #header .hs-mega-menu,
  .public-site .card,
  .public-site .public-feature-card,
  .public-site .public-stat-card,
  .public-site .public-nav-feature,
  .public-site .public-nav-download,
  .public-site .public-gallery-section,
  .public-site .public-contact-panel,
  .public-site .registration-logo-row,
  .public-site .registration-intro-card,
  .public-site .registration-notice-card,
  .public-site .registration-document,
  .public-site .registration-masyaikh-card,
  .public-site .public-masyayikh-profile-card,
  .public-site .activity-aside-panel,
  .public-site .public-code-card,
  .public-site .public-class-day,
  .public-site .floating-social-menu {
    color: var(--default-color);
    background: var(--brand-panel) !important;
    border-color: var(--brand-border) !important;
  }

  .public-site .public-hero,
  .public-site .public-stats-section {
    background:
      linear-gradient(135deg, rgba(15, 61, 46, .4), rgba(7, 17, 13, .96)),
      var(--background-color);
  }

  .public-site .public-hero-mini-stats span,
  .public-site .public-hero-quote,
  .public-site .public-class-picker,
  .public-site .public-code-list span,
  .public-site .registration-empty-note,
  .public-site .public-masyayikh-profile-details div,
  .public-site .public-masyayikh-profile-note,
  .public-site .homepage-gallery-item {
    background: rgba(255, 255, 255, .06) !important;
    border-color: var(--brand-border) !important;
  }

  .public-site .form-control,
  .public-site .form-select {
    color: var(--brand-ink);
    background-color: #0b1b14;
    border-color: var(--brand-border);
  }
}

@media (prefers-reduced-motion: reduce) {

  .public-site *,
  .public-site *::before,
  .public-site *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }

  .public-site [data-aos],
  .public-site [data-aos].aos-animate {
    opacity: 1 !important;
    transform: none !important;
    transition-delay: 0ms !important;
  }

  .public-site .homepage-gallery-track,
  .public-site .swiper-wrapper,
  .public-site .js-swiper-autoplay .swiper-wrapper {
    animation: none !important;
    transform: none !important;
  }

  .public-site.mdq-motion-ready .mdq-reveal:not(.mdq-inview),
  .public-site.mdq-motion-ready .mdq-reveal {
    opacity: 1 !important;
    transform: none !important;
  }

  .public-site.mdq-cinema-enabled {
    scroll-behavior: auto !important;
  }

  .public-site.mdq-cinema-enabled .mdq-cinema-section,
  .public-site.mdq-cinema-enabled.mdq-scroll-down #header.public-navbar {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }

  .public-site.mdq-cinema-enabled .public-home-hero,
  .public-site.mdq-cinema-enabled .public-registration-hero,
  .public-site.mdq-cinema-enabled .public-founder-section,
  .public-site.mdq-cinema-enabled .public-stats-section,
  .public-site.mdq-cinema-enabled .registration-contact-section,
  .public-site.mdq-cinema-enabled .public-cta-band {
    background-attachment: scroll !important;
  }
}

.public-site .public-editors-page,
.public-site .public-editor-profile-page {
  background:
    linear-gradient(180deg, rgba(246, 249, 245, .86), rgba(255, 255, 255, 0) 18rem),
    #fff;
}

.public-site .public-editor-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 31rem);
  gap: clamp(1.25rem, 4vw, 3.5rem);
  align-items: end;
  margin-bottom: clamp(1.4rem, 4vw, 2.6rem);
}

.public-site .public-editor-hero h1,
.public-site .public-editor-profile-header h1 {
  max-width: 12ch;
  margin: .45rem 0 .85rem;
  color: var(--brand-ink);
  font-size: clamp(2.35rem, 5vw, 4.8rem);
  font-weight: 900;
  line-height: 1.02;
  letter-spacing: 0;
}

.public-site .public-editor-hero p,
.public-site .public-editor-profile-header p,
.public-site .public-editor-writing-heading p {
  max-width: 45rem;
  margin: 0;
  color: var(--brand-muted);
  font-size: clamp(1rem, 1.7vw, 1.15rem);
  line-height: 1.75;
}

.public-site .public-editor-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(11rem, auto) auto;
  gap: .7rem;
  padding: .75rem;
  background: rgba(255, 255, 255, .82);
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
  box-shadow: 0 1.35rem 3rem rgba(13, 36, 27, .08);
  backdrop-filter: blur(16px);
}

.public-site .public-editor-toolbar .form-control,
.public-site .public-editor-toolbar .form-select,
.public-site .public-editor-toolbar .btn {
  min-height: 3.15rem;
  border-radius: .75rem;
  font-weight: 800;
}

.public-site .public-editor-toolbar .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  padding-inline: 1.25rem;
}

.public-site .public-editor-statline {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  margin-bottom: clamp(1.25rem, 4vw, 2.4rem);
  overflow: hidden;
  background: var(--brand-border);
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
}

.public-site .public-editor-statline div {
  padding: clamp(1rem, 2vw, 1.35rem);
  background: rgba(255, 255, 255, .88);
}

.public-site .public-editor-statline span {
  display: block;
  color: var(--brand-green);
  font-size: clamp(1.65rem, 3vw, 2.35rem);
  font-weight: 900;
  line-height: 1;
}

.public-site .public-editor-statline strong {
  display: block;
  margin-top: .35rem;
  color: var(--brand-muted);
  font-size: .82rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-editor-leaderboards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: clamp(1.6rem, 5vw, 3rem);
}

.public-site .public-editor-board {
  padding: clamp(1.1rem, 3vw, 1.6rem);
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
  box-shadow: 0 1rem 2.6rem rgba(13, 36, 27, .07);
}

.public-site .public-editor-board-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .9rem;
}

.public-site .public-editor-board-heading span {
  color: var(--brand-gold);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.public-site .public-editor-board h2 {
  margin: 0;
  color: var(--brand-ink);
  font-size: clamp(1.25rem, 2vw, 1.55rem);
  font-weight: 900;
}

.public-site .public-editor-board ol {
  display: grid;
  gap: .55rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.public-site .public-editor-board li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .75rem;
  align-items: center;
  min-height: 3rem;
  padding: .5rem .65rem;
  background: rgba(246, 249, 245, .7);
  border-radius: .8rem;
}

.public-site .public-editor-rank {
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .1);
  border-radius: 50%;
  font-weight: 900;
}

.public-site .public-editor-board-name {
  min-width: 0;
  overflow: hidden;
  color: var(--brand-ink);
  font-weight: 850;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.public-site .public-editor-board strong {
  color: var(--brand-muted);
  font-size: .9rem;
  white-space: nowrap;
}

.public-site .public-editor-board-empty {
  grid-template-columns: minmax(0, 1fr) !important;
  color: var(--brand-muted);
  font-weight: 700;
}

.public-site .public-editor-directory {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2.5vw, 1.4rem);
}

.public-site .public-editor-card {
  display: grid;
  grid-template-columns: 5.25rem minmax(0, 1fr);
  gap: 1rem;
  min-height: 17rem;
  padding: 1.1rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
  box-shadow: 0 1rem 2.5rem rgba(13, 36, 27, .07);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.public-site .public-editor-card:hover {
  transform: translateY(-3px);
  border-color: rgba(13, 91, 66, .24);
  box-shadow: 0 1.4rem 3.2rem rgba(13, 36, 27, .1);
}

.public-site .public-editor-card-media img,
.public-site .public-editor-card-media span {
  display: block;
  width: 5.25rem;
  height: 5.25rem;
  border-radius: 1rem;
}

.public-site .public-editor-card-media img {
  object-fit: cover;
  background: rgba(13, 91, 66, .08);
}

.public-site .public-editor-card-media span {
  display: grid;
  place-items: center;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .1);
  font-size: 2rem;
  font-weight: 900;
}

.public-site .public-editor-card-body {
  display: grid;
  min-width: 0;
}

.public-site .public-editor-card-heading {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
}

.public-site .public-editor-card-heading h2 {
  margin: 0;
  color: var(--brand-ink);
  font-size: 1.08rem;
  font-weight: 900;
  line-height: 1.25;
}

.public-site .public-editor-card-heading p {
  margin: .25rem 0 0;
  color: var(--brand-muted);
  font-size: .9rem;
  line-height: 1.45;
}

.public-site .public-editor-card-heading span {
  align-self: start;
  padding: .28rem .55rem;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .08);
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 900;
  white-space: nowrap;
}

.public-site .public-editor-card-bio {
  display: -webkit-box;
  margin: .85rem 0 1rem;
  overflow: hidden;
  color: var(--brand-muted);
  font-size: .94rem;
  line-height: 1.6;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.public-site .public-editor-card-bio.is-muted {
  color: rgba(101, 118, 109, .78);
}

.public-site .public-editor-card-stats {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: auto;
}

.public-site .public-editor-card-stats span {
  padding: .45rem .62rem;
  color: var(--brand-muted);
  background: rgba(246, 249, 245, .95);
  border-radius: .7rem;
  font-size: .84rem;
}

.public-site .public-editor-card-stats strong {
  color: var(--brand-ink);
}

.public-site .public-editor-card-link,
.public-site .public-editor-card-note {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-top: 1rem;
  color: var(--brand-green);
  font-weight: 900;
  text-decoration: none;
}

.public-site .public-editor-card-note {
  color: var(--brand-muted);
  font-size: .9rem;
}

.public-site .public-editor-back {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-bottom: 1.5rem;
  color: var(--brand-green);
  font-weight: 900;
  text-decoration: none;
}

.public-site .public-editor-profile-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(15rem, 22rem);
  gap: clamp(1.25rem, 4vw, 3rem);
  align-items: end;
  margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
  padding-bottom: clamp(1.25rem, 4vw, 2rem);
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-editor-profile-identity {
  display: flex;
  gap: clamp(1rem, 3vw, 1.5rem);
  align-items: center;
}

.public-site .public-editor-profile-avatar img,
.public-site .public-editor-profile-avatar span {
  display: block;
  width: clamp(5.5rem, 11vw, 8rem);
  height: clamp(5.5rem, 11vw, 8rem);
  border-radius: 1.25rem;
}

.public-site .public-editor-profile-avatar img {
  object-fit: cover;
  background: rgba(13, 91, 66, .08);
}

.public-site .public-editor-profile-avatar span {
  display: grid;
  place-items: center;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .1);
  font-size: clamp(2.2rem, 5vw, 3.4rem);
  font-weight: 900;
}

.public-site .public-editor-profile-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  background: var(--brand-border);
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
}

.public-site .public-editor-profile-stats div {
  padding: 1.15rem;
  background: rgba(255, 255, 255, .9);
}

.public-site .public-editor-profile-stats span {
  display: block;
  color: var(--brand-green);
  font-size: 2rem;
  font-weight: 900;
  line-height: 1;
}

.public-site .public-editor-profile-stats strong {
  display: block;
  margin-top: .4rem;
  color: var(--brand-muted);
  font-size: .77rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-editor-profile-layout {
  display: grid;
  grid-template-columns: minmax(17rem, 24rem) minmax(0, 1fr);
  gap: clamp(1.25rem, 4vw, 2.6rem);
  align-items: start;
}

.public-site .public-editor-profile-panel {
  position: sticky;
  top: 7rem;
  padding: 1.25rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
  box-shadow: 0 1rem 2.5rem rgba(13, 36, 27, .07);
}

.public-site .public-editor-profile-panel h2,
.public-site .public-editor-writing-heading h2 {
  margin: 0 0 1rem;
  color: var(--brand-ink);
  font-size: clamp(1.45rem, 2.4vw, 2.05rem);
  font-weight: 900;
}

.public-site .public-editor-profile-panel dl {
  display: grid;
  gap: 0;
  margin: 0;
}

.public-site .public-editor-profile-panel dl div {
  display: grid;
  gap: .25rem;
  padding: .85rem 0;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-editor-profile-panel dl div:last-child {
  border-bottom: 0;
}

.public-site .public-editor-profile-panel dt {
  color: var(--brand-muted);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-editor-profile-panel dd,
.public-site .public-editor-profile-panel p {
  margin: 0;
  color: var(--brand-ink);
  font-weight: 800;
  line-height: 1.55;
}

.public-site .public-editor-writing-heading {
  margin-bottom: 1.1rem;
}

.public-site .public-editor-activity-list {
  display: grid;
  gap: 1rem;
}

.public-site .public-editor-activity {
  display: grid;
  grid-template-columns: minmax(10rem, 16rem) minmax(0, 1fr);
  gap: 1.1rem;
  padding: 1rem;
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: 1rem;
  box-shadow: 0 .8rem 2rem rgba(13, 36, 27, .06);
}

.public-site .public-editor-activity-no-image {
  grid-template-columns: minmax(0, 1fr);
}

.public-site .public-editor-activity-image {
  display: block;
  overflow: hidden;
  min-height: 10rem;
  background: rgba(13, 91, 66, .08);
  border-radius: .85rem;
}

.public-site .public-editor-activity-image img {
  width: 100%;
  height: 100%;
  min-height: 10rem;
  object-fit: cover;
  transition: transform .24s ease;
}

.public-site .public-editor-activity:hover .public-editor-activity-image img {
  transform: scale(1.035);
}

.public-site .public-editor-activity-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  align-items: center;
  margin-bottom: .45rem;
  color: var(--brand-muted);
  font-size: .88rem;
  font-weight: 800;
}

.public-site .public-editor-activity-meta span {
  padding: .25rem .55rem;
  color: var(--brand-green);
  background: rgba(13, 91, 66, .08);
  border-radius: 999px;
}

.public-site .public-editor-activity h3 {
  margin: 0 0 .45rem;
  color: var(--brand-ink);
  font-size: clamp(1.2rem, 2vw, 1.7rem);
  font-weight: 900;
  line-height: 1.2;
}

.public-site .public-editor-activity h3 a {
  color: inherit;
  text-decoration: none;
}

.public-site .public-editor-activity h3 a:hover {
  color: var(--brand-green);
}

.public-site .public-editor-activity p {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--brand-muted);
  line-height: 1.65;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

@media (max-width: 1199.98px) {
  .public-site .public-editor-directory {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991.98px) {

  .public-site .public-editor-hero,
  .public-site .public-editor-leaderboards,
  .public-site .public-editor-profile-header,
  .public-site .public-editor-profile-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .public-site .public-editor-profile-panel {
    position: static;
  }
}

@media (max-width: 767.98px) {

  .public-site .public-editor-toolbar,
  .public-site .public-editor-statline,
  .public-site .public-editor-directory,
  .public-site .public-editor-profile-stats,
  .public-site .public-editor-activity {
    grid-template-columns: minmax(0, 1fr);
  }

  .public-site .public-editor-card {
    grid-template-columns: minmax(0, 1fr);
    min-height: 0;
  }

  .public-site .public-editor-card-media img,
  .public-site .public-editor-card-media span {
    width: 4.8rem;
    height: 4.8rem;
    border-radius: 50%;
  }

  .public-site .public-editor-profile-identity {
    align-items: flex-start;
    flex-direction: column;
  }

  .public-site .public-editor-board li {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .public-site .public-editor-board strong {
    grid-column: 2;
  }
}

/*--------------------------------------------------------------
# Fase M7 - Content Tone & Trust Layer
--------------------------------------------------------------*/
.public-site .public-article-trustline {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem .9rem;
  padding-top: .85rem;
  margin-top: .95rem;
  border-top: 1px solid var(--brand-border-soft);
  color: var(--brand-muted);
  font-size: .88rem;
  line-height: 1.5;
}

.public-site .public-article-trustline span {
  display: inline-flex;
  align-items: center;
  gap: .38rem;
}

.public-site .public-article-trustline i {
  color: var(--brand-gold);
  font-size: .95rem;
}

.public-site .public-empty-state p,
.public-site .public-map-empty p {
  max-width: 34rem;
  margin: .45rem auto 0;
  color: var(--brand-muted);
}

.public-site .public-footer-kicker,
.public-site .activity-aside-kicker,
.public-site .public-section-kicker {
  text-wrap: balance;
}

/* Fase M8 - Global Editorial Restraint */
body.public-site {
  --brand-panel: #fff;
  --brand-panel-soft: #fcfdfb;
  --brand-border: rgba(16, 35, 29, .11);
  --brand-border-strong: rgba(16, 35, 29, .17);
  --brand-shadow: none;
  --brand-shadow-strong: 0 8px 22px rgba(19, 43, 32, .055);
  --brand-shadow-hover: 0 8px 20px rgba(19, 43, 32, .06);
  --brand-radius: 5px;
  --brand-radius-sm: 4px;
  --brand-radius-lg: 6px;
  --brand-section-space: clamp(3.5rem, 5.5vw, 5.5rem);
  --brand-page-title: clamp(2.1rem, 3.7vw, 3.35rem);
  --brand-section-title: clamp(1.55rem, 2.35vw, 2.2rem);
  background: #fff;
}

.public-site .public-page-heading {
  max-width: 48rem;
  margin-bottom: clamp(2.25rem, 4vw, 3.35rem) !important;
}

.public-site .public-section-heading {
  max-width: 46rem;
}

.public-site .public-page-heading h1,
.public-site .public-section-heading h2 {
  max-width: 21ch;
  line-height: 1.12;
}

.public-site .public-listing-page .public-page-heading h1 {
  max-width: 20ch;
  font-size: var(--brand-page-title);
  line-height: 1.1;
}

.public-site .public-page-heading p,
.public-site .public-section-heading p {
  max-width: 42rem;
  font-weight: 400;
  line-height: 1.65;
}

.public-site .public-section-kicker,
.public-site .activity-aside-kicker,
.public-site .public-footer-kicker {
  color: #8b7040;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.public-site .public-section-kicker::before,
.public-site .public-section-kicker::after,
.public-site .public-page-heading .public-section-kicker::before,
.public-site .public-page-heading .public-section-kicker::after,
.public-site .public-section-heading.text-center .public-section-kicker::before,
.public-site .public-section-heading.text-center .public-section-kicker::after,
.public-site .public-home-hero .public-section-kicker::before,
.public-site .public-home-hero .public-section-kicker::after {
  display: none !important;
}

.public-site .btn {
  min-height: 2.7rem;
  padding: .72rem 1.1rem;
  border-radius: var(--brand-radius);
  font-weight: 680;
  box-shadow: none !important;
}

.public-site .badge,
.public-site .activity-aside-tag-list a,
.public-site .public-article-tags a,
.public-site .public-active-filters span {
  border-radius: var(--brand-radius-sm);
  box-shadow: none;
  font-weight: 600;
}

.public-site .card,
.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .registration-masyaikh-card,
.public-site .registration-action-panel,
.public-site .public-schedule-panel,
.public-site .public-class-section,
.public-site .public-post-card,
.public-site .public-empty-state,
.public-site .public-map-empty,
.public-site .activity-aside-panel,
.public-site .public-masyayikh-profile-card,
.public-site .public-editor-card,
.public-site .public-editor-board,
.public-site .public-editor-toolbar,
.public-site .registration-document {
  background: var(--brand-panel);
  border: 1px solid var(--brand-border) !important;
  border-radius: var(--brand-radius);
  box-shadow: none !important;
  backdrop-filter: none;
}

.public-site .public-feature-card,
.public-site .public-stat-card,
.public-site .registration-document,
.public-site .public-schedule-panel,
.public-site .activity-aside-panel,
.public-site .public-editor-board {
  background: var(--brand-panel-soft);
}

.public-site .public-stat-card,
.public-site .public-editor-statline {
  border-color: var(--brand-border) !important;
}

.public-site .public-editor-statline {
  border-radius: 0;
  border-inline: 0;
  box-shadow: none;
}

@media (hover: hover) {

  .public-site .btn:hover,
  .public-site .public-feature-card:hover,
  .public-site .public-stat-card:hover,
  .public-site .registration-masyaikh-card:hover,
  .public-site .public-code-card:hover,
  .public-site .public-class-day:hover,
  .public-site .public-editor-card:hover,
  .public-site .public-masyayikh-profile-card:hover,
  .public-site .public-post-grid-with-aside .public-post-card:hover {
    transform: none;
    box-shadow: none !important;
    border-color: var(--brand-border-strong) !important;
  }
}

.public-site #header.public-navbar,
.public-site.scrolled #header.public-navbar {
  border-bottom-color: var(--brand-border);
  box-shadow: none;
}

.public-site #header .navbar-nav .nav-link {
  border-radius: 0;
  font-weight: 600;
}

.public-site #header .navbar-nav .nav-link.active,
.public-site #header .navbar-nav .nav-link[aria-expanded="true"],
.public-site #header .navbar-nav .nav-link:hover,
.public-site #header .navbar-nav .nav-link:focus {
  background: transparent;
  box-shadow: inset 0 -2px 0 var(--brand-green);
}

@media (max-width: 1199.98px) {
  .public-site #header .navbar-nav .nav-link.active,
  .public-site #header .navbar-nav .nav-link[aria-expanded="true"],
  .public-site #header .navbar-nav .nav-link:hover,
  .public-site #header .navbar-nav .nav-link:focus {
    background: rgba(13, 91, 66, .075);
    box-shadow: none !important;
  }
}

.public-site #header .dropdown-menu,
.public-site #header .hs-mega-menu,
.public-site #header .public-navbar-more-menu {
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow-strong);
}

.public-site .public-nav-feature,
.public-site .public-nav-download {
  background: #fff;
  box-shadow: none;
  border-radius: var(--brand-radius);
}

.public-site .public-home-hero .public-hero-quote,
.public-site .public-home-hero .public-hero-mini-stats span {
  border-radius: var(--brand-radius);
  background: rgba(255, 255, 255, .96);
  box-shadow: none;
  backdrop-filter: none;
}

.public-site .registration-hero-card {
  background: rgba(9, 31, 24, .72);
  border-color: rgba(255, 255, 255, .22);
  border-radius: var(--brand-radius);
  box-shadow: none;
  backdrop-filter: none;
}

.public-site .registration-flow-list a,
.public-site .public-schedule-tabs button {
  border-radius: var(--brand-radius);
  box-shadow: none;
}

.public-site .public-cta-band,
.public-site .bg-gradient-green.public-cta-band {
  background: var(--brand-green) !important;
}

.public-site .public-cta-band::before {
  display: none;
}

.public-site .public-cta-band .content-space-1 {
  padding-block: clamp(2.7rem, 4vw, 3.5rem);
}

footer.bg-dark.public-footer {
  background: #10372b !important;
  border-top: 0;
}

.public-footer {
  padding-block: clamp(2.5rem, 4vw, 3.5rem) 1.25rem;
}

.public-footer::before {
  display: none;
}

.public-footer-hero {
  padding-bottom: clamp(1.35rem, 2.4vw, 1.8rem);
}

.public-footer-brand img {
  width: 3.85rem;
  height: 3.85rem;
  padding: .3rem;
  border-radius: var(--brand-radius);
  box-shadow: none;
}

.public-footer h2 {
  margin-bottom: .25rem;
  font-size: clamp(1.45rem, 2vw, 1.8rem);
  font-weight: 700;
  text-shadow: none;
}

.public-footer-main {
  gap: clamp(1.2rem, 3vw, 2.8rem);
  padding-block: clamp(1.35rem, 2.5vw, 1.8rem);
}

.public-footer-panel {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.public-footer-links {
  grid-template-columns: 1fr;
  gap: .42rem;
}

.public-footer-contact li,
.public-footer-social {
  gap: .48rem;
}

.public-footer-links a,
.public-footer-social a {
  font-weight: 500;
}

.public-footer-bottom p {
  font-size: .86rem;
}

@media (max-width: 991.98px) {
  .public-site #header .navbar-nav .nav-link {
    border-radius: var(--brand-radius);
  }

  .public-site #header .navbar-nav .nav-link.active,
  .public-site #header .navbar-nav .nav-link[aria-expanded="true"] {
    background: rgba(13, 91, 66, .06);
    box-shadow: none;
  }
}

@media (max-width: 767.98px) {
  body.public-site {
    --brand-page-title: clamp(1.85rem, 8vw, 2.25rem);
    --brand-section-title: clamp(1.4rem, 6.5vw, 1.8rem);
  }

  .public-site .public-section,
  .public-site .content-space-1,
  .public-site .content-space-2 {
    padding-block: clamp(2.6rem, 9vw, 3.4rem);
  }
}

/* Fase M9 - Public Primary Pages */
.public-site .public-home-hero {
  padding-block: clamp(3rem, 5vw, 4.65rem);
  background: #fff;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-home-hero::after {
  display: none;
}

.public-site .public-home-hero .public-hero-copy {
  padding-block: 0;
}

.public-site .public-home-hero .public-hero-copy h1 {
  max-width: 11ch;
  margin-bottom: 1.15rem !important;
  font-size: clamp(2.7rem, 4.9vw, 4.2rem);
  letter-spacing: -.035em;
}

.public-site .public-home-hero .public-hero-copy h2 {
  max-width: 28rem;
  color: var(--brand-green);
  font-size: clamp(1.06rem, 1.5vw, 1.22rem);
  font-weight: 650;
  line-height: 1.5;
}

.public-site .public-home-hero .public-hero-copy p {
  max-width: 30rem;
  color: var(--brand-muted);
  line-height: 1.68;
}

.public-site .public-hero-facts {
  display: flex;
  gap: clamp(1.1rem, 3vw, 2.2rem);
  margin: 0;
  padding: 1rem 0 0;
  border-top: 1px solid var(--brand-border);
}

.public-site .public-hero-facts div {
  display: grid;
  gap: .15rem;
  max-width: 10.5rem;
}

.public-site .public-hero-facts dt {
  color: var(--brand-ink);
  font-family: var(--heading-font, inherit);
  font-size: clamp(1.7rem, 2.5vw, 2.1rem);
  font-weight: 700;
  line-height: 1;
}

.public-site .public-hero-facts dd {
  margin: 0;
  color: var(--brand-muted);
  font-size: .85rem;
  line-height: 1.45;
}

.public-site .public-home-hero .public-hero-media {
  display: grid;
  gap: 1rem;
  max-width: 37rem;
}

.public-site .public-home-hero .public-hero-image {
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: none;
}

.public-site .public-home-hero .public-hero-image img {
  aspect-ratio: 5 / 4;
  object-position: center;
}

.public-site .public-home-hero .public-hero-quote {
  position: static !important;
  display: grid;
  gap: .45rem;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: .9rem 0 0 1.15rem;
  color: var(--brand-ink);
  background: transparent;
  border: 0;
  border-left: 2px solid #b9934a;
  border-radius: 0;
}

.public-site .public-home-hero .public-hero-quote blockquote {
  margin: 0;
  font-family: var(--heading-font, inherit);
  font-size: clamp(1.03rem, 1.45vw, 1.15rem);
  font-weight: 620;
  line-height: 1.48;
}

.public-site .public-home-hero .public-hero-quote figcaption {
  color: var(--brand-muted);
  font-size: .85rem;
  line-height: 1.45;
}

.public-site .public-activity-feed-section {
  padding-block: clamp(3.2rem, 5vw, 5rem);
  background: #fff;
}

.public-site .public-activity-feed-section .public-section-heading {
  max-width: 49rem;
  margin-inline: 0;
  text-align: left;
}

.public-site .home-publication-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(18.5rem, .8fr);
  gap: clamp(1.4rem, 3vw, 2.4rem);
  padding-top: .15rem;
}

.public-site .home-publication-feature {
  display: grid;
  gap: 1.05rem;
  color: inherit;
  text-decoration: none;
}

.public-site .home-publication-feature img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
}

.public-site .home-publication-label {
  display: block;
  margin-bottom: .42rem;
  color: #8b7040;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.public-site .home-publication-feature h3 {
  max-width: 25ch;
  margin: 0 0 .55rem;
  color: var(--brand-ink);
  font-size: clamp(1.42rem, 2.15vw, 1.9rem);
  font-weight: 700;
  line-height: 1.22;
}

.public-site .home-publication-feature p,
.public-site .home-publication-item p {
  margin: 0;
  color: var(--brand-muted);
  line-height: 1.6;
}

.public-site .home-publication-list {
  display: grid;
  align-content: start;
  gap: 0;
  border-top: 1px solid var(--brand-border);
}

.public-site .home-publication-item {
  display: grid;
  grid-template-columns: 6.7rem minmax(0, 1fr);
  gap: .9rem;
  padding-block: .95rem;
  color: inherit;
  border-bottom: 1px solid var(--brand-border);
  text-decoration: none;
}

.public-site .home-publication-item img {
  display: block;
  width: 100%;
  height: 4.7rem;
  object-fit: cover;
  border-radius: 3px;
}

.public-site .home-publication-item h3 {
  margin: 0;
  color: var(--brand-ink);
  font-size: 1.02rem;
  font-weight: 670;
  line-height: 1.38;
}

.public-site .home-publication-item p {
  display: none;
}

.public-site .home-publication-index {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  width: fit-content;
  margin-top: 1.05rem;
  color: var(--brand-green);
  font-size: .9rem;
  font-weight: 650;
  text-decoration: none;
}

.public-site .public-feature-strip {
  padding-top: 0;
}

.public-site .public-feature-card {
  padding-inline: 0;
  border: 0 !important;
  border-top: 1px solid var(--brand-border) !important;
  border-radius: 0;
  background: transparent;
}

.public-site .public-feature-card img {
  width: 3rem !important;
  height: 3rem;
  padding: .35rem;
  border-radius: 0;
}

.public-site .public-registration-hero .hero-image {
  padding-top: 0;
  background:
    linear-gradient(90deg, rgba(7, 29, 21, .93) 0%, rgba(7, 29, 21, .82) 38%, rgba(7, 29, 21, .18) 100%),
    var(--registration-hero-image, url("../img/backgrounds/modern-section-haul-stage.jpg")) center / cover no-repeat;
}

.public-site .public-registration-hero .hero-image>.container {
  min-height: clamp(29rem, 43vw, 35rem) !important;
}

.public-site .registration-hero-card {
  width: min(100%, 37rem);
  max-width: 37rem;
  padding: 0;
  background: transparent;
  border: 0;
}

.public-site .registration-hero-card h1 {
  max-width: 12ch;
  margin-block: .65rem .85rem;
  font-size: clamp(2.45rem, 4.6vw, 3.7rem);
  line-height: 1.08;
}

.public-site .registration-hero-institution {
  max-width: 34rem;
  margin-bottom: 1.55rem;
  color: #fff;
  font-size: clamp(1.05rem, 1.5vw, 1.18rem);
  font-weight: 600;
  line-height: 1.52;
}

.public-site .registration-hero-institution span {
  display: block;
  color: rgba(255, 255, 255, .7);
  font-size: .92em;
  font-weight: 450;
}

.public-site .registration-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.15rem;
  padding-top: 1.15rem;
  border-top: 1px solid rgba(255, 255, 255, .28);
}

.public-site .registration-hero-link {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  color: #fff;
  font-weight: 650;
  text-decoration: none;
}

.public-site .registration-hero-meta {
  margin: 0;
  color: rgba(255, 255, 255, .7);
  font-size: .88rem;
}

.public-site .registration-hero-meta strong {
  margin-right: .25rem;
  color: #fff;
  font-size: 1.05rem;
}

.public-site .registration-flow-nav {
  padding-block: 0;
  background: #fff;
  box-shadow: none;
  backdrop-filter: none;
}

.public-site .registration-flow-list {
  gap: clamp(1.15rem, 3.5vw, 2.4rem);
}

.public-site .registration-flow-list a {
  min-height: 3.55rem;
  padding: 0;
  color: var(--brand-muted);
  background: transparent;
  border: 0;
  border-radius: 0;
  font-size: .87rem;
  font-weight: 600;
}

.public-site .registration-flow-list a:hover,
.public-site .registration-flow-list a:focus {
  color: var(--brand-green);
  background: transparent;
  box-shadow: inset 0 -2px 0 var(--brand-green);
  transform: none;
}

.public-site .public-activity-page-heading {
  width: min(calc(100% - clamp(6rem, 16vw, 18rem)), 88rem);
  max-width: 88rem;
  margin-inline: auto;
}

.public-site .public-activity-page-heading h1 {
  margin-bottom: .85rem;
}

.public-site .public-activity-listing-toolbar .public-section-kicker {
  display: none;
}

.public-site .public-post-grid-with-aside .public-post-card {
  border-radius: var(--brand-radius);
}

.public-site .public-article-header {
  padding-bottom: 1.15rem;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-article-header h1 {
  max-width: 18ch;
  letter-spacing: -.02em;
}

.public-site .public-article-share .activity-aside-share-button,
.public-site .public-article-share .activity-aside-share-button:nth-of-type(2),
.public-site .public-article-share .activity-aside-share-button:nth-of-type(3),
.public-site .public-article-share .activity-aside-share-button:nth-of-type(4),
.public-site .public-article-share .activity-aside-share-button:nth-of-type(5),
.public-site .public-article-share .activity-aside-share-button:nth-of-type(6) {
  color: var(--brand-green);
  background: #fff;
  border-color: var(--brand-border);
  border-radius: var(--brand-radius);
  box-shadow: none;
}

.public-site .public-article-share .activity-aside-share-button i,
.public-site .public-article-share .activity-aside-share-button .activity-share-svg-icon,
.public-site .public-article-share .activity-aside-share-button .activity-share-svg-icon path {
  color: currentColor;
  fill: currentColor;
  opacity: 1;
}

.public-site .public-article-share .activity-aside-share-button:hover,
.public-site .public-article-share .activity-aside-share-button:focus-visible,
.public-site .public-article-share .activity-aside-share-button.is-copied {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-site .public-article-share .activity-aside-share-button:hover i,
.public-site .public-article-share .activity-aside-share-button:focus-visible i,
.public-site .public-article-share .activity-aside-share-button.is-copied i,
.public-site .public-article-share .activity-aside-share-button:hover .activity-share-svg-icon,
.public-site .public-article-share .activity-aside-share-button:focus-visible .activity-share-svg-icon,
.public-site .public-article-share .activity-aside-share-button.is-copied .activity-share-svg-icon,
.public-site .public-article-share .activity-aside-share-button:hover .activity-share-svg-icon path,
.public-site .public-article-share .activity-aside-share-button:focus-visible .activity-share-svg-icon path,
.public-site .public-article-share .activity-aside-share-button.is-copied .activity-share-svg-icon path {
  color: currentColor;
  fill: currentColor;
}

.public-site .public-article-share .activity-aside-share-button:hover .activity-share-svg-icon,
.public-site .public-article-share .activity-aside-share-button:focus-visible .activity-share-svg-icon,
.public-site .public-article-share .activity-aside-share-button.is-copied .activity-share-svg-icon {
  color: #fff;
  fill: #fff;
  background: transparent;
}

.public-site .public-article-share .activity-aside-share-button:hover .activity-share-svg-icon path,
.public-site .public-article-share .activity-aside-share-button:focus-visible .activity-share-svg-icon path,
.public-site .public-article-share .activity-aside-share-button.is-copied .activity-share-svg-icon path {
  fill: #fff;
}

/* Tanggapan Pembaca - institutional reaction system */
.public-site .activity-reaction {
  padding: clamp(1.25rem, 3vw, 2rem);
  color: #10261d;
  background:
    linear-gradient(180deg, rgba(248, 246, 240, .94), rgba(255, 255, 255, .98));
  border: 1px solid #dde5df;
  border-radius: 18px;
  box-shadow: 0 1rem 2.4rem rgba(11, 61, 46, .06);
  scroll-margin-top: calc(var(--public-navbar-offset, 96px) + 1.5rem);
}

.public-site .activity-reaction-header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}

.public-site .activity-reaction-heading h2 {
  margin: .35rem 0 .35rem;
  color: #0b3d2e;
  font-size: clamp(1.65rem, 3vw, 2.25rem);
  line-height: 1.1;
  letter-spacing: -.025em;
}

.public-site .activity-reaction-heading p {
  margin: 0;
  color: #617168;
  font-size: 1rem;
}

.public-site .activity-reaction-score {
  min-width: 6.25rem;
  padding: .8rem 1rem;
  text-align: center;
  color: #0b3d2e;
  background: #fff;
  border: 1px solid rgba(201, 164, 92, .42);
  border-radius: 16px;
}

.public-site .activity-reaction-score strong {
  display: block;
  font-size: 1.45rem;
  line-height: 1;
}

.public-site .activity-reaction-score span {
  display: block;
  margin-top: .2rem;
  color: #8a7852;
  font-size: .84rem;
  font-weight: 700;
}

.public-site .activity-reaction-thanks {
  display: inline-flex;
  margin: .2rem 0 1rem;
  padding: .72rem 1rem;
  color: #0b3d2e;
  background: rgba(201, 164, 92, .14);
  border: 1px solid rgba(201, 164, 92, .32);
  border-radius: 999px;
  font-size: .92rem;
  font-weight: 750;
}

.public-site .activity-reaction-options {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: .85rem;
  margin-top: 1.25rem;
}

.public-site .activity-reaction-button {
  display: grid;
  align-content: start;
  justify-items: start;
  gap: .5rem;
  min-height: 11rem;
  padding: 1rem;
  text-align: left;
  color: #10261d;
  background: rgba(255, 255, 255, .92);
  border: 1px solid #dde5df;
  border-radius: 16px;
  box-shadow: none;
  transition: border-color .18s ease, background-color .18s ease, transform .18s ease;
}

.public-site .activity-reaction-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.65rem;
  height: 2.65rem;
  color: #0b3d2e;
  background: rgba(11, 61, 46, .07);
  border: 1px solid rgba(11, 61, 46, .08);
  border-radius: 14px;
  transition: color .18s ease, background-color .18s ease, border-color .18s ease;
}

.public-site .activity-reaction-icon svg {
  width: 1.35rem;
  height: 1.35rem;
  fill: currentColor;
}

.public-site .activity-reaction-label {
  color: #10261d;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
}

.public-site .activity-reaction-description {
  color: #66766d;
  font-size: .84rem;
  line-height: 1.4;
}

.public-site .activity-reaction-point {
  align-self: end;
  margin-top: .2rem;
  color: #8a7852;
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .02em;
}

.public-site .activity-reaction-button:hover:not(:disabled),
.public-site .activity-reaction-button:focus-visible:not(:disabled) {
  transform: translateY(-1px);
  background: #fff;
  border-color: #c9a45c;
  box-shadow: none;
}

.public-site .activity-reaction-button:hover:not(:disabled) .activity-reaction-icon,
.public-site .activity-reaction-button:focus-visible:not(:disabled) .activity-reaction-icon {
  color: #0b3d2e;
  background: rgba(201, 164, 92, .18);
  border-color: rgba(201, 164, 92, .34);
}

.public-site .activity-reaction-button:focus-visible {
  outline: 3px solid rgba(201, 164, 92, .34);
  outline-offset: 3px;
}

.public-site .activity-reaction-button.is-selected {
  color: #0b3d2e;
  background: rgba(11, 61, 46, .055);
  border-color: #0b3d2e;
  transform: none;
  box-shadow: inset 0 0 0 1px rgba(11, 61, 46, .08);
}

.public-site .activity-reaction-button.is-selected .activity-reaction-icon {
  color: #fff;
  background: #0b3d2e;
  border-color: #0b3d2e;
}

.public-site .activity-reaction-button:disabled {
  cursor: default;
  opacity: 1;
}

@media (max-width: 1199.98px) {
  .public-site .activity-reaction-options {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .public-site .activity-reaction-header {
    flex-direction: column;
  }

  .public-site .activity-reaction-score {
    min-width: 0;
    width: 100%;
    text-align: left;
  }

  .public-site .activity-reaction-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 420px) {
  .public-site .activity-reaction-options {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {

  .public-site .activity-reaction-button,
  .public-site .activity-reaction-icon {
    transition: none;
  }

  .public-site .activity-reaction-button:hover:not(:disabled),
  .public-site .activity-reaction-button:focus-visible:not(:disabled) {
    transform: none;
  }
}

/* Halaman Kritik dan Saran */
.public-site .public-feedback-hero .hero-image {
  min-height: 34rem;
  background:
    linear-gradient(90deg, rgba(7, 29, 21, .9), rgba(7, 29, 21, .76) 42%, rgba(7, 29, 21, .46)),
    var(--feedback-hero-image, url("../img/backgrounds/modern-section-halaqah-kitabs.jpg")) center / cover no-repeat;
}

.public-site .feedback-hero-card {
  width: min(100%, 42rem);
  padding: clamp(1.4rem, 3vw, 2.25rem);
  color: #fff;
  background: rgba(8, 42, 30, .54);
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: var(--brand-radius-lg);
  box-shadow: 0 24px 70px rgba(0, 0, 0, .22);
  backdrop-filter: blur(8px);
}

.public-site .feedback-hero-card h1 {
  max-width: 11ch;
  margin: .4rem 0 .8rem;
  color: #fff;
  font-size: clamp(2.6rem, 7vw, 5rem);
  line-height: .98;
  letter-spacing: -.05em;
}

.public-site .feedback-hero-card p {
  max-width: 36rem;
  margin: 0;
  color: rgba(255, 255, 255, .78);
  font-size: clamp(1rem, 1.5vw, 1.18rem);
  line-height: 1.75;
}

.public-site .feedback-main-section {
  background:
    linear-gradient(180deg, rgba(246, 248, 245, .88), #fff 34%),
    radial-gradient(circle at 82% 0, rgba(194, 143, 45, .11), transparent 32%);
}

.public-site .feedback-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(18rem, .85fr);
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: start;
  max-width: 72rem;
  margin-inline: auto;
}

.public-site .feedback-form-panel,
.public-site .feedback-guidance-card {
  background: #fff;
  border: 1px solid rgba(17, 42, 34, .1);
  border-radius: var(--brand-radius-lg);
  box-shadow: 0 24px 70px rgba(17, 42, 34, .08);
}

.public-site .feedback-form-panel {
  padding: clamp(1.25rem, 3vw, 2rem);
}

.public-site .feedback-form-panel h2,
.public-site .feedback-guidance-card h2 {
  margin: .35rem 0 .55rem;
  color: var(--brand-ink);
  font-size: clamp(1.75rem, 3vw, 2.4rem);
  letter-spacing: -.035em;
}

.public-site .feedback-form-intro {
  margin-bottom: 1.25rem;
  color: var(--brand-muted);
}

.public-site .feedback-form {
  display: grid;
  gap: 1rem;
}

.public-site .feedback-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .9rem;
}

.public-site .feedback-field {
  display: grid;
  gap: .42rem;
}

.public-site .feedback-field label {
  color: var(--brand-ink);
  font-weight: 720;
}

.public-site .feedback-field label span {
  color: var(--brand-muted);
  font-size: .78rem;
  font-weight: 600;
}

.public-site .feedback-field input,
.public-site .feedback-field select,
.public-site .feedback-field textarea {
  width: 100%;
  min-height: 3.25rem;
  padding: .78rem .9rem;
  color: var(--brand-ink);
  background: rgba(246, 248, 245, .48);
  border: 1px solid rgba(17, 42, 34, .14);
  border-radius: var(--brand-radius);
  outline: 0;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

.public-site .feedback-field textarea {
  resize: vertical;
  line-height: 1.65;
}

.public-site .feedback-field input:focus,
.public-site .feedback-field select:focus,
.public-site .feedback-field textarea:focus {
  background: #fff;
  border-color: rgba(13, 91, 66, .58);
  box-shadow: 0 0 0 4px rgba(13, 91, 66, .1);
}

.public-site .feedback-check {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
  color: var(--brand-muted);
  font-size: .92rem;
  line-height: 1.55;
}

.public-site .feedback-check input {
  width: 1.05rem;
  height: 1.05rem;
  margin-top: .18rem;
  accent-color: var(--brand-green);
}

.public-site .feedback-consent {
  padding: .85rem;
  background: rgba(13, 91, 66, .06);
  border: 1px solid rgba(13, 91, 66, .11);
  border-radius: var(--brand-radius);
}

.public-site .feedback-submit {
  justify-self: start;
  min-width: 12rem;
}

.public-site .feedback-form-notices {
  display: grid;
  gap: .75rem;
  margin-top: 1.25rem;
}

.public-site .feedback-toast-layer {
  position: fixed;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  z-index: 1080;
  width: min(27rem, calc(100vw - 2rem));
  pointer-events: none;
}

.public-site .feedback-toast {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: .9rem;
  align-items: start;
  padding: 1rem;
  color: #10261d;
  background: rgba(255, 255, 255, .94);
  border: 1px solid rgba(15, 81, 63, .14);
  border-left: 4px solid #0f513f;
  border-radius: 1rem;
  box-shadow: 0 1.35rem 3rem rgba(12, 37, 27, .18);
  backdrop-filter: blur(18px);
  pointer-events: auto;
  transform: translateY(0);
  opacity: 1;
  transition: opacity .28s ease, transform .28s ease;
}

.public-site .feedback-toast.is-error {
  border-left-color: #9f2f2f;
}

.public-site .feedback-toast-layer.is-hiding .feedback-toast {
  opacity: 0;
  transform: translateY(.8rem);
}

.public-site .feedback-toast-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  color: #fff;
  background: #0f513f;
  border-radius: 999px;
  font-size: 1.1rem;
}

.public-site .feedback-toast.is-error .feedback-toast-icon {
  background: #9f2f2f;
}

.public-site .feedback-toast-copy strong {
  display: block;
  margin-bottom: .2rem;
  font-size: 1rem;
  color: #10261d;
}

.public-site .feedback-toast-copy p {
  margin: 0;
  color: #5f6f67;
  font-size: .95rem;
  line-height: 1.55;
}

.public-site .feedback-toast-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  color: #53645c;
  background: rgba(15, 81, 63, .06);
  border: 0;
  border-radius: 999px;
}

.public-site .feedback-toast-close:hover {
  color: #0f513f;
  background: rgba(15, 81, 63, .12);
}

.public-site .feedback-honeypot {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
}

.public-site .feedback-guidance-panel {
  display: grid;
  gap: 1rem;
  position: sticky;
  top: calc(var(--public-navbar-offset) + 1rem);
}

.public-site .feedback-guidance-card {
  padding: clamp(1.15rem, 2.5vw, 1.5rem);
}

.public-site .feedback-guidance-card ul {
  display: grid;
  gap: .72rem;
  margin: 1rem 0 0;
  padding: 0;
  list-style: none;
}

.public-site .feedback-guidance-card li {
  position: relative;
  padding-left: 1.35rem;
  color: var(--brand-muted);
  line-height: 1.55;
}

.public-site .feedback-guidance-card li::before {
  position: absolute;
  left: 0;
  top: .58rem;
  width: .46rem;
  height: .46rem;
  content: "";
  background: var(--brand-gold);
  border-radius: 50%;
}

.public-site .feedback-privacy-card {
  display: grid;
  grid-template-columns: 2.4rem minmax(0, 1fr);
  gap: .85rem;
  background: var(--brand-green);
  color: #fff;
}

.public-site .feedback-privacy-card>i {
  display: inline-grid;
  place-items: center;
  width: 2.4rem;
  height: 2.4rem;
  color: var(--brand-gold);
  background: rgba(255, 255, 255, .1);
  border-radius: 50%;
}

.public-site .feedback-privacy-card h3 {
  margin: 0 0 .3rem;
  color: #fff;
  font-size: 1.05rem;
}

.public-site .feedback-privacy-card p {
  margin: 0;
  color: rgba(255, 255, 255, .74);
  line-height: 1.6;
}

@media (max-width: 991.98px) {
  .public-site .feedback-shell {
    grid-template-columns: 1fr;
  }

  .public-site .feedback-guidance-panel {
    position: static;
  }

  .public-site .feedback-toast-layer {
    right: 1rem;
    bottom: 1rem;
  }
}

@media (max-width: 575.98px) {
  .public-site .feedback-grid {
    grid-template-columns: 1fr;
  }

  .public-site .feedback-hero-card h1 {
    max-width: 100%;
  }
}

@media (hover: hover) {

  .public-site .home-publication-feature:hover h3,
  .public-site .home-publication-item:hover h3,
  .public-site .home-publication-index:hover {
    color: var(--brand-green);
  }
}

@media (max-width: 1199.98px) {
  .public-site .public-activity-page-heading {
    width: min(calc(100% - 2rem), 72rem);
  }
}

@media (max-width: 991.98px) {
  .public-site .public-home-hero {
    background: #fff;
  }

  .public-site .home-publication-grid {
    grid-template-columns: 1fr;
  }

  .public-site .public-activity-page-heading {
    width: min(calc(100% - 2rem), 54rem);
  }

  .public-site .public-registration-hero .hero-image {
    background:
      linear-gradient(180deg, rgba(7, 29, 21, .87), rgba(7, 29, 21, .68)),
      var(--registration-hero-image, url("../img/backgrounds/modern-section-haul-stage.jpg")) center / cover no-repeat;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-home-hero .public-hero-copy h1 {
    font-size: clamp(2.2rem, 11.5vw, 2.8rem);
  }

  .public-site .public-hero-facts {
    gap: 1rem;
  }

  .public-site .home-publication-item {
    grid-template-columns: 5.5rem minmax(0, 1fr);
  }

  .public-site .home-publication-item img {
    height: 4.25rem;
  }

  .public-site .public-registration-hero .hero-image>.container {
    min-height: 29rem !important;
    align-items: flex-start !important;
  }

  .public-site .registration-hero-card {
    width: 100% !important;
    max-width: 100%;
    margin-inline: 0;
    padding: 0;
  }

  .public-site .registration-hero-actions {
    display: grid;
    gap: .85rem;
  }
}

/* Fase M10 - Secondary Pages and Trust Layer */
.public-site .public-secondary-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(17rem, 22rem);
  align-items: end;
  gap: clamp(1.5rem, 4vw, 3rem);
  max-width: 78rem;
  margin-inline: auto;
}

.public-site .public-secondary-heading {
  max-width: 48rem;
  margin: 0 !important;
}

.public-site .public-secondary-heading h1 {
  max-width: 18ch;
  margin-bottom: .9rem;
}

.public-site .public-trust-note {
  padding: 1.05rem 0 0 1rem;
  border-top: 2px solid #b9934a;
}

.public-site .public-trust-note strong {
  display: flex;
  align-items: center;
  gap: .42rem;
  margin-bottom: .48rem;
  color: var(--brand-ink);
  font-size: .92rem;
  font-weight: 670;
}

.public-site .public-trust-note i {
  color: var(--brand-green);
}

.public-site .public-trust-note p {
  margin: 0;
  color: var(--brand-muted);
  font-size: .88rem;
  line-height: 1.62;
}

.public-site .public-schedule-page {
  background: #fff;
}

.public-site .public-schedule-tabs,
.public-site .public-schedule-panel {
  max-width: 78rem;
  margin-inline: auto;
}

.public-site .public-schedule-tabs {
  justify-content: flex-start;
  gap: 1.5rem;
  margin-bottom: 1.75rem;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-schedule-tabs button {
  min-height: 3.1rem;
  padding: .7rem 0;
  color: var(--brand-muted);
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  font-size: .93rem;
  font-weight: 620;
}

.public-site .public-schedule-tabs button.active {
  color: var(--brand-green);
  background: transparent;
  border-color: var(--brand-green);
}

.public-site .public-schedule-panel {
  padding: 0;
  background: #fff;
  border: 0 !important;
}

.public-site .public-schedule-panel-header {
  align-items: end;
  margin-bottom: 1.15rem;
  padding-bottom: 1.15rem;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-schedule-panel-header h2 {
  margin: .28rem 0 .38rem;
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  font-weight: 680;
}

.public-site .public-schedule-panel-header p {
  font-size: .93rem;
}

.public-site .schedule-table-wrap {
  border-radius: 0;
}

.public-site .public-schedule-table thead th,
.public-site .public-class-detail-table thead th {
  color: var(--brand-muted);
  background: #f7f9f7;
  font-size: .78rem;
  font-weight: 680;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.public-site .public-schedule-table tbody strong,
.public-site .public-class-detail-table tbody strong {
  font-weight: 620;
}

.public-site .public-schedule-index {
  width: 4rem;
  color: var(--brand-muted);
  text-align: center;
}

.public-site .public-schedule-person-link {
  color: var(--brand-green);
  font-weight: 620;
  text-decoration: none;
}

.public-site .public-schedule-person-link:hover {
  color: var(--brand-green-2);
  text-decoration: underline;
  text-underline-offset: .16em;
}

.public-site .public-article-mentions {
  margin: 2rem 0;
  padding: 1.15rem 0;
  border-top: 1px solid var(--brand-border);
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-article-mentions h2 {
  margin: 0 0 .8rem;
  color: var(--brand-muted);
  font-size: .76rem;
  font-weight: 680;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-article-mentions div {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.public-site .public-article-mentions a,
.public-site .public-article-mentions span {
  display: inline-flex;
  align-items: center;
  gap: .18rem;
  padding: .4rem .72rem;
  color: var(--brand-ink);
  background: #f7f9f7;
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  font-size: .9rem;
  text-decoration: none;
}

.public-site .public-article-mentions a {
  color: var(--brand-green);
  font-weight: 620;
}

.public-site .public-article-mentions a:hover {
  color: var(--brand-green-2);
  border-color: rgba(15, 61, 46, .25);
  background: #eef4f0;
}

.public-site .public-class-section,
.public-site .public-class-day {
  border-radius: 0;
  box-shadow: none;
}

.public-site .public-class-filter,
.public-site .public-class-subfilter {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
}

.public-site .public-class-filter {
  margin: 0 0 1.2rem;
}

.public-site .public-class-subfilter {
  margin: -.45rem 0 1.2rem;
  padding: .75rem 0 0;
  border-top: 1px solid var(--brand-border);
}

.public-site .public-class-filter button,
.public-site .public-class-subfilter button {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 2.55rem;
  padding: .56rem .95rem;
  color: var(--brand-muted);
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 640;
}

.public-site .public-class-subfilter button {
  min-height: 2.25rem;
  padding: .42rem .8rem;
  font-size: .84rem;
}

.public-site .public-class-filter button.active,
.public-site .public-class-subfilter button.active {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-site .public-class-filter button:disabled,
.public-site .public-class-subfilter button:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.public-site .public-class-filter span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.35rem;
  padding-inline: .25rem;
  color: inherit;
  background: rgba(15, 61, 46, .08);
  border-radius: 999px;
  font-size: .72rem;
}

.public-site .public-class-filter button.active span {
  background: rgba(255, 255, 255, .18);
}

.public-site .public-class-by-class {
  padding: 1.15rem;
  border: 1px solid var(--brand-border);
  background: #fff;
}

.public-site .public-class-by-class+.public-class-by-class {
  margin-top: 1rem;
}

.public-site .public-class-day-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: .85rem;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-class-day-heading h3 {
  margin: .22rem 0 0;
  color: #fff;
  font-size: clamp(1.08rem, 1.7vw, 1.35rem);
  font-weight: 680;
}

.public-site .public-class-day-heading p {
  margin: 0;
  color: var(--brand-muted);
  font-size: .9rem;
  font-weight: 620;
  text-align: right;
}

.public-site .public-class-section-header h3,
.public-site .public-class-day h4 {
  font-weight: 680;
}

.public-site .public-class-day h4 {
  color: var(--brand-ink);
  background: #f7f9f7;
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-class-day+.public-class-day {
  margin-top: 1rem;
}

.public-site .public-masyayikh-page {
  background: #fff;
}

.public-site .public-masyayikh-intro {
  display: block;
}

.public-site .public-masyayikh-page .public-page-heading,
.public-site .public-masyayikh-page .public-page-heading p {
  margin-inline: 0;
}

.public-site .public-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  margin-top: 2rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--brand-border);
}

.public-site .public-pagination-link,
.public-site .public-pagination-status {
  display: inline-flex;
  align-items: center;
  min-height: 2.55rem;
  padding: .55rem .95rem;
  border-radius: 999px;
  font-size: .9rem;
  font-weight: 650;
}

.public-site .public-pagination-link {
  color: var(--brand-green);
  background: #fff;
  border: 1px solid var(--brand-border);
  text-decoration: none;
}

.public-site .public-pagination-link:hover {
  color: #fff;
  background: var(--brand-green);
  border-color: var(--brand-green);
}

.public-site .public-pagination-link.is-disabled {
  color: var(--brand-muted);
  background: #f7f9f7;
  cursor: not-allowed;
  opacity: .62;
}

.public-site .public-pagination-status {
  color: var(--brand-muted);
  background: #f7f9f7;
}

.public-site .mdqh-pagination {
  display: flex;
  justify-content: center;
  margin-top: 2rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--brand-border);
}

.public-site .mdqh-pagination-list {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.public-site .mdqh-pagination-link,
.public-site .mdqh-pagination-ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  min-height: 2.25rem;
  padding: .35rem .7rem;
  color: var(--brand-ink);
  border: 1px solid transparent;
  border-radius: 12px;
  font-size: .95rem;
  font-weight: 650;
  line-height: 1;
  text-decoration: none;
  transition:
    color 180ms var(--brand-ease),
    background-color 180ms var(--brand-ease),
    border-color 180ms var(--brand-ease),
    transform 180ms var(--brand-ease);
}

.public-site .mdqh-pagination-control {
  gap: .42rem;
  min-width: auto;
  padding-inline: .45rem;
  color: #0b1f18;
}

.public-site .mdqh-pagination-link:hover,
.public-site .mdqh-pagination-link:focus-visible {
  color: var(--brand-green);
  background: rgba(13, 58, 44, .06);
  border-color: rgba(13, 58, 44, .12);
}

.public-site .mdqh-pagination-link:focus-visible {
  outline: 2px solid rgba(201, 164, 92, .45);
  outline-offset: 3px;
}

.public-site .mdqh-pagination-link.is-active {
  color: var(--brand-green);
  background: #fff;
  border-color: var(--brand-border);
  box-shadow: 0 8px 20px rgba(17, 42, 32, .08);
}

.public-site .mdqh-pagination-link.is-disabled {
  color: var(--brand-muted);
  cursor: not-allowed;
  opacity: .42;
}

.public-site .mdqh-pagination-ellipsis {
  min-width: 1.75rem;
  color: var(--brand-muted);
  letter-spacing: .08em;
}

.public-site .mdqh-pagination-link i {
  font-size: .82rem;
  line-height: 1;
}

@media (max-width: 575.98px) {
  .public-site .mdqh-pagination-list {
    gap: .24rem;
  }

  .public-site .mdqh-pagination-link,
  .public-site .mdqh-pagination-ellipsis {
    min-width: 2rem;
    min-height: 2rem;
    padding-inline: .55rem;
    font-size: .88rem;
  }

  .public-site .mdqh-pagination-control {
    padding-inline: .28rem;
  }
}

.public-site .public-masyayikh-directory {
  max-width: 78rem;
  gap: 0;
}

.public-site .public-masyayikh-profile-card {
  grid-template-columns: minmax(9rem, 10.5rem) minmax(0, 1fr);
  gap: clamp(1rem, 2.5vw, 1.65rem);
  padding: 1.2rem 0;
  background: #fff;
  border: 0 !important;
  border-top: 1px solid var(--brand-border) !important;
  border-radius: 0;
}

.public-site .public-masyayikh-profile-card:last-child {
  border-bottom: 1px solid var(--brand-border) !important;
}

.public-site .public-masyayikh-profile-card::before {
  display: none;
}

.public-site .public-masyayikh-profile-media,
.public-site .public-masyayikh-profile-media img {
  min-height: 12rem;
  border-radius: 3px;
}

.public-site .public-masyayikh-profile-heading {
  display: block;
  margin-bottom: 1rem;
}

.public-site .public-masyayikh-profile-heading h2 {
  margin-bottom: .55rem;
  font-weight: 680;
  max-width: 54rem;
}

.public-site .public-masyayikh-profile-heading .public-masyayikh-profile-category {
  margin-bottom: 0;
  padding: 0;
  color: #8b7040;
  background: transparent;
  border: 0;
  border-radius: 0;
  font-size: .72rem;
  letter-spacing: .08em;
}

.public-site .public-masyayikh-profile-details {
  grid-template-columns: minmax(13rem, .72fr) minmax(18rem, 1.28fr);
  gap: clamp(1.25rem, 3vw, 2.75rem);
  margin-bottom: 0;
  border-top: 1px solid var(--brand-border);
}

.public-site .public-masyayikh-profile-details div {
  padding: .8rem 0 .2rem;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.public-site .public-masyayikh-profile-details dt {
  color: var(--brand-muted);
  font-weight: 650;
}

.public-site .public-masyayikh-profile-details dd {
  font-weight: 500;
}

.public-site .public-editors-page,
.public-site .public-editor-profile-page {
  background: #fff;
}

.public-site .public-editor-hero {
  align-items: start;
  max-width: 78rem;
  margin-inline: auto;
}

.public-site .public-editor-hero h1,
.public-site .public-editor-profile-header h1 {
  max-width: 16ch;
  font-size: var(--brand-page-title);
  font-weight: 700;
  letter-spacing: -.03em;
}

.public-site .public-editor-disclosure {
  display: flex;
  gap: .5rem;
  max-width: 41rem !important;
  margin-top: 1rem !important;
  color: var(--brand-muted) !important;
  font-size: .86rem !important;
  line-height: 1.55 !important;
}

.public-site .public-editor-disclosure i {
  flex: 0 0 auto;
  color: var(--brand-green);
}

.public-site .public-editor-toolbar {
  padding: 0 0 1rem;
  background: transparent;
  border: 0 !important;
  border-bottom: 1px solid var(--brand-border) !important;
  border-radius: 0;
}

.public-site .public-editor-toolbar .form-control,
.public-site .public-editor-toolbar .form-select,
.public-site .public-editor-toolbar .btn {
  min-height: 2.8rem;
  border-radius: var(--brand-radius);
  font-weight: 580;
}

.public-site .public-editor-statline {
  max-width: 78rem;
  margin-inline: auto;
  margin-bottom: 2.2rem;
  background: transparent;
  border-top: 1px solid var(--brand-border) !important;
  border-bottom: 1px solid var(--brand-border) !important;
}

.public-site .public-editor-statline div {
  padding: 1rem 1rem 1rem 0;
  background: #fff;
}

.public-site .public-editor-statline span {
  font-size: clamp(1.45rem, 2.3vw, 1.8rem);
  font-weight: 680;
}

.public-site .public-editor-statline strong {
  font-weight: 600;
  letter-spacing: .05em;
}

.public-site .public-editor-leaderboards,
.public-site .public-editor-directory {
  max-width: 78rem;
  margin-inline: auto;
}

.public-site .public-editor-board {
  padding: 1rem 0;
  background: #fff;
  border: 0 !important;
  border-top: 1px solid var(--brand-border) !important;
  border-radius: 0;
}

.public-site .public-editor-board-heading span,
.public-site .public-editor-board h2 {
  font-weight: 650;
}

.public-site .public-editor-board li {
  padding: .55rem 0;
  background: transparent;
  border-top: 1px solid rgba(16, 35, 29, .07);
  border-radius: 0;
}

.public-site .public-editor-rank {
  width: 1.55rem;
  height: 1.55rem;
  background: transparent;
  border: 1px solid var(--brand-border);
  border-radius: 3px;
  font-size: .75rem;
  font-weight: 650;
}

.public-site .public-editor-directory {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border-top: 1px solid var(--brand-border);
}

.public-site .public-editor-card {
  min-height: 0;
  padding: 1.15rem 0;
  background: #fff;
  border: 0 !important;
  border-bottom: 1px solid var(--brand-border) !important;
  border-radius: 0;
}

.public-site .public-editor-card:nth-child(odd) {
  padding-right: clamp(1rem, 3vw, 2rem);
}

.public-site .public-editor-card:nth-child(even) {
  padding-left: clamp(1rem, 3vw, 2rem);
  border-left: 1px solid var(--brand-border) !important;
}

.public-site .public-editor-card-media img,
.public-site .public-editor-card-media span,
.public-site .public-editor-profile-avatar img,
.public-site .public-editor-profile-avatar span {
  border-radius: 3px;
}

.public-site .public-editor-card-heading h2,
.public-site .public-editor-card-link {
  font-weight: 650;
}

.public-site .public-editor-card-heading span,
.public-site .public-editor-card-stats span,
.public-site .public-editor-activity-meta span {
  background: transparent;
  border: 1px solid var(--brand-border);
  border-radius: 3px;
  font-weight: 560;
}

.public-site .public-editor-profile-header,
.public-site .public-editor-profile-layout {
  max-width: 78rem;
  margin-inline: auto;
}

.public-site .public-editor-profile-panel,
.public-site .public-editor-activity {
  border-radius: var(--brand-radius);
  box-shadow: none;
}

/* Fase M12 - Hero Quote Portrait Restoration */
.public-site .public-home-hero .public-section-kicker {
  margin-top: clamp(3rem, 4.5vw, 3.75rem);
}

.public-site .public-home-hero .public-hero-quote {
  grid-template-columns: 3.35rem minmax(0, 1fr);
  align-items: center;
  column-gap: .95rem;
}

.public-site .public-home-hero .public-hero-quote-photo {
  display: block;
  width: 3.35rem;
  height: 3.35rem;
  object-fit: cover;
  border-radius: 50%;
}

.public-site .public-home-hero .public-hero-quote-copy {
  display: grid;
  gap: .45rem;
  min-width: 0;
}

/* Fase M13 - Hero Background Restoration */
.public-site .public-home-hero {
  background:
    linear-gradient(rgba(255, 255, 255, .84), rgba(255, 255, 255, .84)),
    url("../img/backgrounds/modern-hero-masjid-anjani.jpg") center / cover no-repeat;
}

@media (max-width: 991.98px) {
  .public-site .public-home-hero {
    background:
      linear-gradient(rgba(255, 255, 255, .9), rgba(255, 255, 255, .9)),
      url("../img/backgrounds/modern-hero-masjid-anjani.jpg") center / cover no-repeat;
  }

  .public-site .public-secondary-intro {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-schedule-tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: 1.15rem;
    overflow-x: auto;
  }

  .public-site .public-schedule-tabs button {
    flex: 0 0 auto;
  }

  .public-site .public-masyayikh-profile-card {
    grid-template-columns: 1fr;
  }

  .public-site .public-masyayikh-profile-media,
  .public-site .public-masyayikh-profile-media img {
    min-height: 16rem;
  }

  .public-site .public-masyayikh-profile-details {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .public-site .public-editor-directory {
    grid-template-columns: 1fr;
  }

  .public-site .public-editor-card:nth-child(odd),
  .public-site .public-editor-card:nth-child(even) {
    padding-inline: 0;
    border-left: 0 !important;
  }
}

/* Fase M14 - Activity Listing Hero Alignment */
.public-site .public-listing-page {
  padding-top: clamp(2.25rem, 4vw, 3.25rem);
}

.public-site .public-activity-page-heading {
  margin-bottom: clamp(1.65rem, 3vw, 2.25rem) !important;
  padding-bottom: clamp(1.35rem, 2.4vw, 1.8rem);
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-activity-page-heading .public-section-kicker {
  margin-bottom: .7rem;
}

.public-site .public-listing-page .public-activity-page-heading h1 {
  max-width: 16ch;
  margin-inline: 0;
  margin-bottom: .7rem;
  font-size: clamp(2.35rem, 4.1vw, 3.55rem);
  line-height: 1.06;
}

.public-site .public-activity-page-heading p {
  max-width: 47rem;
  margin-inline: 0;
  margin-bottom: 0;
  line-height: 1.62;
}

@media (max-width: 767.98px) {
  .public-site .public-listing-page {
    padding-top: 2rem;
  }

  .public-site .public-listing-page .public-activity-page-heading h1 {
    font-size: clamp(2rem, 10.5vw, 2.55rem);
  }
}

/* Fase M15 - Editorial Activity Hero */
.public-site .public-activity-editorial-hero {
  width: min(calc(100% - clamp(3rem, 8vw, 8rem)), 96rem);
  max-width: 96rem;
  margin-bottom: clamp(2.8rem, 5vw, 4.25rem);
  padding-inline: 0;
}

.public-site .public-activity-editorial-heading {
  max-width: 49rem;
  margin: clamp(1.9rem, 3vw, 2.5rem) auto 0;
  text-align: center;
}

.public-site .public-activity-editorial-heading h1 {
  max-width: 20ch;
  margin: 0 auto .75rem;
  font-size: clamp(2.15rem, 3.35vw, 3rem);
  font-weight: 700;
  letter-spacing: -.03em;
  line-height: 1.12;
}

.public-site .public-activity-editorial-heading p {
  max-width: 43rem;
  margin: 0 auto;
  color: var(--brand-muted);
  font-weight: 400;
  line-height: 1.65;
}

.public-site .public-activity-hero-carousel {
  width: 100%;
  margin: 0;
  transform: none;
}

.public-site .public-activity-hero-carousel .activity-feed-swiper-main {
  overflow: hidden;
}

.public-site .public-activity-hero-carousel .activity-feed-main img {
  aspect-ratio: 16 / 6.9;
}

.public-site .public-activity-hero-carousel .activity-carousel-prev {
  left: .85rem;
}

.public-site .public-activity-hero-carousel .activity-carousel-next {
  right: .85rem;
}

.public-site .public-activity-archive-link {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-top: 1.15rem;
  color: var(--brand-green);
  font-size: .9rem;
  font-weight: 650;
  text-decoration: none;
}

@media (max-width: 1199.98px) {
  .public-site .public-activity-editorial-hero {
    width: min(calc(100% - 2rem), 78rem);
  }
}

@media (max-width: 991.98px) {
  .public-site .public-activity-editorial-hero {
    width: min(calc(100% - 2rem), 54rem);
  }

  .public-site .public-activity-editorial-heading {
    text-align: left;
  }

  .public-site .public-activity-editorial-heading h1,
  .public-site .public-activity-editorial-heading p {
    margin-inline: 0;
  }

}

@media (max-width: 767.98px) {
  .public-site .public-activity-editorial-hero {
    margin-bottom: 2.3rem;
  }

  .public-site .public-activity-hero-carousel .activity-feed-main img {
    aspect-ratio: 4 / 3.35;
  }
}

/* Mobile editorial carousel refinement for kegiatan.php */
.public-site .public-activity-hero-carousel .activity-feed-main::after {
  background:
    linear-gradient(to top,
      rgba(0, 0, 0, .65),
      rgba(0, 0, 0, .25),
      transparent);
}

.public-site .public-activity-hero-carousel .activity-feed-caption h3 {
  display: -webkit-box !important;
  overflow: hidden !important;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

@media (hover: hover) and (pointer: fine) {

  .public-site .public-activity-hero-carousel .activity-carousel-nav:hover,
  .public-site .public-activity-hero-carousel .activity-carousel-nav:focus-visible {
    color: #fff;
    background: rgba(13, 58, 44, .86);
    transform: translateY(-50%) scale(1.04);
  }
}

@media (hover: none),
(pointer: coarse) {

  .public-site .public-activity-hero-carousel .activity-carousel-nav:hover,
  .public-site .public-activity-hero-carousel .activity-carousel-nav:focus {
    color: var(--brand-green);
    background: rgba(255, 255, 255, .94);
    transform: translateY(-50%);
  }

  .public-site .public-activity-hero-carousel .activity-carousel-pagination .swiper-pagination-bullet:hover,
  .public-site .public-activity-hero-carousel .activity-carousel-pagination .swiper-pagination-bullet:focus-visible {
    transform: none;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-activity-editorial-hero {
    width: min(calc(100% - 1.5rem), 30rem);
    max-width: 100%;
    margin-bottom: 2.2rem;
    overflow-x: clip;
  }

  .public-site .public-activity-hero-carousel,
  .public-site .public-activity-hero-carousel .activity-feed-swiper-main,
  .public-site .public-activity-hero-carousel .swiper-wrapper,
  .public-site .public-activity-hero-carousel .swiper-slide {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .public-site .public-activity-hero-carousel.public-activity-layout {
    width: 100%;
    max-width: 100%;
    margin-inline: 0;
    padding-inline: 0;
    overflow: visible !important;
    transform: none !important;
  }

  .public-site .public-activity-hero-carousel {
    position: relative;
    width: 100%;
    max-width: 100%;
    padding-block: 1.1rem 1.25rem;
    padding-bottom: 2.05rem;
  }

  .public-site .public-activity-hero-carousel .activity-feed-swiper-main {
    width: 100%;
    max-width: 100%;
    padding: 0;
  }

  .public-site .public-activity-hero-carousel .swiper-wrapper {
    align-items: stretch;
  }

  .public-site .public-activity-hero-carousel .swiper-slide {
    width: 100% !important;
    max-width: 100%;
    opacity: 0;
    filter: none;
    transform: none !important;
  }

  .public-site .public-activity-hero-carousel .swiper-slide-active {
    opacity: 1;
  }

  .public-site .public-activity-hero-carousel .swiper-slide-prev,
  .public-site .public-activity-hero-carousel .swiper-slide-next {
    opacity: 0;
    filter: none;
  }

  .public-site .public-activity-hero-carousel .activity-feed-main {
    position: relative;
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    min-height: 300px;
    aspect-ratio: 4 / 3;
    overflow: hidden !important;
    border-radius: 14px;
    box-shadow: 0 18px 42px rgba(17, 42, 32, .14);
  }

  .public-site .public-activity-hero-carousel .activity-feed-main img {
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    object-fit: cover;
    border-radius: 14px;
  }

  .public-site .public-activity-hero-carousel .activity-feed-main::after {
    background:
      linear-gradient(to bottom, rgba(0, 0, 0, .25), transparent 35%),
      linear-gradient(to top, rgba(0, 0, 0, .72), transparent 45%);
  }

  .public-site .public-activity-hero-carousel .activity-feed-caption {
    right: 1rem;
    bottom: 1.25rem;
    left: 1rem;
    overflow: visible;
  }

  .public-site .public-activity-hero-carousel .activity-feed-caption h3 {
    max-width: 100%;
    max-height: calc(1.25em * 2);
    margin-bottom: 0;
    font-size: clamp(1.25rem, 5.6vw, 1.5rem);
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: -.015em;
    text-shadow: 0 8px 22px rgba(0, 0, 0, .28);
  }

  .public-site .public-activity-hero-carousel .activity-feed-caption p {
    display: none;
  }

  .public-site .public-activity-hero-carousel .activity-feed-badge {
    top: .85rem;
    left: .85rem;
    padding: .38rem .62rem;
    color: var(--brand-green);
    background: rgba(255, 255, 255, .96);
    border-color: rgba(16, 35, 29, .08);
    font-size: .72rem;
    font-weight: 650;
    line-height: 1;
    border-radius: 8px;
    box-shadow: 0 8px 18px rgba(17, 42, 32, .08);
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    text-shadow: none;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-nav {
    width: 36px;
    height: 36px;
    top: 50%;
    color: var(--brand-green);
    background: rgba(255, 255, 255, .94);
    box-shadow: 0 10px 24px rgba(17, 42, 32, .14);
    backdrop-filter: blur(8px);
  }

  .public-site .public-activity-hero-carousel .activity-carousel-nav i {
    font-size: .95rem;
    line-height: 1;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-prev {
    left: .75rem;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-next {
    right: .75rem;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-pagination {
    position: static;
    bottom: auto !important;
    left: auto;
    z-index: 5;
    gap: .3rem;
    width: max-content;
    min-height: 1.28rem;
    margin: .7rem auto 0;
    padding: .22rem .38rem;
    background: rgba(255, 255, 255, .82);
    box-shadow: 0 12px 28px rgba(17, 42, 32, .12);
    transform: none;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-pagination .swiper-pagination-bullet {
    width: 7px;
    height: 7px;
    background: rgba(13, 58, 44, .18);
    border-color: rgba(13, 58, 44, .1);
  }

  .public-site .public-activity-hero-carousel .activity-carousel-pagination .swiper-pagination-bullet-active {
    width: 22px;
    height: 8px;
    background: var(--brand-green);
    box-shadow: none;
    transform: none;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-dot-index {
    display: none;
  }
}

@media (max-width: 390px) {
  .public-site .public-activity-hero-carousel .activity-feed-main {
    min-height: 300px;
    aspect-ratio: 4 / 3;
  }

  .public-site .public-activity-hero-carousel .activity-feed-caption {
    right: .9rem;
    bottom: 1.15rem;
    left: .9rem;
  }

  .public-site .public-activity-hero-carousel .activity-feed-caption h3 {
    font-size: 1.375rem;
    line-height: 1.25;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-prev {
    left: .65rem;
  }

  .public-site .public-activity-hero-carousel .activity-carousel-next {
    right: .65rem;
  }
}

@media (max-width: 340px) {
  .public-site .public-activity-hero-carousel .activity-feed-main {
    min-height: 300px;
  }

  .public-site .public-activity-hero-carousel .activity-feed-caption h3 {
    font-size: 1.3rem;
  }
}

/* Fase M16 - Popular Publications Main Feature */
.public-site .public-popular-publications {
  margin-bottom: clamp(2rem, 3.5vw, 2.7rem);
  padding: clamp(1.4rem, 2.4vw, 1.85rem) clamp(1.2rem, 2.5vw, 1.7rem) clamp(1.8rem, 3vw, 2.35rem);
  background: #fff;
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius);
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-popular-publications-heading {
  margin-bottom: clamp(1rem, 2vw, 1.3rem);
}

.public-site .public-popular-publications-heading h2 {
  margin: 0;
  color: var(--brand-ink);
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  font-weight: 680;
  line-height: 1.18;
}

.public-site .public-popular-publication-grid {
  grid-template-columns: minmax(0, 1.28fr) minmax(14.5rem, .72fr);
  align-items: start;
  gap: clamp(1.2rem, 2.3vw, 1.8rem);
}

.public-site .public-popular-publication-grid .home-publication-feature img {
  aspect-ratio: 16 / 7.35;
}

.public-site .public-popular-publication-grid .home-publication-feature h3 {
  display: -webkit-box;
  overflow: hidden;
  font-size: clamp(1.2rem, 1.8vw, 1.52rem);
  line-height: 1.24;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.public-site .public-popular-publication-grid .home-publication-feature p {
  display: -webkit-box;
  overflow: hidden;
  max-width: 41rem;
  font-size: .93rem;
  line-height: 1.58;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.public-site .public-popular-publication-grid .home-publication-list {
  border-top: 0;
}

.public-site .public-popular-publication-grid .home-publication-item {
  grid-template-columns: 5.25rem minmax(0, 1fr);
  gap: .8rem;
  padding-block: .15rem 1rem;
  margin-bottom: 1rem;
}

.public-site .public-popular-publication-grid .home-publication-item img {
  height: 3.8rem;
}

.public-site .public-popular-publication-grid .home-publication-item h3 {
  display: -webkit-box;
  overflow: hidden;
  font-size: .96rem;
  line-height: 1.4;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.public-site .public-popular-publication-grid .home-publication-index {
  margin-top: .1rem;
}

@media (max-width: 1199.98px) {
  .public-site .public-popular-publication-grid {
    grid-template-columns: 1fr;
  }
}

/* Fase M17 - Consistent Desktop Navigation Dropdown Offset */
@media (min-width: 1200px) {
  .public-site #header .hs-has-mega-menu>.public-navbar-mega-menu {
    top: calc(var(--public-navbar-offset, 72px) - 1.46rem);
  }

  .public-site #header .hs-has-mega-menu>.public-navbar-mega-menu::before {
    inset: -.8rem 0 auto;
    height: .8rem;
  }

  .public-site #header .public-navbar-more>.hs-mega-menu.hs-position-right {
    top: calc(100% + .28rem);
  }

  .public-site #header .public-navbar-more>.hs-mega-menu.hs-position-right::before {
    content: none;
  }

  .public-site #header .public-navbar-activities-menu,
  .public-site #header .public-navbar-more:not(.public-navbar-schedule):not(.public-navbar-activities)>.public-navbar-more-menu {
    width: clamp(16.75rem, 20vw, 18.5rem);
    min-width: 16.75rem !important;
    max-width: calc(100vw - 2rem);
  }
}

/* Fase M18 - Compact Navigation Text Wrapping */
.public-site #header .navbar-nav .nav-dropdown-toggle>span {
  min-width: 0;
}

.public-site #header .navbar-nav .nav-dropdown-toggle::after {
  flex: 0 0 auto;
  margin-left: .42rem;
}

.public-site #header .public-navbar-activities-menu .dropdown-item,
.public-site #header .public-navbar-more:not(.public-navbar-schedule):not(.public-navbar-activities)>.public-navbar-more-menu .dropdown-item {
  white-space: normal;
  overflow-wrap: break-word;
  line-height: 1.38;
}

@media (max-width: 1199.98px) {
  .public-site #header .navbar-nav .nav-dropdown-toggle {
    width: 100%;
    gap: .75rem;
  }
}

/* Fase M19 - Tablet Navigation Collapse Guard */
@media (min-width: 992px) and (max-width: 1199.98px) {
  .public-site #header.navbar-expand-xl .navbar-toggler {
    display: inline-flex;
  }

  .public-site #header .navbar-nav-wrap {
    flex-wrap: wrap;
    gap: .6rem;
  }

  .public-site #header.navbar-expand-xl .navbar-collapse {
    display: none !important;
    flex-basis: 100%;
    width: 100%;
    max-width: min(32rem, 100%);
    max-height: min(74vh, 36rem);
    overflow-y: auto;
    overscroll-behavior: contain;
    margin-top: .45rem;
    margin-left: auto;
    padding: .75rem;
    background: #fff;
    border: 1px solid rgba(17, 42, 34, .1);
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(17, 42, 34, .08);
  }

  .public-site #header.navbar-expand-xl .navbar-collapse.show {
    display: block !important;
  }

  .public-site .public-navbar-nav {
    display: grid;
    gap: .35rem;
    width: 100%;
  }

  .public-site #header .navbar-nav .nav-link,
  .public-site .public-navbar-cta {
    justify-content: space-between;
    width: 100%;
    min-height: 2.7rem;
    padding: .72rem .82rem;
    border-radius: var(--brand-radius);
    font-size: .94rem;
    text-align: left;
  }

  .public-site #header .hs-has-mega-menu>.hs-mega-menu,
  .public-site #header .public-navbar-more-menu {
    position: static;
    width: 100%;
    min-width: 0 !important;
    max-width: 100%;
    margin-top: .35rem;
    padding: .5rem;
    transform: none !important;
    background: rgba(248, 250, 247, .9);
    border: 1px solid rgba(17, 42, 34, .08);
    border-radius: 8px;
    box-shadow: none;
  }

  .public-site .public-navbar-mega-menu .navbar-dropdown-menu-inner,
  .public-site #header .public-navbar-more-menu .navbar-dropdown-menu-inner {
    gap: .25rem;
    padding: .35rem;
  }
}

/* Fase M20 - Compact Navigation Marker Clearance */
@media (min-width: 1200px) {

  .public-site #header .public-navbar-more.public-navbar-activities>.hs-mega-menu.public-navbar-activities-menu.hs-position-right,
  .public-site #header .public-navbar-more:not(.public-navbar-schedule):not(.public-navbar-activities)>.hs-mega-menu.public-navbar-more-menu.hs-position-right {
    width: clamp(18.75rem, 22vw, 20rem);
    min-width: 18.75rem !important;
  }
}

.public-site #header .public-navbar-more-menu .dropdown-item {
  padding-right: 2.75rem;
}

.public-site #header .public-navbar-more-menu .dropdown-item::after {
  content: "";
  display: block;
}

/* Fase M21 - Registration Masyayikh Profile List */
.public-site .registration-masyayikh-section .public-section-heading {
  margin-bottom: clamp(1.65rem, 2.4vw, 2rem) !important;
}

.public-site .registration-masyayikh-list {
  gap: .72rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: 72rem;
}

.public-site .registration-masyaikh-card {
  grid-template-columns: 2rem 4.5rem minmax(0, 1fr);
  gap: .72rem;
  align-items: center;
  min-height: 0;
  padding: .68rem .95rem .68rem .68rem;
  border-radius: var(--brand-radius);
}

.public-site .registration-masyaikh-number {
  align-self: center;
  color: var(--brand-gold);
  font-size: .76rem;
  font-weight: 780;
  letter-spacing: .08em;
  text-align: center;
}

.public-site .registration-masyaikh-card img {
  width: 4.5rem;
  height: 5.65rem;
  min-height: 0;
  aspect-ratio: auto;
  object-fit: cover;
  object-position: center top;
  border: 1px solid rgba(16, 35, 29, .1);
  border-radius: var(--brand-radius-sm);
  padding: 0;
}

.public-site .registration-masyaikh-card h3 {
  margin: 0;
  font-size: clamp(.98rem, 1.2vw, 1.12rem);
  font-weight: 720;
  line-height: 1.34;
  -webkit-line-clamp: 3;
}

@media (max-width: 767.98px) {
  .public-site .registration-masyayikh-list {
    grid-template-columns: 1fr;
    max-width: 28rem;
  }
}

@media (max-width: 575.98px) {
  .public-site .registration-masyayikh-list {
    gap: .75rem;
  }

  .public-site .registration-masyaikh-card {
    grid-template-columns: 1.7rem 3.8rem minmax(0, 1fr);
    gap: .52rem;
    padding: .56rem .68rem .56rem .56rem;
  }

  .public-site .registration-masyaikh-number {
    font-size: .68rem;
  }

  .public-site .registration-masyaikh-card img {
    width: 3.8rem;
    height: 4.8rem;
  }

  .public-site .registration-masyaikh-card h3 {
    font-size: .9rem;
  }
}

/* Fase M22 - Registration Contact And Brochure Panels */
.public-site .registration-contact-section {
  scroll-margin-top: var(--public-navbar-offset);
}

.public-site .registration-contact-section .public-section-heading {
  max-width: 46rem;
}

.public-site .registration-contact-section .public-section-heading p {
  color: rgba(255, 255, 255, .76) !important;
}

.public-site .registration-contact-grid {
  max-width: 70rem;
  margin-inline: auto;
}

.public-site .registration-contact-section .registration-action-panel {
  padding: clamp(1.15rem, 2vw, 1.5rem);
  border-radius: var(--brand-radius-lg);
}

.public-site .registration-contact-section .registration-action-panel h3 {
  margin-bottom: 1rem;
  font-size: clamp(1.18rem, 1.55vw, 1.38rem);
}

.public-site .registration-contact-list {
  display: grid;
  gap: .65rem;
}

.public-site .registration-contact-group {
  display: grid;
  gap: .65rem;
}

.public-site .registration-contact-group+.registration-contact-group {
  margin-top: .35rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, .16);
}

.public-site .registration-contact-group h4 {
  margin: 0;
  color: rgba(235, 198, 126, .96);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .12em;
  line-height: 1.2;
  text-transform: uppercase;
}

.public-site .registration-contact-items {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
}

.public-site .registration-contact-list .registration-contact-item {
  position: relative;
  display: grid;
  grid-template-columns: 2.2rem minmax(0, 1fr) auto;
  align-items: center;
  gap: .65rem;
  min-height: 4.8rem;
  padding: .72rem .75rem;
  text-decoration: none;
}

.public-site .registration-contact-list .registration-contact-item>i {
  display: inline-grid;
  place-items: center;
  width: 2.2rem;
  height: 2.2rem;
  background: rgba(235, 198, 126, .13);
  border-radius: 50%;
  font-size: 1rem;
}

.public-site .registration-contact-list .registration-contact-item span {
  min-width: 0;
}

.public-site .registration-contact-list .registration-contact-item strong,
.public-site .registration-download-card strong {
  display: block;
  color: #fff;
  font-size: .94rem;
  line-height: 1.3;
}

.public-site .registration-contact-list .registration-contact-item small,
.public-site .registration-download-card small,
.public-site .registration-download-intro {
  display: block;
  color: rgba(255, 255, 255, .7);
  font-size: .84rem;
  line-height: 1.45;
}

.public-site .registration-contact-list .registration-contact-item em {
  color: rgba(235, 198, 126, .96);
  font-size: .76rem;
  font-style: normal;
  font-weight: 760;
  white-space: nowrap;
}

.public-site .registration-contact-list .registration-contact-item em i {
  margin-left: .16rem;
  font-size: .72rem;
}

.public-site .registration-contact-item-static {
  grid-template-columns: 2.2rem minmax(0, 1fr);
  color: #fff;
  background: rgba(255, 255, 255, .11);
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: var(--brand-radius);
}

.public-site .registration-download-intro {
  margin: -.35rem 0 1rem;
}

.public-site .registration-download-list {
  display: grid;
  gap: .65rem;
}

.public-site .registration-download-card {
  display: grid;
  grid-template-columns: 2.2rem minmax(0, 1fr) auto;
  align-items: center;
  gap: .65rem;
  min-height: 5rem;
  padding: .72rem .75rem;
  flex-direction: row;
}

.public-site .registration-download-card>i {
  display: inline-grid;
  place-items: center;
  width: 2.2rem;
  height: 2.2rem;
  background: rgba(235, 198, 126, .13);
  border-radius: 50%;
  font-size: 1rem;
}

.public-site .registration-download-card span {
  min-width: 0;
}

.public-site .registration-download-card .link {
  color: rgba(235, 198, 126, .96) !important;
  font-size: .76rem;
  font-weight: 760;
  white-space: nowrap;
}

.public-site .registration-download-card .link i {
  margin-left: .15rem;
  font-size: .72rem;
}

@media (max-width: 767.98px) {
  .public-site .registration-contact-items {
    grid-template-columns: 1fr;
  }

  .public-site .registration-contact-list .registration-contact-item,
  .public-site .registration-download-card {
    grid-template-columns: 2.1rem minmax(0, 1fr);
  }

  .public-site .registration-contact-list .registration-contact-item em,
  .public-site .registration-download-card .link {
    grid-column: 2;
  }
}

/* Fase M24 - Public Masyayikh Profiles */
.public-site .public-masyayikh-profile-link {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-top: 1rem;
  color: var(--brand-green);
  font-size: .92rem;
  font-weight: 650;
  text-decoration: none;
}

.public-site .public-masyayikh-profile-link:hover {
  color: var(--brand-ink);
}

.public-site .public-masyayikh-detail-page {
  max-width: 78rem;
  padding-top: clamp(2.5rem, 5vw, 4.25rem);
}

.public-site .public-masyayikh-back-link {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
  color: var(--brand-green);
  font-size: .94rem;
  font-weight: 650;
  text-decoration: none;
}

.public-site .public-masyayikh-detail-hero {
  display: grid;
  grid-template-columns: clamp(13rem, 21vw, 18.5rem) minmax(0, 1fr);
  align-items: start;
  gap: clamp(1.8rem, 5vw, 3.8rem);
  padding-bottom: clamp(2rem, 4vw, 3.2rem);
  border-bottom: 1px solid var(--brand-border);
}

.public-site .public-masyayikh-detail-photo {
  margin: 0;
  overflow: hidden;
  background: #edf3ee;
  border-radius: 4px;
}

.public-site .public-masyayikh-detail-photo img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1.14;
  object-fit: cover;
  object-position: center top;
}

.public-site .public-masyayikh-detail-identity h1 {
  max-width: 20ch;
  margin-bottom: .8rem;
  color: var(--brand-ink);
  font-size: clamp(2rem, 4.3vw, 3.2rem);
  line-height: 1.08;
}

.public-site .public-masyayikh-detail-category {
  display: block;
  margin-bottom: clamp(1.5rem, 3vw, 2.25rem);
  color: #8b7040;
  font-size: .74rem;
  font-weight: 750;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-masyayikh-detail-facts {
  display: grid;
  gap: 1rem;
  margin: 0;
}

.public-site .public-masyayikh-detail-facts div {
  padding-top: .8rem;
  border-top: 1px solid var(--brand-border);
}

.public-site .public-masyayikh-detail-facts dt,
.public-site .public-masyayikh-detail-section h2 {
  margin-bottom: .42rem;
  color: #8b7040;
  font-size: .74rem;
  font-weight: 750;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-masyayikh-detail-facts dd {
  margin: 0;
  color: var(--brand-ink);
  font-size: 1.02rem;
  line-height: 1.58;
}

.public-site .public-masyayikh-detail-sections {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.3rem, 3vw, 2.5rem);
  padding-block: clamp(2rem, 4vw, 3rem);
}

.public-site .public-masyayikh-detail-section p {
  margin: 0;
  color: var(--brand-muted);
  font-size: .98rem;
  line-height: 1.8;
}

@media (max-width: 991.98px) {
  .public-site .public-masyayikh-detail-sections {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-masyayikh-detail-hero {
    grid-template-columns: 1fr;
  }

  .public-site .public-masyayikh-detail-photo {
    max-width: 16rem;
  }
}

/* MDQH institutional loading system */
html.mdq-loader-seen .mdq-site-loader {
  display: none;
}

html.mdq-loader-pending,
html.mdq-loader-pending body {
  overflow: hidden;
}

.mdq-site-loader {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  display: grid;
  place-items: center;
  width: 100vw;
  min-height: 100vh;
  padding: 1.5rem;
  color: #f8f6f0;
  background: #073526;
  opacity: 1;
  visibility: visible;
  transition: opacity .28s ease, visibility .28s ease;
}

.mdq-site-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.mdq-site-loader-panel {
  display: grid;
  justify-items: center;
  width: min(100%, 40rem);
  transform: translateY(6px);
  opacity: 0;
  animation: mdq-loader-enter .42s cubic-bezier(.2, .8, .2, 1) .04s forwards;
}

.mdq-site-loader-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: clamp(.8rem, 2.2vw, 1rem);
  max-width: 100%;
}

.mdq-site-loader-logo {
  display: inline-grid;
  place-items: center;
  width: clamp(3.4rem, 7vw, 4.25rem);
  height: clamp(3.4rem, 7vw, 4.25rem);
  flex: 0 0 auto;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.mdq-site-loader-logo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.mdq-site-loader-mark {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.mdq-site-loader-mark img {
  display: block;
  width: auto;
  height: clamp(2.25rem, 5.2vw, 3rem);
  max-width: min(27rem, 68vw);
}

.mdq-site-loader-line {
  position: relative;
  display: block;
  width: clamp(18rem, 34vw, 26rem);
  height: 2px;
  margin-top: clamp(1.55rem, 2.6vw, 1.95rem);
  margin-left: clamp(3.4rem, 7vw, 4.25rem);
  overflow: hidden;
  background: rgba(248, 246, 240, .18);
  border-radius: 0;
}

.mdq-site-loader-line span {
  position: absolute;
  inset: 0 auto 0 0;
  display: block;
  width: 42%;
  background: #c9a45c;
  border-radius: inherit;
  transform: translateX(-110%);
  animation: mdq-loader-line 1.08s cubic-bezier(.55, .08, .2, 1) infinite;
}

.mdq-page-progress {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2147483001;
  width: 100%;
  height: 2px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  background: transparent;
  transition: opacity .18s ease;
}

.mdq-page-progress span {
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, #0b4d38, #c9a45c);
  transform: scaleX(0);
  transform-origin: left;
}

.mdq-page-progress.is-active {
  opacity: 1;
}

.mdq-page-progress.is-active span {
  animation: mdq-page-progress 1.1s cubic-bezier(.18, .72, .2, 1) forwards;
}

.mdq-page-progress.is-finishing span {
  transform: scaleX(1);
  transition: transform .16s ease;
}

.mdq-skeleton,
.mdq-skeleton-line,
.mdq-skeleton-thumb {
  position: relative;
  overflow: hidden;
  color: transparent;
  background: #edf3ef;
  border-radius: .9rem;
}

.mdq-skeleton-thumb {
  min-height: 10rem;
}

.mdq-skeleton-line {
  display: block;
  height: .78rem;
  border-radius: 999px;
}

.mdq-skeleton-line.is-short {
  width: 62%;
}

.mdq-skeleton::after,
.mdq-skeleton-line::after,
.mdq-skeleton-thumb::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .72), transparent);
  transform: translateX(-100%);
  animation: mdq-skeleton-shimmer 1.5s ease-in-out infinite;
}

@keyframes mdq-loader-line {
  0% {
    transform: translateX(-110%);
  }

  100% {
    transform: translateX(250%);
  }
}

@keyframes mdq-loader-enter {
  0% {
    opacity: 0;
    transform: translateY(6px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes mdq-page-progress {
  0% {
    transform: scaleX(0);
  }

  72% {
    transform: scaleX(.74);
  }

  100% {
    transform: scaleX(.92);
  }
}

@keyframes mdq-skeleton-shimmer {
  100% {
    transform: translateX(100%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .mdq-site-loader,
  .mdq-site-loader-panel,
  .mdq-page-progress,
  .mdq-site-loader-line span,
  .mdq-page-progress span,
  .mdq-skeleton::after,
  .mdq-skeleton-line::after,
  .mdq-skeleton-thumb::after {
    animation: none !important;
    transition: none !important;
  }

  .mdq-site-loader-line span,
  .mdq-page-progress.is-active span {
    transform: none;
  }
}

@media (max-width: 575.98px) {
  .mdq-site-loader-brand {
    gap: .72rem;
  }

  .mdq-site-loader-logo {
    width: 3rem;
    height: 3rem;
  }

  .mdq-site-loader-mark img {
    height: 2rem;
    max-width: min(15rem, 68vw);
  }

  .mdq-site-loader-line {
    width: clamp(12.5rem, 62vw, 16rem);
    margin-top: 1.25rem;
    margin-left: 0;
  }
}

/* Premium institutional public footer */
footer.bg-dark.public-footer {
  background: #0b4d38 !important;
  border-top: 1px solid rgba(201, 164, 92, .32);
}

.public-site .public-footer {
  position: relative;
  overflow: hidden;
  padding-block: clamp(5rem, 7vw, 6.25rem) clamp(2.6rem, 4vw, 3.6rem);
  color: #f8f6f0;
}

.public-site .public-footer::before {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .025), transparent 34%),
    radial-gradient(circle at 18% 0%, rgba(201, 164, 92, .12), transparent 24rem);
  pointer-events: none;
}

.public-site .public-footer>.container {
  position: relative;
  z-index: 1;
}

.public-site .public-footer-hero {
  display: block;
  padding-bottom: clamp(2.2rem, 4vw, 3rem);
  border-bottom: 1px solid rgba(248, 246, 240, .16);
}

.public-site .public-footer-brand {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  gap: clamp(1.35rem, 2.5vw, 2rem);
  max-width: 68rem;
}

.public-site .public-footer-logo-frame {
  display: inline-grid;
  place-items: center;
  width: clamp(5.35rem, 7.4vw, 6.4rem);
  height: clamp(5.35rem, 7.4vw, 6.4rem);
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.public-site .public-footer-logo-frame img,
.public-site .public-footer-brand img {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  object-fit: contain;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.public-site .public-footer-identity {
  min-width: 0;
}

.public-site .public-footer-kicker {
  display: block;
  margin-bottom: .42rem;
  color: #c9a45c;
  font-size: .78rem;
  font-weight: 780;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.public-site .public-footer h2 {
  margin: 0 0 .35rem;
  color: #fff;
  font-size: clamp(2rem, 3.1vw, 3.15rem);
  font-weight: 760;
  line-height: 1.05;
  letter-spacing: -.035em;
  text-shadow: none;
}

.public-site .public-footer .public-footer-brand p {
  max-width: 56rem;
  margin: 0;
  color: #fff !important;
  font-size: clamp(1rem, 1.35vw, 1.22rem);
  font-weight: 520;
  line-height: 1.5;
}

.public-site .public-footer .public-footer-tagline {
  margin-top: .72rem;
  color: rgba(248, 246, 240, .84) !important;
  font-size: clamp(1rem, 1.18vw, 1.12rem);
  font-weight: 560;
}

.public-site .public-footer .public-footer-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  min-width: max-content;
  min-height: 3.35rem;
  margin-top: clamp(1.25rem, 2.4vw, 1.8rem);
  padding: .86rem 1.35rem;
  color: #073224;
  background: #f8f6f0;
  border: 1px solid rgba(201, 164, 92, .55);
  border-radius: 8px;
  box-shadow: none;
  font-weight: 760;
}

.public-site .public-footer .public-footer-cta:hover,
.public-site .public-footer .public-footer-cta:focus {
  color: #073224;
  background: #c9a45c;
  border-color: #c9a45c;
  transform: translateY(-1px);
}

.public-site .public-footer-main {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(12rem, .9fr) minmax(12rem, .9fr);
  gap: clamp(3.2rem, 5vw, 4.5rem);
  padding-block: clamp(2.4rem, 4.8vw, 3.8rem);
}

.public-site .public-footer-panel {
  min-height: 0;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.public-site .public-footer-panel .text-cap,
.public-site footer .text-cap {
  display: block;
  margin-bottom: 1.15rem;
  color: #ffe2a4 !important;
  font-size: .8rem;
  font-weight: 780;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.public-site .public-footer-contact ul {
  display: grid;
  gap: .82rem;
}

.public-site .public-footer-contact li {
  display: grid;
  grid-template-columns: 1.55rem minmax(0, 1fr);
  align-items: start;
  gap: .72rem;
  color: rgba(248, 246, 240, .92);
  font-size: .98rem;
  line-height: 1.65;
}

.public-site .public-footer-contact i,
.public-site .public-footer-social i {
  display: inline-grid;
  place-items: center;
  width: 1.35rem;
  min-width: 1.35rem;
  color: #c9a45c;
  font-size: 1rem;
  line-height: 1;
}

.public-site .public-footer-links,
.public-site .public-footer-social {
  display: grid;
  grid-template-columns: 1fr;
  gap: .54rem;
}

.public-site .public-footer-links a,
.public-site .public-footer-social a {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  width: fit-content;
  min-height: 2.25rem;
  color: rgba(248, 246, 240, .9);
  font-size: .98rem;
  font-weight: 640;
  line-height: 1.35;
  text-decoration: none;
  transition: color .2s ease, opacity .2s ease, transform .2s ease;
}

.public-site .public-footer-links a {
  padding-left: .85rem;
}

.public-site .public-footer-links a::before {
  position: absolute;
  left: 0;
  top: 50%;
  width: .28rem;
  height: .28rem;
  content: "";
  background: rgba(201, 164, 92, .55);
  border-radius: 999px;
  transform: translateY(-50%);
  transition: width .2s ease, background-color .2s ease;
}

.public-site .public-footer-links a:hover,
.public-site .public-footer-links a:focus {
  color: #ffe2a4;
  transform: translateX(4px);
}

.public-site .public-footer-links a:hover::before,
.public-site .public-footer-links a:focus::before {
  width: .55rem;
  background: #c9a45c;
}

.public-site .public-footer-social a:hover,
.public-site .public-footer-social a:focus {
  color: #ffe2a4;
  opacity: .86;
  transform: translateX(2px);
}

.public-site .public-footer-empty {
  max-width: 20rem;
  color: rgba(248, 246, 240, .68) !important;
  font-size: .94rem;
  line-height: 1.65;
}

.public-site .public-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.2rem;
  padding-top: clamp(1.4rem, 2.4vw, 1.8rem);
  border-top: 1px solid rgba(248, 246, 240, .16);
}

.public-site .public-footer-bottom p {
  margin: 0;
  color: rgba(248, 246, 240, .58);
  font-size: .9rem;
  line-height: 1.45;
}

@media (prefers-reduced-motion: reduce) {
  .public-site .public-footer .public-footer-cta,
  .public-site .public-footer-links a,
  .public-site .public-footer-social a {
    transition: none;
  }
}

@media (max-width: 991.98px) {
  .public-site .public-footer .public-footer-cta {
    width: fit-content;
  }

  .public-site .public-footer-main {
    grid-template-columns: 1fr 1fr;
  }

  .public-site .public-footer-contact {
    grid-column: 1 / -1;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-footer {
    padding-block: 4rem 2.25rem;
  }

  .public-site .public-footer-brand {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .public-site .public-footer-logo-frame {
    width: 5.05rem;
    height: 5.05rem;
  }

  .public-site .public-footer-main {
    grid-template-columns: 1fr;
    gap: 2.15rem;
  }

  .public-site .public-footer .public-footer-cta,
  .public-site .public-footer-links a,
  .public-site .public-footer-social a {
    width: 100%;
  }

  .public-site .public-footer-links a,
  .public-site .public-footer-social a {
    min-height: 2.6rem;
  }

  .public-site .public-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* Sesi Theme 3 - Public Site Dark Mode */
html[data-theme="dark"] body.public-site {
  color: var(--default-color);
  background:
    radial-gradient(circle at 18% 0%, rgba(201, 164, 92, .08), transparent 24rem),
    linear-gradient(180deg, rgba(11, 61, 46, .28), transparent 28rem),
    var(--brand-bg);
}

html[data-theme="dark"] .public-site #content,
html[data-theme="dark"] .public-site main,
html[data-theme="dark"] .public-site .public-section,
html[data-theme="dark"] .public-site .content-space-1,
html[data-theme="dark"] .public-site .content-space-2,
html[data-theme="dark"] .public-site .public-schedule-page,
html[data-theme="dark"] .public-site .public-masyayikh-page,
html[data-theme="dark"] .public-site .public-masyayikh-detail-page,
html[data-theme="dark"] .public-site .public-activity-page,
html[data-theme="dark"] .public-site .public-listing-page,
html[data-theme="dark"] .public-site .public-feedback-page {
  color: var(--default-color);
  background-color: transparent;
}

html[data-theme="dark"] .public-site h1,
html[data-theme="dark"] .public-site h2,
html[data-theme="dark"] .public-site h3,
html[data-theme="dark"] .public-site h4,
html[data-theme="dark"] .public-site h5,
html[data-theme="dark"] .public-site h6,
html[data-theme="dark"] .public-site .public-page-heading h1,
html[data-theme="dark"] .public-site .public-section-heading,
html[data-theme="dark"] .public-site .public-schedule-panel-header h2,
html[data-theme="dark"] .public-site .public-masyayikh-profile-heading h2,
html[data-theme="dark"] .public-site .public-masyayikh-detail-identity h1,
html[data-theme="dark"] .public-site .public-activity-listing-toolbar h2,
html[data-theme="dark"] .public-site .public-article-title,
html[data-theme="dark"] .public-site .activity-detail-title {
  color: var(--heading-color) !important;
}

html[data-theme="dark"] .public-site p,
html[data-theme="dark"] .public-site .lead,
html[data-theme="dark"] .public-site .public-page-heading p,
html[data-theme="dark"] .public-site .public-schedule-panel-header p,
html[data-theme="dark"] .public-site .public-activity-page-heading p,
html[data-theme="dark"] .public-site .public-activity-listing-toolbar p,
html[data-theme="dark"] .public-site .text-body,
html[data-theme="dark"] .public-site .text-body-secondary {
  color: var(--brand-muted) !important;
}

html[data-theme="dark"] .public-site .public-section-kicker,
html[data-theme="dark"] .public-site .public-kicker,
html[data-theme="dark"] .public-site .text-cap,
html[data-theme="dark"] .public-site .dropdown-header,
html[data-theme="dark"] .public-site .public-masyayikh-profile-category,
html[data-theme="dark"] .public-site .public-masyayikh-detail-category,
html[data-theme="dark"] .public-site .activity-feed-badge,
html[data-theme="dark"] .public-site .activity-aside-kicker {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site #header.public-navbar,
html[data-theme="dark"] .public-site.scrolled #header.public-navbar,
html[data-theme="dark"] .public-site.mdq-cinema-enabled #header.public-navbar,
html[data-theme="dark"] .public-site.mdq-cinema-enabled.mdq-scroll-up #header.public-navbar,
html[data-theme="dark"] .public-site.mdq-cinema-enabled.mdq-scroll-resting #header.public-navbar {
  background: rgba(7, 31, 24, .94) !important;
  border-bottom-color: rgba(248, 246, 240, .14) !important;
  box-shadow: 0 12px 32px rgba(0, 0, 0, .22) !important;
  backdrop-filter: blur(18px);
}

html[data-theme="dark"] .public-site #header .navbar-nav .nav-link,
html[data-theme="dark"] .public-site #header .navbar-nav .nav-dropdown-toggle {
  color: var(--heading-color) !important;
}

html[data-theme="dark"] .public-site #header .navbar-nav .nav-link.active,
html[data-theme="dark"] .public-site #header .navbar-nav .nav-link[aria-expanded="true"],
html[data-theme="dark"] .public-site #header .navbar-nav .nav-link:hover,
html[data-theme="dark"] .public-site #header .navbar-nav .nav-link:focus {
  color: var(--brand-gold) !important;
  box-shadow: inset 0 -2px 0 var(--brand-gold);
}

@media (max-width: 1199.98px) {
  html[data-theme="dark"] .public-site #header .navbar-nav .nav-link.active,
  html[data-theme="dark"] .public-site #header .navbar-nav .nav-link[aria-expanded="true"],
  html[data-theme="dark"] .public-site #header .navbar-nav .nav-link:hover,
  html[data-theme="dark"] .public-site #header .navbar-nav .nav-link:focus {
    background: rgba(201, 164, 92, .14);
    box-shadow: none !important;
  }
}

html[data-theme="dark"] .public-site .navbar-toggler,
html[data-theme="dark"] .public-site .public-navbar-cta,
html[data-theme="dark"] .public-site .public-theme-toggle {
  color: var(--heading-color) !important;
  background: rgba(248, 246, 240, .07) !important;
  border-color: rgba(248, 246, 240, .18) !important;
}

html[data-theme="dark"] .public-site #header .dropdown-menu,
html[data-theme="dark"] .public-site #header .hs-mega-menu,
html[data-theme="dark"] .public-site #header .public-navbar-more-menu,
html[data-theme="dark"] .public-site #header .public-navbar-mega-menu .navbar-dropdown-menu-inner,
html[data-theme="dark"] .public-site #header .navbar-dropdown-menu-inner {
  color: var(--default-color) !important;
  background: rgba(13, 45, 35, .98) !important;
  border-color: rgba(248, 246, 240, .14) !important;
  box-shadow: var(--brand-shadow-strong) !important;
}

html[data-theme="dark"] .public-site #header .dropdown-item,
html[data-theme="dark"] .public-site #header .public-navbar-more-menu .dropdown-item {
  color: var(--heading-color) !important;
}

html[data-theme="dark"] .public-site #header .dropdown-item:hover,
html[data-theme="dark"] .public-site #header .dropdown-item:focus,
html[data-theme="dark"] .public-site #header .dropdown-item.active {
  color: var(--brand-gold) !important;
  background: rgba(248, 246, 240, .07) !important;
}

html[data-theme="dark"] .public-site .public-nav-feature,
html[data-theme="dark"] .public-site .public-nav-download {
  color: var(--default-color) !important;
  background: rgba(248, 246, 240, .06) !important;
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-home-hero {
  background:
    linear-gradient(90deg, rgba(7, 31, 24, .94), rgba(7, 31, 24, .66)),
    var(--brand-bg) !important;
  border-bottom-color: var(--brand-border);
}

html[data-theme="dark"] .public-site .public-home-hero .public-hero-copy h1,
html[data-theme="dark"] .public-site .public-home-hero .public-hero-copy h2 {
  color: var(--heading-color) !important;
}

html[data-theme="dark"] .public-site .public-home-hero .public-hero-copy p {
  color: rgba(215, 226, 220, .78) !important;
}

html[data-theme="dark"] .public-site .public-home-hero .public-hero-media,
html[data-theme="dark"] .public-site .public-home-hero .public-hero-image,
html[data-theme="dark"] .public-site .public-home-hero .public-hero-quote,
html[data-theme="dark"] .public-site .public-home-hero .public-hero-mini-stats span {
  color: var(--default-color);
  background: rgba(13, 45, 35, .78) !important;
  border-color: rgba(248, 246, 240, .14) !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .28) !important;
}

html[data-theme="dark"] .public-site .public-home-hero .public-hero-quote .fs-5,
html[data-theme="dark"] .public-site .public-home-hero .public-hero-mini-stats strong {
  color: var(--heading-color) !important;
}

html[data-theme="dark"] .public-site .card,
html[data-theme="dark"] .public-site .public-feature-card,
html[data-theme="dark"] .public-site .public-stat-card,
html[data-theme="dark"] .public-site .registration-logo-row,
html[data-theme="dark"] .public-site .registration-intro-card,
html[data-theme="dark"] .public-site .registration-notice-card,
html[data-theme="dark"] .public-site .registration-document,
html[data-theme="dark"] .public-site .registration-masyaikh-card,
html[data-theme="dark"] .public-site .registration-action-panel,
html[data-theme="dark"] .public-site .public-schedule-panel,
html[data-theme="dark"] .public-site .public-class-section,
html[data-theme="dark"] .public-site .public-class-day,
html[data-theme="dark"] .public-site .public-post-card,
html[data-theme="dark"] .public-site .public-empty-state,
html[data-theme="dark"] .public-site .public-map-empty,
html[data-theme="dark"] .public-site .activity-aside-panel,
html[data-theme="dark"] .public-site .public-masyayikh-profile-card,
html[data-theme="dark"] .public-site .public-masyayikh-detail-hero,
html[data-theme="dark"] .public-site .public-masyayikh-detail-section,
html[data-theme="dark"] .public-site .public-editor-card,
html[data-theme="dark"] .public-site .public-editor-board,
html[data-theme="dark"] .public-site .public-editor-toolbar,
html[data-theme="dark"] .public-site .public-feedback-form-card,
html[data-theme="dark"] .public-site .public-feedback-info-card,
html[data-theme="dark"] .public-site .reader-reaction-section,
html[data-theme="dark"] .public-site .activity-detail-main,
html[data-theme="dark"] .public-site .public-activity-detail-main,
html[data-theme="dark"] .public-site .public-activity-listing-aside,
html[data-theme="dark"] .public-site .public-activity-listing-main,
html[data-theme="dark"] .public-site .public-activity-mobile-search {
  color: var(--default-color) !important;
  background: rgba(13, 45, 35, .82) !important;
  border-color: rgba(248, 246, 240, .14) !important;
  box-shadow: 0 16px 44px rgba(0, 0, 0, .18) !important;
}

html[data-theme="dark"] .public-site .public-schedule-panel,
html[data-theme="dark"] .public-site .public-class-section,
html[data-theme="dark"] .public-site .public-masyayikh-profile-card,
html[data-theme="dark"] .public-site .activity-aside-panel {
  background: rgba(13, 45, 35, .62) !important;
}

html[data-theme="dark"] .public-site .public-registration-hero .hero-image,
html[data-theme="dark"] .public-site .public-feedback-hero .hero-image {
  background-color: #071f18;
}

html[data-theme="dark"] .public-site .public-registration-hero .hero-image::before,
html[data-theme="dark"] .public-site .public-feedback-hero .hero-image::before {
  background: linear-gradient(90deg, rgba(7, 31, 24, .94), rgba(7, 31, 24, .62)) !important;
}

html[data-theme="dark"] .public-site .registration-hero-card,
html[data-theme="dark"] .public-site .public-feedback-hero-card {
  background: rgba(7, 31, 24, .78) !important;
  border-color: rgba(248, 246, 240, .18) !important;
}

html[data-theme="dark"] .public-site .public-activity-feed-section,
html[data-theme="dark"] .public-site .public-activity-editorial-hero,
html[data-theme="dark"] .public-site .public-activity-page-heading,
html[data-theme="dark"] .public-site .public-masyayikh-intro {
  color: var(--default-color);
  background: transparent !important;
}

html[data-theme="dark"] .public-site .activity-feed-main,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-main,
html[data-theme="dark"] .public-site .activity-aside-post-link,
html[data-theme="dark"] .public-site .public-post-card,
html[data-theme="dark"] .public-site .public-editor-activity,
html[data-theme="dark"] .public-site .public-article-mentions a,
html[data-theme="dark"] .public-site .public-article-mentions span {
  background: rgba(248, 246, 240, .055) !important;
  border-color: rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .activity-feed-main::after,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-main::after {
  background: linear-gradient(to top, rgba(0, 0, 0, .74), rgba(0, 0, 0, .2), transparent) !important;
}

html[data-theme="dark"] .public-site .activity-carousel-nav,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-nav {
  color: var(--heading-color) !important;
  background: rgba(248, 246, 240, .94) !important;
  border-color: rgba(248, 246, 240, .35) !important;
}

/* Home feature cards - dark mode refinement */
html[data-theme="dark"] .public-site .public-feature-strip {
  background:
    radial-gradient(circle at 50% 0%, rgba(215, 185, 109, .08), transparent 34rem),
    linear-gradient(180deg, rgba(6, 29, 22, .98), rgba(4, 24, 18, .98)) !important;
}

html[data-theme="dark"] .public-site .public-feature-grid {
  row-gap: 1.35rem;
}

html[data-theme="dark"] .public-site .public-feature-card {
  position: relative;
  min-height: 18.5rem;
  padding: clamp(1.55rem, 2.4vw, 2.1rem) clamp(1.35rem, 2.2vw, 1.85rem) !important;
  overflow: hidden;
  color: rgba(248, 246, 240, .86) !important;
  background:
    linear-gradient(180deg, rgba(248, 246, 240, .07), rgba(248, 246, 240, .035)),
    rgba(11, 61, 46, .62) !important;
  border: 1px solid rgba(248, 246, 240, .12) !important;
  border-radius: 18px !important;
  box-shadow: 0 20px 50px rgba(0, 0, 0, .22) !important;
}

html[data-theme="dark"] .public-site .public-feature-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, rgba(215, 185, 109, .78), rgba(129, 216, 180, .26), transparent);
  opacity: .75;
}

html[data-theme="dark"] .public-site .public-feature-card > div:first-child {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4.55rem;
  height: 4.55rem;
  margin-bottom: 1.45rem !important;
  border-radius: 16px;
  background:
    linear-gradient(145deg, rgba(215, 185, 109, .16), rgba(129, 216, 180, .08)),
    rgba(248, 246, 240, .045);
  border: 1px solid rgba(215, 185, 109, .22);
}

html[data-theme="dark"] .public-site .public-feature-card img {
  width: 3rem !important;
  height: 3rem !important;
  padding: .35rem !important;
  opacity: .95;
  filter: brightness(0) saturate(100%) invert(78%) sepia(31%) saturate(608%) hue-rotate(359deg) brightness(89%) contrast(87%);
}

html[data-theme="dark"] .public-site .public-feature-card h5 {
  max-width: 16rem;
  margin-bottom: .85rem;
  color: #fffaf0 !important;
  font-size: clamp(1.08rem, 1.3vw, 1.22rem);
  font-weight: 760;
  line-height: 1.26;
  letter-spacing: -.015em;
}

html[data-theme="dark"] .public-site .public-feature-card p {
  max-width: 22rem;
  color: rgba(224, 235, 229, .78) !important;
  font-size: clamp(.98rem, 1.1vw, 1.08rem);
  font-weight: 500;
  line-height: 1.62;
}

html[data-theme="dark"] .public-site .public-feature-card:hover {
  transform: translateY(-3px);
  border-color: rgba(215, 185, 109, .34) !important;
  box-shadow: 0 24px 58px rgba(0, 0, 0, .28) !important;
}

@media (max-width: 767.98px) {
  html[data-theme="dark"] .public-site .public-feature-card {
    min-height: unset;
    padding: 1.45rem !important;
  }
}

html[data-theme="dark"] .public-site .activity-carousel-pagination,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-pagination {
  background: rgba(248, 246, 240, .86) !important;
}

html[data-theme="dark"] .public-site .table,
html[data-theme="dark"] .public-site .public-schedule-table,
html[data-theme="dark"] .public-site .public-class-detail-table,
html[data-theme="dark"] .public-site .registration-document-content table,
html[data-theme="dark"] .public-site .public-article-content table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--default-color);
  --bs-table-border-color: rgba(248, 246, 240, .14);
  color: var(--default-color) !important;
  border-color: rgba(248, 246, 240, .14) !important;
}

html[data-theme="dark"] .public-site .table > :not(caption) > * > *,
html[data-theme="dark"] .public-site .public-schedule-table th,
html[data-theme="dark"] .public-site .public-schedule-table td,
html[data-theme="dark"] .public-site .public-class-detail-table th,
html[data-theme="dark"] .public-site .public-class-detail-table td {
  color: var(--default-color) !important;
  background-color: transparent !important;
  border-color: rgba(248, 246, 240, .14) !important;
}

html[data-theme="dark"] .public-site .table thead th,
html[data-theme="dark"] .public-site .public-schedule-table thead th,
html[data-theme="dark"] .public-site .public-class-detail-table thead th,
html[data-theme="dark"] .public-site .registration-notice-fee-table thead th {
  color: var(--heading-color) !important;
  background: rgba(248, 246, 240, .08) !important;
}

html[data-theme="dark"] .public-site .form-control,
html[data-theme="dark"] .public-site .form-select,
html[data-theme="dark"] .public-site textarea,
html[data-theme="dark"] .public-site input:not([type="checkbox"]):not([type="radio"]):not([type="submit"]),
html[data-theme="dark"] .public-site .input-group-text {
  color: var(--heading-color) !important;
  background-color: rgba(248, 246, 240, .07) !important;
  border-color: rgba(248, 246, 240, .18) !important;
}

html[data-theme="dark"] .public-site .form-control::placeholder,
html[data-theme="dark"] .public-site textarea::placeholder,
html[data-theme="dark"] .public-site input::placeholder {
  color: rgba(215, 226, 220, .56) !important;
}

html[data-theme="dark"] .public-site .form-control:focus,
html[data-theme="dark"] .public-site .form-select:focus,
html[data-theme="dark"] .public-site textarea:focus,
html[data-theme="dark"] .public-site input:focus {
  border-color: rgba(215, 185, 109, .72) !important;
  box-shadow: 0 0 0 .2rem rgba(215, 185, 109, .16) !important;
}

html[data-theme="dark"] .public-site .btn-light,
html[data-theme="dark"] .public-site .btn-soft-light,
html[data-theme="dark"] .public-site .public-class-filter button,
html[data-theme="dark"] .public-site .public-class-subfilter button,
html[data-theme="dark"] .public-site .public-schedule-tabs button,
html[data-theme="dark"] .public-site .mdqh-pagination-link,
html[data-theme="dark"] .public-site .public-pagination-link,
html[data-theme="dark"] .public-site .public-pagination-status,
html[data-theme="dark"] .public-site .share-button,
html[data-theme="dark"] .public-site .activity-aside-share-button,
html[data-theme="dark"] .public-site .reader-reaction-card {
  color: var(--heading-color) !important;
  background: rgba(248, 246, 240, .065) !important;
  border-color: rgba(248, 246, 240, .16) !important;
}

html[data-theme="dark"] .public-site .public-class-filter button.active,
html[data-theme="dark"] .public-site .public-class-subfilter button.active,
html[data-theme="dark"] .public-site .public-schedule-tabs button.active,
html[data-theme="dark"] .public-site .mdqh-pagination-link.is-active,
html[data-theme="dark"] .public-site .public-pagination-link:hover,
html[data-theme="dark"] .public-site .reader-reaction-card.is-active {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .btn-primary,
html[data-theme="dark"] .public-site .btn-success,
html[data-theme="dark"] .public-site .public-footer .public-footer-cta {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site a:not(.btn):not(.dropdown-item):not(.nav-link):not(.public-footer a) {
  color: var(--brand-green-2);
}

html[data-theme="dark"] .public-site a:not(.btn):not(.dropdown-item):not(.nav-link):not(.public-footer a):hover {
  color: var(--brand-gold);
}

html[data-theme="dark"] .public-site .public-article-content,
html[data-theme="dark"] .public-site .registration-document-content,
html[data-theme="dark"] .public-site .activity-detail-content,
html[data-theme="dark"] .public-site .public-feedback-copy {
  color: var(--default-color) !important;
}

html[data-theme="dark"] .public-site .public-article-content blockquote,
html[data-theme="dark"] .public-site .registration-document-content blockquote,
html[data-theme="dark"] .public-site .activity-detail-content blockquote,
html[data-theme="dark"] .public-site .public-alert,
html[data-theme="dark"] .public-site .toast-notification {
  color: var(--heading-color) !important;
  background: rgba(248, 246, 240, .07) !important;
  border-color: rgba(215, 185, 109, .34) !important;
}

html[data-theme="dark"] .public-site .public-footer,
html[data-theme="dark"] footer.bg-dark.public-footer {
  background:
    linear-gradient(135deg, #08271e, #0b3d2e 58%, #071f18) !important;
  border-top-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-footer-panel,
html[data-theme="dark"] .public-site .public-footer-links a,
html[data-theme="dark"] .public-site .public-footer-social a {
  color: rgba(248, 246, 240, .9) !important;
}

html[data-theme="dark"] .public-site .public-footer-bottom p {
  color: rgba(248, 246, 240, .62) !important;
}

@media (max-width: 991.98px) {
  html[data-theme="dark"] .public-site .navbar-collapse,
  html[data-theme="dark"] .public-site .public-navbar-nav,
  html[data-theme="dark"] .public-site .public-mobile-menu,
  html[data-theme="dark"] .public-site #header .navbar-collapse {
    color: var(--default-color);
    background: rgba(7, 31, 24, .98) !important;
    border-color: rgba(248, 246, 240, .14) !important;
  }
}

/* Theme Switch - compact icon-only control */
.ui-switch.mdq-theme-toggle {
  --switch-bg: rgba(15, 61, 46, .18);
  --switch-width: 48px;
  --switch-height: 20px;
  --circle-diameter: 32px;
  --circle-bg: var(--brand-green-deep, #0b3d2e);
  --circle-inset: calc((var(--circle-diameter) - var(--switch-height)) / 2);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--switch-width);
  min-width: var(--switch-width);
  min-height: var(--circle-diameter);
  padding: 0;
  color: inherit;
  background: transparent !important;
  border: 0 !important;
  border-radius: 999px;
  box-shadow: none !important;
  cursor: pointer;
  transform: none !important;
}

.ui-switch.mdq-theme-toggle input {
  display: none;
}

.ui-switch.mdq-theme-toggle .slider {
  width: var(--switch-width);
  height: var(--switch-height);
  position: relative;
  cursor: pointer;
  background: var(--switch-bg);
  border-radius: 999px;
  appearance: none;
}

.ui-switch.mdq-theme-toggle .slider .circle {
  position: absolute;
  top: calc(var(--circle-inset) * -1);
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--circle-diameter);
  height: var(--circle-diameter);
  background-color: var(--circle-bg);
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjAiIHdpZHRoPSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICAgIDxwYXRoIGZpbGw9IiNmZmYiCiAgICAgICAgZD0iTTkuMzA1IDEuNjY3VjMuNzVoMS4zODlWMS42NjdoLTEuMzl6bS00LjcwNyAxLjk1bC0uOTgyLjk4Mkw1LjA5IDYuMDcybC45ODItLjk4Mi0xLjQ3My0xLjQ3M3ptMTAuODAyIDBMMTMuOTI3IDUuMDlsLjk4Mi45ODIgMS40NzMtMS40NzMtLjk4Mi0uOTgyek0xMCA1LjEzOWE0Ljg3MiA0Ljg3MiAwIDAwLTQuODYyIDQuODZBNC44NzIgNC44NzIgMCAwMDEwIDE0Ljg2MiA0Ljg3MiA0Ljg3MiAwIDAwMTQuODYgMTAgNC44NzIgNC44NzIgMCAwMDEwIDUuMTM5em0wIDEuMzg5QTMuNDYyIDMuNDYyIDAgMDExMy40NzEgMTBhMy40NjIgMy40NjIgMCAwMS0zLjQ3MyAzLjQ3MkEzLjQ2MiAzLjQ2MiAwIDAxNi41MjcgMTAgMy40NjIgMy40NjIgMCAwMTEwIDYuNTI4ek0xLjY2NSA5LjMwNXYxLjM5aDIuMDgzdi0xLjM5SDEuNjY2em0xNC41ODMgMHYxLjM5aDIuMDg0di0xLjM5aC0yLjA4NHpNNS4wOSAxMy45MjhMMy42MTYgMTUuNGwuOTgyLjk4MiAxLjQ3My0xLjQ3My0uOTgyLS45ODJ6bTkuODIgMGwtLjk4Mi45ODIgMS40NzMgMS40NzMuOTgyLS45ODItMS40NzMtMS40NzN6TTkuMzA1IDE2LjI1djIuMDgzaDEuMzg5VjE2LjI1aC0xLjM5eiIgLz4KPC9zdmc+");
  background-repeat: no-repeat;
  background-position: center;
  border-radius: inherit;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, .2), 0 1px 1px 0 rgba(0, 0, 0, .14), 0 1px 3px 0 rgba(0, 0, 0, .12);
  transition: left 150ms cubic-bezier(.4, 0, .2, 1), transform 150ms cubic-bezier(.4, 0, .2, 1), background-color 150ms cubic-bezier(.4, 0, .2, 1);
}

.ui-switch.mdq-theme-toggle .slider .circle::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, .75);
  border-radius: inherit;
  opacity: 0;
  transition: all 500ms;
}

.ui-switch.mdq-theme-toggle input:checked + .slider {
  --switch-bg: rgba(215, 185, 109, .28);
}

.ui-switch.mdq-theme-toggle input:checked + .slider .circle,
html[data-theme="dark"] .ui-switch.mdq-theme-toggle .slider .circle {
  left: calc(100% - var(--circle-diameter));
  background-color: var(--brand-gold, #d7b96d);
  background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjAiIHdpZHRoPSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICAgIDxwYXRoIGZpbGw9IiNmZmYiCiAgICAgICAgZD0iTTQuMiAyLjVsLS43IDEuOC0xLjguNyAxLjguNy43IDEuOC42LTEuOEw2LjcgNWwtMS45LS43LS42LTEuOHptMTUgOC4zYTYuNyA2LjcgMCAxMS02LjYtNi42IDUuOCA1LjggMCAwMDYuNiA2LjZ6IiAvPgo8L3N2Zz4=");
}

.ui-switch.mdq-theme-toggle input:active + .slider .circle::before {
  width: 0;
  height: 0;
  opacity: 1;
  transition: 0s;
}

.ui-switch.mdq-theme-toggle:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 .2rem rgba(201, 164, 92, .24) !important;
}

@media (max-width: 991.98px) {
  .public-site .public-theme-toggle.ui-switch {
    width: var(--switch-width);
    justify-content: center;
    min-height: var(--circle-diameter);
    padding: 0;
    border-radius: 999px;
  }
}

/* Dark Mode Refinement - homepage sections */
html[data-theme="dark"] .public-site .public-about-section,
html[data-theme="dark"] .public-site .public-vision-section,
html[data-theme="dark"] .public-site .public-masyayikh-section,
html[data-theme="dark"] .public-site .public-gallery-section,
html[data-theme="dark"] .public-site .public-contact-section {
  color: rgba(235, 242, 238, .88) !important;
  background:
    radial-gradient(circle at 18% 10%, rgba(201, 164, 92, .07), transparent 26rem),
    linear-gradient(180deg, #071f18 0%, #0a2e24 48%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .public-about-copy h3,
html[data-theme="dark"] .public-site .public-vision-card h2,
html[data-theme="dark"] .public-site .public-masyayikh-section .section-title h2,
html[data-theme="dark"] .public-site .public-gallery-section .public-section-heading h2,
html[data-theme="dark"] .public-site .public-contact-section .section-title h2 {
  color: #f8f6f0 !important;
  text-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-about-copy p,
html[data-theme="dark"] .public-site .public-about-copy .list-checked-item,
html[data-theme="dark"] .public-site .public-vision-card p,
html[data-theme="dark"] .public-site .public-vision-card .list-checked-item,
html[data-theme="dark"] .public-site .public-contact-panel .info-item p {
  color: rgba(221, 232, 226, .78) !important;
}

html[data-theme="dark"] .public-site .public-about-media .public-hero-image,
html[data-theme="dark"] .public-site .public-about-media .public-hero-quote,
html[data-theme="dark"] .public-site .public-vision-card,
html[data-theme="dark"] .public-site .public-contact-panel {
  background: rgba(248, 246, 240, .075) !important;
  border-color: rgba(248, 246, 240, .16) !important;
  box-shadow: 0 22px 60px rgba(0, 0, 0, .28) !important;
}

html[data-theme="dark"] .public-site .public-vision-card {
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .09), rgba(248, 246, 240, .045)) !important;
}

html[data-theme="dark"] .public-site .list-checked-soft-bg-primary .list-checked-item::before,
html[data-theme="dark"] .public-site .list-checked-item::before {
  content: "\2713" !important;
  display: inline-grid !important;
  place-items: center !important;
  flex: 0 0 1.35rem !important;
  width: 1.35rem !important;
  height: 1.35rem !important;
  margin-top: .1rem !important;
  color: #071f18 !important;
  background: rgba(201, 164, 92, .92) !important;
  border-radius: 999px !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .section-title span,
html[data-theme="dark"] .public-site .public-gallery-section .public-section-kicker,
html[data-theme="dark"] .public-site .public-contact-section .section-title span {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .section-title,
html[data-theme="dark"] .public-site .public-contact-section .section-title {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: .85rem;
  padding-block: clamp(2.5rem, 4vw, 3.75rem);
  margin-bottom: clamp(1.75rem, 3vw, 2.75rem);
}

html[data-theme="dark"] .public-site .public-masyayikh-section .section-title span,
html[data-theme="dark"] .public-site .public-contact-section .section-title span {
  position: relative !important;
  inset: auto !important;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  width: auto;
  color: var(--brand-gold) !important;
  font-size: .78rem !important;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: .16em;
  text-transform: uppercase;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .section-title span::before,
html[data-theme="dark"] .public-site .public-masyayikh-section .section-title span::after,
html[data-theme="dark"] .public-site .public-contact-section .section-title span::before,
html[data-theme="dark"] .public-site .public-contact-section .section-title span::after {
  content: "";
  display: block;
  width: clamp(2.25rem, 6vw, 4.75rem);
  height: 1px;
  background: linear-gradient(90deg, transparent, currentColor);
  opacity: .72;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .section-title span::after,
html[data-theme="dark"] .public-site .public-contact-section .section-title span::after {
  background: linear-gradient(90deg, currentColor, transparent);
}

html[data-theme="dark"] .public-site .public-masyayikh-section .section-title h2,
html[data-theme="dark"] .public-site .public-contact-section .section-title h2 {
  margin: 0;
  max-width: min(780px, 100%);
  color: #f8f6f0 !important;
  font-size: clamp(2rem, 4vw, 2.75rem);
  line-height: 1.12;
  letter-spacing: .02em;
  text-transform: uppercase;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .masyaikh-item {
  background:
    linear-gradient(180deg, rgba(248, 246, 240, .12), rgba(248, 246, 240, .06)) !important;
  border-color: rgba(248, 246, 240, .16) !important;
  box-shadow: 0 22px 52px rgba(0, 0, 0, .34) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .masyaikh-item h3 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .masyaikh-item h4 {
  color: rgba(201, 164, 92, .95) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .swiper-pagination-bullet {
  background: rgba(248, 246, 240, .32) !important;
  border-color: rgba(248, 246, 240, .2) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-section .swiper-pagination-bullet-active {
  background: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-gallery-section {
  background:
    linear-gradient(180deg, #071f18 0%, #0b3d2e 46%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .homepage-gallery-link {
  background: rgba(248, 246, 240, .08) !important;
  border-color: rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .homepage-gallery-img {
  filter: saturate(.92) brightness(.88) contrast(1.04);
}

html[data-theme="dark"] .public-site .public-contact-panel {
  background: rgba(7, 31, 24, .88) !important;
}

html[data-theme="dark"] .public-site .public-contact-panel .info-item {
  background: rgba(248, 246, 240, .08) !important;
  border-color: rgba(248, 246, 240, .14) !important;
}

html[data-theme="dark"] .public-site .public-contact-panel .info-item h3 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-contact-panel .info-item i {
  color: #071f18 !important;
  background: rgba(201, 164, 92, .92) !important;
}

html[data-theme="dark"] .public-site .public-contact-panel iframe {
  background: #f8f6f0 !important;
  filter: saturate(.82) brightness(.92) contrast(.98);
}

html[data-theme="dark"] .public-site .bg-gradient-green.public-cta-band {
  color: #f8f6f0 !important;
  background:
    radial-gradient(circle at 50% 0%, rgba(201, 164, 92, .16), transparent 28rem),
    linear-gradient(135deg, #0b4d38 0%, #0b3d2e 54%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .bg-gradient-green.public-cta-band h2,
html[data-theme="dark"] .public-site .bg-gradient-green.public-cta-band p {
  color: #f8f6f0 !important;
  text-shadow: none !important;
}

html[data-theme="dark"] .public-site .bg-gradient-green.public-cta-band p {
  color: rgba(248, 246, 240, .76) !important;
}

html[data-theme="dark"] .public-site .bg-gradient-green.public-cta-band .btn-soft-light {
  color: #071f18 !important;
  background: #f8f6f0 !important;
  border-color: rgba(248, 246, 240, .9) !important;
}

html[data-theme="dark"] .public-site .public-registration-hero,
html[data-theme="dark"] .public-site .registration-contact-section,
html[data-theme="dark"] .public-site .registration-map-section {
  background:
    radial-gradient(circle at 50% 0%, rgba(201, 164, 92, .1), transparent 24rem),
    linear-gradient(180deg, #071f18 0%, #0a2e24 54%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .public-registration-hero .hero-image {
  background:
    linear-gradient(90deg, rgba(7, 31, 24, .88), rgba(7, 31, 24, .54)),
    var(--registration-hero-image, url("../img/backgrounds/modern-section-majelis-thullab.jpg")) center / cover no-repeat !important;
}

html[data-theme="dark"] .public-site .public-registration-hero .hero-image::before {
  background:
    linear-gradient(180deg, rgba(7, 31, 24, .18), rgba(7, 31, 24, .78)) !important;
}

html[data-theme="dark"] .public-site .registration-hero-card h1,
html[data-theme="dark"] .public-site .registration-hero-card h2,
html[data-theme="dark"] .public-site .registration-hero-card h3,
html[data-theme="dark"] .public-site .registration-contact-section .public-section-heading h2,
html[data-theme="dark"] .public-site .registration-map-section .public-section-heading h2 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .registration-hero-institution,
html[data-theme="dark"] .public-site .registration-hero-institution span,
html[data-theme="dark"] .public-site .registration-hero-meta,
html[data-theme="dark"] .public-site .registration-contact-section .public-section-heading p,
html[data-theme="dark"] .public-site .registration-map-section .public-section-heading p {
  color: rgba(248, 246, 240, .78) !important;
}

html[data-theme="dark"] .public-site .registration-action-panel,
html[data-theme="dark"] .public-site .registration-contact-item,
html[data-theme="dark"] .public-site .registration-map-section iframe {
  background: rgba(248, 246, 240, .075) !important;
  border-color: rgba(248, 246, 240, .15) !important;
  box-shadow: 0 22px 56px rgba(0, 0, 0, .26) !important;
}

html[data-theme="dark"] .public-site .registration-contact-item strong,
html[data-theme="dark"] .public-site .registration-action-panel h3,
html[data-theme="dark"] .public-site .registration-contact-group h4 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .registration-contact-item small {
  color: rgba(221, 232, 226, .78) !important;
}

/* Dark Mode Refinement - schedule page */
html[data-theme="dark"] .public-site .public-schedule-page {
  max-width: min(100% - 2rem, 82rem);
  color: rgba(235, 242, 238, .88) !important;
}

html[data-theme="dark"] .public-site .public-schedule-tabs {
  display: inline-flex;
  flex-wrap: wrap;
  gap: .5rem;
  width: auto;
  margin-bottom: 1.5rem;
  padding: .35rem;
  background: rgba(248, 246, 240, .045) !important;
  border: 1px solid rgba(248, 246, 240, .11);
  border-radius: 999px;
}

html[data-theme="dark"] .public-site .public-schedule-tabs button {
  min-height: 2.75rem;
  padding: .62rem 1.05rem;
  color: rgba(248, 246, 240, .78) !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 999px;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-schedule-tabs button.active {
  color: #071f18 !important;
  background: linear-gradient(135deg, #e2c66f, #c9a45c) !important;
  border-color: rgba(201, 164, 92, .9) !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .2) !important;
}

html[data-theme="dark"] .public-site .public-schedule-panel {
  overflow: hidden;
  padding: clamp(1.25rem, 2vw, 1.75rem);
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .07), rgba(248, 246, 240, .035)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  border-radius: 18px;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .26) !important;
}

html[data-theme="dark"] .public-site .public-schedule-panel-header {
  gap: 1rem;
  padding-bottom: 1.25rem;
  margin-bottom: 1.2rem;
  border-bottom: 1px solid rgba(248, 246, 240, .11);
}

html[data-theme="dark"] .public-site .public-schedule-panel-header h2 {
  margin: .25rem 0 0;
  color: #f8f6f0 !important;
  font-size: clamp(1.75rem, 2.8vw, 2.35rem);
  line-height: 1.1;
}

html[data-theme="dark"] .public-site .public-schedule-panel-header .btn {
  color: #f8f6f0 !important;
  background: rgba(248, 246, 240, .075) !important;
  border: 1px solid rgba(201, 164, 92, .48) !important;
  border-radius: 12px;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-schedule-panel-header .btn:hover,
html[data-theme="dark"] .public-site .public-schedule-panel-header .btn:focus {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-class-filter,
html[data-theme="dark"] .public-site .public-class-subfilter {
  gap: .55rem;
  margin-bottom: 1rem;
  padding: .15rem 0;
}

html[data-theme="dark"] .public-site .public-class-filter button,
html[data-theme="dark"] .public-site .public-class-subfilter button {
  min-height: 2.5rem;
  padding: .54rem .92rem;
  color: rgba(248, 246, 240, .82) !important;
  background: rgba(248, 246, 240, .055) !important;
  border: 1px solid rgba(248, 246, 240, .14) !important;
  border-radius: 999px;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-class-filter button.active,
html[data-theme="dark"] .public-site .public-class-subfilter button.active {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-class-filter button span {
  background: rgba(7, 31, 24, .12) !important;
  color: currentColor !important;
}

html[data-theme="dark"] .public-site .schedule-table-wrap {
  overflow: auto;
  background: rgba(7, 31, 24, .35) !important;
  border: 1px solid rgba(248, 246, 240, .1);
  border-radius: 14px;
}

html[data-theme="dark"] .public-site .public-schedule-table,
html[data-theme="dark"] .public-site .public-class-detail-table {
  min-width: 42rem;
  color: rgba(235, 242, 238, .9) !important;
}

html[data-theme="dark"] .public-site .public-schedule-table thead th,
html[data-theme="dark"] .public-site .public-class-detail-table thead th {
  color: rgba(248, 246, 240, .96) !important;
  background: rgba(248, 246, 240, .075) !important;
  border-color: rgba(248, 246, 240, .1) !important;
  font-size: .78rem;
  letter-spacing: .08em;
}

html[data-theme="dark"] .public-site .public-schedule-table tbody tr,
html[data-theme="dark"] .public-site .public-class-detail-table tbody tr {
  background: transparent !important;
}

html[data-theme="dark"] .public-site .public-schedule-table tbody tr:nth-child(even),
html[data-theme="dark"] .public-site .public-class-detail-table tbody tr:nth-child(even) {
  background: rgba(248, 246, 240, .035) !important;
}

html[data-theme="dark"] .public-site .public-schedule-table td,
html[data-theme="dark"] .public-site .public-class-detail-table td {
  color: rgba(235, 242, 238, .86) !important;
  border-color: rgba(248, 246, 240, .1) !important;
}

html[data-theme="dark"] .public-site .public-schedule-table tbody strong,
html[data-theme="dark"] .public-site .public-class-detail-table tbody strong {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-schedule-person-link {
  color: #91f0cf !important;
  text-decoration-color: rgba(145, 240, 207, .32);
}

html[data-theme="dark"] .public-site .public-class-day {
  padding: clamp(1.1rem, 2vw, 1.4rem);
  background: rgba(7, 31, 24, .42) !important;
  border: 1px solid rgba(248, 246, 240, .12) !important;
  border-radius: 16px;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-class-day-heading {
  align-items: flex-start;
  flex-direction: column;
  gap: 1rem;
  padding: .1rem .15rem 1rem;
  margin-bottom: .95rem;
  border-bottom: 1px solid rgba(248, 246, 240, .1);
}

html[data-theme="dark"] .public-site .public-class-day-heading > div {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: .55rem;
}

html[data-theme="dark"] .public-site .public-class-day-heading .public-section-kicker {
  display: inline-flex;
  width: auto;
  margin: 0;
  color: var(--brand-gold) !important;
  font-size: .75rem;
  line-height: 1.1;
  letter-spacing: .14em;
}

html[data-theme="dark"] .public-site .public-class-day-heading h3 {
  display: inline-flex;
  width: auto;
  margin: 0;
  padding: .72rem 1rem;
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-radius: 12px;
  font-size: clamp(1rem, 1.7vw, 1.25rem);
}

html[data-theme="dark"] .public-site .public-class-day-heading p {
  align-self: flex-end;
  margin: -2.4rem .15rem .7rem 0;
  color: rgba(248, 246, 240, .78) !important;
  font-weight: 700;
}

@media (max-width: 767.98px) {
  html[data-theme="dark"] .public-site .public-class-day-heading p {
    align-self: flex-start;
    margin: 0;
  }
}

/* Dark Mode Refinement - registration page */
html[data-theme="dark"] .public-site #content.registration-page {
  background:
    radial-gradient(circle at 50% 0%, rgba(201, 164, 92, .12), transparent 25rem),
    linear-gradient(180deg, #071f18 0%, #092a21 42%, #071f18 100%) !important;
  color: rgba(235, 242, 238, .88) !important;
}

html[data-theme="dark"] .public-site .registration-page .public-section,
html[data-theme="dark"] .public-site .registration-intro-section,
html[data-theme="dark"] .public-site .registration-masyayikh-section,
html[data-theme="dark"] .public-site .registration-contact-section,
html[data-theme="dark"] .public-site .registration-map-section {
  background: transparent !important;
}

html[data-theme="dark"] .public-site .public-registration-hero {
  background: #071f18 !important;
}

html[data-theme="dark"] .public-site .registration-hero-card {
  width: min(100%, 720px);
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none;
}

html[data-theme="dark"] .public-site .registration-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  align-items: center;
  width: auto;
  padding-top: 1.4rem;
  border-top: 1px solid rgba(248, 246, 240, .18) !important;
}

html[data-theme="dark"] .public-site .registration-hero-link {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .registration-flow-nav {
  background: rgba(7, 31, 24, .96) !important;
  border-top: 1px solid rgba(248, 246, 240, .1) !important;
  border-bottom: 1px solid rgba(248, 246, 240, .12) !important;
  box-shadow: none !important;
  backdrop-filter: blur(14px);
}

html[data-theme="dark"] .public-site .registration-flow-list {
  gap: 2rem;
}

html[data-theme="dark"] .public-site .registration-flow-list a {
  position: relative;
  padding-inline: 0 !important;
  color: rgba(248, 246, 240, .76) !important;
  background: transparent !important;
  border: 1px solid transparent !important;
  border-radius: 0 !important;
}

html[data-theme="dark"] .public-site .registration-flow-list a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: .45rem;
  height: 2px;
  background: var(--brand-gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .18s ease;
}

html[data-theme="dark"] .public-site .registration-flow-list a:hover,
html[data-theme="dark"] .public-site .registration-flow-list a:focus {
  color: var(--brand-gold) !important;
  background: transparent !important;
  border-color: transparent !important;
}

html[data-theme="dark"] .public-site .registration-flow-list a:hover::after,
html[data-theme="dark"] .public-site .registration-flow-list a:focus::after {
  transform: scaleX(1);
}

html[data-theme="dark"] .public-site .registration-document {
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .09), rgba(248, 246, 240, .045)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  box-shadow: 0 28px 75px rgba(0, 0, 0, .28) !important;
}

html[data-theme="dark"] .public-site .registration-document::before {
  background: linear-gradient(90deg, var(--brand-gold), rgba(201, 164, 92, .25)) !important;
}

html[data-theme="dark"] .public-site .registration-document-content,
html[data-theme="dark"] .public-site .registration-document-content p,
html[data-theme="dark"] .public-site .registration-document-content li,
html[data-theme="dark"] .public-site .registration-document-content span,
html[data-theme="dark"] .public-site .registration-document-content em,
html[data-theme="dark"] .public-site .registration-document-content td {
  color: rgba(235, 242, 238, .82) !important;
}

html[data-theme="dark"] .public-site .registration-document-content h1,
html[data-theme="dark"] .public-site .registration-document-content h2,
html[data-theme="dark"] .public-site .registration-document-content h3,
html[data-theme="dark"] .public-site .registration-document-content h4,
html[data-theme="dark"] .public-site .registration-document-content h5,
html[data-theme="dark"] .public-site .registration-document-content h6,
html[data-theme="dark"] .public-site .registration-document-content strong {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .registration-document-content a {
  color: #91f0cf !important;
  text-decoration-color: rgba(145, 240, 207, .36);
}

html[data-theme="dark"] .public-site .registration-period-content {
  padding: 1.15rem 1.25rem;
  background: rgba(201, 164, 92, .1) !important;
  border: 1px solid rgba(201, 164, 92, .25) !important;
  border-radius: 16px;
}

html[data-theme="dark"] .public-site .registration-document-content table {
  overflow: hidden;
  color: rgba(235, 242, 238, .86) !important;
  background: rgba(7, 31, 24, .35) !important;
  border: 1px solid rgba(248, 246, 240, .14) !important;
  border-radius: 12px;
}

html[data-theme="dark"] .public-site .registration-document-content th {
  color: #f8f6f0 !important;
  background: rgba(248, 246, 240, .08) !important;
}

html[data-theme="dark"] .public-site .registration-document-content th,
html[data-theme="dark"] .public-site .registration-document-content td {
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .registration-masyayikh-section .public-section-heading h2,
html[data-theme="dark"] .public-site .registration-contact-section .public-section-heading h2,
html[data-theme="dark"] .public-site .registration-map-section .public-section-heading h2 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .registration-masyayikh-section .public-section-kicker,
html[data-theme="dark"] .public-site .registration-contact-section .public-section-kicker,
html[data-theme="dark"] .public-site .registration-map-section .public-section-kicker {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .registration-masyaikh-card {
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .09), rgba(248, 246, 240, .045)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  box-shadow: 0 18px 50px rgba(0, 0, 0, .22) !important;
}

html[data-theme="dark"] .public-site .registration-masyaikh-card h3 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .registration-masyaikh-number {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .registration-masyaikh-card img {
  border-color: rgba(248, 246, 240, .18) !important;
  box-shadow: 0 10px 28px rgba(0, 0, 0, .2);
}

html[data-theme="dark"] .public-site .registration-action-panel {
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .08), rgba(248, 246, 240, .04)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .registration-contact-list .registration-contact-item,
html[data-theme="dark"] .public-site .registration-download-card {
  background: rgba(7, 31, 24, .38) !important;
  border-color: rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .registration-contact-list .registration-contact-item>i,
html[data-theme="dark"] .public-site .registration-download-card>i {
  color: var(--brand-gold) !important;
  background: rgba(201, 164, 92, .13) !important;
}

html[data-theme="dark"] .public-site .registration-download-card .text-dark,
html[data-theme="dark"] .public-site .registration-download-card strong {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .registration-download-card small,
html[data-theme="dark"] .public-site .registration-download-intro {
  color: rgba(221, 232, 226, .72) !important;
}

html[data-theme="dark"] .public-site .registration-download-card .link {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .registration-map-section iframe {
  border: 1px solid rgba(248, 246, 240, .14) !important;
  border-radius: 18px;
}

@media (max-width: 767.98px) {
  html[data-theme="dark"] .public-site .registration-flow-nav {
    position: relative;
    top: auto;
  }

  html[data-theme="dark"] .public-site .registration-flow-list {
    justify-content: flex-start;
    padding: .85rem 0;
  }

  html[data-theme="dark"] .public-site .registration-document {
    border-radius: 18px;
  }
}

/* Registration page editorial hero/tab reset */
.public-site .registration-page .registration-hero-card {
  width: min(100%, 720px);
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.public-site .registration-page .registration-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  align-items: center;
  width: auto;
  padding-top: 1.4rem;
  border-top: 1px solid rgba(255, 255, 255, .24);
}

.public-site .registration-page .registration-flow-list {
  gap: 2rem;
}

.public-site .registration-page .registration-flow-list a {
  position: relative;
  padding-inline: 0 !important;
  background: transparent !important;
  border-color: transparent !important;
  border-radius: 0 !important;
}

.public-site .registration-page .registration-flow-list a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: .45rem;
  height: 2px;
  background: var(--brand-gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .18s ease;
}

.public-site .registration-page .registration-flow-list a:hover,
.public-site .registration-page .registration-flow-list a:focus {
  color: var(--brand-gold) !important;
  background: transparent !important;
  border-color: transparent !important;
}

.public-site .registration-page .registration-flow-list a:hover::after,
.public-site .registration-page .registration-flow-list a:focus::after {
  transform: scaleX(1);
}

@media (max-width: 767.98px) {
  .public-site .registration-page .registration-flow-list {
    gap: 1.15rem;
  }
}

/* Dark Mode Refinement - activities listing page */
html[data-theme="dark"] .public-site .public-activity-page {
  background:
    radial-gradient(circle at 50% 4rem, rgba(201, 164, 92, .09), transparent 28rem),
    linear-gradient(180deg, #071f18 0%, #0a2b21 36%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .public-activity-page .public-listing-page {
  background: transparent !important;
}

html[data-theme="dark"] .public-site .public-activity-editorial-hero {
  padding-top: clamp(3rem, 6vw, 5.25rem);
  padding-bottom: clamp(2.8rem, 5vw, 4.5rem);
  background:
    linear-gradient(180deg, rgba(248, 246, 240, .045), transparent 70%) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel {
  padding-block: clamp(1rem, 2.5vw, 1.8rem) clamp(1.2rem, 2.8vw, 2rem);
  background:
    radial-gradient(ellipse at 50% 55%, rgba(145, 240, 207, .1), transparent 34rem),
    radial-gradient(ellipse at 50% 70%, rgba(201, 164, 92, .075), transparent 28rem) !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-swiper-main,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .swiper-wrapper {
  background: transparent !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-main {
  background: rgba(248, 246, 240, .045) !important;
  border: 1px solid rgba(248, 246, 240, .16) !important;
  box-shadow: 0 24px 62px rgba(0, 0, 0, .3) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-main img {
  filter: brightness(1.04) contrast(1.04) saturate(1.02);
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-swiper-main .swiper-slide-prev,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-swiper-main .swiper-slide-next {
  opacity: .32 !important;
  filter: saturate(.72) brightness(.68) blur(.25px);
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-swiper-main .swiper-slide-prev .activity-feed-main,
html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-swiper-main .swiper-slide-next .activity-feed-main {
  box-shadow: 0 18px 44px rgba(0, 0, 0, .18) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-badge {
  color: #1d3b30 !important;
  background: rgba(248, 246, 240, .96) !important;
  border: 1px solid rgba(201, 164, 92, .34) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, .12) !important;
  backdrop-filter: none !important;
  text-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-caption h3 {
  color: #fffaf0 !important;
  text-shadow: 0 2px 12px rgba(0, 0, 0, .42);
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-caption p {
  color: rgba(248, 246, 240, .72) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-main::after {
  background:
    linear-gradient(to top, rgba(0, 0, 0, .7), rgba(0, 0, 0, .18) 45%, transparent 74%) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-caption {
  bottom: clamp(1.65rem, 3vw, 2.2rem);
  max-width: min(86%, 58rem);
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-nav {
  color: #0b3d2e !important;
  background: rgba(248, 246, 240, .9) !important;
  border: 1px solid rgba(201, 164, 92, .22) !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .18) !important;
}

@media (hover: hover) and (pointer: fine) {
  html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-nav:hover,
  html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-nav:focus-visible {
    color: #071f18 !important;
    background: var(--brand-gold) !important;
    border-color: var(--brand-gold) !important;
  }
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-pagination {
  background: rgba(248, 246, 240, .72) !important;
  border: 1px solid rgba(248, 246, 240, .24);
  box-shadow: 0 12px 30px rgba(0, 0, 0, .16) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-pagination .swiper-pagination-bullet {
  background: rgba(11, 61, 46, .22) !important;
  border-color: rgba(11, 61, 46, .12) !important;
}

html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-carousel-pagination .swiper-pagination-bullet-active {
  background: linear-gradient(90deg, #0b4d38, #62d5ad) !important;
  box-shadow: none !important;
}

@media (min-width: 768px) {
  html[data-theme="dark"] .public-site .public-activity-editorial-hero {
    padding-top: clamp(2.5rem, 4vw, 4rem);
    padding-bottom: clamp(2rem, 4vw, 3.25rem);
  }

  html[data-theme="dark"] .public-site .public-activity-editorial-hero::before {
    content: "";
    position: absolute;
    inset: 0 -8vw auto;
    height: 68%;
    pointer-events: none;
    background:
      radial-gradient(ellipse at 50% 82%, rgba(145, 240, 207, .085), transparent 36rem),
      linear-gradient(180deg, rgba(248, 246, 240, .024), transparent 78%);
    filter: blur(.01px);
  }

  html[data-theme="dark"] .public-site .public-activity-editorial-hero {
    position: relative;
  }

  html[data-theme="dark"] .public-site .public-activity-hero-carousel,
  html[data-theme="dark"] .public-site .public-activity-editorial-heading {
    position: relative;
    z-index: 1;
  }
}

@media (max-width: 767.98px) {
  html[data-theme="dark"] .public-site .public-activity-hero-carousel {
    padding-block: 1.1rem 2.05rem;
  }

  html[data-theme="dark"] .public-site .public-activity-hero-carousel .activity-feed-caption {
    bottom: 1.25rem;
    max-width: none;
  }
}

html[data-theme="dark"] .public-site .public-activity-editorial-heading {
  color: rgba(235, 242, 238, .86) !important;
}

html[data-theme="dark"] .public-site .public-activity-editorial-heading h1 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-activity-editorial-heading p {
  color: rgba(221, 232, 226, .74) !important;
}

html[data-theme="dark"] .public-site .public-activity-archive-link {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-activity-listing-layout {
  align-items: start;
}

html[data-theme="dark"] .public-site .public-activity-listing-main,
html[data-theme="dark"] .public-site .public-activity-listing-aside,
html[data-theme="dark"] .public-site .public-activity-mobile-search {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-popular-publications {
  color: rgba(235, 242, 238, .86) !important;
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .082), rgba(248, 246, 240, .04)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  box-shadow: 0 22px 62px rgba(0, 0, 0, .24) !important;
}

html[data-theme="dark"] .public-site .public-popular-publications-heading h2,
html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-feature h3,
html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-item h3 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-feature {
  color: inherit !important;
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-feature img {
  border: 1px solid rgba(248, 246, 240, .12);
  box-shadow: 0 18px 46px rgba(0, 0, 0, .22);
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-feature p {
  color: rgba(221, 232, 226, .72) !important;
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-label {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-item {
  border-bottom: 1px solid rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-item img {
  border: 1px solid rgba(248, 246, 240, .1);
  filter: saturate(.94);
}

html[data-theme="dark"] .public-site .public-popular-publication-grid .home-publication-index {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .activity-aside-panel {
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .078), rgba(248, 246, 240, .036)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  box-shadow: 0 16px 44px rgba(0, 0, 0, .2) !important;
}

html[data-theme="dark"] .public-site .activity-aside-title,
html[data-theme="dark"] .public-site .activity-aside-subtitle {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .activity-aside-search .form-control {
  color: #f8f6f0 !important;
  background: rgba(7, 31, 24, .46) !important;
  border-color: rgba(248, 246, 240, .16) !important;
}

html[data-theme="dark"] .public-site .activity-aside-search .btn {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .activity-aside-category-list a,
html[data-theme="dark"] .public-site .activity-aside-contributor-list li {
  color: rgba(235, 242, 238, .8) !important;
  background: rgba(7, 31, 24, .34) !important;
  border: 1px solid rgba(248, 246, 240, .12) !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .activity-aside-category-list a strong,
html[data-theme="dark"] .public-site .activity-aside-contributor-value {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .activity-aside-category-list a.is-active,
html[data-theme="dark"] .public-site .activity-aside-category-list a:hover,
html[data-theme="dark"] .public-site .activity-aside-contributor-list li:hover {
  color: #f8f6f0 !important;
  background: rgba(201, 164, 92, .13) !important;
  border-color: rgba(201, 164, 92, .42) !important;
}

html[data-theme="dark"] .public-site .activity-aside-tag-list a {
  color: rgba(235, 242, 238, .82) !important;
  background: rgba(7, 31, 24, .36) !important;
  border-color: rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .activity-aside-tag-list a.is-active,
html[data-theme="dark"] .public-site .activity-aside-tag-list a:hover {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .activity-aside-share-button {
  color: rgba(235, 242, 238, .88) !important;
  background: rgba(7, 31, 24, .34) !important;
  border-color: rgba(248, 246, 240, .14) !important;
}

html[data-theme="dark"] .public-site .activity-aside-share-button i,
html[data-theme="dark"] .public-site .activity-aside-share-button .activity-share-svg-icon,
html[data-theme="dark"] .public-site .activity-aside-share-button .activity-share-svg-icon path {
  color: #91f0cf !important;
  fill: #91f0cf !important;
}

html[data-theme="dark"] .public-site .activity-aside-share-button:hover,
html[data-theme="dark"] .public-site .activity-aside-rss-link:hover,
html[data-theme="dark"] .public-site .activity-aside-editor-link:hover {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .activity-aside-rss-link,
html[data-theme="dark"] .public-site .activity-aside-editor-link,
html[data-theme="dark"] .public-site .activity-aside-reset {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-activity-listing-toolbar {
  padding: clamp(1.3rem, 2.5vw, 1.8rem);
  margin-bottom: 1.4rem;
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .07), rgba(248, 246, 240, .035)) !important;
  border: 1px solid rgba(248, 246, 240, .12);
  border-radius: 18px;
  box-shadow: 0 16px 42px rgba(0, 0, 0, .18);
}

html[data-theme="dark"] .public-site .public-activity-listing-toolbar h2 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-activity-listing-toolbar p {
  color: rgba(221, 232, 226, .74) !important;
}

html[data-theme="dark"] .public-site .public-post-card {
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .08), rgba(248, 246, 240, .04)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .2) !important;
}

html[data-theme="dark"] .public-site .public-post-card h2 a {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-post-card h2 a:hover {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-post-card .text-primary {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-post-card .badge.bg-soft-primary {
  color: #91f0cf !important;
  background: rgba(145, 240, 207, .1) !important;
}

html[data-theme="dark"] .public-site .public-post-card .badge.bg-light {
  color: rgba(235, 242, 238, .82) !important;
  background: rgba(7, 31, 24, .42) !important;
  border: 1px solid rgba(248, 246, 240, .12);
}

html[data-theme="dark"] .public-site .public-post-card .public-read-more {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .mdqh-pagination {
  margin-top: 2rem;
}

html[data-theme="dark"] .public-site .mdqh-pagination-link,
html[data-theme="dark"] .public-site .mdqh-pagination-ellipsis {
  color: rgba(235, 242, 238, .84) !important;
  background: rgba(248, 246, 240, .055) !important;
  border-color: rgba(248, 246, 240, .14) !important;
}

html[data-theme="dark"] .public-site .mdqh-pagination-link:hover,
html[data-theme="dark"] .public-site .mdqh-pagination-link:focus-visible,
html[data-theme="dark"] .public-site .mdqh-pagination-link.is-active {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

@media (max-width: 991.98px) {
  html[data-theme="dark"] .public-site .public-popular-publications {
    border-radius: 18px;
  }

  html[data-theme="dark"] .public-site .public-activity-listing-toolbar {
    padding: 1.15rem;
  }
}

/* Dark Mode Refinement - masyayikh directory spacing */
html[data-theme="dark"] .public-site .public-masyayikh-page .public-masyayikh-profile-card {
  gap: clamp(1.9rem, 3.8vw, 3rem) !important;
  padding-inline: clamp(1.2rem, 2.8vw, 2rem) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-page .public-masyayikh-profile-media {
  flex: 0 0 clamp(9.5rem, 14vw, 12rem);
}

html[data-theme="dark"] .public-site .public-masyayikh-page .public-masyayikh-profile-body {
  min-width: 0;
  padding-left: .15rem;
}

@media (max-width: 767.98px) {
  html[data-theme="dark"] .public-site .public-masyayikh-page .public-masyayikh-profile-card {
    gap: 1.15rem !important;
    padding-inline: 1rem !important;
  }

  html[data-theme="dark"] .public-site .public-masyayikh-page .public-masyayikh-profile-media {
    flex-basis: auto;
  }

  html[data-theme="dark"] .public-site .public-masyayikh-page .public-masyayikh-profile-body {
    padding-left: 0;
  }
}

/* Dark Mode Refinement - editors directory */
html[data-theme="dark"] .public-site .public-editors-page {
  background:
    radial-gradient(circle at 30% 0%, rgba(201, 164, 92, .09), transparent 26rem),
    linear-gradient(180deg, #071f18 0%, #08281f 44%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .public-editors-page > .public-section {
  background: transparent !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-hero {
  align-items: end;
  gap: clamp(2rem, 5vw, 4rem);
  padding-bottom: clamp(1.8rem, 3vw, 2.4rem);
  border-bottom: 1px solid rgba(248, 246, 240, .12);
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-hero h1 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-hero p {
  color: rgba(221, 232, 226, .76) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-disclosure {
  color: rgba(145, 240, 207, .88) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .form-control,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .form-select {
  min-height: 2.9rem;
  color: #f8f6f0 !important;
  background: rgba(248, 246, 240, .075) !important;
  border-color: rgba(248, 246, 240, .16) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .btn {
  min-height: 2.9rem;
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline {
  overflow: hidden;
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .078), rgba(248, 246, 240, .035)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  border-radius: 18px;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .2);
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline div {
  background: transparent !important;
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline span {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline strong {
  color: rgba(235, 242, 238, .78) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card {
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .078), rgba(248, 246, 240, .035)) !important;
  border: 1px solid rgba(248, 246, 240, .13) !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .18) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board-heading span {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board h2,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-heading h2 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board li {
  background: rgba(7, 31, 24, .36) !important;
  border: 1px solid rgba(248, 246, 240, .1) !important;
  border-radius: 12px;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-rank {
  color: #071f18 !important;
  background: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board-name,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-board strong {
  color: rgba(248, 246, 240, .9) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card {
  gap: 1rem;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-media img,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-media span {
  border: 1px solid rgba(248, 246, 240, .18);
  box-shadow: 0 10px 24px rgba(0, 0, 0, .2);
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-heading p,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-bio {
  color: rgba(221, 232, 226, .76) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-heading span,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-stats span {
  color: #91f0cf !important;
  background: rgba(145, 240, 207, .09) !important;
  border-color: rgba(145, 240, 207, .22) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-link {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card:hover {
  border-color: rgba(201, 164, 92, .36) !important;
}

@media (max-width: 991.98px) {
  html[data-theme="dark"] .public-site .public-editors-page .public-editor-hero {
    align-items: stretch;
  }
}

/* Dark Mode Refinement - editors final polish */
html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar {
  justify-self: end;
  width: min(100%, 34rem);
  padding: .5rem;
  background: rgba(248, 246, 240, .045) !important;
  border: 1px solid rgba(248, 246, 240, .11) !important;
  border-radius: 14px;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .form-control::placeholder {
  color: rgba(221, 232, 226, .5) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .form-control:focus,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .form-select:focus {
  border-color: rgba(201, 164, 92, .55) !important;
  box-shadow: 0 0 0 .2rem rgba(201, 164, 92, .12) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar .form-select option {
  color: #f8f6f0;
  background: #0b3328;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline div {
  padding: clamp(1rem, 2.2vw, 1.35rem) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline div + div {
  border-left: 1px solid rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-leaderboards {
  gap: clamp(1rem, 2vw, 1.35rem);
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card {
  backdrop-filter: none;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board {
  padding: clamp(1.15rem, 2.3vw, 1.45rem) !important;
  border-radius: 16px;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board-heading {
  display: block;
  margin-bottom: 1rem;
  padding-bottom: .85rem;
  border-bottom: 1px solid rgba(248, 246, 240, .1);
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board-heading span {
  display: block;
  margin-bottom: .35rem;
  font-size: .68rem;
  letter-spacing: .14em;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board h2 {
  font-size: clamp(1.05rem, 1.8vw, 1.25rem) !important;
  line-height: 1.25;
  text-align: left;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board ol {
  gap: .65rem;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board li {
  min-height: 3.35rem;
  padding: .65rem .75rem;
  background: rgba(248, 246, 240, .045) !important;
  border-color: rgba(248, 246, 240, .09) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-rank {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: .45rem;
  font-size: .85rem;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board-name {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-board strong {
  color: rgba(235, 242, 238, .82) !important;
  font-size: .86rem;
  font-weight: 800;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card {
  padding: clamp(1.15rem, 2vw, 1.45rem) !important;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-stats {
  border-top: 1px solid rgba(248, 246, 240, .1);
  padding-top: .9rem;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-link:hover,
html[data-theme="dark"] .public-site .public-editors-page .public-editor-card-link:focus-visible {
  color: var(--brand-gold) !important;
}

@media (max-width: 991.98px) {
  html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar {
    justify-self: stretch;
    width: 100%;
  }
}

@media (max-width: 575.98px) {
  html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline {
    grid-template-columns: 1fr;
  }

  html[data-theme="dark"] .public-site .public-editors-page .public-editor-statline div + div {
    border-left: 0 !important;
    border-top: 1px solid rgba(248, 246, 240, .12) !important;
  }
}

/* Editors Toolbar Refinement */
.public-site .public-editors-page .public-editor-toolbar {
  grid-template-columns: minmax(12rem, 1fr) minmax(14rem, 1.15fr) auto;
  align-items: stretch;
  width: min(100%, 42rem);
}

.public-site .public-editors-page .public-editor-toolbar .form-control,
.public-site .public-editors-page .public-editor-toolbar .form-select {
  min-width: 0;
  padding-inline: 1rem;
}

.public-site .public-editors-page .public-editor-toolbar .btn {
  min-width: 5.25rem;
  white-space: nowrap;
}

html[data-theme="dark"] .public-site .public-editors-page .public-editor-toolbar {
  width: min(100%, 42rem);
}

@media (max-width: 1199.98px) {
  .public-site .public-editors-page .public-editor-toolbar {
    grid-template-columns: minmax(10rem, 1fr) minmax(13rem, 1fr) auto;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-editors-page .public-editor-toolbar {
    grid-template-columns: 1fr;
  }

  .public-site .public-editors-page .public-editor-toolbar .btn {
    width: 100%;
  }
}

/* Editors Search Bar Flex Fix */
.public-site .public-editors-page .public-editor-hero {
  grid-template-columns: minmax(0, 1fr) minmax(30rem, 42rem);
}

.public-site .public-editors-page .filter-bar.public-editor-toolbar {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
  width: min(100%, 42rem);
  max-width: 100%;
  overflow: visible;
  box-sizing: border-box;
}

.public-site .public-editors-page .filter-bar.public-editor-toolbar input,
.public-site .public-editors-page .filter-bar.public-editor-toolbar select,
.public-site .public-editors-page .filter-bar.public-editor-toolbar button {
  height: 48px;
  min-height: 48px;
  box-sizing: border-box;
}

.public-site .public-editors-page .filter-bar.public-editor-toolbar input {
  flex: 1 1 300px;
  min-width: 220px;
}

.public-site .public-editors-page .filter-bar.public-editor-toolbar select {
  flex: 0 1 220px;
  min-width: 180px;
}

.public-site .public-editors-page .filter-bar.public-editor-toolbar button {
  flex: 0 0 auto;
  min-width: 110px;
  padding-inline: 1.15rem;
  white-space: nowrap;
}

@media (max-width: 991.98px) {
  .public-site .public-editors-page .public-editor-hero {
    grid-template-columns: 1fr;
  }

  .public-site .public-editors-page .filter-bar.public-editor-toolbar {
    justify-content: stretch;
    width: 100%;
  }
}

@media (max-width: 640px) {
  .public-site .public-editors-page .filter-bar.public-editor-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .public-site .public-editors-page .filter-bar.public-editor-toolbar input,
  .public-site .public-editors-page .filter-bar.public-editor-toolbar select,
  .public-site .public-editors-page .filter-bar.public-editor-toolbar button {
    flex: 0 0 auto;
    width: 100%;
    min-width: 0;
  }
}

/* Dark Mode Refinement - feedback page */
html[data-theme="dark"] .public-site .feedback-page {
  background:
    radial-gradient(circle at 78% 9rem, rgba(201, 164, 92, .08), transparent 26rem),
    linear-gradient(180deg, #071f18 0%, #08291f 52%, #071f18 100%) !important;
}

html[data-theme="dark"] .public-site .feedback-main-section {
  background:
    linear-gradient(180deg, rgba(8, 42, 31, .9), rgba(7, 31, 24, .96)),
    radial-gradient(circle at 18% 0, rgba(145, 240, 207, .06), transparent 30rem) !important;
}

html[data-theme="dark"] .public-site .public-feedback-hero .hero-image {
  background:
    linear-gradient(90deg, rgba(7, 31, 24, .94), rgba(7, 31, 24, .76) 44%, rgba(7, 31, 24, .5)),
    var(--feedback-hero-image, url("../img/backgrounds/modern-section-halaqah-kitabs.jpg")) center / cover no-repeat !important;
}

html[data-theme="dark"] .public-site .feedback-hero-card {
  color: #f8f6f0 !important;
  background: rgba(7, 31, 24, .78) !important;
  border-color: rgba(248, 246, 240, .18) !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .34) !important;
}

html[data-theme="dark"] .public-site .feedback-hero-card h1 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .feedback-hero-card p {
  color: rgba(235, 242, 238, .76) !important;
}

html[data-theme="dark"] .public-site .feedback-form-panel,
html[data-theme="dark"] .public-site .feedback-guidance-card {
  color: rgba(235, 242, 238, .82) !important;
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .082), rgba(248, 246, 240, .036)) !important;
  border-color: rgba(248, 246, 240, .14) !important;
  box-shadow: 0 22px 58px rgba(0, 0, 0, .24) !important;
}

html[data-theme="dark"] .public-site .feedback-form-panel h2,
html[data-theme="dark"] .public-site .feedback-guidance-card h2 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .feedback-form-intro,
html[data-theme="dark"] .public-site .feedback-guidance-card li,
html[data-theme="dark"] .public-site .feedback-check,
html[data-theme="dark"] .public-site .feedback-consent {
  color: rgba(221, 232, 226, .76) !important;
}

html[data-theme="dark"] .public-site .feedback-field label {
  color: rgba(248, 246, 240, .9) !important;
}

html[data-theme="dark"] .public-site .feedback-field label span {
  color: rgba(221, 232, 226, .58) !important;
}

html[data-theme="dark"] .public-site .feedback-field input,
html[data-theme="dark"] .public-site .feedback-field select,
html[data-theme="dark"] .public-site .feedback-field textarea {
  color: #f8f6f0 !important;
  background: rgba(7, 31, 24, .5) !important;
  border-color: rgba(248, 246, 240, .18) !important;
}

html[data-theme="dark"] .public-site .feedback-field input::placeholder,
html[data-theme="dark"] .public-site .feedback-field textarea::placeholder {
  color: rgba(221, 232, 226, .46) !important;
}

html[data-theme="dark"] .public-site .feedback-field select option {
  color: #f8f6f0;
  background: #0b3328;
}

html[data-theme="dark"] .public-site .feedback-field input:focus,
html[data-theme="dark"] .public-site .feedback-field select:focus,
html[data-theme="dark"] .public-site .feedback-field textarea:focus {
  background: rgba(7, 31, 24, .72) !important;
  border-color: rgba(201, 164, 92, .62) !important;
  box-shadow: 0 0 0 .2rem rgba(201, 164, 92, .14) !important;
}

html[data-theme="dark"] .public-site .feedback-consent {
  background: rgba(145, 240, 207, .07) !important;
  border-color: rgba(145, 240, 207, .18) !important;
}

html[data-theme="dark"] .public-site .feedback-check input {
  accent-color: var(--brand-gold);
}

html[data-theme="dark"] .public-site .feedback-guidance-card li::before {
  background: var(--brand-gold);
  box-shadow: 0 0 0 .22rem rgba(201, 164, 92, .12);
}

html[data-theme="dark"] .public-site .feedback-privacy-card {
  background:
    linear-gradient(145deg, rgba(13, 91, 66, .82), rgba(7, 31, 24, .72)) !important;
  border-color: rgba(145, 240, 207, .2) !important;
}

html[data-theme="dark"] .public-site .feedback-privacy-card > i {
  color: var(--brand-gold) !important;
  background: rgba(248, 246, 240, .1) !important;
}

html[data-theme="dark"] .public-site .feedback-privacy-card h3 {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .feedback-privacy-card p {
  color: rgba(235, 242, 238, .74) !important;
}

html[data-theme="dark"] .public-site .feedback-submit {
  color: #071f18 !important;
  background: var(--brand-gold) !important;
  border-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .feedback-toast {
  color: #f8f6f0 !important;
  background: rgba(13, 45, 35, .96) !important;
  border-color: rgba(248, 246, 240, .14) !important;
  border-left-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .feedback-toast-copy strong {
  color: #f8f6f0 !important;
}

html[data-theme="dark"] .public-site .feedback-toast-copy p {
  color: rgba(221, 232, 226, .76) !important;
}

html[data-theme="dark"] .public-site .feedback-toast-close {
  color: rgba(248, 246, 240, .84) !important;
  background: rgba(248, 246, 240, .08) !important;
}

/* Activity detail - dark mode editorial refinement */
html[data-theme="dark"] .public-site .public-article-page {
  background:
    radial-gradient(circle at 68% 8%, rgba(201, 164, 92, .07), transparent 28rem),
    linear-gradient(180deg, rgba(7, 31, 24, .92), rgba(5, 27, 20, .98)) !important;
}

html[data-theme="dark"] .public-site .public-activity-detail-main {
  overflow: hidden;
  color: rgba(235, 242, 238, .84) !important;
  background:
    linear-gradient(180deg, rgba(248, 246, 240, .055), rgba(248, 246, 240, .025)),
    rgba(8, 42, 31, .86) !important;
  border: 1px solid rgba(248, 246, 240, .12) !important;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .24) !important;
}

html[data-theme="dark"] .public-site .public-article-header {
  border-bottom: 1px solid rgba(248, 246, 240, .1);
}

html[data-theme="dark"] .public-site .public-article-header h1 {
  color: #fffaf0 !important;
  text-shadow: none;
}

html[data-theme="dark"] .public-site .public-article-author,
html[data-theme="dark"] .public-site .public-article-trustline span {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-article-byline time,
html[data-theme="dark"] .public-site .public-article-trustline {
  color: rgba(221, 232, 226, .68) !important;
}

html[data-theme="dark"] .public-site .public-article-byline-initial {
  color: #071f18 !important;
  background: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-article-media {
  background: rgba(7, 31, 24, .42) !important;
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-article-media img {
  filter: saturate(.94) contrast(1.02);
}

html[data-theme="dark"] .public-site .public-article-media figcaption {
  color: rgba(221, 232, 226, .66) !important;
  background: rgba(248, 246, 240, .06) !important;
  border-top: 1px solid rgba(248, 246, 240, .1) !important;
}

html[data-theme="dark"] .public-site .public-article-caption,
html[data-theme="dark"] .public-site .public-article-credit {
  color: rgba(221, 232, 226, .72) !important;
}

html[data-theme="dark"] .public-site .public-article-content {
  color: rgba(229, 238, 233, .82) !important;
}

html[data-theme="dark"] .public-site .public-article-content h1,
html[data-theme="dark"] .public-site .public-article-content h2,
html[data-theme="dark"] .public-site .public-article-content h3,
html[data-theme="dark"] .public-site .public-article-content h4,
html[data-theme="dark"] .public-site .public-article-content strong {
  color: #fffaf0 !important;
}

html[data-theme="dark"] .public-site .public-article-content p,
html[data-theme="dark"] .public-site .public-article-content li {
  color: rgba(229, 238, 233, .78) !important;
}

html[data-theme="dark"] .public-site .public-article-content blockquote {
  color: rgba(248, 246, 240, .88) !important;
  background: rgba(248, 246, 240, .065) !important;
  border-left-color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-article-content table {
  color: rgba(229, 238, 233, .82) !important;
  background: rgba(7, 31, 24, .34) !important;
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-article-content th,
html[data-theme="dark"] .public-site .public-article-content td {
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site .public-article-read-also {
  color: rgba(235, 242, 238, .82) !important;
  background:
    linear-gradient(145deg, rgba(201, 164, 92, .14), rgba(248, 246, 240, .055)) !important;
  border: 1px solid rgba(201, 164, 92, .28) !important;
}

html[data-theme="dark"] .public-site .public-article-read-also span {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .public-article-read-also a {
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-article-tags {
  border-top-color: rgba(248, 246, 240, .11) !important;
}

html[data-theme="dark"] .public-site .public-article-tags h2 {
  color: #fffaf0 !important;
}

html[data-theme="dark"] .public-site .public-article-tags a,
html[data-theme="dark"] .public-site .public-article-mentions a,
html[data-theme="dark"] .public-site .public-article-mentions span {
  color: #91f0cf !important;
  background: rgba(145, 240, 207, .075) !important;
  border-color: rgba(145, 240, 207, .18) !important;
}

html[data-theme="dark"] .public-site .public-article-share-end {
  border-top-color: rgba(248, 246, 240, .1) !important;
  border-bottom-color: rgba(248, 246, 240, .1) !important;
}

html[data-theme="dark"] .public-site .public-article-share .activity-share-label {
  color: rgba(221, 232, 226, .78) !important;
}

html[data-theme="dark"] .public-site .public-article-share .activity-aside-share-button {
  color: #91f0cf !important;
  background: rgba(248, 246, 240, .055) !important;
  border-color: rgba(248, 246, 240, .14) !important;
}

html[data-theme="dark"] .public-site .public-article-share .activity-aside-share-button i,
html[data-theme="dark"] .public-site .public-article-share .activity-aside-share-button .activity-share-svg-icon,
html[data-theme="dark"] .public-site .public-article-share .activity-aside-share-button .activity-share-svg-icon path {
  color: #91f0cf !important;
  fill: #91f0cf !important;
}

html[data-theme="dark"] .public-site .activity-reaction {
  color: rgba(235, 242, 238, .86) !important;
  background:
    linear-gradient(180deg, rgba(248, 246, 240, .075), rgba(248, 246, 240, .035)),
    rgba(8, 42, 31, .9) !important;
  border-color: rgba(248, 246, 240, .14) !important;
  box-shadow: 0 22px 64px rgba(0, 0, 0, .25) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-heading h2 {
  color: #fffaf0 !important;
}

html[data-theme="dark"] .public-site .activity-reaction-heading p {
  color: rgba(221, 232, 226, .72) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-score {
  color: var(--brand-gold) !important;
  background: rgba(201, 164, 92, .12) !important;
  border-color: rgba(201, 164, 92, .35) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-score span {
  color: rgba(248, 246, 240, .72) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-thanks {
  color: #071f18 !important;
  background: rgba(145, 240, 207, .86) !important;
  border-color: rgba(145, 240, 207, .32) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-button {
  color: rgba(235, 242, 238, .86) !important;
  background: rgba(248, 246, 240, .06) !important;
  border-color: rgba(248, 246, 240, .13) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-label {
  color: #fffaf0 !important;
}

html[data-theme="dark"] .public-site .activity-reaction-description {
  color: rgba(221, 232, 226, .66) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-point {
  color: var(--brand-gold) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-icon {
  color: #91f0cf !important;
  background: rgba(145, 240, 207, .1) !important;
  border-color: rgba(145, 240, 207, .18) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-button:hover:not(:disabled),
html[data-theme="dark"] .public-site .activity-reaction-button:focus-visible:not(:disabled) {
  background: rgba(248, 246, 240, .095) !important;
  border-color: rgba(201, 164, 92, .44) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-button.is-selected {
  color: #071f18 !important;
  background: rgba(201, 164, 92, .9) !important;
  border-color: rgba(201, 164, 92, .95) !important;
}

html[data-theme="dark"] .public-site .activity-reaction-button.is-selected .activity-reaction-label,
html[data-theme="dark"] .public-site .activity-reaction-button.is-selected .activity-reaction-description,
html[data-theme="dark"] .public-site .activity-reaction-button.is-selected .activity-reaction-point {
  color: #071f18 !important;
}

html[data-theme="dark"] .public-site .activity-reaction-button.is-selected .activity-reaction-icon {
  color: #f8f6f0 !important;
  background: rgba(7, 31, 24, .84) !important;
  border-color: rgba(7, 31, 24, .38) !important;
}

/* Article detail - premium editorial spacing */
.public-site .public-activity-detail-main {
  padding: 48px 56px;
}

.public-site .public-article-header {
  max-width: none;
  margin-bottom: 32px !important;
  padding-bottom: 0;
  border-bottom: 0;
}

.public-site .public-article-header > .public-section-kicker {
  display: inline-block;
  margin-bottom: 18px;
}

.public-site .public-article-header h1 {
  max-width: 800px;
  margin: 0 0 32px;
  line-height: 1.1;
}

.public-site .public-article-byline {
  align-items: center;
  gap: 16px;
  margin: 0 0 24px;
}

.public-site .public-article-share {
  gap: 10px;
  margin-top: 24px;
  margin-bottom: 28px;
}

.public-site .public-article-trustline {
  padding-top: 20px;
  margin-top: 12px;
  border-top: 1px solid rgba(17, 42, 34, .1);
}

html[data-theme="dark"] .public-site .public-article-trustline {
  border-top-color: rgba(255, 255, 255, .08) !important;
}

@media (max-width: 991.98px) {
  .public-site .public-activity-detail-main {
    padding: 40px;
  }
}

@media (max-width: 575.98px) {
  .public-site .public-activity-detail-main {
    padding: 24px;
  }

  .public-site .public-article-header {
    margin-bottom: 24px !important;
  }

  .public-site .public-article-header h1 {
    margin-bottom: 24px;
  }

  .public-site .public-article-share {
    margin-top: 20px;
    margin-bottom: 24px;
  }
}

/* Public navbar - mega menu normalization and refined hover motion */
.public-site #header .public-navbar-activities-menu,
.public-site #header .public-navbar-extra-menu {
  width: min(40rem, calc(100vw - 2rem)) !important;
  min-width: min(40rem, calc(100vw - 2rem));
  max-width: calc(100vw - 2rem);
}

.public-site #header .navbar-nav .nav-link,
.public-site #header .navbar-nav .nav-dropdown-toggle,
.public-site #header .public-navbar-mega-menu .dropdown-item,
.public-site #header .public-nav-feature,
.public-site #header .public-nav-download {
  transition:
    color .18s ease,
    background-color .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    transform .18s ease;
}

.public-site #header .public-navbar-mega-menu .dropdown-item.active {
  color: var(--brand-green);
  background: #e7efe9;
}

.public-site #header .public-navbar-extra-menu .navbar-dropdown-menu-inner,
.public-site #header .public-navbar-activities-menu .navbar-dropdown-menu-inner {
  height: 100%;
  border: 1px solid rgba(15, 61, 46, .08);
  border-radius: var(--brand-radius);
}

@media (hover: hover) and (prefers-reduced-motion: no-preference) {
  .public-site #header .navbar-nav > .nav-item > .nav-link:hover,
  .public-site #header .navbar-nav > .nav-item > .nav-dropdown-toggle:hover,
  .public-site #header .navbar-nav > .nav-item > .nav-link:focus-visible,
  .public-site #header .navbar-nav > .nav-item > .nav-dropdown-toggle:focus-visible {
    transform: translateY(-1px);
  }

  .public-site #header .public-navbar-mega-menu .dropdown-item:hover,
  .public-site #header .public-navbar-mega-menu .dropdown-item:focus-visible {
    transform: translateX(4px);
  }

  .public-site #header .public-nav-feature:hover,
  .public-site #header .public-nav-download:hover {
    transform: translateY(-2px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .public-site #header .navbar-nav .nav-link,
  .public-site #header .navbar-nav .nav-dropdown-toggle,
  .public-site #header .public-navbar-mega-menu .dropdown-item,
  .public-site #header .public-nav-feature,
  .public-site #header .public-nav-download {
    transition: none !important;
    transform: none !important;
  }
}

html[data-theme="dark"] .public-site #header .public-navbar-mega-menu .dropdown-item.active {
  color: var(--brand-gold) !important;
  background: rgba(248, 246, 240, .08) !important;
}

html[data-theme="dark"] .public-site #header .public-navbar-extra-menu .navbar-dropdown-menu-inner,
html[data-theme="dark"] .public-site #header .public-navbar-activities-menu .navbar-dropdown-menu-inner {
  border-color: rgba(248, 246, 240, .12) !important;
}

html[data-theme="dark"] .public-site #header .public-nav-feature-link,
html[data-theme="dark"] .public-site #header .public-nav-feature .link {
  color: #91f0cf !important;
}

@media (max-width: 991.98px) {
  .public-site #header .public-navbar-activities-menu,
  .public-site #header .public-navbar-extra-menu {
    min-width: 100%;
  }

  .public-site #header .public-navbar-extra-menu .navbar-dropdown-menu-inner,
  .public-site #header .public-navbar-activities-menu .navbar-dropdown-menu-inner {
    border-radius: 10px;
  }
}

/* Gallery Masonry Ratio-Safe Layout */
.public-site .public-gallery-section {
  overflow: visible !important;
}

.public-site .homepage-gallery-masonry {
  column-count: 4;
  column-gap: clamp(12px, 1.4vw, 20px);
  width: 100%;
}

.public-site .homepage-gallery-masonry .homepage-gallery-item {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  margin: 0 0 clamp(12px, 1.4vw, 20px) !important;
  overflow: visible !important;
  break-inside: avoid;
  page-break-inside: avoid;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.public-site .homepage-gallery-masonry .homepage-gallery-link {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  overflow: hidden !important;
  border-radius: 18px;
  cursor: zoom-in !important;
  background:
    linear-gradient(135deg, rgba(13, 91, 66, .08), rgba(201, 164, 92, .08)),
    #f6f8f5;
  border: 1px solid rgba(16, 35, 29, .08);
  box-shadow: 0 18px 42px rgba(16, 35, 29, .12);
}

.public-site .homepage-gallery-masonry .homepage-gallery-img,
.public-site .homepage-gallery-masonry .homepage-gallery-img.gallery-orientation-landscape,
.public-site .homepage-gallery-masonry .homepage-gallery-img.gallery-orientation-square,
.public-site .homepage-gallery-masonry .homepage-gallery-img.gallery-orientation-portrait {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center !important;
  background: transparent !important;
  transition: transform 300ms var(--brand-ease), filter 300ms var(--brand-ease) !important;
}

.public-site .homepage-gallery-masonry .homepage-gallery-link:hover .homepage-gallery-img,
.public-site .homepage-gallery-masonry .homepage-gallery-link:focus .homepage-gallery-img {
  transform: scale(1.025);
  filter: brightness(.96);
}

html[data-theme="dark"] .public-site .homepage-gallery-masonry .homepage-gallery-link {
  background: rgba(248, 246, 240, .055) !important;
  border-color: rgba(248, 246, 240, .13) !important;
  box-shadow: 0 22px 52px rgba(0, 0, 0, .28) !important;
}

@media (max-width: 1199.98px) {
  .public-site .homepage-gallery-masonry {
    column-count: 3;
  }
}

@media (max-width: 767.98px) {
  .public-site .homepage-gallery-masonry {
    column-count: 2;
    column-gap: 12px;
  }

  .public-site .homepage-gallery-masonry .homepage-gallery-item {
    margin-bottom: 12px !important;
  }

  .public-site .homepage-gallery-masonry .homepage-gallery-link {
    border-radius: 14px;
  }
}

@media (max-width: 420px) {
  .public-site .homepage-gallery-masonry {
    column-count: 1;
  }
}

/* Public Gallery Foto Page */
.public-site .public-gallery-page-hero {
  padding: clamp(7rem, 10vw, 10rem) 0 clamp(2.5rem, 5vw, 4.5rem);
  background:
    radial-gradient(circle at 18% 20%, rgba(201, 164, 92, .10), transparent 28%),
    linear-gradient(180deg, rgba(248, 246, 240, .95), rgba(248, 246, 240, .82));
}

.public-site .public-gallery-page-heading {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}

.public-site .public-gallery-page-heading h1 {
  margin: .6rem 0 1rem;
  color: var(--brand-green-dark, #0b3d2e);
  font-size: clamp(2.4rem, 5vw, 4.75rem);
  line-height: 1.02;
  letter-spacing: -.055em;
}

.public-site .public-gallery-page-heading p {
  max-width: 660px;
  margin: 0 auto;
  color: rgba(16, 35, 29, .68);
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  line-height: 1.8;
}

.public-site .public-gallery-page-section {
  padding: clamp(2rem, 5vw, 4.5rem) 0 clamp(4rem, 8vw, 7rem);
  background: #f8f6f0;
}

.public-site .public-gallery-page-masonry {
  column-count: 4;
  column-gap: clamp(14px, 1.6vw, 22px);
}

.public-site .public-gallery-page-item {
  display: block;
  width: 100%;
  margin: 0 0 clamp(14px, 1.6vw, 22px);
  break-inside: avoid;
  page-break-inside: avoid;
}

.public-site .public-gallery-page-link {
  display: block;
  width: 100%;
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(16, 35, 29, .08);
  box-shadow: 0 18px 44px rgba(16, 35, 29, .10);
  cursor: zoom-in;
}

.public-site .public-gallery-page-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  aspect-ratio: auto;
  object-fit: contain;
  transition: transform 320ms var(--brand-ease), filter 320ms var(--brand-ease);
}

.public-site .public-gallery-page-link:hover .public-gallery-page-img,
.public-site .public-gallery-page-link:focus .public-gallery-page-img {
  transform: scale(1.025);
  filter: brightness(.96) saturate(1.04);
}

.public-site .public-gallery-pagination {
  margin-top: clamp(1.5rem, 4vw, 3rem);
}

.public-site .homepage-gallery-action {
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
}

.public-site .public-gallery-all-link {
  border-color: rgba(11, 61, 46, .18);
  color: #0b3d2e;
  background: rgba(248, 246, 240, .78);
  font-weight: 700;
}

.public-site .public-gallery-all-link:hover,
.public-site .public-gallery-all-link:focus {
  background: #0b3d2e;
  border-color: #0b3d2e;
  color: #fff;
}

html[data-theme="dark"] .public-site .public-gallery-page-hero {
  background:
    radial-gradient(circle at 18% 20%, rgba(201, 164, 92, .12), transparent 30%),
    linear-gradient(180deg, #06281f, #082f25);
}

html[data-theme="dark"] .public-site .public-gallery-page-heading h1 {
  color: #f8f6f0;
}

html[data-theme="dark"] .public-site .public-gallery-page-heading p {
  color: rgba(248, 246, 240, .72);
}

html[data-theme="dark"] .public-site .public-gallery-page-section {
  background: #06281f;
}

html[data-theme="dark"] .public-site .public-gallery-page-link {
  background: rgba(248, 246, 240, .045);
  border-color: rgba(248, 246, 240, .12);
  box-shadow: 0 20px 56px rgba(0, 0, 0, .28);
}

html[data-theme="dark"] .public-site .public-gallery-all-link {
  border-color: rgba(201, 164, 92, .34);
  color: #f8f6f0;
  background: rgba(248, 246, 240, .06);
}

html[data-theme="dark"] .public-site .public-gallery-all-link:hover,
html[data-theme="dark"] .public-site .public-gallery-all-link:focus {
  color: #06281f;
  background: #c9a45c;
  border-color: #c9a45c;
}

@media (max-width: 1199.98px) {
  .public-site .public-gallery-page-masonry {
    column-count: 3;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-gallery-page-masonry {
    column-count: 2;
    column-gap: 12px;
  }

  .public-site .public-gallery-page-item {
    margin-bottom: 12px;
  }

  .public-site .public-gallery-page-link {
    border-radius: 14px;
  }
}

@media (max-width: 420px) {
  .public-site .public-gallery-page-masonry {
    column-count: 1;
  }
}

/* Targeted QA fixes: homepage featured mosaic gallery, gallery radius, mobile footer */
.public-site .home-featured-gallery {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-flow: dense;
  grid-auto-rows: clamp(4.25rem, 6vw, 5.5rem);
  gap: 12px;
}

.public-site .home-featured-gallery .gallery-card {
  display: block;
  min-height: 0;
  height: auto !important;
  margin: 0;
  overflow: hidden;
  border-radius: 12px;
  background:
    linear-gradient(135deg, rgba(13, 91, 66, .08), rgba(201, 164, 92, .08)),
    #f6f8f5;
  border: 1px solid rgba(16, 35, 29, .08);
  box-shadow: 0 18px 42px rgba(16, 35, 29, .12);
}

.public-site .home-featured-gallery .homepage-gallery-link {
  display: block;
  width: 100%;
  height: 100% !important;
  overflow: hidden;
  border-radius: 12px;
  cursor: zoom-in;
}

.public-site .home-featured-gallery .homepage-gallery-img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  min-height: 100% !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center !important;
  transition: transform 300ms var(--brand-ease), filter 300ms var(--brand-ease);
}

.public-site .home-featured-gallery .gallery-orientation-landscape {
  grid-column: span 4;
  grid-row: span 2;
}

.public-site .home-featured-gallery .gallery-orientation-portrait {
  grid-column: span 3;
  grid-row: span 3;
}

.public-site .home-featured-gallery .gallery-orientation-square {
  grid-column: span 3;
  grid-row: span 2;
}

.public-site .home-featured-gallery .home-mosaic-item-1.gallery-orientation-landscape,
.public-site .home-featured-gallery .home-mosaic-item-6.gallery-orientation-landscape {
  grid-column: span 5;
}

.public-site .home-featured-gallery .home-mosaic-item-2.gallery-orientation-portrait,
.public-site .home-featured-gallery .home-mosaic-item-8.gallery-orientation-portrait {
  grid-row: span 4;
}

.public-site .home-featured-gallery .home-mosaic-item-4.gallery-orientation-square,
.public-site .home-featured-gallery .home-mosaic-item-9.gallery-orientation-square {
  grid-column: span 4;
}

.public-site .home-featured-gallery .home-mosaic-item-5.gallery-orientation-landscape {
  grid-column: span 3;
}

.public-site .home-featured-gallery.home-featured-gallery-count-1 .gallery-card {
  grid-column: 1 / -1;
  grid-row: span 4;
}

.public-site .home-featured-gallery.home-featured-gallery-count-2 .gallery-card {
  grid-column: span 6;
}

.public-site .home-featured-gallery.home-featured-gallery-count-3 .gallery-card {
  grid-column: span 4;
}

.public-site .home-featured-gallery .homepage-gallery-link:hover .homepage-gallery-img,
.public-site .home-featured-gallery .homepage-gallery-link:focus .homepage-gallery-img {
  transform: scale(1.025);
  filter: brightness(.96);
}

.public-site .public-gallery-page-link {
  border-radius: 12px;
}

.public-site .public-footer,
.public-site .public-footer-main,
.public-site .public-footer-panel,
.public-site .public-footer-contact,
.public-site .public-footer-contact ul,
.public-site .public-footer-contact li {
  max-height: none;
  overflow: visible;
}

.public-site .public-footer-contact ul {
  gap: 12px;
}

.public-site .public-footer-contact li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-width: 0;
  line-height: 1.6;
}

.public-site .public-footer-contact i {
  flex: 0 0 1.35rem;
  width: 1.35rem;
  min-width: 1.35rem;
  margin-top: .18rem;
}

.public-site .public-footer-contact li span {
  flex: 1 1 auto;
  min-width: 0;
  line-height: 1.6;
  word-break: break-word;
  overflow-wrap: anywhere;
}

html[data-theme="dark"] .public-site .home-featured-gallery .gallery-card {
  background: rgba(248, 246, 240, .055);
  border-color: rgba(248, 246, 240, .13);
  box-shadow: 0 22px 52px rgba(0, 0, 0, .28);
}

@media (max-width: 768px) {
  .public-site .home-featured-gallery {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    grid-auto-rows: 4.75rem;
    gap: 10px;
  }

  .public-site .home-featured-gallery .gallery-orientation-landscape {
    grid-column: span 3;
    grid-row: span 2;
  }

  .public-site .home-featured-gallery .gallery-orientation-portrait {
    grid-column: span 2;
    grid-row: span 3;
  }

  .public-site .home-featured-gallery .gallery-orientation-square {
    grid-column: span 2;
    grid-row: span 2;
  }
}

@media (max-width: 576px) {
  .public-site .home-featured-gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-rows: 5.4rem;
    gap: 8px;
  }

  .public-site .home-featured-gallery .gallery-card {
    border-radius: 10px;
  }

  .public-site .home-featured-gallery .gallery-orientation-landscape {
    grid-column: span 2;
    grid-row: span 2;
  }

  .public-site .home-featured-gallery .gallery-orientation-portrait {
    grid-column: span 1;
    grid-row: span 3;
  }

  .public-site .home-featured-gallery .gallery-orientation-square {
    grid-column: span 1;
    grid-row: span 2;
  }

  .public-site .home-featured-gallery.home-featured-gallery-count-1 .gallery-card {
    grid-column: 1 / -1;
    grid-row: span 2;
  }

  .public-site .home-featured-gallery.home-featured-gallery-count-2 .gallery-card,
  .public-site .home-featured-gallery.home-featured-gallery-count-3 .gallery-card {
    grid-column: span 1;
    grid-row: span 2;
  }

  .public-site .home-featured-gallery.home-featured-gallery-count-3 .gallery-card:first-child {
    grid-column: 1 / -1;
  }

  .public-site .home-featured-gallery .homepage-gallery-link,
  .public-site .public-gallery-page-link {
    border-radius: 10px;
  }

  .public-site .public-footer {
    padding: 48px 0 32px;
  }

  .public-site .public-footer>.container {
    padding-right: 16px;
    padding-left: 16px;
  }

  .public-site .public-footer-main {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    padding-bottom: 2.5rem;
  }

  .public-site .public-footer-panel {
    width: 100%;
  }
}

@media (max-width: 359.98px) {
  .public-site .home-featured-gallery {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .public-site .home-featured-gallery .gallery-card,
  .public-site .home-featured-gallery .gallery-orientation-landscape,
  .public-site .home-featured-gallery .gallery-orientation-portrait,
  .public-site .home-featured-gallery .gallery-orientation-square {
    grid-column: 1 / -1;
    grid-row: auto;
    aspect-ratio: 4 / 3;
  }
}

@keyframes home-gallery-marquee-left {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(calc(-50% - (var(--home-gallery-gap) / 2)), 0, 0);
  }
}

@keyframes home-gallery-marquee-right {
  from {
    transform: translate3d(calc(-50% - (var(--home-gallery-gap) / 2)), 0, 0);
  }

  to {
    transform: translate3d(0, 0, 0);
  }
}

/* Homepage featured gallery final architecture: clipped viewport + JS marquee/swipe */
.public-site .featured-gallery-section,
.public-site .home-featured-gallery-wrap,
.public-site .home-featured-gallery {
  width: 100%;
  max-width: 100%;
  overflow: hidden !important;
}

.public-site .home-featured-gallery {
  --home-gallery-card-height: 260px;
  --home-gallery-gap: 10px;
  display: block !important;
}

.public-site .featured-gallery-viewport,
.public-site .home-featured-gallery-row {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden !important;
  contain: paint;
  cursor: grab;
  touch-action: pan-y;
  user-select: none;
}

.public-site .featured-gallery-viewport.is-dragging {
  cursor: grabbing;
}

.public-site .home-featured-gallery-row + .home-featured-gallery-row {
  margin-top: var(--home-gallery-gap);
}

.public-site .featured-gallery-track,
.public-site .home-featured-gallery-track {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: flex-start !important;
  width: max-content !important;
  max-width: none !important;
  gap: var(--home-gallery-gap) !important;
  margin: 0 !important;
  transform: translate3d(0, 0, 0);
  will-change: transform;
  animation: none !important;
  transition: none !important;
}

.public-site .featured-gallery-item,
.public-site .home-featured-gallery .gallery-card.featured-gallery-item,
.public-site .home-featured-gallery .gallery-card.featured-gallery-item.gallery-orientation-landscape,
.public-site .home-featured-gallery .gallery-card.featured-gallery-item.gallery-orientation-portrait,
.public-site .home-featured-gallery .gallery-card.featured-gallery-item.gallery-orientation-square {
  flex: 0 0 auto !important;
  width: calc(var(--home-gallery-card-height) * var(--gallery-ratio-width) / var(--gallery-ratio-height)) !important;
  min-width: 8rem !important;
  max-width: min(52rem, 82vw) !important;
  height: var(--home-gallery-card-height) !important;
  min-height: 0 !important;
  max-height: var(--home-gallery-card-height) !important;
  margin: 0 !important;
  overflow: hidden !important;
  border-radius: 10px !important;
  aspect-ratio: auto !important;
}

.public-site .featured-gallery-item img,
.public-site .home-featured-gallery .featured-gallery-item .homepage-gallery-img,
.public-site .home-featured-gallery .featured-gallery-item .homepage-gallery-img.gallery-orientation-landscape,
.public-site .home-featured-gallery .featured-gallery-item .homepage-gallery-img.gallery-orientation-square,
.public-site .home-featured-gallery .featured-gallery-item .homepage-gallery-img.gallery-orientation-portrait {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 100% !important;
  max-height: none !important;
  object-fit: cover !important;
  object-position: center !important;
}

@media (prefers-reduced-motion: reduce) {
  .public-site .home-featured-gallery-row .featured-gallery-track {
    animation: none !important;
    will-change: auto;
  }
}

@media (max-width: 991.98px) {
  .public-site .home-featured-gallery {
    --home-gallery-card-height: 220px;
    --home-gallery-gap: 10px;
  }
}

@media (max-width: 576px) {
  .public-site .home-featured-gallery {
    --home-gallery-card-height: 170px;
    --home-gallery-gap: 9px;
  }

  .public-site .featured-gallery-item,
  .public-site .home-featured-gallery .gallery-card.featured-gallery-item,
  .public-site .home-featured-gallery .gallery-card.featured-gallery-item.gallery-orientation-landscape,
  .public-site .home-featured-gallery .gallery-card.featured-gallery-item.gallery-orientation-portrait,
  .public-site .home-featured-gallery .gallery-card.featured-gallery-item.gallery-orientation-square {
    min-width: 7.5rem !important;
    max-width: 86vw !important;
  }
}

/* Public gallery responsive masonry lock */
.public-site .public-gallery-page-masonry {
  column-count: 4;
  column-gap: clamp(12px, 1.5vw, 22px);
}

.public-site .public-gallery-page-item {
  display: block;
  width: 100%;
  margin: 0 0 clamp(12px, 1.5vw, 22px);
  break-inside: avoid;
  page-break-inside: avoid;
  -webkit-column-break-inside: avoid;
}

.public-site .public-gallery-page-link {
  border-radius: 12px;
}

.public-site .public-gallery-page-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
}

.public-site .public-gallery-pagination {
  display: flex;
  justify-content: center;
}

.public-site .public-gallery-pagination nav {
  width: 100%;
}

@media (max-width: 1199.98px) {
  .public-site .public-gallery-page-masonry {
    column-count: 3;
  }
}

@media (max-width: 767.98px) {
  .public-site .public-gallery-page-masonry {
    column-count: 2;
    column-gap: 10px;
  }

  .public-site .public-gallery-page-item {
    margin-bottom: 10px;
  }

  .public-site .public-gallery-page-link {
    border-radius: 10px;
  }
}

@media (max-width: 359.98px) {
  .public-site .public-gallery-page-masonry {
    column-count: 2;
    column-gap: 8px;
  }

  .public-site .public-gallery-page-item {
    margin-bottom: 8px;
  }
}

.public-site .public-gallery-page-masonry.is-balanced {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(12px, 1.5vw, 22px);
  column-count: initial;
  column-gap: normal;
}

.public-site .public-gallery-page-column {
  display: grid;
  align-content: start;
  gap: clamp(12px, 1.5vw, 22px);
  min-width: 0;
}

.public-site .public-gallery-page-masonry.is-balanced .public-gallery-page-item {
  margin: 0;
}

@media (max-width: 1199.98px) {
  .public-site .public-gallery-page-masonry.is-balanced {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .public-site .public-gallery-page-masonry.is-balanced {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .public-site .public-gallery-page-column {
    gap: 10px;
  }
}

@media (max-width: 359.98px) {
  .public-site .public-gallery-page-masonry.is-balanced {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .public-site .public-gallery-page-column {
    gap: 8px;
  }
}

/* Public gallery spacing refinement */
.public-site .public-gallery-page-masonry,
.public-site .public-gallery-page-masonry.is-balanced {
  gap: 18px !important;
  column-gap: 18px !important;
}

.public-site .public-gallery-page-column {
  gap: 18px !important;
}

.public-site .public-gallery-page-item {
  margin-bottom: 18px;
}

@media (max-width: 991.98px) {
  .public-site .public-gallery-page-masonry,
  .public-site .public-gallery-page-masonry.is-balanced {
    gap: 14px !important;
    column-gap: 14px !important;
  }

  .public-site .public-gallery-page-column {
    gap: 14px !important;
  }

  .public-site .public-gallery-page-item {
    margin-bottom: 14px;
  }
}

@media (max-width: 575.98px) {
  .public-site .public-gallery-page-masonry,
  .public-site .public-gallery-page-masonry.is-balanced {
    gap: 10px !important;
    column-gap: 10px !important;
  }

  .public-site .public-gallery-page-column {
    gap: 10px !important;
  }

  .public-site .public-gallery-page-item {
    margin-bottom: 10px;
  }
}

/* Mobile footer brand overlap fix */
@media (max-width: 575.98px) {
  .public-site .public-footer-hero {
    overflow: visible !important;
  }

  .public-site .public-footer-brand {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 16px !important;
    min-width: 0;
  }

  .public-site .public-footer-logo-frame {
    display: inline-flex !important;
    flex: 0 0 auto !important;
    width: 96px !important;
    height: 96px !important;
    margin: 0 !important;
  }

  .public-site .public-footer-logo-frame img,
  .public-site .public-footer-brand img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: contain !important;
  }

  .public-site .public-footer-identity {
    display: block !important;
    width: 100% !important;
    min-width: 0;
  }

  .public-site .public-footer-kicker {
    display: block !important;
    clear: both;
    margin: 0 0 10px !important;
    line-height: 1.25 !important;
    white-space: normal !important;
  }
}

/* Dark mode spacious polish: Masyayikh detail page */
html[data-theme="dark"] .public-site .public-masyayikh-detail-page {
  max-width: min(100% - 32px, 86rem);
  padding-top: clamp(4rem, 7vw, 6.5rem);
  padding-bottom: clamp(5rem, 8vw, 7rem);
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 20% 12%, rgba(145, 240, 207, .08), transparent 26rem),
    radial-gradient(circle at 78% 18%, rgba(201, 164, 92, .07), transparent 24rem),
    linear-gradient(180deg, rgba(7, 31, 24, .62), rgba(7, 31, 24, .2) 48%, rgba(7, 31, 24, .68));
}

html[data-theme="dark"] .public-site .public-masyayikh-back-link {
  margin-bottom: clamp(2.25rem, 4vw, 3.5rem);
  color: #91f0cf !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-hero {
  grid-template-columns: clamp(16rem, 24vw, 22rem) minmax(0, 1fr);
  gap: clamp(2.6rem, 5.5vw, 5rem);
  align-items: center;
  padding: clamp(2rem, 4vw, 3rem);
  margin-bottom: clamp(2.25rem, 4vw, 3.5rem);
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .07), rgba(248, 246, 240, .035)) !important;
  border: 1px solid rgba(248, 246, 240, .12) !important;
  border-radius: 10px;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .22) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-photo {
  background: rgba(248, 246, 240, .06) !important;
  border: 1px solid rgba(248, 246, 240, .14);
  border-radius: 8px;
  box-shadow: 0 20px 48px rgba(0, 0, 0, .22);
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-photo img {
  aspect-ratio: 1 / 1.08;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-identity h1 {
  max-width: 24ch;
  margin-bottom: 1rem;
  font-size: clamp(2.45rem, 4.15vw, 4rem);
  line-height: 1.08;
  letter-spacing: 0;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-category {
  margin-bottom: clamp(2rem, 3.2vw, 2.8rem);
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-facts {
  gap: 1.25rem;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-facts div {
  padding-top: 1rem;
  border-top-color: rgba(248, 246, 240, .11);
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-facts dd {
  color: rgba(248, 246, 240, .88) !important;
  font-size: 1.06rem;
  line-height: 1.7;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-sections {
  align-items: start;
  gap: clamp(1.5rem, 2.4vw, 2rem);
  padding-block: 0;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-section {
  min-height: auto;
  padding: clamp(1.6rem, 2.6vw, 2rem);
  background:
    linear-gradient(145deg, rgba(248, 246, 240, .06), rgba(248, 246, 240, .03)) !important;
  border: 1px solid rgba(248, 246, 240, .11) !important;
  border-radius: 10px;
  box-shadow: 0 18px 50px rgba(0, 0, 0, .16) !important;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-section h2 {
  margin-bottom: .85rem;
}

html[data-theme="dark"] .public-site .public-masyayikh-detail-section p {
  color: rgba(221, 232, 226, .82) !important;
  font-size: 1rem;
  line-height: 1.85;
}

@media (max-width: 991.98px) {
  html[data-theme="dark"] .public-site .public-masyayikh-detail-page {
    max-width: min(100% - 28px, 54rem);
    padding-top: clamp(3.5rem, 8vw, 5rem);
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-hero {
    grid-template-columns: 1fr;
    align-items: start;
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-photo {
    width: min(100%, 20rem);
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-identity h1 {
    font-size: clamp(2.1rem, 7vw, 3.15rem);
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-sections {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 575.98px) {
  html[data-theme="dark"] .public-site .public-masyayikh-detail-page {
    max-width: min(100% - 24px, 32rem);
    padding-top: 3rem;
    padding-bottom: 4rem;
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-hero {
    gap: 1.5rem;
    padding: 1.15rem;
    border-radius: 8px;
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-photo {
    width: min(100%, 16rem);
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-identity h1 {
    font-size: clamp(1.85rem, 10vw, 2.45rem);
    line-height: 1.12;
  }

  html[data-theme="dark"] .public-site .public-masyayikh-detail-section {
    padding: 1.2rem;
    border-radius: 8px;
  }
}
