/**
 * PropFlagger — Homepage-specific styles
 * Exact match to pfg-home.html standalone.
 * Uses design tokens from theme-gold.css only.
 * @package PropFlagger
 */

/* ============================================================
   HERO
   ============================================================ */
.hero {
    position: relative;
    min-height: calc(100vh - 58px);
    display: flex;
    align-items: center;
    overflow: hidden;
    padding: 72px 0 80px;
}
.hero-grid {
    position: absolute; inset: 0; pointer-events: none;
    background-image:
        linear-gradient(rgba(201,168,76,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(201,168,76,.04) 1px, transparent 1px);
    background-size: 72px 72px;
    mask-image: radial-gradient(ellipse 80% 70% at 30% 30%, black 20%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 80% 70% at 30% 30%, black 20%, transparent 80%);
}
.hero-orb {
    position: absolute; top: -120px; left: -80px;
    width: 700px; height: 700px; border-radius: 50%; pointer-events: none;
    background: radial-gradient(ellipse at center, rgba(124,58,237,.14) 0%, transparent 70%);
}
.hero-orb2 {
    position: absolute; bottom: -200px; right: -100px;
    width: 500px; height: 500px; border-radius: 50%; pointer-events: none;
    background: radial-gradient(ellipse at center, rgba(201,168,76,.07) 0%, transparent 70%);
}
.hero-inner {
    position: relative; z-index: 2;
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
}
.hero-eyebrow-row { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }

.live-badge {
    display: inline-flex; align-items: center; gap: 5px;
    height: 22px; padding: 0 9px;
    font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
    color: var(--jade); background: var(--jade-d); border: 1px solid rgba(16,185,129,.2); border-radius: 99px;
}
.live-dot {
    width: 5px; height: 5px; border-radius: 50%; background: var(--jade);
    animation: hp-blink 1.5s ease-in-out infinite; flex-shrink: 0;
}
@keyframes hp-blink { 0%,100%{opacity:1} 50%{opacity:.3} }

.hero-title {
    font-family: var(--serif);
    font-size: clamp(2.6rem, 4.5vw, 4rem);
    font-weight: 700; line-height: 1.05; letter-spacing: -.01em;
    color: var(--t0); margin-bottom: 22px;
}
.hero-title em {
    font-style: normal;
    background: linear-gradient(120deg, var(--gold-l) 0%, var(--gold) 60%, #a06c20 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-desc { font-size: 16px; line-height: 1.75; color: var(--t2); max-width: 460px; margin-bottom: 32px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 44px; }

.trust-strip { display: flex; flex-wrap: wrap; gap: 20px; align-items: center; padding-top: 28px; border-top: 1px solid var(--border); }
.trust-item { display: flex; flex-direction: column; gap: 2px; }
.trust-val { font-family: var(--serif); font-size: 1.5rem; font-weight: 700; color: var(--t0); letter-spacing: -.02em; line-height: 1; }
.trust-label { font-size: 11px; font-weight: 500; color: var(--t3); letter-spacing: .04em; text-transform: uppercase; }
.trust-sep { width: 1px; height: 32px; background: var(--border); }

/* Screener card */
.screener-card {
    background: var(--ink2); border: 1px solid var(--border); border-radius: 22px;
    padding: 28px; position: relative; overflow: hidden;
    box-shadow: 0 0 40px rgba(201,168,76,.08), 0 8px 32px rgba(0,0,0,.5);
}
.screener-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold-l), transparent); opacity: .4;
}
.screener-title { font-family: var(--serif); font-size: 1.1rem; font-weight: 600; color: var(--t0); margin-bottom: 5px; }
.screener-sub { font-size: 12px; color: var(--t3); margin-bottom: 22px; }
.s-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.s-field { display: flex; flex-direction: column; gap: 5px; }
.s-label { font-size: 10.5px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--t3); }
.s-full { grid-column: 1/-1; }
.match-result {
    margin-top: 16px; padding: 14px 16px;
    background: linear-gradient(135deg, rgba(124,58,237,.08), rgba(201,168,76,.05));
    border: 1px solid var(--border-h); border-radius: 10px;
    display: flex; align-items: center; justify-content: space-between; font-size: 13px;
}
.match-result-label { color: var(--t2); }
.match-count { font-family: var(--serif); font-size: 1.3rem; font-weight: 700; color: var(--gold); }

