/* =========================================================================
   NATURAL CREDITS — CONTACT US PAGE (bespoke, light theme)
   Loaded ONLY on template-contact-us.php. Namespace: .ct-* (contact).
   ====================================================================== */

.contact-page { overflow-x: clip; }
.contact-page .ct-wrap { max-width: var(--wide); margin-inline: auto; padding-inline: var(--edge); }
.contact-page .ct-narrow { max-width: 880px; margin-inline: auto; padding-inline: var(--edge); }
.contact-page > section { position: relative; padding-block: clamp(3rem, 6vw, 5.5rem); }
.contact-page > section:first-child { padding-top: clamp(5.5rem, 11vh, 8rem); }

/* ---- Tonal bands ---- */
.contact-page .ct-mid   { background: linear-gradient(180deg, #EFF8F2 0%, #FDFEFD 100%); }
.contact-page .ct-light { background: linear-gradient(180deg, #F0F9FF 0%, #FAFDFF 100%); }
.contact-page .ct-mid :where(h2, h3), .contact-page .ct-light :where(h2, h3) { color: var(--c-text); }

/* ---- Shared type ---- */
.contact-page .ct-kicker { display: inline-flex; align-items: center; gap: .6rem; font-family: var(--font-display); font-size: .74rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--c-primary); margin: 0 0 1.1rem; }
.contact-page .ct-kicker::before { content: ""; width: 24px; height: 2px; background: var(--gradient); border-radius: 2px; }
.contact-page .ct-h { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.85rem, 1.35rem + 2.1vw, 2.85rem); line-height: 1.08; letter-spacing: -0.028em; margin: 0 0 1rem; color: var(--c-text); }
.contact-page .ct-lead { font-size: clamp(1.02rem, .98rem + .4vw, 1.2rem); line-height: 1.65; color: var(--c-muted); max-width: 62ch; margin: 0 0 1.4rem; }
.contact-page .ct-grad { background: var(--gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.contact-page p { color: var(--c-muted); }

/* ---- Buttons ---- */
.contact-page .ct-btn { position: relative; overflow: hidden; display: inline-flex; align-items: center; gap: .55rem; font-family: var(--font-display); font-weight: 700; font-size: .98rem; padding: .92em 1.85em; border-radius: var(--radius-pill); text-decoration: none; transition: transform .22s ease, box-shadow .22s ease, color .22s ease, background .22s ease, border-color .22s ease; }
.contact-page .ct-btn--primary { background: linear-gradient(135deg, #10B981, #0EA5E9); color: #fff; box-shadow: 0 12px 28px -10px rgba(5, 150, 105, .6); }
.contact-page .ct-btn--primary:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 18px 38px -10px rgba(5, 150, 105, .75); }
.contact-page .ct-btn--ghost { background: #fff; border: 1px solid var(--border-strong); color: var(--c-text); }
.contact-page .ct-btn--ghost:hover { border-color: var(--c-primary); background: rgba(16, 185, 129, .08); color: var(--c-text); transform: translateY(-2px); }

/* =========================================================================
   1. HERO
   ====================================================================== */
.contact-page .ct-hero { text-align: center; background: radial-gradient(55% 70% at 50% -12%, rgba(16, 185, 129, .14), transparent 60%), radial-gradient(45% 60% at 90% 50%, rgba(14, 165, 233, .1), transparent 65%), #fff; }
.contact-page .ct-hero .ct-kicker { margin-inline: auto; }
.contact-page .ct-hero h1 { font-family: var(--font-display); font-weight: 700; font-size: clamp(2.25rem, 1.3rem + 3.8vw, 4rem); line-height: 1.04; letter-spacing: -0.035em; margin: 0 0 1.2rem; color: var(--c-text); text-wrap: balance; }
.contact-page .ct-hero__lead { max-width: 60ch; margin: 0 auto 1.9rem; color: var(--c-muted); }
.contact-page .ct-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: .65rem; }
.contact-page .ct-chip { display: inline-flex; align-items: center; gap: .55rem; padding: .55rem 1.05rem; background: #fff; border: 1px solid rgba(5, 150, 105, .25); border-radius: var(--radius-pill); font-family: var(--font-display); font-weight: 600; font-size: .85rem; color: var(--c-text); box-shadow: 0 8px 20px -14px rgba(15, 32, 25, .3); }
.contact-page .ct-chip svg { width: 16px; height: 16px; stroke: var(--c-primary); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }

/* =========================================================================
   2. CONTACT SPLIT (form + alternatives)
   ====================================================================== */
.contact-page .ct-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(1.8rem, 1rem + 3vw, 3.5rem); align-items: start; }
.contact-page .ct-info p { margin: 0 0 1.4rem; }
.contact-page .ct-method { display: grid; grid-template-columns: auto 1fr; gap: .85rem 1.1rem; padding: .95rem 1rem; margin-bottom: .65rem; background: #fff; border: 1px solid var(--border); border-radius: 14px; transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease; }
.contact-page .ct-method:hover { border-color: rgba(5, 150, 105, .35); box-shadow: 0 16px 32px -22px rgba(5, 64, 40, .3); transform: translateY(-2px); }
.contact-page .ct-method__ic { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; background: rgba(16, 185, 129, .12); border: 1px solid rgba(5, 150, 105, .28); flex: none; }
.contact-page .ct-method__ic svg { width: 18px; height: 18px; stroke: var(--c-primary); fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.contact-page .ct-method__l { font-family: var(--font-display); font-size: .72rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; color: var(--c-primary); margin: 0 0 .15rem; }
.contact-page .ct-method__v { margin: 0; font-family: var(--font-display); font-size: .95rem; font-weight: 600; color: var(--c-text); line-height: 1.4; }
.contact-page .ct-method__v a { color: var(--c-text); text-decoration: none; }
.contact-page .ct-method__v a:hover { color: var(--c-primary); }
.contact-page .ct-info__note { margin-top: 1.4rem; padding: 1rem 1.1rem; background: rgba(16, 185, 129, .08); border: 1px dashed rgba(5, 150, 105, .35); border-radius: 12px; font-size: .9rem; color: var(--c-text); }
.contact-page .ct-info__note a { color: var(--c-primary); font-weight: 700; text-decoration: none; }
.contact-page .ct-info__note a:hover { color: #047857; text-decoration: underline; }

/* Form card */
.contact-page .ct-form-card { position: relative; padding: clamp(1.6rem, 1rem + 1.6vw, 2.2rem); background: #fff; border: 1px solid rgba(5, 150, 105, .25); border-radius: 22px; box-shadow: 0 30px 60px -32px rgba(5, 80, 60, .35); }
.contact-page .ct-form-card::before { content: ""; position: absolute; left: 0; right: 0; top: 0; height: 3px; background: linear-gradient(90deg, #10B981, #34D399 40%, #FACC15 65%, #0EA5E9 100%); border-radius: 22px 22px 0 0; }
.contact-page .ct-form-card h3 { margin: 0 0 .35rem; font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; color: var(--c-text); }
.contact-page .ct-form-card > p { margin: 0 0 1.3rem; color: var(--c-muted); font-size: .95rem; line-height: 1.55; }

/* =========================================================================
   3. WHAT HAPPENS NEXT
   ====================================================================== */
.contact-page .ct-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.6rem; counter-reset: ct-step; position: relative; }
.contact-page .ct-steps::before { content: ""; position: absolute; left: 12px; right: 12px; top: 22px; height: 2px; background: repeating-linear-gradient(90deg, rgba(5, 150, 105, .42) 0 10px, transparent 10px 20px); background-size: 40px 2px; }
.contact-page .ct-step { position: relative; padding-top: 3.3rem; }
.contact-page .ct-step::before { content: ""; position: absolute; left: 0; top: 12px; width: 22px; height: 22px; border-radius: 50%; background: var(--gradient); box-shadow: 0 0 0 5px #EFF8F2, 0 6px 16px -4px rgba(5, 150, 105, .55); }
.contact-page .ct-step__n { position: absolute; right: 0; top: 0; font-family: var(--font-display); font-weight: 800; font-size: 2.4rem; line-height: 1; letter-spacing: -.03em; color: transparent; -webkit-text-stroke: 1.5px rgba(5, 150, 105, .35); }
.contact-page .ct-step h3 { font-family: var(--font-display); font-size: 1.18rem; color: var(--c-text); margin: 0 0 .5rem; }
.contact-page .ct-step p { margin: 0; color: var(--c-muted); font-size: .92rem; line-height: 1.6; }

/* =========================================================================
   4. WHAT TO BRING
   ====================================================================== */
.contact-page .ct-bring { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(1.5rem, 1rem + 3vw, 3rem); align-items: start; }
.contact-page .ct-bring__list { list-style: none; padding: 1.5rem 1.7rem; margin: 0; background: #fff; border: 1px solid rgba(5, 150, 105, .22); border-radius: 18px; box-shadow: 0 24px 48px -28px rgba(5, 80, 60, .35); display: grid; gap: .85rem; }
.contact-page .ct-bring__list li { position: relative; padding-left: 2.1rem; font-family: var(--font-display); font-weight: 500; font-size: .95rem; color: var(--c-text); line-height: 1.5; }
.contact-page .ct-bring__list li > span { position: absolute; left: 0; top: 0; display: grid; place-items: center; width: 1.5em; height: 1.5em; border-radius: 50%; background: var(--gradient); color: #fff; font-size: .78em; font-weight: 800; box-shadow: 0 4px 10px -2px rgba(5, 150, 105, .5); }

/* =========================================================================
   5. MARKETS GRID
   ====================================================================== */
.contact-page .ct-mktgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; margin-top: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.contact-page .ct-mkt { padding: 1.5rem 1.4rem; background: #fff; border: 1px solid var(--border); border-radius: 16px; transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease; }
.contact-page .ct-mkt:hover { transform: translateY(-4px); border-color: rgba(5, 150, 105, .35); box-shadow: 0 22px 44px -22px rgba(5, 64, 40, .3); }
.contact-page .ct-mkt__flag { display: inline-grid; place-items: center; width: 44px; height: 30px; margin-bottom: .8rem; font-family: var(--font-display); font-weight: 800; font-size: .78rem; letter-spacing: .08em; color: #fff; background: var(--gradient); border-radius: 6px; box-shadow: 0 8px 18px -8px rgba(5, 150, 105, .55); }
.contact-page .ct-mkt h3 { font-family: var(--font-display); font-size: 1.1rem; margin: 0 0 .4rem; color: var(--c-text); }
.contact-page .ct-mkt p { margin: 0; color: var(--c-muted); font-size: .9rem; line-height: 1.55; }
.contact-page .ct-mkt--ghost { background: transparent; border-style: dashed; border-color: rgba(5, 150, 105, .35); }
.contact-page .ct-mkt--ghost h3 { color: var(--c-primary); }

/* =========================================================================
   6. FOR EVERY SIZE
   ====================================================================== */
.contact-page .ct-sizes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.3rem; margin-top: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.contact-page .ct-size { padding: 1.6rem 1.5rem; background: #fff; border: 1px solid var(--border); border-radius: 18px; box-shadow: 0 12px 30px -22px rgba(15, 32, 25, .3); transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease; }
.contact-page .ct-size:hover { transform: translateY(-4px); border-color: rgba(5, 150, 105, .35); box-shadow: 0 26px 48px -24px rgba(5, 64, 40, .35); }
.contact-page .ct-size--mid { background: linear-gradient(180deg, #ECFDF5 0%, #F7FEFB 100%); border-color: rgba(5, 150, 105, .35); }
.contact-page .ct-size__tag { display: inline-flex; padding: .35em .9em; margin-bottom: 1rem; font-family: var(--font-display); font-weight: 700; font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--c-primary); background: rgba(16, 185, 129, .12); border: 1px solid rgba(5, 150, 105, .3); border-radius: var(--radius-pill); }
.contact-page .ct-size--mid .ct-size__tag { color: #fff; background: var(--gradient); border-color: transparent; }
.contact-page .ct-size h3 { font-family: var(--font-display); font-size: 1.2rem; margin: 0 0 .55rem; color: var(--c-text); }
.contact-page .ct-size p { margin: 0; color: var(--c-muted); font-size: .92rem; line-height: 1.6; }

/* =========================================================================
   7. WHY US
   ====================================================================== */
.contact-page .ct-why { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem 1.6rem; margin-top: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.contact-page .ct-why__row { display: grid; grid-template-columns: auto 1fr; gap: 0 1rem; padding: 1.2rem 1.3rem; background: #fff; border: 1px solid var(--border); border-radius: 14px; }
.contact-page .ct-why__n { grid-row: span 2; font-family: var(--font-display); font-weight: 800; font-size: 2.2rem; line-height: .8; background: var(--gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.contact-page .ct-why__row h3 { margin: 0 0 .35rem; font-family: var(--font-display); font-size: 1.05rem; color: var(--c-text); }
.contact-page .ct-why__row p { margin: 0; color: var(--c-muted); font-size: .92rem; line-height: 1.55; }

/* =========================================================================
   8. INDUSTRIES STRIP
   ====================================================================== */
.contact-page .ct-indrow { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: clamp(1.2rem, .8rem + 1.5vw, 2rem); }
.contact-page .ct-chip--ind { padding: .65em 1.25em; font-size: .92rem; box-shadow: 0 8px 22px -16px rgba(15, 32, 25, .35); transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease, background .3s ease; }
.contact-page .ct-chip--ind:hover { transform: translateY(-3px); border-color: rgba(5, 150, 105, .5); box-shadow: 0 14px 30px -14px rgba(5, 150, 105, .45); background: #ECFDF5; }

/* =========================================================================
   9. FAQ
   ====================================================================== */
.contact-page .ct-faq__wrap { max-width: 960px; }
.contact-page .ct-faq__list { counter-reset: ctfaq; display: grid; gap: .85rem; margin-top: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.contact-page .ct-faq__item { position: relative; counter-increment: ctfaq; background: #fff; border: 1px solid var(--border); border-radius: 18px; overflow: hidden; transition: border-color .35s ease, box-shadow .35s ease, background .35s ease; }
.contact-page .ct-faq__item[open] { border-color: rgba(5, 150, 105, .45); background: linear-gradient(180deg, #F0FDF8 0%, #fff 60%); box-shadow: 0 22px 44px -26px rgba(5, 64, 40, .4); }
.contact-page .ct-faq__item summary { list-style: none; cursor: pointer; display: grid; grid-template-columns: auto 1fr auto; align-items: center; column-gap: 1.2rem; padding: 1.2rem 1.4rem 1.2rem 1.6rem; }
.contact-page .ct-faq__item summary::-webkit-details-marker { display: none; }
.contact-page .ct-faq__item summary::before { content: counter(ctfaq, decimal-leading-zero); font-family: var(--font-display); font-weight: 800; font-size: 1rem; letter-spacing: .04em; background: var(--gradient); -webkit-background-clip: text; background-clip: text; color: transparent; min-width: 1.85em; }
.contact-page .ct-faq__q { font-family: var(--font-display); font-weight: 600; font-size: clamp(1rem, .96rem + .25vw, 1.12rem); line-height: 1.4; color: var(--c-text); }
.contact-page .ct-faq__icon { position: relative; flex: none; width: 34px; height: 34px; border-radius: 50%; background: rgba(16, 185, 129, .1); border: 1px solid rgba(5, 150, 105, .3); transition: background .35s ease, transform .35s cubic-bezier(.2, .8, .25, 1); }
.contact-page .ct-faq__icon::before, .contact-page .ct-faq__icon::after { content: ""; position: absolute; left: 50%; top: 50%; background: var(--c-primary); border-radius: 2px; }
.contact-page .ct-faq__icon::before { width: 12px; height: 2.2px; margin: -1.1px 0 0 -6px; }
.contact-page .ct-faq__icon::after { width: 2.2px; height: 12px; margin: -6px 0 0 -1.1px; }
.contact-page .ct-faq__item summary:hover .ct-faq__icon { background: rgba(16, 185, 129, .2); }
.contact-page .ct-faq__item[open] .ct-faq__icon { background: var(--gradient); border-color: transparent; transform: rotate(135deg); }
.contact-page .ct-faq__item[open] .ct-faq__icon::before, .contact-page .ct-faq__item[open] .ct-faq__icon::after { background: #fff; }
.contact-page .ct-faq__item p { margin: 0; padding: 0 1.4rem 1.3rem 4.05rem; color: var(--c-muted); font-size: .94rem; line-height: 1.7; }

/* =========================================================================
   10. RELATED RESOURCES
   ====================================================================== */
.contact-page .ct-resgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; margin-top: clamp(1.5rem, 1rem + 2vw, 2.5rem); }
.contact-page .ct-res { display: block; padding: 1.5rem 1.4rem; background: #fff; border: 1px solid var(--border); border-radius: 16px; text-decoration: none; transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease, background .3s ease; }
.contact-page .ct-res:hover { transform: translateY(-4px); border-color: rgba(5, 150, 105, .4); background: linear-gradient(180deg, #F0FDF8 0%, #fff 100%); box-shadow: 0 22px 44px -22px rgba(5, 64, 40, .3); }
.contact-page .ct-res h3 { margin: 0 0 .4rem; font-family: var(--font-display); font-size: 1.05rem; color: var(--c-primary); transition: color .25s ease; }
.contact-page .ct-res:hover h3 { color: #047857; }
.contact-page .ct-res p { margin: 0; color: var(--c-muted); font-size: .88rem; line-height: 1.55; }

/* =========================================================================
   11. FINAL CTA
   ====================================================================== */
.contact-page .ct-cta { background: radial-gradient(50% 60% at 50% 0%, rgba(14, 165, 233, .08), transparent 65%), #fff; text-align: center; }
.contact-page .ct-cta__panel { max-width: 820px; margin-inline: auto; padding: clamp(2.4rem, 2rem + 3vw, 4rem) clamp(1.5rem, 1rem + 3vw, 3.5rem); border-radius: 28px; background: linear-gradient(135deg, #059669 0%, #0E9F8A 50%, #0EA5E9 100%); box-shadow: 0 36px 80px -32px rgba(5, 100, 80, .55); }
.contact-page .ct-cta__panel h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(1.8rem, 1.3rem + 2vw, 2.6rem); letter-spacing: -.025em; color: #fff; margin: 0 0 1rem; }
.contact-page .ct-cta__panel p { color: rgba(255, 255, 255, .92); max-width: 52ch; margin: 0 auto 1.7rem; }
.contact-page .ct-cta__btns { display: flex; flex-wrap: wrap; gap: .85rem; justify-content: center; }
.contact-page .ct-cta__panel .ct-btn--primary { background: #fff; color: #047857; }
.contact-page .ct-cta__panel .ct-btn--primary:hover { color: #047857; }
.contact-page .ct-cta__panel .ct-btn--ghost { background: rgba(255, 255, 255, .12); border-color: rgba(255, 255, 255, .55); color: #fff; }
.contact-page .ct-cta__panel .ct-btn--ghost:hover { border-color: #fff; background: rgba(255, 255, 255, .2); color: #fff; }

/* =========================================================================
   FORM (asm_contact_form shortcode) — light theme overrides
   ====================================================================== */
.contact-page .ct-form-card .asm-lead-form input, .contact-page .ct-form-card .asm-lead-form textarea { background: #F8FDFB; border: 1px solid rgba(17, 34, 27, .14); color: var(--c-text); }
.contact-page .ct-form-card .asm-lead-form input:focus, .contact-page .ct-form-card .asm-lead-form textarea:focus { background: #fff; border-color: var(--c-primary); box-shadow: 0 0 0 4px rgba(16, 185, 129, .12); }
.contact-page .ct-form-card .asm-field__label { color: var(--c-muted); }

/* =========================================================================
   RESPONSIVE
   ====================================================================== */
@media (max-width: 1024px) {
	.contact-page .ct-grid { grid-template-columns: 1fr; }
	.contact-page .ct-steps { grid-template-columns: 1fr 1fr; gap: 2rem 1.6rem; }
	.contact-page .ct-steps::before { display: none; }
	.contact-page .ct-mktgrid, .contact-page .ct-sizes, .contact-page .ct-resgrid { grid-template-columns: 1fr 1fr; }
	.contact-page .ct-why { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
	.contact-page .ct-bring { grid-template-columns: 1fr; }
	.contact-page .ct-steps, .contact-page .ct-mktgrid, .contact-page .ct-sizes, .contact-page .ct-resgrid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
	.contact-page * { transition: none !important; }
}
