:root {
    --theme-ink: #082233;
    --theme-blue: #0c7194;
    --theme-cyan: #1ca4da;
    --theme-green: #2c9b7d;
    --theme-sand: #eef2ef;
    --theme-paper: #f8faf8;
    --theme-white: #ffffff;
    --theme-line: rgba(8, 34, 51, 0.1);
    --theme-line-strong: rgba(8, 34, 51, 0.18);
    --theme-soft: rgba(255, 255, 255, 0.78);
    --theme-shadow: 0 24px 70px rgba(8, 34, 51, 0.1);
    --theme-shadow-soft: 0 12px 35px rgba(8, 34, 51, 0.08);
    --theme-radius: 24px;
    --theme-radius-small: 14px;
    --font-display: "Space Grotesk", sans-serif;
    --font-body: "DM Sans", sans-serif;
    --nav-height: 104px;
    --floating-logo-size: 143px;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--theme-ink);
    font-family: var(--font-body);
    background:
        radial-gradient(circle at top left, rgba(28, 164, 218, 0.14), transparent 24%),
        radial-gradient(circle at bottom right, rgba(44, 155, 125, 0.12), transparent 20%),
        linear-gradient(180deg, #fbfcfb 0%, #f0f5f3 48%, #f7f8f6 100%);
}

a {
    color: inherit;
}

img {
    max-width: 100%;
}

h1,
h2,
h3,
h4 {
    font-family: var(--font-display);
    letter-spacing: -0.04em;
}

.site-header {
    position: relative;
    overflow: visible;
}

.site-nav {
    height: auto;
    line-height: normal;
    background: rgba(248, 250, 248, 0.92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
    box-shadow: 0 12px 30px rgba(8, 34, 51, 0.06);
    overflow: visible;
}

.nav-shell,
.portal-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    min-height: 92px;
}

.nav-shell {
    position: relative;
    min-height: var(--nav-height);
    padding-left: calc(var(--floating-logo-size) + 1.75rem);
}

.site-nav-logo {
    position: fixed;
    left: max(5vw, calc((100vw - 1280px) / 2));
    top: calc(var(--nav-height) - (var(--floating-logo-size) / 2));
    z-index: 120;
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--floating-logo-size);
    height: var(--floating-logo-size);
}

.site-nav-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 12px 24px rgba(8, 34, 51, 0.14));
}

.brand-lockup {
    display: inline-flex;
    align-items: center;
    gap: 1rem;
    min-width: 0;
}

.brand-lockup img {
    width: 76px;
    height: 76px;
    object-fit: contain;
}

.brand-lockup span {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.brand-lockup strong {
    font-family: var(--font-display);
    font-size: 1.05rem;
}

.brand-lockup small {
    color: rgba(8, 34, 51, 0.62);
    font-size: 0.9rem;
}

.nav-links-wrap {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
}

.nav-links li {
    list-style: none;
}

.nav-links a,
.sidenav li > a {
    border-radius: 999px;
    color: var(--theme-ink);
    font-weight: 500;
}

.nav-links a {
    padding: 0.75rem 1rem;
}

.nav-links a:hover,
.nav-links a.is-active {
    background: rgba(12, 113, 148, 0.1);
}

.sidenav-trigger {
    color: var(--theme-ink);
}

.site-sidenav {
    background: #f7faf8;
}

.mobile-brand {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem 2rem 1rem;
}

.mobile-brand img {
    width: 72px;
    height: 72px;
}

.mobile-brand strong {
    display: block;
    font-family: var(--font-display);
}

.mobile-brand small {
    color: rgba(8, 34, 51, 0.6);
}

.site-main,
.portal-main {
    padding-bottom: 4rem;
}

.error-page-main {
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.container.narrow {
    max-width: 860px;
}

.hero-section,
.page-hero {
    padding: 4.75rem 0 2rem;
}

.error-page-section {
    width: 100%;
    padding: clamp(2.5rem, 8vw, 5.5rem) 0;
}

.hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.9fr);
    gap: 1.5rem;
    align-items: start;
}

.hero-title,
.page-hero h1 {
    margin: 0;
    font-size: clamp(3rem, 8vw, 5.6rem);
    line-height: 0.96;
}

.hero-copy,
.page-intro {
    margin: 1.3rem 0 0;
    max-width: 56rem;
    color: rgba(8, 34, 51, 0.72);
    font-size: 1.1rem;
}

.eyebrow,
.panel-kicker,
.footer-kicker,
.portal-label {
    margin: 0 0 0.8rem;
    color: var(--theme-blue);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

.hero-actions,
.section-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    margin-top: 1.5rem;
}

.site-btn {
    border-radius: 999px;
    box-shadow: none;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-transform: none;
}

.site-btn-primary {
    background: linear-gradient(135deg, var(--theme-ink), var(--theme-blue));
}

.site-btn-primary:hover,
.site-btn-primary:focus {
    background: linear-gradient(135deg, var(--theme-blue), var(--theme-cyan));
}

.site-btn-secondary {
    border: 1px solid var(--theme-line-strong);
    background: rgba(255, 255, 255, 0.64);
    color: var(--theme-ink);
}

.site-btn-secondary:hover,
.site-btn-secondary:focus {
    background: rgba(8, 34, 51, 0.05);
}

.hero-points,
.feature-list,
.footer-list,
.method-list {
    margin: 1.4rem 0 0;
    padding-left: 1.2rem;
}

.hero-points li,
.feature-list li,
.footer-list li,
.method-list li {
    margin-bottom: 0.7rem;
    color: rgba(8, 34, 51, 0.78);
}

.surface-card,
.plan-card,
.process-card,
.stat-card,
.project-card,
.project-hero-card,
.detail-panel,
.empty-panel,
.portal-auth-card,
.portal-table-card,
.portal-form-card,
.portal-policy-card {
    border: 1px solid var(--theme-line);
    border-radius: var(--theme-radius);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 248, 0.82));
    box-shadow: var(--theme-shadow-soft);
}

.surface-card,
.plan-card,
.process-card,
.portal-auth-card,
.portal-table-card,
.portal-form-card,
.portal-policy-card {
    padding: 1.6rem;
}

.error-page-card {
    position: relative;
    overflow: hidden;
    max-width: 54rem;
    margin: 0 auto;
    padding: clamp(1.8rem, 4vw, 3rem);
}

.error-page-card::before {
    content: "";
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 0.45rem;
    background: linear-gradient(90deg, var(--theme-ink), var(--theme-blue), var(--theme-cyan));
}

.error-page-brand {
    margin-bottom: 1.4rem;
}

.error-page-status {
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    margin-bottom: 1rem;
}

.error-page-status::before {
    content: "";
    width: 0.7rem;
    height: 0.7rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--theme-ink), var(--theme-cyan));
    box-shadow: 0 0 0 0.25rem rgba(28, 164, 218, 0.14);
}

.error-page-copy {
    max-width: 44rem;
}

.error-page-actions {
    margin-top: 1.75rem;
}

.error-page-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--theme-line);
}

.error-page-meta a {
    display: inline-flex;
    align-items: center;
    min-height: 2.75rem;
    padding: 0.7rem 1rem;
    border: 1px solid var(--theme-line);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.62);
    color: rgba(8, 34, 51, 0.78);
    transition: background 0.2s ease, transform 0.2s ease;
}

.error-page-meta a:hover,
.error-page-meta a:focus {
    background: rgba(12, 113, 148, 0.08);
    transform: translateY(-1px);
}

