/* ================================================================
   Circle Ledger — shared.css
   Universal component styles loaded on EVERY page.

   Architecture:
     base/variables.css  — ALL CSS custom properties (single source of truth)
     base/reset.css      — web fonts, icon font, box-model reset, base element rules
     base/typography.css — heading defaults and text utility classes
     shared.css          — universal: buttons, forms, cards, badges, avatar, spinner,
                           notice, modal, toast, divider, breadcrumb, sr_only, utilities,
                           marketing nav, hero, sections, footer, legal
     components/*        — extended variants loaded only on dashboard / join pages
     dashboard.css       — app-shell layout + dashboard-specific patterns
     auth.css            — auth + join page layouts
================================================================ */

/* ── Design tokens ── */
@import url('./base/variables.css');
/* ── Reset, web fonts, icons, and typography utilities ── */
@import url('./base/reset.css');
@import url('./base/typography.css');

/* ================================================================
   BUTTONS
   Auth pages (login/signup/forgot/reset) rely on shared.css for
   button styles; keep the full set here.
================================================================ */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: var(--space-2);
    padding: var(--btn-py) var(--btn-px);
    border-radius: var(--radius-md);
    font-size: var(--btn-fs); font-family: var(--font-body); font-weight: 600;
    cursor: pointer; border: none; white-space: nowrap; text-decoration: none;
    transition: background var(--t), transform var(--t), box-shadow var(--t), opacity var(--t);
    line-height: 1; -webkit-tap-highlight-color: transparent;
}
.btn:disabled, .btn.is_loading { opacity: .55; cursor: not-allowed; pointer-events: none; }
.btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
    transform: none !important;  /* Cancel any hover transform */
}
.btn_primary { background: var(--teal-600); color: #fff; box-shadow: 0 var(--space-0-5) var(--space-2) rgba(30,107,107,.25); }
.btn_primary:hover { background: var(--teal-700); transform: translateY(-0.0625rem); box-shadow: 0 var(--space-1) var(--space-3-5) rgba(30,107,107,.3); }

.btn_amber { background: var(--amber-400); color: var(--teal-800); box-shadow: 0 var(--space-0-5) var(--space-2) rgba(245,158,11,.3); font-weight: 700; }
.btn_amber:hover { background: var(--amber-300); transform: translateY(-0.0625rem); box-shadow: 0 var(--space-1) var(--space-3-5) rgba(245,158,11,.4); }

.btn_outline_white { background: transparent; border: var(--border-thick) solid rgba(255,255,255,.5); color: #fff; }
.btn_outline_white:hover { background: rgba(255,255,255,.1); border-color: #fff; }

.btn_outline { background: transparent; border: var(--border-thick) solid var(--teal-600); color: var(--teal-600); }
.btn_outline:hover { background: var(--teal-50); }

.btn_success { background: var(--green-600); color: #fff; }
.btn_success:hover { background: var(--green-700); }

.btn_danger { background: var(--red-600); color: #fff; }
.btn_danger:hover { background: var(--red-700); }

.btn_danger_outline { background: transparent; border: var(--border-thick) solid var(--red-600); color: var(--red-600); }
.btn_danger_outline:hover { background: var(--red-50); }

.btn_ghost { background: transparent; border: var(--border-thick) solid var(--slate-300); color: var(--slate-700); }
.btn_ghost:hover { background: var(--slate-50); }

.btn_ghost_danger { background: transparent; border: var(--border-thick) solid var(--red-600); color: var(--red-600); }
.btn_ghost_danger:hover { background: var(--red-50); }

/* Ghost SM — neutral for light backgrounds (topbar, cards) */
.btn_ghost_sm {
    background: transparent;
    border: var(--border-thin) solid var(--slate-300);
    color: var(--slate-600);
    padding: var(--btn-ghost-py) var(--btn-ghost-px);
    border-radius: var(--radius-sm);
    font-size: var(--btn-sm-fs); font-family: var(--font-body); font-weight: 500;
    cursor: pointer; transition: all var(--t);
}
.btn_ghost_sm:hover { background: var(--slate-100); color: var(--slate-800); }

.btn_sm   { padding: var(--btn-sm-py) var(--btn-sm-px); font-size: var(--btn-sm-fs); border-radius: var(--radius-sm); }
.btn_lg   { padding: var(--btn-lg-py) var(--btn-lg-px); font-size: var(--btn-lg-fs); }
.btn_full { width: 100%; }
.btn_xs   { padding: 0.25rem 0.625rem; font-size: var(--text-xs); border-radius: var(--radius-sm); }

/* Flex helper — centres icon + text in link-buttons and anchors */
.btn_flex { display: flex !important; align-items: center; justify-content: center; gap: var(--space-2); }

/* ── Icon button (square, no label) ── */
.btn_icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 2.25rem; height: 2.25rem; border: none; border-radius: var(--radius-sm);
    background: var(--slate-100); color: var(--slate-500); cursor: pointer;
    font-size: var(--icon-md); transition: background var(--t), color var(--t); flex-shrink: 0;
}
.btn_icon:hover { background: var(--teal-100); color: var(--teal-700); }
.btn_icon_sm { width: 1.75rem; height: 1.75rem; font-size: var(--icon-sm); }
.btn_icon_lg { width: 2.75rem; height: 2.75rem; font-size: var(--icon-lg); }

/* ── Link button (text-only) ── */
.btn_link {
    background: none; border: none; cursor: pointer; font-family: var(--font-body);
    font-size: var(--text-md); color: var(--teal-600); padding: 0;
    transition: color var(--t); text-decoration: none;
}
.btn_link:hover { color: var(--teal-800); text-decoration: underline; }
.btn_link_sm { font-size: var(--text-sm); }
.btn_link_danger { color: var(--red-600); }
.btn_link_danger:hover { color: var(--red-700); }

/* ── Spinner inside button ── */
.btn .spinner { margin-right: var(--space-1); }

/* Standalone btn_spinner — used as <i class="spinner"></i> inside buttons */
.btn_spinner {
    display: inline-block;
    width: var(--spinner-size); height: var(--spinner-size);
    border: var(--spinner-bw) solid rgba(255,255,255,.3); border-top-color: #fff;
    border-radius: 50%; animation: cl-spin .6s linear infinite; vertical-align: middle; flex-shrink: 0;
}

/* ================================================================
   FORMS
================================================================ */
.form_grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: flex-start;
    gap: var(--space-2);
}
.form_group { display: flex; flex-direction: column; gap: var(--space-1-5); margin-bottom: var(--space-4); }
.form_group:last-child { margin-bottom: 0; }

.form_label { font-size: var(--text-sm); font-weight: 600; color: var(--slate-600); text-transform: uppercase; letter-spacing: 0.025rem; }
.form_label .optional { color: var(--slate-400); font-weight: 400; text-transform: none; letter-spacing: 0; font-size: var(--text-xs); }
.form_optional { color: var(--slate-400); font-weight: 400; font-size: var(--text-xs); }
/* Inline label — wraps a checkbox + text on the same line */
.form_label_inline { display: flex; align-items: center; gap: var(--space-2); text-transform: none; letter-spacing: 0; cursor: pointer; }

.password_group { display: flex; justify-content: space-between; }
.password_toggle {
    padding: var(--space-1); color: var(--teal-600);
    border-radius: var(--radius-sm); border: var(--border-thin) solid var(--surface);
    background: none; cursor: pointer; font-size: var(--icon-md); transition: color var(--t);
}
.password_toggle:hover { color: var(--teal-800); }

.form_input, .form_select, .form_textarea {
    padding: var(--form-input-py) var(--form-input-px);
    border: var(--border-thick) solid var(--slate-200);
    border-radius: var(--radius-md); resize: none;
    font-size: var(--form-input-fs);
    font-family: var(--font-body); color: var(--slate-800);
    background: var(--surface); outline: none; width: 100%;
    transition: border-color var(--t), box-shadow var(--t);
}
.form_input:focus, .form_select:focus, .form_textarea:focus {
    border-color: var(--teal-400);
    box-shadow: 0 0 0 var(--space-1) rgba(30,107,107,.12);
}
.form_input.is_invalid, .form_select.is_invalid, .form_textarea.is_invalid {
    border-color: var(--red-600);
    box-shadow: 0 0 0 var(--space-1) rgba(220,38,38,.08);
}
.form_input:disabled, .form_select:disabled, .form_textarea:disabled {
    background: var(--slate-50); color: var(--slate-400); cursor: not-allowed;
}
.form_input::placeholder, .form_textarea::placeholder { color: var(--slate-400); }
.form_select {
    appearance: none; cursor: pointer;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%2364748b' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right var(--form-input-px) center;
    padding-right: calc(var(--form-input-px) * 2.5);
}
.form_textarea { resize: vertical; min-height: 5rem; }
.form_hint  { font-size: var(--text-sm); color: var(--slate-400); }
.form_error { font-size: var(--text-lg); color: var(--red-600); display: none;}

.form_check_label { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-md); color: var(--slate-700); cursor: pointer; }
.form_check_label input[type="checkbox"] { accent-color: var(--teal-600); width: 1rem; height: 1rem; flex-shrink: 0; }

/* ── Chip group (payment method / tag selector) ── */
.chip_group { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.chip_group input[type="checkbox"] { display: none; }
.chip {
    display: inline-flex; align-items: center; gap: var(--space-1-5);
    padding: var(--space-1-5) var(--space-3); border-radius: var(--radius-pill);
    border: var(--border-thick) solid var(--slate-200); background: var(--surface);
    font-size: var(--text-sm); font-weight: 600; color: var(--slate-600);
    cursor: pointer; transition: all var(--t); user-select: none; -webkit-tap-highlight-color: transparent;
}
.chip:hover { border-color: var(--teal-300); color: var(--teal-700); background: var(--teal-50); }
.chip_group input[type="checkbox"]:checked + .chip,
.chip_active { background: var(--teal-600); border-color: var(--teal-600); color: #fff; }

/* ── Prefixed input wrap (currency or unit prefix) ── */
.form_input_prefix_wrap { position: relative; }
.form_input_prefix {
    position: absolute; left: var(--form-input-px); top: 50%; transform: translateY(-50%);
    font-size: var(--text-md); font-weight: 700; color: var(--slate-400); pointer-events: none;
}
.form_input_has_prefix { padding-left: calc(var(--form-input-px) + 2rem); font-weight: 600; }

/* ── OTP input row ── */
.otp_row { display: flex; gap: var(--space-2); justify-content: center; }
.otp_input {
    width: 3rem; height: 3.5rem; text-align: center;
    font-size: var(--text-3xl); font-weight: 700; font-family: var(--font-display);
    padding: 0; border: var(--border-thick) solid var(--slate-200); border-radius: var(--radius-md);
    background: var(--surface); outline: none; transition: border-color var(--t), box-shadow var(--t); color: var(--teal-900);
}
.otp_input:focus { border-color: var(--teal-400); box-shadow: 0 0 0 var(--space-1) rgba(30,107,107,.12); }

/* ── Form divider (separator with text) ── */
.form_divider { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-5) 0; }
.form_divider_line { flex: 1; height: var(--border-thin); background: var(--slate-200); }
.form_divider_text { font-size: var(--text-sm); color: var(--slate-400); font-weight: 500; }

/* ── Phone input (flag + number) ── */
.phone_input_wrap { display: flex; gap: var(--space-2); }
.phone_input_wrap .form_select { width: 6rem; flex-shrink: 0; }
.phone_input_wrap .form_input  { flex: 1; }

.error_banner {
    font-size: var(--text-lg); color: var(--red-600);
    background: var(--red-50); border: var(--border-thin) solid var(--red-100);
    padding: var(--space-2-5) var(--form-input-px); border-radius: var(--radius-md);
    margin-bottom: var(--space-4); line-height: 1.5; display: none;
}


/* Password input wrapper */
.pw_input_wrap { position: relative; }
.pw_input      { padding-right: 2.75rem; }
.pw_toggle_btn { position: absolute; right: var(--form-input-px); top: 50%; transform: translateY(-50%); font-size: var(--text-2xl);}

/* ================================================================
   CARDS
================================================================ */
.card { background: var(--surface); border-radius: var(--radius-lg); border: var(--border-thin) solid var(--border); box-shadow: var(--shadow-xs); overflow: hidden; }
.card_body { padding: var(--space-4) var(--space-5); }

/* ================================================================
   BADGES
================================================================ */
.badge {
    display: inline-flex; align-items: center; gap: var(--space-1);
    padding: var(--space-0-5) var(--space-2-5); border-radius: var(--radius-pill);
    font-size: var(--text-xs); font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.025rem; white-space: nowrap;
}
.badge_pending          { background: var(--amber-100); color: var(--amber-600); }
.badge_approved,
.badge_confirmed        { background: var(--green-100); color: var(--green-700); }
.badge_rejected         { background: var(--red-100);   color: var(--red-700);   }
.badge_active           { background: var(--teal-100);  color: var(--teal-700);  }
.badge_paused           { background: var(--amber-100); color: var(--amber-700); }
.badge_closed           { background: var(--slate-100); color: var(--slate-600); }
.badge_admin,
.badge_moderator        { background: var(--teal-900);  color: var(--teal-200);  }
.badge_member           { background: var(--slate-100); color: var(--slate-600); }
.badge_green            { background: var(--green-100); color: var(--green-700); }
.badge_amber            { background: var(--amber-100); color: var(--amber-700); }
.badge_red,
.badge_danger           { background: var(--red-100);   color: var(--red-700);   }
.badge_teal,
.badge_info             { background: var(--teal-50);   color: var(--teal-700);  }
.badge_slate            { background: var(--slate-100); color: var(--slate-600); }

/* ── Extended badge variants (payout, dispute, size, dot, nav) ── */
.badge i { font-size: var(--icon-xs); }
.badge_open         { background: var(--green-100); color: var(--green-700); }
.badge_pending_ack  { background: var(--amber-100); color: var(--amber-600); }
.badge_acknowledged { background: var(--green-100); color: var(--green-700); }
.badge_disputed     { background: var(--red-100);   color: var(--red-700); }
.badge_raised       { background: var(--amber-100); color: var(--amber-700); }
.badge_resolved     { background: var(--green-100); color: var(--green-700); }
.badge_white        { background: rgba(255,255,255,.15); color: #fff; }
.badge_sm { font-size: 0.5625rem; padding: 0.0625rem var(--space-2); letter-spacing: .03rem; }
.badge_lg { font-size: var(--text-sm); padding: var(--space-1) var(--space-3); }
.badge_dot { width: var(--space-2); height: var(--space-2); border-radius: 50%; display: inline-block; flex-shrink: 0; }
.badge_dot.pending  { background: var(--amber-400); }
.badge_dot.approved { background: var(--green-600); }
.badge_dot.active   { background: var(--teal-500); }
.badge_dot.closed   { background: var(--slate-400); }
.badge_dot.rejected { background: var(--red-600); }
.nav_badge {
    position: absolute; top: var(--space-0-5); right: var(--space-0-5);
    min-width: 1rem; height: 1rem; padding: 0 var(--space-1);
    border-radius: var(--radius-pill); background: var(--amber-400); color: var(--teal-900);
    font-size: 0.5rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center; line-height: 1;
}

/* ================================================================
   AVATAR
================================================================ */
.avatar { border-radius: 50%; background: var(--teal-100); color: var(--teal-800); display: flex; align-items: center; justify-content: center; font-weight: 700; flex-shrink: 0; }
.avatar_sm { width: var(--avatar-sm); height: var(--avatar-sm); font-size: var(--text-xs); }
.avatar_md { width: var(--avatar-md); height: var(--avatar-md); font-size: var(--text-base); }
.avatar_lg { width: var(--avatar-lg); height: var(--avatar-lg); font-size: var(--text-xl); }
.avatar.pending   { background: var(--amber-100); color: var(--amber-700); }
.avatar.moderator { background: var(--teal-900);  color: var(--teal-100); }

/* ================================================================
   SPINNER
================================================================ */
.spinner {
    display: inline-block;
    width: var(--spinner-size); height: var(--spinner-size);
    border: var(--spinner-bw) solid rgba(255,255,255,.3); border-top-color: #fff;
    border-radius: 50%; animation: cl-spin .6s linear infinite; vertical-align: middle; flex-shrink: 0;
}
.spinner_dark { border-color: rgba(30,107,107,.2); border-top-color: var(--teal-600); }
.spinner_lg   { width: var(--spinner-size-lg); height: var(--spinner-size-lg); border-width: var(--spinner-bw-lg); }
@keyframes cl-spin { to { transform: rotate(360deg); } }

/* ================================================================
   NOTICE BANNERS
================================================================ */
.notice { display: flex; align-items: flex-start; gap: var(--space-2-5); padding: var(--space-3) var(--form-input-px); border-radius: var(--radius-md); margin-bottom: var(--space-4); font-size: var(--text-base); line-height: 1.5; }
.notice_warning,
.notice_warn    { background: var(--amber-50);  border: var(--border-thin) solid var(--amber-300); color: var(--amber-600); }
.notice_success { background: var(--green-50);  border: var(--border-thin) solid var(--green-200);          color: var(--green-700); }
.notice_info    { background: var(--teal-50);   border: var(--border-thin) solid var(--teal-200);  color: var(--teal-700); }
.notice_danger  { background: var(--red-50);    border: var(--border-thin) solid var(--red-100);   color: var(--red-700); }

/* ================================================================
   PROGRESS BAR
================================================================ */
.progress_bar_wrap { background: var(--slate-100); border-radius: var(--radius-pill); height: var(--space-2); overflow: hidden; margin: var(--space-2) 0; }
.progress_bar_fill { height: 100%; width: 0%; border-radius: var(--radius-pill); background: var(--teal-500); transition: width .4s ease; }
.progress_bar_fill.amber { background: var(--amber-400); }
.progress_bar_fill.red   { background: var(--red-600); }

/* ================================================================
   DIVIDER
================================================================ */
.divider { display: flex; align-items: center; gap: var(--space-3); margin: var(--space-5) 0; }
.divider_line { flex: 1; height: var(--border-thin); background: var(--slate-200); }
.divider_text { font-size: var(--text-sm); color: var(--slate-400); font-weight: 500; }

/* ================================================================
   TOAST
================================================================ */
.toast_container {
    position: fixed; top: var(--toast-top); left: 50%; transform: translateX(-50%);
    z-index: 9000; display: flex; flex-direction: column; gap: var(--space-2);
    pointer-events: none; width: calc(100% - var(--space-8)); max-width: var(--toast-max-w);
}
.toast {
    background: var(--slate-900); color: #fff;
    padding: var(--toast-py) var(--toast-px); border-radius: var(--radius-md);
    font-size: var(--text-base); font-weight: 500; box-shadow: var(--shadow-lg);
    animation: cl-toast-in .2s ease; pointer-events: auto;
}
.toast.success { background: var(--green-700); }
.toast.error   { background: var(--red-700);   }
.toast.info    { background: var(--teal-700);  }
@keyframes cl-toast-in {
    from { transform: translateY(var(--space-4)); opacity: 0; }
    to   { transform: translateY(0);              opacity: 1; }
}

/* ================================================================
   MODAL (bottom-sheet pattern — desktop centres via media query in components/modal.css)
================================================================ */
.modal_overlay {
    position: fixed; inset: 0; background: rgba(13,43,43,.55);
    backdrop-filter: blur(0.25rem); -webkit-backdrop-filter: blur(0.25rem);
    z-index: 8000; display: flex; align-items: flex-end; justify-content: center;
    animation: cl-fade-in .15s ease;
}
@keyframes cl-fade-in { from { opacity: 0; } to { opacity: 1; } }
.modal {
    background: var(--surface); border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    width: 100%; max-width: var(--sheet-max-w); max-height: 90vh; overflow-y: auto;
    padding: var(--space-2) var(--sheet-px) var(--sheet-pb); animation: cl-slide-up .2s ease;
    padding-bottom: max(var(--sheet-pb), env(safe-area-inset-bottom));
}
@keyframes cl-slide-up { from { transform: translateY(var(--space-10)); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.modal_handle   { width: var(--sheet-handle-w); height: var(--sheet-handle-h); background: var(--slate-200); border-radius: var(--space-0-5); margin: var(--sheet-handle-my) auto var(--space-5); }
.modal_header   { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: var(--space-5); gap: var(--space-3); }
.modal_title    { font-family: var(--font-display); font-size: var(--sheet-title-size); font-weight: 700; color: var(--teal-900); letter-spacing: -0.02em; line-height: 1.2; }
.modal_subtitle { font-size: var(--text-base); color: var(--slate-500); margin-top: var(--space-1); }
.modal_close {
    background: var(--slate-100); border: none;
    width: var(--sheet-close-size); height: var(--sheet-close-size);
    border-radius: 50%; cursor: pointer; font-size: var(--icon-md);
    display: flex; align-items: center; justify-content: center;
    color: var(--slate-500); flex-shrink: 0; transition: background var(--t);
}
.modal_close:hover { background: var(--slate-200); }
.modal_confirm_body { padding: 0 var(--space-2); }

/* ================================================================
   PAGE LOADER / EMPTY STATES
================================================================ */
.page_loader { display: flex; align-items: center; justify-content: center; min-height: 12rem; }
.empty_state { text-align: center; padding: var(--space-12) var(--space-6); color: var(--slate-400); }
.empty_state_icon  { font-size: var(--text-6xl); margin-bottom: var(--space-3); color: var(--slate-300); }
.empty_state_title { font-size: var(--text-lg); font-weight: 600; color: var(--slate-600); margin-bottom: var(--space-1-5); }
.empty_state_text   { font-size: var(--text-md); }
.empty_state_action { margin-top: var(--space-5); }

/* ================================================================
   BREADCRUMB
================================================================ */
.breadcrumb { display: flex; align-items: center; gap: var(--breadcrumb-gap); margin-bottom: var(--breadcrumb-mb); font-size: var(--text-sm); color: var(--slate-400); }
.breadcrumb_link { background: none; border: none; cursor: pointer; color: var(--teal-600); font-size: var(--text-sm); font-family: var(--font-body); padding: 0; transition: color var(--t); }
.breadcrumb_link:hover { text-decoration: underline; }
.breadcrumb_sep { font-size: var(--text-xs); color: var(--slate-300); }

/* ================================================================
   SCREEN-READER ONLY
================================================================ */
.sr_only {
    position: absolute; width: var(--border-thin); height: var(--border-thin);
    padding: 0; margin: calc(-1 * var(--border-thin)); overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border-width: 0;
}

/* ================================================================
   VISIBILITY & LAYOUT UTILITIES
================================================================ */
.is_hidden   { display: none !important; }
.is_visible { display: block !important; }
.text_center { text-align: center; }

/* Spacing utilities */
.u_mb_1 { margin-bottom: var(--space-1); }
.u_mb_2 { margin-bottom: var(--space-2); }
.u_mb_3 { margin-bottom: var(--space-3); }
.u_mb_4 { margin-bottom: var(--space-4); }
.u_mb_5 { margin-bottom: var(--space-5); }
.u_mb_6 { margin-bottom: var(--space-6); }
.u_mb_8 { margin-bottom: var(--space-8); }
.u_mt_1 { margin-top: var(--space-1); }
.u_mt_2 { margin-top: var(--space-2); }
.u_mt_3 { margin-top: var(--space-3); }
.u_mt_4 { margin-top: var(--space-4); }
.u_mt_5 { margin-top: var(--space-5); }
.u_mt_6 { margin-top: var(--space-6); }
.u_mt_8 { margin-top: var(--space-8); }
.u_my_4 { margin-top: var(--space-4); margin-bottom: var(--space-4); }
.u_my_6 { margin-top: var(--space-6); margin-bottom: var(--space-6); }

/* ── Responsive ── */
@media (max-width: 480px) {
    .form_grid { grid-template-columns: 1fr; }
}

/* ================================================================
   MARKETING SITE NAV
   Light background header shared across all marketing pages.
   Uses circle-ledger-logo.svg (dark teal + amber) — correct for
   light backgrounds.
   Mobile drawer stays dark (full-screen overlay matches footer tone).
================================================================ */
.site_nav {
    position: sticky;
    top: 0;
    z-index: 700;
    background: #ffffff;
    backdrop-filter: blur(0.5rem);
    -webkit-backdrop-filter: blur(0.5rem);
    border-bottom: var(--border-thin) solid var(--border);
    box-shadow: 0 1px 4px rgba(13,43,43,.06);
}
.nav_inner {
    max-width: var(--mkt-max-w);
    margin: 0 auto;
    padding: 0 var(--space-6);
    height: var(--nav-height);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-6);
}
.nav_brand {
    display: flex;
    align-items: center;
    gap: var(--space-2-5);
    text-decoration: none;
    flex-shrink: 0;
}
.nav_logo { height: 1.625rem; }
.nav_brand_name {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--teal-900);
    letter-spacing: -0.02em;
}
.nav_links {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    list-style: none;
}
.nav_links a {
    font-size: var(--text-md);
    font-weight: 500;
    color: var(--teal-700);
    padding: var(--space-2) var(--space-3);
    border-radius: var(--radius-sm);
    transition: color var(--t), background var(--t);
    text-decoration: none;
}
.nav_links a:hover { color: var(--teal-900); background: var(--teal-50); }
.nav_links a.active { color: var(--teal-800); background: var(--teal-50); font-weight: 600; }
.nav_cta {
    display: flex;
    align-items: center;
    gap: var(--space-2-5);
    flex-shrink: 0;
}
.nav_hamburger {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--teal-700);
    font-size: var(--icon-2xl);
    padding: var(--space-2);
    border-radius: var(--radius-sm);
    transition: color var(--t), background var(--t);
    -webkit-tap-highlight-color: transparent;
}
.nav_hamburger:hover { color: var(--teal-900); background: var(--teal-50); }

/* ── Mobile drawer — stays dark (brand-consistent overlay) ── */
.nav_drawer {
    position: fixed;
    top: var(--nav-height);
    left: 0; right: 0; bottom: 0;
    background: var(--teal-950);
    z-index: 600;
    padding: var(--space-5) var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    transform: translateX(100%);
    transition: transform .25s cubic-bezier(.32,.72,0,1);
    overflow-y: auto;
}
.nav_drawer.open { transform: translateX(0); }

/* Direct <a> links inside the drawer (not .btn elements) */
.nav_drawer > a {
    display: block;
    padding: var(--space-3-5) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--text-xl);
    font-weight: 500;
    color: var(--teal-200);
    text-decoration: none;
    transition: color var(--t), background var(--t);
}
.nav_drawer > a:hover   { color: #fff; background: rgba(255,255,255,.07); }
.nav_drawer > a.active  { color: #fff; background: rgba(255,255,255,.05); }

/* Legacy class — kept for any page that uses it */
.nav_drawer_link {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3-5) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--text-xl);
    font-weight: 500;
    color: var(--teal-200);
    text-decoration: none;
    transition: color var(--t), background var(--t);
}
.nav_drawer_link:hover { color: #fff; background: rgba(255,255,255,.07); }
.nav_drawer_cta {
    margin-top: var(--space-4);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}
.nav_drawer_overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 590;
    display: none;
}
.nav_drawer_overlay.open { display: block; }
@media (max-width: 768px) {
    .nav_links,
    .nav_cta       { display: none; }
    .nav_hamburger { display: flex; }
}

/* ================================================================
   SITE FOOTER
   Shared across all marketing pages.
================================================================ */
.site_footer {
    background: var(--teal-950);
    color: var(--teal-300);
    padding: var(--space-20) var(--space-6) var(--space-8);
}
.footer_inner { max-width: var(--mkt-max-w); margin: 0 auto; }
.footer_top {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: var(--space-12);
    padding-bottom: var(--space-10);
    border-bottom: var(--border-thin) solid rgba(255,255,255,.07);
}
@media (max-width: 768px) {
    .footer_top { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
    .footer_brand_col { grid-column: 1 / -1; }
}
@media (max-width: 480px) {
    .footer_top { grid-template-columns: 1fr; }
}
.footer_brand {
    display: flex;
    align-items: center;
    gap: var(--space-2-5);
    margin-bottom: var(--space-4);
}
.footer_logo  { height: 1.625rem; }
.footer_tagline {
    font-size: var(--text-md);
    line-height: 1.7;
    color: var(--teal-400);
    max-width: 17.5rem;
}
.footer_col_title {
    font-size: var(--text-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04rem;
    color: var(--teal-300);
    margin-bottom: var(--space-4);
}
.footer_links {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-2-5);
}
.footer_links a {
    font-size: var(--text-md);
    color: var(--teal-400);
    transition: color var(--t);
}
.footer_links a:hover { color: #fff; }
.footer_bottom {
    padding-top: var(--space-7);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--space-3);
}
@media (max-width: 480px) {
    .footer_bottom { flex-direction: column; align-items: center; }
}
.footer_copy { font-size: var(--text-base); color: var(--teal-500); }
.footer_powered { font-weight: 700; }
.footer_powered a { color: var(--amber-600); }
.footer_legal_links {
    display: flex;
    gap: var(--space-5);
    list-style: none;
}
.footer_legal_links a {
    font-size: var(--text-base);
    color: var(--teal-500);
    transition: color var(--t);
}
.footer_legal_links a:hover { color: var(--teal-300); }

/* ================================================================
   MARKETING LAYOUT WRAPPERS
   Shared across all marketing pages.
================================================================ */
.mkt_page {
    background: var(--bg);
    min-height: 100vh;
}
.mkt_inner {
    max-width: var(--mkt-max-w);
    margin: 0 auto;
    padding: 0 var(--space-6);
}
@media (max-width: 768px) {
    .mkt_inner { padding: 0 var(--space-5); }
}
.mkt_section      { padding: var(--space-20) var(--space-6); }
.mkt_section_sm   { padding: var(--space-12) var(--space-6); }
.mkt_section_dark { background: var(--teal-950); color: var(--teal-200); }
.mkt_section_teal { background: linear-gradient(135deg, var(--teal-900), var(--teal-700)); color: #fff; }
.mkt_section_alt  { background: var(--surface); }

.mkt_section_head {
    text-align: center;
    margin-bottom: var(--space-12);
}
.mkt_section_head .text_overline { margin-bottom: var(--space-3); display: block; }
.mkt_section_head h2 {
    font-family: var(--font-display);
    font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
    font-weight: 700;
    color: var(--teal-900);
    letter-spacing: -0.025em;
    margin-bottom: var(--space-4);
}
.mkt_section_dark .mkt_section_head h2,
.mkt_section_teal .mkt_section_head h2 { color: #fff; }
.mkt_section_head p {
    font-size: var(--text-2xl);
    color: var(--slate-500);
    max-width: 38rem;
    margin: 0 auto;
    line-height: 1.65;
}
.mkt_section_dark .mkt_section_head p,
.mkt_section_teal .mkt_section_head p { color: var(--teal-300); }

.section       { padding: var(--space-20) var(--space-6); }
.section_inner { max-width: var(--mkt-max-w); margin: 0 auto; }

/* ================================================================
   MARKETING TYPOGRAPHY UTILITIES
================================================================ */
.section_label {
    font-size: var(--text-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--teal-600);
    margin-bottom: var(--space-4);
}
.section_label_light { color: var(--teal-300); }

/* .text_overline is defined in base/typography.css (imported via shared.css) */
.text_overline_light { color: var(--teal-300); }

.section_title {
    font-family: var(--font-display);
    font-size: clamp(var(--text-2xl), 3.5vw, var(--text-4xl));
    font-weight: 700;
    color: var(--teal-900);
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin-bottom: var(--space-4);
}
.section_title_light {
    color: #fff;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
}
.section_sub {
    font-size: var(--text-lg);
    color: var(--slate-500);
    line-height: 1.7;
    max-width: 42rem;
    margin-left: auto;
    margin-right: auto;
}
.section_sub_light { color: var(--teal-200); }

.how_section_intro  { text-align: center; margin-bottom: 0; }
.section_intro_narrow { max-width: 560px; margin-bottom: 0; }
.link_teal { color: var(--teal-600); }
.section_bg_alt  { background: var(--slate-50); }
.section_bg_dark { background: var(--teal-900); }

/* ================================================================
   HERO BASE
   Gradient backdrop shared by home and waitlist pages.
   Each page defines its own .hero_inner layout.
================================================================ */
.hero {
    background: linear-gradient(160deg, var(--teal-950) 0%, var(--teal-800) 60%, var(--teal-700) 100%);
    position: relative;
    overflow: hidden;
    padding: var(--space-20) var(--space-6) var(--space-24);
    text-align: center;
}
.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 60% 50%, rgba(245,158,11,.07) 0%, transparent 70%);
    pointer-events: none;
}
.hero_actions {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-4);
}
.hero_trust {
    margin-top: var(--space-8);
    font-size: var(--text-sm);
    color: var(--teal-400);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-5);
    flex-wrap: wrap;
}
.hero_trust_item {
    display: flex;
    align-items: center;
    gap: var(--space-1-5);
}
.hero_trust_item i { color: var(--amber-400); }

/* ================================================================
   PAGE HERO
   Interior page header — about, contact, feedback.
================================================================ */
.page_hero {
    background: linear-gradient(160deg, var(--teal-950) 0%, var(--teal-800) 100%);
    padding: var(--space-16) var(--space-6) var(--space-12);
    text-align: center;
}
.page_hero_label {
    font-size: var(--text-sm);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--amber-300);
    margin-bottom: var(--space-4);
}
.page_hero_title {
    font-family: var(--font-display);
    font-size: clamp(var(--text-4xl), 5vw, 3.5rem);
    font-weight: 700;
    color: #fff;
    line-height: 1.1;
    letter-spacing: -0.025em;
    margin-bottom: var(--space-5);
}
.page_hero_sub {
    font-size: var(--text-2xl);
    color: var(--teal-200);
    line-height: 1.65;
    max-width: 38rem;
    margin: 0 auto;
}

