:root {
    --container: 1280px;
    --ink: #18212f;
    --muted: #667085;
    --line: #d9e1ec;
    --surface: #ffffff;
    --soft: #f5f7fb;
    --brand: #146c5f;
    --accent: #c48a2c;
    --danger: #b42318;
    --site-body-font-family: "Nunito Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
    --site-body-color: var(--ink);
    --site-body-size: 16px;
    --site-heading-font-family: var(--site-body-font-family);
    --site-heading-color: var(--ink);
    --site-heading-size: 32px;
    --site-link-font-family: var(--site-body-font-family);
    --site-link-color: var(--brand);
    --site-link-size: 15px;
    --site-link-hover-color: #0f554b;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    background: var(--soft);
    color: var(--site-body-color, var(--ink));
    font-family: var(--site-body-font-family);
    font-size: var(--site-body-size, 16px);
    line-height: 1.5;
}

a {
    color: inherit;
}

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

.site-main h1 {
    font-size: clamp(var(--site-heading-size, 32px), 5vw, calc(var(--site-heading-size, 32px) + 18px));
}

.site-main h2 {
    font-size: var(--site-heading-size, 32px);
}

.site-main h3 {
    font-size: max(18px, calc(var(--site-heading-size, 32px) - 8px));
}

.site-main a:not(.button),
.site-footer a {
    color: var(--site-link-color, var(--brand));
    font-family: var(--site-link-font-family);
    font-size: var(--site-link-size, 15px);
}

.site-main a:not(.button):hover,
.site-footer a:hover {
    color: var(--site-link-hover-color, var(--brand));
}

.site-main a.home-archive-title-link {
    color: inherit;
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    text-decoration: none;
}

.site-main a.home-archive-title-link:hover {
    color: inherit;
    opacity: .82;
    text-decoration: none;
}

.site-container {
    margin-inline: auto;
    max-width: var(--container);
    width: min(calc(100% - 40px), var(--container));
}

.site-main {
    display: flex;
    flex-direction: column;
}

.topbar,
.site-header {
    background: var(--surface);
    border-bottom: 1px solid var(--line);
}