/* ============================================================
   PAYOUT TICKER
   ============================================================ */
.payout-ticker {
    background: var(--ink2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
    height: 42px; display: flex; align-items: center; overflow: hidden; position: relative;
}
.ticker-label {
    flex-shrink: 0; padding: 0 20px; font-size: 10px; font-weight: 700; letter-spacing: .1em;
    text-transform: uppercase; color: var(--gold); white-space: nowrap;
    border-right: 1px solid var(--border); height: 100%; display: flex; align-items: center;
    background: var(--ink2); z-index: 2;
}
.ticker-track { display: flex; animation: hp-ticker 30s linear infinite; white-space: nowrap; }
.ticker-item {
    display: inline-flex; align-items: center; gap: 10px; padding: 0 28px;
    font-size: 12px; color: var(--t2); border-right: 1px solid var(--border);
}
.ticker-item strong { color: var(--jade); font-family: var(--mono); font-weight: 500; }
.ticker-item .tf { color: var(--t1); font-weight: 500; }
.tfade-l, .tfade-r { position: absolute; top: 0; bottom: 0; width: 60px; z-index: 1; pointer-events: none; }
.tfade-l { left: 0; background: linear-gradient(90deg, var(--ink2), transparent); }
.tfade-r { right: 0; background: linear-gradient(-90deg, var(--ink2), transparent); }
@keyframes hp-ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ============================================================
   SECTION HEADER — left-aligned with view-all
   ============================================================ */
.section-hd-split {
    display: flex; justify-content: space-between; align-items: flex-end;
    flex-wrap: wrap; gap: 16px; margin-bottom: 36px;
}

/* ============================================================
   FILTER TABS
   ============================================================ */
.filter-tabs {
    display: flex; flex-wrap: wrap; gap: 2px; padding: 4px;
    background: rgba(255,255,255,.03); border: 1px solid var(--border);
    border-radius: 10px; width: fit-content; margin-bottom: 36px;
}
.filter-tab {
    display: flex; align-items: center; gap: 6px; height: 34px; padding: 0 16px;
    font-size: 12.5px; font-weight: 500; color: var(--t3);
    border-radius: 7px; cursor: pointer; transition: all .15s; border: none; background: none;
}
.filter-tab:hover { color: var(--t1); background: rgba(255,255,255,.04); }
.filter-tab.active { color: var(--gold); background: var(--gold-d); border: 1px solid var(--gold-ln); }
.tab-count {
    height: 17px; min-width: 17px; padding: 0 5px; font-size: 10px; font-weight: 700;
    border-radius: 99px; background: rgba(255,255,255,.08); color: var(--t2);
    display: inline-flex; align-items: center; justify-content: center;
}
.filter-tab.active .tab-count { background: rgba(201,168,76,.2); color: var(--gold); }

/* ============================================================
   FIRM CARDS
   ============================================================ */
.firms-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 18px; }

.firm-card {
    background: var(--ink2); border: 1px solid var(--border); border-radius: 22px;
    overflow: hidden; display: flex; flex-direction: column; position: relative;
    transition: border-color .22s var(--ease-out), box-shadow .22s var(--ease-out), transform .22s var(--ease-out);
}
.firm-card:hover {
    border-color: var(--border-h);
    box-shadow: 0 0 40px rgba(201,168,76,.08), 0 8px 32px rgba(0,0,0,.5);
    transform: translateY(-4px);
}