/* ================================================================
   CTA SECTION
   Gradient call-to-action block — home, waitlist.
================================================================ */
.cta_section {
    background: linear-gradient(135deg, var(--teal-900), var(--teal-700));
    padding: var(--space-20) var(--space-6);
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta_section::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at 50% 50%, rgba(245,158,11,.08) 0%, transparent 70%);
    pointer-events: none;
}
.cta_title {
    font-family: var(--font-display);
    font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.025em;
    margin-bottom: var(--space-5);
    position: relative;
}
.cta_sub {
    font-size: var(--text-2xl);
    color: var(--teal-200);
    max-width: 38rem;
    margin: 0 auto var(--space-8);
    line-height: 1.65;
    position: relative;
}
.cta_actions {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-4);
    position: relative;
}

/* ================================================================
   CTA BANNER
   Rounded gradient banner — home, about.
================================================================ */
.cta_banner {
    background: linear-gradient(135deg, var(--teal-800) 0%, var(--teal-600) 100%);
    border-radius: var(--radius-xl);
    padding: var(--space-12) var(--space-8);
    text-align: center;
    box-shadow: var(--shadow-lg);
    position: relative;
    overflow: hidden;
}
.cta_banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 70% 50%, rgba(245,158,11,.08) 0%, transparent 70%);
    pointer-events: none;
}
.cta_banner_title {
    font-family: var(--font-display);
    font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.025em;
    margin-bottom: var(--space-4);
    position: relative;
}
.cta_banner_body {
    font-size: var(--text-2xl);
    color: var(--teal-200);
    margin-bottom: var(--space-8);
    max-width: 32rem;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.65;
    position: relative;
}
.cta_banner_actions {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-4);
    position: relative;
}

