@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500;600;700&family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
    --site-font-body: "Plus Jakarta Sans", "Segoe UI", sans-serif;
    --site-font-heading: "Outfit", "Plus Jakarta Sans", sans-serif;
    --bg-main: #F7F7FA;
    --text-primary: #2D3748;
    --accent-primary: #3f2be8;
    --accent-primary-strong: #2d1cc9;
    --border-neutral: #E2E8F0;
    --bg-editor: #1A202C;
    --site-ink-strong: #19356c;
    --site-ink: #2f4c7e;
    --site-ink-soft: #62779f;
    --site-line: rgba(183, 205, 240, 0.72);
    --site-line-strong: rgba(122, 156, 215, 0.34);
    --site-surface: rgba(255, 255, 255, 0.74);
    --site-surface-strong: rgba(255, 255, 255, 0.88);
    --site-surface-muted: rgba(245, 249, 255, 0.92);
    --site-blue: #245db3;
    --site-blue-strong: #1a4c98;
    --site-blue-soft: #eef5ff;
    --site-shadow: 0 26px 70px rgba(32, 70, 130, 0.10);
    --site-shadow-soft: 0 18px 40px rgba(32, 70, 130, 0.08);
}

html,
body {
    min-height: 100%;
}

body {
    font-family: var(--site-font-body);
    color: var(--site-ink);
    background:
        radial-gradient(circle at top left, rgba(204, 221, 255, 0.95), transparent 36%),
        radial-gradient(circle at top right, rgba(223, 231, 255, 0.9), transparent 30%),
        radial-gradient(circle at 10% 92%, rgba(213, 229, 255, 0.85), transparent 28%),
        linear-gradient(180deg, #f8fbff 0%, #f5f8fe 42%, #f8fbff 100%);
}

body,
.page {
    position: relative;
}

h1,
h2,
h3,
h4,
h5,
h6,
.nav-brand-name,
.hero-title,
.page-title,
.home-title {
    font-family: var(--site-font-heading);
}

.page {
    min-height: 100vh;
    background: transparent;
    isolation: isolate;
}

.site-global-background {
    position: fixed;
    inset: 0;
    width: 100vw;
    max-width: 100vw;
    height: 100vh;
    z-index: -2;
    overflow: hidden;
    pointer-events: none;
    background: #f8fbff url('/img/site-global/background-rectangular.png') center center / cover no-repeat;
}

.site-global-background__video,
.site-global-background__fallback,
.site-global-background__overlay {
    position: absolute;
    inset: 0;
    width: 100%;
    max-width: 100vw;
    height: 100%;
}

.site-global-background__video {
    display: block;
    z-index: 1;
    object-fit: cover;
    opacity: 0.48;
}

.site-global-background__fallback {
    z-index: 0;
    background: url('/img/site-global/background-rectangular.png') center center / cover no-repeat;
    opacity: 0.22;
}

.site-global-background__overlay {
    z-index: 2;
    background:
        linear-gradient(180deg, rgba(248, 251, 255, 0.62), rgba(245, 249, 255, 0.58)),
        radial-gradient(circle at 12% 18%, rgba(181, 210, 255, 0.26), transparent 28%),
        radial-gradient(circle at 88% 12%, rgba(226, 232, 255, 0.34), transparent 24%);
}

.page::before {
    content: "";
    position: fixed;
    inset: 0;
    background:
        radial-gradient(circle at 10% 20%, rgba(135, 174, 240, 0.16), transparent 32%),
        radial-gradient(circle at 90% 12%, rgba(220, 226, 255, 0.85), transparent 24%),
        radial-gradient(circle at 84% 82%, rgba(172, 208, 255, 0.14), transparent 24%);
    pointer-events: none;
    z-index: -1;
}

.page-header-shell,
.footer {
    position: relative;
}

.page-header-shell {
    z-index: 1200;
}

.page-main {
    position: relative;
    z-index: 1;
}

.footer {
    z-index: 1;
}

.page > main.page-main {
    margin-top: 0;
    padding: 4.15rem 0 1.8rem;
    display: flex;
}

.page > main.page-main.page-main--home {
    padding-bottom: 0.5rem;
}

.page-main {
    flex: 1;
}

.page-backdrop {
    opacity: 1;
    mix-blend-mode: normal;
    background: transparent !important;
}

.page-content {
    width: 100%;
    align-items: stretch;
}

.page-content-card {
    width: 100%;
    max-width: 1200px;
    padding: clamp(1.5rem, 3vw, 2.4rem);
    border-radius: 15px;
    background: var(--site-surface);
    border: 1px solid rgba(255, 255, 255, 0.92);
    box-shadow: var(--site-shadow);
    backdrop-filter: blur(26px);
    -webkit-backdrop-filter: blur(26px);
}

.page-content-card--inner {
    max-width: 1240px;
    padding: clamp(0.25rem, 0.65vw, 0.4rem);
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.32);
    border: 1px solid rgba(255, 255, 255, 0.62);
    box-shadow: 0 14px 34px rgba(30, 62, 114, 0.06);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.page-content-card--inner .inner-page {
    gap: 0.16rem;
}

.page-content-card--inner .inner-page__section.container,
.page-content-card--inner .inner-page__alerts.container,
.page-content-card--inner .container.py-5.inner-page__section {
    max-width: none;
    width: 100%;
    margin: 0;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.page-content-card--inner .inner-page .hero-summary-wrapper,
.page-content-card--inner .inner-page .inner-page__body,
.page-content-card--inner .inner-page .info-wrap {
    width: 100%;
    max-width: none;
}

.page-content-card--inner .inner-page .hero-summary-wrapper {
    padding: clamp(0.15rem, 0.45vw, 0.28rem) clamp(0.35rem, 0.9vw, 0.55rem);
}

.page-content-card--inner .inner-page .hero-summary-wrapper .hero-bg {
    display: block;
    width: min(100%, 1020px);
    max-width: 100%;
    margin: -0.5rem auto -0.06rem;
    border-radius: 15px;
}

.page-content-card--inner .inner-page .inner-page__body,
.page-content-card--inner .inner-page .info-wrap {
    margin-top: -0.22rem;
    padding: clamp(0.18rem, 0.45vw, 0.32rem);
    background: rgba(255, 255, 255, 0.46);
    box-shadow: 0 6px 16px rgba(35, 69, 123, 0.04);
}

.inner-page--courses .cv-record-grid,
.inner-page--certifications .cv-record-grid {
    gap: 0.8rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.inner-page--about .cv-record-title-card,
.inner-page--admin-blog .cv-record-title-card,
.inner-page--contact .cv-record-title-card,
.inner-page--courses .cv-record-title-card,
.inner-page--file-tools .cv-record-title-card,
.inner-page--labs .cv-record-title-card,
.inner-page--management .cv-record-title-card,
.inner-page--mermaid-tool .cv-record-title-card,
.inner-page--privacy .cv-record-title-card,
.inner-page--visitor-analytics .cv-record-title-card,
.inner-page--certifications .cv-record-title-card,
.inner-page--experience .cv-record-title-card,
.inner-page--blog .cv-record-title-card,
.inner-page--booking .cv-record-title-card,
.inner-page--skills .cv-record-title-card,
.inner-page--qualifications .cv-record-title-card,
.inner-page--summary .cv-record-title-card {
    position: relative;
    width: min(980px, 100%);
    margin: -1.05rem auto 0;
    padding: 0;
    overflow: hidden;
    border: 0 !important;
    border-radius: 15px !important;
    background: transparent !important;
    box-shadow: none !important;
}

.inner-page--about .cv-record-title-card__bg,
.inner-page--admin-blog .cv-record-title-card__bg,
.inner-page--contact .cv-record-title-card__bg,
.inner-page--courses .cv-record-title-card__bg,
.inner-page--file-tools .cv-record-title-card__bg,
.inner-page--labs .cv-record-title-card__bg,
.inner-page--management .cv-record-title-card__bg,
.inner-page--mermaid-tool .cv-record-title-card__bg,
.inner-page--privacy .cv-record-title-card__bg,
.inner-page--visitor-analytics .cv-record-title-card__bg,
.inner-page--certifications .cv-record-title-card__bg,
.inner-page--experience .cv-record-title-card__bg,
.inner-page--blog .cv-record-title-card__bg,
.inner-page--booking .cv-record-title-card__bg,
.inner-page--skills .cv-record-title-card__bg,
.inner-page--qualifications .cv-record-title-card__bg,
.inner-page--summary .cv-record-title-card__bg {
    display: block;
    width: 100%;
    margin: 0;
    border-radius: 15px;
    opacity: 0.35;
}

.inner-page--about .cv-record-title-card .hero-title,
.inner-page--admin-blog .cv-record-title-card .hero-title,
.inner-page--contact .cv-record-title-card .hero-title,
.inner-page--courses .cv-record-title-card .hero-title,
.inner-page--file-tools .cv-record-title-card .hero-title,
.inner-page--labs .cv-record-title-card .hero-title,
.inner-page--management .cv-record-title-card .hero-title,
.inner-page--mermaid-tool .cv-record-title-card .hero-title,
.inner-page--privacy .cv-record-title-card .hero-title,
.inner-page--visitor-analytics .cv-record-title-card .hero-title,
.inner-page--certifications .cv-record-title-card .hero-title,
.inner-page--experience .cv-record-title-card .hero-title,
.inner-page--blog .cv-record-title-card .hero-title,
.inner-page--booking .cv-record-title-card .hero-title,
.inner-page--skills .cv-record-title-card .hero-title,
.inner-page--qualifications .cv-record-title-card .hero-title,
.inner-page--summary .cv-record-title-card .hero-title {
    position: absolute;
    top: 50%;
    left: 50%;
    margin: 0;
    transform: translate(-50%, -50%);
    z-index: 1;
}

.inner-page--about .cv-record-shell,
.inner-page--admin-blog .cv-record-shell,
.inner-page--contact .cv-record-shell,
.inner-page--courses .cv-record-shell,
.inner-page--file-tools .cv-record-shell,
.inner-page--labs .cv-record-shell,
.inner-page--management .cv-record-shell,
.inner-page--mermaid-tool .cv-record-shell,
.inner-page--privacy .cv-record-shell,
.inner-page--visitor-analytics .cv-record-shell,
.inner-page--certifications .cv-record-shell,
.inner-page--experience .cv-record-shell,
.inner-page--blog .cv-record-shell,
.inner-page--booking .cv-record-shell,
.inner-page--skills .cv-record-shell,
.inner-page--qualifications .cv-record-shell,
.inner-page--summary .cv-record-shell {
    width: min(980px, 100%);
    margin: 0.48rem auto 0;
    padding: 1rem;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.36);
    border: 1px solid rgba(255, 255, 255, 0.64);
    box-shadow: 0 14px 30px rgba(36, 66, 116, 0.06);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.inner-page--courses .cv-record-card,
.inner-page--certifications .cv-record-card {
    padding: 0.78rem;
    border-radius: 15px !important;
}

.inner-page--about .alert,
.inner-page--admin-blog .alert,
.inner-page--contact .alert,
.inner-page--courses .alert,
.inner-page--file-tools .alert,
.inner-page--labs .alert,
.inner-page--management .alert,
.inner-page--mermaid-tool .alert,
.inner-page--privacy .alert,
.inner-page--visitor-analytics .alert,
.inner-page--certifications .alert,
.inner-page--experience .alert,
.inner-page--blog .alert,
.inner-page--booking .alert,
.inner-page--skills .alert,
.inner-page--qualifications .alert,
.inner-page--summary .alert {
    width: min(980px, 100%);
    margin: 0 auto;
}

.inner-page--experience .cv-experience-card {
    padding: 1rem 1.05rem;
    border-radius: 15px !important;
}

.inner-page--experience .cv-experience-meta {
    gap: 0.6rem;
    margin-bottom: 0.8rem;
}

.inner-page--experience .cv-meta-item {
    padding: 0.72rem 0.82rem;
}

.cv-card-grid {
    display: grid;
    gap: 0.8rem;
    align-items: start;
}

.cv-card-grid--uniform {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.cv-card-uniform {
    height: 100%;
    min-height: 10.5rem;
}

.cv-card-uniform .e-card-content {
    height: 100%;
}

.inner-page--skills .cv-skills-grid,
.inner-page--qualifications .cv-qualifications-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.inner-page--qualifications .cv-qualification-card {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0.95rem 1rem;
    border-radius: 15px !important;
}

.inner-page--summary .summary-stack {
    display: grid;
    gap: 0.8rem;
}

.inner-page--summary .summary-block {
    padding: 0.95rem 1rem;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: inset 0 0 0 1px rgba(203, 219, 245, 0.82);
}

.inner-page--courses .cv-record-card .e-card-header,
.inner-page--certifications .cv-record-card .e-card-header {
    padding: 0 0 0.55rem;
}

.inner-page--courses .cv-record-card .e-card-header-title,
.inner-page--certifications .cv-record-card .e-card-header-title {
    font-size: 0.98rem !important;
    line-height: 1.3;
}

.inner-page--courses .cv-record-card .e-card-sub-title,
.inner-page--certifications .cv-record-card .e-card-sub-title {
    font-size: 0.82rem !important;
}

.inner-page--courses .cv-record-meta,
.inner-page--certifications .cv-record-meta {
    gap: 0.42rem;
}

.inner-page--courses .cv-record-meta-item,
.inner-page--certifications .cv-record-meta-item {
    gap: 0.35rem;
    padding: 0.38rem 0.62rem;
    font-size: 0.8rem;
}

.inner-page--courses .cv-record-meta-item strong,
.inner-page--certifications .cv-record-meta-item strong {
    font-size: 0.72rem;
}

@media (max-width: 991.98px) {
    .inner-page--courses .cv-record-grid,
    .inner-page--certifications .cv-record-grid {
        grid-template-columns: 1fr;
    }

    .inner-page--about .cv-record-title-card,
    .inner-page--admin-blog .cv-record-title-card,
    .inner-page--contact .cv-record-title-card,
    .inner-page--courses .cv-record-title-card,
    .inner-page--file-tools .cv-record-title-card,
    .inner-page--labs .cv-record-title-card,
    .inner-page--management .cv-record-title-card,
    .inner-page--mermaid-tool .cv-record-title-card,
    .inner-page--privacy .cv-record-title-card,
    .inner-page--visitor-analytics .cv-record-title-card,
    .inner-page--certifications .cv-record-title-card,
    .inner-page--experience .cv-record-title-card,
    .inner-page--booking .cv-record-title-card,
    .inner-page--skills .cv-record-title-card,
    .inner-page--qualifications .cv-record-title-card,
    .inner-page--summary .cv-record-title-card {
        margin-top: -0.55rem;
    }

    .inner-page--about .cv-record-shell,
    .inner-page--admin-blog .cv-record-shell,
    .inner-page--contact .cv-record-shell,
    .inner-page--courses .cv-record-shell,
    .inner-page--file-tools .cv-record-shell,
    .inner-page--labs .cv-record-shell,
    .inner-page--management .cv-record-shell,
    .inner-page--mermaid-tool .cv-record-shell,
    .inner-page--privacy .cv-record-shell,
    .inner-page--visitor-analytics .cv-record-shell,
    .inner-page--certifications .cv-record-shell,
    .inner-page--experience .cv-record-shell,
    .inner-page--booking .cv-record-shell,
    .inner-page--skills .cv-record-shell,
    .inner-page--qualifications .cv-record-shell,
    .inner-page--summary .cv-record-shell {
        padding: 0.7rem;
    }

    .inner-page--skills .cv-skills-grid {
        grid-template-columns: 1fr;
    }

    .cv-card-grid--uniform,
    .inner-page--skills .cv-skills-grid,
    .inner-page--qualifications .cv-qualifications-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .cv-card-grid--uniform,
    .inner-page--skills .cv-skills-grid,
    .inner-page--qualifications .cv-qualifications-grid {
        grid-template-columns: 1fr;
    }
}

.page-header-shell .site-navbar.navbar,
.site-navbar.navbar {
    padding: 1.35rem 0 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

.page-header-shell .site-navbar__inner,
.site-navbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.95rem 1.4rem;
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.96) !important;
    border: 1px solid rgba(255, 255, 255, 0.98) !important;
    box-shadow: 0 20px 55px rgba(40, 77, 138, 0.12) !important;
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

.nav-brand {
    gap: 0.95rem;
    margin-left: 0;
    padding: 0;
}

.nav-brand-avatar {
    width: 52px;
    height: 52px;
    flex: 0 0 52px;
    border-radius: 50%;
    border: 2px solid rgba(215, 228, 248, 0.95);
    box-shadow: 0 10px 25px rgba(43, 77, 130, 0.12);
    background: #f4f8ff;
}

.nav-brand-avatar-img {
    max-width: none;
    max-height: none;
}

.nav-brand-name {
    color: var(--site-ink-strong);
    font-size: clamp(1.2rem, 1.35vw, 1.5rem);
    font-weight: 800;
    letter-spacing: -0.02em;
}

.nav-brand-role {
    color: var(--site-ink-soft);
    font-size: 0.88rem;
}

@media (max-width: 1399.98px) and (min-width: 992px) {
    .site-navbar__inner {
        gap: 0.65rem;
        padding: 0.8rem 1rem;
    }

    .nav-brand {
        gap: 0.72rem;
    }

    .nav-brand-avatar {
        width: 46px;
        height: 46px;
        flex-basis: 46px;
    }

    .nav-brand-name {
        font-size: 1.02rem;
    }

    .nav-brand-role {
        display: none;
    }

    .site-navbar__actions {
        gap: 0.35rem;
    }

    .site-navbar__actions .nav-link {
        gap: 0.45rem;
        min-height: 44px;
        padding: 0.68rem 0.78rem !important;
        font-size: 0.94rem;
    }

    .culture-switch {
        min-width: 46px;
        padding-inline: 0.75rem !important;
    }
}

.site-navbar__panel {
    flex-grow: 0;
}

.site-navbar__menu {
    position: relative;
}

.site-navbar__actions {
    gap: 0.9rem;
}

.site-navbar__actions .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    min-height: 48px;
    padding: 0.75rem 1rem !important;
    border-radius: 6px !important;
    color: var(--site-ink) !important;
    font-weight: 600;
    line-height: 1;
    background: transparent !important;
}

.site-navbar__actions button.nav-link {
    border: none;
}

.site-navbar__actions .nav-link::after {
    display: none !important;
}

.site-navbar__actions .nav-link:hover,
.site-navbar__actions .nav-link:focus,
.site-navbar__actions .nav-link.active {
    color: var(--site-blue) !important;
    background: rgba(236, 244, 255, 0.96) !important;
    border-radius: 6px !important;
    box-shadow: inset 0 0 0 1px rgba(190, 211, 243, 0.9) !important;
}

.nav-menu-trigger {
    background: rgba(244, 248, 255, 0.96) !important;
    box-shadow: inset 0 0 0 1px rgba(198, 215, 242, 0.95);
}

.nav-menu-trigger__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 999px;
    background: linear-gradient(135deg, #dceaff, #edf4ff);
    color: var(--site-blue);
    font-size: 0.8rem;
}

.nav-contact-btn {
    background: transparent !important;
    box-shadow: none !important;
}

.nav-contact-btn:hover,
.nav-contact-btn:focus,
.nav-contact-btn.active {
    color: var(--site-blue) !important;
    background: rgba(236, 244, 255, 0.96) !important;
    border-radius: 6px !important;
    box-shadow: inset 0 0 0 1px rgba(190, 211, 243, 0.9) !important;
}

.admin-link {
    background: rgba(255, 243, 205, 0.9) !important;
    color: #7a5a00 !important;
    box-shadow: inset 0 0 0 1px rgba(234, 203, 111, 0.55);
}

.culture-switch-item {
    list-style: none;
}

.culture-switch {
    min-width: 52px;
    justify-content: center;
    border: 1px solid rgba(198, 215, 242, 0.95) !important;
    background: rgba(247, 250, 255, 0.95) !important;
    color: var(--site-blue) !important;
    font-weight: 800 !important;
}

.site-navbar .navbar-toggler {
    border: none;
    padding: 0.45rem;
    background: rgba(244, 248, 255, 0.96) !important;
    border-radius: 15px;
    box-shadow: inset 0 0 0 1px rgba(198, 215, 242, 0.95);
}

.site-navbar .navbar-toggler:focus {
    box-shadow: 0 0 0 0.2rem rgba(93, 134, 203, 0.18);
}

.site-navbar .navbar-toggler-icon {
    width: 1.45rem;
    height: 1.45rem;
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(26,76,152,1)' stroke-width='2.15' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}

.site-navbar .navbar-nav .dropdown-menu,
.site-navbar .cv-dropdown-menu,
.cv-dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 0.7rem);
    right: 0;
    min-width: 290px !important;
    padding: 0.85rem !important;
    border-radius: 15px !important;
    background: rgba(255, 255, 255, 0.96) !important;
    border: 1px solid rgba(208, 222, 245, 0.9) !important;
    box-shadow: 0 26px 44px rgba(31, 63, 114, 0.14) !important;
}

.site-navbar .cv-dropdown-menu.show,
.cv-dropdown-menu.show {
    display: block;
}

.site-navbar .cv-dropdown-menu li,
.cv-dropdown-menu li {
    padding: 0 !important;
    margin-bottom: 0.3rem !important;
}

.site-navbar .cv-dropdown-menu li:last-child,
.cv-dropdown-menu li:last-child {
    margin-bottom: 0 !important;
}

.site-navbar .cv-dropdown-item,
.cv-dropdown-item {
    gap: 0.85rem !important;
    padding: 0.85rem 1rem !important;
    color: var(--site-ink) !important;
    border-radius: 15px !important;
    font-size: 0.97rem !important;
    font-weight: 600 !important;
    background: transparent !important;
}

.site-navbar .cv-dropdown-item i,
.cv-dropdown-item i {
    color: var(--site-blue) !important;
    filter: none !important;
}

.site-navbar .cv-dropdown-item:hover,
.site-navbar .cv-dropdown-item:focus,
.site-navbar .cv-dropdown-item.active,
.cv-dropdown-item:hover,
.cv-dropdown-item:focus,
.cv-dropdown-item.active {
    color: var(--site-blue) !important;
    background: rgba(239, 246, 255, 0.95) !important;
    box-shadow: inset 0 0 0 1px rgba(198, 214, 241, 0.8) !important;
}

.main {
    gap: 1.5rem;
}

.inner-page {
    gap: 1.05rem;
}

.inner-page__section {
    position: relative;
}

.inner-page .hero-summary-wrapper {
    position: relative;
    overflow: hidden;
    width: min(1120px, 100%);
    margin: 0 auto;
    padding: clamp(1.8rem, 4vw, 2.35rem) clamp(1.35rem, 3vw, 2rem);
    border-radius: 15px;
    box-shadow: 0 18px 42px rgba(37, 72, 126, 0.11);
}

.inner-page .hero-summary-wrapper .hero-bg {
    opacity: 0.035;
}

.inner-page .hero-summary-wrapper .hero-title,
.inner-page .hero-summary-wrapper .display-5 {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: clamp(1.95rem, 2.8vw, 2.7rem);
    font-weight: 800;
    letter-spacing: -0.03em;
}

.inner-page .hero-summary {
    padding: 0;
    max-width: none;
}

.inner-page .hero-subtitle {
    max-width: 720px;
    margin: 0.55rem auto 0;
}

.inner-page .inner-page__body {
    width: min(1120px, 100%);
    margin: 0 auto;
    padding: clamp(1rem, 2.2vw, 1.45rem);
    border-radius: 15px;
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: 0 16px 36px rgba(37, 72, 126, 0.08);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.cv-record-grid,
.cv-experience-list {
    display: grid;
    gap: 1rem;
}

.cv-record-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.cv-record-grid__item,
.cv-experience-list__item {
    min-width: 0;
}

.inner-page .cv-record-card,
.inner-page .cv-experience-card,
.inner-page .cv-skill-card,
.inner-page .cv-qualification-card,
.inner-page .booking-card {
    padding: 1rem;
    border-radius: 15px !important;
}

.inner-page .cv-record-card .e-card-header,
.inner-page .cv-experience-card .e-card-header,
.inner-page .cv-skill-card .e-card-header {
    padding: 0 0 0.85rem;
}

.inner-page .cv-record-card .e-card-content,
.inner-page .cv-experience-card .e-card-content,
.inner-page .cv-skill-card .e-card-content {
    padding: 0;
}

.inner-page .cv-record-card .e-card-header-title,
.inner-page .cv-experience-card .e-card-header-title {
    font-size: 1.02rem !important;
    line-height: 1.4;
}

.inner-page .cv-record-card .e-card-sub-title,
.inner-page .cv-experience-card .e-card-sub-title {
    color: var(--site-ink-soft) !important;
    font-size: 0.88rem !important;
}

.cv-record-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.cv-record-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.5rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-ink);
    font-size: 0.86rem;
}

.cv-record-meta-item strong {
    color: var(--site-ink-strong);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.01em;
    text-transform: uppercase;
}

.cv-record-description {
    margin: 0.85rem 0 0;
    color: var(--site-ink-soft);
    line-height: 1.7;
}

.cv-experience-list {
    grid-template-columns: 1fr;
}

.inner-page .cv-experience-card {
    padding: 1.15rem 1.2rem;
}

.cv-experience-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.cv-meta-item {
    padding: 0.8rem 0.9rem;
    border-radius: 15px;
    background: rgba(242, 247, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.92);
}

.cv-meta-label {
    display: block;
    margin-bottom: 0.28rem;
    color: var(--site-ink-soft);
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cv-meta-value {
    color: var(--site-ink-strong);
    font-weight: 700;
    line-height: 1.45;
}

.cv-experience-description {
    margin: 0 0 1rem;
    color: var(--site-ink-soft);
    line-height: 1.75;
}

.cv-experience-section + .cv-experience-section {
    margin-top: 0.95rem;
}

.cv-experience-section h5 {
    margin-bottom: 0.45rem;
    color: var(--site-ink-strong);
    font-size: 0.88rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cv-experience-section p {
    margin-bottom: 0;
    color: var(--site-ink);
    line-height: 1.75;
}

.cv-responsibility-list {
    display: grid;
    gap: 0.45rem;
    margin: 0;
    padding-left: 1.1rem;
    color: var(--site-ink);
}

.inner-page .cv-skill-card {
    padding: 0.9rem 0.95rem;
}

.inner-page--skills .cv-skill-card {
    padding: 0.95rem 1rem;
    border-radius: 15px !important;
}

.cv-skill-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.72rem;
    height: 100%;
}

.cv-skill-card__topline {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.65rem;
}

.cv-skill-card__category {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 28px;
    padding: 0.28rem 0.62rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.cv-skill-card__category .category-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    color: var(--site-blue);
}

.cv-skill-card__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.75rem;
}

.cv-skill-card__title {
    color: var(--site-ink-strong);
    font-weight: 800;
    line-height: 1.35;
}

.cv-skill-card__content {
    color: var(--site-ink);
}

.cv-skill-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.55rem;
}