.firm-card-accent { height: 3px; }
.ac-gold   { background: linear-gradient(90deg, var(--gold), var(--gold-l)); }
.ac-jade   { background: linear-gradient(90deg, var(--jade), #34d399); }
.ac-violet { background: linear-gradient(90deg, var(--purple), var(--violet)); }

.firm-rank {
    position: absolute; top: 16px; right: 16px;
    width: 32px; height: 32px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center; font-size: 14px;
}
.rk1 { background: rgba(245,158,11,.15); border: 1px solid rgba(245,158,11,.25); }
.rk2 { background: rgba(156,163,175,.1);  border: 1px solid rgba(156,163,175,.2); }
.rk3 { background: rgba(161,103,50,.12);  border: 1px solid rgba(161,103,50,.22); }
.rkn { background: rgba(255,255,255,.04); border: 1px solid var(--border); }
.rk-n { font-family: var(--mono); font-size: 11px; color: var(--t3); font-weight: 500; }

.firm-hdr { padding: 20px 20px 16px; display: flex; align-items: flex-start; gap: 14px; border-bottom: 1px solid var(--border); }
.firm-logo {
    width: 48px; height: 48px; flex-shrink: 0; border-radius: 10px;
    background: var(--ink4); border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.firm-logo img { width: 100%; height: 100%; object-fit: contain; }
.firm-logo-pl { font-family: var(--serif); font-size: 16px; font-weight: 700; color: var(--gold); }
.firm-hdr-info { flex: 1; min-width: 0; }
.firm-name { font-family: var(--serif); font-size: 1.05rem; font-weight: 700; color: var(--t0); margin-bottom: 5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.firm-tags { display: flex; flex-wrap: wrap; gap: 5px; }

.star-row { display: flex; align-items: center; gap: 6px; margin-top: 5px; }
.stars { display: flex; gap: 1.5px; }
.star,.star-h,.star-e { width: 12px; height: 12px; background: no-repeat center/contain; }
.star   { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 1l1.3 2.7L10.5 4l-2.2 2.2.5 3L6 7.7 3.2 9.2l.5-3L1.5 4l3.2-.3z' fill='%23c9a84c'/%3E%3C/svg%3E"); }
.star-h { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3ClinearGradient id='h' x1='0' x2='1'%3E%3Cstop offset='50%25' stop-color='%23c9a84c'/%3E%3Cstop offset='50%25' stop-color='%232d2550'/%3E%3C/linearGradient%3E%3Cpath d='M6 1l1.3 2.7L10.5 4l-2.2 2.2.5 3L6 7.7 3.2 9.2l.5-3L1.5 4l3.2-.3z' fill='url(%23h)'/%3E%3C/svg%3E"); }
.star-e { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 1l1.3 2.7L10.5 4l-2.2 2.2.5 3L6 7.7 3.2 9.2l.5-3L1.5 4l3.2-.3z' fill='%232d2550'/%3E%3C/svg%3E"); }
.star-val { font-family: var(--mono); font-size: 12px; font-weight: 500; color: var(--gold); }
.review-ct { font-size: 11px; color: var(--t3); }

.firm-stats { display: grid; grid-template-columns: repeat(4,1fr); }
.fstat { display: flex; flex-direction: column; gap: 3px; padding: 14px 16px; border-right: 1px solid var(--border); }
.fstat:last-child { border-right: none; }
.fstat-label { font-size: 9.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--t3); }
.fstat-val { font-family: var(--mono); font-size: 14px; font-weight: 500; color: var(--t0); }
.fstat-val.green { color: var(--jade); }
.fstat-val.gold  { color: var(--gold); }
.fstat-val.amber { color: var(--amber); }

.firm-discount {
    display: flex; align-items: center; justify-content: space-between; padding: 10px 16px;
    background: linear-gradient(90deg, rgba(201,168,76,.06), rgba(124,58,237,.04));
    border-top: 1px solid var(--border);
}
.disc-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; color: var(--gold-l); }
.disc-code  { font-family: var(--mono); font-size: 11px; color: var(--t3); }
.disc-copy  { font-size: 10px; color: var(--purple); cursor: pointer; background: none; border: none; padding: 2px 6px; border-radius: 4px; transition: all .15s; font-family: var(--sans); }
.disc-copy:hover { color: var(--violet); background: var(--violet-d); }

.firm-footer { display: flex; gap: 8px; padding: 14px 16px; border-top: 1px solid var(--border); background: rgba(0,0,0,.15); }
.firm-footer .btn, .firm-footer a.btn { flex: 1; }

/* ============================================================
   PAYOUT INTELLIGENCE
   ============================================================ */
.payout-section { display: none; } /* Legacy — replaced by comparison-section */

/* ============================================================
   COMPARISON SECTION
   ============================================================ */
.comparison-section { background: var(--ink2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.comparison-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center; }
.comparison-feature-list { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 12px; }
.comparison-feature-list li { display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--t2); }
.cfl-icon { font-size: 16px; flex-shrink: 0; width: 28px; text-align: center; }
.comparison-cta { margin-top: 0; }

/* Comparison preview card */
.comparison-card { background: var(--ink3); border: 1px solid var(--border-h); border-radius: 24px; padding: 28px; position: relative; overflow: hidden; }
.comparison-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent 10%, var(--gold) 50%, transparent 90%); opacity: .35; }
.comparison-card-hd { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px; }
.comparison-card-title { font-family: var(--serif); font-size: 1rem; font-weight: 700; color: var(--t0); }
.comparison-card-sub { font-size: 11px; color: var(--t3); }
.cmp-firm-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.cmp-firm-row:last-of-type { border-bottom: none; }
.cmp-rank { font-family: var(--mono); font-size: 11px; font-weight: 700; color: var(--t4); width: 16px; text-align: center; flex-shrink: 0; }
.cmp-logo { width: 32px; height: 32px; border-radius: 8px; object-fit: contain; border: 1px solid var(--border); padding: 3px; background: var(--ink2); flex-shrink: 0; }
.cmp-logo-init { width: 32px; height: 32px; border-radius: 8px; background: var(--gold-d); color: var(--gold); font-size: 11px; font-weight: 800; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cmp-info { flex: 1; min-width: 0; }
.cmp-name { font-size: 12px; font-weight: 600; color: var(--t1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-bottom: 5px; }
.cmp-bar-wrap { height: 3px; background: rgba(255,255,255,.06); border-radius: 99px; overflow: hidden; }
.cmp-bar-fill { height: 100%; border-radius: 99px; transition: width 1s ease; }
.cmp-score-ring { position: relative; flex-shrink: 0; width: 44px; height: 44px; }
.cmp-score-ring svg { position: absolute; inset: 0; }
.cmp-score-num { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 10px; font-weight: 800; }
.cmp-view-all { display: block; text-align: center; margin-top: 16px; font-size: 12px; font-weight: 700; color: var(--gold); text-decoration: none; padding: 8px; border: 1px solid var(--gold-ln); border-radius: 8px; transition: all .15s; }
.cmp-view-all:hover { background: var(--gold-d); }

/* Score ticker */
.score-ticker-item .ticker-score { font-size: 13px; }
.score-ticker-item .ticker-score-label { font-size: 10px; }
.score-ticker-item .ticker-badge { white-space: nowrap; }

.payout-info { flex: 1; min-width: 0; }
.payout-name { font-size: 14px; font-weight: 600; color: var(--t1); margin-bottom: 3px; }
.payout-bar { height: 3px; background: rgba(255,255,255,.06); border-radius: 99px; overflow: hidden; }
.payout-bar-fill { height: 100%; border-radius: 99px; background: linear-gradient(90deg, var(--purple-m), var(--gold)); transition: width 1.2s var(--ease-out); }
.payout-speed { font-size: 10.5px; color: var(--t3); }
.payout-amt { font-family: var(--mono); font-size: 13px; font-weight: 500; color: var(--jade); white-space: nowrap; flex-shrink: 0; }

/* Total payout box */
.tpb { background: var(--ink3); border: 1px solid var(--border-h); border-radius: 32px; padding: 40px; position: relative; overflow: hidden; }
.tpb::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent 10%, var(--gold) 50%, transparent 90%); opacity: .35; }
.tpb::after  { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(124,58,237,.08), transparent 70%); pointer-events: none; }
.tpb-inner { position: relative; z-index: 1; }
.tpb-ey { font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; display: flex; align-items: center; gap: 6px; }
.tpb-amt { font-family: var(--serif); font-size: clamp(2.2rem,4vw,3.4rem); font-weight: 700; letter-spacing: -.03em; color: var(--t0); margin-bottom: 6px; line-height: 1; }
.tpb-sub { font-size: 13px; color: var(--t3); margin-bottom: 28px; line-height: 1.5; }
.tpb-rows { display: flex; flex-direction: column; gap: 10px; margin-bottom: 28px; }
.tpb-row  { display: flex; justify-content: space-between; align-items: center; font-size: 13px; }
.tpb-row-label { color: var(--t3); }
.tpb-row-val   { font-family: var(--mono); font-weight: 500; color: var(--t1); }
.tpb-div { height: 1px; background: var(--border); }

/* ============================================================
   TOOLS STRIP
   ============================================================ */
.tools-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 22px; overflow: hidden; }
.tool-cell { background: var(--ink2); padding: 28px 24px; display: flex; flex-direction: column; gap: 10px; transition: background .18s; }
.tool-cell:hover { background: var(--ink3); }
.tool-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; margin-bottom: 4px; }
.ic-gold   { background: var(--gold-d);                border: 1px solid var(--gold-ln); }
.ic-purple { background: var(--purple-d);              border: 1px solid var(--border-p); }
.ic-jade   { background: var(--jade-d);                border: 1px solid rgba(16,185,129,.2); }
.ic-amber  { background: rgba(245,158,11,.1);          border: 1px solid rgba(245,158,11,.2); }
.tool-title { font-size: 14px; font-weight: 600; color: var(--t0); letter-spacing: -.01em; }
.tool-desc  { font-size: 12.5px; color: var(--t3); line-height: 1.55; }
.tool-link  { font-size: 11.5px; font-weight: 600; color: var(--gold); margin-top: 4px; display: flex; align-items: center; gap: 4px; opacity: .7; transition: opacity .15s, gap .15s; }
.tool-cell:hover .tool-link { opacity: 1; gap: 7px; }

