.cylc {
    --cylc-navy: #06243f;
    --cylc-navy-2: #103a60;
    --cylc-gold: #c9a227;
    --cylc-gold-soft: #fff6d8;
    --cylc-text: #102033;
    --cylc-muted: #58677a;
    --cylc-border: #dce5ef;
    --cylc-surface: #ffffff;
    --cylc-wash: #f4f8fc;
    --cylc-wash-2: #eaf2fb;
    --cylc-success: #166534;
    --cylc-danger: #991b1b;
    --cylc-shadow: 0 14px 34px rgba(6, 36, 63, 0.12);
    color: var(--cylc-text);
    font-family: "Source Sans 3", "Source Sans Pro", "Inter", "Segoe UI", sans-serif;
    font-size: 16px;
    line-height: 1.55;
}

.cylc *,
.cylc *::before,
.cylc *::after {
    box-sizing: border-box;
}

.cylc [hidden] {
    display: none !important;
}

.cylc__inner {
    width: min(1180px, 92%);
    margin: 0 auto;
    padding: 42px 0 56px;
}

.cylc h1,
.cylc h2,
.cylc h3 {
    margin: 0;
    color: inherit;
    font-family: "Playfair Display", Georgia, serif;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.15;
}

.cylc p {
    margin: 0;
}

.cylc a {
    color: inherit;
}

.cylc-hero {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 28px;
    align-items: stretch;
    margin-bottom: 26px;
    padding: clamp(26px, 4vw, 48px);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgba(201, 162, 39, 0.18) 0%, rgba(201, 162, 39, 0) 34%),
        linear-gradient(135deg, var(--cylc-navy) 0%, var(--cylc-navy-2) 100%);
    color: #ffffff;
    box-shadow: var(--cylc-shadow);
}

.cylc-hero__copy {
    display: grid;
    gap: 16px;
    align-content: center;
}

.cylc-kicker {
    width: fit-content;
    padding: 7px 10px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    border-radius: 999px;
    color: #f7e8a5;
    font-size: 0.86rem;
    font-weight: 700;
}

.cylc-hero h1 {
    max-width: 760px;
    color: #ffffff;
    font-size: clamp(2rem, 5vw, 4.15rem);
}

.cylc-hero-title {
    max-width: 840px;
    color: #ffffff;
    font-family: "Source Sans 3", "Source Sans Pro", "Inter", "Segoe UI", sans-serif;
    font-size: clamp(2.2rem, 5vw, 4.4rem);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 1;
}

.cylc-hero p {
    max-width: 680px;
    color: rgba(255, 255, 255, 0.88);
    font-size: clamp(1rem, 2vw, 1.22rem);
}

.cylc-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cylc-badges span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 6px 12px;
    border: 1px solid rgba(201, 162, 39, 0.66);
    border-radius: 999px;
    background: rgba(201, 162, 39, 0.16);
    color: #fff4c6;
    font-weight: 800;
}

.cylc-hero__panel {
    display: grid;
    gap: 10px;
    align-content: center;
    padding: 20px;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.1);
}

.cylc-hero__panel strong {
    color: #ffffff;
    font-family: "Playfair Display", Georgia, serif;
    font-size: 1.35rem;
}

.cylc-hero__panel span,
.cylc-hero__panel a {
    color: rgba(255, 255, 255, 0.86);
}

.cylc-tool-grid,
.cylc-checklist__grid {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: 22px;
    align-items: start;
}

.cylc-panel {
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: var(--cylc-surface);
    box-shadow: 0 8px 22px rgba(16, 32, 51, 0.07);
}

.cylc-panel--input,
.cylc-panel--results,
.cylc-panel--schedule,
.cylc-checklist .cylc-panel {
    padding: clamp(18px, 3vw, 26px);
}

.cylc-panel--schedule,
.cylc-checklist,
.cylc-video,
.cylc-cta,
.cylc-contact,
.cylc-disclaimer {
    margin-top: 24px;
}

.cylc-panel__heading {
    display: grid;
    gap: 7px;
    margin-bottom: 18px;
}

.cylc-panel__heading--row {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
}

.cylc-panel__heading h2,
.cylc-section-heading h2 {
    color: var(--cylc-navy);
    font-size: clamp(1.35rem, 3vw, 2rem);
}

.cylc-panel__heading h3,
.cylc-checklist h3 {
    color: var(--cylc-navy);
    font-size: 1.3rem;
}