.hero-panel {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.hero-panel-stack {
    display: grid;
    gap: 1rem;
}

.hero-panel .surface-card h2,
.page-card h2,
.plan-card h2,
.portal-table-card h2,
.portal-form-card h2 {
    margin: 0 0 0.6rem;
    font-size: 1.5rem;
}

.stats-grid,
.card-grid,
.process-grid,
.portal-summary,
.portal-grid,
.two-column {
    display: grid;
    gap: 1rem;
}

.stats-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin-top: 1.5rem;
}

.card-grid.three-up,
.process-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.two-column,
.portal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.legal-layout {
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 2.1fr);
    align-items: start;
}

.legal-sidebar {
    position: sticky;
    top: 1.5rem;
}

.portal-legal-review-layout {
    grid-template-columns: minmax(290px, 0.34fr) minmax(0, 1fr);
}

.portal-legal-review-sidebar {
    display: grid;
    gap: 1rem;
}

.portal-legal-review-account p:last-child {
    margin: 0;
    color: rgba(8, 34, 51, 0.72);
}

.portal-legal-review-note {
    margin-bottom: 0;
}

.portal-legal-review-note p:last-child {
    margin: 0;
    color: rgba(8, 34, 51, 0.78);
}

.portal-legal-review-nav.collection {
    display: block;
}

.portal-legal-review-link.collection-item {
    align-items: flex-start;
}

.portal-legal-review-link-main {
    display: flex;
    align-items: flex-start;
    gap: 0.8rem;
    min-width: 0;
}

.portal-legal-review-link-main .material-icons {
    margin-top: 0.05rem;
    color: var(--theme-blue);
    font-size: 1.2rem;
}

.portal-legal-review-link-copy {
    display: grid;
    gap: 0.2rem;
    min-width: 0;
}

.portal-legal-review-link-copy strong {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.2;
}

.portal-legal-review-link-copy small {
    color: rgba(8, 34, 51, 0.68);
    font-size: 0.86rem;
    line-height: 1.35;
}

.portal-legal-review-current-badge {
    background: rgba(12, 113, 148, 0.12);
    color: var(--theme-blue);
    box-shadow: inset 0 0 0 1px rgba(12, 113, 148, 0.12);
}

.portal-legal-review-sidebar-actions {
    margin-top: 0.1rem;
}

.portal-legal-review-document {
    display: grid;
    gap: 0;
    padding: 0;
    overflow: hidden;
}

.portal-legal-review-document-hero,
.portal-legal-review-document-body,
.portal-legal-review-footer {
    padding-left: 1.75rem;
    padding-right: 1.75rem;
}

.portal-legal-review-document-hero {
    padding-top: 1.75rem;
    padding-bottom: 1.4rem;
    background: rgba(255, 255, 255, 0.18);
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.portal-legal-review-document-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.portal-legal-review-document-copy {
    min-width: 0;
}

.portal-legal-review-document-header h2 {
    margin: 0 0 0.55rem;
    font-size: clamp(2rem, 4vw, 2.7rem);
}

.portal-legal-review-document-copy p {
    margin: 0 0 0.8rem;
    color: rgba(8, 34, 51, 0.82);
    line-height: 1.7;
}

.portal-legal-review-document-tools {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: flex-end;
}

.portal-legal-review-summary {
    margin-top: 1.15rem;
    border: 1px solid rgba(12, 113, 148, 0.1);
    background: rgba(12, 113, 148, 0.07);
}

.portal-legal-review-summary h3 {
    margin-top: 0;
}

.portal-legal-review-summary .feature-list {
    margin-top: 0.8rem;
}

.portal-legal-review-section {
    padding: 1.45rem 0;
    border-top: 1px solid rgba(8, 34, 51, 0.08);
}

.portal-legal-review-document-body {
    background: transparent;
}

.portal-legal-review-document-body .portal-legal-review-section:first-child {
    border-top: 0;
}

.portal-legal-review-section h3 {
    margin: 0 0 0.7rem;
    font-size: 1.28rem;
}

.portal-legal-review-section p {
    margin: 0 0 0.9rem;
    color: rgba(8, 34, 51, 0.8);
    line-height: 1.78;
}

.portal-legal-review-section p:last-child {
    margin-bottom: 0;
}

.portal-legal-review-footer {
    padding-top: 1.2rem;
    padding-bottom: 1.6rem;
    border-top: 1px solid rgba(8, 34, 51, 0.08);
    background: rgba(255, 255, 255, 0.14);
}

.portal-legal-review-actions {
    margin-top: 0;
}

.stat-card {
    padding: 1.4rem;
}

.stat-card strong {
    display: block;
    font-family: var(--font-display);
    font-size: 2.4rem;
}

.stat-card span {
    display: block;
    margin-top: 0.4rem;
    color: rgba(8, 34, 51, 0.7);
}

.section-block {
    padding: 2rem 0;
}

.section-soft {
    background: rgba(255, 255, 255, 0.45);
}

.section-dark {
    margin-top: 1rem;
    background:
        radial-gradient(circle at top right, rgba(28, 164, 218, 0.18), transparent 28%),
        linear-gradient(180deg, rgba(8, 34, 51, 0.98), rgba(12, 47, 66, 0.96));
}

.section-heading {
    max-width: 58rem;
    margin-bottom: 1.5rem;
}

.section-heading h2 {
    margin: 0;
    font-size: clamp(2.2rem, 5vw, 4rem);
}

.section-heading p:last-child,
.surface-card p,
.plan-card p,
.page-card p,
.process-card p,
.portal-table-card p,
.portal-form-card p {
    color: rgba(8, 34, 51, 0.72);
}

.section-heading-dark,
.section-heading-dark p,
.section-heading-dark h2,
.process-card,
.process-card p {
    color: rgba(255, 255, 255, 0.88);
}

.process-card {
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: none;
}

.process-card span {
    display: inline-block;
    margin-bottom: 0.85rem;
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.9rem;
    font-weight: 700;
    letter-spacing: 0.14em;
}

.process-grid-light .process-card-light {
    color: var(--theme-ink);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(248, 250, 248, 0.82));
    border-color: var(--theme-line);
    box-shadow: var(--theme-shadow-soft);
}

.process-grid-light .process-card-light span {
    color: var(--theme-blue);
}

.plan-card {
    position: relative;
}

.plan-card.featured {
    border-color: rgba(12, 113, 148, 0.28);
    transform: translateY(-6px);
}

.plan-pill {
    display: inline-block;
    margin-bottom: 0.9rem;
    padding: 0.35rem 0.8rem;
    border-radius: 999px;
    background: rgba(12, 113, 148, 0.12);
    color: var(--theme-blue);
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.plan-price {
    margin: 0.5rem 0 0.9rem;
    font-family: var(--font-display);
    font-size: 2rem;
}

.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.7fr);
    gap: 1rem;
}

.contact-side {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.contact-side a:not(.btn) {
    font-size: 1.05rem;
    font-weight: 600;
}

.contact-side .hero-actions {
    flex-wrap: wrap;
}

.contact-form-errors {
    margin-bottom: 1rem;
    padding: 0.85rem 1rem;
    border-radius: var(--theme-radius-small);
    border: 1px solid rgba(183, 44, 44, 0.14);
    background: linear-gradient(180deg, rgba(255, 244, 244, 0.96), rgba(252, 247, 247, 0.94));
    color: #a42323;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

.contact-form,
.portal-form {
    display: grid;
    gap: 1rem;
}

.contact-form .row,
.portal-form .row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    margin-bottom: 0;
    margin-left: -0.45rem;
    margin-right: -0.45rem;
}

.contact-form .input-field,
.portal-form .input-field {
    position: relative;
    margin-top: 0;
    margin-bottom: 0.95rem;
    padding-top: 0.9rem;
}

.contact-form .input-field.col,
.portal-form .input-field.col {
    float: none;
    padding-left: 0.45rem;
    padding-right: 0.45rem;
    padding-bottom: 0.15rem;
}

.input-field label,
.input-field input,
.input-field textarea,
.input-field select,
.select-wrapper input.select-dropdown {
    font-family: var(--font-body);
}

.contact-form .input-field > label,
.portal-form .input-field > label {
    left: 1rem;
    width: calc(100% - 2rem);
    color: rgba(8, 34, 51, 0.56);
    font-weight: 600;
}

.contact-form .input-field > label:not(.label-icon),
.portal-form .input-field > label:not(.label-icon) {
    top: 1.82rem;
}

.contact-form .input-field > label.active,
.portal-form .input-field > label.active {
    width: auto;
    padding: 0 0.4rem;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(243, 248, 246, 0.96));
    color: var(--theme-blue);
    transform: translateY(-1.3rem) scale(0.82);
    transform-origin: left top;
    z-index: 2;
}

