/* Mortaro Authority — components v4 (rizkad-style, light) */

/* ---- Buttons ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .6em; font-family: var(--font-body); font-weight: 600; font-size: .98rem; line-height: 1; white-space: nowrap; padding: 15px 24px; border-radius: var(--radius-pill); border: 1.5px solid transparent; min-height: 50px; transition: transform .2s var(--ease), background .2s, color .2s, border-color .2s; will-change: transform; }
.btn__arrow { transition: transform .2s var(--ease); }
.btn:hover .btn__arrow { transform: translateX(4px); }
.btn--primary { background: var(--ink); color: var(--cream); }
.btn--primary:hover { background: var(--brass); transform: translateY(-2px); }
.btn--brass { background: var(--brass); color: var(--cream); }
.btn--brass:hover { background: var(--brass-bright); transform: translateY(-2px); }
.btn--secondary { background: transparent; color: var(--ink); border-color: var(--line); }
.btn--secondary:hover { border-color: var(--ink); }
.surface-dark .btn--primary { background: var(--cream); color: var(--ink); }
.surface-dark .btn--primary:hover { background: var(--brass-bright); }
.surface-dark .btn--secondary { color: var(--cream); border-color: var(--line-dark); }
.surface-dark .btn--secondary:hover { border-color: var(--cream); }
.btn--lg { padding: 18px 30px; font-size: 1.05rem; min-height: 58px; }
.btn--block { width: 100%; }

/* ---- Spots / urgency pill (inline) ---- */
.spots { display: inline-flex; align-items: center; gap: .5em; font-family: var(--font-cond); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; font-size: .8rem; color: var(--brass); }
.spots .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brass); flex: none; }

/* ---- Spot meter (segmented progress bar of build slots) ---- */
.spotmeter { display: inline-flex; align-items: center; gap: .65em; }
.spotmeter__pips { display: inline-flex; gap: 3px; }
.spotmeter__pips i { width: 16px; height: 7px; border-radius: 2px; background: var(--line); display: block; }
.spotmeter__pips i.on { background: var(--brass); }
.spotmeter__txt { font-family: var(--font-cond); font-weight: 600; letter-spacing: .07em; text-transform: uppercase; font-size: .78rem; color: var(--text-muted); white-space: nowrap; }
.surface-dark .spotmeter__pips i { background: var(--line-dark); }
.surface-dark .spotmeter__pips i.on { background: var(--brass-bright); }
.surface-dark .spotmeter__txt { color: var(--on-dark-muted); }

/* ---- Trust / proof row ---- */
.proofbar { display: flex; flex-wrap: wrap; gap: var(--s3); }
.proofbar span { display: inline-flex; align-items: center; gap: .45em; font-family: var(--font-cond); font-weight: 600; font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted); }
.proofbar span svg { color: var(--brass); flex: none; }
.proofbar span:not(:last-child)::after { content: "·"; margin-left: var(--s3); color: var(--line); }

/* ---- Stat ---- */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: var(--s7) var(--s5); }
.stat__value { font-family: var(--font-display); font-size: clamp(3rem,2rem+4vw,6rem); font-weight: 780; color: var(--ink); line-height: .85; letter-spacing: -.04em; }
.surface-dark .stat__value { color: var(--cream); }
.stat__value .stat__suffix { color: var(--brass); }
.stat__label { margin-top: var(--s4); font-family: var(--font-cond); font-weight: 600; font-size: .85rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted); max-width: 22ch; }

/* ---- Card ---- */
.card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: var(--s7); }
.surface-dark .card { background: var(--night-2); border-color: var(--line-dark); }

/* ---- FAQ ---- */
.faq { max-width: 920px; margin-inline: auto; border-top: 2px solid var(--ink); }
.surface-dark .faq { border-top-color: var(--cream); }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q { width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; gap: var(--s5); padding: var(--s6) 0; font-family: var(--font-display); font-weight: 720; font-size: clamp(1.3rem,1rem+1.2vw,2rem); letter-spacing: -.02em; color: var(--heading); }
.faq__icon { flex: none; width: 26px; height: 26px; position: relative; }
.faq__icon::before, .faq__icon::after { content: ""; position: absolute; background: var(--brass); border-radius: 2px; inset: 0; margin: auto; }
.faq__icon::before { width: 16px; height: 2.5px; }
.faq__icon::after { width: 2.5px; height: 16px; transition: transform .3s var(--ease); }
.faq__q[aria-expanded="true"] .faq__icon::after { transform: rotate(90deg) scaleX(0); }
.faq__a { overflow: hidden; max-height: 0; transition: max-height .4s var(--ease); }
.faq__a-inner { padding-bottom: var(--s6); color: var(--text-muted); max-width: 74ch; font-size: var(--fs-lead); line-height: 1.5; }
@media (prefers-reduced-motion: reduce) { .faq__a { transition: none; } }