.cylc-panel__heading p,
.cylc-note,
.cylc-disclaimer {
    color: var(--cylc-muted);
}

.cylc-form {
    display: grid;
    gap: 16px;
}

.cylc-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.cylc-fields--single {
    grid-template-columns: 1fr;
}

.cylc-field,
.cylc-currency {
    display: grid;
    gap: 7px;
}

.cylc-field small {
    color: var(--cylc-muted);
    font-size: 0.84rem;
    line-height: 1.35;
}

.cylc-field span,
.cylc-currency span,
.cylc-radio-group legend,
.cylc-segmented legend {
    color: var(--cylc-text);
    font-size: 0.92rem;
    font-weight: 800;
}

.cylc input[type="text"],
.cylc input[type="number"],
.cylc input[type="date"],
.cylc input[type="email"],
.cylc input[type="url"],
.cylc select {
    width: 100%;
    min-height: 44px;
    padding: 10px 12px;
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: #ffffff;
    color: var(--cylc-text);
    font: inherit;
}

.cylc input:focus,
.cylc select:focus,
.cylc button:focus,
.cylc a:focus {
    outline: 3px solid rgba(201, 162, 39, 0.32);
    outline-offset: 2px;
}

.cylc-radio-group,
.cylc-segmented {
    min-width: 0;
    margin: 0;
    padding: 0;
    border: 0;
}

.cylc-radio-group {
    display: grid;
    gap: 8px;
}

.cylc-radio-group label {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 32px;
    color: var(--cylc-muted);
    font-weight: 700;
}

.cylc-radio-group input,
.cylc-segmented input {
    accent-color: var(--cylc-gold);
}

.cylc-segmented {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.cylc-segmented legend {
    grid-column: 1 / -1;
}

.cylc-segmented label {
    position: relative;
}

.cylc-segmented input {
    position: absolute;
    inset: 0;
    opacity: 0;
}

.cylc-segmented span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 8px 10px;
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: var(--cylc-wash);
    color: var(--cylc-navy);
    font-weight: 800;
    text-align: center;
}

.cylc-segmented input:checked + span {
    border-color: var(--cylc-gold);
    background: var(--cylc-gold-soft);
    color: var(--cylc-navy);
}

.cylc-entity,
.cylc-currency {
    padding: 10px 12px;
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: var(--cylc-wash);
    color: var(--cylc-navy);
    font-weight: 800;
}

.cylc-currency strong {
    color: var(--cylc-navy);
    font-size: 1.25rem;
}

.cylc-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 11px 18px;
    border: 1px solid var(--cylc-gold);
    border-radius: 8px;
    background: var(--cylc-gold);
    color: var(--cylc-navy);
    font: inherit;
    font-weight: 900;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}

.cylc-button:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(201, 162, 39, 0.24);
}

.cylc-button:disabled {
    cursor: not-allowed;
    opacity: 0.55;
    transform: none;
    box-shadow: none;
}

.cylc-button--secondary {
    border-color: var(--cylc-border);
    background: #ffffff;
    color: var(--cylc-navy);
}

.cylc-button--wide {
    width: 100%;
}

.cylc-errors {
    padding: 12px 14px;
    border: 1px solid #fecaca;
    border-radius: 8px;
    background: #fff1f2;
    color: var(--cylc-danger);
    font-weight: 700;
}

.cylc-errors ul {
    margin: 0;
    padding-left: 20px;
}

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

.cylc-results--compact {
    grid-template-columns: 1fr;
}

.cylc-results div {
    min-width: 0;
    padding: 14px;
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: var(--cylc-wash);
}

.cylc-results dt {
    margin: 0 0 6px;
    color: var(--cylc-muted);
    font-size: 0.88rem;
    font-weight: 800;
}

.cylc-results dd {
    margin: 0;
    color: var(--cylc-navy);
    font-size: 1.28rem;
    font-weight: 900;
    overflow-wrap: anywhere;
}

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

.cylc-table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
    background: #ffffff;
}

.cylc-table th,
.cylc-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--cylc-border);
    color: var(--cylc-text);
    text-align: left;
    white-space: nowrap;
}

.cylc-table th {
    background: var(--cylc-navy);
    color: #ffffff;
    font-weight: 900;
}

.cylc-table tbody tr:nth-child(even) {
    background: var(--cylc-wash);
}

.cylc-note {
    margin-top: 12px;
    font-size: 0.95rem;
}