.cv-skill-note {
    margin-top: 0.55rem;
    color: var(--site-ink-soft);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.inner-page--qualifications .cv-qualification-card .e-card-content {
    padding: 0;
    height: 100%;
}

.inner-page--qualifications .cv-qualification-card__text {
    margin: 0;
    color: var(--site-ink);
    font-size: 0.93rem;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 7;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.inner-page--qualifications .cv-qualification-card__text.cv-skill-note {
    margin-top: 0;
    color: var(--site-ink-soft);
}

.inner-page--qualifications .cv-qualification-card__category .qual-icon {
    display: block;
    width: 14px;
    height: 14px;
    object-fit: contain;
    opacity: 0.95;
}

.inner-page--qualifications .cv-qualification-card--highlighted {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(241, 247, 255, 0.96)) !important;
    box-shadow:
        0 18px 42px rgba(40, 71, 125, 0.11) !important,
        inset 0 0 0 1px rgba(160, 194, 243, 0.55) !important;
}

.inner-page--booking {
    gap: 0.2625rem;
}

.inner-page--contact {
    gap: 0.2625rem;
}

.inner-page--labs {
    gap: 0.2625rem;
}

.inner-page--management,
.inner-page--privacy,
.inner-page--file-tools {
    gap: 0.2625rem;
}

.inner-page--management .cv-record-shell,
.inner-page--privacy .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.inner-page--management .management-intro-card,
.inner-page--management .management-section-card,
.privacy-shell {
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06) !important;
}

.inner-page--management .e-card-header,
.inner-page--management .e-card-content {
    padding: 1rem !important;
}

.inner-page--management .management-section-card {
    height: 100%;
}

.inner-page--management .management-section-card .e-card-header h5 {
    color: #111827;
    font-weight: 850;
    line-height: 1.25;
}

.inner-page--management .management-section-card .e-card-content {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.inner-page--management .management-section-card .e-card-content p {
    flex: 1;
    color: #475569;
    line-height: 1.55;
}

.privacy-shell {
    padding: clamp(1.25rem, 3vw, 2rem);
    color: #334155;
    line-height: 1.78;
}

.privacy-shell h1 {
    display: none;
}

.privacy-shell h2 {
    margin: 1.35rem 0 0.55rem;
    color: #111827;
    font-size: clamp(1.2rem, 2vw, 1.45rem);
    font-weight: 850;
}

.privacy-shell h2:first-of-type {
    margin-top: 0.5rem;
}

.privacy-shell ul {
    display: grid;
    gap: 0.4rem;
    margin-bottom: 0;
    padding-left: 1.25rem;
}

.page-content-card--inner > h1,
.page-content-card--inner > .row {
    width: min(980px, 100%);
    margin-inline: auto;
}

.page-content-card--inner > h1 {
    margin-top: 0.25rem;
    margin-bottom: 0.75rem;
    color: #111827;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 900;
    letter-spacing: 0;
    text-align: center;
}

.page-content-card--inner > .row {
    padding: clamp(1rem, 2.4vw, 1.6rem);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--border-neutral);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.page-content-card--inner > .row section h2,
.page-content-card--inner > .row section h3 {
    color: #111827;
    font-weight: 850;
    letter-spacing: 0;
}

.inner-page--account {
    width: 100%;
}

.account-shell {
    width: min(980px, 100%);
    margin-inline: auto;
    padding: clamp(1.1rem, 2.6vw, 1.8rem);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid var(--border-neutral);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.account-shell > h1 {
    margin: 0 0 0.9rem;
    color: #111827;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 900;
    letter-spacing: 0;
    text-align: center;
}

.account-shell > .row {
    --bs-gutter-x: clamp(1rem, 3vw, 2rem);
    --bs-gutter-y: 1.25rem;
    align-items: flex-start;
    margin: 0;
}

.account-shell > .row > [class*="col-"] {
    min-width: 0;
}

.account-shell section {
    padding: 1rem;
    border-radius: 8px;
    background: rgba(248, 250, 252, 0.76);
    border: 1px solid rgba(226, 232, 240, 0.95);
}

.account-shell h2,
.account-shell h3 {
    color: #111827;
    font-weight: 850;
    letter-spacing: 0;
}

.account-shell h2 {
    font-size: clamp(1.25rem, 2vw, 1.65rem);
}

.account-shell h3 {
    font-size: clamp(1.1rem, 1.7vw, 1.35rem);
}

.account-shell p,
.account-shell a {
    overflow-wrap: anywhere;
}

.account-shell .form-control,
.account-shell .btn {
    width: 100%;
}

.account-shell .form-floating > label {
    color: #475569;
}

.inner-page--visitor-analytics {
    gap: 0.2625rem;
}

.inner-page--visitor-analytics .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

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

.analytics-summary-card,
.analytics-section-card {
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 18px 36px rgba(24, 56, 114, 0.09);
    border: 1px solid rgba(223, 232, 247, 0.95);
}

.analytics-summary-card {
    padding: 1.25rem 1.35rem;
}

.analytics-summary-card__label {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--site-ink-soft);
    font-size: 0.88rem;
    font-weight: 700;
}

.analytics-summary-card__value {
    color: var(--site-ink-strong);
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: -0.03em;
}

.analytics-section-card {
    padding: 1rem 1.1rem;
}

.analytics-section-card__header h3 {
    margin: 0 0 0.8rem;
    color: var(--site-ink-strong);
    font-size: 1.05rem;
    font-weight: 800;
}

.analytics-table {
    margin-bottom: 0;
}

.analytics-table thead th {
    color: var(--site-ink-soft);
    font-size: 0.84rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.analytics-table td {
    color: var(--site-ink);
    font-size: 0.94rem;
}

@media (max-width: 991.98px) {
    .analytics-summary-grid {
        grid-template-columns: 1fr;
    }
}

.inner-page--labs .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.labs-shell__intro {
    max-width: 780px;
    margin: 0 auto;
}

.labs-shell__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.labs-shell__intro-text {
    margin: 0.9rem 0 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.8;
}

.cv-card-grid--labs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.labs-card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    height: 100%;
    padding: 1.2rem 1.3rem !important;
}

.labs-card__icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    border-radius: 16px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 1.25rem;
}

.labs-card__title {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: 1.18rem;
    font-weight: 800;
}

.labs-card__text {
    margin: 0;
    color: var(--site-ink);
    line-height: 1.8;
}

.labs-card__tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.labs-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.72rem;
    border-radius: 999px;
    background: rgba(244, 248, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(198, 215, 242, 0.95);
    color: var(--site-blue);
    font-size: 0.82rem;
    font-weight: 700;
}

.labs-card__actions {
    margin-top: auto;
}

.labs-card__actions--stacked {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.8rem;
}

.labs-youtube-btn {
    min-height: 48px;
    padding-inline: 1.1rem;
    border-radius: 999px !important;
    font-weight: 800 !important;
    box-shadow: 0 14px 24px rgba(196, 30, 58, 0.18);
}

.labs-card__subnote {
    color: var(--site-ink-soft);
    font-size: 0.92rem;
    line-height: 1.65;
}

.inner-page--mermaid-tool {
    gap: 0.2625rem;
}

.mermaid-product-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.95fr);
    gap: clamp(1.2rem, 3vw, 2.25rem);
    align-items: center;
    width: min(1180px, 100%);
    margin: -0.35rem auto 0.8rem;
    padding: clamp(1rem, 3vw, 2.1rem) clamp(0.65rem, 2.4vw, 1.7rem);
}