/* ============================================================
   AWARDS
   ============================================================ */
.awards-strip { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.award-card { background: var(--ink2); border: 1px solid var(--border); border-radius: 22px; padding: 28px; display: flex; flex-direction: column; gap: 12px; position: relative; overflow: hidden; transition: all .22s var(--ease-out); }
.award-card:hover { border-color: var(--border-h); transform: translateY(-3px); box-shadow: 0 0 40px rgba(201,168,76,.08); }
.award-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--purple), var(--gold)); }
.award-badge { width: 48px; height: 48px; border-radius: 12px; background: linear-gradient(135deg, var(--purple-d), var(--gold-d)); border: 1px solid var(--border-h); display: flex; align-items: center; justify-content: center; font-size: 22px; }
.award-year  { font-size: 10.5px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); }
.award-title { font-family: var(--serif); font-size: 1rem; font-weight: 700; color: var(--t0); line-height: 1.2; }
.award-winner { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: rgba(255,255,255,.03); border: 1px solid var(--border); border-radius: 10px; }
.award-wl { width: 26px; height: 26px; border-radius: 5px; background: var(--ink4); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 10px; font-family: var(--serif); font-weight: 700; color: var(--gold); }
.award-wn { font-size: 13px; font-weight: 600; color: var(--t1); }
.award-ws { font-size: 11px; color: var(--t3); }