.cylc-video {
    display: grid;
    gap: 16px;
    padding: clamp(18px, 3vw, 26px);
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 8px 22px rgba(16, 32, 51, 0.07);
}

.cylc-section-heading {
    display: grid;
    gap: 7px;
}

.cylc-section-heading p {
    color: var(--cylc-muted);
}

.cylc-video__frame {
    position: relative;
    overflow: hidden;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    background: var(--cylc-navy);
}

.cylc-video__frame iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.cylc-video__fallback {
    display: grid;
    min-height: 220px;
    place-items: center;
    padding: 20px;
    color: #ffffff;
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.cylc-checklist {
    display: grid;
    gap: 18px;
}

.cylc-list {
    display: grid;
    gap: 9px;
    margin: 14px 0 0;
    padding: 0;
    list-style: none;
}

.cylc-list li {
    position: relative;
    padding-left: 24px;
    color: var(--cylc-text);
}

.cylc-list li::before {
    position: absolute;
    left: 0;
    top: 0.05em;
    font-weight: 900;
}

.cylc-list--covered li::before {
    content: "+";
    color: var(--cylc-success);
}

.cylc-list--complex li::before {
    content: "!";
    color: var(--cylc-danger);
}

.cylc-callout,
.cylc-cta,
.cylc-contact {
    border-radius: 8px;
}

.cylc-callout {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 14px;
    align-items: center;
    justify-content: space-between;
    padding: 18px 20px;
    border: 1px solid rgba(201, 162, 39, 0.5);
    background: var(--cylc-gold-soft);
    color: var(--cylc-navy);
}

.cylc-callout strong {
    font-weight: 900;
}

.cylc-cta,
.cylc-contact {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 22px;
    align-items: center;
    padding: clamp(20px, 3vw, 28px);
    border: 1px solid var(--cylc-border);
    background: var(--cylc-wash-2);
}

.cylc-cta h2,
.cylc-contact h2 {
    margin-bottom: 10px;
    color: var(--cylc-navy);
    font-size: clamp(1.35rem, 3vw, 2rem);
}

.cylc-cta p,
.cylc-contact p {
    color: var(--cylc-muted);
}

.cylc-cta p + p {
    margin-top: 8px;
}

.cylc-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-end;
}

.cylc-contact dl {
    display: grid;
    gap: 8px;
    margin: 16px 0 0;
}

.cylc-contact dl div {
    display: grid;
    grid-template-columns: 100px minmax(0, 1fr);
    gap: 10px;
}

.cylc-contact dt,
.cylc-contact dd {
    margin: 0;
}

.cylc-contact dt {
    color: var(--cylc-muted);
    font-weight: 900;
}

.cylc-contact dd {
    color: var(--cylc-navy);
    font-weight: 800;
    overflow-wrap: anywhere;
}

.cylc-disclaimer {
    padding: 14px 16px;
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: #ffffff;
    font-size: 0.95rem;
}

.cylc-widget {
    display: grid;
    gap: 14px;
    max-width: 460px;
    padding: 18px;
    border: 1px solid var(--cylc-border);
    border-radius: 8px;
    background: #ffffff;
    box-shadow: 0 10px 26px rgba(6, 36, 63, 0.1);
}

.cylc-widget__heading {
    display: grid;
    gap: 5px;
}

.cylc-widget__heading h2 {
    color: var(--cylc-navy);
    font-size: 1.65rem;
}

.cylc-widget__heading p {
    color: var(--cylc-muted);
}

.cylc-widget .cylc-panel {
    box-shadow: none;
}

.cylc-widget .cylc-panel--input,
.cylc-widget .cylc-panel--results {
    padding: 14px;
}

.cylc-widget__links {
    display: grid;
    gap: 8px;
}

.cylc-widget__links a {
    color: var(--cylc-navy);
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 3px;
}

@media (max-width: 980px) {
    .cylc-hero,
    .cylc-tool-grid,
    .cylc-checklist__grid,
    .cylc-cta,
    .cylc-contact {
        grid-template-columns: 1fr;
    }

    .cylc-panel__heading--row {
        grid-template-columns: 1fr;
    }

    .cylc-actions {
        justify-content: flex-start;
    }

    .cylc-hero__panel {
        max-width: 520px;
    }
}