.mermaid-product-hero__copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
}

.mermaid-product-hero__copy h1 {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: clamp(2.2rem, 5vw, 4.6rem);
    line-height: 0.98;
    font-weight: 800;
    max-width: 820px;
}

.mermaid-product-hero__copy p {
    margin: 0;
    max-width: 680px;
    color: #31537f;
    font-size: clamp(1rem, 1.7vw, 1.22rem);
    line-height: 1.75;
}

.mermaid-product-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 0.3rem;
}

.mermaid-product-trust-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.7rem;
    margin-top: 0.35rem;
}

.mermaid-product-trust-row span {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 36px;
    padding: 0.45rem 0.75rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.68);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.78);
    color: #264a76;
    font-size: 0.86rem;
    font-weight: 800;
}

.mermaid-product-trust-row i {
    color: #14715f;
}

.mermaid-product-hero__preview {
    display: grid;
    gap: 0.9rem;
}

.mermaid-preview-window {
    overflow: hidden;
    border-radius: 8px;
    background: #172033;
    border: 1px solid rgba(111, 138, 182, 0.34);
    box-shadow: 0 24px 60px rgba(27, 54, 102, 0.22);
}

.mermaid-preview-window__bar {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 42px;
    padding: 0 0.9rem;
    background: #202d45;
    color: #bfd0ea;
    font-size: 0.82rem;
}

.mermaid-preview-window__bar span {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #58c59d;
}

.mermaid-preview-window__bar span:first-child {
    background: #ef6f76;
}

.mermaid-preview-window__bar span:nth-child(2) {
    background: #f4c15d;
}

.mermaid-preview-window__bar strong {
    margin-left: 0.4rem;
    font-weight: 800;
}

.mermaid-preview-window pre {
    margin: 0;
    padding: 1.1rem;
    color: #eef6ff;
    font-size: clamp(0.78rem, 1.4vw, 0.92rem);
    line-height: 1.75;
    white-space: pre-wrap;
}

.mermaid-preview-output {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    padding: 0.85rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.78);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.82), 0 14px 30px rgba(32, 70, 130, 0.08);
}

.mermaid-preview-output__node {
    display: grid;
    place-items: center;
    min-width: 116px;
    min-height: 52px;
    padding: 0.55rem 0.85rem;
    border-radius: 8px;
    background: #f3f8ff;
    color: #245181;
    font-weight: 800;
    box-shadow: inset 0 0 0 1px rgba(179, 203, 238, 0.88);
}

.mermaid-preview-output__node--strong {
    background: #e8f8f2;
    color: #12614f;
    box-shadow: inset 0 0 0 1px rgba(111, 192, 163, 0.72);
}

.inner-page--mermaid-tool .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.mermaid-commercial-strip {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.34fr);
    gap: 1rem;
    align-items: stretch;
    padding: clamp(1rem, 2.5vw, 1.35rem);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: 0 18px 42px rgba(32, 70, 130, 0.09);
}

.mermaid-commercial-strip h2 {
    margin: 0.8rem 0 0.45rem;
    color: var(--site-ink-strong);
    font-size: clamp(1.35rem, 2.6vw, 2rem);
    font-weight: 800;
}

.mermaid-commercial-strip p {
    margin: 0;
    color: var(--site-ink-soft);
    line-height: 1.75;
}

.mermaid-plan-card {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.45rem;
    padding: 1rem;
    border-radius: 8px;
    background: #173454;
    color: #f7fbff;
    box-shadow: 0 16px 34px rgba(19, 49, 86, 0.18);
}

.mermaid-plan-card__label {
    color: #96ddcb;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.07em;
    text-transform: uppercase;
}

.mermaid-plan-card strong {
    font-size: 1.2rem;
    line-height: 1.3;
}

.mermaid-plan-card small {
    color: #d6e3f4;
    line-height: 1.55;
}

.tool-shell__intro {
    max-width: 760px;
    margin: 0 auto;
}

.tool-shell__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.tool-shell__intro-text {
    margin: 0.9rem 0 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.8;
}

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

.tool-status-card {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1rem 1.05rem;
}

.tool-status-card__icon-wrap,
.tool-panel__icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 15px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 1.18rem;
    flex: 0 0 48px;
}

.tool-status-card__label {
    display: block;
    margin-bottom: 0.35rem;
    color: var(--site-ink-soft);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.tool-workbench-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: 1rem;
    align-items: start;
}

.tool-panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: 1.2rem 1.25rem !important;
}

.tool-panel__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.tool-panel__header-main {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
}

.tool-panel__title {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: 1.15rem;
    font-weight: 800;
}

.tool-panel__text {
    margin: 0.35rem 0 0;
    color: var(--site-ink-soft);
    line-height: 1.7;
}

.tool-mode-switch {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.tool-upload-shell,
.tool-textarea-shell {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.tool-upload-label {
    color: var(--site-ink-strong);
    font-size: 0.92rem;
    font-weight: 700;
}

.tool-upload-help {
    margin: 0;
    color: var(--site-ink-soft);
    font-size: 0.88rem;
}

.tool-textarea {
    min-height: 320px;
    resize: vertical;
    font-family: "JetBrains Mono", "Fira Code", Consolas, monospace;
}

.tool-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.tool-alert {
    margin: 0;
}

.tool-limit-callout {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    padding: 0.9rem 1rem;
    border-radius: 8px;
    background: #fff7e8;
    color: #80540f;
    box-shadow: inset 0 0 0 1px rgba(224, 174, 83, 0.52);
}

.tool-limit-callout i {
    margin-top: 0.15rem;
    color: #b36d00;
}

.tool-limit-callout div {
    display: grid;
    gap: 0.15rem;
}

.tool-placeholder-state {
    display: grid;
    place-items: center;
    gap: 0.85rem;
    min-height: 240px;
    padding: 1.2rem;
    text-align: center;
    border-radius: 20px;
    background: rgba(247, 250, 255, 0.82);
    box-shadow: inset 0 0 0 1px rgba(208, 222, 245, 0.9);
    color: var(--site-ink-soft);
}

.tool-panel__icon-wrap--placeholder {
    width: 56px;
    height: 56px;
    border-radius: 18px;
    font-size: 1.35rem;
}

.tool-readiness-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    font-weight: 800;
}

.tool-readiness-badge--good {
    background: rgba(233, 248, 238, 0.95);
    color: #1f7a45;
    box-shadow: inset 0 0 0 1px rgba(131, 201, 155, 0.55);
}

.tool-readiness-badge--warn {
    background: rgba(255, 246, 229, 0.96);
    color: #9a6513;
    box-shadow: inset 0 0 0 1px rgba(232, 191, 119, 0.58);
}

.tool-result-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
}

.tool-result-item {
    padding: 0.9rem 0.95rem;
    border-radius: 16px;
    background: rgba(242, 247, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.92);
}

.tool-result-item__label {
    display: block;
    margin-bottom: 0.28rem;
    color: var(--site-ink-soft);
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.tool-plan-meter {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 0.9rem 1rem;
    border-radius: 8px;
    background: #eef9f5;
    color: #164f45;
    box-shadow: inset 0 0 0 1px rgba(121, 194, 169, 0.52);
}

.tool-plan-meter div {
    display: grid;
    gap: 0.2rem;
}

.tool-plan-meter span {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.tool-list-block {
    padding: 0.95rem 1rem;
    border-radius: 16px;
}

.tool-list-block h4 {
    margin: 0 0 0.65rem;
    font-size: 0.95rem;
    font-weight: 800;
}

.tool-list-block ul {
    margin: 0;
    padding-left: 1.1rem;
}

.tool-list-block--danger {
    background: rgba(255, 240, 242, 0.96);
    box-shadow: inset 0 0 0 1px rgba(226, 147, 164, 0.46);
    color: #8f3348;
}

.tool-list-block--warning {
    background: rgba(255, 249, 236, 0.98);
    box-shadow: inset 0 0 0 1px rgba(231, 199, 134, 0.52);
    color: #8b6214;
}

.tool-next-step-callout,
.tool-download-callout {
    padding: 0.95rem 1rem;
    border-radius: 16px;
    color: var(--site-ink);
    line-height: 1.7;
}

.tool-next-step-callout {
    background: rgba(240, 246, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.92);
}

.tool-download-callout {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
    background: rgba(234, 247, 238, 0.96);
    box-shadow: inset 0 0 0 1px rgba(133, 199, 156, 0.44);
}

.tool-download-callout p {
    margin: 0;
}

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

.mermaid-growth-grid article {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    padding: 1rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid rgba(255, 255, 255, 0.86);
    box-shadow: 0 14px 30px rgba(32, 70, 130, 0.07);
}

.mermaid-growth-grid i {
    display: inline-grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 8px;
    background: #eef9f5;
    color: #14715f;
    font-size: 1.12rem;
}

.mermaid-growth-grid h3 {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: 1rem;
    font-weight: 800;
}

.mermaid-growth-grid p {
    margin: 0;
    color: var(--site-ink-soft);
    line-height: 1.65;
    font-size: 0.92rem;
}

@media (max-width: 991.98px) {
    .mermaid-product-hero,
    .mermaid-commercial-strip,
    .tool-status-grid,
    .tool-workbench-grid,
    .tool-result-grid,
    .mermaid-growth-grid {
        grid-template-columns: 1fr;
    }

    .tool-panel__header,
    .tool-panel__header-main,
    .tool-status-card {
        flex-direction: column;
    }

    .mermaid-product-hero {
        margin-top: 0;
    }
}

@media (max-width: 767.98px) {
    .cv-card-grid--labs {
        grid-template-columns: 1fr;
    }

    .tool-mode-switch,
    .tool-actions-row {
        flex-direction: column;
    }

    .mermaid-product-hero__actions,
    .tool-plan-meter {
        align-items: stretch;
        flex-direction: column;
    }

    .mermaid-product-hero__actions .btn,
    .tool-plan-meter .btn {
        width: 100%;
    }

    .mermaid-preview-output {
        align-items: stretch;
        flex-direction: column;
    }

    .mermaid-preview-output i {
        transform: rotate(90deg);
    }
}

/* =========================================================
   Mermaid-to-Visio engineering product redesign
   ========================================================= */
.site-global-background--disabled,
.site-global-background--disabled .site-global-background__video,
.site-global-background--disabled .site-global-background__fallback,
.site-global-background--disabled .site-global-background__overlay {
    display: none !important;
}

.page--engineering-tool {
    --site-font-body: "Inter", "Segoe UI", system-ui, sans-serif;
    --site-font-heading: "Inter", "Segoe UI", system-ui, sans-serif;
    --site-ink-strong: var(--text-primary);
    --site-ink: #334155;
    --site-ink-soft: #64748b;
    --site-blue: var(--accent-primary);
    --site-blue-strong: var(--accent-primary-strong);
    color: var(--text-primary);
    background-color: var(--bg-main);
    background-image: radial-gradient(circle, rgba(45, 55, 72, 0.18) 1px, transparent 1.2px);
    background-size: 24px 24px;
}

.page--engineering-tool::before {
    display: none;
}

.page-main--engineering-tool {
    padding-top: 4.35rem !important;
    padding-bottom: 0 !important;
}

.page-content--engineering-tool {
    max-width: 1280px;
}

.page--engineering-chrome .site-navbar.navbar,
.page--engineering-tool .site-navbar.navbar {
    padding-top: 1.1rem !important;
}

.page--engineering-chrome .site-navbar__inner,
.page--engineering-tool .site-navbar__inner {
    max-width: 1040px;
    min-height: 58px;
    padding: 0.7rem 1rem;
    border-radius: 8px;
    background: rgba(247, 247, 250, 0.92) !important;
    border: 1px solid rgba(226, 232, 240, 0.92) !important;
    box-shadow: 0 18px 46px rgba(15, 23, 42, 0.08) !important;
}

.page--engineering-chrome .nav-brand,
.page--engineering-tool .nav-brand {
    gap: 0.65rem;
}

.page--engineering-chrome .nav-brand-avatar,
.page--engineering-tool .nav-brand-avatar {
    width: 38px;
    height: 38px;
    flex-basis: 38px;
    border-color: rgba(226, 232, 240, 0.98);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.10);
}

.page--engineering-chrome .nav-brand-name,
.page--engineering-tool .nav-brand-name {
    color: #111827;
    font-size: 1.02rem;
    font-weight: 800;
    letter-spacing: 0;
}

.page--engineering-chrome .nav-brand-role,
.page--engineering-tool .nav-brand-role {
    color: #475569;
    font-size: 0.78rem;
    font-weight: 500;
}

.page--engineering-chrome .site-navbar__actions .nav-link,
.page--engineering-tool .site-navbar__actions .nav-link {
    color: #111827 !important;
    border-radius: 6px;
    font-weight: 700;
}

.page--engineering-chrome .site-navbar__actions .nav-link:hover,
.page--engineering-chrome .site-navbar__actions .nav-link:focus,
.page--engineering-chrome .site-navbar__actions .nav-link.active,
.page--engineering-tool .site-navbar__actions .nav-link:hover,
.page--engineering-tool .site-navbar__actions .nav-link:focus,
.page--engineering-tool .site-navbar__actions .nav-link.active {
    color: var(--accent-primary) !important;
    background: rgba(63, 43, 232, 0.08) !important;
}

.inner-page--mermaid-tool {
    gap: clamp(2.2rem, 4.2vw, 4rem);
    font-family: "Inter", "Segoe UI", system-ui, sans-serif;
}

.inner-page--mermaid-tool .btn {
    border-radius: 7px !important;
    letter-spacing: 0;
}

.inner-page--mermaid-tool .btn-primary {
    color: #fff !important;
    border-color: var(--accent-primary) !important;
    background: var(--accent-primary) !important;
    box-shadow: 0 18px 34px rgba(63, 43, 232, 0.22);
}

.inner-page--mermaid-tool .btn-primary:hover,
.inner-page--mermaid-tool .btn-primary:focus {
    border-color: var(--accent-primary-strong) !important;
    background: var(--accent-primary-strong) !important;
}

.inner-page--mermaid-tool .btn-primary:disabled {
    opacity: 0.52;
    box-shadow: none;
}

.inner-page--mermaid-tool .btn-outline-primary {
    color: var(--accent-primary) !important;
    border-color: rgba(63, 43, 232, 0.38) !important;
    background: transparent !important;
}

.inner-page--mermaid-tool code,
.inner-page--mermaid-tool pre,
.inner-page--mermaid-tool textarea,
.tool-result-item strong,
.tool-plan-meter strong,
.tool-list-block,
.tool-file-chip {
    font-family: "Fira Code", "JetBrains Mono", "Source Code Pro", Consolas, monospace;
}

.mermaid-product-hero {
    grid-template-columns: minmax(300px, 0.92fr) minmax(520px, 1.08fr);
    gap: clamp(1.6rem, 3.4vw, 3.6rem);
    width: min(1120px, 100%);
    min-height: auto;
    margin: 0 auto;
    padding: clamp(0.65rem, 2.2vw, 1.65rem) 0 clamp(1.15rem, 2.6vw, 2rem);
    background: transparent !important;
}

.mermaid-product-hero__copy {
    gap: 1.35rem;
}

.tool-shell__eyebrow {
    min-height: auto;
    padding: 0;
    border-radius: 0;
    color: var(--accent-primary);
    background: transparent;
    box-shadow: none;
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.08em;
}

.mermaid-product-hero__copy h1 {
    max-width: 600px;
    color: #050505;
    font-size: clamp(2.55rem, 4.15vw, 4.45rem);
    line-height: 1.06;
    font-weight: 900;
    letter-spacing: 0;
}

.mermaid-product-hero__copy p {
    max-width: 520px;
    color: #111827;
    font-size: clamp(1.02rem, 1.4vw, 1.22rem);
    line-height: 1.55;
}

.mermaid-product-hero__actions {
    margin-top: 0.25rem;
}

.mermaid-product-hero__actions .btn {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 54px;
    padding: 0.95rem 1.45rem;
    font-weight: 850 !important;
}

.mermaid-product-trust-row {
    gap: 0.65rem;
}

.mermaid-product-trust-row span {
    min-height: 34px;
    padding: 0.42rem 0.68rem;
    border-radius: 999px;
    color: #334155;
    background: rgba(255, 255, 255, 0.62);
    box-shadow: inset 0 0 0 1px rgba(226, 232, 240, 0.9);
}

.mermaid-product-trust-row i {
    color: #111827;
}

.mermaid-product-hero__proof {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.25fr);
    gap: 1rem;
    align-items: center;
}

.mermaid-code-proof,
.code-editor-shell {
    overflow: hidden;
    border-radius: 8px;
    background: var(--bg-editor);
    border: 1px solid rgba(148, 163, 184, 0.32);
    box-shadow: 0 26px 56px rgba(15, 23, 42, 0.18);
}

.mermaid-window-bar {
    display: flex;
    align-items: center;
    gap: 0.48rem;
    min-height: 38px;
    padding: 0 0.9rem;
    color: #cbd5e1;
    background: #243047;
    font-family: "Fira Code", Consolas, monospace;
    font-size: 0.75rem;
}