.contact-form .input-field input:not([type]),
.contact-form .input-field input[type="text"],
.contact-form .input-field input[type="email"],
.contact-form .input-field input[type="url"],
.contact-form .input-field input[type="tel"],
.contact-form .input-field input[type="number"],
.contact-form .input-field input[type="search"],
.contact-form .input-field textarea.materialize-textarea,
.contact-form .input-field .select-wrapper input.select-dropdown,
.portal-form .input-field input:not([type]),
.portal-form .input-field input[type="text"],
.portal-form .input-field input[type="email"],
.portal-form .input-field input[type="password"],
.portal-form .input-field input[type="url"],
.portal-form .input-field input[type="tel"],
.portal-form .input-field input[type="number"],
.portal-form .input-field input[type="search"],
.portal-form .input-field textarea.materialize-textarea,
.portal-form .input-field .select-wrapper input.select-dropdown {
    box-sizing: border-box;
    width: 100%;
    min-height: 3.45rem;
    margin: 0;
    padding: 1.15rem 1rem 0.55rem;
    border: 1px solid rgba(8, 34, 51, 0.12) !important;
    border-bottom: 1px solid rgba(8, 34, 51, 0.12) !important;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(243, 248, 246, 0.95));
    color: var(--theme-ink);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9), 0 10px 24px rgba(8, 34, 51, 0.04) !important;
}

.contact-form .input-field textarea.materialize-textarea,
.portal-form .input-field textarea.materialize-textarea {
    min-height: 9.5rem;
    padding-top: 1.35rem;
    line-height: 1.55;
}

.contact-form .input-field input::placeholder,
.contact-form .input-field textarea::placeholder,
.portal-form .input-field input::placeholder,
.portal-form .input-field textarea::placeholder {
    color: rgba(8, 34, 51, 0.44);
}

.contact-form .input-field .select-wrapper,
.portal-form .input-field .select-wrapper {
    position: relative;
}

.contact-form .input-field .select-wrapper input.select-dropdown,
.portal-form .input-field .select-wrapper input.select-dropdown {
    padding: 0.95rem 2.7rem 0.95rem 1rem;
    cursor: pointer;
}

.contact-form .input-field .select-wrapper .caret,
.portal-form .input-field .select-wrapper .caret {
    fill: var(--theme-blue);
    right: 1rem;
}

.contact-form .dropdown-content,
.portal-form .dropdown-content {
    border: 1px solid rgba(8, 34, 51, 0.1);
    border-radius: 20px;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(243, 248, 246, 0.96));
    box-shadow: var(--theme-shadow-soft);
}

.contact-form .dropdown-content li > a,
.contact-form .dropdown-content li > span,
.contact-form .select-dropdown li > span,
.portal-form .dropdown-content li > a,
.portal-form .dropdown-content li > span,
.portal-form .select-dropdown li > span {
    color: var(--theme-ink);
    font-family: var(--font-body);
}

.contact-form .dropdown-content li:hover,
.contact-form .dropdown-content li.active,
.contact-form .dropdown-content li.selected,
.portal-form .dropdown-content li:hover,
.portal-form .dropdown-content li.active,
.portal-form .dropdown-content li.selected {
    background: rgba(12, 113, 148, 0.08);
}

.contact-form .dropdown-content li.disabled > span,
.portal-form .dropdown-content li.disabled > span {
    color: rgba(8, 34, 51, 0.4);
}

.contact-form .input-field input:focus,
.contact-form .input-field textarea:focus,
.contact-form .input-field .select-wrapper input.select-dropdown:focus,
.portal-form .input-field input:focus,
.portal-form .input-field textarea:focus,
.portal-form .input-field .select-wrapper input.select-dropdown:focus {
    border: 1px solid rgba(12, 113, 148, 0.28) !important;
    border-bottom: 1px solid rgba(12, 113, 148, 0.28) !important;
    box-shadow: 0 0 0 4px rgba(12, 113, 148, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.92) !important;
}

.contact-form .input-field input:focus + label,
.contact-form .input-field textarea:focus + label,
.contact-form .input-field label.active,
.portal-form .input-field input:focus + label,
.portal-form .input-field textarea:focus + label,
.portal-form .input-field label.active {
    color: var(--theme-blue);
}

.contact-form .helper-text,
.portal-form .helper-text,
.field-error {
    display: block;
    margin-top: 0.45rem;
    color: #b72c2c;
    font-size: 0.85rem;
}

.portal-form > p {
    margin: 0 0 0.95rem;
}

.portal-form > p label {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    padding: 0.95rem 1rem;
    border: 1px solid rgba(8, 34, 51, 0.1);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(243, 248, 246, 0.95));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.88);
}

.portal-form > p label span,
.contact-form [type="checkbox"] + span:not(.lever),
.portal-form [type="checkbox"] + span:not(.lever),
.contact-form [type="radio"] + span,
.portal-form [type="radio"] + span {
    color: var(--theme-ink);
    font-weight: 600;
}

.contact-form [type="checkbox"] + span:not(.lever)::before,
.portal-form [type="checkbox"] + span:not(.lever)::before {
    border-color: rgba(8, 34, 51, 0.28);
}

.contact-form [type="checkbox"]:checked + span:not(.lever)::before,
.portal-form [type="checkbox"]:checked + span:not(.lever)::before {
    border-right-color: var(--theme-blue);
    border-bottom-color: var(--theme-blue);
}

.contact-form [type="checkbox"].filled-in:checked + span:not(.lever)::after,
.portal-form [type="checkbox"].filled-in:checked + span:not(.lever)::after {
    border-color: var(--theme-blue);
    background-color: var(--theme-blue);
}

.contact-form [type="radio"]:checked + span::after,
.contact-form [type="radio"].with-gap:checked + span::after,
.portal-form [type="radio"]:checked + span::after,
.portal-form [type="radio"].with-gap:checked + span::after {
    background-color: var(--theme-blue);
}

.contact-form [type="radio"]:checked + span::after,
.contact-form [type="radio"].with-gap:checked + span::before,
.contact-form [type="radio"].with-gap:checked + span::after,
.portal-form [type="radio"]:checked + span::after,
.portal-form [type="radio"].with-gap:checked + span::before,
.portal-form [type="radio"].with-gap:checked + span::after {
    border-color: var(--theme-blue);
}

.faq-list {
    border-radius: var(--theme-radius);
    border: 1px solid var(--theme-line);
    overflow: hidden;
    box-shadow: var(--theme-shadow-soft);
}

.faq-list .collapsible-header,
.faq-list .collapsible-body {
    border-bottom-color: rgba(8, 34, 51, 0.08);
    background: rgba(255, 255, 255, 0.86);
}

.faq-list .collapsible-header {
    font-weight: 600;
}

