/* ==========================================================================
   CertBoost — Component Layer
   Every class is prefixed `cb-` so we never collide with Bootstrap / pbmit.
   Pages opt in by wrapping a section in `.cb` and using these utilities.
   ========================================================================== */

/* ----- Opt-in scope helper --------------------------------------------- */
.cb { color: var(--cb-text); font-size: var(--cb-t-base); line-height: 1.55; }
.cb a { color: var(--cb-primary); text-decoration: none; transition: color var(--cb-dur) var(--cb-ease); }
.cb a:hover { color: var(--cb-primary-hover); }

/* ----- Container -------------------------------------------------------- */
.cb-container { max-width: var(--cb-container-max); margin: 0 auto; padding-left: var(--cb-gutter); padding-right: var(--cb-gutter); }

/* ----- Section / vertical rhythm --------------------------------------- */
.cb-section      { padding-top: var(--cb-s-12); padding-bottom: var(--cb-s-12); }
.cb-section--sm  { padding-top: var(--cb-s-8);  padding-bottom: var(--cb-s-8); }
.cb-section--lg  { padding-top: var(--cb-s-16); padding-bottom: var(--cb-s-16); }
.cb-section--dark{ background: var(--cb-grad-hero); color: var(--cb-text-invert); }
.cb-section--soft{ background: var(--cb-bg-subtle); }

/* ----- Typography ------------------------------------------------------- */
.cb-eyebrow { display:inline-block; font-size: var(--cb-t-xs); font-weight:700; letter-spacing:.14em; text-transform:uppercase; color: var(--cb-primary); padding:6px 12px; background: var(--cb-blue-50); border-radius: var(--cb-r-pill); }
.cb-h1 { font-size: var(--cb-t-3xl); font-weight: 700; line-height: 1.08; letter-spacing: -.02em; color: var(--cb-text-strong); margin: 0 0 var(--cb-s-4); }
.cb-h2 { font-size: var(--cb-t-2xl); font-weight: 700; line-height: 1.15; letter-spacing: -.015em; color: var(--cb-text-strong); margin: 0 0 var(--cb-s-3); }
.cb-h3 { font-size: var(--cb-t-xl);  font-weight: 600; line-height: 1.3;  color: var(--cb-text-strong); margin: 0 0 var(--cb-s-2); }
.cb-lead { font-size: var(--cb-t-lg); color: var(--cb-text-muted); line-height: 1.55; margin: 0 0 var(--cb-s-5); max-width: 62ch; }
.cb-muted { color: var(--cb-text-muted); }
.cb-gradient-text { background: var(--cb-grad-primary); -webkit-background-clip: text; background-clip: text; color: transparent; }