.mermaid-window-bar .dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
}

.dot--red { background: #ef6b73; }
.dot--yellow { background: #f4c15d; }
.dot--green { background: #58c59d; }

.mermaid-window-bar strong {
    margin-left: 0.38rem;
    font-weight: 700;
}

.mermaid-window-bar em {
    margin-left: auto;
    color: #94a3b8;
    font-style: normal;
}

.mermaid-code-proof pre {
    margin: 0;
    padding: 1rem 1.05rem 1.15rem;
    color: #e2e8f0;
    font-size: clamp(0.74rem, 0.78vw, 0.9rem);
    line-height: 1.85;
    white-space: pre-wrap;
}

.mermaid-code-proof code span {
    display: inline-block;
    width: 2.2rem;
    color: #64748b;
    user-select: none;
}

.visio-proof {
    overflow: hidden;
    min-height: 310px;
    border: 8px solid #111827;
    border-radius: 9px;
    background: #2f3339;
    box-shadow: 0 26px 60px rgba(15, 23, 42, 0.24);
}

.visio-proof__chrome,
.visio-proof__ribbon {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 34px;
    padding: 0 0.9rem;
    color: #cbd5e1;
    background: #171a1f;
    font-size: 0.72rem;
}

.visio-proof__chrome div {
    display: flex;
    gap: 0.75rem;
}

.visio-proof__ribbon {
    justify-content: flex-start;
    gap: 1rem;
    min-height: 36px;
    background: #22262c;
    color: #e5e7eb;
    font-size: 0.68rem;
}

.visio-proof__canvas {
    position: relative;
    height: 250px;
    margin: 0.75rem 1.05rem 1rem;
    background:
        linear-gradient(90deg, #f8fafc 0 68%, #55585d 68% 100%);
    border: 1px solid rgba(226, 232, 240, 0.12);
}

.visio-proof__canvas svg {
    position: absolute;
    inset: 0;
    width: 68%;
    height: 100%;
    fill: none;
    stroke: #475569;
    stroke-width: 2.5;
    z-index: 1;
}

.visio-node {
    position: absolute;
    z-index: 2;
    display: grid;
    place-items: center;
    min-width: 110px;
    min-height: 42px;
    padding: 0.35rem 0.65rem;
    border-radius: 5px;
    color: #111827;
    background: #eeeefc;
    border: 1px solid #c7c9e9;
    font-size: 0.72rem;
    font-weight: 700;
}

.visio-node--start {
    top: 18px;
    left: 156px;
}

.visio-node--selected {
    top: 102px;
    left: 140px;
    background: #f5f3ff;
    border: 3px solid #6ea7be;
}

.visio-node--selected i {
    position: absolute;
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: #f8fafc;
    border: 2px solid #4f9ab7;
}

.visio-node--selected i:nth-child(1) { top: -8px; left: -8px; }
.visio-node--selected i:nth-child(2) { top: -8px; right: -8px; }
.visio-node--selected i:nth-child(3) { bottom: -8px; left: -8px; }
.visio-node--selected i:nth-child(4) { bottom: -8px; right: -8px; }

.visio-node--side {
    bottom: 28px;
    left: 56px;
}

.visio-node--end {
    bottom: 28px;
    left: 220px;
}

.inner-page--mermaid-tool .cv-record-shell {
    width: min(1180px, 100%);
    margin: 0 auto;
    gap: 1.35rem;
    padding: 0 0 clamp(2rem, 5vw, 4rem) !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.security-proof-band {
    display: grid;
    grid-template-columns: auto minmax(260px, 1fr) auto;
    gap: 1.25rem;
    align-items: center;
    padding: 1.1rem 1.25rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.84);
    border: 1px solid var(--border-neutral);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.mermaid-commercial-ref {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: center;
    padding: 1.1rem 1.25rem;
    border-radius: 8px;
    color: #f8fafc;
    background:
        linear-gradient(135deg, rgba(17, 24, 39, 0.98), rgba(49, 46, 129, 0.94));
    border: 1px solid rgba(165, 180, 252, 0.34);
    box-shadow: 0 22px 46px rgba(15, 23, 42, 0.18);
}

.mermaid-commercial-ref__icon {
    display: grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border-radius: 8px;
    color: #111827;
    background: #eef2ff;
    font-size: 1.45rem;
}

.mermaid-commercial-ref .tool-shell__eyebrow {
    color: #c4b5fd;
}

.mermaid-commercial-ref h2 {
    margin: 0.25rem 0 0;
    color: #ffffff;
    font-size: clamp(1.18rem, 1.7vw, 1.55rem);
    font-weight: 900;
    letter-spacing: 0;
}

.mermaid-commercial-ref p {
    max-width: 72ch;
    margin: 0.4rem 0 0;
    color: #dbeafe;
    line-height: 1.55;
}

.mermaid-commercial-ref .btn {
    white-space: nowrap;
}

.security-proof-band__icons {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    color: #111827;
    font-size: 2rem;
}

.security-proof-band strong,
.security-proof-band span {
    display: block;
}

.security-proof-band strong {
    color: #050505;
    font-size: 1rem;
    font-weight: 900;
}

.security-proof-band span {
    color: #334155;
}

.diagram-type-strip {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.9rem;
}

.diagram-type-strip span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: #111827;
    font-size: 0.78rem;
    font-weight: 800;
}

.diagram-type-strip i {
    font-size: 1.35rem;
}

.tool-workbench-grid {
    grid-template-columns: minmax(0, 1.9fr) minmax(310px, 0.9fr);
    gap: 1rem;
}

.tool-panel {
    padding: 1.2rem !important;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid var(--border-neutral);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.tool-panel--editor {
    background: rgba(255, 255, 255, 0.74);
}

.tool-panel__header--compact {
    align-items: flex-start;
}

.tool-panel__title {
    margin-top: 0.28rem;
    color: #050505;
    font-size: clamp(1.45rem, 2vw, 2rem);
    font-weight: 900;
    letter-spacing: 0;
}

.tool-editor-links {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.2rem 0.8rem;
}

.tool-editor-links .btn-link,
.tool-analysis-toggle {
    padding: 0;
    color: #111827 !important;
    font-weight: 800;
    text-decoration: underline;
    text-underline-offset: 3px;
    box-shadow: none !important;
}

.editor-upload-zone {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    min-height: 76px;
    padding: 0.95rem 1rem;
    border: 1px dashed #94a3b8;
    border-radius: 8px;
    color: #111827;
    background: rgba(248, 250, 252, 0.86);
    cursor: pointer;
    transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.editor-upload-zone:hover,
.editor-upload-zone:focus-within {
    border-color: var(--accent-primary);
    background: rgba(245, 243, 255, 0.94);
    box-shadow: 0 10px 24px rgba(63, 43, 232, 0.08);
}

.editor-upload-zone--locked {
    cursor: default;
    border-style: solid;
    border-color: rgba(99, 102, 241, 0.26);
    background: rgba(238, 242, 255, 0.92);
}

.editor-upload-zone--locked:hover,
.editor-upload-zone--locked:focus-within {
    border-color: rgba(99, 102, 241, 0.34);
    background: rgba(238, 242, 255, 0.92);
    box-shadow: none;
}

.editor-upload-zone--locked i {
    background: #111827;
}

.editor-upload-zone--locked a {
    color: var(--accent-primary);
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.editor-upload-zone i {
    display: grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: 8px;
    color: #fff;
    background: var(--accent-primary);
    font-size: 1.2rem;
    flex: 0 0 42px;
}

.editor-upload-zone span,
.editor-upload-zone strong,
.editor-upload-zone em {
    display: block;
}

.editor-upload-zone strong {
    font-weight: 900;
}

.editor-upload-zone em {
    margin-top: 0.12rem;
    color: #64748b;
    font-style: normal;
    font-size: 0.82rem;
}

.code-editor-shell {
    min-height: 390px;
}

.code-editor-body {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    min-height: 352px;
    background: #111827;
}

.code-line-numbers {
    display: grid;
    grid-template-rows: repeat(18, 1.4rem);
    gap: 0.1rem;
    padding: 1rem 0.75rem;
    color: #64748b;
    background: #101722;
    font-family: "Fira Code", Consolas, monospace;
    font-size: 0.82rem;
    text-align: right;
    user-select: none;
}

.tool-textarea {
    min-height: 352px;
    height: 100%;
    padding: 1rem 1.1rem;
    resize: vertical;
    color: #f8fafc !important;
    background: #111827 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    caret-color: #a5b4fc;
    font-size: 0.92rem;
    line-height: 1.55;
}

.tool-textarea::placeholder {
    color: #94a3b8;
}

.inner-page--mermaid-tool .code-editor-body textarea.form-control.tool-textarea {
    color: #f8fafc !important;
    background-color: #111827 !important;
    background-image: none !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    outline: none !important;
}

.inner-page--mermaid-tool .code-editor-body textarea.form-control.tool-textarea::placeholder {
    color: #94a3b8 !important;
    opacity: 1;
}

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

.tool-generate-btn {
    width: min(520px, 100%);
    min-height: 48px;
    font-weight: 900 !important;
}

.tool-actions-row__hint {
    color: #64748b;
    font-size: 0.86rem;
    font-weight: 700;
}

.tool-upload-help {
    color: #475569;
    line-height: 1.65;
}

.tool-upload-help code,
.tool-upload-help span {
    color: #be185d;
}

.tool-alert {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    border-radius: 8px;
}

.tool-limit-callout {
    border-radius: 8px;
    background: #fff7ed;
    color: #9a3412;
}

.visually-hidden-file {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
}

.tool-file-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    width: fit-content;
    padding: 0.5rem 0.7rem;
    border-radius: 8px;
    color: #334155;
    background: #f8fafc;
    border: 1px solid var(--border-neutral);
    font-size: 0.82rem;
}

.tool-placeholder-state {
    min-height: 180px;
    border-radius: 8px;
    color: #475569;
    background: #f8fafc;
    box-shadow: inset 0 0 0 1px var(--border-neutral);
}

.tool-placeholder-state > i {
    color: #111827;
    font-size: 2.2rem;
}

.tool-readiness-badge {
    border-radius: 8px;
    justify-content: flex-start;
    font-family: "Fira Code", Consolas, monospace;
    font-size: 0.85rem;
}

.tool-readiness-badge--good {
    color: #065f46;
    background: #ecfdf5;
    box-shadow: inset 0 0 0 1px #a7f3d0;
}

.tool-readiness-badge--warn {
    color: #92400e;
    background: #fffbeb;
    box-shadow: inset 0 0 0 1px #fde68a;
}

.tool-result-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tool-result-item {
    border-radius: 8px;
    background: #f8fafc;
    box-shadow: inset 0 0 0 1px var(--border-neutral);
}

.tool-result-item__label {
    color: #64748b;
}

.tool-result-item strong {
    color: #111827;
}

.tool-plan-meter {
    border-radius: 8px;
    color: #1e293b;
    background: #f8fafc;
    box-shadow: inset 0 0 0 1px var(--border-neutral);
}

.tool-list-block {
    border-radius: 8px;
    font-size: 0.85rem;
}

.tool-next-step-callout,
.tool-download-callout {
    border-radius: 8px;
    color: #334155;
    background: #f8fafc;
    box-shadow: inset 0 0 0 1px var(--border-neutral);
}

.tool-download-callout {
    background: #ecfdf5;
}

.mermaid-commercial-strip {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.36fr);
    padding: clamp(1.2rem, 2.4vw, 2rem);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid var(--border-neutral);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.mermaid-commercial-strip h2 {
    color: #050505;
    font-weight: 900;
    letter-spacing: 0;
}

.mermaid-commercial-strip p {
    color: #475569;
}

.mermaid-plan-card {
    gap: 0.65rem;
    padding: 1.2rem;
    border-radius: 8px;
    color: #fff;
    background: linear-gradient(135deg, #13243d, #0f335a);
    box-shadow: 0 20px 44px rgba(15, 23, 42, 0.18);
}

.mermaid-plan-card__label {
    width: fit-content;
    padding: 0.34rem 0.58rem;
    border-radius: 999px;
    color: #0f172a;
    background: #dbeafe;
    letter-spacing: 0.05em;
}

.mermaid-plan-card strong {
    font-size: 1.35rem;
}

.mermaid-plan-card ul {
    display: grid;
    gap: 0.34rem;
    margin: 0.15rem 0 0.35rem;
    padding-left: 1.15rem;
    color: #e2e8f0;
}

.mermaid-plan-card .btn {
    width: 100%;
    box-shadow: 0 16px 30px rgba(63, 43, 232, 0.28);
}

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

.mermaid-growth-grid article {
    min-height: 230px;
    padding: 1.25rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.88);
    border: 1px solid var(--border-neutral);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.mermaid-growth-grid i {
    width: 52px;
    height: 52px;
    border-radius: 8px;
    color: #111827;
    background: transparent;
    box-shadow: none;
    font-size: 2rem;
}

.mermaid-growth-grid h3 {
    color: #050505;
    font-size: 1.28rem;
    font-weight: 900;
}

.mermaid-growth-grid p {
    color: #334155;
    font-size: 0.98rem;
}

.cw-footer__profile-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 1rem;
    padding: 0.85rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(226, 232, 240, 0.92);
}

.cw-footer__profile-card img {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    object-fit: cover;
}

.cw-footer__profile-card strong,
.cw-footer__profile-card span {
    display: block;
}

.cw-footer__profile-card strong {
    color: #111827;
    font-size: 0.98rem;
    font-weight: 900;
}

.cw-footer__profile-card span {
    color: #475569;
    font-size: 0.82rem;
    line-height: 1.3;
}

.cw-footer--engineering-tool {
    margin-top: 0;
    padding-bottom: 1rem;
    background: #e5e7eb;
}

.cw-footer--engineering-tool .cw-footer__shell {
    border-radius: 0;
    background: #e5e7eb;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
}

.cw-footer--engineering-tool .cw-footer__shell::before,
.cw-footer--engineering-tool .cw-footer__privacy-art {
    display: none;
}

.cw-footer--engineering-tool .cw-footer__cta {
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid #d1d5db;
    box-shadow: none;
}

.cw-footer--engineering-tool .cw-footer__cta h2,
.cw-footer--engineering-tool .cw-footer__col h4,
.cw-footer--engineering-tool .cw-footer__copyright strong {
    color: #111827 !important;
    letter-spacing: 0;
}

.cw-footer--engineering-tool .cw-footer__cta p,
.cw-footer--engineering-tool .cw-footer__eyebrow,
.cw-footer--engineering-tool .cw-footer__text,
.cw-footer--engineering-tool .cw-footer__links a,
.cw-footer--engineering-tool .cw-footer__contact-list a,
.cw-footer--engineering-tool .cw-footer__copyright {
    color: #334155;
}

.cw-footer--engineering-tool .cw-footer__cta-btn {
    border-radius: 8px !important;
    background: var(--accent-primary) !important;
    box-shadow: 0 16px 28px rgba(63, 43, 232, 0.18);
}

.cw-footer--engineering-tool .cw-footer__secondary-btn,
.cw-footer--engineering-tool .cw-footer__privacy-chip,
.cw-footer--engineering-tool .cw-footer__social-links a,
.cw-footer--engineering-tool .cw-footer__icon-badge {
    border-radius: 8px !important;
    color: #111827 !important;
    background: #f8fafc !important;
    box-shadow: inset 0 0 0 1px #d1d5db;
}

.cw-footer--engineering-tool .cw-footer__bottom {
    background: transparent;
    border-top-color: #d1d5db;
}

@media (max-width: 1199.98px) {
    .mermaid-product-hero {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .mermaid-product-hero__proof {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .page-main--engineering-tool {
        padding-top: 4.15rem !important;
    }

    .security-proof-band,
    .mermaid-commercial-ref,
    .mermaid-commercial-strip,
    .tool-workbench-grid,
    .mermaid-growth-grid {
        grid-template-columns: 1fr;
    }

    .diagram-type-strip {
        justify-content: flex-start;
    }

    .tool-panel__header--compact {
        flex-direction: column;
    }

    .tool-editor-links {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .page--engineering-chrome .site-navbar__inner,
    .page--engineering-tool .site-navbar__inner {
        border-radius: 0;
    }

    .mermaid-product-hero {
        padding-top: 0.75rem;
    }

    .mermaid-product-hero__copy h1 {
        font-size: clamp(2.15rem, 11vw, 3.25rem);
    }

    .security-proof-band {
        align-items: flex-start;
    }

    .code-editor-body {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .code-line-numbers {
        padding-inline: 0.55rem;
        font-size: 0.72rem;
    }

    .tool-textarea {
        font-size: 0.82rem;
    }

    .visio-proof {
        border-width: 5px;
    }

    .visio-proof__canvas {
        transform-origin: top left;
        overflow: hidden;
    }

    .tool-plan-meter,
    .security-proof-band__icons {
        align-items: flex-start;
        flex-direction: column;
    }

    .tool-plan-meter .btn,
    .mermaid-plan-card .btn,
    .tool-generate-btn {
        width: 100%;
    }
}

/* =========================================================
   Creative Studio / channel-only landing page (not linked in main nav)
   ========================================================= */
.channel-page {
    min-height: 100vh;
    background:
        radial-gradient(circle at 12% 16%, rgba(226, 138, 88, 0.26), transparent 25%),
        radial-gradient(circle at 86% 12%, rgba(113, 148, 218, 0.26), transparent 24%),
        radial-gradient(circle at 54% 78%, rgba(233, 187, 115, 0.17), transparent 30%),
        linear-gradient(180deg, #211923 0%, #2b2030 28%, #21304a 62%, #172232 100%);
    color: #f7f2eb;
}

.channel-page--card-shell {
    min-height: auto;
    width: min(100% - 2rem, 1480px);
    margin: 2rem auto 3rem;
    overflow: hidden;
    border-radius: 30px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.10), 0 28px 70px rgba(5, 8, 18, 0.32);
}

.channel-page section,
.channel-page .section {
    background: transparent !important;
    color: inherit !important;
}

.channel-hero,
.channel-story,
.channel-mission,
.channel-playlist,
.channel-commission,
.channel-feedback,
.channel-cta-strip {
    position: relative;
}

.channel-hero {
    overflow: hidden;
    padding: clamp(4.8rem, 7vw, 6rem) 0 clamp(3rem, 5vw, 4rem);
}

.channel-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(15, 12, 18, 0.28) 0%, rgba(18, 16, 25, 0.11) 38%, rgba(20, 22, 32, 0) 100%),
        linear-gradient(180deg, rgba(255, 246, 228, 0.16) 0%, rgba(86, 113, 155, 0.10) 100%),
        url('/img/creative-studio-forest.jpg') center 28% / cover no-repeat;
    opacity: 1;
    filter: brightness(1.34) saturate(1.12);
    pointer-events: none;
}

.channel-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: url('/img/creative-studio-sacred-geometry.jpg') center / 680px auto repeat;
    opacity: 0.06;
    mix-blend-mode: screen;
    pointer-events: none;
}

.channel-hero__ambient {
    position: absolute;
    border-radius: 999px;
    filter: blur(50px);
    opacity: 0.55;
}

.channel-hero__ambient--one {
    top: 6rem;
    left: -4rem;
    width: 18rem;
    height: 18rem;
    background: rgba(92, 121, 240, 0.35);
}

.channel-hero__ambient--two {
    top: 2rem;
    right: -2rem;
    width: 15rem;
    height: 15rem;
    background: rgba(223, 76, 98, 0.25);
}

.channel-hero__ambient--three {
    bottom: 1rem;
    left: 34%;
    width: 20rem;
    height: 10rem;
    background: rgba(215, 171, 103, 0.18);
}

.channel-hero__inner {
    position: relative;
    z-index: 1;
    max-width: 920px;
    padding: clamp(1.15rem, 2vw, 1.8rem);
    border-radius: 28px;
    background: linear-gradient(90deg, rgba(14, 12, 18, 0.36), rgba(14, 12, 18, 0.13) 64%, rgba(14, 12, 18, 0));
}

.channel-kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
    color: rgba(255, 248, 238, 0.84);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.channel-kicker--soft {
    background: rgba(231, 188, 118, 0.12);
    color: #f0dec1;
}

.channel-title {
    margin: 1.15rem 0 0.95rem;
    color: #fffaf3;
    font-size: clamp(2.5rem, 4vw, 4.4rem);
    font-weight: 900;
    letter-spacing: -0.04em;
}

.channel-subtitle {
    margin: 0;
    max-width: 760px;
    color: rgba(247, 239, 229, 0.86);
    font-size: 1.12rem;
    line-height: 1.9;
}

.channel-hero__quote {
    max-width: 720px;
    margin: 1.25rem 0 0;
    padding-left: 1rem;
    border-left: 2px solid rgba(226, 183, 116, 0.55);
    color: rgba(242, 221, 191, 0.94);
    font-size: 1.03rem;
    line-height: 1.85;
    font-style: italic;
}

.channel-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 1.8rem;
}

.channel-btn-primary,
.channel-btn-secondary,
.channel-btn-support {
    min-height: 52px;
    padding-inline: 1.2rem;
    border-radius: 999px !important;
    font-weight: 800 !important;
}

.channel-btn-primary {
    box-shadow: 0 18px 32px rgba(179, 28, 52, 0.24);
}

.channel-btn-support {
    color: #2e1d0a !important;
    background: linear-gradient(135deg, #f5ddb1, #e8b96c) !important;
    border: 0 !important;
    box-shadow: 0 18px 38px rgba(210, 154, 66, 0.26);
}

.channel-btn-support:hover,
.channel-btn-support:focus {
    color: #241506 !important;
    background: linear-gradient(135deg, #f8e6c3, #efc580) !important;
}

.channel-story,
.channel-mission,
.channel-playlist,
.channel-commission,
.channel-feedback {
    padding: 0 0 2.5rem;
}

.channel-story__intro {
    max-width: 860px;
    margin-bottom: 1.5rem;
}

.channel-story__intro h2,
.channel-mission__panel h2,
.channel-commission__panel h2,
.channel-cta-strip__inner h3 {
    margin: 0 0 0.8rem;
    color: #fff8f0;
    font-size: clamp(1.8rem, 2.5vw, 2.4rem);
    font-weight: 850;
    letter-spacing: -0.03em;
}

.channel-story__intro p,
.channel-mission__panel p,
.channel-commission__panel p,
.channel-cta-strip__inner p {
    margin: 0;
    color: rgba(241, 232, 219, 0.82);
    font-size: 1rem;
    line-height: 1.85;
}

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

.channel-card,
.channel-mission__panel,
.channel-commission__panel,
.channel-feedback__panel,
.channel-cta-strip__inner,
.channel-list-card {
    position: relative;
    border-radius: 26px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.03));
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 20px 40px rgba(6, 11, 22, 0.25);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.channel-card {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    padding: 1.35rem 1.4rem;
}

.channel-card--warm {
    background: linear-gradient(180deg, rgba(214, 154, 103, 0.16), rgba(255, 255, 255, 0.03));
}

.channel-card--romance {
    background: linear-gradient(180deg, rgba(153, 71, 88, 0.18), rgba(255, 255, 255, 0.03));
}

.channel-card--pulse {
    background: linear-gradient(180deg, rgba(88, 109, 180, 0.18), rgba(255, 255, 255, 0.03));
}

.channel-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.08);
    color: #f5f7ff;
    font-size: 1.2rem;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
}

.channel-card h3,
.channel-list-card h3 {
    margin: 0;
    color: #fff;
    font-size: 1.16rem;
    font-weight: 800;
}

.channel-card p {
    margin: 0;
    color: rgba(233, 238, 251, 0.8);
    line-height: 1.8;
}

.channel-mission__grid {
    display: grid;
    grid-template-columns: 1.2fr 0.9fr;
    gap: 1rem;
}

.channel-mission__panel,
.channel-commission__panel,
.channel-feedback__panel {
    padding: 1.55rem 1.6rem;
}

.channel-mission__panel--accent {
    background: linear-gradient(180deg, rgba(202, 149, 75, 0.18), rgba(255, 255, 255, 0.04));
}

.channel-mission__panel--accent::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        linear-gradient(180deg, rgba(14, 11, 18, 0.08), rgba(14, 11, 18, 0.22)),
        url('/img/creative-studio-sacred-geometry.jpg') center / cover no-repeat;
    opacity: 0.10;
    pointer-events: none;
}

.channel-mission__panel > *,
.channel-commission__panel > *,
.channel-feedback__panel > *,
.channel-cta-strip__inner > * {
    position: relative;
    z-index: 1;
}

.channel-manifesto__chips,
.channel-commission__ideas {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    margin-top: 1.15rem;
}

.channel-manifesto__chips span,
.channel-commission__ideas span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0.42rem 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(244, 246, 255, 0.88);
    font-size: 0.84rem;
    font-weight: 700;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}

.channel-support__actions {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.8rem;
    margin-top: 1.25rem;
}

.channel-support__note {
    color: rgba(245, 231, 208, 0.74);
    font-size: 0.94rem;
    line-height: 1.7;
}

.channel-list-card {
    padding: 1.3rem 1.35rem;
}

.channel-list-card h3 {
    margin: 0 0 0.85rem;
}

.channel-list-card ul {
    display: grid;
    gap: 0.75rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.channel-list-card li {
    padding: 0.7rem 0.8rem;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(237, 241, 251, 0.88);
    line-height: 1.65;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.channel-story__intro--feedback {
    max-width: 860px;
    margin-bottom: 1.15rem;
}

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

.channel-feedback__field {
    min-width: 0;
}

.channel-feedback__field--full {
    grid-column: 1 / -1;
}

.channel-feedback__field label {
    display: inline-block;
    margin-bottom: 0.45rem;
    color: rgba(246, 248, 255, 0.9);
    font-size: 0.92rem;
    font-weight: 700;
}

.channel-feedback__input,
.channel-feedback__textarea {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 16px !important;
    background: rgba(255, 255, 255, 0.08) !important;
    color: #fff !important;
    box-shadow: none !important;
}

.channel-feedback__input {
    min-height: 52px;
    padding: 0.9rem 1rem;
}

.channel-feedback__textarea {
    min-height: 220px;
    padding: 1rem;
}

.channel-feedback__input::placeholder,
.channel-feedback__textarea::placeholder {
    color: rgba(235, 239, 250, 0.52);
}

.channel-feedback__input:focus,
.channel-feedback__textarea:focus {
    border-color: rgba(255, 255, 255, 0.25) !important;
    box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.08) !important;
}

.channel-feedback .validation-message,
.channel-feedback .field-validation-error {
    color: #ffb6c1;
    font-size: 0.84rem;
}

.channel-feedback__alert {
    margin-top: 1rem;
    border-radius: 14px;
}

.channel-feedback__actions,
.channel-cta-strip__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
}

.channel-feedback__actions {
    justify-content: flex-end;
    margin-top: 1rem;
}

.channel-cta-strip {
    padding: 0 0 4rem;
}

.channel-cta-strip__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.2rem;
    padding: 1.4rem 1.5rem;
}

@media (max-width: 991.98px) {
    .channel-grid,
    .channel-playlist__grid,
    .channel-feedback__grid,
    .channel-mission__grid {
        grid-template-columns: 1fr;
    }

    .channel-cta-strip__inner {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .channel-hero {
        padding: 4.6rem 0 3.1rem;
    }

    .channel-title {
        font-size: 2.5rem;
    }

    .channel-subtitle {
        font-size: 1rem;
    }

    .channel-actions,
    .channel-cta-strip__actions {
        flex-direction: column;
        align-items: stretch;
    }

    .channel-btn-primary,
    .channel-btn-secondary,
    .channel-btn-support {
        width: 100%;
        justify-content: center;
    }
}

.inner-page--contact .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.contact-shell__intro {
    max-width: 760px;
    margin: 0 auto;
}

.contact-shell__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.contact-shell__intro-text {
    margin: 0.9rem 0 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.8;
}

.contact-shell__grid {
    display: grid;
    grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
    gap: 1rem;
}

.contact-panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    height: 100%;
    padding: 1.35rem 1.45rem !important;
}

.contact-panel__icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 16px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 1.3rem;
}

.contact-panel__title {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: 1.25rem;
    font-weight: 800;
}

.contact-panel__text {
    margin: 0;
    color: var(--site-ink-soft);
    line-height: 1.8;
}

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

.contact-info-item {
    display: flex;
    gap: 0.9rem;
    align-items: flex-start;
    padding: 0.95rem 1rem;
    border-radius: 16px;
    background: rgba(242, 247, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.92);
    color: var(--site-ink);
    text-decoration: none;
}

.contact-info-item:hover {
    color: var(--site-blue);
}

.contact-info-item__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: #fff;
    color: var(--site-blue);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.9);
}

