.rs-public-body {
    min-height: 100vh;
    background: var(--rs-bg-image);
    color: var(--rs-text);
}

.rs-public-main {
    min-height: 70vh;
}

.rs-landing {
    padding: 2rem 0 4.5rem;
}

.rs-home-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
    gap: 2rem;
    align-items: center;
    padding-top: clamp(2.5rem, 7vw, 5rem);
    padding-bottom: 3rem;
}

.rs-home-hero__copy h1,
.rs-section-title-block h2,
.rs-public-page h1 {
    margin: 0.65rem 0 1rem;
    color: var(--rs-text);
    font-size: clamp(2.15rem, 5vw, 4.5rem);
    line-height: 0.98;
    letter-spacing: -0.065em;
}

.rs-section-title-block h2,
.rs-public-page h1 {
    font-size: clamp(1.8rem, 3vw, 3rem);
    line-height: 1.08;
}

.rs-home-hero__copy p,
.rs-section-title-block p,
.rs-public-page__lead,
.rs-home-panel p,
.rs-home-panel li {
    color: var(--rs-text-muted);
    font-size: 1.02rem;
    line-height: 1.8;
}

.rs-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--rs-accent);
    font-size: 0.76rem;
    font-weight: 300;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

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

.rs-public-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0.7rem 1.1rem;
    border: 1px solid transparent;
    border-radius: 0;
    font-weight: 300;
    line-height: 1;
    text-decoration: none;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
}

.rs-public-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--rs-shadow-sm);
}

.rs-public-btn--solid {
    background: var(--rs-accent-strong);
    color: #fff;
}

.rs-public-btn--outline,
.rs-public-btn--ghost {
    border-color: var(--rs-border-strong);
    background: var(--rs-panel-strong);
    color: var(--rs-text);
}

.rs-home-panel,
.rs-clean-card,
.rs-clean-form {
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: var(--rs-panel-strong);
    box-shadow: var(--rs-shadow-sm);
    backdrop-filter: blur(14px);
}

.rs-home-panel {
    padding: clamp(1.25rem, 2.5vw, 2rem);
}

.rs-home-panel strong {
    display: block;
    margin: 0.7rem 0 0.4rem;
    color: var(--rs-text);
    font-size: clamp(1.45rem, 2.5vw, 2rem);
    letter-spacing: -0.04em;
}

.rs-home-panel ul {
    display: grid;
    gap: 0.5rem;
    margin: 1rem 0 0;
    padding-left: 1.2rem;
}

.rs-public-section,
.rs-public-page {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
}

.rs-section-title-block {
    max-width: 820px;
    margin: 0 auto 1.75rem;
    text-align: center;
}

.rs-clean-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
}

.rs-clean-grid--portfolio {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.rs-clean-card {
    display: flex;
    min-height: 118px;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.15rem;
    color: var(--rs-text);
    text-decoration: none;
}

.rs-clean-card strong,
.rs-clean-card span {
    color: var(--rs-text);
    font-size: 1rem;
    font-weight: 300;
    letter-spacing: -0.02em;
}

.rs-clean-card small,
.rs-clean-card p {
    color: var(--rs-text-muted);
    line-height: 1.65;
}

.rs-public-page {
    max-width: 1040px;
}

.rs-public-page__image {
    width: 100%;
    max-height: 460px;
    object-fit: cover;
    margin: 1.5rem 0;
    border-radius: 0;
    box-shadow: var(--rs-shadow-sm);
}

.rs-public-content {
    color: var(--rs-text);
    font-size: 1.02rem;
    line-height: 1.85;
}

.rs-public-content img {
    max-width: 100%;
    height: auto;
    border-radius: 0;
}

.rs-contact-grid {
    display: grid;
    grid-template-columns: 320px minmax(0, 1fr);
    gap: 1.25rem;
    align-items: start;
}

.rs-clean-form {
    display: grid;
    gap: 0.9rem;
    padding: 1.25rem;
}

.rs-clean-form .rs-label {
    display: grid;
    gap: 0.5rem;
}

@media (max-width: 991.98px) {
    .rs-home-hero,
    .rs-contact-grid {
        grid-template-columns: 1fr;
    }

    .rs-clean-grid,
    .rs-clean-grid--portfolio {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .rs-clean-grid,
    .rs-clean-grid--portfolio {
        grid-template-columns: 1fr;
    }

    .rs-landing {
        padding-top: 1rem;
    }
}

.rs-public-btn--icon {
    width: 42px;
    min-width: 42px;
    padding-right: 0;
    padding-left: 0;
}

.rs-public-btn--icon svg {
    width: 1.05rem;
    height: 1.05rem;
}

.rs-public-btn--icon span:not(.rs-sr-only) {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}


/* F3 shared background for public screens */
.rs-public-body {
    background-image:
        linear-gradient(135deg, rgba(244, 248, 252, 0.58), rgba(232, 238, 245, 0.42)),
        var(--rs-bg-art),
        var(--rs-bg-image);
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-position: center, center, center;
    background-size: cover, cover, cover;
    background-attachment: fixed, fixed, fixed;
}

html[data-rs-theme="gelap"] .rs-public-body {
    background-image:
        linear-gradient(135deg, rgba(13, 17, 22, 0.76), rgba(9, 13, 18, 0.70)),
        var(--rs-bg-art),
        var(--rs-bg-image);
}

/* F4 public standard layout */
.rs-public-body {
    overflow-x: hidden;
}

.rs-public-main {
    position: relative;
    z-index: 1;
    min-height: 64vh;
    padding-top: 0;
}

.rs-site-header {
    position: sticky;
    top: 0;
    z-index: 30;
    padding: 1rem 0 0.35rem;
    pointer-events: none;
}

.rs-site-header__inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
    min-height: 58px;
    pointer-events: auto;
}

.rs-site-brand {
    display: inline-flex;
    align-items: center;
    min-width: 0;
    gap: 0.8rem;
    color: var(--rs-text);
    text-decoration: none;
}

.rs-site-brand:hover {
    color: var(--rs-text);
}

.rs-site-brand__mark,
.rs-site-brand img {
    display: inline-grid;
    place-items: center;
    width: 42px;
    height: 42px;
    flex: 0 0 auto;
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: var(--rs-panel-strong);
    color: var(--rs-text);
    box-shadow: var(--rs-shadow-sm);
    object-fit: cover;
    font-weight: 300;
}

html[data-rs-theme="gelap"] .rs-site-brand__mark,
html[data-rs-theme="gelap"] .rs-site-brand img {
    background: rgba(255, 255, 255, 0.07);
}

.rs-site-brand strong {
    overflow: hidden;
    color: var(--rs-text);
    font-size: 1.05rem;
    font-weight: 300;
    letter-spacing: 0.04em;
    text-overflow: ellipsis;
    text-transform: uppercase;
    white-space: nowrap;
}

.rs-site-nav {
    display: inline-flex;
    justify-self: center;
    align-items: center;
    gap: 0.2rem;
    min-width: 0;
    padding: 0.35rem;
    border: 1px solid rgba(15, 23, 42, 0.05);
    border-radius: 0;
    background: rgba(255, 255, 255, 0.38);
    backdrop-filter: blur(18px);
}

html[data-rs-theme="gelap"] .rs-site-nav {
    border-color: rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.045);
}

.rs-site-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 38px;
    padding: 0.45rem 0.9rem;
    border-radius: 0;
    color: var(--rs-text-muted);
    font-size: 0.94rem;
    font-weight: 300;
    text-decoration: none;
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.rs-site-nav a:hover {
    background: var(--rs-panel-strong);
    color: var(--rs-text);
    transform: translateY(-1px);
}

.rs-site-actions {
    display: inline-flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.65rem;
}

.rs-site-actions .rs-theme-toggle,
.rs-site-actions .rs-public-btn--icon {
    width: 46px;
    height: 46px;
    min-width: 46px;
    min-height: 46px;
    border-radius: 0;
}

.rs-site-actions .rs-public-btn--icon {
    padding: 0;
}

.rs-site-footer {
    position: relative;
    z-index: 1;
    padding: clamp(2.75rem, 5vw, 4rem) 0 1.35rem;
    border-top: 1px solid rgba(148, 163, 184, 0.18);
    background: linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.34));
}

html[data-rs-theme="gelap"] .rs-site-footer {
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.18));
}

.rs-site-footer__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(160px, 0.7fr) minmax(180px, 0.8fr);
    gap: clamp(1rem, 4vw, 4rem);
    align-items: start;
}

.rs-site-brand--footer .rs-site-brand__mark {
    width: 38px;
    height: 38px;
    border-radius: 0;
}

.rs-site-footer p,
.rs-site-footer a,
.rs-site-footer__bottom {
    color: var(--rs-text-muted);
    font-size: 0.94rem;
    line-height: 1.75;
}

.rs-site-footer p {
    max-width: 620px;
    margin: 0.9rem 0 0;
}