.topbar-inner,
.site-header-inner {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.topbar {
    background: var(--topbar-bg, var(--surface));
    border-bottom: 1px solid var(--line);
    color: var(--topbar-color, var(--muted));
    font-size: var(--topbar-font-size, 14px);
}

.topbar-inner {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    gap: 18px;
    min-height: var(--topbar-height, 36px);
    padding-block: 6px;
}

.topbar-item {
    align-items: center;
    color: inherit;
    display: inline-flex;
    min-width: 0;
    text-decoration: none;
    white-space: nowrap;
}

.topbar-social {
    display: inline-flex;
    gap: 10px;
    margin-left: auto;
}

.topbar-social a {
    align-items: center;
    color: inherit;
    display: inline-flex;
    height: 24px;
    justify-content: center;
    text-decoration: none;
    width: 24px;
}

.site-header {
    padding-block: 2px;
}

.site-footer {
    background: var(--footer-bg, var(--ink));
    border-bottom: 0;
    border-top: 1px solid var(--line);
    color: var(--footer-text, #d7deea);
    padding-block: var(--footer-pt, 34px) var(--footer-pb, 18px);
}

.brand,
.admin-logo {
    font-weight: 700;
    text-decoration: none;
}

.site-nav {
    display: flex;
    gap: 18px;
}

.site-nav a,
.admin-sidebar a {
    color: var(--muted);
    text-decoration: none;
}

.header-cta {
    background: var(--brand);
    border-radius: 6px;
    color: #fff;
    font-weight: 700;
    padding: 9px 12px;
    text-decoration: none;
}

.hero,
.error-page {
    align-items: center;
    display: grid;
    margin-inline: auto;
    max-width: var(--container);
    min-height: 58vh;
    padding-block: clamp(42px, 8vw, 96px);
    width: min(calc(100% - 40px), var(--container));
}

.hero-copy,
.error-page {
    max-width: 760px;
}

.slider-hero {
    background: var(--ink);
    height: var(--slider-desktop-height, 466px);
    overflow: hidden;
    position: relative;
}

.slider-hero.slider-width-contained {
    margin-inline: auto;
    max-width: var(--container);
    width: min(100%, var(--container));
}

.slider-hero.slider-width-full {
    width: 100%;
}

.slider-hero-mobile {
    display: none;
}

.slide {
    align-items: center;
    color: #fff;
    display: none;
    height: 100%;
    position: relative;
}

.slide.active {
    display: grid;
}

.slide::before {
    background: rgba(3, 7, 18, var(--slider-overlay-opacity, .45));
    content: '';
    inset: 0;
    position: absolute;
    z-index: 1;
}

.slide > img {
    height: 100%;
    inset: 0;
    object-fit: cover;
    position: absolute;
    width: 100%;
}

.slide .hero-copy {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    margin-inline: auto;
    max-width: var(--container);
    position: relative;
    text-align: left;
    gap: var(--slider-text-gap, 14px);
    width: min(calc(100% - 40px), var(--container));
    z-index: 2;
}

.slide .hero-copy h1,
.slide .hero-copy p,
.slide .hero-copy .hero-actions {
    margin-bottom: 0;
    margin-top: 0;
}

.slider-width-contained.slider-align-left .hero-copy {
    margin-left: clamp(92px, 8vw, 118px);
    margin-right: 58px;
    max-width: none;
    width: auto;
}

.slider-width-contained.slider-align-center .hero-copy,
.slider-width-contained.slider-align-right .hero-copy {
    width: min(calc(100% - 150px), calc(var(--container) - 150px));
}

.slider-align-center .hero-copy {
    align-items: center;
    text-align: center;
}

.slider-align-right .hero-copy {
    align-items: flex-end;
    text-align: right;
}

.slide h1 {
    color: var(--slider-title-color, #fff);
    font-size: var(--slider-title-size, 56px);
    font-weight: var(--slider-title-weight, 800);
}

.slide .hero-copy > p:not(.eyebrow) {
    color: var(--slider-desc-color, #fff);
    font-size: var(--slider-desc-size, 18px);
    font-weight: var(--slider-desc-weight, 500);
}

.slide .button {
    background: var(--slider-button-bg, var(--brand));
    border-color: var(--slider-button-bg, var(--brand));
    color: var(--slider-button-color, #fff);
    font-size: var(--slider-button-size, 15px);
}

.slide .button:hover {
    background: var(--slider-button-hover, var(--brand));
    border-color: var(--slider-button-hover, var(--brand));
}

.slide .button.secondary {
    border-color: #fff;
    color: #fff;
}

.slider-desktop-desc-off .hero-copy > p:not(.eyebrow),
.slider-desktop-button-off .hero-actions,
.slider-desktop-dots-off .slider-dots {
    display: none;
}


.slider-nav {
    align-items: center;
    background: rgba(255, 255, 255, .9);
    border: 0;
    border-radius: 999px;
    color: #06152d;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    padding: 0;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 42px;
    z-index: 3;
}

.slider-prev {
    left: 22px;
}

.slider-next {
    right: 22px;
}

.slider-dots {
    align-items: center;
    bottom: 18px;
    display: flex;
    gap: 8px;
    justify-content: center;
    left: 0;
    position: absolute;
    right: 0;
    z-index: 3;
}

.slider-dots button {
    background: rgba(255, 255, 255, .58);
    border: 0;
    border-radius: 999px;
    height: 10px;
    padding: 0;
    width: 10px;
}

.slider-dots button.active {
    background: #fff;
    width: 28px;
}

.about-section {
    align-items: center;
    background: var(--surface);
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.8fr);
}

.about-section img {
    aspect-ratio: 4 / 3;
    border-radius: 8px;
    display: block;
    object-fit: cover;
    width: 100%;
}

.eyebrow {
    color: var(--accent);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0;
    margin: 0 0 8px;
    text-transform: uppercase;
}

h1,
h2,
h3,
p {
    margin-top: 0;
}

h1 {
    font-size: clamp(36px, 6vw, 68px);
    line-height: 1.05;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 26px;
}

.button,
button {
    background: var(--brand);
    border: 1px solid var(--brand);
    border-radius: 6px;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-weight: 700;
    justify-content: center;
    padding: 11px 16px;
    text-decoration: none;
}

.button.secondary {
    background: transparent;
    color: var(--brand);
}

.text-link {
    color: var(--brand);
    font-weight: 700;
    text-decoration: none;
}

.lead {
    color: var(--muted);
    font-size: 20px;
    max-width: 760px;
}

.section {
    margin-inline: auto;
    max-width: var(--container);
    padding-block: 34px 64px;
    width: min(calc(100% - 40px), var(--container));
}

.lead-section {
    align-items: start;
    background: #fff;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 0.9fr) minmax(300px, 1.1fr);
}

.lead-form {
    background: var(--soft);
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 14px;
    padding: 20px;
}

.hp-field {
    left: -9999px;
    position: absolute;
}

.feature-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.feature-card-image {
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    display: block;
    margin-bottom: 14px;
    object-fit: cover;
    width: 100%;
}

.empty-section {
    background: var(--surface);
    border: 1px dashed var(--line);
    border-radius: 8px;
    color: var(--muted);
    margin: 0;
    padding: 18px;
}

.featured-card-grid,
.process-grid,
.announcement-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.featured-card,
.process-card,
.announcement-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 22px;
}

.featured-card span,
.process-card strong {
    color: var(--accent);
    display: block;
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 10px;
}

.featured-card p,
.process-card p,
.announcement-card p {
    color: var(--muted);
}

.announcement-section {
    background: #fff;
}

.announcement-card {
    align-items: center;
    display: flex;
    gap: 18px;
    justify-content: space-between;
}

.process-section {
    background: #fff;
}

.process-card span {
    color: var(--brand);
    display: block;
    font-size: 28px;
    font-weight: 700;
}

.contact-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.faq-list {
    display: grid;
    gap: 12px;
}

.faq-list.two-column {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.faq-list details {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 16px;
}

.faq-list summary {
    cursor: pointer;
    font-weight: 700;
}

.faq-list p {
    color: var(--muted);
    margin: 12px 0 0;
}

.faq-section-header {
    margin-bottom: 24px;
}

.faq-section-header h1,
.faq-section-header h2 {
    margin: 0;
}

.faq-section-header p {
    color: var(--faq-answer-color, var(--muted));
    font-size: var(--faq-answer-size, 15px);
    font-weight: var(--faq-answer-weight, 400);
    line-height: 1.7;
    margin: 10px auto 0;
    max-width: 760px;
}

.faq-section .faq-list {
    gap: var(--faq-gap, 12px);
}

.faq-section .faq-list details {
    background: var(--faq-card-bg, #fff);
    border-color: var(--faq-card-border, var(--line));
    border-radius: var(--faq-card-radius, 8px);
    overflow: hidden;
}

.faq-section .faq-list details[open] {
    background: var(--faq-active-bg, #f4f8fb);
}

.faq-section .faq-list summary {
    align-items: center;
    color: var(--faq-question-color, var(--ink));
    display: flex;
    font-size: var(--faq-question-size, 17px);
    font-weight: var(--faq-question-weight, 700);
    gap: 14px;
    justify-content: space-between;
}

.faq-section .faq-list summary::after {
    color: var(--faq-icon-color, var(--brand));
    content: "\f078";
    font-family: "Font Awesome 6 Free";
    font-size: .9em;
    font-weight: 900;
    transition: transform .18s ease;
}

.faq-section .faq-list details[open] summary::after {
    transform: rotate(180deg);
}

.faq-section .faq-answer,
.faq-section .faq-answer p {
    color: var(--faq-answer-color, var(--muted));
    font-size: var(--faq-answer-size, 15px);
    font-weight: var(--faq-answer-weight, 400);
    line-height: 1.7;
}

.faq-admin-row {
    grid-template-columns: 34px 64px minmax(0, 1fr) 150px 170px;
}

.faq-admin-icon {
    align-items: center;
    background: #f3f6fa;
    border-radius: 8px;
    color: var(--brand);
    display: flex;
    font-size: 24px;
    height: 56px;
    justify-content: center;
    width: 64px;
}

.faq-admin-row .admin-row-check {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    margin: 0;
    white-space: nowrap;
}

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

@media (max-width: 900px) {
    .faq-admin-row {
        grid-template-columns: 34px 64px minmax(0, 1fr);
    }

    .faq-admin-row .admin-row-check,
    .faq-admin-row .row-actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}

.stats-section {
    background: var(--stats-bg, var(--ink));
    color: var(--stats-text-color, #fff);
    max-width: none;
    padding-inline: max(20px, calc((100% - var(--container)) / 2));
    width: 100%;
}

.stats-title {
    color: var(--stats-title-color, #fff);
    font-size: var(--stats-title-size, 32px);
    font-weight: var(--stats-title-weight, 700);
    margin: 0 0 28px;
    text-align: center;
}

.site-main .stats-section .stats-title {
    color: var(--stats-title-color, #fff);
    font-size: var(--stats-title-size, 32px);
    font-weight: var(--stats-title-weight, 700);
}

.stats-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.stats-grid article {
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 8px;
    padding: 20px;
}

.stats-grid span {
    color: var(--stats-icon-color, var(--accent));
    display: block;
    font-size: var(--stats-icon-size, 24px);
    font-weight: var(--stats-icon-weight, 700);
    margin-bottom: 10px;
}

.stats-grid strong {
    color: var(--stats-number-color, #fff);
    display: block;
    font-size: var(--stats-number-size, 34px);
    font-weight: var(--stats-number-weight, 800);
}

.stats-grid p {
    color: var(--stats-text-color, #d7deea);
    font-size: var(--stats-text-size, 16px);
    font-weight: var(--stats-text-weight, 500);
    margin: 4px 0 0;
}

.media-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.media-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    min-width: 0;
    padding: 12px;
}

.media-card img,
.pdf-preview {
    align-items: center;
    aspect-ratio: 4 / 3;
    background: var(--soft);
    border-radius: 6px;
    display: flex;
    justify-content: center;
    object-fit: cover;
    width: 100%;
}

.media-card strong {
    display: block;
    font-size: 13px;
    line-height: 1.35;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.media-card span,
.media-card code {
    color: var(--muted);
    display: block;
    font-size: 12px;
    overflow-wrap: anywhere;
}

.media-field {
    background: #f8fafc;
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 14px;
    padding: 16px;
}

.media-field > div:first-child strong {
    display: block;
}

.media-field > div:first-child span,
.media-preview span {
    color: var(--muted);
    display: block;
    font-size: 13px;
    margin-top: 4px;
}

.media-preview {
    align-items: center;
    background: #fff;
    border: 1px dashed #cfd7e3;
    border-radius: 8px;
    display: flex;
    gap: 12px;
    min-height: 92px;
    padding: 12px;
}

.media-preview img {
    aspect-ratio: 16 / 9;
    border-radius: 6px;
    max-width: 180px;
    object-fit: cover;
    width: 32%;
}

.media-preview-file {
    align-items: center;
    aspect-ratio: 4 / 3;
    background: #eef4ff;
    border: 1px solid #c9d8f6;
    border-radius: 6px;
    color: #1d4f91;
    display: flex;
    font-size: 13px;
    font-weight: 800;
    justify-content: center;
    max-width: 120px;
    width: 24%;
}

.gallery-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.gallery-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.gallery-grid a {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--ink);
    overflow: hidden;
    text-decoration: none;
}

.gallery-grid img {
    aspect-ratio: 4 / 3;
    display: block;
    object-fit: cover;
    width: 100%;
}

.gallery-grid span {
    display: block;
    font-weight: 700;
    padding: 10px 12px;
}

.document-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.document-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.document-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
}

.document-card a {
    color: var(--ink);
    text-decoration: none;
}

.document-card img {
    aspect-ratio: 4 / 3;
    display: block;
    object-fit: cover;
    width: 100%;
}

.document-card div {
    padding: 14px 14px 12px;
}

.document-card h2,
.document-card h3 {
    font-size: 16px;
    margin-bottom: 6px;
}

.document-card p {
    color: var(--muted);
    margin-bottom: 10px;
}

.reference-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.reference-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.reference-card {
    align-items: center;
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    justify-items: center;
    min-height: 150px;
    padding: 18px;
    text-align: center;
}

.reference-card a {
    color: var(--ink);
    text-decoration: none;
}

.reference-card img {
    display: block;
    max-height: 74px;
    max-width: 150px;
    object-fit: contain;
    width: 100%;
}

.reference-card h2,
.reference-card h3 {
    font-size: 17px;
    margin-bottom: 0;
}

.reference-card p {
    color: var(--muted);
    margin-bottom: 0;
}

.references-home-section {
    overflow: hidden;
}

.references-section-header {
    margin-bottom: 26px;
}

.references-section-header h1,
.references-section-header h2 {
    margin: 0;
}

.references-marquee {
    overflow: hidden;
    position: relative;
    width: 100%;
}

.references-track {
    align-items: stretch;
    display: flex;
    gap: var(--reference-gap, 22px);
    justify-content: center;
    width: 100%;
}

.references-home-section.is-sliding .references-track {
    animation: references-slide var(--reference-speed, 28s) linear infinite;
    justify-content: flex-start;
    width: max-content;
}

.references-marquee:hover .references-track {
    animation-play-state: paused;
}

.reference-logo-item {
    flex: 0 0 calc((100% - (var(--reference-gap, 22px) * 5)) / 6);
    max-width: calc((1280px - (var(--reference-gap, 22px) * 5)) / 6);
    min-width: 150px;
    text-align: center;
}

.references-home-section.is-static .reference-logo-item {
    flex-grow: 0;
}

.reference-logo-box {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: var(--reference-radius, 8px);
    display: flex;
    height: var(--reference-logo-height, 110px);
    justify-content: center;
    padding: 0;
    width: 100%;
}

.reference-logo-box img {
    display: block;
    max-height: 100%;
    max-width: 100%;
    object-fit: contain;
    width: 100%;
}

.reference-logo-item h3 {
    color: var(--reference-title-color, var(--ink));
    font-size: var(--reference-title-size, 15px);
    font-weight: var(--reference-title-weight, 700);
    line-height: 1.35;
    margin: 12px 0 0;
}

.site-main .reference-logo-item h3 a,
.reference-logo-item h3 span {
    color: inherit;
    font: inherit;
    text-decoration: none;
}

.site-main .reference-logo-item h3 a:hover {
    color: var(--site-link-hover-color, var(--primary));
}

.references-public-section {
    --reference-archive-cols: 6;
}

.references-public-grid {
    display: grid;
    gap: var(--reference-gap, 22px);
    grid-template-columns: repeat(var(--reference-archive-cols), minmax(0, 1fr));
}

@keyframes references-slide {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(calc(-50% - (var(--reference-gap, 22px) / 2)));
    }
}

@media (max-width: 900px) {
    .reference-logo-item {
        flex-basis: calc((100vw - 32px - var(--reference-gap, 22px)) / 2);
        max-width: none;
        min-width: 140px;
    }

    .references-public-grid {
        --reference-archive-cols: 2;
    }
}

.testimonial-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.testimonial-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.testimonial-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 22px;
}

.testimonial-card strong {
    color: var(--accent);
    display: block;
    letter-spacing: 0;
    margin-bottom: 10px;
}

.testimonial-card p {
    color: var(--ink);
}

.testimonial-card h2,
.testimonial-card h3 {
    font-size: 16px;
    margin-bottom: 2px;
}

.testimonial-card span {
    color: var(--muted);
    display: block;
}

.testimonials-home-section,
.testimonials-public-section {
    overflow: hidden;
}

.testimonials-section-header {
    margin-bottom: 34px;
}

.testimonials-section-header h1,
.testimonials-section-header h2 {
    margin: 0;
}

.testimonials-slider {
    overflow: hidden;
    width: 100%;
}

.testimonials-track {
    display: flex;
    gap: var(--testimonial-gap, 28px);
    justify-content: flex-start;
    transition: transform .45s ease;
    width: 100%;
    will-change: transform;
}

.testimonials-home-section.is-desktop-static .testimonials-track {
    justify-content: center;
}

.testimonial-slide {
    flex: 0 0 calc((100% - (var(--testimonial-gap, 28px) * 2)) / 3);
    min-width: 0;
    text-align: center;
}

.testimonial-person {
    align-items: center;
    display: inline-flex;
    gap: 14px;
    justify-content: center;
    margin-bottom: 36px;
    text-align: left;
}

.testimonial-person img,
.testimonial-avatar-placeholder {
    align-items: center;
    background: #fff;
    border-radius: 50%;
    display: flex;
    flex: 0 0 var(--testimonial-photo-size, 96px);
    height: var(--testimonial-photo-size, 96px);
    justify-content: center;
    object-fit: cover;
    overflow: hidden;
    width: var(--testimonial-photo-size, 96px);
}

.testimonial-avatar-placeholder {
    color: var(--primary);
    font-size: calc(var(--testimonial-photo-size, 96px) * .36);
}

.testimonial-person h2,
.testimonial-person h3 {
    color: var(--testimonial-name-color, var(--ink));
    font-size: var(--testimonial-name-size, 16px);
    font-weight: var(--testimonial-name-weight, 700);
    line-height: 1.25;
    margin: 0 0 4px;
}

.testimonial-person span {
    color: var(--testimonial-company-color, var(--muted));
    display: block;
    font-size: var(--testimonial-company-size, 14px);
    font-weight: var(--testimonial-company-weight, 500);
    line-height: 1.25;
}

.testimonial-slide > p {
    color: var(--testimonial-text-color, #5f6f82);
    font-size: var(--testimonial-text-size, 21px);
    font-style: italic;
    font-weight: var(--testimonial-text-weight, 500);
    line-height: 1.55;
    margin: 0 auto;
    max-width: 430px;
}

.testimonials-public-grid {
    display: grid;
    gap: var(--testimonial-gap, 28px);
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
    .testimonials-home-section.is-mobile-static .testimonials-track {
        justify-content: center;
    }

    .testimonial-slide {
        flex-basis: 100%;
        width: 100%;
    }

    .testimonials-home-section .testimonial-slide {
        flex-basis: calc(100vw - 20px);
        max-width: calc(100vw - 20px);
    }

    .testimonial-person {
        margin-bottom: 24px;
    }

    .testimonial-slide > p {
        font-size: min(var(--testimonial-text-size, 21px), 19px);
        max-width: 92%;
    }

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

.team-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.team-grid.compact {
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
}

.team-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
}

.team-card img {
    aspect-ratio: 4 / 4;
    display: block;
    object-fit: cover;
    width: 100%;
}

.team-card div {
    padding: 16px;
}

.team-card h2,
.team-card h3 {
    font-size: 19px;
    margin-bottom: 4px;
}

.team-card strong {
    color: var(--brand);
    display: block;
    margin-bottom: 10px;
}

.team-card p {
    color: var(--muted);
}

.pricing-grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pricing-grid.compact {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pricing-card {
    background: var(--pricing-card-bg, var(--surface));
    border: 1px solid var(--pricing-card-border, var(--line));
    border-radius: var(--pricing-card-radius, 8px);
    display: grid;
    gap: 12px;
    padding: 22px;
}

.pricing-card.featured {
    border-color: var(--pricing-featured, var(--brand));
    box-shadow: inset 0 4px 0 var(--pricing-featured, var(--brand));
}

.pricing-card h2,
.pricing-card h3 {
    color: var(--pricing-title-color, var(--ink));
    font-size: var(--pricing-title-size, 22px);
    font-weight: var(--pricing-title-weight, 700);
    margin-bottom: 0;
}

.pricing-card strong {
    color: var(--pricing-price-color, var(--brand));
    display: block;
    font-size: var(--pricing-price-size, 34px);
    font-weight: var(--pricing-price-weight, 800);
}

.pricing-card span,
.pricing-card p {
    color: var(--pricing-text-color, var(--muted));
    font-size: var(--pricing-text-size, 15px);
    font-weight: var(--pricing-text-weight, 400);
}

.pricing-card .pricing-kicker {
    color: var(--pricing-featured, var(--brand));
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0;
    margin: 0;
    text-transform: uppercase;
}

.pricing-card ul {
    color: var(--pricing-text-color, var(--muted));
    display: grid;
    font-size: var(--pricing-text-size, 15px);
    font-weight: var(--pricing-text-weight, 400);
    gap: 8px;
    margin: 0;
    padding-left: 18px;
}

.pricing-card .button {
    background: var(--pricing-button-bg, var(--brand));
    color: var(--pricing-button-color, #fff);
    margin-top: 6px;
}

.pricing-card .button:hover {
    background: var(--pricing-button-hover, var(--brand-700));
    color: var(--pricing-button-color, #fff);
}

.pricing-section-header {
    margin-bottom: 28px;
}

.pricing-section-header h1,
.pricing-section-header h2 {
    margin: 0;
}

.pricing-section-header p {
    color: var(--pricing-text-color, var(--muted));
    font-size: var(--pricing-text-size, 15px);
    font-weight: var(--pricing-text-weight, 400);
    line-height: 1.7;
    margin: 12px auto 0;
    max-width: 820px;
}

.pricing-admin-price {
    align-items: center;
    display: grid;
    justify-items: center;
    text-align: center;
}

.pricing-admin-price strong {
    color: var(--primary);
    display: block;
    font-size: 18px;
}

.pricing-admin-price span {
    color: var(--muted);
    font-size: 12px;
}

.pricing-page-description-box {
    margin-top: 18px;
}

.pricing-page-description-box textarea {
    min-height: 96px;
}

@media (max-width: 900px) {
    .pricing-grid,
    .pricing-grid.compact {
        grid-template-columns: 1fr;
    }
}

.area-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
}

.area-grid > p {
    width: 100%;
    text-align: center;
}

.area-card {
    background: var(--area-card-bg, var(--surface));
    border: 1px solid var(--area-card-border, var(--line));
    border-radius: var(--area-card-radius, 8px);
    flex: 0 1 calc((100% - 60px) / 4);
    max-width: calc((100% - 60px) / 4);
    padding: 20px;
}

.area-card h2,
.area-card h3 {
    color: var(--area-title-color, var(--ink));
    font-size: var(--area-title-size, 22px);
    font-weight: var(--area-title-weight, 700);
    margin-bottom: 8px;
}

.area-card p {
    color: var(--area-text-color, var(--muted));
    font-size: var(--area-text-size, 15px);
    font-weight: var(--area-text-weight, 400);
}

.area-section-header {
    margin-bottom: 28px;
}

.area-section-header h1,
.area-section-header h2 {
    margin: 0;
}

.area-section-header p {
    color: var(--area-text-color, var(--muted));
    font-size: var(--area-text-size, 15px);
    font-weight: var(--area-text-weight, 400);
    line-height: 1.7;
    margin: 12px auto 0;
    max-width: 820px;
}

.area-admin-icon {
    align-items: center;
    color: var(--primary);
    display: flex;
    font-size: 24px;
    justify-content: center;
}

.area-page-description-box {
    margin-top: 18px;
}

.area-page-description-box textarea {
    min-height: 96px;
}

@media (max-width: 900px) {
    .area-card {
        flex-basis: calc((100% - 20px) / 2);
        max-width: calc((100% - 20px) / 2);
    }
}

.catalog-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
}

.catalog-grid > .empty-section {
    width: 100%;
}

.catalog-card {
    background: var(--catalog-card-bg, var(--surface));
    border: 1px solid var(--catalog-card-border, var(--line));
    border-radius: var(--catalog-card-radius, 8px);
    flex: 0 1 calc((100% - 48px) / 4);
    max-width: calc((100% - 48px) / 4);
    display: grid;
    gap: 12px;
    padding: 20px;
    align-content: start;
}

.catalog-preview,
.catalog-preview-fallback {
    align-items: center;
    aspect-ratio: auto;
    background: #f3f6fb;
    border-radius: max(6px, calc(var(--catalog-card-radius, 8px) - 2px));
    display: flex;
    justify-content: center;
    margin: 0;
    min-height: 165px;
    overflow: hidden;
    padding-top: 3px;
    width: 100%;
}

.catalog-preview img {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    transform: none;
    transform-origin: initial;
    width: 100%;
}

.catalog-preview-fallback {
    color: var(--catalog-title-color, var(--ink));
    flex-direction: column;
    font-weight: 700;
    gap: 8px;
}

.catalog-preview-fallback i {
    font-size: 34px;
}

.catalog-card h2,
.catalog-card h3 {
    color: var(--catalog-title-color, var(--ink));
    font-size: var(--catalog-title-size, 20px);
    font-weight: var(--catalog-title-weight, 700);
    margin-bottom: 0;
}

.catalog-card p {
    color: var(--catalog-text-color, var(--muted));
    font-size: var(--catalog-text-size, 15px);
    font-weight: var(--catalog-text-weight, 400);
}

.catalog-section-header {
    margin-bottom: 26px;
}

.catalog-section-header h1,
.catalog-section-header h2 {
    margin: 0;
}

.catalog-section-header p {
    color: var(--catalog-text-color, var(--muted));
    font-size: var(--catalog-text-size, 15px);
    font-weight: var(--catalog-text-weight, 400);
    line-height: 1.7;
    margin: 10px auto 0;
    max-width: 760px;
}

.catalog-button {
    background: var(--catalog-button-bg, var(--brand));
    border-color: var(--catalog-button-bg, var(--brand));
    color: var(--catalog-button-color, #fff);
    font-size: var(--catalog-button-size, 14px);
}

.catalog-button:hover {
    background: var(--catalog-button-hover, var(--brand));
    border-color: var(--catalog-button-hover, var(--brand));
    color: var(--catalog-button-color, #fff);
}

@media (max-width: 900px) {
    .catalog-card {
        flex-basis: calc((100% - 16px) / 2);
        max-width: calc((100% - 16px) / 2);
    }

    .catalog-preview,
    .catalog-preview-fallback {
        min-height: 138px;
    }
}

.video-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.video-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 18px;
}

.video-card h2 {
    font-size: 20px;
    margin-bottom: 0;
}

.video-card p {
    color: var(--muted);
}

.video-frame {
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: 8px;
    overflow: hidden;
    width: 100%;
}

.video-frame iframe {
    border: 0;
    display: block;
    height: 100%;
    width: 100%;
}

.video-section-header {
    margin-bottom: 26px;
}

.video-section-header h1,
.video-section-header h2 {
    margin: 0;
}

.video-section-header p {
    color: var(--video-text-color, var(--muted));
    font-size: var(--video-text-size, 15px);
    font-weight: var(--video-text-weight, 400);
    line-height: 1.7;
    margin: 10px auto 0;
    max-width: 760px;
}

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

.video-public-grid > .empty-section {
    grid-column: 1 / -1;
}

.video-public-card {
    background: var(--video-card-bg, var(--surface));
    border: 1px solid var(--video-card-border, var(--line));
    border-radius: var(--video-card-radius, 8px);
    display: grid;
    gap: 12px;
    overflow: hidden;
    padding: 18px;
}

.video-public-card .video-frame {
    aspect-ratio: var(--video-ratio, 16/9);
    background: #101828;
    border-radius: 8px;
    margin: 0;
    overflow: hidden;
    position: relative;
}

.video-public-card .video-frame.has-video-thumb {
    background-image: linear-gradient(rgba(16, 24, 40, .18), rgba(16, 24, 40, .18)), var(--video-thumb);
    background-position: center;
    background-size: cover;
}

.video-public-card h2,
.video-public-card h3 {
    color: var(--video-title-color, var(--ink));
    font-size: var(--video-title-size, 20px);
    font-weight: var(--video-title-weight, 700);
    margin: 0;
}

.video-public-card p {
    color: var(--video-text-color, var(--muted));
    font-size: var(--video-text-size, 15px);
    font-weight: var(--video-text-weight, 400);
    line-height: 1.65;
    margin: 0;
}

.video-admin-thumb {
    aspect-ratio: 16 / 9;
}

.video-admin-thumb iframe {
    border: 0;
    height: 100%;
    width: 100%;
}

.service-admin-row[data-video-row] {
    grid-template-columns: 34px 92px minmax(0, 1fr) 150px 270px;
}

.service-admin-row[data-video-row] .admin-row-check {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    margin: 0;
    white-space: nowrap;
}

.service-admin-row[data-video-row] .row-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

.service-admin-row[data-video-row] .row-actions .button,
.service-admin-row[data-video-row] .row-actions button {
    margin: 0;
    min-width: 74px;
}

@media (max-width: 900px) {
    .video-public-grid {
        grid-template-columns: repeat(var(--video-mobile-columns, 1), minmax(0, 1fr));
    }

    .service-admin-row[data-video-row] {
        grid-template-columns: 34px 92px minmax(0, 1fr);
    }

    .service-admin-row[data-video-row] .admin-row-check,
    .service-admin-row[data-video-row] .row-actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}

.media-placeholder {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 0;
    color: #ffffff;
    cursor: pointer;
    display: flex;
    font-size: 16px;
    font-weight: 800;
    height: 100%;
    justify-content: center;
    min-height: 220px;
    position: relative;
    text-shadow: 0 2px 12px rgba(0, 0, 0, .36);
    width: 100%;
}

.media-placeholder::before {
    align-items: center;
    background: rgba(220, 38, 38, .94);
    border-radius: 999px;
    box-shadow: 0 14px 28px rgba(16, 24, 40, .22);
    content: "\f04b";
    display: flex;
    font-family: "Font Awesome 6 Free";
    font-size: 22px;
    font-weight: 900;
    height: 66px;
    justify-content: center;
    margin-right: 12px;
    padding-left: 4px;
    transition: transform .18s ease, background .18s ease;
    width: 66px;
}

.media-placeholder:hover::before {
    background: #ef233c;
    transform: scale(1.06);
}

.video-frame iframe {
    border: 0;
    display: block;
    height: 100%;
    inset: 0;
    position: absolute;
    width: 100%;
}

.map-contact-section {
    align-items: center;
    display: grid;
    gap: 28px;
    grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr);
    padding: clamp(24px, 4vw, 42px);
}

.map-contact-section p {
    color: var(--muted);
}

.map-contact-content {
    min-width: 0;
}

.map-contact-content h2 {
    margin-bottom: 12px;
}

.map-contact-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

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

.map-contact-map-left .map-frame {
    order: 1;
}

.map-contact-map-left .map-contact-content {
    order: 2;
}

.map-contact-contact-left .map-contact-content {
    order: 1;
}

.map-contact-contact-left .map-frame {
    order: 2;
}

.map-frame {
    aspect-ratio: 16 / 10;
    background: var(--soft);
    border: 1px solid var(--line);
    border-radius: 8px;
    overflow: hidden;
    width: 100%;
}

.map-frame .media-placeholder::before,
.map-placeholder::before {
    content: "\f3c5";
}

.map-frame iframe {
    border: 0;
    display: block;
    height: 100%;
    width: 100%;
}

.map-frame iframe ~ .media-placeholder {
    display: none;
}

.lightbox-overlay {
    align-items: center;
    background: rgba(16, 24, 40, 0.86);
    display: none;
    inset: 0;
    justify-content: center;
    padding: 24px;
    position: fixed;
    z-index: 100;
}

.lightbox-overlay.is-open {
    display: flex;
}

.lightbox-overlay img {
    background: #ffffff;
    border-radius: 8px;
    max-height: min(86vh, 900px);
    max-width: min(92vw, 1100px);
    object-fit: contain;
}

.lightbox-close {
    align-items: center;
    background: #ffffff;
    border: 0;
    border-radius: 999px;
    color: #101828;
    display: inline-flex;
    font-size: 26px;
    height: 44px;
    justify-content: center;
    padding: 0;
    position: absolute;
    right: 22px;
    top: 22px;
    width: 44px;
}

.feature-grid article,
.contact-grid article,
.login-card,
.admin-panel,
.module-row {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 22px;
}

.page-section {
    min-height: 52vh;
}

.footer-grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.footer-grid h2 {
    color: var(--footer-heading, #fff);
    font-size: 16px;
}

.footer-grid a {
    color: var(--footer-link, #fff);
    text-decoration: none;
}

.footer-logo {
    display: block;
    height: auto;
    margin-bottom: 14px;
    max-height: 64px;
    max-width: 220px;
    object-fit: contain;
}

.footer-social {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 14px 0;
}

.footer-social a {
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--footer-social, #ffffff) 28%, transparent);
    border-radius: 999px;
    color: var(--footer-social, #ffffff);
    display: inline-flex;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.footer-map {
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    margin-bottom: 16px;
    overflow: hidden;
}

.footer-map iframe {
    border: 0;
    display: block;
    height: 100%;
    width: 100%;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, 0.14);
    color: #aeb8c8;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: space-between;
    margin-top: 24px;
    padding-top: 16px;
}

.quick-access {
    bottom: 18px;
    display: grid;
    gap: 8px;
    position: fixed;
    right: 18px;
    z-index: 50;
}

.quick-access a {
    align-items: center;
    aspect-ratio: 1;
    background: var(--quick-access-bg, var(--brand));
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    box-shadow: 0 10px 28px rgba(24, 33, 47, 0.18);
    color: var(--quick-access-icon, #fff);
    display: inline-flex;
    font-size: 18px;
    font-weight: 700;
    height: 44px;
    justify-content: center;
    padding: 0;
    text-decoration: none;
    width: 44px;
}

.quick-access a:hover {
    color: var(--quick-access-icon, #fff);
    opacity: .9;
}

.quick-access-admin-list {
    display: grid;
    gap: 12px;
}

.quick-access-admin-row {
    align-items: end;
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: 34px minmax(120px, 1fr) minmax(120px, .8fr) minmax(180px, 1.3fr) minmax(150px, 1fr) auto auto;
    padding: 12px;
}

.quick-access-admin-row-new {
    grid-template-columns: repeat(4, minmax(160px, 1fr));
}

.quick-access-active-check {
    align-self: center;
    white-space: nowrap;
}

@media (max-width: 980px) {
    .quick-access-admin-row,
    .quick-access-admin-row-new {
        grid-template-columns: 1fr;
    }
}

.auth-page {
    display: grid;
    min-height: 100vh;
    place-items: center;
    padding: 18px;
}

.login-card {
    max-width: 420px;
    width: 100%;
}

.form {
    display: grid;
    gap: 14px;
}

label {
    color: var(--muted);
    display: grid;
    gap: 6px;
    font-size: 14px;
}

input {
    border: 1px solid var(--line);
    border-radius: 6px;
    font: inherit;
    padding: 10px 12px;
}

select {
    border: 1px solid var(--line);
    border-radius: 6px;
    font: inherit;
    padding: 10px 12px;
}

textarea {
    border: 1px solid var(--line);
    border-radius: 6px;
    font: inherit;
    min-height: 110px;
    padding: 10px 12px;
    resize: vertical;
}

.rich-editor {
    background: #ffffff;
    border: 1px solid #d8e1ef;
    border-radius: 8px;
    box-shadow: 0 12px 28px rgba(24, 33, 47, 0.05);
    overflow: hidden;
}

.rich-editor-toolbar {
    align-items: center;
    background: #f8fafc;
    border-bottom: 1px solid #d8e1ef;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px;
}

.editor-tool-group {
    align-items: center;
    background: #ffffff;
    border: 1px solid #d8e1ef;
    border-radius: 8px;
    display: inline-flex;
    gap: 2px;
    padding: 3px;
}

.editor-format {
    background: transparent;
    border: 0;
    color: #314158;
    min-height: 34px;
    padding: 5px 8px;
}

.editor-tool {
    background: transparent;
    border: 0;
    border-radius: 6px;
    color: #314158;
    font-size: 13px;
    font-weight: 800;
    min-height: 34px;
    min-width: 36px;
    padding: 6px 10px;
}

.editor-tool:hover,
.editor-tool:focus-visible {
    background: #e8f3f1;
    color: var(--brand);
}

.rich-editor-surface {
    background: #ffffff;
    color: var(--ink);
    min-height: 280px;
    outline: none;
    padding: 18px;
}

.rich-editor-surface:empty::before {
    color: #98a2b3;
    content: "\0130\00E7eri\011Fi buraya yaz\0131n";
}

.rich-editor-surface:focus {
    box-shadow: inset 0 0 0 2px rgba(20, 108, 95, 0.16);
}

.rich-editor-surface img,
.page-content img {
    border-radius: 8px;
    display: block;
    height: auto;
    margin: 14px 0;
    max-width: 100%;
}

.rich-editor-source {
    display: none !important;
}

.editor-picker-panel {
    background: #ffffff;
    border-top: 1px solid #d8e1ef;
    padding: 12px;
}

.editor-picker-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.editor-picker-header strong {
    font-size: 15px;
}

.editor-picker-header span {
    color: var(--muted);
    font-size: 13px;
}

.editor-media-grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    max-height: 320px;
    overflow: auto;
}

.editor-media-item {
    background: #ffffff;
    border: 1px solid #d8e1ef;
    border-radius: 8px;
    color: #314158;
    display: grid;
    gap: 8px;
    min-height: 130px;
    padding: 8px;
    text-align: left;
}

.editor-media-item:hover {
    border-color: var(--brand);
    box-shadow: 0 10px 22px rgba(20, 108, 95, 0.1);
}

.editor-media-item img {
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    object-fit: cover;
    width: 100%;
}

.editor-media-item span {
    color: var(--muted);
    font-size: 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.editor-link-list {
    border: 1px solid #d8e1ef;
    border-radius: 8px;
    display: grid;
    max-height: 260px;
    overflow: auto;
}

.editor-link-item {
    background: #ffffff;
    border: 0;
    border-bottom: 1px solid #edf1f7;
    border-radius: 0;
    color: var(--ink);
    display: grid;
    gap: 3px;
    justify-content: stretch;
    min-height: auto;
    padding: 10px 12px;
    text-align: left;
}

.editor-link-item:hover {
    background: #f2f8f7;
    color: var(--brand);
}

.editor-link-item small {
    color: var(--muted);
}

.editor-custom-link {
    display: grid;
    gap: 8px;
    grid-template-columns: minmax(0, 1fr) auto;
    margin-top: 10px;
}

.alert {
    background: #fff1f0;
    border: 1px solid #f4b8b2;
    border-radius: 6px;
    color: var(--danger);
    margin-bottom: 16px;
    padding: 10px 12px;
}

.notice {
    background: #ecfdf3;
    border: 1px solid #abefc6;
    border-radius: 6px;
    color: #067647;
    margin-bottom: 16px;
    padding: 10px 12px;
}

.admin-page {
    background: #f3f6fb;
    display: grid;
    grid-template-columns: 286px 1fr;
    min-height: 100vh;
}

.admin-sidebar {
    background: #ffffff;
    border-right: 1px solid #e7ebf3;
    box-shadow: 14px 0 34px rgba(24, 33, 47, 0.05);
    color: var(--ink);
    max-height: 100vh;
    overflow-y: auto;
    padding: 24px 18px;
    position: sticky;
    top: 0;
}

.admin-sidebar nav {
    display: grid;
    gap: 6px;
    margin-top: 24px;
}

.admin-sidebar a {
    align-items: center;
    border-radius: 8px;
    color: #50627c;
    display: flex;
    font-size: 14px;
    min-height: 40px;
    padding: 9px 12px;
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.admin-sidebar a.active,
.admin-sidebar a:hover {
    background: #eef5ff;
    color: #2357a4;
    transform: translateX(2px);
}

.admin-main {
    max-width: 1280px;
    padding: 32px;
    width: 100%;
}

.admin-logo {
    color: #202a3a;
    font-size: 22px;
    padding: 0 8px 18px;
}

.admin-user-card {
    align-items: center;
    border-bottom: 1px solid #eef1f6;
    border-top: 1px solid #eef1f6;
    display: grid;
    gap: 6px;
    justify-items: center;
    padding: 22px 8px;
    text-align: center;
}

.admin-avatar {
    align-items: center;
    background: linear-gradient(135deg, #eef5ff, #f7ecff);
    border: 1px solid #dfe7f3;
    border-radius: 999px;
    color: #2357a4;
    display: inline-flex;
    font-size: 24px;
    font-weight: 800;
    height: 72px;
    justify-content: center;
    width: 72px;
}

.admin-user-card span {
    color: var(--muted);
    font-size: 13px;
}

.admin-header {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}

.admin-header h1 {
    font-size: 30px;
    line-height: 1.15;
    margin-bottom: 0;
}

.role-badge {
    background: #e5f4ef;
    border-radius: 999px;
    color: var(--brand);
    font-size: 13px;
    font-weight: 700;
    padding: 7px 10px;
}

.module-list {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}

.settings-form {
    display: grid;
    gap: 18px;
    max-width: 100%;
    overflow: hidden;
}

.form-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.map-contact-form-wide {
    grid-column: 1 / -1;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
}

.module-row {
    align-items: center;
    display: flex;
    gap: 14px;
    justify-content: space-between;
    padding: 16px 18px;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.module-row.is-sortable {
    cursor: grab;
}

.module-row.is-sortable,
.module-row.is-sortable * {
    cursor: grab;
}

.module-row.is-sortable:active,
.module-row.is-sortable:active * {
    cursor: grabbing;
}

.module-row.is-dragging {
    background: #ffffff;
    border-color: var(--brand);
    box-shadow: 0 18px 34px rgba(20, 108, 95, 0.16);
    color: var(--ink);
    opacity: 0.96;
}

.module-row.is-locked {
    background: #f8fafc;
}

.module-row-copy {
    flex: 1;
    min-width: 0;
}

.drag-handle {
    align-items: center;
    background: #eef2f7;
    border: 1px solid #d7dfeb;
    border-radius: 6px;
    color: #50627c;
    cursor: grab;
    display: inline-flex;
    flex: 0 0 40px;
    height: 40px;
    justify-content: center;
    padding: 0;
    width: 40px;
}

.drag-handle:hover,
.module-row.is-dragging .drag-handle {
    background: var(--brand);
    border-color: var(--brand);
    color: #ffffff;
}

.drag-handle:disabled {
    cursor: not-allowed;
    opacity: 0.45;
}

.module-row:hover {
    border-color: #b9c7da;
    box-shadow: 0 12px 28px rgba(24, 33, 47, 0.06);
    transform: translateY(-1px);
}

.toggle-row {
    align-items: center;
    color: var(--muted);
    display: inline-flex;
    flex-direction: row;
    font-weight: 700;
    gap: 10px;
}

.toggle-row input {
    accent-color: var(--brand);
    height: 18px;
    width: 18px;
}

.sticky-actions {
    background: linear-gradient(180deg, rgba(245, 247, 251, 0), var(--soft) 32%);
    bottom: 0;
    display: flex;
    justify-content: flex-end;
    margin: 8px -22px -22px;
    padding: 22px;
    position: sticky;
}

.module-row span {
    color: var(--muted);
    display: block;
    font-size: 13px;
}

.status.locked {
    background: #eef2f7;
    border-radius: 999px;
    color: var(--muted);
    display: inline-flex;
    font-weight: 700;
    padding: 7px 10px;
}

button.small {
    min-height: 40px;
    padding: 9px 13px;
}

button.danger {
    background: var(--danger);
    border-color: var(--danger);
}

.row-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.button.small {
    min-height: 40px;
    padding: 9px 13px;
}

.button.secondary {
    background: #ffffff;
    color: var(--brand);
}

.admin-panel {
    box-shadow: 0 16px 36px rgba(24, 33, 47, 0.06);
}

.admin-panel > p {
    color: var(--muted);
}

.row-actions .button,
.row-actions button {
    min-width: 74px;
}

.theme-preview {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 18px;
}

.theme-preview span {
    background: linear-gradient(90deg, var(--brand), var(--accent));
    border-radius: 999px;
    display: block;
    height: 10px;
    width: min(280px, 100%);
}

.theme-preview p {
    color: var(--muted);
    margin-bottom: 0;
}

.settings-overview {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.settings-card {
    background: #ffffff;
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--text);
    display: grid;
    gap: 10px;
    min-height: 154px;
    padding: 18px;
    text-decoration: none;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.settings-card:hover {
    border-color: color-mix(in srgb, var(--brand) 36%, var(--line));
    box-shadow: 0 18px 32px rgba(20, 108, 95, 0.12);
    transform: translateY(-1px);
}

.settings-card span {
    color: var(--brand);
    font-size: 13px;
    font-weight: 800;
}

.settings-card strong {
    font-size: 16px;
    line-height: 1.3;
}

.settings-card small {
    color: var(--muted);
    line-height: 1.5;
}

.check-row {
    align-items: center;
    display: flex;
    gap: 8px;
    justify-content: flex-start;
}

.check-row input {
    flex: 0 0 auto;
    width: auto;
}

.inline-checks {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
}

.content-page {
    max-width: 920px;
}

.page-cover-image {
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    display: block;
    margin: 22px 0;
    object-fit: cover;
    width: 100%;
}

.page-content {
    color: var(--ink);
    font-size: 16px;
    white-space: normal;
}

.page-content.compact {
    font-size: 16px;
}

.page-content :is(h2, h3) {
    margin-bottom: 10px;
}

.page-content :is(ul, ol) {
    padding-left: 22px;
}

.project-meta {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    margin: 24px 0;
}

.project-meta div {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 14px 14px 12px;
}

.project-meta dt {
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
}

.project-meta dd {
    margin: 4px 0 0;
}

.detail-list dl {
    display: grid;
    gap: 14px;
    margin: 0;
}

.detail-list dt {
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
}

.detail-list dd {
    margin: -8px 0 6px;
}

.metric-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}

.metric-card {
    background: #f8fafc;
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 6px;
    padding: 16px;
}

.metric-card span,
.muted-copy {
    color: var(--muted);
}

.metric-card strong {
    font-size: 28px;
    line-height: 1.1;
}

.table-scroll {
    overflow-x: auto;
    width: 100%;
}

.admin-table {
    border-collapse: collapse;
    min-width: 720px;
    width: 100%;
}

.admin-table th,
.admin-table td {
    border-bottom: 1px solid var(--line);
    padding: 12px 10px;
    text-align: left;
    vertical-align: top;
}

.admin-table th {
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.status-badge {
    background: #eef2f7;
    border-radius: 999px;
    color: #50627c;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    padding: 5px 9px;
    white-space: nowrap;
}

.status-badge.is-success {
    background: #e5f4ef;
    color: #067647;
}

.status-badge.is-warning {
    background: #fff7e6;
    color: #946200;
}

.status-badge.is-danger {
    background: #fff1f0;
    color: var(--danger);
}

.log-viewer {
    background: #101828;
    border-radius: 8px;
    color: #e5edf8;
    font-size: 13px;
    line-height: 1.6;
    max-height: 420px;
    overflow: auto;
    padding: 16px;
    white-space: pre-wrap;
}

.domain-migration-form {
    margin-top: 18px;
}

.migration-preview {
    border-top: 1px solid var(--line);
    display: grid;
    gap: 14px;
    margin-top: 8px;
    padding-top: 18px;
}

.ck.ck-editor {
    border: 1px solid #cfd7e3;
    border-radius: 2px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
    max-width: 100%;
    overflow: hidden;
    width: 100%;
}

.ck.ck-editor__main > .ck-editor__editable,
.ck.ck-editor__main > .ck-editor__editable_inline {
    border: 0;
    border-top: 1px solid #d8dee8;
    min-height: 520px !important;
    padding: 18px 22px !important;
}

.ck.ck-toolbar {
    background: #f7f8fa;
    border: 0;
    border-radius: 0;
    border-bottom: 1px solid #d8dee8;
    flex-wrap: wrap !important;
    gap: 2px 4px !important;
    padding: 6px 8px !important;
}

.ck.ck-toolbar > .ck-toolbar__items {
    flex-wrap: wrap !important;
    gap: 2px 4px !important;
    min-width: 0;
}

.ck.ck-toolbar .ck.ck-button,
.ck.ck-toolbar .ck.ck-dropdown__button {
    border-radius: 2px;
    min-height: 30px;
}

.ck.ck-toolbar .ck-button_with-text {
    padding-inline: 8px;
}

.ck.ck-toolbar .ck-button__label {
    font-size: 13px;
}

.ck.ck-toolbar .ck.ck-dropdown {
    max-width: 185px;
}

.ck.ck-toolbar .ck-dropdown__button .ck-button__label {
    overflow: hidden;
    text-overflow: ellipsis;
}

.ck.ck-editor__main > .ck-editor__editable:not(.ck-focused) {
    border-color: #d8dee8;
}

.ck.ck-editor__main > .ck-editor__editable.ck-focused {
    border-color: #d8dee8;
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--brand) 34%, transparent);
}

.ck-content h2,
.ck-content h3,
.ck-content h4 {
    color: var(--ink);
    line-height: 1.25;
}

.ck-content img {
    height: auto;
    max-width: 100%;
}

.ck-content blockquote {
    background: #f8fafc;
    border-left: 4px solid #50627c;
    margin: 18px 0;
    padding: 14px 18px;
}

.ck-content blockquote[data-box="info"],
.page-content blockquote[data-box="info"] {
    background: #eef5ff;
    border-left-color: #2357a4;
}

.ck-content blockquote[data-box="warning"],
.page-content blockquote[data-box="warning"] {
    background: #fff7e6;
    border-left-color: #946200;
}

.ck-content blockquote[data-box="success"],
.page-content blockquote[data-box="success"] {
    background: #e5f4ef;
    border-left-color: #067647;
}

.ck-content blockquote[data-box="danger"],
.page-content blockquote[data-box="danger"] {
    background: #fff1f0;
    border-left-color: #b42318;
}

.ck-content blockquote[data-box="cta"],
.page-content blockquote[data-box="cta"] {
    background: #f8fafc;
    border-left-color: var(--brand);
}

.page-content blockquote {
    background: #f8fafc;
    border-left: 4px solid #50627c;
    margin: 18px 0;
    padding: 14px 18px;
}

.ck-content table {
    border-collapse: collapse;
    width: 100%;
}

.ck-content table td,
.ck-content table th {
    border: 1px solid #cfd7e3;
    padding: 10px;
    vertical-align: top;
}

.ck-source-editing-area textarea {
    color: #111827;
    font-family: Consolas, Monaco, "Courier New", monospace;
    font-size: 14px;
    min-height: 520px !important;
    line-height: 1.6;
}

.ckeditor-picker-backdrop {
    align-items: center;
    background: rgba(15, 23, 42, 0.44);
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 18px;
    position: fixed;
    z-index: 9999;
}

.ckeditor-picker {
    background: #ffffff;
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.26);
    display: flex;
    flex-direction: column;
    max-height: min(720px, calc(100vh - 36px));
    max-width: 820px;
    overflow: hidden;
    width: 100%;
}

.ckeditor-picker-header {
    align-items: center;
    border-bottom: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    padding: 16px 18px;
}

.ckeditor-picker-header strong {
    display: block;
    font-size: 17px;
}

.ckeditor-picker-header span {
    color: var(--muted);
    display: block;
    font-size: 13px;
    margin-top: 2px;
}

.ckeditor-picker-header button {
    align-items: center;
    background: #f3f6fa;
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--ink);
    cursor: pointer;
    display: inline-flex;
    font-size: 22px;
    height: 38px;
    justify-content: center;
    line-height: 1;
    width: 38px;
}

.ckeditor-picker-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: scroll;
    padding: 18px;
    scrollbar-gutter: stable;
}

.ckeditor-picker-title {
    font-size: 15px;
    margin: 18px 0 10px;
}

.ckeditor-upload-form {
    background: #f8fafc;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    grid-template-columns: minmax(240px, 1fr) minmax(180px, .75fr) auto;
    padding: 14px 14px 12px;
}

.ckeditor-upload-form strong,
.ckeditor-upload-form span,
.ckeditor-upload-message {
    display: block;
}

.ckeditor-upload-form span,
.ckeditor-upload-message {
    color: var(--muted);
    font-size: 13px;
    margin: 4px 0 0;
}

.ckeditor-upload-form input {
    min-width: 0;
}

.ckeditor-upload-form button {
    align-self: stretch;
    white-space: nowrap;
}

.ckeditor-upload-message {
    grid-column: 1 / -1;
}

.ckeditor-media-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
}

.ckeditor-media-item,
.ckeditor-link-item {
    background: #ffffff;
    border: 1px solid var(--line);
    border-radius: 8px;
    color: var(--ink);
    cursor: pointer;
    text-align: left;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.ckeditor-media-item:hover,
.ckeditor-link-item:hover {
    border-color: var(--brand);
    box-shadow: 0 14px 28px rgba(20, 108, 95, 0.14);
    transform: translateY(-1px);
}

.ckeditor-media-item img {
    aspect-ratio: 4 / 3;
    background: #f4f7fb;
    border-radius: 7px 7px 0 0;
    display: block;
    object-fit: cover;
    width: 100%;
}

.ckeditor-media-item span,
.ckeditor-link-item span {
    display: block;
    font-size: 13px;
    font-weight: 800;
    overflow: hidden;
    padding: 10px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ckeditor-link-list {
    display: grid;
    gap: 10px;
}

.ckeditor-link-item {
    padding: 12px 14px;
}

.ckeditor-link-item span {
    padding: 0;
}

.ckeditor-link-item small {
    color: var(--muted);
    display: block;
    margin-top: 4px;
}

.ckeditor-custom-link {
    border-top: 1px solid var(--line);
    display: grid;
    gap: 10px;
    grid-template-columns: 1fr auto;
    margin-top: 16px;
    padding-top: 16px;
}

@media (max-width: 1200px) {
    .media-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .media-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .site-header,
    .site-nav,
    .topbar,
    .topbar-inner,
    .site-header-inner,
    .topbar-links,
    .admin-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .announcement-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .footer-grid {
        grid-template-columns: 1fr;
    }

    .lead-section {
        grid-template-columns: 1fr;
    }

    .about-section {
        grid-template-columns: 1fr;
    }

    .map-contact-section {
        grid-template-columns: 1fr;
    }

    .admin-page {
        grid-template-columns: 1fr;
    }

    .media-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .ckeditor-custom-link {
        grid-template-columns: 1fr;
    }

    .ckeditor-upload-form {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 520px) {
    .media-grid {
        grid-template-columns: 1fr;
    }
}

.project-slides-list {
    display: grid;
    gap: 12px;
}

.project-slide-item {
    align-items: center;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    cursor: grab;
    display: grid;
    gap: 14px;
    grid-template-columns: 120px minmax(0, 1fr) auto;
    padding: 12px;
}

.project-slide-item.is-dragging {
    cursor: grabbing;
    opacity: .65;
}

.project-slide-item img {
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    object-fit: cover;
    width: 100%;
}

.project-slide-item .drag-handle {
    align-items: center;
    background: #eef4ff;
    border: 1px solid #c9d8f6;
    border-radius: 999px;
    color: #1d4f91;
    display: flex;
    font-weight: 800;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.project-slider {
    display: grid;
    gap: 12px;
    margin: 24px 0;
}

.project-slider figure {
    margin: 0;
}

.project-slider img {
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    display: block;
    object-fit: cover;
    width: 100%;
}

.project-slider figure:not(:first-child) img {
    aspect-ratio: 4 / 3;
}

@media (min-width: 760px) {
    .project-slider {
        grid-template-columns: repeat(3, 1fr);
    }

    .project-slider figure:first-child {
        grid-column: 1 / -1;
    }
}

@media (max-width: 640px) {
    .project-slide-item {
        grid-template-columns: 1fr;
    }

    .project-slide-item .drag-handle {
        justify-self: start;
    }
}
.project-slider {
    margin: 24px 0;
}

.project-slider-viewport {
    border-radius: 8px;
    overflow: hidden;
}

.project-slider-track {
    display: flex;
    transition: transform .28s ease;
    will-change: transform;
}

.project-slider-track figure {
    flex: 0 0 100%;
    margin: 0;
}

.project-slider-track img {
    aspect-ratio: 16 / 9;
    display: block;
    object-fit: cover;
    width: 100%;
}

.project-slider-controls {
    align-items: center;
    display: flex;
    gap: 10px;
    justify-content: center;
    margin-top: 12px;
}

.project-slider-controls button {
    align-items: center;
    background: var(--brand);
    border: 0;
    border-radius: 999px;
    color: #fff;
    cursor: pointer;
    display: flex;
    font-size: 24px;
    height: 38px;
    justify-content: center;
    line-height: 1;
    width: 38px;
}

.project-slider-controls span {
    color: var(--muted);
    font-size: 14px;
    font-weight: 700;
    min-width: 54px;
    text-align: center;
}
.sidebar-group {
    display: grid;
    gap: 6px;
}

.sidebar-group summary {
    align-items: center;
    border-radius: 8px;
    color: #50627c;
    cursor: pointer;
    display: flex;
    font-size: 14px;
    font-weight: 700;
    justify-content: space-between;
    list-style: none;
    min-height: 40px;
    padding: 9px 12px;
}

.sidebar-group summary::-webkit-details-marker {
    display: none;
}

.sidebar-group summary::after {
    content: "\203A";
    font-size: 16px;
    transform: rotate(90deg);
    transition: transform .18s ease;
}

.sidebar-group[open] summary {
    background: #f6f9fe;
    color: #2357a4;
}

.sidebar-group[open] summary::after {
    transform: rotate(270deg);
}

.sidebar-submenu {
    border-left: 1px solid #dbe4f2;
    display: grid;
    gap: 4px;
    margin-left: 12px;
    padding-left: 8px;
}

.admin-sidebar .sidebar-submenu a {
    font-size: 13px;
    min-height: 34px;
    padding: 7px 10px;
}
/* Theme settings page */
.compact-header {
    margin-bottom: 14px;
}

.compact-header h1 {
    color: #152033;
    font-size: 24px;
    font-weight: 700;
    letter-spacing: 0;
}

.theme-settings-panel {
    max-width: 100%;
}

.theme-color-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.color-control {
    display: grid;
    gap: 8px;
}

.color-control input[type="color"] {
    appearance: none;
    background: #fff;
    border: 1px solid #cfd8e6;
    border-radius: 8px;
    cursor: pointer;
    height: 54px;
    padding: 5px;
    width: 96px;
}

.color-control input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

.color-control input[type="color"]::-webkit-color-swatch {
    border: 0;
    border-radius: 5px;
}

.color-control input[type="color"]::-moz-color-swatch {
    border: 0;
    border-radius: 5px;
}

.theme-preview {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 0;
    overflow: hidden;
    padding: 0;
}

.theme-preview-topbar {
    align-items: center;
    background: var(--brand);
    color: #fff;
    display: flex;
    font-size: 12px;
    justify-content: space-between;
    padding: 10px 16px;
}

.theme-preview-header {
    align-items: center;
    border-bottom: 1px solid #e5ebf4;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 16px;
}

.theme-preview-header strong {
    color: var(--brand);
    font-size: 16px;
}

.theme-preview-header nav {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.theme-preview-header nav span {
    background: #f3f6fb;
    border-radius: 999px;
    color: #50627c;
    font-size: 12px;
    padding: 6px 10px;
}

.theme-preview-body {
    display: grid;
    gap: 18px;
    grid-template-columns: minmax(0, 1.5fr) minmax(180px, .8fr);
    padding: 18px;
}

.theme-preview-body small {
    color: var(--accent);
    font-weight: 800;
    text-transform: uppercase;
}

.theme-preview-body h2 {
    color: #152033;
    font-size: 22px;
    margin: 8px 0;
}

.theme-preview-body p {
    color: #5b6b82;
    margin-bottom: 14px;
}

.theme-preview-body button {
    background: var(--brand);
    border: 0;
    border-radius: 7px;
    color: #fff;
    font-weight: 800;
    padding: 10px 16px;
}

.theme-preview-body aside {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    display: grid;
    gap: 8px;
    padding: 14px 14px 12px;
}

.theme-preview-body aside span {
    background: linear-gradient(90deg, var(--brand), var(--accent));
    border-radius: 999px;
    display: block;
    height: 8px;
    width: 100%;
}

.theme-preview-body aside p {
    background: color-mix(in srgb, var(--accent) 16%, #fff);
    border-radius: 999px;
    color: #7a4f09;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    margin: 0;
    padding: 6px 10px;
    width: max-content;
}

@media (max-width: 720px) {
    .site-popup {
        padding: 22px 10px;
    }

    .site-popup-dialog {
        max-height: calc(100vh - 44px);
        max-width: calc(100vw - 20px);
        padding-top: 14px;
    }

    .site-popup-image {
        max-height: 34vh;
        width: calc(100% - 28px);
    }

    .site-popup-content {
        padding: 22px;
    }

    .site-popup-content h2 {
        font-size: 22px;
    }

    .site-popup-button {
        width: 100%;
    }
}
/* Social settings page */
.social-settings-list {
    display: grid;
    gap: 12px;
}

.social-setting-row {
    align-items: center;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    display: grid;
    gap: 16px;
    grid-template-columns: 48px 190px minmax(320px, 1fr);
    padding: 14px 16px;
}

.social-setting-label strong,
.social-setting-label small {
    display: block;
}

.social-setting-label strong {
    color: var(--ink);
    font-weight: 800;
}

.social-setting-label small {
    color: var(--muted);
    font-size: 12px;
    margin-top: 2px;
}

.social-setting-row input {
    min-width: 0;
    width: 100%;
}

.social-brand-icon {
    align-items: center;
    background: var(--social-color);
    border-radius: 999px;
    color: #fff;
    display: flex;
    font-size: 20px;
    font-weight: 900;
    height: 44px;
    justify-content: center;
    line-height: 1;
    width: 44px;
}

.social-brand-icon .fa-brands {
    line-height: 1;
}

.social-setting-row:has([name="social_snapchat"]) .social-brand-icon {
    color: #111;
}

@media (max-width: 900px) {
    .social-setting-row {
        grid-template-columns: 48px minmax(0, 1fr);
    }

    .social-setting-row input {
        grid-column: 1 / -1;
    }
}

/* SEO settings page */
.seo-settings-form {
    gap: 22px;
}

.seo-settings-section {
    border-bottom: 1px solid var(--line);
    display: grid;
    gap: 14px;
    padding-bottom: 20px;
}

.seo-settings-section:last-of-type {
    border-bottom: 0;
    padding-bottom: 0;
}

.seo-settings-section h2 {
    color: var(--ink);
    font-size: 17px;
    font-weight: 800;
    margin: 0;
}

.field-help {
    color: var(--muted);
    display: block;
    font-size: 12px;
    line-height: 1.55;
    margin-top: 7px;
}
/* Site popup */
.site-popup[hidden] {
    display: none;
}

.site-popup {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 34px 16px;
    position: fixed;
    z-index: 1000;
}

.site-popup-backdrop {
    background: rgba(8, 17, 31, .58);
    inset: 0;
    position: absolute;
}

.site-popup-dialog {
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(8, 17, 31, .24);
    display: flex;
    flex-direction: column;
    max-height: calc(100vh - 68px);
    max-width: min(560px, calc(100vw - 32px));
    overflow: auto;
    padding-top: 22px;
    position: relative;
    width: 100%;
    z-index: 1;
}

.site-popup-close {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 999px;
    color: #0f172a;
    cursor: pointer;
    display: flex;
    font-size: 22px;
    height: 36px;
    justify-content: center;
    line-height: 1;
    position: absolute;
    right: 12px;
    top: 12px;
    width: 36px;
    z-index: 2;
}

.site-popup-image {
    aspect-ratio: 16 / 9;
    display: block;
    margin: 0 auto;
    max-height: min(38vh, 285px);
    object-fit: contain;
    width: calc(100% - 44px);
}

.site-popup-content {
    align-items: center;
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    gap: 14px;
    padding: 26px;
    text-align: center;
}

.site-popup-content h2 {
    color: #0f172a;
    font-size: 26px;
    line-height: 1.18;
    margin: 0;
}

.site-popup-content p {
    color: #516179;
    line-height: 1.65;
    margin: 0;
    max-width: 460px;
}

.site-popup-action {
    display: flex;
    justify-content: center;
    margin-top: auto;
    padding-top: 4px;
    width: 100%;
}

.site-popup-button {
    background: var(--brand, #146c5f);
    border: 0;
    border-radius: 8px;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    font: inherit;
    font-weight: 800;
    justify-content: center;
    padding: 12px 18px;
    text-decoration: none;
    width: max-content;
}

body.has-site-popup {
    overflow: hidden;
}

@media (max-width: 720px) {
    .site-popup {
        padding: 22px 10px;
    }

    .site-popup-dialog {
        max-height: calc(100vh - 44px);
        max-width: calc(100vw - 20px);
        padding-top: 14px;
    }

    .site-popup-image {
        max-height: 34vh;
        width: calc(100% - 28px);
    }

    .site-popup-content {
        padding: 22px;
    }

    .site-popup-content h2 {
        font-size: 22px;
    }

    .site-popup-button {
        width: 100%;
    }
}
/* Main module management */

.module-management-header {
    margin-bottom: 12px;
}

.module-management-header h1 {
    color: #07132f;
    font-size: 24px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.module-info-bar {
    align-items: center;
    background: var(--brand);
    border-radius: 6px;
    color: #fff;
    display: flex;
    font-size: 13px;
    justify-content: space-between;
    line-height: 1.35;
    min-height: var(--header-button-height, 42px);
    padding: 10px 14px;
}

.module-info-bar span {
    color: rgba(255, 255, 255, .65);
    font-size: 26px;
    font-weight: 300;
    line-height: 1;
}

.module-order-form {
    gap: 12px;
}

.module-order-list {
    gap: 14px;
    margin-top: 0;
}

.module-order-list .module-row {
    align-items: stretch;
    background: #fff;
    border: 1px solid #d9e2ef;
    border-radius: 8px;
    box-shadow: 0 12px 26px rgba(25, 42, 70, .06);
    display: grid;
    gap: 0;
    grid-template-columns: minmax(0, 1fr) auto;
    overflow: hidden;
    padding: 0;
    position: relative;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
    cursor: default;
}

.module-order-list .module-row::before {
    background: var(--brand);
    border-radius: 0 999px 999px 0;
    content: '';
    height: 18px;
    left: 0;
    position: absolute;
    top: 18px;
    width: 6px;
}

.module-row-main {
    align-items: center;
    display: flex;
    gap: 14px;
    min-height: 54px;
    padding: 12px 22px;
}

.module-order-list .module-row-copy strong {
    color: #07132f;
    display: block;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.module-row-description {
    border-top: 1px solid #e6edf6;
    color: #07132f;
    font-size: 14px;
    grid-column: 1 / -1;
    line-height: 1.45;
    padding: 16px 22px 18px 46px;
}

.module-order-list .drag-handle {
    background: transparent;
    border: 0;
    color: var(--brand);
    cursor: move;
    flex: 0 0 22px;
    height: 32px;
    opacity: .85;
    width: 22px;
}

.module-order-list .drag-handle:hover,
.module-order-list .module-row.is-dragging .drag-handle {
    background: transparent;
    color: var(--brand);
    cursor: move;
}

.module-switch {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    padding: 0 22px;
}

.module-switch input {
    height: 1px;
    opacity: 0;
    position: absolute;
    width: 1px;
}

.module-switch span {
    background: #c7ccd8;
    border-radius: 999px;
    box-shadow: inset 0 0 0 1px rgba(15, 23, 42, .06);
    display: block;
    height: 26px;
    position: relative;
    transition: background .18s ease;
    width: 66px;
}

.module-switch span::after {
    background: #fff;
    border-radius: 999px;
    box-shadow: 0 2px 8px rgba(15, 23, 42, .2);
    content: '';
    height: 22px;
    left: 2px;
    position: absolute;
    top: 2px;
    transition: transform .18s ease;
    width: 22px;
}

.module-switch input:checked + span {
    background: var(--brand);
}

.module-switch input:checked + span::after {
    transform: translateX(40px);
}

.module-switch em {
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px;
}

.module-order-list .status.locked {
    align-items: center;
    align-self: center;
    background: #eef3f8;
    border: 1px solid #dce6f1;
    border-radius: 4px;
    color: #516176;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    justify-content: center;
    line-height: 1;
    margin: 0 20px 0 0;
    min-height: 30px;
    min-width: 56px;
    padding: 0 12px;
}

.module-order-list .module-row.is-sortable,
.module-order-list .module-row.is-sortable * {
    cursor: move;
}

.module-order-list .module-row.is-dragging,
.module-order-list .module-row.is-dragging * {
    cursor: move;
}

.module-order-list .module-row.is-dragging,
.module-drag-preview {
    background: #ffffff;
    border-color: var(--brand);
    box-shadow: 0 22px 42px color-mix(in srgb, var(--brand) 24%, transparent);
    opacity: 1;
    transform: scale(1.01);
}
.module-save-actions {
    background: linear-gradient(180deg, rgba(245, 247, 251, 0), var(--soft) 32%);
}

@media (max-width: 760px) {
    .module-order-list .module-row {
        grid-template-columns: minmax(0, 1fr);
    }

    .module-switch {
        justify-content: flex-start;
        padding: 0 22px 12px 46px;
    }

    .module-row-description {
        padding-left: 24px;
    }
}


/* Standard admin sidebar menu */
.standard-sidebar-nav {
    display: grid;
    gap: 8px;
    margin-top: 24px;
}

.admin-sidebar .sidebar-main-link,
.sidebar-group.standard-menu-group summary {
    align-items: center;
    background: #eef2f7;
    border-radius: 8px;
    color: #101828;
    display: grid;
    font-size: 14px;
    font-weight: 800;
    gap: 6px;
    grid-template-columns: 36px minmax(0, 1fr);
    line-height: 1.25;
    min-height: 46px;
    padding: 4px 12px 4px 4px;
    text-decoration: none;
    transition: background .18s ease, color .18s ease, transform .18s ease;
}

.sidebar-group.standard-menu-group summary {
    cursor: pointer;
    grid-template-columns: 36px minmax(0, 1fr) 20px;
    list-style: none;
}

.sidebar-group.standard-menu-group summary::after {
    content: none;
}

.sidebar-group.standard-menu-group summary::-webkit-details-marker {
    display: none;
}

.admin-sidebar .sidebar-main-link:hover,
.admin-sidebar .sidebar-main-link.active,
.sidebar-group.standard-menu-group summary:hover,
.sidebar-group.standard-menu-group[open] summary {
    background: #e9eef5;
    color: #101828;
    transform: translateX(0);
}

.admin-sidebar .sidebar-main-link .menu-icon,
.standard-menu-group .menu-icon {
    align-items: center;
    background: #fff;
    border: 1px solid #dde5f1;
    border-radius: 999px;
    box-shadow: 0 3px 10px rgba(30, 41, 59, .08);
    color: var(--brand);
    display: flex;
    height: 34px;
    justify-content: center;
    width: 34px;
}

.admin-sidebar .sidebar-main-link .menu-icon i,
.standard-menu-group .menu-icon i {
    font-size: 14px;
}

.standard-menu-group .menu-chevron {
    color: #7c6ff4;
    font-size: 16px;
    font-weight: 800;
    line-height: 1;
    text-align: center;
    transform: rotate(180deg);
    transition: transform .18s ease;
}

.sidebar-group.standard-menu-group[open] .menu-chevron {
    transform: rotate(0deg);
}

.standard-menu-group .sidebar-submenu {
    border-left: 0;
    display: grid;
    gap: 2px;
    margin-left: 0;
    padding: 8px 0 4px 30px;
}

.admin-sidebar .standard-menu-group .sidebar-submenu a {
    align-items: center;
    background: transparent;
    border-radius: 7px;
    color: #4d5d75;
    display: grid;
    font-size: 13px;
    gap: 10px;
    grid-template-columns: 14px minmax(0, 1fr);
    min-height: 32px;
    padding: 6px 10px 6px 0;
    text-decoration: none;
}

.admin-sidebar .standard-menu-group .sidebar-submenu a:hover,
.admin-sidebar .standard-menu-group .sidebar-submenu a.active {
    background: #e9eef8;
    color: #304f86;
    transform: translateX(0);
}

.standard-menu-group .submenu-icon {
    height: 12px;
    position: relative;
    width: 12px;
}

.standard-menu-group .submenu-icon::before,
.standard-menu-group .submenu-icon::after {
    background: #4d6b96;
    border-radius: 999px;
    content: '';
    height: 3px;
    position: absolute;
    width: 3px;
}

.standard-menu-group .submenu-icon::before {
    left: 2px;
    top: 3px;
}

.standard-menu-group .submenu-icon::after {
    left: 7px;
    top: 6px;
}
.sidebar-section-title {
    color: #7b8798;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .04em;
    margin: 12px 8px 4px;
    text-transform: uppercase;
}
/* Topbar manager */
.topbar-settings-form {
    gap: 16px;
}

.topbar-settings-panel {
    display: grid;
    gap: 16px;
}

.topbar-settings-heading {
    align-items: flex-start;
    display: flex;
    gap: 16px;
    justify-content: space-between;
}

.topbar-settings-heading h2 {
    font-size: 18px;
    margin: 0 0 4px;
}

.topbar-settings-heading p,
.topbar-config-copy small,
.topbar-social-row small {
    color: var(--muted);
    margin: 0;
}

.topbar-item-list,
.topbar-social-sort {
    display: grid;
    gap: 12px;
}

.topbar-config-row,
.topbar-social-row {
    align-items: center;
    background: #fff;
    border: 1px solid #d9e2ef;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    grid-template-columns: 34px minmax(0, 1fr) auto;
    padding: 12px;
}

.topbar-config-row.is-dragging,
.topbar-social-row.is-dragging {
    border-color: var(--brand);
    box-shadow: 0 18px 34px rgba(20, 108, 95, .14);
}

.topbar-config-copy {
    display: grid;
    gap: 6px;
}

.topbar-config-copy input {
    margin-top: 4px;
}

.topbar-device-switches {
    align-items: center;
    display: flex;
    gap: 10px;
}

.topbar-device-switches label {
    align-items: center;
    color: #50627c;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    gap: 6px;
    white-space: nowrap;
}

.topbar-device-switches input {
    accent-color: var(--brand);
    height: 18px;
    width: 18px;
}

.topbar-source-pill {
    background: #eef3f8;
    border-radius: 6px;
    color: #516176;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    padding: 7px 9px;
    width: max-content;
}

.topbar-social-row {
    grid-template-columns: 34px 28px minmax(0, 1fr) auto;
}

.topbar-social-row i {
    color: var(--brand);
    font-size: 18px;
    text-align: center;
}

.topbar-social-row:not(.is-filled) {
    opacity: .62;
}

@media (max-width: 760px) {
    .topbar.topbar-mobile-hidden,
    .topbar-mobile-off {
        display: none !important;
    }

    .topbar-inner {
        align-items: stretch;
        flex-direction: column;
        gap: 6px;
        padding-block: 8px;
    }

    .topbar-item,
    .topbar-social {
        justify-content: center;
        white-space: normal;
        width: 100%;
    }

    .topbar-settings-heading,
    .topbar-device-switches {
        align-items: flex-start;
        flex-direction: column;
    }

    .topbar-config-row,
    .topbar-social-row {
        grid-template-columns: 34px minmax(0, 1fr);
    }

    .topbar-config-row .topbar-device-switches,
    .topbar-social-row small {
        grid-column: 2;
    }
}

@media (min-width: 761px) {
    .topbar.topbar-desktop-hidden,
    .topbar-desktop-off {
        display: none !important;
    }
}
/* Topbar compact refinements 20260619 */
.topbar-item {
    gap: 7px;
}

.topbar-item > i {
    color: var(--brand);
    flex: 0 0 auto;
    font-size: .95em;
}

.topbar-item > span {
    min-width: 0;
}

.topbar-settings-form {
    font-size: 13px;
    gap: 12px;
}

.topbar-settings-panel {
    gap: 12px;
}

.topbar-settings-heading h2 {
    font-size: 16px;
    margin-bottom: 3px;
}

.topbar-settings-heading p,
.topbar-config-copy small,
.topbar-social-row small {
    font-size: 12px;
    line-height: 1.35;
}

.topbar-item-list,
.topbar-social-sort {
    gap: 8px;
}

.topbar-config-row,
.topbar-social-row {
    gap: 10px;
    padding: 10px 12px;
}

.topbar-config-copy {
    gap: 5px;
}

.topbar-config-copy strong,
.topbar-social-row strong {
    font-size: 14px;
}

.topbar-config-copy input {
    font-size: 13px;
    margin-top: 2px;
    min-height: 38px;
    padding: 8px 10px;
}

.topbar-device-switches label {
    font-size: 12px;
}

.topbar-device-switches input {
    height: 16px;
    width: 16px;
}

.topbar-source-pill {
    font-size: 12px;
    padding: 6px 8px;
}

.topbar-social-row {
    grid-template-columns: 30px 24px minmax(0, 1fr) auto;
    min-height: 46px;
    padding-block: 8px;
}

.topbar-social-row i {
    font-size: 16px;
}
/* Topbar card visual layout 20260619b */
.topbar-settings-form .topbar-item-list {
    gap: 10px;
}

.topbar-settings-form .topbar-config-row {
    align-items: center;
    background: #fff;
    border: 1px solid #d7e2f0;
    border-radius: 8px;
    box-shadow: none;
    display: grid;
    grid-template-columns: 34px minmax(260px, 1fr) auto;
    min-height: 94px;
    padding: 12px;
}

.topbar-settings-form .topbar-config-row .drag-handle {
    align-self: center;
    background: #f3f7fb;
    border: 1px solid #d4dfec;
    border-radius: 6px;
    color: var(--brand);
    cursor: grab;
    height: 40px;
    justify-self: center;
    min-width: 40px;
    width: 40px;
}

.topbar-settings-form .topbar-config-row .drag-handle span {
    display: block;
    font-size: 18px;
    line-height: 1;
    transform: rotate(90deg);
}

.topbar-settings-form .topbar-config-row .drag-handle:active {
    cursor: grabbing;
}

.topbar-settings-form .topbar-config-copy {
    align-self: stretch;
    display: grid;
    gap: 7px;
    grid-template-rows: auto auto minmax(38px, auto);
}

.topbar-settings-form .topbar-config-copy strong {
    color: #06152d;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.2;
}

.topbar-settings-form .topbar-config-copy small {
    color: #66758b;
    font-size: 12px;
    line-height: 1.35;
}

.topbar-settings-form .topbar-config-copy input {
    border: 1px solid #d5dfec;
    border-radius: 6px;
    font-size: 13px;
    min-height: 40px;
    padding: 8px 12px;
    width: min(920px, 100%);
}

.topbar-settings-form .topbar-source-pill {
    align-items: center;
    background: #f3f7fb;
    border: 1px solid #d8e2ee;
    border-radius: 6px;
    color: #526176;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    min-height: 36px;
    padding: 7px 10px;
    width: max-content;
}

.topbar-settings-form .topbar-device-switches {
    align-items: center;
    align-self: center;
    display: flex;
    flex-direction: row;
    gap: 12px;
    justify-content: flex-end;
    min-width: 160px;
}

.topbar-settings-form .topbar-device-switches label {
    align-items: center;
    color: #40516a;
    display: inline-flex;
    flex-direction: row;
    font-size: 12px;
    font-weight: 800;
    gap: 6px;
}

.topbar-settings-form .topbar-device-switches input {
    accent-color: var(--brand);
    height: 17px;
    width: 17px;
}

.topbar-settings-form .topbar-social-sort {
    gap: 8px;
}

.topbar-settings-form .topbar-social-row {
    border-radius: 8px;
    grid-template-columns: 30px 24px minmax(0, 1fr) auto;
    min-height: 44px;
    padding: 8px 12px;
}

.topbar-settings-form .topbar-social-row .drag-handle {
    height: 32px;
    min-width: 32px;
    width: 32px;
}

.topbar-settings-form .topbar-social-row i {
    font-size: 16px;
}

@media (max-width: 900px) {
    .topbar-settings-form .topbar-config-row {
        grid-template-columns: 34px minmax(0, 1fr);
    }

    .topbar-settings-form .topbar-device-switches {
        grid-column: 2;
        justify-content: flex-start;
        min-width: 0;
    }
}
/* Topbar final visual layout 20260619c */
.topbar-item > i {
    color: currentColor;
    opacity: .95;
}

.topbar-settings-form .topbar-config-row.is-inline-controls {
    display: block;
    min-height: 0;
    padding: 14px 14px 12px;
}

.topbar-settings-form .topbar-config-row.is-inline-controls .topbar-config-copy {
    display: grid;
    gap: 9px;
}

.topbar-settings-form .topbar-config-titleline {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.topbar-settings-form .topbar-config-titleline strong {
    color: #06152d;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.2;
}

.topbar-settings-form .topbar-config-titleline .topbar-device-switches {
    align-items: center;
    display: inline-flex;
    flex-direction: row;
    gap: 12px;
    justify-content: flex-start;
    min-width: 0;
}

.topbar-settings-form .topbar-config-titleline .topbar-device-switches label {
    align-items: center;
    color: #40516a;
    display: inline-flex;
    flex-direction: row;
    font-size: 12px;
    font-weight: 800;
    gap: 6px;
}

.topbar-settings-form .topbar-config-titleline .topbar-device-switches input {
    accent-color: var(--brand);
    height: 17px;
    width: 17px;
}

.topbar-settings-form .topbar-config-row.is-inline-controls small {
    color: #66758b;
    font-size: 12px;
    line-height: 1.35;
}

.topbar-settings-form .topbar-config-fieldline {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: 40px minmax(0, 1fr);
}

.topbar-settings-form .topbar-config-fieldline .drag-handle {
    background: #f3f7fb;
    border: 1px solid #d4dfec;
    border-radius: 6px;
    color: var(--brand);
    cursor: grab;
    height: 40px;
    min-width: 40px;
    width: 40px;
}

.topbar-settings-form .topbar-config-fieldline .drag-handle span {
    display: block;
    font-size: 18px;
    line-height: 1;
    transform: rotate(90deg);
}

.topbar-settings-form .topbar-config-fieldline input[type="text"] {
    border: 1px solid #d5dfec;
    border-radius: 6px;
    font-size: 14px;
    min-height: 46px;
    padding: 10px 12px;
    width: 100%;
}

.topbar-settings-form .topbar-config-fieldline .topbar-source-pill {
    align-items: center;
    background: #f3f7fb;
    border: 1px solid #d8e2ee;
    border-radius: 6px;
    color: #526176;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    min-height: 40px;
    padding: 8px 10px;
    width: max-content;
}

.topbar-settings-form input[type="color"] {
    appearance: none;
    background: transparent;
    border: 1px solid #ccd7e6;
    border-radius: 6px;
    cursor: pointer;
    height: 44px;
    padding: 4px;
    width: 72px;
}

.topbar-settings-form input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

.topbar-settings-form input[type="color"]::-webkit-color-swatch {
    border: 0;
    border-radius: 4px;
}

.topbar-settings-form input[type="color"]::-moz-color-swatch {
    border: 0;
    border-radius: 4px;
}

@media (max-width: 760px) {
    .topbar-settings-form .topbar-config-fieldline {
        grid-template-columns: 40px minmax(0, 1fr);
    }
}
/* Topbar icon alignment 20260619 */
.topbar-item,
.topbar-social a {
    align-items: center;
    line-height: 1;
}

.topbar-item > span {
    align-items: center;
    display: inline-flex;
    line-height: 1;
}

.topbar .fa-solid,
.topbar .fa-regular,
.topbar .fa-brands {
    align-items: center;
    display: inline-flex;
    height: 1em;
    justify-content: center;
    line-height: 1;
    vertical-align: middle;
    width: 1em;
}

.topbar .fa-solid::before,
.topbar .fa-regular::before,
.topbar .fa-brands::before {
    display: block;
    line-height: 1;
}
/* Header admin shell 20260619 */
.header-admin-panel {
    display: grid;
    gap: 16px;
}

.header-placeholder-grid,
.header-menu-builder {
    display: grid;
    gap: 22px;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
}

.header-placeholder-box {
    background: #f8fbfe;
    border: 1px dashed #cbd8e8;
    border-radius: 8px;
    display: grid;
    gap: 6px;
    min-height: 110px;
    padding: 16px;
}

.header-placeholder-box strong {
    color: #06152d;
}

.header-placeholder-box span {
    color: var(--muted);
    font-size: 13px;
}

.form-grid.single {
    grid-template-columns: 1fr;
}

.button-wide {
    background: var(--brand);
    border: 0;
    border-radius: 6px;
    color: #fff;
    font-weight: 800;
    min-height: var(--header-button-height, 42px);
    padding: 10px 16px;
}

.button-wide:disabled {
    cursor: not-allowed;
    opacity: .68;
}

.header-menu-preview {
    display: grid;
    gap: 5px;
}

.header-menu-preview .menu-row {
    align-items: center;
    background: linear-gradient(#fefefe, #ececec);
    border: 1px solid #c7cdd5;
    display: grid;
    font-size: 13px;
    gap: 8px;
    grid-template-columns: 28px minmax(0, 1fr) auto;
    min-height: 30px;
    padding: 3px 8px 3px 0;
}

.header-menu-preview .menu-row.child {
    margin-left: 30px;
}

.header-menu-preview .drag-handle {
    align-items: center;
    background: #c9c9c9;
    color: #fff;
    display: inline-flex;
    height: 28px;
    justify-content: center;
    width: 28px;
}

@media (max-width: 980px) {
    .header-placeholder-grid,
    .header-menu-builder {
        grid-template-columns: 1fr;
    }
}
/* Admin color fields 20260619 */
.settings-form input[type="color"],
.admin-panel input[type="color"] {
    appearance: none;
    background: #fff;
    border: 1px solid #ccd7e6;
    border-radius: 6px;
    cursor: pointer;
    height: 44px;
    min-width: 84px;
    padding: 5px;
    width: 84px;
}

.settings-form input[type="color"]::-webkit-color-swatch-wrapper,
.admin-panel input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

.settings-form input[type="color"]::-webkit-color-swatch,
.admin-panel input[type="color"]::-webkit-color-swatch {
    border: 0;
    border-radius: 4px;
}

.settings-form input[type="color"]::-moz-color-swatch,
.admin-panel input[type="color"]::-moz-color-swatch {
    border: 0;
    border-radius: 4px;
}
/* Header logo design 20260619 */
.site-header {
    background: var(--header-bg, var(--surface));
    color: var(--header-color, var(--ink));
    font-size: var(--header-font-size, 15px);
    font-weight: var(--header-font-weight, 600);
    height: var(--header-height, 72px);
}

.site-header-inner {
    height: var(--header-height, 72px);
}

.site-header .brand,
.site-header .site-nav a {
    color: inherit;
    font-size: inherit;
    font-weight: inherit;
}

.header-logo {
    display: block;
    height: auto;
    max-height: calc(var(--header-height, 72px) - 4px);
    max-width: 260px;
    object-fit: contain;
}

.header-logo-mobile {
    display: none;
}

.header-design-form {
    display: grid;
    gap: 18px;
}

.header-design-section {
    display: grid;
    gap: 14px;
}

@media (max-width: 760px) {
    .header-logo-desktop.has-mobile-logo {
        display: none;
    }

    .header-logo-mobile {
        display: block;
    }
}
/* Header height control 20260619 */
.site-header {
    box-sizing: border-box;
    overflow: visible;
}

.site-header-inner {
    box-sizing: border-box;
}
.media-preview[data-preview-mode="image-only"] {
    justify-content: flex-start;
}

.media-preview[data-preview-mode="image-only"] img {
    aspect-ratio: auto;
    max-height: 140px;
    max-width: 100%;
    object-fit: contain;
    width: auto;
}

/* Header design controls compact 20260619 */
.header-design-controls {
    align-items: start;
    gap: 16px;
    grid-template-columns: repeat(5, minmax(150px, 1fr));
}

.header-design-controls label {
    align-self: start;
    display: grid;
    gap: 8px;
    min-width: 0;
}

.header-design-controls input,
.header-design-controls select {
    min-height: 44px;
}

.header-design-controls input[type="color"] {
    height: 44px;
    min-height: 44px;
    min-width: 84px;
    width: 84px;
}

.header-design-help {
    max-width: 620px;
}

@media (max-width: 1180px) {
    .header-design-controls {
        grid-template-columns: repeat(3, minmax(160px, 1fr));
    }
}

@media (max-width: 760px) {
    .header-design-controls {
        grid-template-columns: 1fr;
    }
}




/* Header menu management 20260619 */
.header-menu-form [hidden] {
    display: none !important;
}

.split-actions {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.header-menu-row {
    align-items: center;
    background: #fff;
    border: 1px solid #dbe4ef;
    border-radius: 7px;
    display: grid;
    gap: 10px;
    grid-template-columns: 42px minmax(0, 1fr) auto auto;
    margin-bottom: 7px;
    padding: 8px 10px;
}

.header-menu-row.is-child {
    margin-left: 28px;
}

.header-menu-row.is-dragging {
    border-color: var(--brand);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .12);
    opacity: .96;
}

.header-menu-row-title {
    align-items: center;
    display: flex;
    gap: 9px;
    min-width: 0;
}

.header-menu-row-title strong {
    color: #07132f;
    font-size: 13px;
}

.header-menu-row-title small {
    color: #66758b;
    font-size: 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.header-menu-row-badges,
.header-menu-row-actions {
    align-items: center;
    display: inline-flex;
    gap: 7px;
}

.status-pill {
    background: #eef2f7;
    border-radius: 999px;
    color: #526176;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 8px;
}

.status-pill.is-on {
    background: color-mix(in srgb, var(--brand) 14%, #fff);
    color: var(--brand);
}

.icon-action {
    align-items: center;
    background: #f7fafc;
    border: 1px solid #d9e3ef;
    border-radius: 6px;
    color: #07132f;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    width: 32px;
}

.icon-action.danger {
    color: #b42318;
}

.header-menu-row-actions form {
    margin: 0;
}

.site-nav {
    align-items: center;
    display: flex;
    gap: 22px;
}

.site-nav-item {
    position: relative;
}

.site-nav-item > a {
    align-items: center;
    display: inline-flex;
    min-height: 36px;
}

.site-submenu {
    background: #fff;
    border: 1px solid #e3e8f0;
    border-radius: 8px;
    box-shadow: 0 18px 40px rgba(15, 23, 42, .12);
    display: none;
    left: 0;
    min-width: 210px;
    padding: 8px;
    position: absolute;
    top: 100%;
    z-index: 30;
}

.site-submenu a {
    border-radius: 6px;
    display: block;
    padding: 9px 10px;
    white-space: nowrap;
}

.site-nav-item:hover .site-submenu,
.site-nav-item:focus-within .site-submenu {
    display: block;
}

@media (max-width: 900px) {
    .header-menu-row {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .header-menu-row-badges,
    .header-menu-row-actions {
        grid-column: 2;
        justify-content: flex-start;
    }
}

/* Header menu page polish 20260619 */
.header-menu-builder {
    align-items: start;
    gap: 24px;
    grid-template-columns: minmax(360px, .92fr) minmax(520px, 1.35fr);
}

.header-menu-builder .admin-panel {
    overflow: hidden;
    padding: 0;
}

.header-menu-builder .topbar-settings-heading {
    border-bottom: 1px solid #e3e9f2;
    margin: 0;
    padding: 18px 22px;
    position: relative;
}

.header-menu-builder .topbar-settings-heading::before {
    background: var(--brand);
    border-radius: 0 4px 4px 0;
    content: "";
    height: 20px;
    left: 0;
    position: absolute;
    top: 22px;
    width: 5px;
}

.header-menu-builder .topbar-settings-heading h2 {
    font-size: 16px;
    line-height: 1.25;
    margin: 0;
}

.header-menu-builder .topbar-settings-heading p {
    color: #66758b;
    font-size: 12px;
    margin: 7px 0 0;
}

.header-menu-form,
.header-menu-builder form:not(.header-menu-form) {
    padding: 20px 22px 22px;
}

.header-menu-form {
    gap: 14px;
}

.header-menu-form label {
    gap: 7px;
}

.header-menu-form input,
.header-menu-form select {
    min-height: 40px;
}

.header-menu-form .checkbox-row {
    align-items: center;
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.header-menu-form .checkbox-row label {
    align-items: center;
    display: inline-flex;
    gap: 8px;
}

.header-menu-preview {
    display: grid;
    gap: 5px;
    margin-bottom: 18px;
}

.header-menu-row {
    align-items: center;
    background: linear-gradient(#fbfbfb, #eeeeee);
    border: 1px solid #c8cfd8;
    border-radius: 2px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.78);
    display: grid;
    gap: 8px;
    grid-template-columns: 28px minmax(0, 1fr) auto auto;
    margin: 0;
    min-height: 28px;
    padding: 0 7px 0 0;
}

.header-menu-row.is-child {
    margin-left: 30px;
}

.header-menu-row .drag-handle {
    background: linear-gradient(#cfd2d6, #aeb4bb);
    border: 1px solid #aeb5bd;
    border-radius: 2px;
    color: #fff;
    flex: 0 0 28px;
    height: 28px;
    width: 28px;
}

.header-menu-row-title {
    align-items: center;
    color: #111827;
    display: flex;
    gap: 5px;
    min-width: 0;
}

.header-menu-row-title i {
    color: #07132f;
    font-size: 12px;
    width: 14px;
}

.header-menu-row-title strong {
    color: #0b1225;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

.header-menu-row-title small {
    color: #0b1225;
    font-size: 12px;
    line-height: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.header-menu-row-badges {
    align-items: center;
    display: inline-flex;
    gap: 5px;
}

.header-menu-row-badges .status-pill {
    background: transparent;
    border-radius: 0;
    color: #0b1225;
    font-size: 12px;
    font-weight: 500;
    padding: 0;
}

.header-menu-row-badges .status-pill:not(.is-on) {
    color: #66758b;
}

.header-menu-row-actions {
    align-items: center;
    display: inline-flex;
    gap: 6px;
}

.header-menu-row-actions form {
    align-items: center;
    display: inline-flex;
    margin: 0;
}

.header-menu-row-actions .icon-action,
.header-menu-row-actions button.icon-action {
    appearance: none;
    background: transparent;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    color: #07132f;
    cursor: pointer;
    display: inline-flex;
    font-size: 12px;
    height: 22px;
    line-height: 1;
    min-height: 0;
    padding: 0;
    text-decoration: none;
    width: 18px;
}

.header-menu-row-actions .icon-action.danger,
.header-menu-row-actions button.icon-action.danger {
    color: #07132f;
}

.header-menu-row-actions .icon-action:hover,
.header-menu-row-actions button.icon-action:hover {
    color: var(--brand);
}

.header-menu-row-actions .icon-action.danger:hover,
.header-menu-row-actions button.icon-action.danger:hover {
    color: #b42318;
}

.header-menu-builder .button-wide {
    border-radius: 5px;
    min-height: var(--header-button-height, 42px);
}

@media (max-width: 1180px) {
    .header-menu-builder {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .header-menu-row {
        grid-template-columns: 28px minmax(0, 1fr) auto;
    }

    .header-menu-row-badges {
        display: none;
    }

    .header-menu-row.is-child {
        margin-left: 18px;
    }
}

/* Header menu drag icon fixes 20260619 */
.header-icon-picker {
    align-items: center;
    display: grid;
    gap: 0;
    grid-template-columns: 42px minmax(0, 1fr);
}

.header-icon-preview {
    align-items: center;
    background: #f3f6fa;
    border: 1px solid #cdd8e6;
    border-right: 0;
    border-radius: 6px 0 0 6px;
    color: #07132f;
    display: inline-flex;
    height: 40px;
    justify-content: center;
}

.header-icon-picker select {
    border-radius: 0 6px 6px 0;
    min-height: 40px;
}

.header-menu-preview {
    align-items: stretch;
}

.header-menu-row {
    box-sizing: border-box;
    width: 100%;
}

.header-menu-row.is-child {
    margin-left: 30px;
    width: calc(100% - 30px);
}

.header-menu-row.is-dragging {
    cursor: grabbing;
}

.header-menu-row.is-child .drag-handle {
    background: linear-gradient(#d9dcdf, #b8bec5);
}

.header-menu-preview::after {
    color: #66758b;
    content: "Alt menü yapmak için satırı sürüklerken biraz sağa çekin; ana menü yapmak için sola hizalayın.";
    display: block;
    font-size: 12px;
    margin-top: 8px;
}

/* Public header menu icons 20260619 */
.site-nav-item > a,
.site-submenu a {
    align-items: center;
    display: inline-flex;
    gap: 7px;
}

.site-nav-item > a i,
.site-submenu a i {
    color: currentColor;
    font-size: .9em;
    line-height: 1;
}

/* Public submenu chevron 20260619 */
.site-nav-item.has-submenu > a::after {
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid currentColor;
    content: "";
    display: inline-block;
    margin-left: 2px;
    transform: translateY(1px);
}

.site-nav-item.has-submenu:hover > a::after,
.site-nav-item.has-submenu:focus-within > a::after {
    transform: translateY(1px) rotate(180deg);
}

/* Header icon picker visual list 20260619 */
.header-icon-picker {
    display: block;
    position: relative;
}

.header-icon-picker-button {
    align-items: center;
    background: #fff;
    border: 1px solid #ccd7e6;
    border-radius: 6px;
    color: #07132f;
    cursor: pointer;
    display: grid;
    gap: 8px;
    grid-template-columns: 34px minmax(0, 1fr) 18px;
    min-height: var(--header-button-height, 42px);
    padding: 4px 10px 4px 4px;
    text-align: left;
    width: 100%;
}

.header-icon-picker-button > span {
    align-items: center;
    background: #f3f6fa;
    border: 1px solid #d5deea;
    border-radius: 5px;
    display: inline-flex;
    height: 32px;
    justify-content: center;
    width: 34px;
}

.header-icon-picker-button strong {
    font-size: 13px;
    font-weight: 700;
}

.header-icon-picker-list {
    background: #fff;
    border: 1px solid #aeb9c8;
    border-radius: 6px;
    box-shadow: 0 16px 36px rgba(15, 23, 42, .14);
    display: grid;
    left: 0;
    max-height: 310px;
    overflow: auto;
    padding: 5px;
    position: absolute;
    right: 0;
    top: calc(100% + 6px);
    z-index: 50;
}

.header-icon-picker-list[hidden] {
    display: none !important;
}

.header-icon-picker-list button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 5px;
    color: #07132f;
    cursor: pointer;
    display: grid;
    font-size: 13px;
    gap: 8px;
    grid-template-columns: 22px minmax(0, 1fr);
    min-height: 30px;
    padding: 5px 8px;
    text-align: left;
}

.header-icon-picker-list button i {
    text-align: center;
}

.header-icon-picker-list button:hover,
.header-icon-picker-list button.is-selected {
    background: #1f6fd6;
    color: #fff;
}

/* Header button settings 20260619 */
.header-button-form {
    display: grid;
    gap: 18px;
}

.header-button-toggle {
    align-items: center;
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    display: flex;
    justify-content: space-between;
    padding: 16px 18px;
}

.header-button-toggle div {
    display: grid;
    gap: 4px;
}

.header-button-toggle span {
    color: #5d6b82;
    font-size: 13px;
}

.header-button-controls {
    grid-template-columns: minmax(170px, .8fr) minmax(220px, 1fr) minmax(260px, 1.2fr);
}

.header-button-design-controls {
    grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.header-button-design-controls input[type="color"] {
    height: 44px;
    min-height: 44px;
    min-width: 92px;
    width: 92px;
}

.header-button-preview-box {
    align-items: center;
    background: #f8fafc;
    border: 1px dashed #cdd7e5;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 16px 18px;
}

.header-button-preview-box > span {
    color: #5d6b82;
    font-size: 13px;
    font-weight: 700;
}

.header-cta {
    align-items: center;
    background: var(--header-button-bg, var(--brand));
    border-radius: 8px;
    color: var(--header-button-color, #fff);
    display: inline-flex;
    font-weight: 800;
    gap: 8px;
    min-height: var(--header-button-height, 42px);
    padding: 0 18px;
    text-decoration: none;
    transition: background .18s ease, transform .18s ease;
    white-space: nowrap;
}

.header-cta i {
    color: currentColor;
    font-size: .95em;
    line-height: 1;
}

.header-cta:hover,
.header-cta:focus {
    background: var(--header-button-hover, var(--brand));
    color: var(--header-button-color, #fff);
    transform: translateY(-1px);
}

@media (max-width: 900px) {
    .header-button-controls,
    .header-button-design-controls {
        grid-template-columns: 1fr;
    }

    .header-button-preview-box {
        align-items: flex-start;
        flex-direction: column;
    }
}
/* Header nav action grouping 20260619 */
.site-header-inner {
    gap: 22px;
    justify-content: flex-start;
}

.site-header .brand {
    margin-right: auto;
}

.site-header .site-nav {
    margin-left: 0;
}

.site-header .header-cta {
    flex: 0 0 auto;
}

.header-button-preview-box {
    align-items: flex-start;
    flex-direction: column;
    justify-content: flex-start;
}

.header-button-preview-empty {
    background: #f8fafc;
    border: 1px dashed #cdd7e5;
    border-radius: 8px;
    color: #5d6b82;
    font-size: 13px;
    padding: 14px 16px;
    width: 100%;
}

@media (max-width: 1180px) {
    .header-button-design-controls {
        grid-template-columns: repeat(2, minmax(150px, 1fr));
    }
}
/* Header button icon picker alignment 20260620 */
.header-button-design-controls {
    align-items: start;
}

.header-button-design-controls label {
    align-content: start;
    display: grid;
    gap: 8px;
    grid-template-rows: auto 44px auto;
}

.header-button-design-controls input[type="number"] {
    height: 44px;
    min-height: 44px;
    width: 120px;
}

.header-button-controls .header-icon-picker-button {
    min-height: 44px;
}
/* Header mobile menu 20260620 */
.mobile-menu-toggle {
    align-items: center;
    background: #f3f7fb;
    border: 1px solid #d8e1ec;
    border-radius: 8px;
    color: var(--header-color, #06152d);
    cursor: pointer;
    display: none;
    height: 40px;
    justify-content: center;
    width: 42px;
}

.mobile-menu-panel-wrap[hidden] {
    display: none !important;
}

.mobile-menu-panel-wrap {
    inset: 0;
    position: fixed;
    z-index: 120;
}

.mobile-menu-backdrop {
    background: rgba(6, 21, 45, .42);
    border: 0;
    cursor: pointer;
    inset: 0;
    opacity: 0;
    position: absolute;
    transition: opacity .18s ease;
}

.mobile-menu-panel {
    background: var(--mobile-menu-bg, #fff);
    border-right: 1px solid var(--mobile-menu-divider, #d7e2f0);
    box-shadow: 24px 0 60px rgba(15, 23, 42, .18);
    color: var(--mobile-menu-color, #06152d);
    height: 100%;
    max-width: min(86vw, 360px);
    overflow: auto;
    position: relative;
    transform: translateX(-102%);
    transition: transform .2s ease;
    width: 360px;
}

.mobile-menu-panel-wrap.is-open .mobile-menu-backdrop {
    opacity: 1;
}

.mobile-menu-panel-wrap.is-open .mobile-menu-panel {
    transform: translateX(0);
}

.mobile-menu-panel-head {
    align-items: center;
    border-bottom: 1px solid var(--mobile-menu-divider, #d7e2f0);
    display: flex;
    font-weight: 800;
    justify-content: space-between;
    min-height: 58px;
    padding: 0 18px;
}

.mobile-menu-panel-head button {
    align-items: center;
    background: transparent;
    border: 0;
    color: inherit;
    cursor: pointer;
    display: inline-flex;
    height: 38px;
    justify-content: center;
    width: 38px;
}

.mobile-menu-list {
    display: grid;
}

.mobile-menu-list a {
    align-items: center;
    border-bottom: 1px solid var(--mobile-menu-divider, #d7e2f0);
    color: inherit;
    display: grid;
    font-weight: 750;
    gap: 10px;
    grid-template-columns: 22px minmax(0, 1fr) auto;
    min-height: 50px;
    padding: 0 18px;
    text-decoration: none;
}

.mobile-menu-list a.is-child {
    font-size: 14px;
    font-weight: 650;
    min-height: 44px;
    padding-left: 42px;
}

.mobile-menu-list a i {
    color: currentColor;
    text-align: center;
}

.mobile-menu-arrow {
    font-size: 12px;
}

.mobile-menu-cta {
    background: var(--header-button-bg, var(--brand));
    color: var(--header-button-color, #fff) !important;
    margin-top: 10px;
}

body.mobile-menu-open {
    overflow: hidden;
}

.header-mobile-form {
    display: grid;
    gap: 18px;
}

.header-mobile-controls {
    grid-template-columns: repeat(3, minmax(150px, 1fr));
}

.header-mobile-controls label {
    display: grid;
    gap: 8px;
}

.header-mobile-controls input[type="color"] {
    height: 44px;
    min-height: 44px;
    min-width: 92px;
    width: 92px;
}

.header-mobile-preview {
    display: grid;
    gap: 10px;
}

.header-mobile-preview > span {
    color: #5d6b82;
    font-size: 13px;
    font-weight: 800;
}

.mobile-menu-preview-card {
    background: var(--mobile-menu-bg, #fff);
    border: 1px solid var(--mobile-menu-divider, #d7e2f0);
    border-radius: 8px;
    color: var(--mobile-menu-color, #06152d);
    max-width: 360px;
    overflow: hidden;
}

.mobile-menu-preview-card div {
    align-items: center;
    border-bottom: 1px solid var(--mobile-menu-divider, #d7e2f0);
    display: flex;
    gap: 10px;
    min-height: 42px;
    padding: 0 14px;
}

.mobile-menu-preview-card div:last-child {
    border-bottom: 0;
}

.mobile-menu-preview-card .is-child {
    padding-left: 34px;
}

@media (max-width: 760px) {
    .mobile-menu-toggle {
        display: inline-flex;
        flex: 0 0 auto;
    }

    .site-header .site-nav,
    .site-header .header-cta {
        display: none;
    }

    .site-header .brand {
        margin-left: 0;
        margin-right: 0;
    }

    .site-header-inner {
        justify-content: flex-start;
    }
}

@media (max-width: 760px) {
    .header-mobile-controls {
        grid-template-columns: 1fr;
    }
}
/* Mobile header single row fix 20260620 */
@media (max-width: 760px) {
    .site-header .site-header-inner {
        align-items: center;
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 12px;
        justify-content: flex-start;
        min-height: var(--mobile-header-height, 72px);
        width: 100%;
    }

    .site-header .brand {
        align-items: center;
        display: inline-flex;
        flex: 0 1 auto;
        min-width: 0;
    }

    .site-header .brand img {
        max-width: min(240px, calc(100vw - 92px));
    }

    .site-header .header-logo-mobile,
    .site-header .header-logo-desktop {
        max-height: calc(var(--mobile-header-height, 72px) - 8px);
    }
}
/* Mobile header side padding 20260620 */
@media (max-width: 760px) {
    .site-header .site-header-inner {
        padding-left: 14px;
        padding-right: 14px;
    }
}
/* Mobile design split settings 20260620 */
@media (max-width: 760px) {
    .site-header {
        background: var(--mobile-header-bg, #ffffff);
        height: var(--mobile-header-height, 72px);
    }

    .site-header .site-header-inner {
        min-height: var(--mobile-header-height, 72px);
        padding-left: 8px;
        padding-right: 12px;
        position: relative;
    }

    .mobile-menu-toggle {
        background: var(--mobile-toggle-bg, #f3f7fb);
        border-color: var(--mobile-toggle-border, #d8e1ec);
        color: var(--mobile-toggle-color, #c1121f);
    }

    .site-header[style*="--mobile-logo-align:center"] .brand {
        left: 50%;
        position: absolute;
        transform: translateX(-50%);
    }

    .site-header .header-logo-mobile,
    .site-header .header-logo-desktop {
        max-height: calc(var(--mobile-header-height, 72px) - 8px);
    }
}

.mobile-menu-topbar-items {
    border-top: 1px solid var(--mobile-menu-divider, #d7e2f0);
    display: grid;
}

.mobile-menu-info {
    align-items: center;
    border-bottom: 1px solid var(--mobile-menu-divider, #d7e2f0);
    color: inherit;
    display: grid;
    font-size: 14px;
    font-weight: 650;
    gap: 10px;
    grid-template-columns: 22px minmax(0, 1fr);
    min-height: 44px;
    padding: 0 18px;
    text-decoration: none;
}

.mobile-menu-social {
    border-bottom: 1px solid var(--mobile-menu-divider, #d7e2f0);
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 18px;
}

.mobile-menu-social a {
    align-items: center;
    color: inherit;
    display: inline-flex;
    height: 30px;
    justify-content: center;
    text-decoration: none;
    width: 30px;
}

/* Gallery module */
.gallery-section-header {
    margin: 0 auto 24px;
    max-width: 820px;
}

.gallery-section-header h1,
.gallery-section-header h2 {
    margin: 0;
}

.gallery-section-header p {
    color: var(--muted);
    margin: 10px 0 0;
}

.gallery-grid.gallery-grid-managed {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gallery-gap, 16px);
    justify-content: center;
}

.gallery-grid.gallery-grid-managed a {
    background: transparent;
    border: 0;
    border-radius: var(--gallery-radius, 8px);
    box-shadow: none;
    min-width: 0;
    overflow: hidden;
    flex: 0 0 var(--gallery-item-width, calc(25% - 12px));
    width: var(--gallery-item-width, calc(25% - 12px));
}

.gallery-grid.gallery-grid-managed a[hidden] {
    display: none;
}

.gallery-grid.gallery-grid-managed img {
    aspect-ratio: 4 / 3;
    border-radius: var(--gallery-radius, 8px);
    transition: transform 180ms ease, filter 180ms ease;
}

.gallery-grid.gallery-grid-managed a:hover img {
    filter: brightness(0.9);
    transform: scale(1.025);
}

.gallery-grid.gallery-grid-managed span {
    color: var(--gallery-caption-color, var(--ink));
    font-size: var(--gallery-caption-size, 15px);
    font-weight: var(--gallery-caption-weight, 700);
    padding: 10px 2px 0;
}

.gallery-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    margin: 0 0 24px;
}

.gallery-filters button {
    background: #ffffff;
    border: 1px solid var(--line);
    color: var(--ink);
    min-height: 38px;
    padding: 7px 15px;
}

.gallery-filters button.is-active,
.gallery-filters button:hover {
    background: var(--brand);
    border-color: var(--brand);
    color: #ffffff;
}

.lightbox-open {
    overflow: hidden;
}

.lightbox-figure {
    margin: 0;
    max-width: min(92vw, 1200px);
    position: relative;
}

.lightbox-overlay .lightbox-figure img {
    display: block;
    max-height: min(82vh, 900px);
    max-width: 100%;
}

.lightbox-figure figcaption {
    color: #ffffff;
    font-size: 15px;
    margin-top: 10px;
    text-align: center;
}

.lightbox-nav {
    align-items: center;
    background: #ffffff;
    border: 0;
    border-radius: 50%;
    color: #101828;
    display: inline-flex;
    height: 46px;
    justify-content: center;
    padding: 0;
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    width: 46px;
    z-index: 2;
}

.lightbox-prev {
    left: 22px;
}

.lightbox-next {
    right: 22px;
}

.gallery-admin-thumb {
    aspect-ratio: 4 / 3;
}

.gallery-admin-thumb img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

@media (max-width: 700px) {
    .gallery-grid.gallery-grid-managed {
        justify-content: center;
    }

    .gallery-grid.gallery-grid-managed a {
        flex-basis: var(--gallery-mobile-item-width, calc(50% - 8px));
        width: var(--gallery-mobile-item-width, calc(50% - 8px));
    }

    .gallery-grid.gallery-grid-managed span {
        font-size: min(var(--gallery-caption-size, 15px), 14px);
    }

    .lightbox-overlay {
        padding: 16px;
    }

    .lightbox-nav {
        height: 40px;
        width: 40px;
    }

    .lightbox-prev {
        left: 8px;
    }

    .lightbox-next {
        right: 8px;
    }
}

/* Gallery admin alignment */
.gallery-entry-form,
.gallery-settings-form {
    gap: 20px;
}

/* Certificates and documents module */
.documents-section-header {
    margin: 0 auto 24px;
    max-width: 820px;
}

.documents-section-header h1,
.documents-section-header h2 {
    margin: 0;
}

.documents-section-header p {
    color: var(--muted);
    margin: 10px 0 0;
}

.documents-public-grid {
    display: flex;
    flex-wrap: wrap;
    gap: var(--document-gap, 18px);
    justify-content: center;
}

.document-public-card {
    background: transparent;
    border: 0;
    box-shadow: none;
    display: flex;
    flex: 0 0 var(--document-item-width, calc(25% - 14px));
    flex-direction: column;
    min-width: 0;
    padding: 0;
    width: var(--document-item-width, calc(25% - 14px));
}

.document-image-link {
    background: #ffffff;
    border: 1px solid var(--line);
    border-radius: var(--document-radius, 8px);
    display: block;
    overflow: hidden;
}

.document-image-link img {
    display: block;
    height: var(--document-image-height, 300px);
    object-fit: contain;
    transition: transform 180ms ease, filter 180ms ease;
    width: 100%;
}

.document-image-link:hover img {
    filter: brightness(.94);
    transform: scale(1.015);
}

.document-public-copy {
    align-items: flex-start;
    display: flex;
    flex: 1;
    flex-direction: column;
    padding-top: 12px;
}

.document-public-copy h2,
.document-public-copy h3 {
    color: var(--document-title-color, #18212f);
    font-size: var(--document-title-size, 18px);
    font-weight: var(--document-title-weight, 700);
    margin: 0;
}

.document-public-copy p {
    color: var(--document-meta-color, #667085);
    font-size: var(--document-meta-size, 14px);
    font-weight: var(--document-meta-weight, 400);
    margin: 6px 0 0;
}

.site-main a.document-pdf-button {
    align-items: center;
    align-self: flex-start;
    background: var(--document-button-bg, #146c5f);
    border-radius: 6px;
    color: var(--document-button-color, #ffffff);
    display: inline-flex;
    font-size: var(--document-button-size, 14px);
    font-weight: 700;
    gap: 7px;
    margin-top: 12px;
    min-height: 40px;
    padding: 8px 14px;
    text-decoration: none;
}

.site-main a.document-pdf-button:hover {
    background: var(--document-button-hover, #0f554b);
    color: var(--document-button-color, #ffffff);
}

.document-admin-thumb {
    aspect-ratio: 3 / 4;
}

.document-admin-thumb img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.document-entry-form,
.document-settings-form {
    gap: 20px;
}

.document-form-grid,
.document-settings-grid {
    align-items: start;
    display: grid;
    gap: 16px;
}

.catalog-entry-form {
    gap: 20px;
}

.catalog-form-grid {
    align-items: start;
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.catalog-form-grid input,
.catalog-form-grid select,
.catalog-form-grid textarea {
    width: 100%;
}

.catalog-form-grid input,
.catalog-form-grid select {
    min-height: 44px;
}

.catalog-form-wide {
    grid-column: 1 / -1;
}

.catalog-form-grid small {
    color: var(--muted);
    display: block;
    font-size: 13px;
    line-height: 1.5;
    margin-top: 7px;
}

.document-form-grid-two,
.document-settings-grid.grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.document-settings-grid.grid-three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.document-settings-grid.grid-four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.document-form-grid input,
.document-form-grid select,
.document-settings-grid input:not([type="color"]),
.document-settings-grid select {
    min-height: 44px;
    width: 100%;
}

.document-settings-grid input[type="color"] {
    height: 44px;
    min-height: 44px;
    width: 100%;
}

.document-field-heading {
    display: grid;
    gap: 4px;
}

.document-field-heading span {
    color: var(--muted);
    font-size: 13px;
}

.document-media-preview {
    min-height: 220px;
}

.document-media-preview img {
    max-height: 300px;
    max-width: 240px;
    object-fit: contain;
}

.document-pdf-preview {
    min-height: 64px;
}

.document-form-footer {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

@media (max-width: 980px) {
    .document-settings-grid.grid-four,
    .document-settings-grid.grid-three {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .document-public-card {
        flex-basis: var(--document-mobile-item-width, calc(50% - 9px));
        width: var(--document-mobile-item-width, calc(50% - 9px));
    }

    .document-image-link img {
        height: var(--document-mobile-image-height, 180px);
    }

    .catalog-form-grid,
    .document-form-grid-two,
    .document-settings-grid.grid-two,
    .document-settings-grid.grid-three,
    .document-settings-grid.grid-four {
        grid-template-columns: 1fr;
    }

    .document-form-footer {
        align-items: stretch;
        flex-direction: column;
        gap: 14px;
    }
}

.gallery-form-grid,
.gallery-settings-grid {
    align-items: start;
    display: grid;
    gap: 16px;
}

.gallery-form-grid-two,
.gallery-settings-grid-two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.gallery-form-grid-three,
.gallery-settings-grid-three {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.gallery-settings-grid-four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.gallery-form-grid label,
.gallery-settings-grid label {
    align-content: start;
    min-width: 0;
}

.gallery-form-grid input,
.gallery-form-grid select,
.gallery-settings-grid input:not([type="color"]):not([type="checkbox"]),
.gallery-settings-grid select {
    min-height: 44px;
    width: 100%;
}

.gallery-settings-grid input[type="color"] {
    height: 44px;
    min-height: 44px;
    width: 100%;
}

.gallery-media-field {
    gap: 16px;
}

.gallery-field-heading {
    display: grid;
    gap: 4px;
}

.gallery-field-heading span {
    color: var(--muted);
    font-size: 13px;
}

.gallery-media-preview {
    min-height: 170px;
}

.gallery-media-preview img {
    max-height: 220px;
    max-width: 360px;
    object-fit: contain;
}

.gallery-form-footer {
    align-items: center;
    display: flex;
    justify-content: space-between;
}

.gallery-form-footer .check-row,
.gallery-caption-toggle .check-row {
    margin: 0;
}

.gallery-caption-toggle {
    align-content: start;
}

@media (max-width: 980px) {
    .gallery-settings-grid-four,
    .gallery-form-grid-three,
    .gallery-settings-grid-three {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 700px) {
    .gallery-form-grid-two,
    .gallery-form-grid-three,
    .gallery-settings-grid-two,
    .gallery-settings-grid-three,
    .gallery-settings-grid-four {
        grid-template-columns: 1fr;
    }

    .gallery-form-footer {
        align-items: stretch;
        flex-direction: column;
        gap: 14px;
    }
}

.media-field .media-size-recommendation {
    color: var(--admin-primary, #147d70);
    display: block;
    font-weight: 700;
    margin-top: 4px;
}

/* Process manager and public process flow 20260624 */
.button.disabled {
    cursor: not-allowed;
    opacity: .62;
    pointer-events: none;
}

.process-admin-row {
    min-height: 104px;
}

.process-section {
    background: transparent !important;
}

.process-section-heading {
    margin-bottom: 32px;
    text-align: center;
}

.process-align-left .process-section-heading {
    text-align: left;
}

.process-align-right .process-section-heading {
    text-align: right;
}

.process-section-heading h2 {
    color: var(--process-title-color, #18212f);
    font-size: var(--process-title-size, 32px);
    font-weight: var(--process-title-weight, 800);
    margin: 0;
}

.process-section-heading p {
    color: var(--process-description-color, #667085);
    font-size: var(--process-description-size, 17px);
    font-weight: var(--process-description-weight, 400);
    margin: 10px 0 0;
}

.process-section .process-grid {
    display: grid;
    gap: var(--process-gap, 24px);
    grid-template-columns: repeat(var(--process-count, 4), minmax(0, 1fr));
}

.process-section .process-card {
    background: transparent;
    border: 0;
    min-width: 0;
    padding: 0 18px 8px;
    position: relative;
    text-align: center;
}

.process-step-visual {
    align-items: center;
    display: inline-flex;
    justify-content: center;
    margin-bottom: 22px;
    min-height: 164px;
    padding-left: 42px;
    position: relative;
}

.process-step-number {
    color: var(--process-arrow-color, #146c5f);
    font-size: 22px;
    font-weight: 800;
    left: 0;
    line-height: 1;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.process-section .process-card .process-step-orbit {
    align-items: center;
    border: 1px dashed color-mix(in srgb, var(--process-arrow-color, #146c5f) 34%, transparent);
    border-radius: 50%;
    display: inline-flex;
    height: 164px;
    justify-content: center;
    margin: 0;
    position: relative;
    width: 164px;
}

.process-section .process-card .process-step-icon {
    align-items: center;
    background: var(--process-icon-bg, #146c5f);
    border-radius: 50%;
    color: var(--process-icon-color, #fff);
    display: inline-flex;
    height: 124px;
    justify-content: center;
    margin: 0;
    width: 124px;
}

.process-section .process-card .process-step-icon i {
    color: inherit;
    font-size: var(--process-icon-size, 30px);
}

.process-section .process-card h3 {
    color: var(--process-step-title-color, #18212f);
    font-size: var(--process-step-title-size, 20px);
    font-weight: var(--process-step-title-weight, 700);
    margin: 0 0 7px;
}

.process-section .process-card p {
    color: var(--process-step-description-color, #667085);
    font-size: var(--process-step-description-size, 15px);
    font-weight: var(--process-step-description-weight, 400);
    margin: 0;
}

.process-arrows-on .process-card:not(:last-child)::before {
    border-top: 1px dashed color-mix(in srgb, var(--process-arrow-color, #146c5f) 42%, transparent);
    content: "";
    left: calc(50% + 95px);
    position: absolute;
    right: calc((var(--process-gap, 24px) * -1) - 50%);
    top: 81px;
    z-index: 0;
}

.process-arrows-on .process-card:not(:last-child)::after {
    color: var(--process-arrow-color, #146c5f);
    content: "\f1d8";
    font-family: "Font Awesome 6 Free";
    font-size: 17px;
    font-weight: 900;
    position: absolute;
    right: calc((var(--process-gap, 24px) / -2) - 9px);
    top: 70px;
    transform: rotate(18deg);
    z-index: 2;
}

@media (max-width: 800px) {
    .process-section .process-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .process-section .process-card {
        padding-inline: 4px;
    }

    .process-arrows-on .process-card::before,
    .process-arrows-on .process-card::after {
        display: none;
    }

    .process-step-visual {
        margin-bottom: 16px;
        min-height: 116px;
        padding-left: 28px;
    }

    .process-step-number {
        font-size: 17px;
    }

    .process-section .process-card .process-step-orbit {
        height: 116px;
        width: 116px;
    }

    .process-section .process-card .process-step-icon {
        height: 86px;
        width: 86px;
    }
}

/* Keep team contact icon, label and input on one line */
.team-contact-grid .social-account-row {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 32px minmax(0, 1fr);
    margin: 0;
}

.team-contact-grid .social-account-icon {
    align-items: center;
    color: var(--brand);
    display: inline-flex;
    font-size: 15px;
    justify-content: center;
}

.team-contact-grid .social-account-input {
    align-items: center;
    display: grid;
    gap: 10px;
    grid-template-columns: 86px minmax(0, 1fr);
    min-width: 0;
}

.team-contact-grid .social-account-input strong {
    color: var(--muted);
    font-size: 14px;
    white-space: nowrap;
}

.team-contact-grid .social-account-input input {
    min-width: 0;
    width: 100%;
}

@media (max-width: 560px) {
    .team-contact-grid .social-account-input {
        grid-template-columns: 76px minmax(0, 1fr);
    }
}

/* Team detail profile layout 20260625 */
.team-detail-page .team-detail-hero {
    align-items: start;
    grid-template-columns: minmax(240px, 360px) minmax(0, 1fr);
}

.team-detail-page .team-detail-hero > img {
    border: var(--team-detail-image-border, 0) solid var(--team-detail-image-border-color, #146c5f);
    border-radius: var(--team-detail-image-radius, 8px);
    display: block;
    width: 100%;
}

.team-detail-copy {
    align-self: start;
    min-width: 0;
}

.site-main .team-detail-copy h1 {
    color: var(--team-detail-name-color, #18212f);
    font-size: var(--team-detail-name-size, 20px);
    font-weight: var(--team-detail-name-weight, 700);
    line-height: 1.15;
    margin: 0 0 6px;
}

.team-detail-page .team-detail-position {
    color: var(--team-detail-position-color, #667085);
    font-size: var(--team-detail-position-size, 15px);
    font-weight: var(--team-detail-position-weight, 400);
    margin: 0 0 14px;
}

.team-detail-socials {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin-bottom: 18px;
}

.site-main .team-detail-socials a {
    align-items: center;
    background: #202124;
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    font-size: 15px;
    height: 36px;
    justify-content: center;
    text-decoration: none;
    width: 36px;
}

.site-main .team-detail-socials a:hover {
    background: var(--brand);
    color: #fff;
}

.team-detail-page .team-detail-content {
    margin-top: 0;
}

.team-detail-page .team-detail-content > :first-child {
    margin-top: 0;
}

@media (max-width: 800px) {
    .team-detail-page .team-detail-hero {
        grid-template-columns: 1fr;
    }
}
/* Mobile header desktop isolation 20260620 */
@media (max-width: 760px) {
    .site-header {
        background: var(--mobile-header-bg, #ffffff);
        height: var(--mobile-header-height, 72px);
    }

    .site-header .site-header-inner {
        height: var(--mobile-header-height, 72px);
        min-height: var(--mobile-header-height, 72px);
    }

    .site-header .header-logo-mobile,
    .site-header .header-logo-desktop {
        max-height: calc(var(--mobile-header-height, 72px) - 8px);
    }

    .site-header .header-logo-mobile[style=""],
    .site-header .header-logo-desktop[style=""] {
        height: auto;
    }
}

/* Header button device checks 20260620 */
.header-button-device-checks {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: flex-end;
}

.header-button-device-checks label:not(.switch-control) {
    align-items: center;
    color: #33425b;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    gap: 8px;
}

.header-button-device-checks input[type="checkbox"] {
    accent-color: var(--admin-primary, #146c5f);
    height: 18px;
    width: 18px;
}


/* Header button device row fix 20260620 */
.header-button-toggle .header-button-device-checks {
    align-items: center;
    display: inline-flex;
    flex-wrap: nowrap;
    gap: 18px;
    justify-content: flex-end;
}

.header-button-toggle .header-button-device-checks label {
    align-items: center;
    display: inline-flex;
    flex-direction: row;
    gap: 8px;
    white-space: nowrap;
}


/* Mobile menu typography 20260620 */
.mobile-menu-panel {
    border-radius: 0 10px 10px 0;
}

.mobile-menu-list a,
.mobile-menu-info,
.mobile-menu-social a,
.mobile-menu-panel-head {
    font-size: var(--mobile-menu-font-size, 15px);
    font-weight: var(--mobile-menu-font-weight, 700);
}

.mobile-menu-list a.is-child {
    font-size: max(12px, calc(var(--mobile-menu-font-size, 15px) - 1px));
    font-weight: var(--mobile-menu-font-weight, 700);
}

.mobile-menu-preview-card div {
    font-size: var(--mobile-menu-font-size, 15px);
    font-weight: var(--mobile-menu-font-weight, 700);
}


/* Bottom fixed menu 20260620 */
.bottom-fixed-form {
    display: grid;
    gap: 18px;
}

.bottom-fixed-items {
    display: grid;
    gap: 12px;
}

.bottom-fixed-item-card {
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    display: grid;
    gap: 14px;
    padding: 16px;
}

.bottom-fixed-item-head {
    align-items: center;
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.bottom-fixed-new-tab {
    align-items: center;
    color: #33425b;
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    gap: 8px;
}

.bottom-fixed-new-tab input {
    accent-color: var(--admin-primary, #146c5f);
    height: 18px;
    width: 18px;
}

.bottom-fixed-item-grid {
    grid-template-columns: minmax(170px, 1fr) minmax(190px, 1fr) minmax(240px, 1.3fr);
}

.bottom-fixed-design-grid {
    grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.bottom-fixed-design-grid input[type="color"] {
    height: 44px;
    min-height: 44px;
    min-width: 92px;
    width: 92px;
}

.bottom-fixed-help {
    background: #f8fafc;
    border: 1px dashed #cdd7e5;
    border-radius: 8px;
    color: #42526b;
    display: grid;
    gap: 6px;
    padding: 14px 16px;
}

.bottom-fixed-help code {
    color: #0f766e;
    font-weight: 800;
}

.bottom-fixed-preview {
    align-items: center;
    background: var(--bottom-fixed-bg, #fff);
    border: 1px solid #d7e1ee;
    border-radius: 16px;
    box-shadow: 0 16px 34px rgba(15, 23, 42, .12);
    color: var(--bottom-fixed-text, #06152d);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    min-height: var(--bottom-fixed-height, 64px);
    max-width: 430px;
    overflow: hidden;
}

.bottom-fixed-preview span {
    align-items: center;
    display: grid;
    font-size: var(--bottom-fixed-font-size, 12px);
    font-weight: var(--bottom-fixed-font-weight, 700);
    gap: 5px;
    justify-items: center;
    min-width: 0;
    padding: 7px 6px;
    text-align: center;
}

.bottom-fixed-preview i {
    color: var(--bottom-fixed-icon, #146c5f);
    font-size: var(--bottom-fixed-icon-size, 20px);
}

.bottom-fixed-menu {
    display: none;
}

@media (max-width: 760px) {
    body.has-bottom-fixed-menu {
        padding-bottom: calc(var(--bottom-fixed-height, 64px) + env(safe-area-inset-bottom, 0px));
    }

    .bottom-fixed-menu {
        align-items: stretch;
        background: var(--bottom-fixed-bg, #fff);
        border-top: 1px solid rgba(15, 23, 42, .12);
        bottom: 0;
        box-shadow: 0 -14px 34px rgba(15, 23, 42, .14);
        color: var(--bottom-fixed-text, #06152d);
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        left: 0;
        min-height: calc(var(--bottom-fixed-height, 64px) + env(safe-area-inset-bottom, 0px));
        padding-bottom: env(safe-area-inset-bottom, 0px);
        position: fixed;
        right: 0;
        z-index: 70;
    }

    .bottom-fixed-menu a {
        align-items: center;
        color: inherit;
        display: grid;
        font-size: var(--bottom-fixed-font-size, 12px);
        font-weight: var(--bottom-fixed-font-weight, 700);
        gap: 5px;
        justify-items: center;
        min-width: 0;
        padding: 7px 4px;
        text-align: center;
        text-decoration: none;
    }

    .bottom-fixed-menu i {
        color: var(--bottom-fixed-icon, #146c5f);
        font-size: var(--bottom-fixed-icon-size, 20px);
    }

    .bottom-fixed-menu span {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        width: 100%;
    }
}

@media (max-width: 760px) {
    .bottom-fixed-item-grid,
    .bottom-fixed-design-grid {
        grid-template-columns: 1fr;
    }

    .bottom-fixed-item-head {
        align-items: flex-start;
        flex-direction: column;
    }
}


/* Bottom fixed true height 20260620 */
@media (max-width: 760px) {
    .bottom-fixed-menu {
        height: calc(var(--bottom-fixed-height, 64px) + env(safe-area-inset-bottom, 0px));
        min-height: 0;
    }

    .bottom-fixed-menu a {
        gap: clamp(0px, calc((var(--bottom-fixed-height, 64px) - 28px) / 8), 5px);
        min-height: 0;
        overflow: hidden;
        padding: 2px 4px;
    }

    .bottom-fixed-menu i {
        font-size: min(var(--bottom-fixed-icon-size, 20px), calc(var(--bottom-fixed-height, 64px) * .42));
        line-height: 1;
    }

    .bottom-fixed-menu span {
        font-size: min(var(--bottom-fixed-font-size, 12px), calc(var(--bottom-fixed-height, 64px) * .32));
        line-height: 1;
    }
}


/* Desktop slider manager 20260621 */
.desktop-slider-panel,
.desktop-slider-settings {
    display: grid;
    gap: 18px;
}

.desktop-slider-list {
    background: #fff;
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 14px 14px 12px;
}

.desktop-slider-item {
    align-items: center;
    background: #f8fafc;
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    cursor: grab;
    display: grid;
    gap: 14px;
    grid-template-columns: 36px 180px minmax(0, 1fr) auto;
    padding: 12px;
}

.desktop-slider-item.is-dragging {
    opacity: .88;
}

.slider-drag-handle {
    align-items: center;
    background: #edf3f9;
    border: 1px solid #d7e1ee;
    border-radius: 6px;
    color: #52627a;
    cursor: grab;
    display: inline-flex;
    height: 36px;
    justify-content: center;
    padding: 0;
    width: 36px;
}

.desktop-slider-thumb {
    aspect-ratio: 16 / 6;
    background: #e9eff7;
    border-radius: 6px;
    overflow: hidden;
}

.desktop-slider-thumb img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.desktop-slider-info {
    display: grid;
    gap: 4px;
}

.desktop-slider-info strong {
    color: #06152d;
    font-size: 15px;
}

.desktop-slider-info span,
.desktop-slider-info p {
    color: #607089;
    font-size: 13px;
    margin: 0;
}

.desktop-slider-actions {
    justify-content: flex-end;
}

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

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

.slider-width-options label {
    background: #f8fafc;
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    cursor: pointer;
    display: grid;
    gap: 6px;
    padding: 14px 14px 12px;
}

.slider-width-options label.is-selected {
    border-color: var(--admin-primary, #146c5f);
    box-shadow: 0 0 0 3px rgba(20, 108, 95, .12);
}

.slider-width-options input {
    accent-color: var(--admin-primary, #146c5f);
}

.slider-width-options span {
    color: #607089;
    font-size: 13px;
}

.slider-setting-group {
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    display: grid;
    gap: 12px;
    padding: 14px 14px 12px;
}

.slider-setting-group h3 {
    color: #06152d;
    font-size: 15px;
    font-weight: 800;
    margin: 0;
}

.slider-group-grid {
    align-items: start;
    gap: 14px;
}

.slider-group-grid-five {
    grid-template-columns: repeat(5, minmax(120px, 1fr));
}

.slider-group-grid-four {
    grid-template-columns: repeat(4, minmax(140px, 1fr));
}

.slider-group-grid-three {
    grid-template-columns: repeat(3, minmax(170px, 1fr));
}

.slider-group-grid input[type="color"] {
    height: 44px;
    min-height: 44px;
    min-width: 92px;
    width: 92px;
}

.slider-feature-toggles {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(5, minmax(130px, 1fr));
}

.slider-feature-toggles-mobile {
    grid-template-columns: repeat(4, minmax(150px, 1fr));
}

.slider-feature-toggles label {
    align-items: flex-start;
    background: #f8fafc;
    border: 1px solid #d7e1ee;
    border-radius: 8px;
    color: #33425b;
    display: flex;
    font-size: 13px;
    font-weight: 800;
    gap: 8px;
    padding: 12px;
}

.slider-feature-toggles input {
    accent-color: var(--admin-primary, #146c5f);
    flex: 0 0 auto;
    height: 18px;
    margin-top: 2px;
    width: 18px;
}

.slider-feature-toggles span {
    display: grid;
    gap: 4px;
}

.slider-feature-toggles small {
    color: #607089;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.35;
}

@media (max-width: 760px) {
    .slider-hero-desktop {
        display: none;
    }

    .slider-hero-mobile {
        display: block;
    }

    .slider-hero {
        height: var(--slider-mobile-height, 520px);
        max-width: none;
        width: 100%;
    }

    .slide::before {
        background: rgba(3, 7, 18, var(--slider-mobile-overlay-opacity, .5));
    }

    .slide .hero-copy {
        gap: var(--slider-mobile-text-gap, 12px);
        margin-left: auto;
        margin-right: auto;
        width: min(calc(100% - 40px), var(--container));
    }

    .slider-mobile-align-left .hero-copy {
        align-items: flex-start;
        text-align: left;
    }

    .slider-mobile-align-center .hero-copy {
        align-items: center;
        text-align: center;
    }

    .slider-mobile-align-right .hero-copy {
        align-items: flex-end;
        text-align: right;
    }

    .slide h1 {
        color: var(--slider-mobile-title-color, #fff);
        font-size: var(--slider-mobile-title-size, 38px);
        font-weight: var(--slider-mobile-title-weight, 800);
    }

    .slide .hero-copy > p:not(.eyebrow) {
        color: var(--slider-mobile-desc-color, #fff);
        font-size: var(--slider-mobile-desc-size, 16px);
        font-weight: var(--slider-mobile-desc-weight, 500);
    }

    .slide .button {
        background: var(--slider-mobile-button-bg, var(--brand));
        border-color: var(--slider-mobile-button-bg, var(--brand));
        color: var(--slider-mobile-button-color, #fff);
        font-size: var(--slider-mobile-button-size, 14px);
    }

    .slide .button:hover {
        background: var(--slider-mobile-button-hover, var(--brand));
        border-color: var(--slider-mobile-button-hover, var(--brand));
    }

    .slider-mobile-desc-off .hero-copy > p:not(.eyebrow),
    .slider-mobile-button-off .hero-actions,
    .slider-mobile-dots-off .slider-dots {
        display: none;
    }

    .slider-mobile-desc-on .hero-copy > p:not(.eyebrow) {
        display: block;
    }

    .slider-mobile-button-on .hero-actions {
        display: flex;
    }

    .slider-mobile-dots-on .slider-dots {
        display: flex;
    }

    .slider-nav {
        display: none;
    }

    .slider-width-contained.slider-align-left .hero-copy {
        margin-left: auto;
        margin-right: auto;
        width: min(calc(100% - 40px), var(--container));
    }

    .desktop-slider-item,
    .slider-width-options,
    .desktop-slider-design-grid,
    .slider-group-grid-five,
    .slider-group-grid-four,
    .slider-group-grid-three,
    .slider-feature-toggles,
    .slider-feature-toggles-mobile {
        grid-template-columns: 1fr;
    }
}


.typography-preview-body h2 {
    color: var(--site-heading-color, var(--ink));
    font-family: var(--site-heading-font-family);
    font-size: var(--site-heading-size, 32px);
}

.typography-preview-body p {
    color: var(--site-body-color, var(--ink));
    font-family: var(--site-body-font-family);
    font-size: var(--site-body-size, 16px);
}

.typography-preview-body a {
    color: var(--site-link-color, var(--brand));
    font-family: var(--site-link-font-family);
    font-size: var(--site-link-size, 15px);
    font-weight: 700;
}

/* Featured cards badge layout 20260621 */
.featured-badge-section {
    padding-top: 72px;
}

.featured-badge-section > .eyebrow,
.featured-badge-section > h2,
.featured-badge-section > .lead {
    text-align: center;
}

.featured-badge-section > h2 {
    color: var(--featured-section-title-color, var(--site-heading-color, #18212f));
    font-size: var(--featured-section-title-size, 32px);
}

.featured-badge-section > .lead {
    color: var(--featured-section-desc-color, var(--muted));
    font-size: var(--featured-section-desc-size, 17px);
    max-width: none;
    width: 100%;
}

.featured-card-grid-badge {
    gap: var(--featured-gap, 24px);
    grid-template-columns: repeat(var(--featured-columns, 3), minmax(0, 1fr));
    margin-top: 46px;
}

.featured-card-badge {
    background: var(--featured-card-bg, #f4f4f4);
    border: 0;
    border-radius: var(--featured-radius-tl, 0) var(--featured-radius-tr, 0) var(--featured-radius-br, 0) var(--featured-radius-bl, 0);
    box-shadow: none;
    min-height: var(--featured-min-height, 235px);
    padding: var(--featured-padding-top, 88px) var(--featured-padding-x, 34px) var(--featured-padding-bottom, 46px);
    position: relative;
    text-align: center;
}

.featured-shadow-on .featured-card-badge {
    box-shadow: 0 18px 38px rgba(15, 23, 42, .12);
}

.featured-bottom-notch-on .featured-card-badge::after {
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 20px solid var(--featured-card-bg, #f4f4f4);
    bottom: -20px;
    content: '';
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
}

.featured-card-badge .featured-card-icon {
    align-items: center;
    background: var(--featured-badge-bg, var(--brand));
    border-radius: var(--featured-badge-radius-tl, 0) var(--featured-badge-radius-tr, 0) var(--featured-badge-radius-br, 0) var(--featured-badge-radius-bl, 0);
    color: var(--featured-icon-color, #fff);
    display: inline-flex;
    font-size: var(--featured-icon-size, 40px);
    height: var(--featured-badge-size, 100px);
    justify-content: center;
    left: 50%;
    margin: 0;
    position: absolute;
    top: calc(var(--featured-badge-size, 100px) / -2 + 5px);
    transform: translateX(-50%);
    width: var(--featured-badge-size, 100px);
}

.featured-badge-notch-on .featured-card-badge .featured-card-icon::after {
    border-left: 13px solid transparent;
    border-right: 13px solid transparent;
    border-top: 13px solid var(--featured-badge-bg, var(--brand));
    bottom: -13px;
    content: '';
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
}

.featured-card-badge h3 {
    color: var(--featured-title-color, var(--site-heading-color, #06152d));
    font-size: 24px;
    font-weight: 800;
    margin: 0 0 16px;
    text-align: var(--featured-title-align, center);
}

.featured-card-badge p {
    color: var(--featured-desc-color, var(--muted));
    font-size: 16px;
    line-height: 1.7;
    margin: 0;
}

.featured-card-badge .text-link {
    color: var(--featured-link-color, var(--brand)) !important;
    display: inline-block;
    font-size: var(--featured-link-size, 15px) !important;
    font-weight: 800;
    margin-top: 18px;
}

.featured-card-badge .text-link:hover {
    color: var(--featured-link-hover, var(--brand)) !important;
}

.featured-link-off .featured-card-badge .text-link {
    display: none;
}

@media (max-width: 900px) {
    .featured-card-grid-badge {
        grid-template-columns: repeat(var(--featured-mobile-columns, 1), minmax(0, 1fr));
        gap: var(--featured-mobile-gap, 60px);
    }

    .featured-card-badge {
        padding-top: var(--featured-mobile-padding-top, 74px);
    }

    .featured-card-badge .featured-card-icon {
        font-size: var(--featured-mobile-icon-size, 34px);
        height: var(--featured-mobile-badge-size, 86px);
        top: calc(var(--featured-mobile-badge-size, 86px) / -2 + 5px);
        width: var(--featured-mobile-badge-size, 86px);
    }
}

@media (max-width: 520px) {
    .featured-badge-section {
        padding-left: 10px;
        padding-right: 10px;
    }

    .featured-card-grid-badge {
        gap: var(--featured-mobile-gap, 60px);
        width: 100%;
    }

    .featured-card-grid-badge[style*="--featured-mobile-columns: 2"],
    .featured-badge-section[style*="--featured-mobile-columns: 2"] .featured-card-grid-badge {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .featured-badge-section[style*="--featured-mobile-columns: 2"] .featured-card-badge {
        padding-left: 14px;
        padding-right: 14px;
    }

    .featured-badge-section[style*="--featured-mobile-columns: 2"] .featured-card-badge h3 {
        font-size: 18px;
    }

    .featured-badge-section[style*="--featured-mobile-columns: 2"] .featured-card-badge p {
        font-size: 13px;
        line-height: 1.55;
    }
}


/* Announcement single CTA 20260621 */
.announcement-single-section {
    background: transparent;
}

.announcement-single-card {
    background: var(--announcement-bg, #f4f8fb);
    border: 1px solid transparent;
    border-radius: 8px;
    color: var(--announcement-text-color, #18212f);
    padding: 28px 32px;
}

.announcement-frame-on .announcement-single-card {
    border-color: var(--announcement-frame-color, #d7e2f0);
}

.announcement-single-card h2 {
    color: var(--announcement-text-color, #18212f);
    font-size: calc(var(--announcement-font-size, 18px) + 10px);
    font-weight: var(--announcement-font-weight, 700);
    margin: 0 0 8px;
}

.announcement-single-card p {
    color: var(--announcement-text-color, #18212f);
    font-size: var(--announcement-font-size, 18px);
    line-height: 1.65;
    margin: 0;
}

.announcement-single-card .announcement-button {
    background: var(--announcement-button-color, var(--brand));
    border-color: var(--announcement-button-color, var(--brand));
    color: #fff;
    flex: 0 0 auto;
}

.announcement-admin-preview {
    background: #f5f8fc;
    border: 1px solid #d7e2f0;
    border-radius: 8px;
    margin-top: 18px;
    padding: 18px;
}

.announcement-preview-card {
    align-items: center;
    background: #fff;
    border: 1px solid #d7e2f0;
    border-radius: 8px;
    display: flex;
    gap: 16px;
    justify-content: space-between;
    margin-top: 10px;
    padding: 18px;
}

.announcement-preview-card h2 {
    font-size: 22px;
    margin: 0 0 6px;
}

.announcement-preview-card p {
    color: #667085;
    margin: 0;
}

.announcement-preview-card span {
    background: var(--brand);
    border-radius: 7px;
    color: #fff;
    font-weight: 800;
    padding: 10px 16px;
}

@media (max-width: 700px) {
    .announcement-single-card,
    .announcement-preview-card {
        align-items: flex-start;
        flex-direction: column;
    }

    .announcement-single-card {
        padding: 22px;
    }
}


/* About prompt layout 20260621 */
.about-home-section {
    align-items: center;
    display: grid;
    gap: 44px;
    grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
}

.about-home-section.about-image-right .about-home-media {
    order: 2;
}

.about-home-section.about-image-right .about-home-copy {
    order: 1;
}

.about-home-media {
    margin: 0;
}

.about-home-media img {
    border-radius: 8px;
    display: block;
    height: auto;
    max-width: 100%;
    width: 100%;
}

.about-home-copy h2 {
    margin-bottom: 14px;
}

.about-home-copy .lead {
    max-width: none;
}

.about-home-bullets {
    display: grid;
    gap: 12px;
    list-style: none;
    margin: 24px 0;
    padding: 0;
}

.about-home-bullets li {
    align-items: flex-start;
    color: var(--site-body-color, var(--ink));
    display: flex;
    gap: 10px;
    line-height: 1.55;
}

.about-home-bullets i {
    color: var(--brand);
    flex: 0 0 auto;
    margin-top: 4px;
}

@media (max-width: 800px) {
    .about-home-section {
        grid-template-columns: 1fr;
    }

    .about-home-section.about-image-right .about-home-media,
    .about-home-section.about-image-right .about-home-copy {
        order: initial;
    }
}


/* About contact and radius 20260621 */
.about-home-media {
    border-radius: var(--about-radius-tl, 8px) var(--about-radius-tr, 8px) var(--about-radius-br, 8px) var(--about-radius-bl, 8px);
    overflow: hidden;
}

.about-home-media img {
    border-radius: inherit;
}

.about-contact-strip {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin: 22px 0 18px;
}

.about-phone-link {
    align-items: center;
    background: color-mix(in srgb, var(--brand) 10%, #fff);
    border: 1px solid color-mix(in srgb, var(--brand) 25%, #d7e2f0);
    border-radius: 8px;
    color: var(--brand);
    display: inline-flex;
    font-weight: 800;
    gap: 9px;
    padding: 10px 14px;
    text-decoration: none;
}

.about-social-links {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.about-social-links a {
    align-items: center;
    background: #f5f8fc;
    border: 1px solid #d7e2f0;
    border-radius: 8px;
    color: var(--brand);
    display: inline-flex;
    height: 38px;
    justify-content: center;
    text-decoration: none;
    width: 38px;
}

.about-social-links a:hover,
.about-phone-link:hover {
    background: var(--brand);
    border-color: var(--brand);
    color: #fff;
}


/* About design controls 20260621 */
.about-home-section {
    background: transparent !important;
}

.about-home-copy h2 {
    color: var(--about-title-color, #18212f);
    font-size: var(--about-title-size, 32px);
    font-weight: var(--about-title-weight, 800);
}

.about-home-copy .lead {
    color: var(--about-subtitle-color, #667085);
    font-size: var(--about-subtitle-size, 17px);
    font-weight: var(--about-subtitle-weight, 400);
}

.about-home-bullets li {
    color: var(--about-bullet-color, #18212f);
    font-size: var(--about-bullet-size, 16px);
    font-weight: var(--about-bullet-weight, 500);
}


/* Services admin and simple layout 20260621 */
.service-admin-list {
    display: grid;
    gap: 12px;
}

.service-admin-row {
    align-items: center;
    background: #fff;
    border: 1px solid #d9e2ef;
    border-radius: 8px;
    display: grid;
    gap: 14px;
    grid-template-columns: 34px 92px minmax(0, 1fr) auto;
    padding: 12px;
}

.service-admin-row.is-dragging {
    border-color: var(--brand);
    box-shadow: 0 18px 32px color-mix(in srgb, var(--brand) 22%, transparent);
    opacity: .92;
}

.service-admin-thumb {
    align-items: center;
    background: #f3f6fa;
    border-radius: 6px;
    display: flex;
    height: 64px;
    justify-content: center;
    margin: 0;
    overflow: hidden;
    width: 92px;
}

.service-admin-thumb img {
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.service-admin-thumb span {
    color: #718096;
    font-size: 12px;
}

.service-admin-copy strong {
    color: #07132f;
    display: block;
    font-size: 16px;
    font-weight: 800;
}

.service-admin-copy span,
.service-admin-copy p {
    color: #667085;
    font-size: 13px;
    margin: 4px 0 0;
}

.service-admin-actions {
    align-items: center;
    display: flex;
    gap: 8px;
}

.service-home-check {
    align-items: center;
    color: #314158;
    display: grid;
    font-size: 12px;
    gap: 4px;
    justify-items: center;
    min-width: 86px;
}

.service-home-check input {
    height: 18px;
    width: 18px;
}

.services-simple-grid {
    display: grid;
    gap: var(--services-gap, 28px);
    grid-template-columns: repeat(var(--services-columns, 3), minmax(0, 1fr));
}

.services-simple-item {
    background: transparent;
    border: 0;
    box-shadow: none;
}

.services-hide-desktop {
    display: none;
}

.services-simple-image {
    border-radius: var(--services-image-radius-tl, 0) var(--services-image-radius-tr, 0) var(--services-image-radius-br, 0) var(--services-image-radius-bl, 0);
    display: block;
    height: var(--services-image-height, 220px);
    overflow: hidden;
}

.services-simple-image img {
    display: block;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.services-simple-item h2,
.services-simple-item h3 {
    color: var(--services-title-color, #18212f);
    font-size: var(--services-title-size, 22px);
    font-weight: var(--services-title-weight, 800);
    margin: 16px 0 8px;
}

.services-simple-item h2 a,
.services-simple-item h3 a {
    color: var(--services-title-color, #18212f) !important;
    font-size: var(--services-title-size, 22px) !important;
    font-weight: var(--services-title-weight, 800) !important;
    line-height: 1.25;
    text-decoration: none;
}

.services-simple-item p {
    color: var(--services-text-color, #667085);
    font-size: var(--services-text-size, 16px);
    font-weight: var(--services-text-weight, 400);
    line-height: 1.65;
    margin: 0;
}

@media (max-width: 800px) {
    .section {
        width: min(calc(100% - 20px), var(--container));
    }

    .service-admin-row {
        grid-template-columns: 34px 76px minmax(0, 1fr);
    }

    .service-admin-actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }

    .services-simple-grid {
        grid-template-columns: repeat(var(--services-mobile-columns, 1), minmax(0, 1fr));
    }

    .services-simple-image {
        height: var(--services-mobile-image-height, 180px);
    }

    .services-hide-desktop {
        display: block;
    }

    .services-hide-mobile {
        display: none;
    }
}


.services-simple-section > h2 {
    color: var(--services-home-title-color, #18212f);
    font-size: var(--services-home-title-size, 32px);
    font-weight: var(--services-home-title-weight, 800);
    text-align: var(--services-home-title-align, center);
}


/* Reusable detail sidebar 20260622 */
.detail-with-sidebar-section {
    max-width: var(--container);
}

.detail-layout {
    align-items: start;
    display: grid;
    gap: 42px;
    grid-template-columns: minmax(0, 1fr) 320px;
}

.detail-main {
    max-width: none;
    min-width: 0;
}

.detail-sidebar {
    display: grid;
    font-family: var(--site-body-font-family);
    gap: 14px;
    position: sticky;
    top: 108px;
}

.detail-sidebar-card {
    background: #fff;
    border: 1px solid #dbe5f2;
    border-radius: 8px;
    box-shadow: 0 16px 34px rgba(15, 35, 65, .07);
    color: var(--site-body-color, #18212f);
    overflow: hidden;
}

.detail-sidebar-intro {
    padding: 22px 20px;
}

.detail-sidebar-intro h2 {
    color: var(--site-heading-color, #101828);
    font-family: var(--site-heading-font-family);
    font-size: 24px;
    font-weight: 900;
    line-height: 1.15;
    margin: 0 0 10px;
}

.detail-sidebar-intro p {
    color: var(--site-body-color, #667085);
    font-family: var(--site-body-font-family);
    font-size: 14px;
    line-height: 1.65;
    margin: 0;
}

.detail-sidebar-action {
    display: grid;
    gap: 15px;
    padding: 17px 16px 16px;
    text-decoration: none;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.detail-sidebar-action:hover {
    border-color: color-mix(in srgb, var(--brand) 34%, #dbe5f2);
    box-shadow: 0 18px 38px rgba(15, 35, 65, .11);
    transform: translateY(-2px);
}

.detail-sidebar-block-title,
.detail-social-title {
    align-items: center;
    color: var(--brand);
    display: grid;
    font-family: var(--site-heading-font-family);
    font-size: 14px;
    font-weight: 900;
    gap: 12px;
    grid-template-columns: 1fr auto 1fr;
    letter-spacing: .02em;
    line-height: 1.2;
    text-align: center;
}

.detail-sidebar-block-title::before,
.detail-sidebar-block-title::after,
.detail-social-title::before,
.detail-social-title::after {
    background: color-mix(in srgb, var(--brand) 35%, #dbe5f2);
    content: "";
    display: block;
    height: 1px;
}

.detail-sidebar-action-row {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: 46px minmax(0, 1fr);
}

.detail-sidebar-icon {
    align-items: center;
    background: color-mix(in srgb, var(--brand) 10%, #f6f9fc);
    border: 1px solid color-mix(in srgb, var(--brand) 20%, #dbe5f2);
    border-radius: 8px;
    color: var(--brand);
    display: inline-flex;
    font-size: 18px;
    height: 46px;
    justify-content: center;
    width: 46px;
}

.detail-sidebar-action strong {
    color: var(--site-heading-color, #101828);
    display: block;
    font-family: var(--site-heading-font-family);
    font-size: 16px;
    font-weight: 800;
    line-height: 1.25;
}

.detail-sidebar-action small {
    color: var(--site-body-color, #667085);
    display: block;
    font-family: var(--site-body-font-family);
    font-size: 13px;
    line-height: 1.35;
    margin-top: 4px;
    word-break: break-word;
}

.detail-sidebar-primary {
    background: linear-gradient(135deg, var(--brand), color-mix(in srgb, var(--brand) 78%, #07132f));
    border-color: transparent;
}

.detail-sidebar-primary .detail-sidebar-block-title,
.detail-sidebar-primary .detail-sidebar-action strong,
.detail-sidebar-primary .detail-sidebar-action small,
.detail-sidebar-primary strong,
.detail-sidebar-primary small {
    color: #fff;
}

.detail-sidebar-primary .detail-sidebar-block-title::before,
.detail-sidebar-primary .detail-sidebar-block-title::after {
    background: rgba(255, 255, 255, .42);
}

.detail-sidebar-primary .detail-sidebar-icon {
    background: rgba(255, 255, 255, .14);
    border-color: rgba(255, 255, 255, .24);
    color: #fff;
}

.detail-social-card {
    padding: 18px 16px 20px;
}

.detail-social-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    margin-top: 20px;
}

.detail-social-links a {
    align-items: center;
    background: #fff;
    border: 1px solid #dbe5f2;
    border-radius: 50%;
    color: var(--brand);
    display: inline-flex;
    font-size: 15px;
    height: 38px;
    justify-content: center;
    text-decoration: none;
    transition: background .18s ease, border-color .18s ease, color .18s ease, transform .18s ease;
    width: 38px;
}

.detail-social-links a:hover {
    background: var(--brand);
    border-color: var(--brand);
    color: #fff;
    transform: translateY(-2px);
}

@media (max-width: 980px) {
    .detail-layout {
        gap: 28px;
        grid-template-columns: 1fr;
    }

    .detail-sidebar {
        position: static;
    }
}

@media (max-width: 640px) {
    .detail-sidebar-action {
        padding: 15px 14px 14px;
    }

    .detail-sidebar-action-row {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .detail-sidebar-icon {
        font-size: 16px;
        height: 42px;
        width: 42px;
    }
}



/* Service short description clamp 20260622 */
.services-simple-item p {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    line-clamp: 2;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

/* Editor media modal polish 20260622 */
.ckeditor-upload-form input[type="file"] {
    background: #fff;
    border: 1px solid #d8dee8;
    border-radius: 8px;
    padding: 11px 12px;
}

.ckeditor-upload-form input[name="alt_text"] {
    min-height: 48px;
}

/* Editor media modal scrollbar 20260622 */
.ckeditor-picker-body::-webkit-scrollbar {
    width: 10px;
}

.ckeditor-picker-body::-webkit-scrollbar-track {
    background: #eef3f8;
}

.ckeditor-picker-body::-webkit-scrollbar-thumb {
    background: #9aa8bb;
    border: 2px solid #eef3f8;
    border-radius: 999px;
}
/* Project detail slider overrides */
.detail-main .project-slider {
    display: block;
    gap: 0;
    width: 100%;
}

.detail-main .project-slider-viewport {
    border-radius: 8px;
    width: 100%;
}

.detail-main .project-slider-track img,
.detail-main .detail-cover-image {
    aspect-ratio: 16 / 9;
    display: block;
    object-fit: cover;
    width: 100%;
}

.detail-main .project-slider-controls {
    display: flex;
    justify-content: center;
    margin-top: 14px;
    width: 100%;
}

.project-slide-upload-grid {
    grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) minmax(220px, 1fr);
}

@media (max-width: 900px) {
    .project-slide-upload-grid {
        grid-template-columns: 1fr;
    }
}
/* Stable project detail image ratio */
.detail-main .project-slider .project-slider-track figure img,
.detail-main .project-slider .project-slider-track figure:not(:first-child) img,
.detail-main .project-slider img,
.detail-main .detail-cover-image {
    aspect-ratio: 16 / 9;
    height: auto;
    max-height: none;
    object-fit: cover;
    width: 100%;
}
/* Project detail title settings */
.project-detail-title {
    color: var(--project-title-color, #18212f) !important;
    font-size: var(--project-title-size, 22px) !important;
    font-weight: var(--project-title-weight, 800) !important;
}

/* Featured card admin list split 20260623 */
.featured-card-admin-icon {
    color: var(--brand);
    font-size: 28px;
}

.featured-card-admin-icon i {
    line-height: 1;
}


/* Home module spacing and compact admin cards 20260623 */
.home-module-flow {
    display: flex;
    flex-direction: column;
    gap: var(--home-module-gap, 48px);
    margin-bottom: var(--home-module-gap, 48px);
}

.home-module-flow > .section {
    margin-bottom: 0;
    margin-top: 0;
    padding-block: 0;
}

.home-module-flow > .slider-hero {
    margin-bottom: 0;
    margin-top: 0;
}

.module-gap-settings {
    margin-top: 14px;
}

.module-order-list {
    gap: 10px;
}

.module-order-list .module-row::before {
    height: 14px;
    top: 14px;
    width: 5px;
}

.module-row-main {
    gap: 10px;
    min-height: 42px;
    padding: 8px 18px;
}

.settings-fieldset {
    border: 1px solid #d7e2f0;
    border-radius: 8px;
    margin-bottom: 18px;
    padding: 18px;
}

.settings-fieldset h2 {
    font-size: 16px;
    margin: 0 0 8px;
}

.settings-fieldset > p {
    color: #667085;
    font-size: 13px;
    margin: 0 0 16px;
}

.settings-fieldset .color-field {
    height: 44px;
    min-height: 44px;
    width: 100%;
}

.home-module-flow > .stats-section {
    padding-block: 5px;
}

.home-module-flow > .stats-section .stats-title {
    line-height: 1.15;
    margin-bottom: 8px;
}

.home-module-flow > .stats-section .stats-grid {
    gap: 12px;
}

.home-module-flow > .stats-section .stats-grid article {
    padding: 14px 18px;
}

.home-module-flow > .stats-section .stats-grid span {
    margin-bottom: 6px;
}

.home-module-flow > .stats-section .stats-grid p {
    margin-top: 2px;
}

@media (max-width: 800px) {
    .home-module-flow > .stats-section {
        padding-inline: 10px;
    }

    .home-module-flow > .stats-section .stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.module-order-list .module-row-copy strong {
    font-size: 15px;
}

.module-row-description {
    font-size: 13px;
    padding: 9px 18px 11px 42px;
}

.module-order-list .drag-handle {
    height: 26px;
    width: 26px;
}

.module-order-list .module-switch {
    right: 18px;
    top: 13px;
}

@media (max-width: 800px) {
    .home-module-flow {
        gap: var(--home-module-gap-mobile, 32px);
        margin-bottom: var(--home-module-gap-mobile, 32px);
    }
}
/* Lead form and admin submissions 20260624 */
.lead-section {
    align-items: center;
    background: var(--lead-bg, #eaf4f1);
    border-radius: 8px;
    display: grid;
    gap: clamp(30px, 5vw, 72px);
    grid-template-columns: minmax(0, .92fr) minmax(360px, 1.08fr);
    padding: clamp(32px, 5vw, 68px);
}

.lead-form {
    background: var(--lead-box-bg, #dceee8);
    border: 0;
    border-radius: 8px;
    display: grid;
    gap: 10px;
    padding: 16px;
}

.lead-form > input,
.lead-form > textarea {
    background: #fff;
    border: 1px solid color-mix(in srgb, var(--brand) 38%, #9aa4b2);
    border-radius: 6px;
    color: var(--lead-text-color, #18212f);
    font: inherit;
    min-height: 46px;
    padding: 11px 14px;
    width: 100%;
}

.lead-form > textarea {
    min-height: 132px;
    resize: vertical;
}

.lead-form > input::placeholder,
.lead-form > textarea::placeholder {
    color: color-mix(in srgb, var(--lead-text-color, #18212f) 58%, transparent);
    opacity: 1;
}

.lead-form > input:focus,
.lead-form > textarea:focus {
    border-color: var(--brand);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 16%, transparent);
    outline: 0;
}

.lead-form > button {
    background: var(--brand);
    min-height: 48px;
    width: 100%;
}

.lead-section-copy {
    color: var(--lead-text-color, #18212f);
}

.lead-section-copy h2 {
    color: inherit;
    font-size: clamp(30px, 3.8vw, 48px);
    line-height: 1.12;
    margin: 18px 0 14px;
}

.lead-section-copy > p {
    color: color-mix(in srgb, var(--lead-text-color, #18212f) 76%, transparent);
    font-size: 17px;
    line-height: 1.75;
    margin: 0;
    max-width: 560px;
}

.lead-section-icon {
    align-items: center;
    background: var(--brand);
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    font-size: 24px;
    height: 58px;
    justify-content: center;
    width: 58px;
}

.lead-section-note {
    align-items: center;
    color: color-mix(in srgb, var(--lead-text-color, #18212f) 68%, transparent);
    display: flex;
    font-size: 13px;
    gap: 9px;
    margin-top: 24px;
}

.lead-section-note i {
    color: var(--brand);
}

.lead-admin-table {
    display: grid;
    gap: 8px;
}

.lead-admin-table-head,
.lead-admin-table-row {
    align-items: center;
    display: grid;
    gap: 14px;
    grid-template-columns: 1.15fr .9fr 1.45fr .9fr auto;
}

.lead-admin-table-head {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    padding: 0 14px 6px;
    text-transform: uppercase;
}

.lead-admin-table-row {
    border: 1px solid var(--line);
    border-radius: 7px;
    min-height: 66px;
    padding: 10px 14px;
}

.lead-admin-table-row > span,
.lead-admin-table-row > time,
.lead-admin-table-row > a {
    color: var(--muted);
    min-width: 0;
    overflow-wrap: anywhere;
}

.lead-admin-table-row > a {
    color: var(--brand);
    text-decoration: none;
}

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

.lead-detail-grid article,
.lead-detail-message {
    border: 1px solid var(--line);
    border-radius: 7px;
    padding: 16px;
}

.lead-detail-grid span,
.lead-detail-message > span {
    color: var(--muted);
    display: block;
    font-size: 12px;
    font-weight: 700;
    margin-bottom: 6px;
}

.lead-detail-grid a {
    color: var(--brand);
    font-weight: 700;
    text-decoration: none;
}

.lead-detail-message {
    margin-top: 12px;
}

.lead-detail-message p {
    line-height: 1.7;
    margin: 0;
}

@media (max-width: 800px) {
    .lead-section {
        grid-template-columns: 1fr;
        padding: 24px 14px;
    }

    .lead-section-copy h2 {
        font-size: 30px;
    }

    .lead-admin-table-head {
        display: none;
    }

    .lead-admin-table-row {
        align-items: start;
        grid-template-columns: 1fr;
    }

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

.lead-detail-grid {
        grid-template-columns: 1fr;
    }
}

/* FAQ module final overrides 20260628 */
body .faq-section .faq-list {
    gap: var(--faq-gap, 12px);
}

body .faq-section .faq-list details {
    background: var(--faq-card-bg, #ffffff) !important;
    border-color: var(--faq-card-border, var(--line)) !important;
    border-radius: var(--faq-card-radius, 8px) !important;
    overflow: hidden;
    padding: 0 !important;
}

body .faq-section .faq-list details[open] {
    background: var(--faq-card-bg, #ffffff) !important;
}

body .faq-section .faq-list summary {
    align-items: center;
    color: var(--faq-question-color, var(--ink));
    display: flex;
    font-size: var(--faq-question-size, 17px);
    font-weight: var(--faq-question-weight, 700);
    gap: 14px;
    justify-content: space-between;
    padding: 16px;
}

body .faq-section .faq-list details[open] summary {
    background: var(--faq-active-bg, #f4f8fb);
}

body .faq-section .faq-list summary::after {
    color: var(--faq-icon-color, var(--brand)) !important;
}

body .faq-section .faq-answer,
body .faq-section .faq-answer p,
body .faq-section .page-content.faq-answer,
body .faq-section .page-content.faq-answer p {
    color: var(--faq-answer-color, var(--muted));
    font-size: var(--faq-answer-size, 15px);
    font-weight: var(--faq-answer-weight, 400);
}

body .faq-section .faq-answer,
body .faq-section .page-content.faq-answer {
    padding: 0 16px 16px;
}

.service-admin-row.faq-admin-row {
    grid-template-columns: 34px 64px minmax(0, 1fr) 170px 170px;
}

.service-admin-row.faq-admin-row .admin-row-check {
    grid-column: auto;
}

.service-admin-row.faq-admin-row .row-actions {
    display: flex;
    gap: 8px;
    grid-column: auto;
    justify-content: flex-end;
}

.service-admin-row.faq-admin-row .row-actions .button,
.service-admin-row.faq-admin-row .row-actions button {
    margin: 0;
    min-width: 74px;
}

@media (max-width: 900px) {
    .service-admin-row.faq-admin-row {
        grid-template-columns: 34px 64px minmax(0, 1fr);
    }

    .service-admin-row.faq-admin-row .admin-row-check,
    .service-admin-row.faq-admin-row .row-actions {
        grid-column: 1 / -1;
        justify-content: flex-start;
    }
}
/* Team module 20260624 */
.team-section-heading{text-align:center;margin-bottom:30px}.team-align-left .team-section-heading{text-align:left}.team-align-right .team-section-heading{text-align:right}.team-section-heading h1,.team-section-heading h2{margin:0}.team-section-heading p{color:var(--muted);margin:9px 0 0}
.team-public-grid{display:grid;gap:28px;grid-template-columns:repeat(var(--team-count,4),minmax(0,1fr));justify-content:center}.team-archive-grid{--team-count:4}.team-public-card{text-align:center;min-width:0}.team-photo-link{display:block}.team-public-card img{aspect-ratio:1/1;border:var(--team-image-border,0) solid var(--team-image-border-color,#146c5f);border-radius:var(--team-image-radius,8px);display:block;object-fit:cover;width:100%}.team-public-card h3{font-size:var(--team-name-size,20px);font-weight:var(--team-name-weight,700);margin:14px 0 4px}.team-public-card h3 a{color:var(--team-name-color,#18212f);text-decoration:none}.team-public-card>p{color:var(--team-position-color,#667085);font-size:var(--team-position-size,15px);font-weight:var(--team-position-weight,400);margin:0}.team-socials{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin-top:12px}.team-socials a{align-items:center;border:1px solid var(--line);border-radius:50%;color:var(--brand);display:inline-flex;height:34px;justify-content:center;text-decoration:none;width:34px}
.team-detail-hero{align-items:center;display:grid;gap:38px;grid-template-columns:minmax(260px,420px) 1fr}.team-detail-hero img{border-radius:8px;width:100%}.team-detail-position{color:var(--muted);font-size:20px}.team-detail-contacts{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.team-detail-contacts a{align-items:center;border:1px solid var(--line);border-radius:6px;color:var(--brand);display:inline-flex;gap:7px;padding:9px 12px;text-decoration:none}.team-detail-content{margin-top:36px}.team-contact-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:800px){.team-public-grid,.team-archive-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.team-detail-hero{grid-template-columns:1fr}.team-contact-grid{grid-template-columns:1fr}.team-public-card h3{font-size:16px}.team-socials a{height:30px;width:30px}}

/* Keep team card size stable when fewer than four members are visible */
@media (min-width: 801px) {
    .team-public-grid {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }

    .team-public-grid .team-public-card {
        flex: 0 0 calc((100% - 84px) / 4);
        max-width: calc((100% - 84px) / 4);
    }
}

/* Team names use team typography instead of the global link typography */
.site-main .team-public-card h3,
.site-main .team-public-card h3 a {
    font-family: var(--site-heading-font-family);
    font-size: var(--team-name-size, 20px);
    font-weight: var(--team-name-weight, 700);
    line-height: 1.25;
}

.site-main .team-public-card h3 a {
    color: var(--team-name-color, #18212f);
}

@media (max-width: 800px) {
    .site-main .team-public-card h3,
    .site-main .team-public-card h3 a {
        font-size: var(--team-name-size, 20px);
    }
}

/* Map contact module */
@media (max-width: 760px) {
    .map-contact-section {
        grid-template-columns: 1fr;
        padding: 22px 14px;
    }

    .map-contact-map-left .map-frame,
    .map-contact-contact-left .map-contact-content {
        order: 1;
    }

    .map-contact-map-left .map-contact-content,
    .map-contact-contact-left .map-frame {
        order: 2;
    }

    .map-contact-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .map-contact-actions .button {
        justify-content: center;
        min-width: 0;
    }
}

@media (max-width: 420px) {
    .map-contact-actions {
        grid-template-columns: 1fr;
    }
}