/* ================================================================
   PRICING CARDS
   Shared by waitlist and pricing pages.
================================================================ */
.pricing_grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
    align-items: stretch;
}
@media (max-width: 900px) { .pricing_grid { grid-template-columns: 1fr; max-width: 28rem; margin: 0 auto; } }

.pricing_card {
    background: var(--surface);
    border: var(--border-thin) solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-7) var(--space-6);
    display: flex;
    flex-direction: column;
    transition: box-shadow var(--t), transform var(--t);
}
.pricing_card.featured {
    background: var(--teal-900);
    border-color: transparent;
    box-shadow: var(--shadow-xl);
    transform: scale(1.03);
    color: #fff;
}
.pricing_card:not(.featured):hover { box-shadow: var(--shadow-md); }

.pricing_badge {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--amber-400);
    margin-bottom: var(--space-3);
}
.pricing_name {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--teal-900);
    margin-bottom: var(--space-2);
}
.pricing_card.featured .pricing_name { color: #fff; }
.pricing_amount {
    font-family: var(--font-display);
    font-size: var(--text-5xl);
    font-weight: 700;
    color: var(--teal-900);
    line-height: 1;
    letter-spacing: -0.03em;
    margin-bottom: var(--space-1);
}
.pricing_card.featured .pricing_amount { color: var(--amber-300); }
.pricing_amount_currency { font-size: .45em; vertical-align: super; font-weight: 600; }
.pricing_period {
    font-size: var(--text-sm);
    color: var(--slate-400);
    margin-bottom: var(--space-5);
}
.pricing_card.featured .pricing_period { color: var(--teal-300); }
.pricing_desc {
    font-size: var(--text-md);
    color: var(--slate-500);
    line-height: 1.6;
    margin-bottom: var(--space-5);
}
.pricing_card.featured .pricing_desc { color: var(--teal-200); }
.pricing_features {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    flex: 1;
    margin-bottom: var(--space-6);
}
.pricing_features li {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2-5);
    font-size: var(--text-md);
    color: var(--slate-600);
    line-height: 1.5;
}
.pricing_card.featured .pricing_features li { color: var(--teal-200); }
.pricing_features li i { color: var(--teal-500); flex-shrink: 0; margin-top: var(--space-0-5); }
.pricing_card.featured .pricing_features li i { color: var(--amber-400); }