.site-footer {
    padding: 2.5rem 0 2rem;
    background: linear-gradient(180deg, rgba(8, 34, 51, 0.98), rgba(5, 26, 39, 1));
    color: rgba(255, 255, 255, 0.84);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 0.8fr;
    gap: 1.25rem;
}

.site-footer h2,
.site-footer h3,
.site-footer p,
.site-footer a,
.site-footer li {
    color: inherit;
}

.footer-list {
    list-style: none;
    padding-left: 0;
}

.footer-list li {
    margin-bottom: 0.6rem;
}

.work-hero,
.project-detail-shell {
    padding-top: 3rem;
}

.work-title {
    margin: 0;
    font-size: clamp(2.8rem, 6vw, 4.6rem);
    line-height: 0.96;
}

.project-card {
    overflow: hidden;
    height: 100%;
}

.project-card-link {
    display: block;
    height: 100%;
}

.project-visual {
    aspect-ratio: 16 / 10;
    background: linear-gradient(135deg, rgba(12, 113, 148, 0.12), rgba(44, 155, 125, 0.18));
}

.project-image,
.project-detail-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.project-placeholder,
.project-placeholder-detail {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(8, 34, 51, 0.98), rgba(12, 113, 148, 0.9));
    color: white;
}

.project-placeholder span {
    font-family: var(--font-display);
    font-size: 3.5rem;
}

.project-card .card-content {
    padding: 1.4rem;
}

.project-card-meta,
.project-detail-meta,
.portal-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.project-card-meta span,
.project-meta-pill,
.portal-meta span {
    padding: 0.32rem 0.75rem;
    border-radius: 999px;
    background: rgba(12, 113, 148, 0.08);
    color: var(--theme-blue);
    font-size: 0.82rem;
    font-weight: 600;
}

.project-tag-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 1rem;
}

.project-tag {
    display: inline-flex;
    align-items: center;
    padding: 0.32rem 0.7rem;
    border-radius: 999px;
    background: rgba(44, 155, 125, 0.12);
    color: var(--theme-green);
    font-size: 0.8rem;
    font-weight: 600;
}

.project-build-time {
    margin-top: 0.9rem;
    font-size: 0.92rem;
    color: rgba(8, 34, 51, 0.6);
}

.project-summary {
    color: rgba(8, 34, 51, 0.72);
}

.project-hero-card {
    padding: 0;
    overflow: hidden;
    min-height: 360px;
}

.detail-panel {
    padding: 1.6rem;
}

.detail-panel h3 {
    margin: 1.2rem 0 0.6rem;
    font-size: 1.1rem;
}

.result-card {
    height: 100%;
    padding: 1.1rem;
    border: 1px solid var(--theme-line);
    border-radius: var(--theme-radius-small);
    background: rgba(255, 255, 255, 0.82);
}

.portal-site {
    background:
        radial-gradient(circle at top left, rgba(28, 164, 218, 0.12), transparent 22%),
        linear-gradient(180deg, #f8faf8 0%, #eef4f2 100%);
}

.control-site {
    min-height: 100vh;
    --control-primary: var(--theme-blue);
    --control-primary-strong: #0a5f7d;
    --control-primary-soft: rgba(12, 113, 148, 0.12);
    --control-primary-soft-strong: rgba(12, 113, 148, 0.18);
    --control-border: rgba(8, 34, 51, 0.08);
    --control-text-muted: rgba(8, 34, 51, 0.62);
    --control-surface: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(241, 246, 244, 0.97));
    --control-surface-soft: linear-gradient(180deg, rgba(248, 250, 248, 0.96), rgba(236, 243, 240, 0.98));
    --control-shadow: 0 18px 42px rgba(8, 34, 51, 0.08);
}

.control-site .btn:focus,
.control-site .btn-large:focus,
.control-site .btn-small:focus,
.control-site .btn-floating:focus {
    background-color: var(--control-primary-strong);
}

.control-site .site-btn,
.control-site .site-btn .material-icons {
    color: inherit;
}

.control-site .site-btn-primary,
.control-site a.site-btn-primary,
.control-site button.site-btn-primary {
    color: var(--theme-white) !important;
    box-shadow: 0 12px 28px rgba(12, 113, 148, 0.18);
}

.control-site .site-btn-secondary,
.control-site a.site-btn-secondary,
.control-site button.site-btn-secondary {
    color: var(--theme-ink) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(242, 247, 245, 0.96)) !important;
    border: 1px solid rgba(8, 34, 51, 0.12) !important;
    box-shadow: 0 10px 24px rgba(8, 34, 51, 0.04);
}

.control-site .site-btn-secondary:hover,
.control-site .site-btn-secondary:focus,
.control-site a.site-btn-secondary:hover,
.control-site a.site-btn-secondary:focus,
.control-site button.site-btn-secondary:hover,
.control-site button.site-btn-secondary:focus {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(236, 243, 240, 0.98)) !important;
}

.control-site .control-access-button,
.control-site a.control-access-button,
.control-site button.control-access-button {
    color: var(--theme-white) !important;
    border: 1px solid transparent !important;
    box-shadow: 0 12px 24px rgba(8, 34, 51, 0.1);
}

