/* ── GOOGLE FONTS ── */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400;1,600&family=Jost:wght@300;400;500&family=Playfair+Display:ital,wght@0,700;1,400&display=swap');

/* ── TOKENS ── */
.gjw-diamonds {
    --white:      #ffffff;
    --ivory:      #FAFAF8;
    --parchment:  #F7F5F1;
    --slate:      #5F6B85;
    --gold:       #C4A45A;
    --gold-soft:  #e8d5a8;
    --charcoal:   #2e2e2e;
    --mid:        #7a7a7a;
    --soft:       #b0b0b0;
    --rule:       #eeebe6;
    --nat-tint:   #fdfaf6;
    --lab-tint:   #f6f8fb;

    font-family: 'Jost', sans-serif;
    color: var(--charcoal);
    background: var(--white);
    line-height: 1.8;
}

/* ── RESET ── */
.gjw-diamonds *, .gjw-diamonds *::before, .gjw-diamonds *::after { box-sizing: border-box; margin: 0; padding: 0; }
.gjw-diamonds img { max-width: 100%; display: block; }
.gjw-diamonds a { color: inherit; text-decoration: none; }

/* ── HERO ── */
.gjw-diamonds__hero {
    background: var(--white);
    padding: 88px 24px 72px;
    text-align: center;
    border-bottom: 1px solid var(--rule);
}
.gjw-diamonds__hero-eyebrow {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--soft);
    margin-bottom: 28px;
}
.gjw-diamonds__hero-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(32px, 6vw, 60px);
    font-weight: 700;
    color: var(--charcoal);
    line-height: 1.1;
    margin-bottom: 24px;
}
.gjw-diamonds__hero-title em {
    font-style: italic;
    color: var(--slate);
}
.gjw-diamonds__hero-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-bottom: 28px;
}
.gjw-diamonds__hero-divider-line {
    width: 40px;
    height: 1px;
    background: var(--gold-soft);
}
.gjw-diamonds__hero-divider-icon {
    color: var(--gold-soft);
    font-size: 10px;
}
.gjw-diamonds__hero-sub {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(18px, 2.5vw, 22px);
    font-style: italic;
    color: var(--mid);
    max-width: 520px;
    margin: 0 auto 18px;
    font-weight: 400;
}
.gjw-diamonds__hero-lead {
    font-size: 14px;
    color: var(--soft);
    max-width: 480px;
    margin: 0 auto;
    font-weight: 300;
    line-height: 1.8;
}

/* ── SPLIT BANNER ── */
.gjw-diamonds__split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-bottom: 1px solid var(--rule);
}
.gjw-diamonds__split-panel {
    padding: 56px 48px;
    text-align: center;
}
.gjw-diamonds__split-panel--nat {
    background: var(--nat-tint);
    border-right: 1px solid var(--rule);
}
.gjw-diamonds__split-panel--lab {
    background: var(--lab-tint);
}
.gjw-diamonds__split-label {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.gjw-diamonds__split-panel--nat .gjw-diamonds__split-label { color: var(--gold); }
.gjw-diamonds__split-panel--lab .gjw-diamonds__split-label { color: var(--slate); }
.gjw-diamonds__split-heading {
    font-family: 'Playfair Display', serif;
    font-size: clamp(20px, 2.5vw, 26px);
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: 16px;
}
.gjw-diamonds__split-body {
    font-size: 14px;
    color: var(--mid);
    max-width: 320px;
    margin: 0 auto;
    font-weight: 300;
    line-height: 1.8;
}

/* ── SECTION WRAPPER ── */
.gjw-diamonds__section {
    max-width: 840px;
    margin: 0 auto;
    padding: 88px 24px;
}
.gjw-diamonds__section--wide {
    max-width: 1040px;
    margin: 0 auto;
    padding: 88px 24px;
}
.gjw-diamonds__section-eyebrow {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--soft);
    margin-bottom: 16px;
    text-align: center;
}
.gjw-diamonds__section-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(26px, 4vw, 38px);
    font-weight: 700;
    color: var(--charcoal);
    text-align: center;
    margin-bottom: 16px;
    line-height: 1.2;
}
.gjw-diamonds__section-title em {
    font-style: italic;
    color: var(--slate);
}
.gjw-diamonds__section-intro {
    font-size: 15px;
    color: var(--mid);
    text-align: center;
    max-width: 580px;
    margin: 0 auto 56px;
    font-weight: 300;
    line-height: 1.8;
}