.rs-site-footer h3 {
    margin: 0 0 0.85rem;
    color: var(--rs-text);
    font-size: 0.86rem;
    font-weight: 300;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.rs-site-footer__nav,
.rs-site-footer__contact {
    display: grid;
    gap: 0.25rem;
}

.rs-site-footer a {
    text-decoration: none;
}

.rs-site-footer a:hover {
    color: var(--rs-text);
}

.rs-site-footer__bottom {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: clamp(2rem, 4vw, 3rem);
    padding-top: 1rem;
    border-top: 1px solid rgba(148, 163, 184, 0.18);
}

.rs-home-hero {
    min-height: clamp(540px, 70vh, 760px);
    padding-top: clamp(3.25rem, 7vw, 6.5rem);
}

.rs-home-hero__copy h1 {
    max-width: 720px;
    font-weight: 300;
}

.rs-home-panel,
.rs-clean-card,
.rs-clean-form {
    background: color-mix(in srgb, var(--rs-panel-strong) 88%, transparent);
}

.rs-public-section {
    position: relative;
    padding-top: clamp(3.25rem, 7vw, 5.5rem);
}

.rs-clean-card {
    transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.rs-clean-card:hover {
    transform: translateY(-2px);
    border-color: var(--rs-border-strong);
}

@media (max-width: 991.98px) {
    .rs-site-header {
        position: relative;
        padding-top: 0.75rem;
    }

    .rs-site-header__inner {
        grid-template-columns: minmax(0, 1fr) auto;
        min-height: 54px;
    }

    .rs-site-nav {
        display: none;
    }

    .rs-home-hero {
        min-height: 0;
        padding-top: clamp(3rem, 12vw, 5rem);
        padding-bottom: 2rem;
    }

    .rs-site-footer__grid {
        grid-template-columns: 1fr 1fr;
    }

    .rs-site-footer__brand-block {
        grid-column: 1 / -1;
    }
}

@media (max-width: 575.98px) {
    .rs-site-header__inner {
        padding-right: 0.15rem;
        padding-left: 0.15rem;
    }

    .rs-site-brand {
        gap: 0.7rem;
    }

    .rs-site-brand__mark,
    .rs-site-brand img {
        width: 38px;
        height: 38px;
        border-radius: 0;
    }

    .rs-site-brand strong {
        max-width: 148px;
        font-size: 1rem;
        letter-spacing: 0.06em;
    }

    .rs-site-actions {
        gap: 0.45rem;
    }

    .rs-site-actions .rs-theme-toggle,
    .rs-site-actions .rs-public-btn--icon {
        width: 42px;
        height: 42px;
        min-width: 42px;
        min-height: 42px;
    }

    .rs-landing {
        padding-bottom: 3rem;
    }

    .rs-home-hero {
        gap: 1.2rem;
        padding-top: 3rem;
    }

    .rs-home-hero__copy h1,
    .rs-section-title-block h2,
    .rs-public-page h1 {
        font-size: clamp(2rem, 13vw, 3.2rem);
        line-height: 1.02;
        letter-spacing: -0.055em;
    }

    .rs-home-hero__copy p,
    .rs-section-title-block p,
    .rs-public-page__lead,
    .rs-home-panel p,
    .rs-home-panel li {
        font-size: 0.95rem;
        line-height: 1.72;
    }

    .rs-public-actions {
        gap: 0.55rem;
        margin-top: 1.2rem;
    }

    .rs-public-btn {
        min-height: 40px;
        padding: 0.65rem 1rem;
        font-size: 0.9rem;
    }

    .rs-home-panel {
        padding: 1.1rem;
        border-radius: 0;
    }

    .rs-clean-card {
        min-height: 96px;
        padding: 1rem;
        border-radius: 0;
    }

    .rs-public-section,
    .rs-public-page {
        padding-top: 2.75rem;
        padding-bottom: 2.75rem;
    }

    .rs-site-footer {
        padding-top: 2.5rem;
    }

    .rs-site-footer__grid {
        grid-template-columns: 1fr;
        gap: 1.4rem;
    }

    .rs-site-footer__nav {
        display: none;
    }

    .rs-site-footer h3 {
        margin-bottom: 0.45rem;
        font-size: 0.78rem;
    }

    .rs-site-footer p,
    .rs-site-footer a,
    .rs-site-footer__bottom {
        font-size: 0.88rem;
        line-height: 1.65;
    }

    .rs-site-footer__bottom {
        flex-direction: column;
        gap: 0.35rem;
        margin-top: 1.4rem;
    }
}

/* F4 refinement: public home renders real sections, not internal model list */
.rs-clean-home,
.rs-clean-home * {
    font-weight: 300 !important;
}

.rs-clean-home .rs-home-panel strong,
.rs-clean-home .rs-clean-card strong,
.rs-clean-home .rs-service-item strong,
.rs-clean-home h1,
.rs-clean-home h2 {
    font-weight: 300 !important;
}

.rs-section-about {
    padding-top: clamp(2.5rem, 5vw, 4rem);
}

.rs-value-grid,
.rs-workflow-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
}

.rs-service-accordion,
.rs-faq-list {
    display: grid;
    gap: 0.85rem;
    max-width: 920px;
    margin: 0 auto;
}

.rs-service-item {
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: color-mix(in srgb, var(--rs-panel-strong) 88%, transparent);
    box-shadow: var(--rs-shadow-sm);
    backdrop-filter: blur(14px);
    overflow: hidden;
}

.rs-service-item summary {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 0.9rem;
    align-items: center;
    min-height: 68px;
    padding: 1rem 1.15rem;
    color: var(--rs-text);
    cursor: pointer;
    list-style: none;
}

.rs-service-item summary::-webkit-details-marker {
    display: none;
}

.rs-service-item summary span {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: var(--rs-panel);
    color: var(--rs-text-muted);
    font-size: 0.82rem;
    letter-spacing: 0.08em;
}

.rs-service-item p {
    margin: -0.25rem 1.15rem 1.15rem 4.05rem;
    color: var(--rs-text-muted);
    line-height: 1.75;
}

.rs-portfolio-card {
    min-height: 172px;
}

.rs-portfolio-card a {
    width: fit-content;
    margin-top: auto;
    color: var(--rs-text);
    font-size: 0.9rem;
    text-decoration: none;
}

.rs-portfolio-card a:hover {
    color: var(--rs-accent);
}

.rs-faq-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.78fr);
    gap: 1rem;
    align-items: start;
}

.rs-faq-list {
    max-width: none;
    margin: 0;
}

.rs-faq-list > .rs-eyebrow {
    margin-bottom: 0.2rem;
}

.rs-cta-panel {
    position: sticky;
    top: 96px;
}

@media (max-width: 991.98px) {
    .rs-value-grid,
    .rs-workflow-grid,
    .rs-faq-cta {
        grid-template-columns: 1fr;
    }

    .rs-cta-panel {
        position: static;
    }
}

@media (max-width: 575.98px) {
    .rs-section-title-block {
        text-align: left;
    }

    .rs-service-item {
        border-radius: 0;
    }

    .rs-service-item summary {
        min-height: 60px;
        padding: 0.95rem;
    }

    .rs-service-item summary span {
        width: 34px;
        height: 34px;
    }

    .rs-service-item p {
        margin: -0.15rem 0.95rem 0.95rem 3.75rem;
        font-size: 0.9rem;
    }

    .rs-portfolio-card {
        min-height: 132px;
    }
}

/* F4 anchor/detail refinement */
html {
    scroll-behavior: smooth;
}

.rs-site-nav a[href*="#layanan"] {
    display: inline-flex;
}

.rs-home-panel--about,
.rs-portfolio-card,
.rs-section-title-block {
    position: relative;
}

.rs-detail-dot {
    position: absolute;
    top: 1rem;
    right: 1rem;
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: color-mix(in srgb, var(--rs-panel-strong) 82%, transparent);
    color: var(--rs-text-muted);
    font-size: 1rem;
    line-height: 1;
    letter-spacing: -0.12em;
    text-decoration: none;
    box-shadow: var(--rs-shadow-sm);
    transition: transform 0.18s ease, color 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.rs-detail-dot:hover {
    transform: translateY(-1px);
    border-color: var(--rs-border-strong);
    background: var(--rs-panel-strong);
    color: var(--rs-text);
}

.rs-detail-dot--section {
    position: static;
    margin-top: 0.75rem;
}

.rs-portfolio-card {
    padding-right: 4.2rem;
}

.rs-portfolio-card .rs-detail-dot {
    top: 0.9rem;
    right: 0.9rem;
}

.rs-public-section[id],
.rs-home-hero[id],
.rs-section[id],
.rs-hero[id] {
    scroll-margin-top: 92px;
}

.rs-faq-cta[id] {
    scroll-margin-top: 72px;
}

@media (max-width: 575.98px) {
    .rs-public-section[id],
    .rs-home-hero[id],
    .rs-section[id],
    .rs-hero[id] {
        scroll-margin-top: 24px;
    }

    .rs-detail-dot {
        width: 36px;
        height: 36px;
        top: 0.85rem;
        right: 0.85rem;
    }

    .rs-home-panel--about {
        padding-top: 3.25rem;
    }

    .rs-portfolio-card {
        padding-right: 3.75rem;
    }
}

/* F4 public detail refinement */
.rs-public-detail-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.rs-public-page__media {
    margin: 1.4rem 0 1.25rem;
}

.rs-public-page__media .rs-public-page__image {
    display: block;
    margin: 0;
}

.rs-portfolio-detail-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.85rem;
    margin: 1rem 0 1.25rem;
}