.control-site .control-access-button.is-grant,
.control-site a.control-access-button.is-grant,
.control-site button.control-access-button.is-grant {
    background: linear-gradient(135deg, #9a4747, #bf5d5d) !important;
}

.control-site .control-access-button.is-grant:hover,
.control-site .control-access-button.is-grant:focus,
.control-site a.control-access-button.is-grant:hover,
.control-site a.control-access-button.is-grant:focus,
.control-site button.control-access-button.is-grant:hover,
.control-site button.control-access-button.is-grant:focus {
    background: linear-gradient(135deg, #ad5353, #cf6b6b) !important;
}

.control-site .control-access-button.is-revoke,
.control-site a.control-access-button.is-revoke,
.control-site button.control-access-button.is-revoke {
    background: linear-gradient(135deg, #1d8a6f, #2c9b7d) !important;
}

.control-site .control-access-button.is-revoke:hover,
.control-site .control-access-button.is-revoke:focus,
.control-site a.control-access-button.is-revoke:hover,
.control-site a.control-access-button.is-revoke:focus,
.control-site button.control-access-button.is-revoke:hover,
.control-site button.control-access-button.is-revoke:focus {
    background: linear-gradient(135deg, #23967a, #34af8d) !important;
}

.control-site .control-access-button.is-pending,
.control-site a.control-access-button.is-pending,
.control-site button.control-access-button.is-pending {
    background: linear-gradient(135deg, #a86f0f, #c98512) !important;
}

.control-site .control-access-button.is-pending:hover,
.control-site .control-access-button.is-pending:focus,
.control-site a.control-access-button.is-pending:hover,
.control-site a.control-access-button.is-pending:focus,
.control-site button.control-access-button.is-pending:hover,
.control-site button.control-access-button.is-pending:focus {
    background: linear-gradient(135deg, #b67912, #d9971c) !important;
}

.control-inline-note {
    margin: 0.8rem 0 0;
    color: rgba(8, 34, 51, 0.72);
}

.control-site .dropdown-content {
    border: 1px solid var(--control-border);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: var(--theme-shadow-soft);
}

.control-site .dropdown-content li > a,
.control-site .dropdown-content li > span,
.control-site .select-dropdown li > span {
    color: var(--theme-ink);
}

.control-site .dropdown-content li:hover,
.control-site .dropdown-content li.active,
.control-site .dropdown-content li.selected {
    background: var(--control-primary-soft);
}

.control-site .select-wrapper input.select-dropdown:focus {
    border-bottom: 1px solid var(--control-primary);
}

.control-site input:not([type]):focus:not([readonly]),
.control-site input[type="text"]:focus:not([readonly]),
.control-site input[type="password"]:focus:not([readonly]),
.control-site input[type="email"]:focus:not([readonly]),
.control-site input[type="url"]:focus:not([readonly]),
.control-site input[type="time"]:focus:not([readonly]),
.control-site input[type="date"]:focus:not([readonly]),
.control-site input[type="datetime"]:focus:not([readonly]),
.control-site input[type="datetime-local"]:focus:not([readonly]),
.control-site input[type="tel"]:focus:not([readonly]),
.control-site input[type="number"]:focus:not([readonly]),
.control-site input[type="search"]:focus:not([readonly]),
.control-site textarea.materialize-textarea:focus:not([readonly]) {
    border-bottom: 1px solid var(--control-primary);
    box-shadow: 0 1px 0 0 var(--control-primary);
}

.control-site input:not([type]):focus:not([readonly]) + label,
.control-site input[type="text"]:focus:not([readonly]) + label,
.control-site input[type="password"]:focus:not([readonly]) + label,
.control-site input[type="email"]:focus:not([readonly]) + label,
.control-site input[type="url"]:focus:not([readonly]) + label,
.control-site input[type="time"]:focus:not([readonly]) + label,
.control-site input[type="date"]:focus:not([readonly]) + label,
.control-site input[type="datetime"]:focus:not([readonly]) + label,
.control-site input[type="datetime-local"]:focus:not([readonly]) + label,
.control-site input[type="tel"]:focus:not([readonly]) + label,
.control-site input[type="number"]:focus:not([readonly]) + label,
.control-site input[type="search"]:focus:not([readonly]) + label,
.control-site textarea.materialize-textarea:focus:not([readonly]) + label {
    color: var(--control-primary);
}

.control-site [type="checkbox"]:checked + span:not(.lever)::before {
    border-right-color: var(--control-primary);
    border-bottom-color: var(--control-primary);
}

.control-site [type="checkbox"].filled-in:checked + span:not(.lever)::after {
    border-color: var(--control-primary);
    background-color: var(--control-primary);
}

.control-site [type="radio"]:checked + span::after,
.control-site [type="radio"].with-gap:checked + span::after {
    background-color: var(--control-primary);
}

.control-site [type="radio"]:checked + span::after,
.control-site [type="radio"].with-gap:checked + span::before,
.control-site [type="radio"].with-gap:checked + span::after {
    border-color: var(--control-primary);
}

.control-site .secondary-content {
    color: var(--control-primary);
}

.control-site .chip {
    background: var(--control-primary-soft);
    color: var(--control-primary-strong);
    font-weight: 700;
}

.control-shell {
    position: relative;
    width: min(1460px, 92vw);
    padding: 1.5rem 0 3rem;
}

.control-layout-row {
    margin-bottom: 0;
}

.control-side-column,
.control-main-column {
    padding-bottom: 0;
}

.control-main-column {
    position: relative;
    opacity: 1;
    transition: opacity 750ms ease;
    will-change: opacity;
}

.control-side-panel {
    position: sticky;
    top: 1.5rem;
    margin: 0;
    padding: 1.5rem 1.3rem;
    border-radius: 28px;
    border: 1px solid rgba(12, 113, 148, 0.1);
    background: var(--control-surface);
    backdrop-filter: blur(16px);
    box-shadow: var(--control-shadow);
}

.control-brand {
    margin-bottom: 1.1rem;
    padding: 0.15rem 0.1rem 0.95rem;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.control-brand strong {
    font-size: 1.5rem;
    line-height: 1;
}

.control-brand small {
    margin-top: 0.18rem;
    color: var(--control-text-muted);
}

.control-nav-collection.collection {
    margin: 0 0 1.3rem;
    border: 1px solid rgba(12, 113, 148, 0.08);
    border-radius: 24px;
    overflow: hidden;
    background: var(--control-surface-soft);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.control-nav-link.collection-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid rgba(8, 34, 51, 0.06);
    background: transparent;
    color: rgba(8, 34, 51, 0.88) !important;
    font-weight: 600;
    box-shadow: inset 0 0 0 0 transparent;
    transition: background 180ms ease, box-shadow 180ms ease, color 180ms ease;
}

.control-nav-link.collection-item:last-child {
    border-bottom: 0;
}

.control-nav-link.collection-item:hover,
.control-nav-link.collection-item.is-active {
    background: linear-gradient(135deg, rgba(12, 113, 148, 0.12), rgba(28, 164, 218, 0.05));
    box-shadow: inset 4px 0 0 var(--theme-blue);
    color: var(--theme-ink) !important;
}

.control-nav-badge.badge {
    min-width: 2rem;
    padding: 0 0.65rem;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--theme-ink), var(--theme-blue));
    color: var(--theme-white);
    font-weight: 700;
    box-shadow: 0 8px 18px rgba(12, 113, 148, 0.16);
}

.control-side-actions {
    display: grid;
    gap: 0.8rem;
    margin-top: 1.25rem;
}

.control-side-actions .btn,
.control-side-actions button {
    width: 100%;
    min-height: 3rem;
}

.control-header {
    display: grid;
    gap: 1.35rem;
}

.control-header h1 {
    margin: 0.15rem 0 0;
}

.control-header-top {
    position: relative;
    display: grid;
    gap: 0.15rem;
}

.control-header-middle {
    display: flex;
    align-items: center;
}

.control-header-bottom {
    display: block;
}

.control-header-panel {
    margin: 0 0 1.5rem;
    padding: 1.75rem 1.8rem 0.9rem;
    border-radius: 28px;
    border: 1px solid rgba(8, 34, 51, 0.08);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(240, 245, 243, 0.92));
    box-shadow: var(--theme-shadow-soft);
}

.control-header-panel .divider {
    margin: 1.35rem 0;
    background-color: rgba(8, 34, 51, 0.08);
}

.control-header-actions,
.control-inline-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.control-header-actions > .btn,
.control-header-actions > a.btn,
.control-header-actions > form,
.control-header-actions > form > .btn {
    width: 13.5rem;
}

.control-header-actions > .btn,
.control-header-actions > a.btn,
.control-header-actions > form > .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.control-stat-grid {
    margin: 0;
}

.control-stat-grid > .col {
    margin-bottom: 1rem;
}

.control-stat-link {
    display: block;
    height: 100%;
    color: inherit;
    text-decoration: none;
    border-radius: 20px;
}

.control-stat-link:hover,
.control-stat-link:focus,
.control-stat-link:focus-visible {
    color: inherit;
    text-decoration: none;
}

.control-stat-panel {
    height: 100%;
    margin: 0;
    padding: 1.3rem 1.25rem;
    border-radius: 20px;
    border: 1px solid rgba(8, 34, 51, 0.05);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(243, 247, 245, 0.95));
    box-shadow: none;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.control-stat-link:hover .control-stat-panel,
.control-stat-link:focus-visible .control-stat-panel {
    transform: translateY(-2px);
    border-color: rgba(15, 94, 129, 0.18);
    background: linear-gradient(180deg, rgba(244, 250, 255, 0.98), rgba(236, 246, 249, 0.95));
    box-shadow: var(--theme-shadow-soft);
}

.control-stat-panel strong {
    display: block;
    font-family: var(--font-display);
    font-size: 2rem;
    line-height: 1;
}

.control-stat-panel span {
    display: block;
    margin-top: 0.35rem;
    color: rgba(8, 34, 51, 0.7);
}

.control-content-shell {
    position: relative;
}

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

.portal-panel-section {
    padding: 0 0 1.5rem;
}

.portal-table-card.card-panel,
.portal-form-card.card-panel {
    height: 100%;
    margin: 0;
    padding: 1.6rem;
    border-radius: var(--theme-radius);
    border: 1px solid var(--theme-line);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(248, 250, 248, 0.86));
    box-shadow: var(--theme-shadow-soft);
}

.control-tab-card {
    padding: 0 !important;
    overflow: hidden;
}

.control-tab-toolbar,
.control-tab-panel {
    padding: 1.6rem;
}

.control-tab-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.control-tab-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.control-tabs.tabs {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 72px;
    padding: 0.7rem 0.85rem;
    background: transparent;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.control-tabs.tabs .tab {
    flex: 1 1 0;
    height: auto;
    line-height: normal;
}

.control-tabs.tabs .tab a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin: 0;
    padding: 0.85rem 1rem;
    border-radius: 999px;
    color: var(--control-text-muted) !important;
    font-family: var(--font-display);
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.control-tabs.tabs .tab a:hover,
.control-tabs.tabs .tab a:focus,
.control-tabs.tabs .tab a:focus.active {
    background: rgba(12, 113, 148, 0.08) !important;
    color: var(--control-primary) !important;
}

.control-tabs.tabs .tab a.active {
    background: linear-gradient(135deg, rgba(12, 113, 148, 0.14), rgba(28, 164, 218, 0.18)) !important;
    color: var(--control-primary-strong) !important;
    box-shadow: inset 0 0 0 1px rgba(12, 113, 148, 0.16);
}

.control-tabs.tabs .indicator {
    display: none;
}

.control-tab-panel h2 {
    margin-top: 0;
}

.control-list-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.85rem;
    flex-wrap: wrap;
}

.control-table-actions {
    display: grid;
    justify-items: stretch;
    gap: 0.5rem;
    min-width: 10.75rem;
}

.control-table-actions a {
    white-space: nowrap;
}

.control-table-actions .control-action-link {
    width: 100%;
}

.control-action-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.2rem;
    padding: 0.42rem 0.82rem;
    border-radius: 999px;
    border: 1px solid rgba(12, 113, 148, 0.16);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(240, 246, 248, 0.94));
    color: var(--theme-ink);
    font-weight: 700;
    line-height: 1.1;
    text-decoration: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease;
}

.control-action-link:hover,
.control-action-link:focus,
.control-action-link:focus-visible {
    color: var(--theme-ink);
    text-decoration: none;
    transform: translateY(-1px);
    border-color: rgba(12, 113, 148, 0.28);
    background: linear-gradient(180deg, rgba(245, 251, 253, 0.99), rgba(233, 244, 248, 0.96));
    box-shadow: var(--theme-shadow-soft);
}

.control-action-link.is-accent {
    border-color: rgba(12, 113, 148, 0.22);
    background: linear-gradient(135deg, rgba(12, 113, 148, 0.14), rgba(28, 164, 218, 0.2));
    color: var(--control-primary-strong);
}

.control-action-link.is-accent:hover,
.control-action-link.is-accent:focus,
.control-action-link.is-accent:focus-visible {
    color: var(--control-primary-strong);
    border-color: rgba(12, 113, 148, 0.34);
    background: linear-gradient(135deg, rgba(12, 113, 148, 0.18), rgba(28, 164, 218, 0.26));
}

.control-billing-item-side {
    display: grid;
    justify-items: end;
    gap: 0.6rem;
}

.control-billing-item-meta {
    justify-content: flex-end;
}

.control-record-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.control-switch-form {
    margin: 0;
}

.control-toggle-availability-form.is-loading {
    opacity: 0.7;
    pointer-events: none;
}

.control-switch-form .switch label {
    color: var(--theme-ink);
    font-weight: 600;
}

.control-switch-form .switch label .lever {
    margin: 0 0.65rem;
}

.control-switch-form .switch label input[type="checkbox"]:checked + .lever {
    background-color: rgba(6, 89, 131, 0.3);
}

.control-switch-form .switch label input[type="checkbox"]:checked + .lever::after {
    background-color: var(--theme-blue);
}

.control-status-toggle,
.control-status-toggle:hover,
.control-status-toggle:focus {
    color: var(--theme-white) !important;
}

.control-status-toggle.is-live,
.control-status-toggle.is-live:hover,
.control-status-toggle.is-live:focus {
    background: #2e7d32;
}

.control-status-toggle.is-suspended,
.control-status-toggle.is-suspended:hover,
.control-status-toggle.is-suspended:focus {
    background: #c62828;
}

.control-state-chip {
    margin: 0;
    font-weight: 700;
}

.control-state-chip.is-demo {
    background: rgba(214, 164, 42, 0.18);
    color: #8a6100;
}

.control-state-chip.is-cancelled {
    background: rgba(143, 26, 26, 0.14);
    color: #7a1a1a;
}

.control-key-value {
    display: inline-block;
    max-width: 100%;
    font-family: var(--font-display);
    letter-spacing: 0.08em;
    word-break: break-all;
    overflow-wrap: anywhere;
}

.control-hash-value {
    display: inline-block;
    max-width: 100%;
    font-family: var(--font-display);
    font-size: 0.92rem;
    letter-spacing: 0.04em;
    word-break: break-all;
    overflow-wrap: anywhere;
    vertical-align: top;
}

.control-code-block {
    margin: 0;
    padding: 1rem 1.1rem;
    border-radius: 20px;
    background: #041b28;
    color: #e7f4fa;
    font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
    font-size: 0.85rem;
    line-height: 1.6;
    white-space: pre-wrap;
    word-break: break-word;
    overflow-wrap: anywhere;
}

.passkey-callout {
    margin: 1.5rem 0;
    padding: 1rem 1.1rem;
    border-radius: 18px;
    background: rgba(12, 113, 148, 0.08);
    color: var(--ink-strong);
}

.passkey-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    margin-top: 1.2rem;
}