@media (max-width: 680px) {
    .cylc__inner {
        width: min(100% - 24px, 1180px);
        padding: 24px 0 36px;
    }

    .cylc-hero {
        padding: 22px;
    }

    .cylc-fields,
    .cylc-results,
    .cylc-segmented {
        grid-template-columns: 1fr;
    }

    .cylc-panel--input,
    .cylc-panel--results,
    .cylc-panel--schedule,
    .cylc-checklist .cylc-panel,
    .cylc-cta,
    .cylc-contact {
        padding: 16px;
    }

    .cylc-contact dl div {
        grid-template-columns: 1fr;
        gap: 2px;
    }

    .cylc-button {
        width: 100%;
    }
}

/* Version 1.0.2 page polish for the dedicated calculator page. */
.cylc--full {
    background:
        linear-gradient(180deg, #f7fafc 0%, #eef4fb 42%, #f8fafc 100%);
}

.cylc--full .cylc__inner {
    width: min(1240px, calc(100% - 40px));
    padding: clamp(28px, 4vw, 58px) 0 clamp(42px, 5vw, 72px);
}

.cylc--full .cylc-hero {
    position: relative;
    overflow: hidden;
    grid-template-columns: minmax(0, 1.55fr) minmax(280px, 0.95fr);
    gap: clamp(24px, 4vw, 46px);
    min-height: auto;
    margin-bottom: 28px;
    padding: clamp(30px, 5vw, 56px);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 18px;
    background:
        linear-gradient(135deg, rgba(201, 162, 39, 0.25) 0%, rgba(201, 162, 39, 0) 38%),
        linear-gradient(145deg, #061b31 0%, #08365c 52%, #0d5f73 100%);
    box-shadow: 0 24px 60px rgba(6, 36, 63, 0.22);
}

.cylc--full .cylc-hero::before {
    content: "";
    position: absolute;
    left: -10%;
    top: -40%;
    width: clamp(280px, 40vw, 520px);
    height: clamp(280px, 40vw, 520px);
    background: radial-gradient(circle, rgba(201, 162, 39, 0.18), rgba(201, 162, 39, 0) 70%);
    pointer-events: none;
}

.cylc-hero__facts {
    display: grid;
    gap: 11px;
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
}

.cylc-hero__facts li {
    position: relative;
    padding-left: 28px;
    color: rgba(255, 255, 255, 0.92);
    font-weight: 600;
}

.cylc-hero__facts li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.18em;
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23061b31' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center / 12px no-repeat,
        var(--cylc-gold);
}

.cylc--full .cylc-hero::after {
    content: "";
    position: absolute;
    right: clamp(18px, 4vw, 56px);
    bottom: clamp(18px, 3vw, 44px);
    width: clamp(220px, 32vw, 420px);
    height: clamp(220px, 32vw, 420px);
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    pointer-events: none;
}

.cylc--full .cylc-hero__copy,
.cylc--full .cylc-hero__panel {
    position: relative;
    z-index: 1;
}

.cylc--full .cylc-hero__copy {
    max-width: 900px;
    gap: 14px;
    align-content: center;
}

.cylc--full .cylc-kicker {
    min-height: 34px;
    border-color: rgba(255, 255, 255, 0.24);
    background: rgba(255, 255, 255, 0.1);
    color: #ffe9a6;
}

.cylc--full .cylc-hero h1 {
    max-width: 820px;
    font-family: "Source Sans 3", "Inter", "Segoe UI", sans-serif;
    font-size: clamp(2.35rem, 6vw, 5.25rem);
    font-weight: 900;
    letter-spacing: 0;
    line-height: 0.98;
}

.cylc--full .cylc-hero-title {
    max-width: 900px;
    font-size: clamp(2.25rem, 5.4vw, 4.65rem);
}

.cylc--full .cylc-hero p {
    max-width: 650px;
    font-size: clamp(1.08rem, 2vw, 1.34rem);
}

.cylc--full .cylc-badges span {
    min-height: 38px;
    padding: 7px 14px;
    border-color: rgba(255, 229, 145, 0.58);
    background: rgba(255, 229, 145, 0.16);
}

.cylc--full .cylc-hero__panel {
    align-self: stretch;
    min-height: 250px;
    padding: clamp(20px, 3vw, 30px);
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.1);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18);
    backdrop-filter: blur(8px);
}

.cylc--full .cylc-hero__panel strong {
    font-family: "Source Sans 3", "Inter", "Segoe UI", sans-serif;
    font-size: clamp(1.5rem, 2.4vw, 2rem);
    font-weight: 900;
}