/* ============================================================
   ANNOUNCEMENTS
   ============================================================ */
.ann-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 18px; }
.ann-main { background: var(--ink2); border: 1px solid var(--border); border-radius: 22px; overflow: hidden; transition: all .22s var(--ease-out); }
.ann-main:hover { border-color: var(--border-h); transform: translateY(-3px); box-shadow: 0 0 40px rgba(201,168,76,.08); }
.ann-img { height: 200px; background: linear-gradient(135deg, var(--ink4), var(--ink5)); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.ann-img-bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 30% 50%, rgba(124,58,237,.25), transparent 60%), radial-gradient(ellipse at 70% 50%, rgba(201,168,76,.15), transparent 60%); }
.ann-img-inner { position: relative; z-index: 1; text-align: center; }
.ann-body { padding: 22px; }
.ann-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.ann-firm { font-size: 11.5px; font-weight: 600; color: var(--violet); }
.ann-date { font-size: 11px; color: var(--t3); }
.ann-title { font-family: var(--serif); font-size: 1.15rem; font-weight: 700; color: var(--t0); margin-bottom: 8px; line-height: 1.3; }
.ann-exc   { font-size: 13px; color: var(--t2); line-height: 1.6; }
.ann-read  { display: inline-flex; align-items: center; gap: 5px; margin-top: 14px; font-size: 12px; font-weight: 600; color: var(--gold); opacity: .8; transition: all .15s; }
.ann-main:hover .ann-read { opacity: 1; gap: 8px; }
.ann-side  { display: flex; flex-direction: column; gap: 12px; }
.ann-mini  { background: var(--ink2); border: 1px solid var(--border); border-radius: 14px; padding: 16px; display: flex; gap: 14px; align-items: flex-start; transition: all .18s; }
.ann-mini:hover { border-color: var(--border-h); transform: translateX(4px); }
.ann-mini-icon  { width: 38px; height: 38px; flex-shrink: 0; border-radius: 9px; background: var(--ink4); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 16px; }
.ann-mini-firm  { font-size: 10.5px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--violet); margin-bottom: 3px; }
.ann-mini-title { font-size: 13px; font-weight: 600; color: var(--t1); line-height: 1.35; margin-bottom: 4px; }
.ann-mini-date  { font-size: 11px; color: var(--t3); }