.contact-info-item__content {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
}

.contact-info-item__content strong {
    color: var(--site-ink-strong);
    font-size: 0.92rem;
}

.contact-panel__note {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.78rem 0.95rem;
    border-radius: 14px;
    background: rgba(249, 251, 255, 0.95);
    color: var(--site-ink-soft);
    box-shadow: inset 0 0 0 1px rgba(215, 226, 246, 0.9);
}

.contact-panel__note i {
    color: var(--site-blue);
}

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

.contact-field {
    min-width: 0;
}

.contact-field--full {
    grid-column: 1 / -1;
}

.contact-field label {
    display: inline-block;
    margin-bottom: 0.45rem;
    color: var(--site-ink-strong);
    font-size: 0.92rem;
    font-weight: 700;
}

.contact-panel--form .contact-input,
.contact-panel--form .contact-textarea,
.contact-panel--form .contact-textarea.e-input-group,
.contact-panel--form .contact-textarea .e-input,
.contact-panel--form .form-control {
    width: 100% !important;
    border: 1px solid rgba(194, 213, 243, 0.95) !important;
    border-radius: 16px !important;
    background: rgba(249, 251, 255, 0.98) !important;
    color: var(--site-ink-strong) !important;
    box-shadow: none !important;
}

.contact-panel--form .contact-input {
    min-height: 52px;
    padding: 0.9rem 1rem;
}

.contact-panel--form .contact-textarea,
.contact-panel--form .contact-textarea textarea,
.contact-panel--form .contact-textarea .e-input {
    min-height: 220px;
    font-size: 1rem !important;
}

.contact-panel--form .contact-input:focus,
.contact-panel--form .form-control:focus,
.contact-panel--form .contact-textarea:focus,
.contact-panel--form .contact-textarea .e-input:focus {
    border-color: rgba(83, 132, 212, 0.92) !important;
    box-shadow: 0 0 0 0.25rem rgba(75, 124, 206, 0.12) !important;
}

.contact-panel--form .validation-message,
.contact-panel--form .validation-errors,
.contact-panel--form .validation-message,
.contact-panel--form .field-validation-error {
    color: #c94b63;
    font-size: 0.85rem;
}

.contact-alert {
    margin-top: 1rem;
    border-radius: 14px;
}

.contact-actions {
    margin-top: 1rem;
}

.contact-submit-btn {
    min-width: 220px;
    min-height: 52px;
    border-radius: 999px !important;
    font-weight: 800 !important;
    box-shadow: 0 14px 26px rgba(40, 91, 176, 0.16);
}

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

@media (max-width: 767.98px) {
    .contact-form-grid {
        grid-template-columns: 1fr;
    }

    .contact-submit-btn {
        width: 100%;
    }
}

.inner-page--booking .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.booking-shell__intro {
    max-width: 720px;
    margin: 0 auto;
}

.booking-shell__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.booking-shell__description {
    margin: 0.9rem auto 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.75;
}

.inner-page--booking .booking-panel {
    display: grid;
    grid-template-columns: minmax(280px, 0.95fr) minmax(340px, 1.15fr);
    gap: 1rem;
    align-items: stretch;
}

.booking-panel__column {
    min-width: 0;
}

.inner-page--booking .booking-card {
    min-height: 100%;
    padding: 1.35rem;
}

.booking-card--calendar {
    display: flex;
    align-items: center;
    justify-content: center;
}

.booking-card--calendar .e-calendar,
.booking-card--calendar .e-calendar-container,
.booking-card--calendar .e-content {
    width: 100%;
}

.booking-card--slots {
    text-align: left !important;
    align-items: stretch !important;
}

.booking-card__title {
    color: var(--site-ink-strong) !important;
    font-size: 1.15rem;
    font-weight: 800;
}

.booking-card__subtitle {
    margin: 0 0 1rem;
    color: var(--site-ink-soft);
    line-height: 1.7;
}

.booking-slot-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(92px, max-content));
    gap: 0.75rem;
    justify-content: start;
    width: 100%;
}

.booking-slot-grid .e-btn,
.booking-slot-grid .btn-outline-primary {
    min-height: 44px;
}

.booking-confirmation-wrap {
    display: flex;
    justify-content: center;
}

.booking-confirmation-wrap .confirmation-card {
    width: min(620px, 100%);
}

.inner-page--blog {
    gap: 0.2625rem;
}

.inner-page--blog .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.inner-page--blog .blog-shell__intro {
    margin: 0;
    text-align: center;
    color: var(--site-ink-soft);
    font-size: 0.95rem;
    line-height: 1.6;
}

.inner-page--blog .blog-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem 1rem;
}

.inner-page--blog .blog-toolbar__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.inner-page--blog .blog-filter-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    padding: 0.55rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(191, 209, 239, 0.9);
    background: rgba(248, 251, 255, 0.95);
    color: var(--site-blue);
    font-size: 0.92rem;
    font-weight: 700;
    transition: all 0.2s ease;
}