.cb-section--dark .cb-h1,
.cb-section--dark .cb-h2,
.cb-section--dark .cb-h3 { color: #fff; }
.cb-section--dark .cb-lead { color: var(--cb-slate-300); }

/* ----- Buttons ---------------------------------------------------------- */
.cb-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 20px; font-size: .9rem; font-weight: 600; line-height: 1;
    border-radius: var(--cb-r-md); border: 1px solid transparent;
    cursor: pointer; text-decoration: none; white-space: nowrap;
    transition: transform var(--cb-dur-fast) var(--cb-ease),
                background-color var(--cb-dur) var(--cb-ease),
                box-shadow var(--cb-dur) var(--cb-ease),
                color var(--cb-dur) var(--cb-ease);
}
.cb-btn:active { transform: scale(.98); }
.cb-btn:focus-visible { outline: none; box-shadow: var(--cb-ring); }
.cb-btn--primary { background: var(--cb-grad-primary); color: #fff; }
.cb-btn--primary:hover { color:#fff; box-shadow: 0 8px 20px rgba(59,130,246,.35); transform: translateY(-1px); }
.cb-btn--secondary { background: var(--cb-bg-mute); color: var(--cb-text-strong); }
.cb-btn--secondary:hover { background: var(--cb-slate-200); color: var(--cb-text-strong); }
.cb-btn--ghost { background: transparent; color: var(--cb-text-strong); border-color: var(--cb-border); }
.cb-btn--ghost:hover { background: var(--cb-bg-subtle); color: var(--cb-text-strong); }
.cb-btn--danger { background: var(--cb-red-500); color: #fff; }
.cb-btn--danger:hover { background: var(--cb-red-600); color: #fff; }
.cb-btn--invert { background: rgba(255,255,255,.1); color: #fff; border-color: rgba(255,255,255,.2); }
.cb-btn--invert:hover { background: rgba(255,255,255,.18); color:#fff; }
.cb-btn--sm { padding: 7px 14px; font-size: .82rem; }
.cb-btn--lg { padding: 14px 28px; font-size: 1rem; }
.cb-btn--block { width: 100%; }

/* ----- Card ------------------------------------------------------------- */
.cb-card { background: var(--cb-bg); border: 1px solid var(--cb-border-soft); border-radius: var(--cb-r-lg); box-shadow: var(--cb-e2); overflow: hidden; transition: transform var(--cb-dur) var(--cb-ease), box-shadow var(--cb-dur) var(--cb-ease); }
.cb-card--hover:hover { transform: translateY(-2px); box-shadow: var(--cb-e3); }
.cb-card--pad { padding: var(--cb-s-6); }
.cb-card__head { padding: var(--cb-s-4) var(--cb-s-6); border-bottom: 1px solid var(--cb-border-soft); display:flex; align-items:center; gap: 10px; }
.cb-card__head .cb-card__title { font-size: var(--cb-t-base); font-weight: 600; color: var(--cb-text-strong); margin: 0; }
.cb-card__head .cb-card__subtitle { font-size: var(--cb-t-sm); color: var(--cb-text-muted); margin-left: auto; }
.cb-card__body { padding: var(--cb-s-6); }
.cb-card__foot { padding: var(--cb-s-4) var(--cb-s-6); background: var(--cb-bg-subtle); border-top: 1px solid var(--cb-border-soft); display:flex; justify-content:flex-end; gap: 10px; }

/* ----- KPI tile --------------------------------------------------------- */
.cb-kpi { background: var(--cb-bg); border: 1px solid var(--cb-border-soft); border-radius: var(--cb-r-lg); padding: var(--cb-s-5); box-shadow: var(--cb-e1); }
.cb-kpi__label { font-size: var(--cb-t-xs); color: var(--cb-text-muted); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.cb-kpi__value { font-size: var(--cb-t-2xl); font-weight: 700; color: var(--cb-text-strong); line-height: 1; margin-top: 6px; letter-spacing: -.01em; }
.cb-kpi__delta { font-size: var(--cb-t-sm); font-weight: 600; margin-top: 6px; display: inline-flex; align-items: center; gap: 4px; }
.cb-kpi__delta--up   { color: var(--cb-green-600); }
.cb-kpi__delta--down { color: var(--cb-red-600); }

.cb-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--cb-s-4); }

/* ----- Badges / pills --------------------------------------------------- */
.cb-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; font-size: var(--cb-t-xs); font-weight: 700; letter-spacing: .04em; text-transform: uppercase; border-radius: var(--cb-r-pill); }
.cb-badge--neutral { background: var(--cb-bg-mute); color: var(--cb-slate-700); }
.cb-badge--brand   { background: var(--cb-blue-100); color: var(--cb-blue-700); }
.cb-badge--success { background: var(--cb-green-100); color: var(--cb-green-600); }
.cb-badge--warn    { background: var(--cb-amber-100); color: #92400e; }
.cb-badge--danger  { background: var(--cb-red-100); color: var(--cb-red-600); }
.cb-badge--invert  { background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.2); }

/* ----- Empty state ------------------------------------------------------ */
.cb-empty { text-align: center; padding: var(--cb-s-10) var(--cb-s-6); color: var(--cb-text-muted); }
.cb-empty__icon { width: 72px; height: 72px; border-radius: 50%; background: var(--cb-bg-mute); display: inline-flex; align-items: center; justify-content: center; color: var(--cb-text-faint); font-size: 28px; margin-bottom: var(--cb-s-4); }
.cb-empty__title { font-size: var(--cb-t-lg); font-weight: 600; color: var(--cb-text-strong); margin-bottom: 4px; }
.cb-empty__desc  { font-size: var(--cb-t-sm); color: var(--cb-text-muted); max-width: 40ch; margin: 0 auto var(--cb-s-4); }

/* ----- Skeleton --------------------------------------------------------- */
@keyframes cb-skel-pulse {
    0%   { background-position: -400px 0; }
    100% { background-position: 400px 0; }
}
.cb-skel {
    display: block; border-radius: var(--cb-r-sm); height: 14px;
    background: linear-gradient(90deg, var(--cb-slate-100) 0%, var(--cb-slate-200) 40%, var(--cb-slate-100) 80%);
    background-size: 800px 100%;
    animation: cb-skel-pulse 1.4s ease-in-out infinite;
}
.cb-skel--lg { height: 22px; }
.cb-skel--xl { height: 36px; }
.cb-skel--circle { border-radius: 50%; }

/* ----- Toast ------------------------------------------------------------ */
.cb-toast {
    padding: 14px 18px; border-radius: var(--cb-r-md);
    display: flex; align-items: center; gap: 10px;
    font-size: var(--cb-t-sm); font-weight: 500;
    border-left: 4px solid var(--cb-slate-400);
    background: #fff; box-shadow: var(--cb-e2);
    animation: cb-toast-in var(--cb-dur-slow) var(--cb-ease) both;
}
.cb-toast--success { background: var(--cb-green-50); color: #065f46; border-left-color: var(--cb-green-500); }
.cb-toast--error   { background: var(--cb-red-50);   color: #991b1b; border-left-color: var(--cb-red-500); }
.cb-toast--info    { background: var(--cb-blue-50);  color: #1e40af; border-left-color: var(--cb-blue-500); }
.cb-toast--warn    { background: #fffbeb;            color: #92400e; border-left-color: var(--cb-amber-500); }
@keyframes cb-toast-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ----- Slim page header (replacement for pbmit title-bar) --------------
   NOTE: pbmit's site-header is position:absolute and sits ON TOP of this
   section. We therefore need (a) a dark background so the menu stays
   legible, and (b) top-padding > header height (~165px desktop, ~90px
   mobile) so the actual page-header content isn't hidden under the menu.
*/
.cb-page-header {
    background: var(--cb-grad-hero);
    color: #fff;
    padding: 180px 0 48px;
    position: relative;
    overflow: hidden;
}
.cb-page-header::before {
    content: ''; position: absolute; inset: 0; z-index: 0;
    background:
        radial-gradient(circle at 85% 40%, rgba(59,130,246,.25), transparent 55%),
        radial-gradient(circle at 15% 90%, rgba(139,92,246,.18), transparent 55%);
    pointer-events: none;
}
.cb-page-header > .cb-container { position: relative; z-index: 1; }
.cb-page-header__crumbs { font-size: var(--cb-t-xs); color: rgba(255,255,255,.7); margin-bottom: var(--cb-s-3); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.cb-page-header__crumbs a { color: rgba(255,255,255,.7); }
.cb-page-header__crumbs a:hover { color: #fff; }
.cb-page-header__crumbs .sep { opacity: .4; }
.cb-page-header__row { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--cb-s-5); flex-wrap: wrap; }
.cb-page-header__title { font-size: var(--cb-t-3xl); font-weight: 700; color: #fff; margin: 0; letter-spacing: -.015em; line-height: 1.1; }
.cb-page-header__sub   { font-size: var(--cb-t-base); color: var(--cb-slate-300); margin-top: 10px; max-width: 72ch; }
.cb-page-header__actions { display: flex; gap: 10px; flex-shrink: 0; }
.cb-page-header__actions .cb-btn--ghost { color: #fff; border-color: rgba(255,255,255,.25); background: rgba(255,255,255,.05); }
.cb-page-header__actions .cb-btn--ghost:hover { background: rgba(255,255,255,.15); color: #fff; }
@media (max-width: 1199px) {
    .cb-page-header { padding-top: 120px; padding-bottom: 36px; }
}
@media (max-width: 767px) {
    .cb-page-header { padding-top: 100px; padding-bottom: 28px; }
}

/* ----- Dark hero (reuses existing authorized-area signature) ----------- */
.cb-hero-dark { background: var(--cb-grad-hero); color: #fff; border-radius: var(--cb-r-xl); padding: var(--cb-s-8) var(--cb-s-8); position: relative; overflow: hidden; }
.cb-hero-dark::before { content: ''; position: absolute; top: 0; right: 0; width: 360px; height: 100%; background: radial-gradient(circle at top right, rgba(59,130,246,.18), transparent 70%); }
.cb-hero-dark > * { position: relative; z-index: 1; }

/* ----- Form controls (opt-in) ------------------------------------------ */
.cb-field { display: flex; flex-direction: column; }
.cb-field > label { font-size: var(--cb-t-xs); font-weight: 600; color: var(--cb-slate-600); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .3px; }
.cb-field > input,
.cb-field > select,
.cb-field > textarea {
    width: 100%; padding: 10px 14px; border: 1px solid var(--cb-border); border-radius: var(--cb-r-md);
    font-size: .92rem; color: var(--cb-text-strong); background: #fff;
    transition: border-color var(--cb-dur) var(--cb-ease), box-shadow var(--cb-dur) var(--cb-ease);
}
.cb-field > input:focus,
.cb-field > select:focus,
.cb-field > textarea:focus { outline: none; border-color: var(--cb-primary); box-shadow: var(--cb-ring); }
.cb-field > .hint { font-size: var(--cb-t-xs); color: var(--cb-text-faint); margin-top: 4px; }

/* ----- Motion utilities ------------------------------------------------- */
@keyframes cb-fade-up {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cb-anim-fade-up { animation: cb-fade-up var(--cb-dur-slow) var(--cb-ease) both; }
.cb-anim-stagger > * { animation: cb-fade-up var(--cb-dur-slow) var(--cb-ease) both; opacity: 0; }
.cb-anim-stagger > *:nth-child(1) { animation-delay: 40ms;  }
.cb-anim-stagger > *:nth-child(2) { animation-delay: 80ms;  }
.cb-anim-stagger > *:nth-child(3) { animation-delay: 120ms; }
.cb-anim-stagger > *:nth-child(4) { animation-delay: 160ms; }
.cb-anim-stagger > *:nth-child(5) { animation-delay: 200ms; }
.cb-anim-stagger > *:nth-child(6) { animation-delay: 240ms; }
.cb-anim-stagger > *:nth-child(7) { animation-delay: 280ms; }
.cb-anim-stagger > *:nth-child(8) { animation-delay: 320ms; }
.cb-anim-stagger > *:nth-child(9) { animation-delay: 360ms; }
.cb-anim-stagger > *:nth-child(10){ animation-delay: 400ms; }
.cb-anim-stagger > *:nth-child(11){ animation-delay: 440ms; }
.cb-anim-stagger > *:nth-child(12){ animation-delay: 480ms; }

/* ----- Feature tile ---------------------------------------------------- */
.cb-feat { padding: var(--cb-s-6); border-radius: var(--cb-r-lg); background: #fff; border: 1px solid var(--cb-border-soft); transition: transform var(--cb-dur) var(--cb-ease), box-shadow var(--cb-dur) var(--cb-ease), border-color var(--cb-dur) var(--cb-ease); }
.cb-feat:hover { transform: translateY(-3px); box-shadow: var(--cb-e3); border-color: var(--cb-blue-100); }
.cb-feat__icon { width: 48px; height: 48px; border-radius: 12px; background: var(--cb-grad-primary); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 22px; margin-bottom: var(--cb-s-4); }
.cb-feat__title { font-size: var(--cb-t-lg); font-weight: 600; color: var(--cb-text-strong); margin: 0 0 6px; }
.cb-feat__desc { font-size: var(--cb-t-sm); color: var(--cb-text-muted); line-height: 1.55; margin: 0; }

/* ----- Pricing card --------------------------------------------------- */
.cb-plan { display:flex; flex-direction:column; gap: 14px; padding: var(--cb-s-6); background: #fff; border: 1px solid var(--cb-border); border-radius: var(--cb-r-lg); position: relative; transition: transform var(--cb-dur) var(--cb-ease), box-shadow var(--cb-dur) var(--cb-ease); }
.cb-plan--featured { border-color: var(--cb-blue-500); box-shadow: 0 0 0 2px rgba(59,130,246,.15); transform: translateY(-4px); }
.cb-plan__ribbon { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background: var(--cb-grad-primary); color:#fff; font-size: var(--cb-t-xs); font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 4px 14px; border-radius: var(--cb-r-pill); }
.cb-plan__name { font-size: var(--cb-t-lg); font-weight: 700; color: var(--cb-text-strong); }
.cb-plan__price { display:flex; align-items:baseline; gap: 4px; }
.cb-plan__price-amount { font-size: var(--cb-t-3xl); font-weight: 700; color: var(--cb-text-strong); line-height: 1; letter-spacing: -.02em; }
.cb-plan__price-period { font-size: var(--cb-t-sm); color: var(--cb-text-muted); }
.cb-plan__desc { font-size: var(--cb-t-sm); color: var(--cb-text-muted); min-height: 40px; }
.cb-plan__features { list-style: none; margin: 0; padding: 0; display:flex; flex-direction:column; gap: 8px; }
.cb-plan__features li { font-size: var(--cb-t-sm); color: var(--cb-text); display:flex; align-items:flex-start; gap: 8px; }
.cb-plan__features li::before { content: '✓'; flex-shrink: 0; width: 18px; height: 18px; border-radius: 50%; background: var(--cb-green-100); color: var(--cb-green-600); display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; margin-top: 1px; }
.cb-plan__features li.na { color: var(--cb-text-faint); }
.cb-plan__features li.na::before { content:'–'; background: var(--cb-bg-mute); color: var(--cb-text-faint); }

/* ----- Long-form (blog / legal) ---------------------------------------- */
.cb-longform { max-width: 72ch; margin: 0 auto; color: var(--cb-text); font-size: var(--cb-t-base); line-height: 1.75; }
.cb-longform h1, .cb-longform h2, .cb-longform h3, .cb-longform h4 { color: var(--cb-text-strong); font-weight: 700; letter-spacing: -.01em; margin: var(--cb-s-6) 0 var(--cb-s-3); }
.cb-longform h1 { font-size: var(--cb-t-2xl); }
.cb-longform h2 { font-size: var(--cb-t-xl); }
.cb-longform h3 { font-size: var(--cb-t-lg); }
.cb-longform p  { margin: 0 0 var(--cb-s-4); }
.cb-longform a  { color: var(--cb-primary); text-decoration: underline; text-underline-offset: 3px; }
.cb-longform ul, .cb-longform ol { margin: 0 0 var(--cb-s-4); padding-left: 1.4em; }
.cb-longform li { margin-bottom: 6px; }
.cb-longform blockquote { margin: var(--cb-s-5) 0; padding: var(--cb-s-4) var(--cb-s-5); border-left: 4px solid var(--cb-primary); background: var(--cb-bg-subtle); border-radius: var(--cb-r-sm); color: var(--cb-text-strong); font-size: var(--cb-t-lg); font-style: italic; }
.cb-longform code { background: var(--cb-bg-mute); padding: 2px 6px; border-radius: 4px; font-size: .92em; }
.cb-longform img { max-width: 100%; height: auto; border-radius: var(--cb-r-md); margin: var(--cb-s-5) 0; }
.cb-longform hr { border: 0; border-top: 1px solid var(--cb-border-soft); margin: var(--cb-s-6) 0; }

.cb-toc { position: sticky; top: 100px; padding: var(--cb-s-4); background: var(--cb-bg-subtle); border: 1px solid var(--cb-border-soft); border-radius: var(--cb-r-md); font-size: var(--cb-t-sm); }
.cb-toc__title { font-size: var(--cb-t-xs); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--cb-text-muted); margin: 0 0 10px; }
.cb-toc ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.cb-toc a { color: var(--cb-text); text-decoration: none; }
.cb-toc a:hover { color: var(--cb-primary); }

/* ----- Responsive ------------------------------------------------------- */
@media (max-width: 768px) {
    .cb-section      { padding-top: var(--cb-s-8); padding-bottom: var(--cb-s-8); }
    .cb-section--lg  { padding-top: var(--cb-s-10); padding-bottom: var(--cb-s-10); }
    .cb-page-header__row { flex-direction: column; align-items: flex-start; }
    .cb-page-header__actions { width: 100%; }
    .cb-page-header__actions .cb-btn { flex: 1; }
    .cb-hero-dark { padding: var(--cb-s-6); }
}

/* ==========================================================================
   Account / Dashboard shared UI
   Used by CSubscriptions, CPayments, CNotification, Identity/Manage, etc.
   ========================================================================== */
.cb-dash-wrap  { padding: 28px 0 48px; background: var(--cb-bg-subtle); min-height: 60vh; }
.cb-dash-grid  { display: grid; grid-template-columns: 260px 1fr; gap: 28px; align-items: flex-start; }
.cb-dash-main  { display: flex; flex-direction: column; gap: 22px; min-width: 0; }
.cb-dash-side  { position: sticky; top: 88px; display: flex; flex-direction: column; gap: 16px; }

.cb-dash-head  { display:flex; align-items:center; justify-content:space-between; gap:14px; margin-bottom:6px; flex-wrap:wrap; }
.cb-dash-head h1 { font-size: clamp(1.6rem, 1.2rem + 1vw, 2.1rem); font-weight:800; color:var(--cb-text-strong); margin:0; letter-spacing:-.02em; }
.cb-dash-head p  { margin:4px 0 0; color:var(--cb-text-muted); font-size:var(--cb-t-sm); }

/* --- KPI tiles --- */
.cb-kpi-row { display:grid; grid-template-columns:repeat(4, 1fr); gap:16px; }
.cb-kpi-tile {
    background:#fff; border:1px solid var(--cb-border-soft); border-radius: var(--cb-r-lg);
    padding:18px 20px; display:flex; align-items:center; gap:14px;
    transition: transform .2s, box-shadow .2s, border-color .2s;
}
.cb-kpi-tile:hover { transform:translateY(-2px); box-shadow: var(--cb-e2); border-color: var(--cb-blue-100); }
.cb-kpi-tile__icon {
    width:44px; height:44px; border-radius:12px; flex-shrink:0;
    display:inline-flex; align-items:center; justify-content:center; color:#fff;
    box-shadow: 0 6px 14px -4px rgba(0,0,0,.2);
}
.cb-kpi-tile__icon--blue    { background: linear-gradient(135deg,#3b82f6,#1d4ed8); }
.cb-kpi-tile__icon--violet  { background: linear-gradient(135deg,#8b5cf6,#6d28d9); }
.cb-kpi-tile__icon--emerald { background: linear-gradient(135deg,#10b981,#047857); }
.cb-kpi-tile__icon--amber   { background: linear-gradient(135deg,#f59e0b,#b45309); }
.cb-kpi-tile__icon--rose    { background: linear-gradient(135deg,#ef4444,#be123c); }
.cb-kpi-tile__icon--cyan    { background: linear-gradient(135deg,#06b6d4,#0e7490); }
.cb-kpi-tile__label { font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color: var(--cb-text-muted); }
.cb-kpi-tile__value { font-size:1.25rem; font-weight:800; color: var(--cb-text-strong); line-height:1.2; letter-spacing:-.01em; margin-top:2px; word-break:break-word; }
.cb-kpi-tile__sub   { font-size:.74rem; color: var(--cb-text-muted); margin-top:2px; }

/* --- Panels / cards --- */
.cb-panel {
    background:#fff; border:1px solid var(--cb-border-soft); border-radius: var(--cb-r-xl);
    padding: 22px 24px;
}
.cb-panel__head {
    display:flex; align-items:center; justify-content:space-between; gap:10px;
    margin-bottom:16px; padding-bottom:14px; border-bottom:1px solid var(--cb-border-soft);
}
.cb-panel__title { font-size:1rem; font-weight:700; color:var(--cb-text-strong); margin:0; display:inline-flex; align-items:center; gap:8px; }
.cb-panel__title i { color:var(--cb-primary); }
.cb-panel__sub   { font-size:var(--cb-t-sm); color:var(--cb-text-muted); margin:0; }
.cb-panel--two   { display:grid; grid-template-columns: 1fr 1fr; gap:22px; }

/* --- Definition list --- */
.cb-dl { display:grid; grid-template-columns: 120px 1fr; gap: 10px 14px; margin:0; font-size:var(--cb-t-sm); }
.cb-dl dt { color: var(--cb-text-muted); font-weight:600; }
.cb-dl dd { margin:0; color: var(--cb-text-strong); font-weight:600; word-break:break-word; }

/* --- Data table --- */
.cb-tbl-wrap { overflow-x:auto; border:1px solid var(--cb-border-soft); border-radius: var(--cb-r-lg); }
.cb-tbl { width:100%; border-collapse: separate; border-spacing:0; font-size: var(--cb-t-sm); }
.cb-tbl thead th {
    background: var(--cb-bg-subtle); color: var(--cb-text-muted);
    font-weight:700; font-size:.7rem; text-transform:uppercase; letter-spacing:.08em;
    padding: 12px 16px; text-align:left; border-bottom:1px solid var(--cb-border-soft);
    white-space:nowrap;
}
.cb-tbl tbody td { padding: 14px 16px; border-bottom:1px solid var(--cb-border-soft); color:var(--cb-text); vertical-align:middle; }
.cb-tbl tbody tr:last-child td { border-bottom:0; }
.cb-tbl tbody tr:hover td { background: var(--cb-blue-50); }
.cb-tbl td b { color: var(--cb-text-strong); font-weight:700; }
.cb-tier-pill {
    display:inline-flex; align-items:center; gap:6px;
    font-size:.72rem; font-weight:800; padding:4px 10px; border-radius:999px;
    background: linear-gradient(135deg, var(--cb-blue-50), var(--cb-violet-100));
    color: var(--cb-blue-700); border:1px solid rgba(59,130,246,.18);
}
.cb-pill {
    display:inline-flex; align-items:center; gap:5px;
    font-size:.7rem; font-weight:800; padding:4px 10px; border-radius:999px;
    text-transform:uppercase; letter-spacing:.04em; white-space:nowrap;
}
.cb-pill::before { content:''; width:6px; height:6px; border-radius:50%; background: currentColor; opacity:.9; }
.cb-pill--paid    { background:#d1fae5; color:#065f46; }
.cb-pill--pending { background:#fef3c7; color:#92400e; }
.cb-pill--failed  { background:#fee2e2; color:#991b1b; }
.cb-pill--info    { background:#dbeafe; color:#1e40af; }
.cb-pill--open    { background:#dbeafe; color:#1e40af; }
.cb-pill--progress{ background:#ede9fe; color:#5b21b6; }
.cb-pill--resolved{ background:#d1fae5; color:#065f46; }
.cb-pill--closed  { background:#f1f5f9; color:#475569; }
.cb-pay { display:inline-flex; align-items:center; gap:8px; color: var(--cb-text); }
.cb-pay__icon { width:28px; height:28px; border-radius:6px; background:#f1f5f9; display:inline-flex; align-items:center; justify-content:center; color:#475569; flex-shrink:0; }
.cb-amount { font-weight:800; color:var(--cb-text-strong); font-variant-numeric: tabular-nums; }

/* --- Timeline --- */
.cb-timeline { position:relative; padding-left: 26px; margin:0; list-style:none; }
.cb-timeline::before {
    content:''; position:absolute; left:10px; top:6px; bottom:6px;
    width:2px; background: linear-gradient(180deg, var(--cb-blue-500), var(--cb-violet-500));
    opacity:.3; border-radius:99px;
}
.cb-timeline__item { position:relative; padding: 0 0 18px 18px; }
.cb-timeline__item:last-child { padding-bottom:0; }
.cb-timeline__dot {
    position:absolute; left:-24px; top:4px;
    width:20px; height:20px; border-radius:50%;
    background:#fff; border:3px solid var(--cb-blue-500);
    box-shadow: 0 0 0 4px rgba(59,130,246,.08);
}
.cb-timeline__dot--green  { border-color:#10b981; box-shadow: 0 0 0 4px rgba(16,185,129,.1); }
.cb-timeline__dot--amber  { border-color:#f59e0b; box-shadow: 0 0 0 4px rgba(245,158,11,.1); }
.cb-timeline__dot--violet { border-color:#8b5cf6; box-shadow: 0 0 0 4px rgba(139,92,246,.1); }
.cb-timeline__date { font-size:.72rem; font-weight:700; color:var(--cb-text-muted); text-transform:uppercase; letter-spacing:.05em; margin-bottom:3px; }
.cb-timeline__desc { font-size:.92rem; color: var(--cb-text-strong); line-height:1.5; margin:0; }
.cb-timeline__id { display:block; font-size:.68rem; color:var(--cb-text-faint); margin-top:3px; font-family: var(--cb-font-mono); }

/* --- Hero status card (dark gradient) --- */
.cb-status-hero {
    position:relative; overflow:hidden;
    background: var(--cb-grad-hero); color:#fff;
    border-radius: var(--cb-r-xl);
    padding: 28px 32px; box-shadow: var(--cb-e3);
}
.cb-status-hero::before {
    content:''; position:absolute; inset:0; pointer-events:none;
    background:
        radial-gradient(circle at 88% 18%, rgba(59,130,246,.35), transparent 55%),
        radial-gradient(circle at 8% 85%,  rgba(139,92,246,.28), transparent 55%);
}
.cb-status-hero > * { position:relative; z-index:1; }

/* --- Empty states --- */
.cb-empty-card {
    text-align:center; padding: 48px 24px;
    background: linear-gradient(135deg, var(--cb-blue-50), var(--cb-violet-100));
    border: 1px dashed rgba(59,130,246,.3);
    border-radius: var(--cb-r-xl);
}
.cb-empty-card__icon {
    width:72px; height:72px; border-radius:50%;
    background: linear-gradient(135deg, var(--cb-blue-500), var(--cb-violet-500));
    color:#fff; display:inline-flex; align-items:center; justify-content:center;
    margin-bottom:16px; box-shadow: 0 12px 28px -10px rgba(59,130,246,.5);
}
.cb-empty-card h3 { font-size:1.3rem; font-weight:700; color:var(--cb-text-strong); margin:0 0 8px; }
.cb-empty-card p  { color:var(--cb-text); margin:0 auto 20px; max-width: 46ch; line-height:1.6; }
.cb-empty-mini { padding:28px 20px; text-align:center; color: var(--cb-text-muted); font-size: var(--cb-t-sm); }
.cb-empty-mini i { display:block; width:32px; height:32px; margin:0 auto 10px; color: var(--cb-text-faint); }

/* --- Ticket / action card --- */
.cb-ticket {
    display:flex; gap:14px; align-items:flex-start;
    padding:16px 18px; border-radius: var(--cb-r-lg);
    border:1px solid var(--cb-border-soft); background:#fff;
    transition: background .15s, border-color .15s, transform .15s;
    color: inherit; text-decoration: none;
}
.cb-ticket:hover { background: var(--cb-blue-50); border-color: var(--cb-blue-100); transform:translateX(2px); }
.cb-ticket__icon {
    width:40px; height:40px; border-radius:12px; flex-shrink:0;
    display:inline-flex; align-items:center; justify-content:center;
    background:#f1f5f9; color:#475569;
}
.cb-ticket__body  { flex:1; min-width:0; }
.cb-ticket__head  { display:flex; align-items:center; justify-content:space-between; gap:8px; flex-wrap:wrap; margin-bottom:6px; }
.cb-ticket__title { font-size:.92rem; font-weight:700; color:var(--cb-text-strong); margin:0 0 2px; transition: color .15s; }
.cb-ticket__desc  { font-size:.86rem; color:var(--cb-text); line-height:1.5; margin:0; }
.cb-ticket__foot  { display:flex; gap:14px; margin-top:8px; font-size:.72rem; color:var(--cb-text-muted); font-weight:600; }
.cb-ticket__foot span { display:inline-flex; align-items:center; gap:4px; }
a.cb-ticket:hover .cb-ticket__title { color: var(--cb-primary); }

/* --- FAQ accordion (native <details>) --- */
.cb-faq-qa {
    background:#fff; border:1px solid var(--cb-border-soft); border-radius: var(--cb-r-lg);
    overflow:hidden; transition: box-shadow .2s, border-color .2s;
}
.cb-faq-qa[open] { border-color: var(--cb-blue-100); box-shadow: 0 10px 28px -14px rgba(59,130,246,.2); }
.cb-faq-qa summary {
    list-style: none; cursor:pointer;
    display:flex; align-items:center; justify-content:space-between; gap:16px;
    padding: 18px 22px;
    font-size: 1rem; font-weight:600; color: var(--cb-text-strong);
    transition: background .15s;
}
.cb-faq-qa summary::-webkit-details-marker { display:none; }
.cb-faq-qa summary:hover { background: var(--cb-blue-50); }
.cb-faq-qa[open] summary { background: var(--cb-blue-50); }
.cb-faq-qa__q { display:flex; align-items:center; gap:12px; flex:1; min-width:0; }
.cb-faq-qa__cat {
    width:36px; height:36px; border-radius:10px; flex-shrink:0;
    display:inline-flex; align-items:center; justify-content:center; color:#fff;
}
.cb-faq-qa__cat--start    { background: linear-gradient(135deg,#3b82f6,#1d4ed8); }
.cb-faq-qa__cat--billing  { background: linear-gradient(135deg,#f59e0b,#b45309); }
.cb-faq-qa__cat--security { background: linear-gradient(135deg,#10b981,#047857); }
.cb-faq-qa__cat--partner  { background: linear-gradient(135deg,#8b5cf6,#6d28d9); }
.cb-faq-qa__chev { color: var(--cb-text-muted); flex-shrink:0; transition: transform .25s, color .2s; }
.cb-faq-qa[open] .cb-faq-qa__chev { transform: rotate(180deg); color: var(--cb-primary); }
.cb-faq-qa__body {
    padding: 0 22px 22px 70px;
    font-size: .94rem; line-height:1.7; color: var(--cb-text);
}
.cb-faq-qa__body a { color: var(--cb-primary); font-weight:600; }
.cb-faq-qa__body strong { color: var(--cb-text-strong); font-weight:700; }
.cb-faq-qa__body em { font-style: normal; font-weight:700; color: var(--cb-text-strong); background: var(--cb-bg-mute); padding: 1px 6px; border-radius: 4px; font-size: .88em; }
.cb-faq-qa.is-hidden { display:none; }

/* --- Account-page responsive --- */
@media (max-width: 1100px) {
    .cb-kpi-row { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 960px) {
    .cb-dash-grid  { grid-template-columns: 1fr; }
    .cb-dash-side  { position: static; }
    .cb-panel--two { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
    .cb-kpi-row    { grid-template-columns: 1fr; }
    .cb-status-hero{ padding: 22px 20px; }
    .cb-panel      { padding: 18px 18px; }
    .cb-dl         { grid-template-columns: 1fr; gap:4px 0; }
    .cb-dl dt      { margin-top:8px; }
    .cb-faq-qa__body { padding-left: 22px; }
}

/* ==========================================================================
   Identity / Account Manage — shared UI
   Used by /Identity/Account/Manage/* pages
   ========================================================================== */
.cb-id-hero { display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.cb-id-avatar {
    width:74px; height:74px; border-radius:50%;
    display:inline-flex; align-items:center; justify-content:center;
    font-size:1.8rem; font-weight:800; color:#fff; letter-spacing:-.02em;
    background: linear-gradient(135deg, #3b82f6, #8b5cf6);
    box-shadow: 0 10px 24px -6px rgba(59,130,246,.5);
    flex-shrink:0;
}
.cb-id-hero__name { font-size: clamp(1.3rem, 1rem + .6vw, 1.6rem); font-weight:800; color:#fff; letter-spacing:-.01em; margin:0 0 4px; }
.cb-id-hero__mail { color:rgba(255,255,255,.75); font-size:.92rem; word-break:break-all; }
.cb-id-hero__meta { display:flex; gap:18px; flex-wrap:wrap; margin-top:10px; font-size:.78rem; color:rgba(255,255,255,.75); }
.cb-id-hero__meta span { display:inline-flex; align-items:center; gap:5px; }

/* Left-rail tabs (Profile / Email / Password / 2FA / Personal data) */
.cb-manage-nav { display:flex; flex-direction:column; gap:4px; list-style:none; padding:0; margin:0; }
.cb-manage-nav .nav-link {
    display:flex; align-items:center; gap:10px;
    padding:10px 14px; border-radius: 10px;
    color: var(--cb-text); font-size:.9rem; font-weight:600;
    text-decoration:none; transition: background .15s, color .15s;
}
.cb-manage-nav .nav-link:hover { background: var(--cb-blue-50); color: var(--cb-primary); }
.cb-manage-nav .nav-link.active {
    background: linear-gradient(135deg, var(--cb-blue-500), var(--cb-violet-500));
    color:#fff; box-shadow: 0 6px 16px -6px rgba(59,130,246,.45);
}
.cb-manage-nav .nav-link::before {
    content:''; width:6px; height:6px; border-radius:50%;
    background: currentColor; opacity:.5; flex-shrink:0;
}
.cb-manage-nav .nav-link.active::before { opacity:1; background:#fff; }

/* Identity form fields (richer than the base .cb-field) */
.cb-id-field { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.cb-id-field label { font-size:.8rem; font-weight:700; color:var(--cb-text-strong); letter-spacing:.02em; }
.cb-id-field input, .cb-id-field select, .cb-id-field textarea {
    width:100%; padding:10px 14px; font-size:.95rem;
    border:1px solid var(--cb-border); border-radius: 10px;
    background:#fff; color:var(--cb-text-strong);
    transition: border-color .15s, box-shadow .15s;
}
.cb-id-field input:focus, .cb-id-field select:focus, .cb-id-field textarea:focus {
    outline:none; border-color: var(--cb-primary); box-shadow: var(--cb-ring);
}
.cb-id-field input:disabled { background: var(--cb-bg-subtle); color: var(--cb-text-muted); cursor:not-allowed; }
.cb-id-field .cb-field-help { font-size:.76rem; color:var(--cb-text-muted); }
.cb-id-field .text-danger { font-size:.78rem; color: var(--cb-red-600); margin-top:2px; }
.cb-id-field .cb-input-row { position:relative; display:flex; align-items:center; }
.cb-id-field .cb-input-row input { padding-right:44px; }
.cb-id-field .cb-input-row .cb-input-badge {
    position:absolute; right:10px; display:inline-flex; align-items:center; justify-content:center;
    width:28px; height:28px; border-radius:8px;
    background: var(--cb-green-50); color:#059669;
}

/* Status message banner */
.cb-status-msg {
    padding:12px 16px; border-radius:10px; font-size:.88rem;
    background: var(--cb-green-50); border:1px solid var(--cb-green-100);
    color:#065f46; margin-bottom:18px;
    display:flex; align-items:center; gap:10px;
}
.cb-status-msg--error { background: var(--cb-red-50); border-color: var(--cb-red-100); color:#991b1b; }
.cb-status-msg--warn  { background:#fef3c7; border-color:#fde68a; color:#92400e; }

/* Two-column shell: nav + content */
.cb-manage-split {
    display:grid; grid-template-columns:220px 1fr; gap:22px; align-items:flex-start;
}
@media (max-width: 720px) { .cb-manage-split { grid-template-columns: 1fr; } }

/* Identity action row (2FA, ExternalLogins) */
.cb-id-action-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }

/* Connected providers table/list */
.cb-id-providers { display:flex; flex-direction:column; gap:10px; }
.cb-id-provider {
    display:flex; align-items:center; justify-content:space-between; gap:16px;
    padding:14px 16px; background:#fff; border:1px solid var(--cb-border-soft);
    border-radius: var(--cb-r-lg);
}
.cb-id-provider__info { display:flex; align-items:center; gap:12px; min-width:0; }
.cb-id-provider__icon {
    width:40px; height:40px; border-radius:10px;
    background: var(--cb-blue-50); color:var(--cb-primary);
    display:inline-flex; align-items:center; justify-content:center; flex-shrink:0;
}
.cb-id-provider__name { font-size:.95rem; font-weight:700; color:var(--cb-text-strong); }
.cb-id-provider__meta { font-size:.78rem; color:var(--cb-text-muted); }

/* Danger zone card */
.cb-danger-zone {
    background: var(--cb-red-50); border:1px solid var(--cb-red-100);
    border-radius: var(--cb-r-xl); padding: 22px 24px;
}
.cb-danger-zone h4 { margin:0 0 6px; color:#991b1b; font-size:1rem; font-weight:800; display:inline-flex; align-items:center; gap:8px; }
.cb-danger-zone p  { margin:0 0 14px; font-size:.86rem; color:#7f1d1d; }

/* ==========================================================================
   Auth pages — Login, Register, Forgot Password, Resend Confirmation, etc.
   ========================================================================== */
.cb-auth-wrap {
    min-height: calc(100vh - 120px);
    padding: 40px 0; background: var(--cb-bg-subtle);
    display: flex; align-items: center; justify-content: center;
}
.cb-auth-card {
    width: 100%; max-width: 1040px; margin: 0 20px;
    display: grid; grid-template-columns: 1fr 1fr;
    background: #fff; border-radius: 20px; overflow: hidden;
    box-shadow: 0 30px 80px -30px rgba(15,23,42,.25), 0 4px 14px -6px rgba(15,23,42,.08);
    border: 1px solid var(--cb-border-soft);
}
.cb-auth-card--narrow { max-width: 480px; grid-template-columns: 1fr; }

/* Left hero panel */
.cb-auth-hero {
    position:relative; padding: 48px 44px; color:#fff;
    background:
        radial-gradient(1000px 500px at 100% 0%, rgba(139,92,246,.45), transparent 55%),
        radial-gradient(800px 400px at 0% 100%, rgba(59,130,246,.45), transparent 55%),
        linear-gradient(160deg, #0b1220 0%, #111827 50%, #1e3a8a 100%);
    display:flex; flex-direction:column; justify-content:space-between; gap: 28px;
    min-height: 520px; overflow:hidden;
}
.cb-auth-hero::before {
    content:""; position:absolute; inset:0; opacity:.07; pointer-events:none;
    background-image: radial-gradient(circle at 25% 25%, #fff 1px, transparent 1px);
    background-size: 22px 22px;
}
.cb-auth-hero > * { position:relative; z-index:1; }
.cb-auth-hero__brand { display:inline-flex; align-items:center; gap:12px; font-size:1.02rem; font-weight:800; letter-spacing:-.01em; color:#fff; }
.cb-auth-hero__brand:hover { color:#fff; }
.cb-auth-hero__brand span { font-size:1.08rem; }
.cb-auth-hero__logo {
    width:40px; height:40px; object-fit: contain; display:block;
    padding:6px; background: rgba(255,255,255,.08); border-radius:10px;
    border:1px solid rgba(255,255,255,.1);
}
.cb-auth-hero__brand-dot {
    width:34px; height:34px; border-radius:10px;
    background: linear-gradient(135deg, #60a5fa, #a78bfa);
    display:inline-flex; align-items:center; justify-content:center;
    box-shadow: 0 10px 20px -6px rgba(96,165,250,.5);
}
.cb-auth-hero__title { font-size: clamp(1.6rem, 1.2rem + 1.3vw, 2.2rem); font-weight:800; letter-spacing:-.02em; line-height:1.15; margin:0; color:#fff; }
.cb-auth-hero__title em { font-style:normal; color:#60a5fa; }
.cb-auth-hero__copy { font-size:.95rem; color:rgba(255,255,255,.78); line-height:1.65; margin: 10px 0 0; }
.cb-auth-hero__list { list-style:none; padding:0; margin:18px 0 0; display:flex; flex-direction:column; gap:12px; }
.cb-auth-hero__list li { display:flex; align-items:flex-start; gap:10px; font-size:.9rem; color:rgba(255,255,255,.85); line-height:1.5; }
.cb-auth-hero__list li .cb-auth-check {
    flex-shrink:0; width:22px; height:22px; border-radius:50%;
    display:inline-flex; align-items:center; justify-content:center;
    background: rgba(96,165,250,.2); color:#93c5fd; margin-top:1px;
}
.cb-auth-hero__footer {
    display:flex; align-items:center; gap:12px;
    padding:14px 16px; border:1px solid rgba(255,255,255,.1);
    border-radius: 12px; background: rgba(255,255,255,.04);
    backdrop-filter: blur(8px);
}
.cb-auth-hero__avatar {
    width:36px; height:36px; border-radius:50%;
    background: linear-gradient(135deg, #60a5fa, #a78bfa);
    flex-shrink:0;
}
.cb-auth-hero__quote { font-size:.85rem; color:rgba(255,255,255,.85); line-height:1.5; margin:0; }
.cb-auth-hero__quote strong { color:#fff; }

/* Right form panel */
.cb-auth-body { padding: 48px 44px; display:flex; flex-direction:column; justify-content:center; }
.cb-auth-body__head { margin-bottom: 24px; }
.cb-auth-body__title { font-size: clamp(1.4rem, 1.2rem + .5vw, 1.8rem); font-weight:800; letter-spacing:-.02em; color:var(--cb-text-strong); margin:0 0 8px; }
.cb-auth-body__sub   { font-size:.92rem; color:var(--cb-text-muted); margin:0; line-height:1.5; }
.cb-auth-form { display:flex; flex-direction:column; gap:14px; }

/* Auth-specific field (similar to cb-id-field but with icon support) */
.cb-auth-field { position:relative; display:flex; flex-direction:column; gap:6px; }
.cb-auth-field label { font-size:.82rem; font-weight:700; color:var(--cb-text-strong); letter-spacing:.01em; }
.cb-auth-field-wrap { position:relative; display:flex; align-items:center; }
.cb-auth-field-wrap > i[data-lucide] {
    position:absolute; left:12px; width:18px; height:18px;
    color: var(--cb-text-muted); pointer-events:none;
}
.cb-auth-field input {
    width:100%; padding:12px 14px 12px 40px; font-size:.95rem;
    border:1px solid var(--cb-border); border-radius: 12px;
    background:#fff; color:var(--cb-text-strong);
    transition: border-color .15s, box-shadow .15s;
}
.cb-auth-field input:focus {
    outline:none; border-color: var(--cb-primary); box-shadow: var(--cb-ring);
}
.cb-auth-field .cb-field-help { font-size:.76rem; color:var(--cb-text-muted); }
.cb-auth-field .text-danger   { font-size:.78rem; color: var(--cb-red-600); margin-top:2px; }

/* Checkbox row */
.cb-auth-row {
    display:flex; align-items:center; justify-content:space-between;
    gap:12px; flex-wrap:wrap; font-size:.86rem;
}
.cb-auth-check-inline { display:inline-flex; align-items:center; gap:8px; color:var(--cb-text); font-weight:600; }
.cb-auth-check-inline input { width:16px; height:16px; accent-color: var(--cb-primary); }
.cb-auth-link { color: var(--cb-primary); font-weight:700; text-decoration:none; }
.cb-auth-link:hover { text-decoration: underline; }

/* Primary submit */
.cb-auth-submit {
    width:100%; padding:13px 18px; font-size:.98rem; font-weight:700;
    background: linear-gradient(135deg, var(--cb-blue-500), var(--cb-violet-500));
    color:#fff; border:0; border-radius: 12px; cursor:pointer;
    box-shadow: 0 10px 26px -12px rgba(59,130,246,.6);
    transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
}
.cb-auth-submit:hover { transform: translateY(-1px); filter: brightness(1.06); }
.cb-auth-submit:active { transform: translateY(0); }

/* Separator */
.cb-auth-sep {
    display:flex; align-items:center; gap:12px; margin: 20px 0 16px;
    font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color: var(--cb-text-muted);
}
.cb-auth-sep::before, .cb-auth-sep::after { content:""; flex:1; height:1px; background: var(--cb-border); }

/* Social buttons (stacked) */
.cb-auth-social { display:flex; flex-direction:column; gap:10px; }
.cb-auth-social__btn {
    display:inline-flex; align-items:center; justify-content:center; gap:10px;
    padding:11px 14px; font-size:.92rem; font-weight:700;
    background:#fff; color:var(--cb-text-strong);
    border:1px solid var(--cb-border); border-radius: 12px; cursor:pointer;
    text-decoration:none;
    transition: border-color .15s, background .15s;
}
.cb-auth-social__btn:hover { border-color: var(--cb-primary); background: var(--cb-blue-50); }
.cb-auth-social__btn i[data-lucide] { width:18px; height:18px; }

/* Footer links */
.cb-auth-footer {
    margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--cb-border-soft);
    font-size:.88rem; color: var(--cb-text-muted); text-align:center;
}
.cb-auth-footer a { color: var(--cb-primary); font-weight:700; text-decoration:none; }
.cb-auth-footer a:hover { text-decoration: underline; }

@media (max-width: 880px) {
    .cb-auth-card { grid-template-columns: 1fr; max-width: 520px; }
    .cb-auth-hero { display:none; }
    .cb-auth-body { padding: 40px 28px; }
}
@media (max-width: 480px) {
    .cb-auth-wrap { padding: 20px 0; }
    .cb-auth-body { padding: 32px 22px; }
}