.rs-portfolio-detail-meta > div,
.rs-public-content-card {
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: color-mix(in srgb, var(--rs-panel-strong) 88%, transparent);
    box-shadow: var(--rs-shadow-sm);
}

.rs-portfolio-detail-meta > div {
    display: grid;
    gap: 0.35rem;
    min-height: 86px;
    padding: 1rem;
}

.rs-portfolio-detail-meta span {
    color: var(--rs-text-muted);
    font-size: 0.76rem;
    font-weight: 300;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.rs-portfolio-detail-meta strong,
.rs-portfolio-detail-meta a {
    color: var(--rs-text);
    font-size: 1rem;
    font-weight: 300;
    text-decoration: none;
}

.rs-portfolio-detail-meta a:hover {
    text-decoration: underline;
}

.rs-public-content-card {
    display: block;
    padding: clamp(1.25rem, 2.5vw, 2rem);
}

.rs-related-section {
    margin-top: clamp(2.25rem, 4vw, 3.5rem);
}

.rs-section-title-block--left {
    margin-left: 0;
    text-align: left;
}

@media (max-width: 767.98px) {
    .rs-public-detail-head {
        align-items: flex-start;
    }

    .rs-portfolio-detail-meta {
        grid-template-columns: 1fr;
    }
}

/* F4 accent + mobile offcanvas polish */
.rs-public-body {
    --rs-public-accent: var(--rs-accent);
}

.rs-site-header {
    position: sticky;
    top: 0;
    z-index: 80;
    padding-top: 0.85rem;
    padding-bottom: 0.35rem;
}

.rs-site-header::before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 88px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--rs-bg) 82%, transparent), transparent);
    pointer-events: none;
    z-index: -1;
}

.rs-site-brand__mark,
.rs-site-brand img {
    color: var(--rs-public-accent);
    border-color: color-mix(in srgb, var(--rs-public-accent) 18%, var(--rs-border));
    box-shadow: 0 16px 38px color-mix(in srgb, var(--rs-public-accent) 13%, transparent);
}

.rs-site-nav a {
    position: relative;
}

.rs-site-nav a::after,
.rs-site-offcanvas__nav a::after {
    content: "";
    position: absolute;
    right: 0.9rem;
    bottom: 0.38rem;
    left: 0.9rem;
    height: 2px;
    border-radius: 0;
    background: var(--rs-public-accent);
    opacity: 0;
    transform: scaleX(0.5);
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.rs-site-nav a:hover,
.rs-site-nav a.is-active,
.rs-site-offcanvas__nav a:hover,
.rs-site-offcanvas__nav a.is-active {
    color: var(--rs-text);
}

.rs-site-nav a:hover::after,
.rs-site-nav a.is-active::after,
.rs-site-offcanvas__nav a:hover::after,
.rs-site-offcanvas__nav a.is-active::after {
    opacity: 1;
    transform: scaleX(1);
}

.rs-eyebrow,
.rs-clean-card > span,
.rs-service-item summary span,
.rs-detail-dot:hover,
.rs-portfolio-card a:hover {
    color: var(--rs-public-accent);
}

.rs-eyebrow::before {
    content: "";
    width: 0.38rem;
    height: 0.38rem;
    border-radius: 0;
    background: var(--rs-public-accent);
    box-shadow: 0 0 0 6px var(--rs-accent-soft);
}

.rs-public-btn--solid {
    background: var(--rs-accent-strong);
    color: var(--rs-accent-contrast, #fff);
    box-shadow: 0 16px 34px color-mix(in srgb, var(--rs-public-accent) 16%, transparent);
}

.rs-public-btn--solid:hover {
    border-color: color-mix(in srgb, var(--rs-public-accent) 28%, transparent);
    box-shadow: 0 18px 40px color-mix(in srgb, var(--rs-public-accent) 24%, transparent);
}

.rs-public-btn--outline:hover,
.rs-public-btn--ghost:hover,
.rs-detail-dot:hover,
.rs-clean-card:hover,
.rs-service-item[open] {
    border-color: color-mix(in srgb, var(--rs-public-accent) 28%, var(--rs-border-strong));
}

.rs-service-item[open] summary span,
.rs-clean-card:hover > span {
    background: var(--rs-accent-soft);
    border-color: color-mix(in srgb, var(--rs-public-accent) 30%, var(--rs-border));
}

.rs-clean-card,
.rs-service-item,
.rs-home-panel {
    overflow: hidden;
}

.rs-clean-card::before,
.rs-service-item::before,
.rs-home-panel::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: 3px;
    background: linear-gradient(180deg, var(--rs-public-accent), transparent 72%);
    opacity: 0;
    transition: opacity 0.18s ease;
}

.rs-clean-card:hover::before,
.rs-service-item[open]::before,
.rs-home-panel:hover::before {
    opacity: 0.55;
}

.rs-site-menu-toggle {
    display: none;
}

.rs-site-offcanvas {
    position: fixed;
    inset: 0;
    z-index: 90;
    pointer-events: none;
    visibility: hidden;
}

.rs-site-offcanvas.is-open {
    pointer-events: auto;
    visibility: visible;
}

.rs-site-offcanvas__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(9, 13, 18, 0.34);
    opacity: 0;
    transition: opacity 0.2s ease;
}

.rs-site-offcanvas.is-open .rs-site-offcanvas__backdrop {
    opacity: 1;
}

.rs-site-offcanvas__panel {
    position: absolute;
    top: 0.75rem;
    right: max(0.75rem, calc((100vw - var(--rs-container)) / 2));
    display: grid;
    gap: 0.85rem;
    width: min(320px, calc(100vw - 1.5rem));
    padding: 0.85rem;
    border: 1px solid var(--rs-border);
    border-radius: 0;
    background: color-mix(in srgb, var(--rs-panel-strong) 94%, transparent);
    box-shadow: var(--rs-shadow-md);
    backdrop-filter: blur(20px);
    transform: translateY(-8px) scale(0.98);
    opacity: 0;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.rs-site-offcanvas.is-open .rs-site-offcanvas__panel {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.rs-site-offcanvas__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.25rem 0.25rem 0.45rem 0.65rem;
    color: var(--rs-text-muted);
    font-size: 0.75rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.rs-site-offcanvas__nav {
    display: grid;
    gap: 0.35rem;
}

.rs-site-offcanvas__nav a {
    position: relative;
    display: flex;
    align-items: center;
    min-height: 48px;
    padding: 0.75rem 0.9rem;
    border: 1px solid transparent;
    border-radius: 0;
    color: var(--rs-text);
    text-decoration: none;
    transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.rs-site-offcanvas__nav a:hover,
.rs-site-offcanvas__nav a.is-active {
    border-color: color-mix(in srgb, var(--rs-public-accent) 22%, var(--rs-border));
    background: var(--rs-accent-soft);
}

html.rs-menu-open,
html.rs-menu-open body {
    overflow: hidden;
}

@media (max-width: 991.98px) {
    .rs-site-header {
        position: sticky;
        padding-top: 0.65rem;
        padding-bottom: 0.45rem;
    }

    .rs-site-header__inner {
        grid-template-columns: minmax(0, 1fr) auto;
        min-height: 54px;
    }

    .rs-site-menu-toggle {
        display: inline-grid;
    }

    .rs-site-offcanvas__panel {
        top: 0.65rem;
        right: 0.65rem;
    }

    .rs-home-hero[id],
    .rs-public-section[id],
    .rs-section[id],
    .rs-hero[id] {
        scroll-margin-top: 86px;
    }
}

@media (max-width: 575.98px) {
    .rs-site-header::before {
        height: 76px;
    }

    .rs-site-brand strong {
        max-width: 132px;
    }

    .rs-site-offcanvas__panel {
        border-radius: 0;
    }

    .rs-home-hero[id],
    .rs-public-section[id],
    .rs-section[id],
    .rs-hero[id] {
        scroll-margin-top: 76px;
    }
}

.rs-clean-card,
.rs-service-item,
.rs-home-panel {
    position: relative;
}

/* F4 correction: visible mobile menu icon, stronger offcanvas, and warmer accent details */
.rs-site-actions .rs-public-btn--icon .rs-icon,
.rs-site-offcanvas__head .rs-public-btn--icon .rs-icon {
    display: block;
    width: 1.15rem;
    height: 1.15rem;
    color: currentColor;
    pointer-events: none;
}

.rs-site-menu-toggle {
    color: var(--rs-text);
    border-color: color-mix(in srgb, var(--rs-public-accent) 22%, var(--rs-border));
    background: color-mix(in srgb, var(--rs-panel-strong) 86%, transparent);
}

.rs-site-menu-toggle:hover,
.rs-site-menu-toggle[aria-expanded="true"] {
    color: var(--rs-public-accent);
    background: var(--rs-accent-soft);
    border-color: color-mix(in srgb, var(--rs-public-accent) 42%, var(--rs-border));
}

.rs-site-offcanvas {
    display: block;
}

.rs-site-offcanvas.is-open {
    pointer-events: auto;
    visibility: visible;
}

.rs-site-offcanvas.is-open .rs-site-offcanvas__panel {
    pointer-events: auto;
}

.rs-site-offcanvas__panel {
    border-color: color-mix(in srgb, var(--rs-public-accent) 18%, var(--rs-border));
}

.rs-site-offcanvas__head .rs-public-btn--icon {
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
    color: var(--rs-text);
    border-color: color-mix(in srgb, var(--rs-public-accent) 20%, var(--rs-border));
    background: var(--rs-panel);
}

.rs-clean-card,
.rs-service-item,
.rs-home-panel {
    border-color: color-mix(in srgb, var(--rs-public-accent) 9%, var(--rs-border));
}

.rs-clean-card::after,
.rs-service-item::after,
.rs-home-panel::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 0;
    background:
        radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--rs-public-accent) 12%, transparent), transparent 34%),
        linear-gradient(135deg, color-mix(in srgb, var(--rs-public-accent) 5%, transparent), transparent 42%);
    opacity: 0.58;
    pointer-events: none;
}