/* ================================================================
   PROSE (about page long-form content)
================================================================ */
.mkt_prose { max-width: 48rem; margin: 0 auto; }
.mkt_prose h2 {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: var(--teal-900);
    letter-spacing: -0.02em;
    margin-top: var(--space-8);
    margin-bottom: var(--space-3);
}
.mkt_prose h3 {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--teal-800);
    margin-top: var(--space-6);
    margin-bottom: var(--space-2);
}
.mkt_prose p {
    font-size: var(--text-lg);
    color: var(--slate-600);
    line-height: 1.8;
    margin-bottom: var(--space-4);
}
.mkt_prose ul,
.mkt_prose ol {
    margin: var(--space-3) 0 var(--space-5) var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.mkt_prose li { font-size: var(--text-md); color: var(--slate-600); line-height: 1.7; }

/* ================================================================
   LEGAL BODY (privacy + terms pages)
================================================================ */
.legal_body {
    max-width: 48rem;
    margin: var(--space-10) auto var(--space-16);
    padding: 0 var(--space-6);
}
.legal_body h2 {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--teal-900);
    margin-top: var(--space-8);
    margin-bottom: var(--space-3);
}
.legal_body p {
    font-size: var(--text-md);
    color: var(--slate-600);
    line-height: 1.8;
    margin-bottom: var(--space-4);
}
.legal_body ul,
.legal_body ol {
    margin: var(--space-3) 0 var(--space-5) var(--space-5);
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.legal_body li { font-size: var(--text-md); color: var(--slate-600); line-height: 1.7; }
.legal_h1 {
    font-family: var(--font-display);
    font-size: clamp(var(--text-4xl), 4vw, var(--text-5xl));
    font-weight: 700;
    color: var(--teal-900);
    letter-spacing: -0.025em;
    margin-bottom: var(--space-3);
}
.legal_meta { font-size: var(--text-md); color: var(--slate-400); margin-bottom: var(--space-8); }

/* ================================================================
   MARKETING FORM CARD (contact + waitlist pages)
================================================================ */
.mkt_form_card {
    background: var(--surface);
    border: var(--border-thin) solid var(--border);
    border-radius: var(--radius-xl);
    padding: var(--space-8) var(--space-7);
    max-width: 36rem;
    margin: 0 auto;
    box-shadow: var(--shadow-sm);
}
@media (max-width: 480px) {
    .mkt_form_card { padding: var(--space-6) var(--space-5); border-radius: var(--radius-lg); }
}
.mkt_form_card_title {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: var(--teal-900);
    letter-spacing: -0.02em;
    margin-bottom: var(--space-2);
}
.mkt_form_card_sub {
    font-size: var(--text-md);
    color: var(--slate-500);
    line-height: 1.6;
    margin-bottom: var(--space-6);
}
