/* iDive — Dashboard module styles. Scoped `ffdb-`. Uses brand tokens from
   styles.css (--primary cyan, --secondary teal, --accent amber, --navy). Never edit styles.css. */

.ffdb-wrap { max-width: 1080px; margin: 0 auto; padding: 104px 20px 72px; }  /* top clears the fixed 72px site header */
.ffdb-wrap h1, .ffdb-wrap h2, .ffdb-wrap h3 { font-family: 'Josefin Sans', sans-serif; color: var(--navy, #0f172a); }

/* ── Login ─────────────────────────────────────────────────────────────── */
.ffdb-auth { min-height: calc(100vh - 72px); display: flex; align-items: flex-start; justify-content: center; padding: 104px 20px 56px; background: linear-gradient(160deg, var(--primary-soft, #ecfeff), #fff 60%); }
.ffdb-card { width: 100%; max-width: 420px; background: #fff; border: 1px solid var(--border, rgba(6,182,212,.16)); border-radius: 20px; padding: 34px 30px; box-shadow: 0 18px 50px -28px rgba(15,23,42,.35), 0 8px 32px rgba(6,95,120,.08); }
.ffdb-card .ffdb-logo { text-align: center; margin-bottom: 10px; }
.ffdb-card .ffdb-logo img { height: 40px; width: auto; display: inline-block; }
.ffdb-card .ffdb-logo i { color: var(--secondary, #0d9488); font-size: 1.8rem; }

/* mobile: header is ~60px — tighten the top clearance + side padding */
@media (max-width: 900px) {
  .ffdb-wrap { padding: 84px 16px 56px; }
  .ffdb-auth { min-height: calc(100vh - 60px); padding: 84px 16px 40px; }
  .ffdb-card { padding: 28px 20px; }
}
.ffdb-card h1 { font-size: 1.55rem; text-align: center; margin: 6px 0 2px; }
.ffdb-card .ffdb-sub { text-align: center; color: #5b6b73; font-size: .82rem; margin: 0 0 22px; }

.ffdb-field { margin-bottom: 14px; }
.ffdb-field label { display: block; font-size: .82rem; font-weight: 600; color: var(--deep, #164e63); margin-bottom: 5px; }
.ffdb-field input { width: 100%; padding: 12px 14px; border: 1px solid #d4dee2; border-radius: 12px; font: inherit; box-sizing: border-box; }
.ffdb-field input:focus { outline: none; border-color: var(--primary, #06b6d4); box-shadow: 0 0 0 3px rgba(6,182,212,.18); }
#ffdb-otp { letter-spacing: .5em; text-align: center; font-size: 1.3rem; font-weight: 700; }

/* Primary action — iDive signature gradient (designplan §1) */
.ffdb-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; width: 100%; padding: 13px 18px; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; color: #fff; font: inherit; font-weight: 700; cursor: pointer; transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1));
  background: linear-gradient(135deg, rgba(16,185,129,.96) 0%, rgba(6,182,212,.96) 50%, rgba(29,78,216,.96) 100%);
  box-shadow: 0 6px 18px rgba(29,78,216,.30), 0 3px 10px rgba(16,185,129,.18), inset 0 1px 0 rgba(255,255,255,.26); }
.ffdb-btn:hover { background: linear-gradient(135deg,#0ea371 0%,#0891b2 50%,#1e40af 100%);
  box-shadow: 0 12px 26px rgba(29,78,216,.42), 0 5px 14px rgba(16,185,129,.22), inset 0 1px 0 rgba(255,255,255,.32); }
.ffdb-btn:disabled { opacity: .6; cursor: default; box-shadow: none; }
@media (prefers-reduced-motion: no-preference) { .ffdb-btn:hover:not(:disabled) { transform: translateY(-1px); } }
.ffdb-btn-link { background: none; border: 0; color: var(--secondary, #0d9488); cursor: pointer; font: inherit; padding: 8px; width: 100%; text-align: center; }

.ffdb-msg { min-height: 20px; margin: 12px 0 0; font-size: .88rem; text-align: center; color: #5b6b73; }
.ffdb-msg.is-err { color: var(--coral, #e84545); }
.ffdb-msg.is-ok { color: var(--secondary-hover, #0f766e); }

.ffdb-divider { display: flex; align-items: center; gap: 12px; margin: 20px 0; color: #9aa7ad; font-size: .8rem; }
.ffdb-divider::before, .ffdb-divider::after { content: ''; flex: 1; height: 1px; background: #e3eaed; }
#ffdb-google-btn { display: flex; justify-content: center; min-height: 44px; }
.ffdb-google-off { color: #9aa7ad; font-size: .82rem; text-align: center; margin: 0; }
.ffdb-fineprint { margin: 22px 0 0; font-size: .74rem; color: #9aa7ad; text-align: center; line-height: 1.5; }

/* ── Dashboard header / stat tiles ─────────────────────────────────────── */
.ffdb-top { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 22px; }
.ffdb-top h1 { font-size: 1.7rem; margin: 0; }
.ffdb-top .ffdb-actions { display: flex; gap: 10px; align-items: center; }
.ffdb-pill { display: inline-flex; align-items: center; gap: 7px; padding: 8px 15px; border-radius: 999px; font-weight: 700; font-size: .85rem; text-decoration: none; }
.ffdb-pill-amber { background: rgba(245,158,11,.14); color: var(--accent-hover, #d97706); }
.ffdb-pill-ghost { background: #eef3f5; color: var(--deep, #164e63); }

.ffdb-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 30px; }
.ffdb-tile { border-radius: 18px; padding: 22px; color: #fff; position: relative; overflow: hidden; border: 1px solid rgba(255,255,255,.18); box-shadow: 0 6px 18px rgba(15,23,42,.10), inset 0 1px 0 rgba(255,255,255,.22); transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
.ffdb-tile i { position: absolute; right: 14px; top: 14px; font-size: 2.4rem; opacity: .22; }
.ffdb-tile .ffdb-tile-num { font-family: 'Josefin Sans', sans-serif; font-size: 2.1rem; font-weight: 700; line-height: 1.1; }
.ffdb-tile .ffdb-tile-label { font-size: .82rem; opacity: .94; margin-top: 4px; }
.ffdb-tile-impact { background: linear-gradient(135deg, #0d9488, #06b6d4); }
.ffdb-tile-points { background: linear-gradient(135deg, #f59e0b, #d97706); }
.ffdb-tile-rank { background: linear-gradient(135deg, #164e63, #0e7490); }
@media (prefers-reduced-motion: no-preference) {
  .ffdb-tile:hover { transform: translateY(-3px); box-shadow: 0 14px 28px rgba(15,23,42,.16), inset 0 1px 0 rgba(255,255,255,.28); }
}

/* ── Panels ────────────────────────────────────────────────────────────── */
.ffdb-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 22px; align-items: start; }
.ffdb-panel { background: #fff; border: 1px solid var(--border, rgba(6,182,212,.16)); border-radius: 18px; padding: 20px 22px; margin-bottom: 22px; box-shadow: 0 8px 32px rgba(6,95,120,.06); transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
@media (prefers-reduced-motion: no-preference) {
  .ffdb-panel:hover { transform: translateY(-3px); border-color: var(--primary, #06b6d4); box-shadow: 0 14px 28px rgba(6,182,212,.14), 0 6px 14px rgba(15,23,42,.06); }
}
.ffdb-panel h2 { font-size: 1.12rem; margin: 0 0 14px; display: flex; align-items: center; gap: 8px; }
.ffdb-panel h2 i { color: var(--secondary, #0d9488); }
.ffdb-empty { color: #8a979d; font-size: .9rem; }
.ffdb-empty a { color: var(--primary-hover, #0891b2); }

.ffdb-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.ffdb-table th { text-align: left; font-size: .72rem; text-transform: uppercase; letter-spacing: .04em; color: #93a2a8; padding: 0 10px 8px; }
.ffdb-table td { padding: 11px 10px; border-top: 1px solid #eef3f5; }
.ffdb-r { text-align: right; }
.ffdb-pts { color: var(--accent-hover, #d97706); font-weight: 700; }
.ffdb-badge { font-size: .72rem; padding: 3px 9px; border-radius: 999px; background: #eef3f5; color: #5b6b73; text-transform: capitalize; }
.ffdb-badge.is-paid { background: rgba(34,197,94,.15); color: #15803d; }

.ffdb-ledger { list-style: none; margin: 0; padding: 0; }
.ffdb-ledger li { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; padding: 10px 0; border-top: 1px solid #eef3f5; font-size: .88rem; }
.ffdb-ledger li:first-child { border-top: 0; }
.ffdb-ledger-note { color: var(--navy, #0f172a); }
.ffdb-ledger-date { color: #9aa7ad; font-size: .78rem; }
.ffdb-ledger-delta { font-weight: 700; min-width: 56px; text-align: right; }
.ffdb-ledger-delta.is-pos { color: #15803d; }
.ffdb-ledger-delta.is-neg { color: var(--coral, #e84545); }

/* ── Leaderboard ───────────────────────────────────────────────────────── */
.ffdb-lb-tabs { display: inline-flex; gap: 4px; background: #eef3f5; padding: 4px; border-radius: 999px; margin-bottom: 14px; }
.ffdb-lb-tabs button { border: 1px solid transparent; background: none; padding: 7px 16px; border-radius: 999px; font: inherit; font-size: .82rem; font-weight: 600; color: #5b6b73; cursor: pointer; transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
.ffdb-lb-tabs button:hover:not(.is-active) { color: var(--primary, #06b6d4); }
/* active segment = iDive signature gradient (designplan §1/§4) */
.ffdb-lb-tabs button.is-active { color: #fff; border-color: rgba(255,255,255,.28);
  background: linear-gradient(135deg, rgba(16,185,129,.96) 0%, rgba(6,182,212,.96) 50%, rgba(29,78,216,.96) 100%);
  box-shadow: 0 4px 12px rgba(29,78,216,.16), 0 2px 6px rgba(16,185,129,.08), inset 0 1px 0 rgba(255,255,255,.28); }
.ffdb-lb { list-style: none; margin: 0; padding: 0; }
.ffdb-lb li { display: grid; grid-template-columns: 34px 1fr auto; gap: 10px; align-items: center; padding: 9px 8px; border-radius: 10px; font-size: .9rem; }
.ffdb-lb li.is-me { background: rgba(6,182,212,.1); }
.ffdb-lb-rank { font-weight: 700; color: var(--secondary, #0d9488); text-align: center; }
.ffdb-lb-name em { color: var(--primary-hover, #0891b2); font-style: normal; font-weight: 600; }
.ffdb-lb-val { font-weight: 700; color: var(--navy, #0f172a); }
.ffdb-lb-you { margin: 12px 0 0; font-size: .85rem; color: #5b6b73; }

/* ── P2: rewards, influencer codes, commissions ────────────────────────── */
.ffdb-btn-sm { width: auto; padding: 8px 16px; font-size: .85rem; margin-top: 12px; }
.ffdb-hint { color: #6b7a80; font-size: .85rem; margin: 0 0 14px; }
.ffdb-hint code { background: #eef3f5; padding: 1px 6px; border-radius: 6px; font-size: .82em; }
.ffdb-pct { font-size: .72rem; font-weight: 700; color: var(--accent-hover, #d97706); background: rgba(245,158,11,.14); padding: 3px 10px; border-radius: 999px; margin-left: auto; }
.ffdb-stats-4 { grid-template-columns: repeat(4, 1fr); }

.ffdb-rewards { display: grid; gap: 12px; }
.ffdb-reward { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 13px 15px; border: 1px solid var(--border, rgba(6,182,212,.16)); border-radius: 14px; transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
@media (prefers-reduced-motion: no-preference) {
  .ffdb-reward:hover { transform: translateY(-2px); border-color: var(--primary, #06b6d4); box-shadow: 0 10px 22px rgba(6,182,212,.12), 0 4px 10px rgba(15,23,42,.05); }
}
.ffdb-reward-info { display: flex; flex-direction: column; }
.ffdb-reward-title { font-weight: 700; color: var(--navy, #0f172a); }
.ffdb-reward-desc { font-size: .82rem; color: #6b7a80; }
.ffdb-reward-act { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; flex-shrink: 0; }
.ffdb-reward-cost { font-weight: 700; color: var(--accent-hover, #d97706); font-size: .9rem; }
.ffdb-reward-act .ffdb-btn-sm { margin-top: 0; }

.ffdb-code { padding: 12px 14px; border: 1px solid var(--border, rgba(6,182,212,.16)); border-radius: 14px; margin-bottom: 12px; transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
@media (prefers-reduced-motion: no-preference) {
  .ffdb-code:hover { border-color: var(--primary, #06b6d4); box-shadow: 0 10px 22px rgba(6,182,212,.12), 0 4px 10px rgba(15,23,42,.05); }
}
.ffdb-code-main { display: flex; align-items: center; gap: 10px; }
.ffdb-code-tag { font-family: 'Josefin Sans', sans-serif; font-weight: 700; color: var(--secondary, #0d9488); background: rgba(13,148,136,.12); padding: 4px 10px; border-radius: 8px; white-space: nowrap; }
.ffdb-code-url { flex: 1; min-width: 0; padding: 8px 10px; border: 1px solid #d4dee2; border-radius: 9px; font: inherit; font-size: .82rem; color: #5b6b73; background: #f9fbfc; transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
.ffdb-code-url:focus { outline: none; border-color: var(--primary, #06b6d4); box-shadow: 0 0 0 3px rgba(6,182,212,.18); }
.ffdb-code-meta { display: flex; align-items: center; gap: 10px; margin-top: 8px; font-size: .78rem; color: #93a2a8; }
.ffdb-copy { margin-left: auto; border: 1px solid #d4dee2; background: #fff; border-radius: 8px; padding: 5px 11px; font: inherit; font-size: .78rem; cursor: pointer; color: var(--deep, #164e63); transition: var(--transition, all .25s cubic-bezier(.4,0,.2,1)); }
.ffdb-copy:hover { border-color: var(--primary, #06b6d4); color: var(--primary, #06b6d4); }
.ffdb-copy:focus-visible { outline: none; border-color: var(--primary, #06b6d4); box-shadow: 0 0 0 3px rgba(6,182,212,.18); }

@media (max-width: 820px) {
  .ffdb-stats, .ffdb-stats-4 { grid-template-columns: 1fr; }
  .ffdb-grid { grid-template-columns: 1fr; }
}
@media (min-width: 821px) and (max-width: 1000px) { .ffdb-stats-4 { grid-template-columns: repeat(2, 1fr); } }