.rs-clean-card > *,
.rs-service-item > *,
.rs-home-panel > * {
    position: relative;
    z-index: 1;
}

.rs-clean-card:hover,
.rs-service-item:hover,
.rs-home-panel:hover,
.rs-service-item[open] {
    border-color: color-mix(in srgb, var(--rs-public-accent) 30%, var(--rs-border-strong));
    box-shadow:
        var(--rs-shadow-sm),
        0 18px 42px color-mix(in srgb, var(--rs-public-accent) 10%, transparent);
}

.rs-clean-card > span,
.rs-service-item summary span {
    border-color: color-mix(in srgb, var(--rs-public-accent) 24%, var(--rs-border));
    background: color-mix(in srgb, var(--rs-accent-soft) 70%, var(--rs-panel));
}

.rs-workflow-grid .rs-clean-card > span,
.rs-value-grid .rs-clean-card > span {
    display: inline-grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid color-mix(in srgb, var(--rs-public-accent) 24%, var(--rs-border));
    border-radius: 0;
    background: color-mix(in srgb, var(--rs-accent-soft) 78%, var(--rs-panel));
    color: var(--rs-public-accent);
    font-size: 0.78rem;
    letter-spacing: 0.08em;
}

.rs-portfolio-card {
    border-top-color: color-mix(in srgb, var(--rs-public-accent) 24%, var(--rs-border));
}

.rs-detail-dot {
    color: var(--rs-public-accent);
    border-color: color-mix(in srgb, var(--rs-public-accent) 18%, var(--rs-border));
}

.rs-public-section::before {
    content: "";
    position: absolute;
    top: 1.25rem;
    left: 50%;
    width: min(620px, 78vw);
    height: 1px;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--rs-public-accent) 18%, transparent), transparent);
    opacity: 0.65;
    pointer-events: none;
}

html[data-rs-theme="gelap"] .rs-clean-card::after,
html[data-rs-theme="gelap"] .rs-service-item::after,
html[data-rs-theme="gelap"] .rs-home-panel::after {
    opacity: 0.42;
}

@media (max-width: 991.98px) {
    .rs-site-offcanvas__panel {
        top: 4.75rem;
        right: 0.85rem;
    }
}

@media (max-width: 575.98px) {
    .rs-site-offcanvas__panel {
        top: 4.35rem;
        right: 0.65rem;
        width: min(300px, calc(100vw - 1.3rem));
    }

    .rs-public-section::before {
        left: 1rem;
        width: calc(100% - 2rem);
        transform: none;
    }
}


/* F4 public dark background polish */
html[data-rs-theme="gelap"] .rs-public-body {
    background-color: #090d11;
    background-image:
        radial-gradient(circle at 18% 34%, rgba(249, 115, 22, 0.16), transparent 29%),
        radial-gradient(circle at 80% 11%, rgba(59, 130, 246, 0.10), transparent 34%),
        linear-gradient(135deg, rgba(7, 10, 14, 0.86), rgba(9, 13, 18, 0.82)),
        var(--rs-bg-art),
        linear-gradient(135deg, #080b0f, #11161d);
}

html[data-rs-theme="gelap"] .rs-home-panel,
html[data-rs-theme="gelap"] .rs-clean-card,
html[data-rs-theme="gelap"] .rs-service-item {
    background: color-mix(in srgb, var(--rs-panel-strong) 82%, rgba(249,115,22,0.04));
    border-color: color-mix(in srgb, var(--rs-public-accent) 16%, var(--rs-border));
}

html[data-rs-theme="gelap"] .rs-site-header::before {
    background: linear-gradient(180deg, rgba(8, 11, 15, 0.76), rgba(8, 11, 15, 0));
}
.rs-client-line { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1rem; }
.rs-client-line span { border: 1px solid var(--rs-border); border-radius: 0; padding: .45rem .75rem; color: var(--rs-muted); background: color-mix(in srgb, var(--rs-surface) 86%, transparent); }

/* F7 public page polish */
.rs-public-detail-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1.25rem;
}

.rs-public-content-card {
    display: block;
    padding: clamp(1.25rem, 3vw, 2rem);
}

.rs-about-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.38fr);
    gap: 1rem;
    align-items: start;
}

.rs-about-side {
    display: grid;
    gap: 1rem;
}

.rs-about-mini-card {
    min-height: 104px;
}

.rs-contact-info-card {
    gap: 1rem;
}

.rs-contact-list {
    display: grid;
    gap: 0.9rem;
}

.rs-contact-list p {
    display: grid;
    gap: 0.15rem;
    margin: 0;
}

.rs-contact-list span,
.rs-form-actions span {
    color: var(--rs-text-muted);
    font-size: 0.82rem;
}

.rs-contact-list a {
    color: var(--rs-text);
    text-decoration: none;
}

.rs-contact-list a:hover {
    color: var(--rs-accent);
}

.rs-form-grid-2 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
}

.rs-field-error {
    color: #d94848;
    font-size: 0.8rem;
}