.passkey-status {
    min-height: 1.5rem;
    margin-top: 1rem;
    color: var(--ink-muted);
}

.passkey-status[data-level="success"] {
    color: #0d7d3b;
}

.passkey-status[data-level="error"] {
    color: #b3261e;
}

.control-passkey-collection {
    border: 1px solid rgba(4, 27, 40, 0.08);
    border-radius: 20px;
}

.control-passkey-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.control-code-block code {
    font-family: inherit;
}

.control-ajax-panel {
    position: relative;
    min-height: 240px;
    opacity: 1;
    transition: opacity 750ms ease;
    will-change: opacity;
}

.control-main-column.is-fading-out,
.control-ajax-panel.is-fading-out,
.control-main-column.is-fading-in,
.control-ajax-panel.is-fading-in {
    opacity: 0;
}

.control-page-loader {
    position: absolute;
    inset: 0;
    z-index: 40;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    border-radius: 28px;
    background: rgba(248, 250, 248, 0.82);
    backdrop-filter: blur(8px);
}

.control-title-loader {
    position: absolute;
    inset: 0;
    z-index: 35;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.75rem;
    padding: 0.55rem 0.85rem;
    border-radius: 20px;
    background: rgba(248, 250, 248, 0.8);
    backdrop-filter: blur(6px);
    pointer-events: none;
}

.control-title-loader p {
    margin: 0;
    color: rgba(8, 34, 51, 0.72);
    font-weight: 500;
}

.control-panel-loader {
    position: absolute;
    inset: 0;
    z-index: 30;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    border-radius: 24px;
    background: rgba(248, 250, 248, 0.76);
    backdrop-filter: blur(6px);
}

.control-loader {
    min-height: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.85rem;
    color: rgba(8, 34, 51, 0.7);
}

.control-loader .preloader-wrapper {
    width: 46px;
    height: 46px;
}

.control-page-loader .control-loader .preloader-wrapper {
    width: 56px;
    height: 56px;
}

.control-loader-error {
    min-height: 180px;
}