.inner-page--blog .blog-filter-chip:hover,
.inner-page--blog .blog-filter-chip.active {
    background: linear-gradient(135deg, #225bb0, #2f72d0);
    border-color: rgba(38, 88, 167, 0.9);
    color: #fff;
    box-shadow: 0 14px 24px rgba(40, 91, 176, 0.16);
}

.inner-page--blog .blog-toolbar__meta {
    color: var(--site-ink-soft);
    font-size: 0.9rem;
    font-weight: 600;
}

.inner-page--blog .blog-list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.inner-page--blog .blog-load-more {
    display: flex;
    justify-content: center;
    margin-top: 0.35rem;
}

.inner-page--about {
    gap: 0.2625rem;
}

.inner-page--admin-blog {
    gap: 0.2625rem;
}

.inner-page--admin-blog .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.admin-shell__lead {
    max-width: 780px;
    margin: 0 auto;
}

.admin-shell__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.admin-shell__lead-text {
    margin: 0.9rem 0 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.8;
}

.admin-blog-section {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
}

.admin-blog-section__header h3 {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: 1.15rem;
    font-weight: 800;
}

.inner-page--about .cv-record-shell {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.about-shell__lead {
    max-width: 760px;
    margin: 0 auto;
}

.about-shell__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 32px;
    padding: 0.38rem 0.78rem;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.about-shell__lead-text {
    margin: 0.9rem 0 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.8;
}

.cv-card-grid--about {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.about-card {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    height: 100%;
    padding: 1.15rem 1.2rem !important;
}

.about-card__icon-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border-radius: 15px;
    background: rgba(241, 247, 255, 0.98);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
    color: var(--site-blue);
    font-size: 1.2rem;
}

.about-card__title {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: 1.2rem;
    font-weight: 800;
}

.about-card__text {
    margin: 0;
    color: var(--site-ink);
    line-height: 1.8;
}

.about-feature-list {
    display: grid;
    gap: 0.9rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-feature-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.82rem 0.9rem;
    border-radius: 15px;
    background: rgba(242, 247, 255, 0.96);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.92);
    color: var(--site-ink);
    line-height: 1.65;
}

.about-feature-list i {
    color: var(--site-blue);
    font-size: 1rem;
    margin-top: 0.08rem;
}

.about-card__actions {
    margin-top: auto;
}

@media (max-width: 767.98px) {
    .cv-card-grid--about {
        grid-template-columns: 1fr;
    }
}

.hero-summary-wrapper {
    padding: clamp(2.4rem, 5vw, 3.75rem) clamp(1.5rem, 4vw, 3rem);
    border-radius: 15px;
    text-align: center;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(247, 250, 255, 0.82)),
        url('/img/background_claudecv.png') center center / cover no-repeat;
    border: 1px solid rgba(255, 255, 255, 0.9);
    box-shadow: var(--site-shadow-soft);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

.hero-summary-wrapper::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 18%, rgba(170, 204, 255, 0.18), transparent 26%),
        radial-gradient(circle at 84% 24%, rgba(229, 237, 255, 0.72), transparent 20%);
    pointer-events: none;
}

.hero-summary-wrapper .hero-bg {
    opacity: 0.04;
}

.hero-summary-wrapper h1,
.hero-summary-wrapper .hero-title {
    margin: 0;
    color: var(--site-ink-strong);
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    text-shadow: none;
}

.hero-summary-wrapper .hero-subtitle,
#welcome-text {
    color: var(--site-ink-soft);
    font-size: 1.06rem;
    line-height: 1.75;
}

.main > section.container.py-4,
.main > .container.py-5,
.main > section.container.p-4,
.main > section.container.py-4.d-flex {
    position: relative;
    padding-top: 0 !important;
}

.info-wrap,
.main > section.container.py-4 > :first-child,
.main > .container.py-5 > .row,
.main > section.container.p-4 > :first-child,
.privacy-shell {
    width: min(1120px, 100%);
    margin: 0 auto;
    padding: clamp(1.4rem, 3vw, 2rem);
    border-radius: 15px;
    background: var(--site-surface);
    border: 1px solid rgba(255, 255, 255, 0.88);
    box-shadow: var(--site-shadow-soft);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

.info-wrap > .row:last-child,
.info-wrap > .cv-section-grid:last-child,
.info-wrap > .category-section:last-child {
    margin-bottom: 0;
}

.e-card,
.blog-card,
.contact-form-wrap,
.booking-card,
.confirmation-card,
.main .card,
.main .alert,
.claude-dialog .e-dlg-content > div.bg-light,
.claude-dialog .e-dlg-content > div[class*="rounded"] {
    border-radius: 15px !important;
    border: 1px solid rgba(203, 219, 245, 0.88) !important;
    background: rgba(255, 255, 255, 0.92) !important;
    box-shadow: 0 18px 42px rgba(40, 71, 125, 0.09) !important;
}

.e-card,
.blog-card,
.booking-card {
    overflow: hidden;
}

.e-card {
    padding: 0.9rem;
}

.e-card .e-card-header .e-card-header-title,
.blog-card .card-title,
.summary-section,
.category-section h4,
.footer h4 {
    color: var(--site-ink-strong) !important;
}

.e-card .e-card-content,
.blog-card .card-text,
.summary-content,
.contact-form-wrap,
.booking-card,
.footer p,
.footer li,
.footer span {
    color: var(--site-ink);
}

.blog-card {
    border: 1px solid rgba(203, 219, 245, 0.88) !important;
    transition: transform 0.22s ease, box-shadow 0.22s ease !important;
}

.inner-page--blog .blog-card {
    margin: 0 !important;
}

.inner-page--blog .blog-card .card-body {
    padding: 1.35rem 1.45rem;
}

.inner-page--blog .blog-card .card-title {
    margin-bottom: 0.8rem;
    color: var(--site-ink-strong) !important;
}

.inner-page--blog .blog-card__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.8rem 1rem;
    margin-bottom: 0.8rem;
    color: var(--site-ink-soft);
    font-size: 0.88rem;
}

.inner-page--blog .blog-card__meta span {
    display: inline-flex;
    align-items: center;
    gap: 0.38rem;
}

.inner-page--blog .blog-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    margin-bottom: 0.9rem;
}

.inner-page--blog .blog-card__tag-secondary {
    background: rgba(232, 244, 255, 0.95);
}

.inner-page--blog .blog-card__excerpt {
    font-size: 1rem;
    line-height: 1.7;
    cursor: pointer;
}

.inner-page--blog .blog-card__image-wrap {
    margin-top: 0.85rem;
    cursor: pointer;
}

.inner-page--blog .blog-card__image {
    width: 100%;
    max-height: 250px;
    object-fit: cover;
    border-radius: 15px;
    border: 1px solid rgba(203, 219, 245, 0.88);
    transition: transform 0.3s ease;
}

.blog-card:hover,
.e-card:hover,
.booking-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 48px rgba(35, 70, 126, 0.12) !important;
}

.contact-form-wrap {
    max-width: 720px;
    padding: clamp(1.5rem, 3vw, 2.3rem);
}

.contact-form-wrap label,
.form-label {
    color: var(--site-ink-strong);
    font-weight: 700;
}

.form-control,
.contact-form-wrap .form-control,
.contact-form-wrap .full-width-textarea,
.claude-dialog .form-control {
    min-height: 50px;
    border-radius: 15px !important;
    border: 1px solid rgba(189, 209, 241, 0.9) !important;
    background: rgba(248, 251, 255, 0.96) !important;
    color: var(--site-ink) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.full-width-textarea {
    min-height: 180px !important;
}

.form-control:focus,
.contact-form-wrap .form-control:focus,
.claude-dialog .form-control:focus,
.full-width-textarea:focus {
    border-color: rgba(82, 126, 198, 0.72) !important;
    box-shadow: 0 0 0 0.2rem rgba(92, 134, 202, 0.16) !important;
}

/* =========================================================
   Shared UI QA layer: consistent actions, focus, feedback
   ========================================================= */
:root {
    --ui-radius-control: 8px;
    --ui-radius-pill: 999px;
    --ui-focus-ring: 0 0 0 0.2rem rgba(63, 43, 232, 0.22);
    --ui-focus-ring-strong: 0 0 0 0.22rem rgba(63, 43, 232, 0.28);
    --ui-primary: var(--accent-primary);
    --ui-primary-hover: var(--accent-primary-strong);
    --ui-secondary-surface: rgba(255, 255, 255, 0.86);
    --ui-secondary-border: rgba(127, 164, 221, 0.5);
    --ui-control-shadow: 0 14px 26px rgba(41, 90, 168, 0.14);
}

a,
button,
.btn,
.e-btn,
.nav-link,
.cw-footer__social-links a,
.contact-info-item,
.blog-card__excerpt-button {
    transition:
        color 160ms ease,
        background-color 160ms ease,
        border-color 160ms ease,
        box-shadow 160ms ease,
        transform 160ms ease,
        opacity 160ms ease;
}

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.e-btn:focus-visible,
.nav-link:focus-visible,
.form-control:focus-visible,
.e-input:focus-visible,
.e-control:focus-visible,
[tabindex]:focus-visible {
    outline: 2px solid var(--ui-primary) !important;
    outline-offset: 3px;
    box-shadow: var(--ui-focus-ring) !important;
}

.btn,
.btn-send,
.e-btn,
.footer-primary-btn,
.footer-secondary-btn,
.cw-footer__cta-btn,
.cw-footer__secondary-btn,
.cw-footer__privacy-chip,
.home-btn,
.channel-btn-primary,
.channel-btn-secondary,
.channel-btn-support,
.labs-youtube-btn,
.blog-detail__booking-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    min-height: 44px;
    border-radius: var(--ui-radius-control) !important;
    line-height: 1.15;
    text-align: center;
    white-space: normal;
    touch-action: manipulation;
}

.btn-sm,
.e-small,
.e-btn.e-small {
    min-height: 36px;
    border-radius: var(--ui-radius-control) !important;
}

.btn-lg,
.e-btn.e-large {
    min-height: 52px;
}

.e-calendar .e-prev,
.e-calendar .e-next,
.e-calendar .e-title,
.e-calendar .e-header .e-btn,
.e-datepicker .e-prev,
.e-datepicker .e-next,
.e-datepicker .e-title,
.e-datepicker .e-header .e-btn {
    min-width: 40px !important;
    min-height: 40px !important;
}

.btn-primary,
.btn-send,
.footer-primary-btn,
.e-btn.e-primary,
button.btn-primary {
    color: #fff !important;
    border-color: transparent !important;
    background: var(--ui-primary) !important;
    box-shadow: 0 16px 28px rgba(63, 43, 232, 0.18);
}

.btn-primary:hover,
.btn-send:hover,
.footer-primary-btn:hover,
.e-btn.e-primary:hover,
button.btn-primary:hover {
    color: #fff !important;
    background: var(--ui-primary-hover) !important;
    border-color: transparent !important;
    box-shadow: 0 18px 34px rgba(63, 43, 232, 0.24);
}

.btn-outline-primary,
.footer-secondary-btn,
.e-btn.e-outline.e-primary,
.e-btn.btn-outline-primary {
    color: var(--ui-primary) !important;
    border-color: rgba(63, 43, 232, 0.38) !important;
    background: var(--ui-secondary-surface) !important;
    box-shadow: inset 0 0 0 1px rgba(63, 43, 232, 0.12);
}

.btn-outline-primary:hover,
.btn-outline-primary:focus-visible,
.footer-secondary-btn:hover,
.e-btn.e-outline.e-primary:hover,
.e-btn.btn-outline-primary:hover {
    color: #fff !important;
    border-color: var(--ui-primary) !important;
    background: var(--ui-primary) !important;
    box-shadow: 0 14px 26px rgba(63, 43, 232, 0.16);
}

.btn-danger {
    box-shadow: 0 14px 26px rgba(196, 30, 58, 0.16);
}

.btn-danger:hover,
.btn-danger:focus-visible {
    box-shadow: 0 18px 32px rgba(196, 30, 58, 0.22);
}

.btn:hover:not(:disabled),
.btn-send:hover:not(:disabled),
.e-btn:hover:not(.e-disabled),
.footer-primary-btn:hover:not(:disabled),
.footer-secondary-btn:hover:not(:disabled),
.cw-footer__cta-btn:hover:not(:disabled),
.cw-footer__secondary-btn:hover:not(:disabled),
.cw-footer__privacy-chip:hover:not(:disabled),
.home-btn:hover:not(:disabled),
.channel-btn-primary:hover:not(:disabled),
.channel-btn-secondary:hover:not(:disabled),
.channel-btn-support:hover:not(:disabled),
.labs-youtube-btn:hover:not(:disabled),
.blog-detail__booking-btn:hover:not(:disabled) {
    transform: translateY(-1px);
}

.btn:active:not(:disabled),
.btn-send:active:not(:disabled),
.e-btn:active:not(.e-disabled),
.footer-primary-btn:active:not(:disabled),
.footer-secondary-btn:active:not(:disabled),
.cw-footer__cta-btn:active:not(:disabled),
.cw-footer__secondary-btn:active:not(:disabled),
.cw-footer__privacy-chip:active:not(:disabled),
.home-btn:active:not(:disabled),
.channel-btn-primary:active:not(:disabled),
.channel-btn-secondary:active:not(:disabled),
.channel-btn-support:active:not(:disabled),
.labs-youtube-btn:active:not(:disabled),
.blog-detail__booking-btn:active:not(:disabled) {
    transform: translateY(0);
    box-shadow: inset 0 2px 6px rgba(15, 23, 42, 0.16) !important;
}

.btn:disabled,
.btn.disabled,
.btn-send:disabled,
.e-btn.e-disabled,
.footer-primary-btn:disabled,
.footer-secondary-btn:disabled,
.cw-footer__cta-btn:disabled,
.cw-footer__secondary-btn:disabled,
.home-btn:disabled,
.channel-btn-primary:disabled,
.channel-btn-secondary:disabled,
.channel-btn-support:disabled,
.blog-detail__booking-btn:disabled {
    cursor: not-allowed;
    opacity: 0.62 !important;
    transform: none !important;
    box-shadow: none !important;
}

.btn-link {
    min-height: 36px;
    border-radius: var(--ui-radius-control) !important;
    color: var(--ui-primary) !important;
    font-weight: 800 !important;
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.btn-link:hover,
.btn-link:focus-visible {
    color: var(--ui-primary-hover) !important;
    background: rgba(63, 43, 232, 0.08) !important;
}

.cookie-banner {
    left: clamp(0.75rem, 2vw, 1.25rem) !important;
    bottom: clamp(0.75rem, 2vw, 1.25rem) !important;
    width: min(390px, calc(100vw - 1.5rem));
    max-width: none !important;
    padding: 0.9rem !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 20px 44px rgba(15, 23, 42, 0.16) !important;
    color: #334155;
}

.cookie-content h6 {
    margin: 0 0 0.35rem;
    color: #111827;
    font-size: 0.98rem;
    font-weight: 850;
}

.cookie-content p {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.45;
}

.cookie-banner .cookie-actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.45rem !important;
    margin-top: 0.7rem !important;
}

.cookie-actions .btn {
    min-height: 38px;
    padding: 0.48rem 0.7rem !important;
    border-radius: 7px !important;
    font-size: 0.84rem;
    font-weight: 800 !important;
}

.cookie-actions .btn-success {
    grid-column: 1 / -1;
    color: #111827 !important;
    background: #facc15 !important;
    box-shadow: none !important;
}

.cookie-actions .btn-success:hover,
.cookie-actions .btn-success:focus-visible {
    color: #111827 !important;
    background: #eab308 !important;
}

.cookie-modal .modal-body {
    width: min(560px, calc(100vw - 1.5rem)) !important;
    max-height: calc(100vh - 1.5rem);
    overflow-y: auto;
    border-radius: 8px !important;
}

.cookie-modal .modal-footer {
    gap: 0.55rem !important;
}

.summary-section {
    margin-bottom: 0.45rem;
    font-size: 1.18rem;
    font-weight: 800;
}

.summary-content {
    margin-bottom: 0;
    line-height: 1.8;
}

.category-section + .category-section {
    margin-top: 1.7rem;
}

.category-section h4 {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1rem;
    font-size: 1.2rem;
    font-weight: 800;
}

.cv-section-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.1rem;
}

.cv-qualifications-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.highlight-badge,
.hero-card__chips span,
.home-pill-band__inner span,
.e-badge,
.badge {
    border-radius: 999px;
}

.booking-panel {
    display: grid;
    grid-template-columns: minmax(240px, 0.8fr) minmax(220px, 0.7fr) minmax(320px, 1.2fr);
    gap: 1.25rem;
}

.booking-card {
    padding: 1.5rem;
    background: rgba(255, 255, 255, 0.92) !important;
}

.empty-slot {
    border-radius: 15px;
}

.claude-dialog .e-dlg-header-content,
.calendar-style-dialog .px-4.pt-3.pb-1.text-center.border-bottom.bg-info.rounded {
    background: linear-gradient(135deg, rgba(236, 244, 255, 0.95), rgba(247, 250, 255, 0.98)) !important;
    border-bottom: 1px solid rgba(204, 220, 245, 0.85) !important;
}

.claude-dialog .e-dialog,
.claude-dialog.e-dialog {
    border-radius: 15px !important;
    overflow: hidden !important;
    border: 1px solid rgba(203, 219, 245, 0.88) !important;
    box-shadow: 0 26px 56px rgba(35, 70, 126, 0.16) !important;
}

.footer {
    padding: 0 0 2rem;
    background: transparent;
    box-shadow: none;
}

.footer::before {
    display: none;
}

.footer-surface {
    padding: clamp(1.15rem, 2.6vw, 1.7rem);
    border-radius: 15px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(244, 249, 255, 0.74));
    border: 1px solid rgba(255, 255, 255, 0.92);
    box-shadow: 0 24px 56px rgba(38, 70, 122, 0.11);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