/* ============================================================
   LOYALTY PROGRAM
   ============================================================ */
.loyalty-strip { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.loyalty-item { background: var(--ink2); border: 1px solid var(--border); border-radius: 22px; padding: 24px; display: flex; flex-direction: column; gap: 10px; transition: all .2s var(--ease-out); }
.loyalty-item:hover { border-color: var(--border-h); transform: translateY(-3px); box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.loyalty-step  { width: 28px; height: 28px; border-radius: 7px; background: var(--purple-d); border: 1px solid var(--border-p); display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 12px; font-weight: 500; color: var(--violet); }
.loyalty-title { font-size: 14px; font-weight: 600; color: var(--t0); letter-spacing: -.01em; }
.loyalty-desc  { font-size: 12.5px; color: var(--t3); line-height: 1.55; }

/* ============================================================
   BLOG CARDS
   ============================================================ */
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; }
.blog-card { background: var(--ink2); border: 1px solid var(--border); border-radius: 22px; overflow: hidden; display: flex; flex-direction: column; transition: all .22s var(--ease-out); }
.blog-card:hover { border-color: var(--border-h); box-shadow: 0 0 40px rgba(201,168,76,.08); transform: translateY(-3px); }
.blog-thumb { height: 168px; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.blog-thumb-bg { position: absolute; inset: 0; }
.blog-thumb-bg img { width: 100%; height: 100%; object-fit: cover; }
.blog-thumb-icon { font-size: 36px; position: relative; z-index: 1; }
.blog-body   { padding: 20px; flex: 1; display: flex; flex-direction: column; gap: 10px; }
.blog-meta   { display: flex; align-items: center; gap: 8px; }
.blog-cat    { font-size: 10.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--violet); }
.blog-date   { font-size: 11px; color: var(--t3); }
.blog-title  { font-family: var(--serif); font-size: 1rem; font-weight: 700; color: var(--t0); line-height: 1.3; flex: 1; }
.blog-title a { color: inherit; }
.blog-title a:hover { color: var(--gold-l); }
.blog-footer { padding: 12px 20px; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; }
.blog-rm     { font-size: 12px; font-weight: 600; color: var(--gold); opacity: .75; transition: opacity .15s; display: flex; align-items: center; gap: 4px; }
.blog-card:hover .blog-rm { opacity: 1; }

/* ============================================================
   RED FLAG SECTION
   ============================================================ */
.rf-section { background: var(--ink2); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.rf-inner   { display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start; }
.rf-list    { display: flex; flex-direction: column; }
.rf-item    { display: flex; align-items: flex-start; gap: 14px; padding: 16px 0; border-bottom: 1px solid var(--border); }
.rf-item:last-child { border-bottom: none; }
.rf-icon { width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0; margin-top: 2px; display: flex; align-items: center; justify-content: center; }
.rf-text h4 { font-size: 14px; font-weight: 600; color: var(--t1); margin-bottom: 3px; }
.rf-text p  { font-size: 12.5px; color: var(--t3); line-height: 1.55; }

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner {
    position: relative; overflow: hidden; border-radius: 32px;
    background: var(--ink3); border: 1px solid var(--border-h);
    padding: 72px 64px; text-align: center;
}
.cta-banner::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(124,58,237,.1), transparent 60%),
                radial-gradient(ellipse 40% 60% at 50% 100%, rgba(201,168,76,.06), transparent 60%);
    pointer-events: none;
}
.cta-banner::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent 5%, var(--gold) 50%, transparent 95%); opacity: .35;
}
.cta-inner { position: relative; z-index: 2; }
.cta-banner h2 { font-family: var(--serif); font-size: clamp(1.8rem,3vw,2.6rem); font-weight: 700; color: var(--t0); letter-spacing: -.02em; margin-bottom: 14px; }
.cta-banner p  { font-size: 15px; color: var(--t2); max-width: 480px; margin: 0 auto 32px; line-height: 1.7; }
.cta-actions   { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
    .hero-inner     { grid-template-columns: 1fr; gap: 48px; }
    .payout-inner       { grid-template-columns: 1fr; gap: 40px; }
    .comparison-inner   { grid-template-columns: 1fr; gap: 40px; }
    .tools-strip    { grid-template-columns: repeat(2,1fr); }
    .awards-strip   { grid-template-columns: repeat(2,1fr); }
    .rf-inner       { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 768px) {
    .hero           { min-height: auto; padding: 60px 0 60px; }
    .hero-title     { font-size: 2.2rem; }
    .firms-grid, .blog-grid { grid-template-columns: 1fr; }
    .ann-grid       { grid-template-columns: 1fr; }
    .loyalty-strip  { grid-template-columns: 1fr 1fr; }
    .awards-strip   { grid-template-columns: 1fr; }
    .tools-strip    { grid-template-columns: 1fr 1fr; }
    .cta-banner     { padding: 48px 28px; }
    .firm-stats     { grid-template-columns: repeat(2,1fr); }
    .trust-strip    { gap: 14px; }
    .trust-sep      { display: none; }
    .s-grid         { grid-template-columns: 1fr; }
    .section-hd-split { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
    .tools-strip    { grid-template-columns: 1fr; }
    .loyalty-strip  { grid-template-columns: 1fr; }
    .cta-actions    { flex-direction: column; align-items: center; }
}

/* Score wheel styles moved to theme-gold.css */

/* ==========================================================================
   THEME TOGGLE — top of page floating button
   ========================================================================== */
.theme-toggle-bar {
    position: fixed;
    top: 64px;             /* just below the fixed header */
    right: 18px;
    z-index: 890;
    display: flex;
    align-items: center;
    gap: 8px;
}
.theme-toggle-btn {
    display: flex;
    align-items: center;
    gap: 7px;
    height: 30px;
    padding: 0 12px;
    background: var(--ink3);
    border: 1px solid var(--border-h);
    border-radius: 99px;
    cursor: pointer;
    font-family: var(--mono);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--t2);
    transition: all .2s;
    white-space: nowrap;
}
.theme-toggle-btn:hover { border-color: var(--gold); color: var(--t0); }
.theme-toggle-btn .tt-icon { font-size: 13px; transition: transform .3s; }
.theme-toggle-btn.is-light .tt-icon { transform: rotate(180deg); }

/* Light theme overrides for toggle bar */
body.theme-light .theme-toggle-btn {
    background: #fff;
    border-color: rgba(0,0,0,.15);
    color: var(--t2);
}

/* ── Eyebrow hero — prevent text overflow on small screens ── */
.eyebrow--hero {
    height: auto !important;
    min-height: 26px;
    padding: 4px 11px !important;
    white-space: normal;
    line-height: 1.4;
    max-width: 100%;
    word-break: break-word;
}
@media (max-width: 480px) {
    .eyebrow--hero { font-size: 9px !important; padding: 3px 9px !important; }
    .hero-eyebrow-row { flex-wrap: wrap; }
}