.portal-card-list.collection {
    margin: 1rem 0 0;
    border: 0;
    background: transparent;
}

.portal-item.collection-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 0;
    border: 0;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
    background: transparent;
}

.portal-item.collection-item:first-child {
    padding-top: 0;
}

.portal-item.collection-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.control-form-stack p {
    margin: 0 0 1rem;
}

.control-form-stack label {
    display: block;
    margin-bottom: 0.35rem;
    font-weight: 600;
    color: var(--theme-ink);
}

.control-form-stack input:not([type="checkbox"]):not([type="radio"]),
.control-form-stack select,
.control-form-stack textarea {
    width: 100%;
    padding: 0.85rem 0.9rem;
    border: 1px solid rgba(8, 34, 51, 0.14);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.92);
    box-sizing: border-box;
}

.control-form-stack textarea {
    min-height: 120px;
    resize: vertical;
}

.control-form-stack .helptext {
    display: block;
    margin-top: 0.3rem;
    color: rgba(8, 34, 51, 0.58);
    font-size: 0.86rem;
}

.control-formset-card {
    margin-bottom: 0.9rem;
    padding: 1rem;
    border-radius: 16px;
    background: rgba(8, 34, 51, 0.03);
}

.control-table-wrap {
    overflow-x: auto;
}

.control-table th {
    font-family: var(--font-display);
}

.control-table.responsive-table {
    min-width: 720px;
}

.control-table td,
.control-table th {
    padding: 0.8rem 0.9rem;
}

.portal-header {
    padding: 1.25rem 0 0;
}

.portal-header-actions {
    display: flex;
    align-items: center;
    gap: 0.9rem;
}

.portal-client-name {
    font-weight: 700;
}

.portal-dashboard-shell {
    display: grid;
    grid-template-columns: minmax(280px, 0.34fr) minmax(0, 1fr);
    gap: 1rem;
    align-items: start;
}

.portal-dashboard-sidebar {
    position: sticky;
    top: 1.5rem;
    display: grid;
    gap: 1.1rem;
    padding: 1.6rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), rgba(243, 248, 246, 0.93));
}

.portal-dashboard-account {
    display: grid;
    gap: 0.32rem;
}

.portal-dashboard-account h1 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 2.6rem);
    line-height: 0.96;
    max-width: 10ch;
}

.portal-dashboard-account p:last-child {
    margin: 0;
    color: rgba(8, 34, 51, 0.62);
    font-size: 1rem;
}

.portal-dashboard-metrics {
    display: grid;
    gap: 0.85rem;
    margin: 0;
}

.portal-dashboard-metric {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.1rem;
    border: 1px solid rgba(8, 34, 51, 0.08);
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(242, 247, 245, 0.94));
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.92), 0 10px 24px rgba(8, 34, 51, 0.04);
}

.portal-dashboard-metric-label {
    color: rgba(8, 34, 51, 0.62);
    font-weight: 700;
}

.portal-dashboard-metric-value {
    font-family: var(--font-display);
    font-size: 1.55rem;
    line-height: 1;
    letter-spacing: -0.04em;
    color: var(--theme-ink);
}

.portal-dashboard-metric-value-mode {
    display: inline-flex;
    align-items: center;
    padding: 0.38rem 0.82rem;
    border-radius: 999px;
    background: rgba(12, 113, 148, 0.1);
    color: var(--theme-blue);
    font-family: var(--font-body);
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0;
}