.footer-newsletter {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) minmax(240px, 0.9fr);
    align-items: stretch;
    gap: 1.15rem;
    padding: 0;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    border-top: none;
    border-bottom: none;
}

.footer-newsletter__copy {
    max-width: none;
}

.footer-newsletter__copy-card,
.footer-newsletter__action-card {
    height: 100%;
    padding: 1.2rem 1.3rem;
    border-radius: 15px;
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.82), rgba(240, 247, 255, 0.9));
    box-shadow:
        inset 0 0 0 1px rgba(198, 216, 244, 0.82),
        0 14px 30px rgba(44, 75, 126, 0.06);
}

.footer-newsletter__action {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 240px;
}

.footer-newsletter__action-card {
    justify-content: center;
    text-align: center;
    background:
        radial-gradient(circle at 20% 20%, rgba(213, 228, 255, 0.72), transparent 34%),
        linear-gradient(145deg, rgba(255, 255, 255, 0.84), rgba(237, 244, 255, 0.92));
}

.footer-kicker {
    display: inline-flex;
    align-items: center;
    min-height: 38px;
    margin-bottom: 0.85rem;
    padding: 0.5rem 0.85rem;
    border-radius: 999px;
    background: rgba(239, 245, 255, 0.96);
    color: var(--site-blue);
    font-size: 0.88rem;
    font-weight: 700;
    box-shadow: inset 0 0 0 1px rgba(192, 212, 243, 0.92);
}

.footer-newsletter h4 {
    margin-bottom: 0.35rem;
    font-size: clamp(1.55rem, 2vw, 2rem);
    font-weight: 800;
}

.footer-newsletter p {
    margin-bottom: 0;
    color: var(--site-ink-soft);
    line-height: 1.75;
}

.footer-top {
    padding: 1.55rem 0 1.05rem;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.95fr 1.05fr 0.9fr;
    gap: 1.2rem;
    align-items: start;
}

.footer-column {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.footer-column h4 {
    margin-bottom: 0;
    font-size: 1.04rem;
}

.footer-column p {
    margin-bottom: 0.95rem;
    line-height: 1.75;
}

.footer-panel {
    height: 100%;
    display: flex;
    flex-direction: column;
    padding: 1.05rem 1.1rem;
    border-radius: 15px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(244, 248, 255, 0.86));
    box-shadow:
        inset 0 0 0 1px rgba(198, 216, 244, 0.82),
        0 12px 28px rgba(44, 75, 126, 0.05);
}

.footer-links ul {
    display: grid;
    gap: 0.72rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.footer-links li,
.footer-contact-list a {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.footer-links li {
    min-height: 32px;
}

.footer-links a,
.footer-links .nav-link {
    color: var(--site-ink);
    font-weight: 600;
    text-decoration: none;
}

.footer-links a:hover,
.footer-links .nav-link:hover {
    color: var(--site-blue);
}

.footer-links i,
.footer-contact-list i {
    color: #8aaee3;
}

.footer-contact-block {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.footer-contact-card {
    display: grid;
    gap: 0.9rem;
}

.footer-contact-list {
    display: grid;
    gap: 0.8rem;
}

.footer-contact-list a {
    color: var(--site-ink);
    font-weight: 600;
}

.footer-contact-card .footer-secondary-btn {
    width: fit-content;
    min-width: 190px;
    justify-self: start;
}

.footer-social-card {
    justify-content: space-between;
}

.footer-social-block .social-links {
    margin-top: 0.75rem;
}

.footer-social-card p {
    margin-bottom: 0;
}

.footer-privacy-card {
    justify-content: space-between;
    gap: 1rem;
    background:
        radial-gradient(circle at 82% 24%, rgba(214, 229, 255, 0.7), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(241, 247, 255, 0.88));
}

.footer-privacy-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 15px;
    background: linear-gradient(135deg, rgba(237, 245, 255, 0.98), rgba(220, 234, 255, 0.95));
    box-shadow: inset 0 0 0 1px rgba(192, 212, 243, 0.92);
    color: var(--site-blue);
    font-size: 1.25rem;
}

.footer-privacy-card__text {
    margin: 0;
    color: var(--site-ink-soft);
    line-height: 1.7;
}

.footer-privacy-btn {
    width: 100%;
    justify-content: center;
    gap: 0.5rem;
}

.footer .social-links {
    gap: 0.75rem;
    flex-wrap: wrap;
}

.footer .social-links a {
    width: 44px;
    height: 44px;
    background: linear-gradient(135deg, #edf4ff, #dceafe);
    color: var(--site-blue);
    box-shadow: inset 0 0 0 1px rgba(188, 210, 244, 0.9);
}

.footer .social-links a:hover {
    color: #fff;
    background: linear-gradient(135deg, #235bb0, #2d73d6);
    transform: translateY(-2px);
}

.footer-bottom {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 1rem;
    border-top: 1px solid rgba(210, 224, 246, 0.88);
}

.copyright p {
    margin: 0;
    color: var(--site-ink-soft);
    text-align: center;
}

.scroll-top {
    right: 1.2rem;
    bottom: 1.2rem;
    background: linear-gradient(135deg, #235bb0, #2d73d6);
    box-shadow: 0 18px 28px rgba(41, 90, 168, 0.18);
}

.scroll-top i {
    color: #fff;
}

@media (max-width: 991.98px) {
    .page > main.page-main {
        padding-top: 3.8rem;
    }

    .site-navbar__inner {
        padding: 0.85rem 1rem;
        border-radius: 15px;
    }

    .site-navbar__panel {
        width: 100%;
        margin-top: 1rem;
        padding-top: 1rem;
        border-top: 1px solid rgba(255, 255, 255, 0.12);
        background: linear-gradient(180deg, rgba(14, 23, 42, 0.96), rgba(15, 23, 42, 0.92));
        border-radius: 15px;
        padding-left: 0.75rem;
        padding-right: 0.75rem;
        padding-bottom: 0.75rem;
        box-shadow: 0 24px 40px rgba(2, 8, 23, 0.28);
    }

    .site-navbar__actions {
        align-items: stretch !important;
    }

    .site-navbar__actions .nav-link,
    .culture-switch {
        width: 100%;
        justify-content: flex-start;
    }

    .site-navbar__actions .nav-link {
        color: rgba(248, 250, 252, 0.96) !important;
    }

    .page--engineering-chrome .site-navbar__panel .site-navbar__actions .nav-link {
        color: rgba(248, 250, 252, 0.96) !important;
    }

    .site-navbar__actions .nav-link:hover,
    .site-navbar__actions .nav-link:focus,
    .site-navbar__actions .nav-link.active {
        color: #ffffff !important;
        background: rgba(59, 130, 246, 0.22) !important;
        border-radius: 6px !important;
        box-shadow: inset 0 0 0 1px rgba(96, 165, 250, 0.35) !important;
    }

    .page--engineering-chrome .site-navbar__panel .site-navbar__actions .nav-link:hover,
    .page--engineering-chrome .site-navbar__panel .site-navbar__actions .nav-link:focus,
    .page--engineering-chrome .site-navbar__panel .site-navbar__actions .nav-link.active {
        color: #ffffff !important;
        background: rgba(59, 130, 246, 0.22) !important;
        box-shadow: inset 0 0 0 1px rgba(96, 165, 250, 0.35) !important;
    }

    .nav-brand-name {
        color: var(--site-ink-strong);
    }

    .nav-brand-role {
        color: var(--site-ink-soft);
    }

    .culture-switch {
        background: rgba(255, 255, 255, 0.08) !important;
        border-color: rgba(255, 255, 255, 0.14) !important;
        color: #f8fafc !important;
    }

    .booking-panel {
        grid-template-columns: 1fr;
    }

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

    .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1.4rem;
    }

    .footer-newsletter__copy,
    .footer-newsletter__action {
        max-width: none;
        width: 100%;
    }

    .footer-newsletter__action-card {
        justify-content: flex-start;
    }

    .footer-bottom {
        justify-content: center;
    }
}

@media (max-width: 767.98px) {
    .page > main.page-main {
        padding-top: 3.45rem;
    }

    .page-content-card,
    .hero-summary-wrapper,
    .footer-surface,
    .info-wrap,
    .main > section.container.py-4 > :first-child,
    .main > .container.py-5 > .row,
    .main > section.container.p-4 > :first-child {
        border-radius: 15px;
    }

    .nav-brand-role {
        display: none;
    }

    .footer-surface {
        padding: 1.2rem;
    }

    .footer-newsletter {
        padding: 0.95rem;
    }

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

    .footer-newsletter__action-card {
        justify-content: center;
    }

    .footer-contact-card .footer-secondary-btn,
    .footer-privacy-btn,
    .footer-primary-btn {
        width: 100%;
    }
}

/* =========================================================
   ClaudeWebsite footer refresh (mockup-aligned, isolated)
   ========================================================= */
.cw-footer {
    margin-top: clamp(2rem, 5vw, 4.5rem);
    padding: 0 0 1rem;
    background: transparent;
    box-shadow: none;
}

.cw-footer.cw-footer--home {
    margin-top: clamp(0.75rem, 2vw, 1.5rem);
}

.cw-footer .container-xl {
    position: relative;
    z-index: 1;
}

.cw-footer__shell {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.92), rgba(228, 238, 255, 0.86));
    border: 1px solid rgba(255, 255, 255, 0.94);
    box-shadow: 0 28px 60px rgba(40, 77, 138, 0.12);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}

.cw-footer__shell::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.06)),
        url('/img/site-global/background-ribbon.png') center center / cover no-repeat,
        radial-gradient(circle at 12% 20%, rgba(167, 198, 245, 0.18), transparent 28%),
        radial-gradient(circle at 88% 18%, rgba(214, 228, 255, 0.5), transparent 24%);
    opacity: 0.42;
    pointer-events: none;
}

.cw-footer__cta,
.cw-footer__main,
.cw-footer__bottom {
    position: relative;
    z-index: 1;
}

.cw-footer__cta {
    display: grid;
    grid-template-columns: minmax(0, 1.65fr) minmax(240px, 0.75fr);
    gap: 1.5rem;
    align-items: center;
    margin: 22px;
    padding: 1.7rem 1.8rem;
    border-radius: 24px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.68), rgba(246, 250, 255, 0.56));
    border: 1px solid rgba(255, 255, 255, 0.78);
    box-shadow: 0 14px 28px rgba(40, 77, 138, 0.06);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
}

.cw-footer__eyebrow {
    display: inline-block;
    margin-bottom: 0.55rem;
    color: #334e83;
    font-size: 0.98rem;
    font-weight: 500;
}

.cw-footer__cta h2 {
    margin: 0 0 0.55rem;
    color: #18336a;
    font-size: clamp(2rem, 2.7vw, 2.55rem);
    font-weight: 800;
    letter-spacing: -0.03em;
}

.cw-footer__cta p {
    margin: 0;
    color: #51678f;
    font-size: 1.08rem;
    line-height: 1.65;
}

.cw-footer__cta-action {
    display: flex;
    justify-content: center;
}

.cw-footer__cta-btn,
.cw-footer__secondary-btn,
.cw-footer__privacy-chip {
    border: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.cw-footer__cta-btn {
    min-width: 240px;
    min-height: 62px;
    padding: 0.95rem 1.75rem;
    border-radius: 999px !important;
    color: #fff !important;
    font-size: 1.18rem;
    font-weight: 800 !important;
    background: linear-gradient(135deg, #235bb0, #2d73d6) !important;
    box-shadow: 0 14px 26px rgba(41, 90, 168, 0.18);
}

.cw-footer__cta-btn:hover,
.cw-footer__secondary-btn:hover,
.cw-footer__privacy-chip:hover {
    transform: translateY(-2px);
}

.cw-footer__cta-btn:disabled {
    opacity: 1 !important;
    color: #fff !important;
    background: linear-gradient(135deg, #235bb0, #2d73d6) !important;
    box-shadow: 0 14px 26px rgba(41, 90, 168, 0.18);
}

.cw-footer__main {
    padding: 1.35rem 2rem 1.6rem;
}

.cw-footer__grid {
    display: grid;
    grid-template-columns: 1.05fr 1fr 1.05fr 0.95fr;
    gap: 1.6rem;
}

.cw-footer__col {
    position: relative;
    min-width: 0;
    color: var(--site-ink);
}

.cw-footer__col + .cw-footer__col {
    padding-left: 1.45rem;
}

.cw-footer__col + .cw-footer__col::before {
    content: "";
    position: absolute;
    left: 0;
    top: 2.6rem;
    bottom: 0.4rem;
    width: 1px;
    background: linear-gradient(180deg, rgba(165, 193, 237, 0.45), rgba(165, 193, 237, 0.08));
}

.cw-footer__col h4 {
    margin: 0 0 1.1rem;
    color: var(--site-ink-strong) !important;
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.cw-footer__links {
    display: grid;
    gap: 0.9rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cw-footer__links li {
    margin: 0;
}

.cw-footer__links a,
.cw-footer__contact-list a {
    display: flex;
    align-items: center;
    gap: 0.72rem;
    color: var(--site-ink);
    text-decoration: none;
    font-size: 1rem;
    font-weight: 500;
    min-width: 0;
}

.cw-footer__links a:hover,
.cw-footer__contact-list a:hover {
    color: var(--site-blue);
}

.cw-footer__links i {
    color: rgba(79, 118, 184, 0.72);
    font-size: 0.9rem;
}

.cw-footer__contact-list {
    display: grid;
    gap: 1rem;
    margin-bottom: 1.35rem;
}

.cw-footer__icon-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    background: rgba(241, 247, 255, 0.96);
    color: var(--site-blue);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.95);
}

.cw-footer__contact-list a {
    align-items: flex-start;
    font-size: 1.08rem;
    font-weight: 700;
}

.cw-footer__contact-list a span:last-child {
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.cw-footer__secondary-btn {
    min-width: 220px;
    min-height: 54px;
    padding: 0.85rem 1.4rem;
    border-radius: 999px !important;
    color: var(--site-blue) !important;
    font-size: 1.02rem;
    font-weight: 800 !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(243, 248, 255, 0.9)) !important;
    box-shadow: 0 10px 20px rgba(40, 77, 138, 0.1);
}

.cw-footer__text {
    margin: 0;
    color: var(--site-ink-soft);
    font-size: 1rem;
    line-height: 1.85;
}

.cw-footer__text--privacy {
    max-width: 240px;
}

.cw-footer__social-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    margin-top: 1.5rem;
}

.cw-footer__social-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(238, 245, 255, 0.94));
    color: var(--site-blue);
    text-decoration: none;
    box-shadow: 0 10px 20px rgba(40, 77, 138, 0.1);
}

.cw-footer__social-links a:hover {
    color: #163f84;
    background: linear-gradient(180deg, #ffffff, #f4f8ff);
    transform: translateY(-2px);
}

.cw-footer__privacy-btn {
    margin-bottom: 1.4rem;
}

.cw-footer__privacy-art {
    position: relative;
    min-height: 140px;
    margin-bottom: 0.55rem;
}

.cw-footer__privacy-cloud,
.cw-footer__privacy-shield {
    position: absolute;
    filter: drop-shadow(0 14px 26px rgba(13, 39, 92, 0.2));
}

.cw-footer__privacy-cloud {
    left: 0.25rem;
    bottom: 0;
    color: rgba(151, 186, 238, 0.5);
    font-size: 5.7rem;
}

.cw-footer__privacy-shield {
    right: 1rem;
    top: 0.35rem;
    color: rgba(185, 203, 241, 0.62);
    font-size: 3rem;
}

.cw-footer__bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.55rem 1.15rem;
    border-top: 1px solid rgba(181, 204, 239, 0.42);
    background: linear-gradient(180deg, rgba(248, 251, 255, 0.52), rgba(238, 245, 255, 0.62));
}

.cw-footer__copyright {
    color: var(--site-ink-soft);
    font-size: 0.98rem;
}

.cw-footer__copyright strong {
    color: var(--site-ink-strong);
    font-weight: 800;
}

.cw-footer__privacy-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    min-height: 48px;
    padding: 0.7rem 1.15rem;
    border-radius: 999px;
    color: var(--site-blue);
    font-size: 0.98rem;
    font-weight: 700;
    background: rgba(255, 255, 255, 0.72);
    box-shadow: inset 0 0 0 1px rgba(194, 213, 243, 0.9);
}

.cw-footer__privacy-chip i {
    font-size: 1rem;
}

@media (max-width: 1399.98px) {
    .cw-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        row-gap: 2rem;
    }

    .cw-footer__col:nth-child(3),
    .cw-footer__col:nth-child(4) {
        padding-left: 0;
    }

    .cw-footer__col:nth-child(3)::before,
    .cw-footer__col:nth-child(4)::before {
        display: none;
    }
}

@media (max-width: 1399.98px) and (min-width: 992px) {
    .cw-footer__main {
        padding: 1.15rem 1.6rem 1.45rem;
    }

    .cw-footer__grid {
        gap: 1.45rem;
    }

    .cw-footer__col h4 {
        font-size: 1.34rem;
        line-height: 1.1;
    }
}