/* ---- Risk ---- */
.risk { display: grid; gap: var(--s5); grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); }
.risk__item { display: flex; gap: var(--s4); align-items: flex-start; }
.risk__tick { flex: none; width: 34px; height: 34px; border-radius: 50%; background: var(--brass); color: var(--cream); display: grid; place-items: center; }
.risk__item strong { display: block; font-family: var(--font-display); font-weight: 720; font-size: var(--fs-h3); margin-bottom: var(--s2); letter-spacing: -.02em; }

/* ---- Case placeholder ---- */
.case-grid { display: grid; gap: var(--s5); grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); }
.case { border: 1.5px dashed var(--line); border-radius: var(--radius-lg); padding: var(--s7); min-height: 230px; display: flex; flex-direction: column; justify-content: space-between; }
.surface-dark .case { border-color: var(--line-dark); }
.case__tag { font-family: var(--font-cond); font-weight: 600; font-size: .82rem; letter-spacing: .1em; color: var(--brass); text-transform: uppercase; }
.case__placeholder { color: var(--text-muted); }

/* ---- Sticky mobile CTA ---- */
.sticky-cta { position: fixed; left: 0; right: 0; bottom: 0; z-index: 90; padding: var(--s3) var(--gutter) calc(var(--s3) + env(safe-area-inset-bottom)); background: color-mix(in srgb, var(--cream) 94%, transparent); backdrop-filter: blur(12px); border-top: 1px solid var(--line); transform: translateY(110%); transition: transform .4s var(--ease); display: none; }
.sticky-cta.is-visible { transform: none; }
.sticky-cta .btn { width: 100%; }
@media (max-width: 940px) { .sticky-cta { display: block; } body.has-sticky-cta { padding-bottom: 80px; } }

/* ---- Modal ---- */
.modal { position: fixed; inset: 0; z-index: 200; display: none; }
.modal.is-open { display: block; }
.modal__overlay { position: absolute; inset: 0; background: rgba(21,24,27,.55); backdrop-filter: blur(5px); opacity: 0; transition: opacity .3s; }
.modal.is-open .modal__overlay { opacity: 1; }
.modal__dialog { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-46%); width: min(580px, calc(100vw - 28px)); max-height: calc(100vh - 40px); overflow: auto; background: var(--paper); color: var(--text); border-radius: var(--radius-lg); padding: clamp(26px,4vw,44px); box-shadow: var(--shadow-float); opacity: 0; transition: opacity .3s var(--ease), transform .3s var(--ease); }
.modal.is-open .modal__dialog { opacity: 1; transform: translate(-50%,-50%); }
.modal__close { position: absolute; top: 16px; right: 16px; width: 42px; height: 42px; border-radius: 50%; border: 1.5px solid var(--line); display: grid; place-items: center; }
.modal__close:hover { border-color: var(--ink); }
.modal__eyebrow { margin-bottom: var(--s3); }
.modal__title { font-size: clamp(1.7rem,1.2rem+1.6vw,2.4rem); margin-bottom: var(--s2); letter-spacing: -.03em; }
.modal__reassure { color: var(--text-muted); margin-bottom: var(--s6); }

/* ---- Lead form ---- */
.lead-form { display: grid; gap: var(--s4); }
.field { display: grid; gap: 6px; }
.field label { font-family: var(--font-cond); font-weight: 600; font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; color: var(--text-muted); }
.field input { font: inherit; padding: 14px 16px; border-radius: var(--radius); border: 1.5px solid var(--line); background: var(--cream); color: var(--ink); min-height: 52px; width: 100%; }
.field input:focus-visible { outline: 2px solid var(--brass); outline-offset: 1px; border-color: var(--brass); }
.field--row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s4); }
.field--hp { position: absolute; left: -9999px; }
.lead-form__note { font-family: var(--font-cond); font-weight: 600; font-size: .78rem; letter-spacing: .05em; text-transform: uppercase; color: var(--text-muted); display: flex; align-items: center; gap: .5em; }
.lead-form__note svg { color: var(--brass); }
@media (max-width: 480px) { .field--row { grid-template-columns: 1fr; } }

/* ---- Consent ---- */
.consent { position: fixed; left: var(--gutter); right: var(--gutter); bottom: var(--s4); z-index: 150; max-width: 540px; margin-inline: auto; background: var(--ink); color: var(--cream); border-radius: var(--radius-lg); padding: var(--s5); box-shadow: var(--shadow-float); display: none; gap: var(--s4); align-items: center; flex-wrap: wrap; }
.consent.is-shown { display: flex; }
.consent p { font-size: var(--fs-small); color: var(--on-dark-muted); flex: 1 1 240px; margin: 0; }
.consent__actions { display: flex; gap: var(--s3); }
.consent .btn { padding: 10px 18px; min-height: 42px; }
.consent .btn--primary { background: var(--cream); color: var(--ink); }

.section-cta { margin-top: var(--s7); }