.portal-dashboard-note {
    padding: 1rem;
    border-radius: 20px;
    background: linear-gradient(180deg, rgba(238, 245, 249, 0.97), rgba(245, 249, 247, 0.95));
    border: 1px solid rgba(12, 113, 148, 0.12);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.portal-dashboard-nav.collection {
    margin: 0;
    border: 1px solid rgba(8, 34, 51, 0.08);
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(243, 248, 246, 0.95));
    box-shadow: 0 12px 28px rgba(8, 34, 51, 0.05), inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

a.portal-dashboard-nav-link.collection-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.9rem;
    padding: 1rem 1.1rem;
    border-bottom: 1px solid rgba(8, 34, 51, 0.06);
    background: transparent;
    color: rgba(8, 34, 51, 0.88) !important;
    font-weight: 700;
    box-shadow: inset 0 0 0 0 transparent;
    transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.portal-dashboard-nav-link.collection-item:last-child {
    border-bottom: 0;
}

.portal-dashboard-nav-main {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
    color: inherit;
}

a.portal-dashboard-nav-link.collection-item .material-icons {
    color: var(--theme-blue);
}

a.portal-dashboard-nav-link.collection-item:hover,
a.portal-dashboard-nav-link.collection-item.is-active {
    background: linear-gradient(180deg, rgba(231, 243, 248, 0.96), rgba(243, 248, 246, 0.96));
    color: var(--theme-ink) !important;
    box-shadow: inset 4px 0 0 var(--theme-blue);
}

a.portal-dashboard-nav-link.collection-item:hover .portal-dashboard-nav-main,
a.portal-dashboard-nav-link.collection-item.is-active .portal-dashboard-nav-main,
a.portal-dashboard-nav-link.collection-item:hover .material-icons,
a.portal-dashboard-nav-link.collection-item.is-active .material-icons {
    color: var(--theme-ink);
}

.portal-nav-badge {
    min-width: 2rem;
    margin-left: auto;
    padding: 0.22rem 0.65rem;
    border-radius: 999px;
    background: rgba(12, 113, 148, 0.09);
    color: var(--theme-blue);
    font-size: 0.82rem;
    font-weight: 700;
    text-align: center;
    flex: 0 0 auto;
    box-shadow: inset 0 0 0 1px rgba(12, 113, 148, 0.1);
}

.portal-nav-badge.is-empty {
    background: rgba(8, 34, 51, 0.06);
    color: rgba(8, 34, 51, 0.56);
    box-shadow: inset 0 0 0 1px rgba(8, 34, 51, 0.06);
}

a.portal-dashboard-nav-link.collection-item.is-active .portal-nav-badge {
    background: linear-gradient(135deg, var(--theme-ink), var(--theme-blue));
    color: var(--theme-white);
    box-shadow: none;
}

.portal-dashboard-main {
    min-width: 0;
}

.portal-ajax-panel {
    position: relative;
    min-height: 320px;
}

.portal-workspace-stack {
    display: grid;
    gap: 1rem;
}

.portal-workspace-card {
    padding: 1.6rem;
}

.portal-workspace-summary {
    margin-top: 1.25rem;
}

.portal-workspace-actions {
    margin-top: 0;
}

.portal-tab-card {
    padding: 0;
    overflow: hidden;
}

.portal-section-tabs.tabs {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-height: 72px;
    padding: 0.7rem 0.85rem;
    background: transparent;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.portal-section-tabs.tabs .tab {
    flex: 1 1 0;
    height: auto;
    line-height: normal;
}

.portal-section-tabs.tabs .tab a {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    margin: 0;
    padding: 0.85rem 1rem;
    border-radius: 999px;
    color: rgba(8, 34, 51, 0.62) !important;
    font-family: var(--font-display);
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.portal-section-tabs.tabs .tab a:hover,
.portal-section-tabs.tabs .tab a:focus,
.portal-section-tabs.tabs .tab a:focus.active {
    background: rgba(12, 113, 148, 0.08) !important;
    color: var(--theme-blue) !important;
}

.portal-section-tabs.tabs .tab a.active {
    background: linear-gradient(135deg, rgba(12, 113, 148, 0.14), rgba(28, 164, 218, 0.18)) !important;
    color: #0a5f7d !important;
    box-shadow: inset 0 0 0 1px rgba(12, 113, 148, 0.16);
}

.portal-section-tabs.tabs .indicator {
    display: none;
}

.portal-tab-panel {
    padding: 1.6rem;
}

.portal-auth,
.portal-panel-section {
    padding: 2rem 0;
}

.portal-auth-card {
    max-width: 560px;
    margin: 0 auto;
}

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

.portal-table-card,
.portal-form-card {
    height: 100%;
}

.portal-card-list {
    display: grid;
    gap: 0.9rem;
}

.portal-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 0;
    border-top: 1px solid rgba(8, 34, 51, 0.08);
}

.portal-item:first-child {
    border-top: 0;
    padding-top: 0;
}

.portal-item h3 {
    margin: 0 0 0.35rem;
    font-size: 1.2rem;
}

.portal-meta {
    justify-content: flex-end;
}

.portal-meta a {
    padding: 0.32rem 0.75rem;
    border-radius: 999px;
    background: rgba(8, 34, 51, 0.06);
    font-weight: 600;
}

.portal-meta a.site-btn,
.portal-meta button.site-btn {
    padding: 0 1rem;
    background: initial;
}

.portal-meta a.site-btn-primary,
.portal-meta button.site-btn-primary,
.control-client-open-link {
    background: linear-gradient(135deg, var(--theme-ink), var(--theme-blue)) !important;
    color: var(--theme-white) !important;
}

.portal-meta a.site-btn-primary:hover,
.portal-meta button.site-btn-primary:hover,
.portal-meta a.site-btn-primary:focus,
.portal-meta button.site-btn-primary:focus,
.control-client-open-link:hover,
.control-client-open-link:focus {
    background: linear-gradient(135deg, var(--theme-blue), var(--theme-cyan)) !important;
}

.portal-meta a.site-btn-secondary,
.portal-meta button.site-btn-secondary {
    background: rgba(255, 255, 255, 0.64) !important;
}

.portal-support-header,
.portal-support-body {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

.portal-support-header h3 {
    margin: 0 0 0.3rem;
    font-size: 1.1rem;
}

.portal-support-header p,
.portal-support-message p {
    margin: 0;
}

.portal-support-body {
    flex-direction: column;
}

.portal-support-message {
    padding-bottom: 0.75rem;
    border-bottom: 1px solid rgba(8, 34, 51, 0.08);
}

.portal-timeline-entry {
    border: 1px solid rgba(8, 34, 51, 0.08);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.76);
}

.portal-policy-card {
    max-width: 760px;
    margin: 0 auto;
}

.compact h2 {
    font-size: 1.8rem;
}

.stacked-panels {
    display: grid;
    gap: 1rem;
}

.empty-state {
    padding: 1.8rem;
}

.toast {
    border: 1px solid rgba(8, 34, 51, 0.1);
    border-left: 4px solid var(--theme-blue);
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(236, 245, 250, 0.98), rgba(246, 250, 248, 0.96));
    color: var(--theme-ink);
    box-shadow: var(--theme-shadow-soft);
    font-weight: 600;
}

.toast-success {
    border-color: rgba(44, 155, 125, 0.24);
    border-left-color: var(--theme-green);
    background: linear-gradient(180deg, rgba(225, 245, 236, 0.98), rgba(243, 249, 246, 0.96));
    color: #12382d;
}

.toast-error {
    border-color: rgba(180, 85, 85, 0.24);
    border-left-color: #b45555;
    background: linear-gradient(180deg, rgba(251, 232, 232, 0.98), rgba(253, 244, 244, 0.96));
    color: #5f2626;
}

.toast-warning {
    border-color: rgba(185, 135, 47, 0.24);
    border-left-color: #b9872f;
    background: linear-gradient(180deg, rgba(252, 242, 220, 0.98), rgba(254, 248, 237, 0.96));
    color: #5b4314;
}

.js-ready [data-reveal] {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 420ms ease, transform 420ms ease;
}

.js-ready [data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

@media only screen and (max-width: 992px) {
    :root {
        --nav-height: 92px;
        --floating-logo-size: 126px;
    }

    .hero-grid,
    .contact-layout,
    .footer-grid,
    .legal-layout,
    .portal-dashboard-shell,
    .portal-grid,
    .two-column {
        grid-template-columns: 1fr;
    }

    .stats-grid,
    .card-grid.three-up,
    .process-grid,
    .portal-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .nav-shell,
    .portal-shell {
        min-height: 84px;
    }

    .control-shell {
        width: min(1180px, 94vw);
        padding-top: 1rem;
    }

    .control-side-panel {
        position: static;
        margin-bottom: 1rem;
    }

    .portal-dashboard-sidebar {
        position: static;
    }

    .portal-dashboard-nav.collection {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .portal-dashboard-nav-link.collection-item {
        border-right: 1px solid rgba(8, 34, 51, 0.08);
    }

    .portal-dashboard-nav-link.collection-item:nth-child(2n) {
        border-right: 0;
    }

    .portal-legal-review-nav.collection {
        display: block;
    }

    .portal-legal-review-nav .portal-dashboard-nav-link.collection-item {
        border-right: 0;
    }

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

    .nav-shell {
        padding-left: calc(var(--floating-logo-size) + 1.2rem);
    }

    .brand-lockup img {
        width: 64px;
        height: 64px;
    }
}

@media only screen and (max-width: 600px) {
    :root {
        --nav-height: 80px;
        --floating-logo-size: 120px;
    }

    .hero-section,
    .page-hero {
        padding-top: 3.5rem;
    }

    .error-page-main {
        display: block;
        min-height: auto;
    }

    .stats-grid,
    .card-grid.three-up,
    .process-grid,
    .portal-summary {
        grid-template-columns: 1fr;
    }

    .hero-actions,
    .section-actions,
    .portal-header-actions,
    .portal-item {
        flex-direction: column;
        align-items: flex-start;
    }

    .portal-legal-review-document-header,
    .portal-legal-review-document-tools {
        flex-direction: column;
        align-items: flex-start;
    }

    .control-header-middle,
    .control-header-actions,
    .control-inline-actions,
    .control-tab-toolbar,
    .control-tab-heading {
        flex-direction: column;
        align-items: flex-start;
    }

    .control-chart-grid {
        grid-template-columns: 1fr;
    }

    .legal-sidebar {
        position: static;
    }

    .site-btn {
        width: 100%;
    }

    .hero-title,
    .page-hero h1,
    .work-title {
        font-size: clamp(2.4rem, 10vw, 3.4rem);
    }

    .surface-card,
    .plan-card,
    .process-card,
    .portal-auth-card,
    .portal-table-card,
    .portal-form-card,
    .portal-policy-card {
        padding: 1.2rem;
    }

    .error-page-meta {
        flex-direction: column;
    }

    .error-page-meta a {
        width: 100%;
        justify-content: center;
    }

    .portal-meta {
        justify-content: flex-start;
    }

    .control-billing-item-side {
        width: 100%;
        justify-items: start;
    }

    .control-billing-item-meta,
    .control-record-actions {
        justify-content: flex-start;
    }

    .portal-section-tabs.tabs {
        flex-direction: column;
        align-items: stretch;
    }

    .portal-legal-review-document-hero,
    .portal-legal-review-document-body,
    .portal-legal-review-footer {
        padding-left: 1.2rem;
        padding-right: 1.2rem;
    }

    .portal-dashboard-nav.collection {
        grid-template-columns: 1fr;
    }

    .portal-dashboard-nav-link.collection-item {
        border-right: 0;
    }

    .nav-shell {
        padding-left: calc(var(--floating-logo-size) + 0.9rem);
    }

    .control-shell {
        width: 94vw;
    }

    .control-header-panel,
    .portal-table-card.card-panel,
    .portal-form-card.card-panel {
        padding: 1.2rem;
    }
}