@media (max-width: 991.98px) {
    .cw-footer__cta {
        grid-template-columns: 1fr;
        text-align: left;
    }

    .cw-footer__cta-action {
        justify-content: flex-start;
    }

    .cw-footer__main {
        padding: 1rem 1.4rem 1.45rem;
    }

    .cw-footer__grid {
        grid-template-columns: 1fr;
        gap: 1.75rem;
    }

    .cw-footer__col {
        padding-left: 0 !important;
    }

    .cw-footer__col::before {
        display: none;
    }

    .cw-footer__bottom {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 767.98px) {
    .cw-footer__shell {
        border-radius: 22px;
    }

    .cw-footer__cta {
        margin: 14px;
        padding: 1.35rem 1.2rem;
        border-radius: 20px;
    }

    .cw-footer__cta h2 {
        font-size: 1.9rem;
    }

    .cw-footer__cta p,
    .cw-footer__text,
    .cw-footer__contact-list a,
    .cw-footer__links a {
        font-size: 0.98rem;
    }

    .cw-footer__cta-btn,
    .cw-footer__secondary-btn,
    .cw-footer__privacy-chip {
        width: 100%;
        justify-content: center;
    }

    .cw-footer__privacy-art {
        min-height: 116px;
    }

    .cw-footer__privacy-cloud {
        font-size: 4.6rem;
    }

    .cw-footer__privacy-shield {
        right: 0.35rem;
        font-size: 2.5rem;
    }
}

@media (max-width: 767.98px) {
    .page-content {
        padding-right: 0.75rem;
        padding-left: 0.75rem;
    }

    .page-content-card--inner {
        padding: 0.4rem;
    }

    .page-content-card--inner > .row {
        padding: 1rem;
    }

    .page-content-card--inner > .row > [class*="col-"] + [class*="col-"] {
        margin-top: 1rem;
    }

    .inner-page--management .row {
        --bs-gutter-y: 0.8rem;
    }

    .inner-page--management .e-card-header,
    .inner-page--management .e-card-content {
        padding: 0.9rem !important;
    }

    .privacy-shell {
        padding: 1rem;
    }

    .labs-card__actions,
    .labs-card__actions--stacked,
    .contact-actions,
    .booking-slot-grid,
    .channel-actions,
    .channel-feedback__actions,
    .channel-cta-strip__actions,
    .tool-actions-row,
    .mermaid-product-hero__actions,
    .blog-detail__actions {
        align-items: stretch;
        width: 100%;
    }

    .labs-card__actions .btn,
    .contact-actions .btn,
    .booking-slot-grid .e-btn,
    .channel-actions .btn,
    .channel-feedback__actions .btn,
    .channel-cta-strip__actions .btn,
    .tool-actions-row .btn,
    .mermaid-product-hero__actions .btn,
    .blog-detail__actions .btn {
        width: 100%;
    }

    .btn,
    .e-btn,
    .cw-footer__cta-btn,
    .cw-footer__secondary-btn,
    .cw-footer__privacy-chip {
        min-height: 46px;
    }

    .cookie-banner {
        left: 0.6rem !important;
        right: 0.6rem !important;
        bottom: 0.6rem !important;
        width: auto;
        padding: 0.72rem !important;
    }

    .cookie-content h6 {
        font-size: 0.92rem;
    }

    .cookie-content p {
        font-size: 0.78rem;
        line-height: 1.35;
    }

    .cookie-actions .btn {
        min-height: 34px;
        padding: 0.38rem 0.5rem !important;
        font-size: 0.78rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }

    .btn:hover:not(:disabled),
    .e-btn:hover:not(.e-disabled),
    .cw-footer__cta-btn:hover:not(:disabled),
    .cw-footer__secondary-btn:hover:not(:disabled),
    .cw-footer__privacy-chip:hover:not(:disabled),
    .home-btn:hover:not(:disabled),
    .channel-btn-primary:hover:not(:disabled),
    .channel-btn-secondary:hover:not(:disabled),
    .channel-btn-support:hover:not(:disabled),
    .labs-youtube-btn:hover:not(:disabled),
    .blog-detail__booking-btn:hover:not(:disabled) {
        transform: none;
    }
}

/* =========================================================
   Global engineering product skin
   ========================================================= */
body {
    font-family: "Inter", "Segoe UI", system-ui, sans-serif;
    color: var(--text-primary);
    background-color: var(--bg-main);
    background-image: radial-gradient(circle, rgba(45, 55, 72, 0.18) 1px, transparent 1.2px);
    background-size: 24px 24px;
}

.page--engineering-tool {
    min-height: 100vh;
    background-color: var(--bg-main);
    background-image: radial-gradient(circle, rgba(45, 55, 72, 0.18) 1px, transparent 1.2px);
    background-size: 24px 24px;
}

.page--engineering-tool::before,
.page-backdrop,
.page-blob {
    display: none !important;
}

.page > main.page-main.page-main--engineering-tool {
    padding-top: clamp(4.25rem, 7vw, 5.35rem) !important;
    padding-bottom: clamp(1.6rem, 3.5vw, 2.8rem) !important;
}

.page-content--engineering-tool {
    max-width: 1280px;
}

.page-content--engineering-tool > .content {
    width: 100%;
}

.inner-page {
    gap: clamp(1.6rem, 3vw, 2.6rem) !important;
    font-family: "Inter", "Segoe UI", system-ui, sans-serif;
}

.inner-page .cv-record-title-card,
.inner-page .hero-summary-wrapper {
    width: min(1120px, 100%) !important;
    margin: 0 auto !important;
    padding: clamp(1.2rem, 2.6vw, 2.1rem) !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.76) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06) !important;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

.inner-page .cv-record-title-card__bg,
.inner-page .hero-summary-wrapper .hero-bg {
    display: none !important;
}

.inner-page .cv-record-title-card .hero-title,
.inner-page .hero-summary-wrapper h1,
.inner-page .hero-summary-wrapper .hero-title,
.inner-page .hero-summary-wrapper .display-5 {
    position: static !important;
    transform: none !important;
    margin: 0 !important;
    color: #050505 !important;
    font-family: "Inter", "Segoe UI", system-ui, sans-serif;
    font-size: clamp(2rem, 3.8vw, 3.65rem) !important;
    line-height: 1.08 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
    text-align: left !important;
}

.inner-page .hero-subtitle,
.inner-page .hero-summary-wrapper p,
.inner-page .inner-page__body,
.inner-page p {
    color: #334155;
}

.inner-page .cv-record-shell,
.inner-page .inner-page__body,
.info-wrap,
.privacy-shell,
.main > section.container.py-4 > :first-child,
.main > .container.py-5 > .row,
.main > section.container.p-4 > :first-child {
    width: min(1120px, 100%) !important;
    margin: 0 auto !important;
    padding: clamp(1rem, 2.2vw, 1.35rem) !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.78) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.inner-page--mermaid-tool .cv-record-shell--mermaid-tool {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    padding: 0 !important;
}

.e-card,
.blog-card,
.contact-panel,
.booking-card,
.confirmation-card,
.labs-card,
.about-card,
.main .card,
.main .alert,
.tool-panel {
    border-radius: 8px !important;
    background: rgba(255, 255, 255, 0.88) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06) !important;
}

.labs-chip,
.blog-filter-chip,
.contact-shell__eyebrow,
.booking-shell__eyebrow,
.about-shell__eyebrow,
.admin-shell__eyebrow,
.tool-shell__eyebrow {
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: var(--accent-primary) !important;
    font-family: "Fira Code", Consolas, monospace;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase;
}

.btn-primary,
.btn.btn-primary,
.home-btn-primary,
.contact-submit-btn,
.tool-generate-btn,
.cw-footer__cta-btn {
    color: #fff !important;
    background: var(--accent-primary) !important;
    border-color: var(--accent-primary) !important;
    border-radius: 7px !important;
    box-shadow: 0 16px 32px rgba(63, 43, 232, 0.18) !important;
}

.btn-primary:hover,
.btn.btn-primary:hover,
.home-btn-primary:hover,
.contact-submit-btn:hover,
.tool-generate-btn:hover,
.cw-footer__cta-btn:hover {
    background: var(--accent-primary-strong) !important;
    border-color: var(--accent-primary-strong) !important;
}

.btn-outline-primary,
.btn-link,
.cw-footer__secondary-btn,
.cw-footer__privacy-chip {
    color: #111827 !important;
    border-color: #cbd5e1 !important;
    border-radius: 7px !important;
    background: rgba(255, 255, 255, 0.72) !important;
    box-shadow: none !important;
}

.form-control,
.e-input,
.e-input-group,
.contact-panel--form .contact-input,
.contact-panel--form .contact-textarea {
    border-radius: 8px !important;
    border-color: #cbd5e1 !important;
    background: rgba(248, 250, 252, 0.92) !important;
}

.page--engineering-tool .site-navbar__inner {
    max-width: 1120px;
    min-height: 58px;
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 247, 250, 0.90)),
        radial-gradient(circle at 12% 18%, rgba(63, 43, 232, 0.08), transparent 28%) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 46px rgba(15, 23, 42, 0.08) !important;
}

.site-navbar__mobile-console {
    display: none;
}

.site-navbar__actions .nav-link i:not(.nav-submenu-toggle__chevron) {
    font-size: 1rem;
    color: var(--accent-primary);
}

.nav-brand-avatar--product {
    display: grid;
    place-items: center;
    color: #ffffff;
    background:
        linear-gradient(135deg, #3f2be8, #111827),
        radial-gradient(circle, rgba(255, 255, 255, 0.22), transparent 60%);
    border-color: rgba(63, 43, 232, 0.28) !important;
}

.nav-brand-avatar--product i {
    font-size: 1.15rem;
}

.page--mermaid-product-domain .site-navbar__inner {
    max-width: 1120px;
}

.page--mermaid-product-domain .nav-brand-name {
    font-family: "Fira Code", Consolas, monospace;
    text-transform: uppercase;
}

.page--mermaid-product-domain .cw-footer__profile-card img {
    display: none;
}

.page--mermaid-product-domain .cw-footer__profile-card {
    padding-left: 1rem;
}

.site-navbar__toggle {
    width: 46px;
    height: 46px;
}

.site-navbar__toggle-glyph {
    display: grid;
    gap: 4px;
    width: 22px;
}

.site-navbar__toggle-glyph i {
    display: block;
    height: 2px;
    border-radius: 999px;
    background: #111827;
    box-shadow: 0 0 12px rgba(63, 43, 232, 0.25);
}

.site-navbar__toggle-glyph i:nth-child(2) {
    width: 70%;
    margin-left: auto;
}

.cw-footer {
    margin-top: clamp(1.4rem, 3vw, 2.5rem);
}

.cw-footer__shell {
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.82) !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06) !important;
}

.cw-footer__shell::before {
    background-image: radial-gradient(circle, rgba(45, 55, 72, 0.12) 1px, transparent 1.2px) !important;
    background-size: 24px 24px !important;
    opacity: 0.55 !important;
}

.cw-footer__cta {
    border-radius: 8px;
    background: rgba(248, 250, 252, 0.82) !important;
    border-color: #e2e8f0 !important;
}

.cw-footer__cta h2,
.cw-footer__col h4 {
    color: #050505 !important;
    letter-spacing: 0 !important;
}

.home-page--v2 .home-offer-cta-panel {
    border-radius: 8px !important;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(248, 250, 252, 0.78)),
        radial-gradient(circle, rgba(45, 55, 72, 0.12) 1px, transparent 1.2px) !important;
    background-size: auto, 24px 24px !important;
    border: 1px solid var(--border-neutral) !important;
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06) !important;
}

.home-page--v2 .home-offer-cta-panel::before,
.home-page--v2 .home-offer-cta-panel::after {
    display: none !important;
}

.home-page--v2 .home-offer-cta-panel__copy span,
.home-page--v2 .home-offer-cta-panel__copy p {
    color: #334155 !important;
}

.home-page--v2 .home-btn-secondary,
.home-page--v2 .home-btn-outline {
    color: #111827 !important;
    background: rgba(255, 255, 255, 0.76) !important;
    border: 1px solid #cbd5e1 !important;
    box-shadow: none !important;
}

@media (max-width: 991.98px) {
    .page-header-shell .site-navbar.navbar,
    .site-navbar.navbar {
        padding-top: 0.75rem !important;
    }

    .page--engineering-tool .site-navbar__inner {
        align-items: flex-start;
        padding: 0.72rem;
        background:
            linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(247, 247, 250, 0.88)),
            radial-gradient(circle, rgba(45, 55, 72, 0.12) 1px, transparent 1.2px) !important;
        background-size: auto, 18px 18px !important;
    }

    .site-navbar__panel {
        position: relative;
        width: 100%;
        margin-top: 0.72rem;
        padding: 0.8rem;
        overflow: hidden;
        border-radius: 8px;
        background:
            linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(17, 24, 39, 0.96)),
            radial-gradient(circle, rgba(148, 163, 184, 0.18) 1px, transparent 1.2px) !important;
        background-size: auto, 18px 18px !important;
        border: 1px solid rgba(148, 163, 184, 0.28);
        box-shadow: 0 24px 40px rgba(2, 8, 23, 0.28);
    }

    .site-navbar__panel::before {
        content: "";
        position: absolute;
        inset: 0;
        background:
            linear-gradient(90deg, rgba(63, 43, 232, 0.18), transparent 32%),
            linear-gradient(180deg, rgba(255, 255, 255, 0.06), transparent 42%);
        pointer-events: none;
    }

    .site-navbar__mobile-console {
        position: relative;
        z-index: 1;
        display: flex;
        align-items: center;
        gap: 0.55rem;
        min-height: 34px;
        margin-bottom: 0.65rem;
        padding: 0.45rem 0.55rem;
        border-radius: 6px;
        color: #cbd5e1;
        background: rgba(2, 6, 23, 0.52);
        border: 1px solid rgba(148, 163, 184, 0.22);
        font-family: "Fira Code", Consolas, monospace;
        font-size: 0.72rem;
        letter-spacing: 0.03em;
    }

    .site-navbar__mobile-console strong {
        margin-left: auto;
        color: #a5b4fc;
        font-size: 0.68rem;
    }

    .site-navbar__console-dot {
        width: 8px;
        height: 8px;
        border-radius: 999px;
        background: #22c55e;
        box-shadow: 0 0 16px rgba(34, 197, 94, 0.65);
    }

    .site-navbar__actions {
        position: relative;
        z-index: 1;
        gap: 0.42rem;
        align-items: stretch !important;
    }

    .site-navbar__actions .nav-link,
    .culture-switch {
        width: 100%;
        min-height: 48px;
        justify-content: flex-start;
        border-radius: 7px !important;
        color: #f8fafc !important;
        background: rgba(15, 23, 42, 0.58) !important;
        border: 1px solid rgba(148, 163, 184, 0.18) !important;
        font-family: "Fira Code", Consolas, monospace;
        font-size: 0.9rem;
        text-transform: uppercase;
    }

    .site-navbar__actions .nav-link i:not(.nav-submenu-toggle__chevron) {
        display: inline-grid;
        place-items: center;
        width: 28px;
        height: 28px;
        border-radius: 6px;
        color: #c4b5fd;
        background: rgba(63, 43, 232, 0.18);
    }

    .site-navbar__actions .nav-link:hover,
    .site-navbar__actions .nav-link:focus,
    .site-navbar__actions .nav-link.active,
    .culture-switch:hover,
    .culture-switch:focus {
        color: #ffffff !important;
        background: rgba(63, 43, 232, 0.24) !important;
        border-color: rgba(165, 180, 252, 0.44) !important;
        box-shadow: inset 0 0 0 1px rgba(165, 180, 252, 0.22) !important;
    }

    .site-navbar__dropdown-menu {
        border-radius: 7px !important;
        background: rgba(2, 6, 23, 0.46) !important;
        border-color: rgba(148, 163, 184, 0.2) !important;
    }

    .site-navbar__dropdown-link {
        border-radius: 7px;
        background: rgba(15, 23, 42, 0.62);
        border: 1px solid rgba(148, 163, 184, 0.16);
    }

    .site-navbar__dropdown-link strong,
    .site-navbar__dropdown-link span {
        color: #f8fafc !important;
    }

    .nav-submenu-toggle__chevron {
        margin-left: auto;
    }

    .site-navbar__dropdown.is-open .nav-submenu-toggle__chevron {
        transform: rotate(180deg);
    }
}

@media (max-width: 767.98px) {
    .page > main.page-main.page-main--engineering-tool {
        padding-top: 4.1rem !important;
    }

    .page-content {
        padding-right: 0.75rem;
        padding-left: 0.75rem;
    }

    .inner-page .cv-record-title-card,
    .inner-page .hero-summary-wrapper,
    .inner-page .cv-record-shell,
    .inner-page .inner-page__body,
    .info-wrap,
    .privacy-shell {
        padding: 1rem !important;
    }

    .inner-page .cv-record-title-card .hero-title,
    .inner-page .hero-summary-wrapper h1,
    .inner-page .hero-summary-wrapper .hero-title,
    .inner-page .hero-summary-wrapper .display-5 {
        font-size: clamp(1.8rem, 9vw, 2.45rem) !important;
    }
}