/* ── COMPARISON TABLE ── */
.gjw-diamonds__table-wrap {
    background: var(--white);
    border: 1px solid var(--rule);
    overflow: hidden;
}
.gjw-diamonds__table {
    width: 100%;
    border-collapse: collapse;
}
.gjw-diamonds__table thead tr {
    background: var(--white);
    border-bottom: 1px solid var(--rule);
}
.gjw-diamonds__table thead th {
    padding: 20px 24px;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    text-align: left;
}
.gjw-diamonds__table thead th:first-child { color: var(--soft); width: 30%; }
.gjw-diamonds__table thead th:nth-child(2) { color: var(--gold); }
.gjw-diamonds__table thead th:nth-child(3) { color: var(--slate); }
.gjw-diamonds__table tbody tr { border-bottom: 1px solid var(--rule); }
.gjw-diamonds__table tbody tr:last-child { border-bottom: none; }
.gjw-diamonds__table tbody tr:nth-child(even) { background: var(--ivory); }
.gjw-diamonds__table tbody td {
    padding: 16px 24px;
    font-size: 14px;
    vertical-align: top;
    font-weight: 300;
    line-height: 1.6;
}
.gjw-diamonds__table tbody td:first-child {
    font-weight: 400;
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--soft);
}
.gjw-diamonds__table tbody td:nth-child(2) { color: var(--charcoal); }
.gjw-diamonds__table tbody td:nth-child(3) { color: var(--charcoal); }
.gjw-diamonds__check { color: #9ec9b0; font-size: 13px; margin-right: 6px; }
.gjw-diamonds__neutral { color: var(--gold-soft); font-size: 13px; margin-right: 6px; }

/* ── DUAL CARDS ── */
.gjw-diamonds__cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
}
.gjw-diamonds__card {
    border: 1px solid var(--rule);
    overflow: hidden;
    background: var(--white);
}
.gjw-diamonds__card--nat { border-top: 1px solid var(--gold-soft); }
.gjw-diamonds__card--lab { border-top: 1px solid #b8c8d8; }
.gjw-diamonds__card-header {
    padding: 32px 32px 24px;
    background: var(--white);
}
.gjw-diamonds__card-label {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.gjw-diamonds__card--nat .gjw-diamonds__card-label { color: var(--gold); }
.gjw-diamonds__card--lab .gjw-diamonds__card-label { color: var(--slate); }
.gjw-diamonds__card-title {
    font-family: 'Playfair Display', serif;
    font-size: 21px;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: 10px;
    line-height: 1.3;
}
.gjw-diamonds__card-tagline {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 16px;
    color: var(--soft);
}
.gjw-diamonds__card-body {
    padding: 24px 32px 32px;
    border-top: 1px solid var(--rule);
    background: var(--white);
}
.gjw-diamonds__card-body p {
    font-size: 14px;
    color: var(--mid);
    margin-bottom: 16px;
    font-weight: 300;
    line-height: 1.8;
}
.gjw-diamonds__card-body p:last-child { margin-bottom: 0; }
.gjw-diamonds__card-facts {
    list-style: none;
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--rule);
}
.gjw-diamonds__card-facts li {
    font-size: 13px;
    color: var(--mid);
    padding: 10px 0;
    border-bottom: 1px solid var(--rule);
    display: flex;
    gap: 12px;
    align-items: flex-start;
    font-weight: 300;
    line-height: 1.6;
}
.gjw-diamonds__card-facts li:last-child { border-bottom: none; }
.gjw-diamonds__card-facts li span:first-child {
    flex-shrink: 0;
    margin-top: 4px;
    color: var(--gold-soft);
    font-size: 8px;
}

/* ── QUESTIONS ── */
.gjw-diamonds__q-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px 56px;
}
.gjw-diamonds__q-item {
    padding-bottom: 40px;
    border-bottom: 1px solid var(--rule);
}
.gjw-diamonds__q-item:nth-last-child(-n+2) {
    border-bottom: none;
    padding-bottom: 0;
}
.gjw-diamonds__q-number {
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px;
    font-style: italic;
    color: var(--gold-soft);
    line-height: 1;
    margin-bottom: 16px;
}
.gjw-diamonds__q-question {
    font-family: 'Playfair Display', serif;
    font-size: 16px;
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: 12px;
    line-height: 1.35;
}
.gjw-diamonds__q-answer {
    font-size: 14px;
    color: var(--mid);
    font-weight: 300;
    line-height: 1.8;
}

/* ── CTA BAND ── */
.gjw-diamonds__band {
    background: var(--ivory);
    border-top: 1px solid var(--rule);
    padding: 88px 24px;
    text-align: center;
}
.gjw-diamonds__band-eyebrow {
    font-size: 10px;
    font-weight: 400;
    letter-spacing: 0.25em;
    text-transform: uppercase;
    color: var(--soft);
    margin-bottom: 20px;
}
.gjw-diamonds__band-title {
    font-family: 'Playfair Display', serif;
    font-size: clamp(24px, 4vw, 36px);
    font-weight: 700;
    color: var(--charcoal);
    margin-bottom: 16px;
    line-height: 1.2;
}
.gjw-diamonds__band-title em {
    font-style: italic;
    color: var(--slate);
}
.gjw-diamonds__band-body {
    font-size: 15px;
    color: var(--mid);
    max-width: 520px;
    margin: 0 auto 40px;
    font-weight: 300;
    line-height: 1.8;
}
.gjw-diamonds__band-buttons {
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
}

/* ── BUTTONS ── */
.gjw-diamonds__btn {
    display: inline-block;
    padding: 13px 32px;
    font-family: 'Jost', sans-serif;
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    cursor: pointer;
    transition: opacity 0.2s;
}
.gjw-diamonds__btn:hover { opacity: 0.75; }
.gjw-diamonds__btn--gold { background: var(--gold); color: var(--white); }
.gjw-diamonds__btn--outline { background: transparent; color: var(--charcoal); border: 1px solid var(--rule); }

/* ── SECTION DIVIDER ── */
.gjw-diamonds__rule {
    border: none;
    border-top: 1px solid var(--rule);
    margin: 0;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
    .gjw-diamonds__split { grid-template-columns: 1fr; }
    .gjw-diamonds__split-panel--nat { border-right: none; border-bottom: 1px solid var(--rule); }
    .gjw-diamonds__cards { grid-template-columns: 1fr; }
    .gjw-diamonds__q-grid { grid-template-columns: 1fr; gap: 32px; }
    .gjw-diamonds__q-item:nth-last-child(-n+2) { border-bottom: 1px solid var(--rule); padding-bottom: 32px; }
    .gjw-diamonds__q-item:last-child { border-bottom: none; padding-bottom: 0; }
    .gjw-diamonds__table thead th:first-child { width: 35%; }
    .gjw-diamonds__table tbody td { padding: 12px 14px; font-size: 13px; }
    .gjw-diamonds__section { padding: 56px 20px; }
    .gjw-diamonds__section--wide { padding: 56px 20px; }
    .gjw-diamonds__split-panel { padding: 40px 28px; }
}
