      @import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&display=swap");

      :root {
        --off-white: #faf8f4;
        --charcoal: #1c1c1c;
        --rust: #9f3c24;
        --soft-gray: #545454;
        --line: #e1ddd7;
        --card: #fefcf8;
        --question-card-width: 900px;
      }

      * {
        box-sizing: border-box;
      }

      html {
        scroll-behavior: smooth;
      }

      body {
        margin: 0;
        font-family: "Montserrat", sans-serif;
        color: var(--charcoal);
        background: var(--off-white);
        line-height: 1.5;
      }

      .wrap {
        max-width: 1180px;
        margin: 0 auto;
      }

      .hero {
        min-height: 100vh;
        max-width: var(--question-card-width);
        margin: 0 auto;
        padding: 0.8rem 0;
        display: grid;
        grid-template-columns: minmax(260px, 1fr) minmax(260px, 1fr);
        gap: 1.2rem;
        align-items: center;
      }

      .badge {
        display: inline-block;
        margin-bottom: 1rem;
        border: 1px solid var(--line);
        border-radius: 999px;
        padding: 0.28rem 0.72rem;
        font-size: 0.68rem;
        letter-spacing: 0.08em;
        color: var(--soft-gray);
        text-transform: uppercase;
      }

      .eyebrow {
        margin: 0;
        font-size: 0.72rem;
        letter-spacing: 0.22em;
        color: var(--rust);
        text-transform: uppercase;
      }

      .hero h1 {
        margin: 0.7rem 0 0;
        font-size: clamp(2.6rem, 6.3vw, 4.7rem);
        letter-spacing: -0.035em;
        line-height: 0.94;
        text-transform: lowercase;
        font-weight: 500;
      }

      .hero-copy {
        margin-top: 1.4rem;
        color: var(--soft-gray);
        max-width: 700px;
      }

      .hero-actions {
        margin-top: 1.5rem;
        display: flex;
        align-items: center;
        gap: 1rem;
        flex-wrap: wrap;
      }

      .ghost-note {
        color: var(--soft-gray);
        font-size: 0.84rem;
      }

      .motif {
        justify-self: center;
        width: min(460px, 100%);
        aspect-ratio: 1 / 1;
        border-radius: 50%;
        border: 1px solid #e5dfd8;
        position: relative;
      }

      .motif::before,
      .motif::after {
        content: "";
        position: absolute;
        inset: 9%;
        border-radius: 50%;
        border: 1px solid #ede8e1;
      }

      .motif::after {
        inset: 24%;
      }

      .motif-center {
        position: absolute;
        left: 50%;
        top: 50%;
        width: 14px;
        height: 14px;
        background: var(--rust);
        border-radius: 50%;
        transform: translate(-50%, -50%);
        box-shadow: 0 0 0 8px rgba(159, 60, 36, 0.08);
      }

      .motif-line {
        position: absolute;
        left: 50%;
        top: 10%;
        bottom: 10%;
        width: 1px;
        background: linear-gradient(to bottom, transparent, #d4c9bd 22%, #d4c9bd 78%, transparent);
        transform: translateX(-50%);
      }

      .section-divider {
        border: 0;
        border-top: 1px solid #e8e3dc;
        margin: 0;
      }

      .questionnaire {
        padding: 1.9rem 3.1rem 3.6rem;
        max-width: 1220px;
        margin: 0 auto;
        min-height: 100vh;
        display: flex;
        flex-direction: column;
        justify-content: center;
      }

      .progress-row {
        display: grid;
        grid-template-columns: 260px 1fr auto;
        gap: 1rem;
        align-items: center;
        margin-bottom: 1.5rem;
        max-width: var(--question-card-width);
        width: 100%;
        margin-left: auto;
        margin-right: auto;
      }

      .progress-meta {
        font-size: 0.86rem;
        color: var(--soft-gray);
        text-transform: lowercase;
      }

      .progress-track {
        height: 2px;
        background: #e5e0da;
        position: relative;
      }

      .progress-fill {
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 0%;
        background: var(--rust);
        transition: width 180ms ease;
      }

      .progress-percent {
        font-size: 0.84rem;
        color: var(--soft-gray);
        min-width: 40px;
        text-align: right;
      }

      .questions {
        display: grid;
        gap: 1.15rem;
      }

      .question {
        border: 1px solid #e9e4de;
        border-radius: 14px;
        background: var(--card);
        padding: 1.05rem 1.2rem 1rem;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto 1fr auto;
        column-gap: 1.25rem;
        row-gap: 0.65rem;
        height: 372px;
        overflow: hidden;
        max-width: var(--question-card-width);
        width: 100%;
        margin: 0 auto;
      }

      .question h3 {
        margin: 0;
        font-size: 0.83rem;
        letter-spacing: 0.06em;
        color: var(--soft-gray);
        text-transform: lowercase;
      }

      .question-main,
      .question-side {
        height: 100%;
        min-width: 0;
      }

      .question-main {
        display: grid;
        grid-template-rows: 1fr auto;
        min-height: 0;
        margin-left: -0.55rem;
      }

      .question-content {
        grid-column: 1 / -1;
        display: grid;
        grid-template-columns: 200px minmax(0, 560px);
        gap: 0.78rem;
        height: 100%;
        min-width: 0;
        justify-content: center;
      }

      .options-row {
        display: grid;
        grid-template-columns: auto minmax(0, 1fr) auto;
        grid-template-rows: 1fr auto;
        gap: 0.5rem;
        height: 100%;
        min-width: 0;
      }

      .options-row .options {
        grid-column: 1 / 4;
        grid-row: 1;
        align-self: stretch;
      }

      .question-nav {
        display: inline-flex;
        align-items: center;
        justify-content: center;
      }

      .arrow-btn {
        width: 31px;
        height: 31px;
        border: 1px solid #d9c9c1;
        border-radius: 999px;
        background: #fff;
        color: var(--rust);
        padding: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        line-height: 1;
        font-size: 0.95rem;
        font-weight: 600;
      }

      .arrow-btn--next {
        border-color: var(--rust);
        background: var(--rust);
        color: #fff;
      }

      .see-result-btn {
        border: 1px solid var(--rust);
        border-radius: 999px;
        background: var(--rust);
        color: #fff;
        font-family: "Montserrat", sans-serif;
        font-size: 0.74rem;
        letter-spacing: 0.02em;
        text-transform: lowercase;
        padding: 0.42rem 0.78rem;
        cursor: pointer;
      }

      .question-prompt {
        margin: 0;
        font-size: clamp(1rem, 1.45vw, 1.34rem);
        line-height: 1.14;
        letter-spacing: -0.02em;
        text-transform: lowercase;
        max-width: 220px;
        align-self: center;
      }

      .options {
        display: grid;
        grid-template-rows: repeat(4, minmax(0, 1fr));
        gap: 0.42rem;
        height: 100%;
        min-height: 212px;
      }

      .option {
        position: relative;
        display: grid;
        grid-template-columns: 54px 1fr;
        align-items: stretch;
        border-radius: 10px;
        border: 1px solid #ddd8d1;
        background: #fff;
        min-height: 0;
        max-width: none;
        cursor: pointer;
        overflow: hidden;
      }

      .option input {
        position: absolute;
        opacity: 0;
        pointer-events: none;
      }

      .option-letter {
        height: 100%;
        border-right: 1px solid #e8e2db;
        display: grid;
        place-items: center;
        color: var(--rust);
        font-weight: 600;
        text-transform: uppercase;
        font-size: 0.95rem;
      }

      .option-text {
        padding: 0.62rem 0.82rem;
        font-size: 0.84rem;
        line-height: 1.24;
        color: var(--charcoal);
        display: flex;
        align-items: center;
      }

      .question-meta {
        margin: 0;
        grid-column: 1 / 3;
        margin-left: 1.85rem;
      }

      .question h3.question-meta {
        color: var(--rust);
      }

      .question-nav-left {
        grid-column: 1;
        grid-row: 2;
        justify-self: center;
        align-self: end;
      }

      .question-nav-right {
        grid-column: 3;
        grid-row: 2;
        justify-self: end;
        align-self: end;
      }

      .start-over-wrap {
        margin-top: 0.72rem;
        max-width: var(--question-card-width);
        width: 100%;
        margin-left: auto;
        margin-right: auto;
      }

      .start-over-btn {
        border: 1px solid #d9c9c1;
        border-radius: 999px;
        background: #fff9f6;
        color: var(--rust);
        font-size: 0.78rem;
        padding: 0.32rem 0.7rem;
      }

      .option:has(input:checked) {
        border-color: var(--rust);
        background: #fff8f5;
      }

      .option:has(input:checked) .option-letter {
        background: rgba(159, 60, 36, 0.08);
      }

      button {
        border: none;
        border-radius: 999px;
        padding: 0.7rem 1.28rem;
        cursor: pointer;
        font-family: "Montserrat", sans-serif;
        font-size: 0.88rem;
        text-transform: lowercase;
      }

      #start-btn {
        background: var(--rust);
        color: #fff;
      }

      #status {
        font-size: 0.85rem;
        color: var(--soft-gray);
      }

      .result {
        margin-top: 0;
        border-radius: 0;
        border: none;
        background: transparent;
        padding: 0;
      }

      .result[hidden] {
        display: none;
      }

      .result h2 {
        margin: 0;
        text-transform: lowercase;
        letter-spacing: -0.02em;
        font-size: 2rem;
        line-height: 1.04;
      }

      .result h3 {
        text-transform: lowercase;
        margin: 0 0 0.4rem;
        font-size: 1.8rem;
        line-height: 1.04;
        letter-spacing: -0.01em;
        color: #202020;
      }

      .result h4 {
        text-transform: lowercase;
        margin: 0 0 0.34rem;
        font-size: 1.85rem;
        line-height: 1.05;
        letter-spacing: -0.01em;
        color: #202020;
      }

      .result h5 {
        text-transform: lowercase;
        margin: 0 0 0.34rem;
        font-size: 1.15rem;
        letter-spacing: 0.03em;
        color: var(--rust);
      }

      .result p {
        margin: 0;
        color: #2f2f2f;
        font-size: 0.95rem;
        line-height: 1.6;
      }

      .helper-error {
        margin-top: 0.85rem;
        color: var(--rust);
        font-size: 0.84rem;
      }

      button[hidden] {
        display: none;
      }

      button[disabled] {
        opacity: 0.52;
        cursor: not-allowed;
      }

      .questionnaire[hidden],
      .result-page[hidden] {
        display: none;
      }

      .hero[hidden],
      .section-divider[hidden] {
        display: none !important;
      }

      .result-page {
        height: 100vh;
        padding: 0 0 96px;
        background: var(--off-white);
        overflow: hidden;
      }

      .result-shell {
        max-width: var(--question-card-width);
        margin: 0 auto;
        padding: 0;
        height: 100%;
      }

      .result-layout {
        display: grid;
        grid-template-columns: 260px minmax(0, 1fr);
        height: 100%;
      }

      .result-side {
        border-right: 1px solid #e4ddd5;
        padding: 1.6rem 1rem 5.2rem;
        display: flex;
        flex-direction: column;
      }

      .result-side h2 {
        margin: 0;
        color: var(--rust);
        font-size: 0.92rem;
        letter-spacing: 0.06em;
        text-transform: lowercase;
      }

      .result-motif {
        width: 170px;
        aspect-ratio: 1 / 1;
        border: 1px solid #e5dfd8;
        border-radius: 50%;
        margin: 0 auto 1rem;
        position: relative;
      }

      .result-motif::before {
        content: "";
        position: absolute;
        inset: 18%;
        border-radius: 50%;
        border: 1px solid #ede8e1;
      }

      .result-motif::after {
        content: "";
        position: absolute;
        width: 12px;
        height: 12px;
        background: var(--rust);
        border-radius: 50%;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
      }

      .result-side-block {
        margin-top: 0.9rem;
        text-align: center;
      }

      .result-side-label {
        color: var(--soft-gray);
        font-size: 0.8rem;
        margin-bottom: 0.5rem;
        text-transform: lowercase;
      }

      .result-primary-name {
        font-size: 2.72rem;
        line-height: 0.98;
        letter-spacing: -0.03em;
        text-transform: lowercase;
      }

      .score-circle {
        width: 122px;
        height: 122px;
        margin: 0.4rem auto 0;
        border-radius: 50%;
        display: grid;
        place-items: center;
        background:
          radial-gradient(var(--off-white) 62%, transparent 63%),
          conic-gradient(var(--rust) var(--score-angle), #e4ddd5 0);
      }

      .score-circle-inner {
        text-align: center;
        color: var(--rust);
      }

      .score-circle-inner strong {
        display: block;
        font-size: 3rem;
        font-weight: 500;
        line-height: 1;
      }

      .score-circle-inner span {
        font-size: 0.95rem;
        color: var(--soft-gray);
      }

      .type-btn {
        border: 1px solid #d9c9c1;
        border-radius: 999px;
        background: #fff9f6;
        color: var(--rust);
        font-size: 0.8rem;
        padding: 0.38rem 0.78rem;
      }

      .type-btn.active {
        background: var(--rust);
        border-color: var(--rust);
        color: #fff;
      }

      .type-row {
        margin-top: 0.56rem;
        display: flex;
        flex-direction: column;
        flex-wrap: nowrap;
        gap: 0.42rem;
        align-items: center;
        justify-content: center;
      }

      .result-footer-actions {
        position: fixed;
        left: calc(50% - (var(--question-card-width) / 2) + 130px);
        bottom: 20px;
        transform: translateX(-50%);
        z-index: 20;
        padding-top: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.56rem;
        width: auto;
      }

      .result-footer-actions .result-action-btn {
        width: 208px;
        min-height: 42px;
        background: var(--rust);
        color: #fff;
        border: 1px solid var(--rust);
      }

      .result-footer-actions #retake-btn {
        background: #fff9f6;
        color: var(--rust);
      }

      .result-main {
        padding: 1.6rem 1.25rem 1.9rem;
        height: 100%;
        overflow-y: auto;
      }

      .result-section {
        padding: 0 0 1.65rem;
        border-bottom: 1px solid #ece4db;
        margin-bottom: 1.65rem;
      }

      .result-section:last-child {
        border-bottom: none;
        margin-bottom: 0;
      }

      .result-section-dark {
        background: #141618;
        color: #f3efe9;
        padding: 1.25rem 1.2rem;
        border-radius: 0;
        margin-left: -1.25rem;
        margin-right: -1.25rem;
        padding-left: 1.25rem;
        padding-right: 1.25rem;
      }

      .result-section-dark p {
        color: #f3efe9;
      }

      .result-summary-copy {
        max-width: 620px;
        margin-top: 0.7rem;
        margin-bottom: 0.9rem;
        font-family: "Montserrat", sans-serif;
        font-size: 20pt;
        font-style: italic;
        line-height: 1.62;
        font-weight: 500;
      }

      .type-row-label {
        color: var(--soft-gray);
        font-size: 0.86rem;
        text-transform: lowercase;
      }


      @media (max-width: 940px) {
        .hero,
        .questionnaire {
          padding-left: 1.1rem;
          padding-right: 1.1rem;
        }

        .hero {
          min-height: auto;
          grid-template-columns: 1fr;
          gap: 1.1rem;
          padding-top: 2.1rem;
        }

        .motif {
          width: min(320px, 86vw);
        }

        .question {
          height: auto;
          grid-template-columns: 1fr;
          grid-template-rows: auto auto 1fr auto;
        }

        .question-meta {
          grid-column: 1;
        }

        .question-main,
        .question-side {
          grid-column: 1;
        }

        .question-main {
          min-height: 140px;
        }

        .options {
          min-height: 250px;
        }

        .question-nav-right {
          justify-self: end;
        }

        .result-layout {
          grid-template-columns: 1fr;
          height: auto;
        }

        .result-side {
          border-right: none;
          border-bottom: 1px solid #e4ddd5;
          padding-bottom: 2rem;
        }

        .result-main {
          padding: 1.4rem 1.1rem 2rem;
          height: auto;
          overflow-y: visible;
        }

        .result-section-dark {
          margin-left: -1.1rem;
          margin-right: -1.1rem;
        }

        .progress-row {
          grid-template-columns: 1fr;
          gap: 0.58rem;
        }

        .questionnaire {
          min-height: auto;
          justify-content: flex-start;
        }

        .result-footer-actions {
          left: 50%;
        }

        .result-page {
          height: auto;
          overflow: visible;
        }

        .result-shell {
          height: auto;
        }
      }