.rs-form-actions {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.rs-error-page {
    display: grid;
    min-height: 54vh;
    place-items: center;
}

.rs-error-card {
    max-width: 720px;
    padding: clamp(1.5rem, 4vw, 2.5rem);
    text-align: center;
}

.rs-error-card h1 {
    margin: 0.6rem 0 0.75rem;
    color: var(--rs-text);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 300;
    letter-spacing: -0.05em;
}

.rs-error-card .rs-public-actions {
    justify-content: center;
}

@media (max-width: 991.98px) {
    .rs-public-detail-head,
    .rs-about-layout {
        grid-template-columns: 1fr;
    }

    .rs-public-detail-head {
        display: grid;
    }
}

@media (max-width: 575.98px) {
    .rs-form-grid-2 {
        grid-template-columns: 1fr;
    }
}

/* F8 public dark background polish */
.rs-public-body {
    background-color: #eef3f8;
    background-image:
        linear-gradient(180deg, rgba(247, 250, 253, 0.66), rgba(235, 242, 249, 0.82)),
        var(--rs-bg-art),
        linear-gradient(135deg, #f8fafc, #e8eff6);
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-position: center top, center top, center;
    background-size: cover, cover, cover;
    background-attachment: fixed, fixed, fixed;
}

html[data-rs-theme="gelap"] .rs-public-body {
    background-color: #070b10;
    background-image:
        linear-gradient(180deg, rgba(7, 10, 14, 0.68), rgba(7, 10, 14, 0.88)),
        radial-gradient(circle at 18% 24%, rgba(249, 115, 22, 0.15), transparent 28%),
        radial-gradient(circle at 82% 10%, rgba(59, 130, 246, 0.08), transparent 30%),
        var(--rs-bg-art),
        linear-gradient(135deg, #06090d, #111820);
    background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
    background-position: center top, left top, right top, center top, center;
    background-size: cover, cover, cover, cover, cover;
    background-attachment: fixed, fixed, fixed, fixed, fixed;
}

html[data-rs-theme="gelap"] .rs-site-header::before {
    background: linear-gradient(180deg, rgba(7, 10, 14, 0.86), rgba(7, 10, 14, 0));
}

html[data-rs-theme="gelap"] .rs-site-header__inner,
html[data-rs-theme="gelap"] .rs-site-nav,
html[data-rs-theme="gelap"] .rs-home-panel,
html[data-rs-theme="gelap"] .rs-clean-card,
html[data-rs-theme="gelap"] .rs-service-item,
html[data-rs-theme="gelap"] .rs-site-footer {
    background: rgba(14, 19, 25, 0.70);
    border-color: rgba(255, 255, 255, 0.075);
    backdrop-filter: blur(18px) saturate(120%);
}

html[data-rs-theme="gelap"] .rs-home-hero__copy h1,
html[data-rs-theme="gelap"] .rs-section-title-block h2 {
    color: rgba(255, 255, 255, 0.92);
}

html[data-rs-theme="gelap"] .rs-home-hero__copy p,
html[data-rs-theme="gelap"] .rs-section-title-block p,
html[data-rs-theme="gelap"] .rs-site-footer p,
html[data-rs-theme="gelap"] .rs-site-footer a,
html[data-rs-theme="gelap"] .rs-site-footer__bottom {
    color: rgba(255, 255, 255, 0.66);
}

/* F10 public square mobile controls */
.rs-btn-svg {
    display: block;
    width: 1.15rem;
    height: 1.15rem;
    color: currentColor;
}

.rs-site-actions .rs-theme-toggle,
.rs-site-actions .btn,
.rs-public-close-btn,
.rs-offcanvas-cta,
.rs-home-action-btn,
.rs-site-offcanvas__panel,
.rs-site-offcanvas__nav a {
    border-radius: 0;
}

.rs-site-menu-toggle,
.rs-public-close-btn {
    width: 48px;
    min-width: 48px;
    height: 48px;
    padding: 0 !important;
}

.rs-site-menu-toggle {
    background: color-mix(in srgb, var(--rs-panel-strong) 92%, transparent) !important;
    border-color: color-mix(in srgb, var(--rs-public-accent) 28%, var(--rs-border)) !important;
    color: var(--rs-text) !important;
}

.rs-site-menu-toggle:hover,
.rs-site-menu-toggle[aria-expanded="true"] {
    background: var(--rs-public-accent) !important;
    border-color: var(--rs-public-accent) !important;
    color: #fff !important;
}

html[data-rs-theme="gelap"] .rs-site-menu-toggle {
    background: rgba(255, 255, 255, 0.035) !important;
    border-color: rgba(249, 115, 22, 0.32) !important;
    color: #fb923c !important;
}

html[data-rs-theme="gelap"] .rs-site-menu-toggle:hover,
html[data-rs-theme="gelap"] .rs-site-menu-toggle[aria-expanded="true"] {
    background: #f97316 !important;
    border-color: #f97316 !important;
    color: #070b10 !important;
}

.rs-public-close-btn {
    background: color-mix(in srgb, var(--rs-panel-strong) 88%, transparent) !important;
    border-color: var(--rs-border) !important;
    color: var(--rs-text) !important;
}

html[data-rs-theme="gelap"] .rs-public-close-btn {
    background: rgba(255, 255, 255, 0.045) !important;
    border-color: rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.84) !important;
}

body.rs-public-body *,
body.rs-public-body *::before,
body.rs-public-body *::after {
    border-radius: 0;
}

@media (max-width: 575.98px) {
    .rs-site-actions {
        gap: 0.45rem;
    }

    .rs-site-actions .rs-theme-toggle,
    .rs-site-actions .rs-site-menu-toggle {
        width: 44px !important;
        min-width: 44px !important;
        height: 44px !important;
        min-height: 44px !important;
    }

    .rs-home-page .rs-home-action-btn,
    .rs-site-offcanvas .rs-offcanvas-cta {
        width: 48px !important;
        min-width: 48px !important;
        height: 48px !important;
        min-height: 48px !important;
        padding: 0 !important;
        gap: 0 !important;
        font-size: 0 !important;
    }

    .rs-home-page .rs-home-action-btn .rs-btn-label,
    .rs-site-offcanvas .rs-offcanvas-cta .rs-btn-label {
        position: absolute !important;
        width: 1px !important;
        height: 1px !important;
        padding: 0 !important;
        margin: -1px !important;
        overflow: hidden !important;
        clip: rect(0, 0, 0, 0) !important;
        white-space: nowrap !important;
        border: 0 !important;
    }

    .rs-home-page .rs-home-action-btn span[aria-hidden="true"] {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 100%;
        font-size: 1rem !important;
        line-height: 1;
    }

    .rs-site-offcanvas .rs-offcanvas-cta {
        justify-self: start;
        margin-top: 0.75rem !important;
    }

    .rs-site-offcanvas .rs-offcanvas-cta .rs-btn-svg {
        width: 1.15rem;
        height: 1.15rem;
    }
}

/* F12 final public polish: precise square glass layout */
.rs-public-body {
    --rs-glass-light: rgba(255, 255, 255, 0.56);
    --rs-glass-dark: rgba(12, 17, 23, 0.70);
    overflow-x: hidden;
}

.rs-public-main {
    min-height: 0;
    padding-top: 0;
}

.rs-site-header {
    padding: 0.75rem 0;
}

.rs-site-header__inner {
    min-height: 54px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
}

.rs-site-brand {
    gap: 0.72rem;
    letter-spacing: 0.08em;
}

.rs-site-brand__mark,
.rs-logo-mark,
.rs-site-brand img {
    width: 32px;
    height: 32px;
    display: inline-grid;
    place-items: center;
    border: 1px solid var(--rs-border);
    background: var(--rs-accent-strong);
    color: var(--rs-accent-contrast, #fff);
    font-size: 0.8rem;
    font-weight: 300;
}

html[data-rs-theme="gelap"] .rs-site-brand__mark,
html[data-rs-theme="gelap"] .rs-logo-mark {
    background: #f97316;
    color: #080b0f;
    border-color: rgba(249, 115, 22, 0.55);
}

.rs-site-nav {
    min-height: 46px;
    padding: 0.22rem;
    background: color-mix(in srgb, var(--rs-panel-strong) 74%, transparent);
    border: 1px solid var(--rs-border);
    box-shadow: var(--rs-shadow-sm);
}

.rs-site-nav a {
    min-height: 38px;
    padding: 0.42rem 0.9rem;
}

.rs-site-actions .rs-theme-toggle,
.rs-site-actions .btn,
.rs-site-menu-toggle,
.rs-public-close-btn {
    width: 46px;
    min-width: 46px;
    height: 46px;
    min-height: 46px;
}

.rs-public-consult-btn {
    width: auto !important;
    min-width: 132px !important;
    padding-inline: 1rem !important;
}

.rs-hero {
    position: relative;
    min-height: clamp(520px, 69vh, 720px);
    display: flex;
    align-items: center;
    padding: clamp(3.5rem, 7vw, 6.5rem) 0 clamp(3rem, 6vw, 5rem);
    overflow: hidden;
}

.rs-hero::before {
    content: "";
    position: absolute;
    inset: -10% 0 auto 0;
    height: 110%;
    background:
        linear-gradient(90deg, color-mix(in srgb, var(--rs-bg) 24%, transparent), transparent 72%),
        var(--rs-bg-art);
    background-size: cover;
    background-position: center top;
    opacity: 0.78;
    pointer-events: none;
}

html[data-rs-theme="gelap"] .rs-hero::before {
    opacity: 0.34;
    filter: contrast(1.08) saturate(0.78);
}

.rs-hero > .container,
.rs-section > .container,
.rs-cta > .container {
    position: relative;
    z-index: 1;
}

.rs-hero h1 {
    max-width: 640px;
    margin: 0.75rem 0 1.35rem;
    color: var(--rs-text);
    font-size: clamp(3rem, 6.2vw, 5.8rem);
    font-weight: 300 !important;
    line-height: 0.95;
    letter-spacing: -0.075em;
}

.rs-hero h1 span {
    color: var(--rs-accent);
}

.rs-hero .lead {
    max-width: 540px;
    color: var(--rs-text-muted);
    font-size: clamp(1rem, 1.25vw, 1.22rem);
    line-height: 1.75;
}

.rs-home-action-btn {
    min-height: 48px;
    align-items: center;
    justify-content: center;
    gap: 0.65rem;
    font-weight: 300 !important;
}

.rs-device-stage {
    position: relative;
    min-height: 360px;
    display: grid;
    place-items: center;
}

.rs-laptop,
.rs-phone,
.rs-team-visual {
    border: 8px solid color-mix(in srgb, var(--rs-text) 84%, transparent);
    background: color-mix(in srgb, var(--rs-panel-strong) 58%, transparent);
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.18);
    backdrop-filter: blur(16px) saturate(120%);
}

.rs-laptop {
    width: min(520px, 100%);
    min-height: 238px;
    padding: 1.2rem;
}

.rs-phone {
    position: absolute;
    right: 2%;
    bottom: -2%;
    width: 176px;
    min-height: 252px;
    padding: 1rem;
}

.rs-window-bar {
    display: flex;
    justify-content: flex-end;
    gap: 0.28rem;
    margin-bottom: 0.8rem;
}

.rs-window-bar span,
.rs-phone-notch,
.rs-phone-title,
.rs-phone-total,
.rs-phone-icons i,
.rs-phone-list b,
.rs-dash-title,
.rs-dash-cards i,
.rs-dash-sidebar {
    display: block;
    background: color-mix(in srgb, var(--rs-text) 16%, transparent);
}

.rs-window-bar span {
    width: 7px;
    height: 7px;
}

.rs-dash-grid {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 1rem;
    min-height: 170px;
}

.rs-dash-sidebar {
    min-height: 100%;
}

.rs-dash-main {
    display: grid;
    gap: 0.82rem;
}

.rs-dash-title {
    width: 68%;
    height: 18px;
}

.rs-dash-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.6rem;
}

.rs-dash-cards i {
    height: 56px;
}

.rs-dash-chart {
    display: flex;
    align-items: end;
    gap: 0.42rem;
    height: 72px;
    padding-top: 0.35rem;
}

.rs-dash-chart b {
    flex: 1;
    height: 34%;
    background: var(--rs-accent);
    opacity: 0.56;
}

.rs-dash-chart b:nth-child(2) { height: 48%; }
.rs-dash-chart b:nth-child(3) { height: 66%; }
.rs-dash-chart b:nth-child(4) { height: 78%; }
.rs-dash-chart b:nth-child(5) { height: 58%; }
.rs-dash-chart b:nth-child(6) { height: 86%; }

.rs-phone > * + * {
    margin-top: 0.75rem;
}

.rs-phone-notch {
    width: 44%;
    height: 8px;
    margin-left: auto;
    margin-right: auto;
}

.rs-phone-title { width: 72%; height: 12px; }
.rs-phone-total { width: 86%; height: 48px; }
.rs-phone-icons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.45rem; }
.rs-phone-icons i { height: 38px; }
.rs-phone-list { display: grid; gap: 0.48rem; }
.rs-phone-list b { height: 14px; }