.cylc--full .cylc-video,
.cylc--full .cylc-panel,
.cylc--full .cylc-cta,
.cylc--full .cylc-contact,
.cylc--full .cylc-disclaimer {
    border-color: rgba(15, 23, 42, 0.08);
    border-radius: 14px;
    box-shadow: 0 16px 36px rgba(15, 23, 42, 0.09);
}

.cylc--full .cylc-video {
    grid-template-columns: minmax(250px, 360px) minmax(0, 1fr);
    align-items: center;
    padding: clamp(18px, 2.8vw, 28px);
    background: linear-gradient(145deg, #ffffff 0%, #f5f9fd 100%);
}

.cylc--full .cylc-video__frame {
    min-height: 280px;
    box-shadow: 0 14px 30px rgba(6, 36, 63, 0.14);
}

.cylc--full .cylc-tool-grid {
    grid-template-columns: minmax(360px, 480px) minmax(0, 1fr);
    gap: 26px;
    margin-top: 28px;
}

.cylc--full .cylc-tool-grid:has(.cylc-panel--results[hidden]) {
    grid-template-columns: 1fr;
}

.cylc--full .cylc-tool-grid:has(.cylc-panel--results[hidden]) .cylc-panel--input {
    max-width: none;
    margin-inline: 0;
}

.cylc--full .cylc-panel--input {
    background: #ffffff;
}

.cylc--full .cylc-panel__heading {
    margin-bottom: 20px;
}

.cylc--full .cylc-panel__heading h2,
.cylc--full .cylc-section-heading h2 {
    font-family: "Source Sans 3", "Inter", "Segoe UI", sans-serif;
    font-size: clamp(1.35rem, 2.5vw, 2.05rem);
    font-weight: 900;
}

.cylc--full .cylc-fields {
    gap: 16px;
}

.cylc--full .cylc-field span,
.cylc--full .cylc-currency span,
.cylc--full .cylc-radio-group legend,
.cylc--full .cylc-segmented legend {
    font-size: 0.95rem;
}

.cylc--full input[type="text"],
.cylc--full input[type="number"],
.cylc--full input[type="date"],
.cylc--full input[type="email"],
.cylc--full input[type="url"],
.cylc--full select {
    min-height: 48px;
    border-color: rgba(15, 23, 42, 0.15);
    background: #f8fafc;
}

.cylc--full .cylc-segmented span,
.cylc--full .cylc-entity,
.cylc--full .cylc-currency {
    border-color: rgba(15, 23, 42, 0.12);
    background: #f8fafc;
}

.cylc--full .cylc-segmented input:checked + span {
    border-color: rgba(201, 162, 39, 0.75);
    background: #fff3c4;
}

.cylc--full .cylc-button {
    min-height: 48px;
    border-radius: 10px;
    box-shadow: 0 8px 18px rgba(201, 162, 39, 0.18);
}

.cylc--full .cylc-button--secondary {
    box-shadow: none;
}

.cylc--full .cylc-results {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.cylc--full .cylc-results div {
    border-color: rgba(15, 23, 42, 0.08);
    background: linear-gradient(180deg, #ffffff 0%, #f4f8fc 100%);
}

.cylc--full .cylc-results dd {
    font-size: clamp(1.2rem, 2.2vw, 1.58rem);
}

.cylc--full .cylc-panel--schedule {
    background: #ffffff;
}

.cylc--full .cylc-table-wrap {
    border-color: rgba(15, 23, 42, 0.1);
}

.cylc--full .cylc-table th {
    background: #08243f;
}

.cylc--full .cylc-checklist {
    margin-top: 30px;
}

.cylc--full .cylc-checklist__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    align-items: stretch;
}

.cylc--full .cylc-checklist .cylc-panel {
    display: flex;
    flex-direction: column;
    background: #ffffff;
}

.cylc--full .cylc-list {
    gap: 10px;
}

.cylc--full .cylc-list li {
    padding-left: 28px;
}

.cylc--full .cylc-list li::before {
    display: inline-grid;
    width: 18px;
    height: 18px;
    place-items: center;
    border-radius: 999px;
    background: #ecfdf5;
    font-size: 0.8rem;
    line-height: 1;
}

.cylc--full .cylc-list--complex li::before {
    background: #fff1f2;
}

.cylc--full .cylc-callout {
    border-radius: 12px;
    background: #fff7d6;
}

.cylc--full .cylc-cta {
    align-items: stretch;
    background:
        linear-gradient(135deg, rgba(201, 162, 39, 0.15), rgba(201, 162, 39, 0)),
        linear-gradient(145deg, #eaf4ff 0%, #f7fbff 100%);
}

.cylc--full .cylc-contact {
    background: linear-gradient(145deg, #ffffff 0%, #edf6ff 100%);
}

.cylc--full .cylc-actions {
    align-content: center;
}

.cylc--full .cylc-contact .cylc-actions {
    max-width: 520px;
}

.cylc--full .cylc-disclaimer {
    margin-top: 32px;
    background: #ffffff;
}

@media (min-width: 980px) {
    .cylc--full .cylc-results {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .cylc--full .cylc-hero,
    .cylc--full .cylc-video,
    .cylc--full .cylc-tool-grid,
    .cylc--full .cylc-checklist__grid {
        grid-template-columns: 1fr;
    }

    .cylc--full .cylc-hero {
        min-height: auto;
    }

    .cylc--full .cylc-tool-grid:has(.cylc-panel--results[hidden]) .cylc-panel--input {
        max-width: none;
    }
}

@media (max-width: 680px) {
    .cylc--full .cylc__inner {
        width: min(100% - 24px, 1240px);
    }

    .cylc--full .cylc-hero h1 {
        font-size: clamp(2rem, 12vw, 3.25rem);
    }

    .cylc--full .cylc-hero-title {
        font-size: clamp(2rem, 11vw, 3.2rem);
    }

    .cylc--full .cylc-video__frame {
        min-height: 190px;
    }

    .cylc--full .cylc-results,
    .cylc--full .cylc-fields {
        grid-template-columns: 1fr;
    }
}

/* Version 1.0.6 — refined results, schedule and CTA polish. */
.cylc--full .cylc-results div {
    position: relative;
    overflow: hidden;
    padding: 16px 16px 16px 18px;
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.cylc--full .cylc-results div::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, var(--cylc-gold), var(--cylc-navy-2));
    opacity: 0.85;
}

.cylc--full .cylc-results div:hover {
    transform: translateY(-2px);
    border-color: rgba(201, 162, 39, 0.45);
    box-shadow: 0 10px 24px rgba(6, 36, 63, 0.12);
}

.cylc--full .cylc-results dt {
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-size: 0.78rem;
}

.cylc--full .cylc-panel--results .cylc-panel__heading h2 {
    display: flex;
    align-items: center;
    gap: 10px;
}

.cylc--full .cylc-panel--results .cylc-panel__heading h2::before {
    content: "";
    width: 26px;
    height: 26px;
    flex: 0 0 26px;
    border-radius: 7px;
    background:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='12' y1='20' x2='12' y2='10'/%3E%3Cline x1='18' y1='20' x2='18' y2='4'/%3E%3Cline x1='6' y1='20' x2='6' y2='16'/%3E%3C/svg%3E") center / 16px no-repeat,
        linear-gradient(145deg, var(--cylc-navy), var(--cylc-navy-2));
}

.cylc--full .cylc-panel--schedule {
    position: relative;
}

.cylc--full .cylc-panel__heading--row .cylc-button {
    box-shadow: 0 10px 22px rgba(201, 162, 39, 0.26);
}

.cylc--full .cylc-table thead th {
    background: linear-gradient(145deg, #08243f 0%, #0d3a5a 100%);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    font-size: 0.82rem;
}

.cylc--full .cylc-table tbody tr {
    transition: background 140ms ease;
}

.cylc--full .cylc-table tbody tr:hover {
    background: var(--cylc-gold-soft);
}

.cylc--full .cylc-table td:nth-child(n + 3) {
    font-variant-numeric: tabular-nums;
    text-align: right;
}

.cylc--full .cylc-table th:nth-child(n + 3) {
    text-align: right;
}

.cylc--full .cylc-panel {
    transition: box-shadow 200ms ease;
}

.cylc--full .cylc-panel--input:focus-within {
    box-shadow: 0 18px 40px rgba(6, 36, 63, 0.14);
}

.cylc--full .cylc-button--wide[type="submit"] {
    background: linear-gradient(135deg, #d9b441 0%, #c9a227 100%);
    letter-spacing: 0.02em;
}

@media (max-width: 980px) {
    .cylc--full .cylc-hero__panel {
        min-height: auto;
    }
}