.rs-section {
    position: relative;
    padding: clamp(3.25rem, 7vw, 5.75rem) 0;
}

.rs-section-services .container,
.rs-cta-panel {
    border: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 62%, transparent);
    box-shadow: var(--rs-shadow-sm);
    backdrop-filter: blur(18px) saturate(120%);
}

.rs-section-services .container {
    padding: clamp(1.35rem, 3vw, 2.1rem);
}

.rs-section-head h2 {
    margin: 0.45rem 0 0;
    color: var(--rs-text);
    font-size: clamp(1.65rem, 3vw, 2.35rem);
    font-weight: 300 !important;
    line-height: 1.15;
    letter-spacing: -0.045em;
}

.rs-service-card,
.rs-project-card,
.rs-step,
.rs-stat-list > div,
.rs-dashboard-card,
.rs-card {
    border-radius: 0;
}

.rs-service-card,
.rs-project-card {
    border: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 70%, transparent);
    color: var(--rs-text);
    box-shadow: var(--rs-shadow-sm);
    backdrop-filter: blur(14px);
}

html[data-rs-theme="gelap"] .rs-service-card,
html[data-rs-theme="gelap"] .rs-project-card,
html[data-rs-theme="gelap"] .rs-section-services .container,
html[data-rs-theme="gelap"] .rs-cta-panel,
html[data-rs-theme="gelap"] .rs-stat-list > div {
    background: rgba(14, 19, 25, 0.76) !important;
    border-color: rgba(255, 255, 255, 0.085) !important;
    color: var(--rs-text) !important;
}

.rs-service-card .card-body,
.rs-project-card .card-body {
    padding: clamp(1.1rem, 2.2vw, 1.45rem);
}

.rs-card-icon,
.rs-step-icon {
    display: inline-grid;
    place-items: center;
    width: 44px;
    height: 44px;
    margin-bottom: 1rem;
    border: 1px solid color-mix(in srgb, var(--rs-accent) 22%, var(--rs-border));
    background: var(--rs-accent-soft);
    color: var(--rs-accent);
    font-size: 1.15rem;
    line-height: 1;
}

.rs-service-card h3,
.rs-project-card h3,
.rs-step h3 {
    margin: 0 0 0.5rem;
    color: var(--rs-text);
    font-size: clamp(1.1rem, 1.6vw, 1.45rem);
    font-weight: 300 !important;
    line-height: 1.13;
    letter-spacing: -0.04em;
}

.rs-service-card p,
.rs-project-card p,
.rs-step p,
.rs-about p,
.rs-cta-panel p {
    margin: 0;
    color: var(--rs-text-muted);
    line-height: 1.65;
}

.rs-project-shot {
    height: 124px;
    border-bottom: 1px solid var(--rs-border);
    background: linear-gradient(135deg, rgba(15, 23, 42, 0.86), rgba(30, 41, 59, 0.72));
}

.rs-project-shot--blue { background: linear-gradient(135deg, #3b82f6, #eff6ff); }
.rs-project-shot--image { background: linear-gradient(135deg, #0f172a, #f59e0b); }
.rs-project-shot--phone { background: radial-gradient(circle at 38% 48%, #111827 0 16%, transparent 17%), linear-gradient(135deg, #7c3aed, #f0abfc); }
.rs-project-shot--dash { background: linear-gradient(135deg, #0f172a, #2563eb); }

.rs-project-card a {
    display: inline-grid;
    place-items: center;
    width: 36px;
    height: 36px;
    margin-top: 0.85rem;
    border: 1px solid var(--rs-border);
    color: var(--rs-text);
    text-decoration: none;
}

.rs-workflow .row {
    align-items: stretch;
}

.rs-step {
    height: 100%;
    padding: 1rem 0.65rem;
    color: var(--rs-text);
}

.rs-step-number {
    display: block;
    margin-bottom: 0.7rem;
    color: var(--rs-accent);
    font-size: 0.82rem;
    letter-spacing: 0.08em;
}

.rs-step-icon {
    margin: 0 auto 0.85rem;
    width: 40px;
    height: 40px;
}

.rs-about h2 {
    max-width: 560px;
    color: var(--rs-text);
    font-size: clamp(2rem, 3.7vw, 3.2rem);
    font-weight: 300 !important;
    line-height: 1.05;
    letter-spacing: -0.06em;
}

.rs-team-visual {
    position: relative;
    min-height: 230px;
    border-width: 0;
    display: grid;
    place-items: center;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(30, 41, 59, 0.86), rgba(148, 163, 184, 0.34));
}

.rs-team-logo,
.rs-cta-logo {
    display: inline-grid;
    place-items: center;
    width: 56px;
    height: 56px;
    background: var(--rs-accent);
    color: var(--rs-accent-contrast, #fff);
    font-size: 1.4rem;
    font-weight: 300;
}

.rs-team-visual span {
    position: absolute;
    bottom: 0;
    width: 22%;
    height: 42%;
    background: rgba(15, 23, 42, 0.68);
}

.rs-team-visual span:nth-of-type(1) { left: 23%; height: 38%; }
.rs-team-visual span:nth-of-type(2) { left: 43%; height: 55%; }
.rs-team-visual span:nth-of-type(3) { left: 63%; height: 41%; }

.rs-stat-list {
    display: grid;
    gap: 0.9rem;
}

.rs-stat-list > div {
    display: grid;
    gap: 0.2rem;
    min-height: 76px;
    padding: 1rem;
    border: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 68%, transparent);
    box-shadow: var(--rs-shadow-sm);
    backdrop-filter: blur(14px);
}

.rs-stat-list strong {
    color: var(--rs-text);
    font-size: 1.6rem;
    font-weight: 300 !important;
    line-height: 1;
}

.rs-stat-list span {
    color: var(--rs-text-muted);
    font-size: 0.86rem;
}

.rs-cta {
    padding: clamp(1rem, 3vw, 2.5rem) 0 clamp(3.5rem, 6vw, 5rem);
}

.rs-cta-panel {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    padding: clamp(1.1rem, 2.5vw, 1.7rem);
}

.rs-cta-panel h2 {
    margin: 0 0 0.25rem;
    color: var(--rs-text);
    font-size: clamp(1.35rem, 2.4vw, 2rem);
    font-weight: 300 !important;
    letter-spacing: -0.04em;
}

html[data-rs-theme="gelap"] .rs-hero {
    background: linear-gradient(180deg, rgba(7, 11, 16, 0.20), rgba(7, 11, 16, 0.62));
}

html[data-rs-theme="gelap"] .rs-laptop,
html[data-rs-theme="gelap"] .rs-phone {
    border-color: #0d131b;
    background: rgba(12, 17, 23, 0.68);
}

html[data-rs-theme="gelap"] .rs-project-shot {
    opacity: 0.86;
}

@media (min-width: 1200px) {
    .rs-section .container,
    .rs-hero .container,
    .rs-cta .container,
    .rs-site-header .container,
    .rs-site-footer .container {
        max-width: 1200px;
    }
}

@media (max-width: 991.98px) {
    .rs-hero {
        min-height: 0;
        padding-top: 2.75rem;
        padding-bottom: 2.75rem;
    }

    .rs-device-stage {
        min-height: 300px;
        margin-top: 0.5rem;
    }

    .rs-laptop {
        width: 86%;
    }

    .rs-phone {
        right: 0;
        width: 148px;
        min-height: 218px;
    }

    .rs-cta-panel,
    .rs-cta-panel > .d-flex {
        align-items: flex-start !important;
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .rs-site-header {
        padding: 0.45rem 0;
    }

    .rs-site-header .container,
    .rs-hero .container,
    .rs-section .container,
    .rs-cta .container,
    .rs-site-footer .container {
        padding-inline: 1rem;
    }

    .rs-site-brand__mark,
    .rs-logo-mark,
    .rs-site-brand img {
        width: 26px !important;
        height: 26px !important;
        font-size: 0.7rem;
    }

    .rs-site-brand strong {
        max-width: 104px;
        font-size: 0.78rem;
    }

    .rs-site-actions .rs-theme-toggle,
    .rs-site-actions .rs-site-menu-toggle {
        width: 38px !important;
        min-width: 38px !important;
        height: 38px !important;
        min-height: 38px !important;
    }

    .rs-hero {
        padding-top: 1.45rem;
        padding-bottom: 2.25rem;
    }

    .rs-hero h1 {
        max-width: 320px;
        font-size: clamp(2.35rem, 13.5vw, 3.35rem);
        line-height: 0.98;
        letter-spacing: -0.06em;
    }

    .rs-hero .lead {
        max-width: 300px;
        font-size: 0.92rem;
        line-height: 1.72;
    }

    .rs-hero .d-flex.flex-wrap {
        gap: 0.55rem !important;
    }

    .rs-device-stage {
        min-height: 215px;
        justify-content: start;
        overflow: visible;
    }

    .rs-laptop {
        width: 78%;
        min-height: 150px;
        border-width: 5px;
        padding: 0.7rem;
    }

    .rs-phone {
        right: 2%;
        bottom: 2%;
        width: 88px;
        min-height: 136px;
        border-width: 5px;
        padding: 0.45rem;
    }

    .rs-dash-grid { grid-template-columns: 46px 1fr; gap: 0.45rem; min-height: 105px; }
    .rs-dash-title { height: 9px; }
    .rs-dash-cards { gap: 0.25rem; }
    .rs-dash-cards i { height: 28px; }
    .rs-dash-chart { height: 40px; gap: 0.2rem; }
    .rs-phone-icons, .rs-phone-list, .rs-phone-title, .rs-phone-total, .rs-phone-notch { display: none; }

    .rs-section {
        padding: 2.15rem 0;
    }

    .rs-section-services .container {
        padding: 1rem;
    }

    .rs-section-head {
        margin-bottom: 1rem !important;
        text-align: center !important;
    }

    .rs-section-head h2 {
        font-size: 1.42rem;
        line-height: 1.22;
    }

    .rs-service-card .card-body,
    .rs-project-card .card-body {
        padding: 1rem;
    }

    .rs-service-card,
    .rs-project-card {
        min-height: 0;
    }

    .rs-card-icon {
        width: 38px;
        height: 38px;
        margin-bottom: 0.75rem;
    }

    .rs-service-card h3,
    .rs-project-card h3 {
        font-size: 1.18rem;
    }

    .rs-project-shot {
        height: 96px;
    }

    .rs-workflow .row {
        row-gap: 0.55rem !important;
    }

    .rs-workflow .col-6 {
        width: 50%;
    }

    .rs-step {
        padding: 0.65rem 0.25rem;
    }

    .rs-step p {
        font-size: 0.8rem;
        line-height: 1.45;
    }

    .rs-about h2 {
        font-size: 1.65rem;
    }

    .rs-team-visual {
        min-height: 150px;
    }

    .rs-stat-list {
        gap: 0.5rem;
    }

    .rs-stat-list > div {
        min-height: 58px;
        padding: 0.75rem;
    }

    .rs-stat-list strong {
        font-size: 1.18rem;
    }

    .rs-cta-panel {
        padding: 1rem;
    }

    .rs-cta-logo {
        width: 42px;
        height: 42px;
        font-size: 1rem;
    }

    .rs-cta-panel h2 {
        font-size: 1.28rem;
    }

    .rs-home-page .rs-home-action-btn,
    .rs-site-offcanvas .rs-offcanvas-cta {
        width: 44px !important;
        min-width: 44px !important;
        height: 44px !important;
        min-height: 44px !important;
    }

    .rs-site-offcanvas__panel {
        top: 3.85rem;
        right: 0.8rem;
        width: min(300px, calc(100vw - 1.6rem));
        padding: 1rem;
    }

    .rs-site-offcanvas__nav a {
        min-height: 44px;
        padding: 0.65rem 0.75rem;
    }
}

/* F12 footer precision */
.rs-site-footer {
    padding: clamp(2rem, 5vw, 3.5rem) 0 1rem;
    border-top: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 24%, transparent);
    backdrop-filter: blur(12px);
}

.rs-site-footer__grid {
    grid-template-columns: minmax(0, 1.5fr) repeat(3, minmax(130px, 0.72fr));
    gap: clamp(1.1rem, 4vw, 3rem);
}

.rs-site-footer__brand-block {
    min-width: 0;
}

.rs-site-footer__nav,
.rs-site-footer__contact {
    align-content: start;
}

.rs-site-footer__contact span {
    color: var(--rs-text-muted);
    font-size: 0.9rem;
    line-height: 1.7;
}

.rs-footer-social {
    display: flex;
    gap: 0.45rem;
    margin-top: 1rem;
}

.rs-footer-social span {
    display: inline-grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 60%, transparent);
    color: var(--rs-text-muted);
    font-size: 0.72rem;
}

@media (max-width: 767.98px) {
    .rs-site-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.2rem 1rem;
    }

    .rs-site-footer__brand-block,
    .rs-site-footer__contact {
        grid-column: 1 / -1;
    }

    .rs-site-footer__nav {
        display: grid !important;
    }
}

@media (max-width: 420px) {
    .rs-site-footer__grid {
        grid-template-columns: 1fr;
    }

    .rs-site-footer__brand-block,
    .rs-site-footer__contact {
        grid-column: auto;
    }
}

/* F13 beranda completeness: team, contact, faq */
.rs-team-card,
.rs-contact-info,
.rs-contact-form,
.rs-faq-item {
    border: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 70%, transparent);
    color: var(--rs-text);
    box-shadow: var(--rs-shadow-sm);
    backdrop-filter: blur(14px) saturate(120%);
}

html[data-rs-theme="gelap"] .rs-team-card,
html[data-rs-theme="gelap"] .rs-contact-info,
html[data-rs-theme="gelap"] .rs-contact-form,
html[data-rs-theme="gelap"] .rs-faq-item {
    background: rgba(14, 19, 25, 0.76) !important;
    border-color: rgba(255, 255, 255, 0.085) !important;
    color: var(--rs-text) !important;
}

.rs-team-card .card-body,
.rs-contact-info,
.rs-contact-form {
    padding: clamp(1.1rem, 2.4vw, 1.6rem);
}

.rs-team-avatar {
    display: inline-grid;
    place-items: center;
    width: 62px;
    height: 62px;
    margin-bottom: 1rem;
    border: 1px solid color-mix(in srgb, var(--rs-accent) 24%, var(--rs-border));
    background: var(--rs-accent-soft);
    color: var(--rs-accent);
    font-size: 1rem;
    font-weight: 300;
    letter-spacing: 0.08em;
}

.rs-team-card h3,
.rs-contact-info h2,
.rs-faq-item summary {
    color: var(--rs-text);
    font-weight: 300 !important;
}

.rs-team-card h3 {
    margin: 0 0 0.55rem;
    font-size: 1.18rem;
    letter-spacing: -0.035em;
}

.rs-team-card p,
.rs-contact-info p,
.rs-faq-item p {
    margin: 0;
    color: var(--rs-text-muted);
    line-height: 1.65;
}

.rs-contact-info h2 {
    margin: 0.55rem 0 0.9rem;
    font-size: clamp(1.65rem, 3vw, 2.35rem);
    line-height: 1.14;
    letter-spacing: -0.045em;
}

.rs-contact-list {
    display: grid;
    gap: 0.6rem;
    margin-top: 1.2rem;
    color: var(--rs-text-muted);
    font-size: 0.95rem;
}

.rs-contact-form .form-label {
    color: var(--rs-text);
    font-weight: 300;
}

.rs-contact-form .form-control {
    border-radius: 0;
    font-weight: 300;
}

.rs-faq-list {
    display: grid;
    gap: 0.75rem;
    max-width: 920px;
    margin: 0 auto;
}

.rs-faq-item {
    padding: 1rem 1.15rem;
}

.rs-faq-item summary {
    cursor: pointer;
    list-style: none;
    font-size: 1.02rem;
    letter-spacing: -0.02em;
}

.rs-faq-item summary::-webkit-details-marker {
    display: none;
}

.rs-faq-item summary::after {
    content: "+";
    float: right;
    color: var(--rs-accent);
    font-size: 1.1rem;
    line-height: 1;
}

.rs-faq-item[open] summary::after {
    content: "−";
}

.rs-faq-item p {
    padding-top: 0.75rem;
}

@media (min-width: 992px) {
    .rs-site-nav a {
        padding-right: 0.72rem;
        padding-left: 0.72rem;
        font-size: 0.9rem;
    }
}

@media (max-width: 575.98px) {
    .rs-team-card .card-body,
    .rs-contact-info,
    .rs-contact-form,
    .rs-faq-item {
        padding: 1rem;
    }

    .rs-team-avatar {
        width: 52px;
        height: 52px;
        margin-bottom: 0.8rem;
    }

    .rs-contact-info h2 {
        font-size: 1.42rem;
    }
}

/* Final polish public dynamic render */
.rs-public-nav-dropdown { position: relative; display: inline-flex; align-items: center; }
.rs-public-nav-dropdown > button { border: 0; background: transparent; color: inherit; font: inherit; padding: .35rem .55rem; }
.rs-public-nav-dropdown > div { position: absolute; top: calc(100% + .5rem); right: 0; min-width: 180px; display: none; padding: .45rem; border: 1px solid var(--rs-border, rgba(120,120,120,.22)); background: var(--rs-surface, rgba(255,255,255,.92)); box-shadow: 0 16px 45px rgba(0,0,0,.16); z-index: 50; }
.rs-public-nav-dropdown:hover > div,
.rs-public-nav-dropdown:focus-within > div { display: grid; gap: .2rem; }
.rs-public-nav-dropdown > div a { display: block; padding: .55rem .65rem; white-space: nowrap; }
.rs-dynamic-card .rs-project-shot { min-height: 150px; }
.rs-card-link { display: inline-flex; align-items: center; gap: .35rem; margin-top: .35rem; text-decoration: none; font-weight: 500; }
.rs-section-mobile-compact[data-mobile-limit] .col-md-6:nth-child(n+4),
.rs-section-mobile-compact[data-mobile-limit] .col-6:nth-child(n+4) { display: none; }
@media (min-width: 768px) {
  .rs-section-mobile-compact[data-mobile-limit] .col-md-6:nth-child(n+4),
  .rs-section-mobile-compact[data-mobile-limit] .col-6:nth-child(n+4) { display: block; }
}
@media (max-width: 767.98px) {
  .rs-section-desktop-only { display: none !important; }
  .rs-mobile-visual-hidden { display: none !important; }
  .rs-home-action-btn { padding: .55rem .75rem; }
}

/* UI normalization: dynamic icons, compact process, and stable buttons */
.rs-card-icon i,
.rs-step-icon i {
    font-size: 1.15rem;
    line-height: 1;
}

.rs-workflow .row {
    row-gap: 1.25rem !important;
}

.rs-step {
    padding: 1rem .85rem !important;
    min-height: 0 !important;
}

.rs-step-number {
    display: none !important;
}

.rs-step-icon {
    margin: 0 auto .7rem !important;
    width: 46px !important;
    height: 46px !important;
}

.rs-step h3 {
    margin-bottom: .35rem !important;
}

.rs-step p {
    max-width: 320px;
    margin-inline: auto;
    line-height: 1.5 !important;
}

.rs-detail-hero .rs-home-action-btn,
.rs-home-page .rs-home-action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    white-space: nowrap;
}

@media (max-width: 767.98px) {
    .rs-step {
        text-align: left !important;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        column-gap: .8rem;
        align-items: start;
    }
    .rs-step-icon {
        margin: .1rem 0 0 !important;
    }
    .rs-step h3,
    .rs-step p {
        grid-column: 2;
    }
}

/* CK-033R public topbar: halaman sebagai menu utama, section sebagai dropdown */
.rs-site-nav > .rs-public-nav-dropdown {
    position: relative;
    display: inline-flex;
    align-items: stretch;
}

.rs-public-nav-dropdown__trigger {
    border: 0;
    background: transparent;
    color: var(--rs-text-muted);
    font: inherit;
    cursor: pointer;
}

.rs-site-nav .rs-public-nav-dropdown__trigger {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    min-height: 38px;
    padding: 0.42rem 0.82rem;
    text-decoration: none;
}

.rs-public-nav-dropdown__chevron {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.92rem;
    height: 0.92rem;
    margin-left: 0.1rem;
    opacity: 0.72;
    line-height: 1;
    transition: opacity 0.18s ease, transform 0.18s ease;
}

.rs-public-nav-dropdown__chevron svg {
    display: block;
    width: 100%;
    height: 100%;
}

.rs-public-nav-dropdown__menu {
    position: absolute;
    top: calc(100% + 0.38rem);
    left: 0;
    z-index: 90;
    display: grid;
    min-width: 210px;
    max-width: min(300px, calc(100vw - 2rem));
    padding: 0.35rem;
    border: 1px solid var(--rs-border);
    background: color-mix(in srgb, var(--rs-panel-strong) 98%, transparent);
    box-shadow: 0 18px 46px rgba(15, 23, 42, 0.14);
    backdrop-filter: blur(18px) saturate(120%);
    opacity: 0;
    visibility: hidden;
    transform: translateY(6px);
    transition: opacity 0.16s ease, transform 0.16s ease, visibility 0.16s ease;
}

.rs-public-nav-dropdown:hover .rs-public-nav-dropdown__menu,
.rs-public-nav-dropdown:focus-within .rs-public-nav-dropdown__menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.rs-public-nav-dropdown.is-dropdown-closing .rs-public-nav-dropdown__menu {
    opacity: 0 !important;
    visibility: hidden !important;
    transform: translateY(4px) !important;
    pointer-events: none;
}

.rs-public-nav-dropdown:hover .rs-public-nav-dropdown__chevron,
.rs-public-nav-dropdown:focus-within .rs-public-nav-dropdown__chevron {
    opacity: 1;
    transform: rotate(180deg);
}

.rs-site-nav .rs-public-nav-dropdown__menu a {
    justify-content: flex-start;
    min-height: 36px;
    padding: 0.5rem 0.65rem;
    white-space: normal;
}

.rs-site-nav .rs-public-nav-dropdown__menu a::after {
    right: 0.7rem;
    left: 0.7rem;
    bottom: 0.26rem;
}

.rs-public-nav-dropdown--more .rs-public-nav-dropdown__menu {
    right: 0;
    left: auto;
}

.rs-site-offcanvas__submenu {
    display: grid;
    gap: 0.25rem;
    margin: -0.15rem 0 0.35rem 0.7rem;
    padding-left: 0.7rem;
    border-left: 1px solid var(--rs-border);
}

.rs-site-offcanvas__submenu a {
    min-height: 42px;
    padding-left: 0.8rem;
    font-size: 0.94rem;
}

@media (max-width: 991.98px) {
    .rs-site-nav {
        display: none;
    }
}

.rs-site-nav .rs-public-nav-dropdown > .rs-public-nav-dropdown__menu {
    display: grid;
    right: auto;
    min-width: 210px;
    background: color-mix(in srgb, var(--rs-panel-strong) 98%, transparent);
}

.rs-site-nav .rs-public-nav-dropdown--more > .rs-public-nav-dropdown__menu {
    right: 0;
    left: auto;
}

/* CK-033 contact section: functional public form */
.rs-preview-contact-form {
    display: grid;
    gap: 1rem;
}

.rs-preview-contact-form > strong {
    color: var(--rs-text);
    font-size: 1.02rem;
    font-weight: 300;
    letter-spacing: -0.02em;
}

.rs-public-contact-form,
.rs-public-form-grid {
    display: grid;
    gap: 0.85rem;
}

.rs-public-form-field {
    display: grid;
    gap: 0.35rem;
}

.rs-public-contact-form .form-label {
    margin: 0;
    color: var(--rs-text);
    font-size: 0.88rem;
    font-weight: 300;
}

.rs-public-contact-form .form-control {
    min-height: 3rem;
    border-radius: 0;
    border-color: var(--rs-border);
    background: color-mix(in srgb, var(--rs-surface) 82%, transparent);
    color: var(--rs-text);
    font-weight: 300;
    box-shadow: none;
}

.rs-public-contact-form textarea.form-control {
    min-height: 7.4rem;
    resize: vertical;
}

.rs-public-contact-form .form-control:focus {
    border-color: color-mix(in srgb, var(--rs-accent) 58%, var(--rs-border));
    box-shadow: 0 0 0 0.18rem color-mix(in srgb, var(--rs-accent) 16%, transparent);
}

.rs-public-contact-form .form-control::placeholder {
    color: var(--rs-text-muted);
    opacity: 0.72;
}

.rs-public-contact-submit {
    justify-self: start;
    margin-top: 0.15rem;
}

.rs-public-contact-note {
    margin: 0;
    color: var(--rs-text-muted);
    font-size: 0.86rem;
    line-height: 1.55;
}

.rs-public-contact-note.is-error {
    color: var(--rs-danger, #dc3545);
}

.rs-public-contact-note.is-success {
    color: var(--rs-success, #198754);
}

html[data-rs-theme="gelap"] .rs-public-contact-form .form-control {
    background: rgba(255, 255, 255, 0.035);
}
