/* ═══════════════════════════════════════════════════════════════
   Phoenix Capital — main.css  v1.1 PATCH
   Fixes:
     1. Hero title clipped on left (padding + overflow)
     2. Stats grid: Net Position spans full width on mobile
     3. Tab bar overflow — scrollable, no clipping
     4. Export PDF button visibility
     5. Currency display driven by JS (no CSS change needed —
        see frontend-patch.js for the XAF fix)
     6. PWA install prompt — universal styles
═══════════════════════════════════════════════════════════════ */

/* ── Design tokens ──────────────────────────────────────────── */
:root {
  --ph-forest:      #0d3b2e;
  --ph-forest-mid:  #145c46;
  --ph-forest-lit:  #1a7a5c;
  --ph-gold:        #c8981a;
  --ph-gold-lit:    #e8b220;
  --ph-gold-pale:   #fdf3d0;
  --ph-ember:       #c0392b;
  --ph-ember-pale:  #fde8e6;
  --ph-ink:         #0e1c17;
  --ph-stone:       #3d5449;
  --ph-mist:        #e8f0ec;
  --ph-white:       #ffffff;
  --ph-surface:     #f4f8f5;
  --ph-border:      #d1e4da;
  --ph-wa-green:    #25D366;
  --ph-font-display:'Sora', sans-serif;
  --ph-font-body:   'DM Sans', sans-serif;
  --ph-space-1: 4px;  --ph-space-2: 8px;   --ph-space-3: 12px;
  --ph-space-4: 16px; --ph-space-5: 24px;  --ph-space-6: 32px;
  --ph-space-7: 48px; --ph-space-8: 64px;
  --ph-r-sm: 6px; --ph-r-md: 12px; --ph-r-lg: 20px;
  --ph-r-xl: 28px; --ph-r-full: 999px;
  --ph-shadow-sm: 0 1px 3px rgba(13,59,46,.10);
  --ph-shadow-md: 0 4px 16px rgba(13,59,46,.12);
  --ph-shadow-lg: 0 12px 40px rgba(13,59,46,.18);
  --ph-shadow-gold: 0 4px 24px rgba(200,152,26,.30);
  --ph-ease: cubic-bezier(.22,.68,0,1.2);
  --ph-ease-out: cubic-bezier(.16,1,.3,1);
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; font-size: 16px; }
body {
  font-family: var(--ph-font-body);
  background: var(--ph-surface);
  color: var(--ph-ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; font-family: inherit; border: none; background: none; }
ul { list-style: none; }

/* ── Layout ─────────────────────────────────────────────────── */
.ph-container { width: 100%; max-width: 1100px; margin: 0 auto; padding: 0 var(--ph-space-4); }
.ph-container-narrow { max-width: 520px; }
.phoenix-app { min-height: 100dvh; display: flex; flex-direction: column; }
.phoenix-main { flex: 1; }

/* ════════════════════════════════════════════════════════════
   HEADER
════════════════════════════════════════════════════════════ */
.phoenix-header {
  position: sticky; top: 0; z-index: 900;
  background: var(--ph-forest);
  border-bottom: 1px solid var(--ph-forest-mid);
  box-shadow: 0 2px 12px rgba(0,0,0,.25);
  transition: transform .35s var(--ph-ease-out), box-shadow .3s;
}
.phoenix-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--ph-space-3); height: 60px;
  /* FIX: ensure padding on both sides so logo never clips */
  padding: 0 var(--ph-space-4);
  max-width: 1200px; margin: 0 auto;
}
.phoenix-header-left { display: flex; align-items: center; gap: var(--ph-space-3); min-width: 0; }

.phoenix-wordmark {
  display: flex; align-items: center; gap: var(--ph-space-2);
  color: var(--ph-white); font-family: var(--ph-font-display);
  font-size: 16px; font-weight: 600; letter-spacing: -.3px; white-space: nowrap;
  /* FIX: never let wordmark overflow and clip */
  overflow: hidden; text-overflow: ellipsis;
}
.phoenix-wordmark img { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.phoenix-wordmark-icon { font-size: 22px; line-height: 1; flex-shrink: 0; }
.phoenix-wordmark-text strong { color: var(--ph-gold-lit); font-weight: 800; }

.phoenix-nav { display: none; }
.phoenix-nav-list { display: flex; gap: var(--ph-space-5); align-items: center; }
.phoenix-nav-list a {
  color: rgba(255,255,255,.80); font-size: 14px; font-weight: 500;
  letter-spacing: .2px; transition: color .2s; position: relative;
}
.phoenix-nav-list a::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 100%;
  height: 2px; background: var(--ph-gold-lit);
  transition: right .25s var(--ph-ease-out);
}
.phoenix-nav-list a:hover { color: var(--ph-white); }
.phoenix-nav-list a:hover::after { right: 0; }

.phoenix-header-actions { display: flex; align-items: center; gap: var(--ph-space-2); flex-shrink: 0; }

.phoenix-lang-toggle {
  display: flex; align-items: center; gap: var(--ph-space-1);
  color: rgba(255,255,255,.75); font-size: 12px; font-weight: 500;
  padding: 5px 10px; border-radius: var(--ph-r-full);
  border: 1px solid rgba(255,255,255,.2); transition: all .2s;
  white-space: nowrap;
}
.phoenix-lang-toggle:hover { color: var(--ph-white); border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.08); }

.phoenix-hamburger {
  display: flex; flex-direction: column; justify-content: center;
  gap: 5px; width: 36px; height: 36px; padding: 6px;
  border-radius: var(--ph-r-sm); transition: background .2s; flex-shrink: 0;
}
.phoenix-hamburger span { display: block; height: 2px; background: var(--ph-white); border-radius: 2px; transition: transform .3s var(--ph-ease), opacity .2s; }
.phoenix-hamburger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.phoenix-hamburger.is-open span:nth-child(2) { opacity: 0; }
.phoenix-hamburger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.phoenix-hamburger:hover { background: rgba(255,255,255,.1); }

/* Drawer */
.phoenix-drawer {
  position: fixed; inset: 0 auto 0 0; width: min(320px, 85vw);
  background: var(--ph-forest); z-index: 950;
  transform: translateX(-100%); transition: transform .35s var(--ph-ease-out);
  display: flex; flex-direction: column; padding: var(--ph-space-6) var(--ph-space-5);
}
.phoenix-drawer.is-open { transform: translateX(0); }
.phoenix-drawer-inner { display: flex; flex-direction: column; height: 100%; gap: var(--ph-space-6); }
.phoenix-drawer-list { display: flex; flex-direction: column; gap: var(--ph-space-2); }
.phoenix-drawer-list li a {
  display: block; color: rgba(255,255,255,.85); font-size: 18px; font-weight: 500;
  padding: var(--ph-space-3) 0; border-bottom: 1px solid rgba(255,255,255,.08);
  transition: color .2s, padding-left .2s;
}
.phoenix-drawer-list li a:hover { color: var(--ph-gold-lit); padding-left: var(--ph-space-2); }
.phoenix-drawer-footer { margin-top: auto; display: flex; flex-direction: column; gap: var(--ph-space-3); }
.phoenix-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.55); z-index: 940;
  opacity: 0; pointer-events: none; transition: opacity .3s; backdrop-filter: blur(2px);
}
.phoenix-overlay.is-visible { opacity: 1; pointer-events: all; }

/* ════════════════════════════════════════════════════════════
   BUTTONS
════════════════════════════════════════════════════════════ */
.phoenix-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--ph-space-2); font-family: var(--ph-font-display);
  font-size: 15px; font-weight: 600; padding: 13px 24px;
  border-radius: var(--ph-r-md); transition: all .22s var(--ph-ease);
  white-space: nowrap; position: relative; overflow: hidden;
}
.phoenix-btn-gold { background: var(--ph-gold); color: var(--ph-ink); box-shadow: var(--ph-shadow-gold); }
.phoenix-btn-gold:hover { background: var(--ph-gold-lit); transform: translateY(-2px); box-shadow: 0 8px 32px rgba(200,152,26,.45); }
.phoenix-btn-gold:active { transform: translateY(0); }
.phoenix-btn-ghost { background: transparent; color: rgba(255,255,255,.85); border: 1.5px solid rgba(255,255,255,.3); }
.phoenix-btn-ghost:hover { background: rgba(255,255,255,.1); color: var(--ph-white); border-color: rgba(255,255,255,.6); }
.phoenix-btn-outline { background: transparent; color: var(--ph-gold-lit); border: 1.5px solid var(--ph-gold); }
.phoenix-btn-outline:hover { background: var(--ph-gold); color: var(--ph-ink); }
.phoenix-btn-sm { font-size: 13px; padding: 8px 16px; border-radius: var(--ph-r-sm); }
.phoenix-btn-full { width: 100%; padding: 16px; font-size: 16px; border-radius: var(--ph-r-md); }
.phoenix-btn-lg { font-size: 17px; padding: 16px 32px; border-radius: var(--ph-r-lg); }

.phoenix-wa-btn {
  display: inline-flex; align-items: center; gap: var(--ph-space-2);
  background: var(--ph-wa-green); color: var(--ph-white);
  font-family: var(--ph-font-display); font-size: 14px; font-weight: 600;
  padding: 11px 20px; border-radius: var(--ph-r-md); transition: all .2s; white-space: nowrap;
}
.phoenix-wa-btn:hover { background: #20b858; transform: translateY(-1px); box-shadow: 0 4px 16px rgba(37,211,102,.35); }

.ph-spinner { animation: ph-spin .8s linear infinite; }
@keyframes ph-spin { to { transform: rotate(360deg); } }

/* ════════════════════════════════════════════════════════════
   HERO — FIX: overflow + padding
════════════════════════════════════════════════════════════ */
.ph-hero {
  position: relative; background: var(--ph-forest);
  min-height: 60dvh; display: flex; align-items: center;
  justify-content: center; overflow: hidden;
  /* FIX: symmetric padding so title never clips on left */
  padding: var(--ph-space-8) var(--ph-space-5);
}
.ph-hero-bg { position: absolute; inset: 0; pointer-events: none; }
.ph-hero-orb { position: absolute; border-radius: 50%; filter: blur(80px); opacity: .35; }
.ph-hero-orb-1 { width: 500px; height: 500px; background: radial-gradient(circle, var(--ph-gold) 0%, transparent 70%); top: -150px; right: -100px; animation: ph-float 8s ease-in-out infinite alternate; }
.ph-hero-orb-2 { width: 400px; height: 400px; background: radial-gradient(circle, var(--ph-forest-lit) 0%, transparent 70%); bottom: -100px; left: -80px; animation: ph-float 10s ease-in-out infinite alternate-reverse; }
@keyframes ph-float { from { transform: translate(0,0) scale(1); } to { transform: translate(20px,-30px) scale(1.05); } }
.ph-hero-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(200,152,26,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(200,152,26,.04) 1px, transparent 1px); background-size: 40px 40px; }

.ph-hero-content {
  position: relative; z-index: 1; text-align: center;
  max-width: 680px; width: 100%;
  /* FIX: prevent any child overflowing the container */
  overflow: hidden;
  animation: ph-fade-up .8s var(--ph-ease-out) both;
}
@keyframes ph-fade-up { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }

.ph-hero-eyebrow { display: flex; justify-content: center; gap: var(--ph-space-2); margin-bottom: var(--ph-space-4); animation: ph-fade-up .8s var(--ph-ease-out) .1s both; flex-wrap: wrap; }
.ph-badge { display: inline-flex; align-items: center; gap: var(--ph-space-1); background: rgba(200,152,26,.15); color: var(--ph-gold-lit); border: 1px solid rgba(200,152,26,.25); padding: 4px 12px; border-radius: var(--ph-r-full); font-size: 12px; font-weight: 600; letter-spacing: .4px; text-transform: uppercase; }

.ph-hero-title {
  font-family: var(--ph-font-display);
  /* FIX: clamp prevents oversized text from clipping */
  font-size: clamp(1.8rem, 7vw, 3.8rem);
  font-weight: 800; color: var(--ph-white); line-height: 1.12;
  letter-spacing: -.03em; margin-bottom: var(--ph-space-4);
  /* FIX: wrap long words instead of overflowing */
  word-break: break-word; overflow-wrap: break-word;
  animation: ph-fade-up .8s var(--ph-ease-out) .2s both;
}
.ph-hero-title em { font-style: normal; color: var(--ph-gold-lit); background: linear-gradient(135deg, var(--ph-gold) 0%, var(--ph-gold-lit) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.ph-hero-sub { font-size: clamp(.95rem, 2.8vw, 1.15rem); color: rgba(255,255,255,.72); line-height: 1.65; margin-bottom: var(--ph-space-6); word-break: break-word; animation: ph-fade-up .8s var(--ph-ease-out) .3s both; }
.ph-hero-actions { display: flex; gap: var(--ph-space-3); justify-content: center; flex-wrap: wrap; margin-bottom: var(--ph-space-7); animation: ph-fade-up .8s var(--ph-ease-out) .4s both; }
.ph-hero-cta { min-width: 180px; }

/* Hero stats strip */
.ph-hero-stats {
  display: flex; align-items: center; justify-content: center;
  gap: var(--ph-space-4); background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1); border-radius: var(--ph-r-lg);
  padding: var(--ph-space-4) var(--ph-space-5);
  backdrop-filter: blur(12px);
  /* FIX: allow wrapping on very small screens */
  flex-wrap: wrap;
  animation: ph-fade-up .8s var(--ph-ease-out) .5s both;
}
.ph-hero-stat { text-align: center; }
.ph-hero-stat-num { display: block; font-family: var(--ph-font-display); font-size: 18px; font-weight: 700; color: var(--ph-gold-lit); }
.ph-hero-stat-label { display: block; font-size: 11px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .5px; margin-top: 2px; }
.ph-hero-stat-divider { width: 1px; height: 40px; background: rgba(255,255,255,.15); }
/* Hide dividers when stats wrap */
@media (max-width: 380px) { .ph-hero-stat-divider { display: none; } }

/* ════════════════════════════════════════════════════════════
   LOGIN SECTION
════════════════════════════════════════════════════════════ */
.ph-login-section { padding: var(--ph-space-8) var(--ph-space-4); background: var(--ph-surface); }
.ph-login-card { background: var(--ph-white); border-radius: var(--ph-r-xl); box-shadow: var(--ph-shadow-lg); overflow: hidden; }
.ph-login-header { background: linear-gradient(135deg, var(--ph-forest) 0%, var(--ph-forest-mid) 100%); padding: var(--ph-space-6) var(--ph-space-6) var(--ph-space-5); text-align: center; }
.ph-login-icon { font-size: 36px; margin-bottom: var(--ph-space-3); }
.ph-login-header h2 { font-family: var(--ph-font-display); font-size: 22px; font-weight: 700; color: var(--ph-white); margin-bottom: var(--ph-space-2); }
.ph-login-header p { color: rgba(255,255,255,.7); font-size: 14px; line-height: 1.5; }
.ph-login-form { padding: var(--ph-space-6); display: flex; flex-direction: column; gap: var(--ph-space-4); }
.ph-label { display: flex; align-items: center; gap: var(--ph-space-2); font-size: 13px; font-weight: 600; color: var(--ph-stone); margin-bottom: var(--ph-space-2); text-transform: uppercase; letter-spacing: .5px; }
.ph-input { width: 100%; padding: 14px 16px; font-family: var(--ph-font-body); font-size: 16px; color: var(--ph-ink); background: var(--ph-surface); border: 1.5px solid var(--ph-border); border-radius: var(--ph-r-md); transition: border-color .2s, box-shadow .2s; -webkit-appearance: none; }
.ph-input:focus { outline: none; border-color: var(--ph-gold); box-shadow: 0 0 0 3px rgba(200,152,26,.15); background: var(--ph-white); }
.ph-input::placeholder { color: #aab5b0; }
.ph-phone-wrap { display: flex; align-items: stretch; }
.ph-phone-prefix { display: flex; align-items: center; gap: 6px; padding: 0 14px; background: var(--ph-mist); border: 1.5px solid var(--ph-border); border-right: none; border-radius: var(--ph-r-md) 0 0 var(--ph-r-md); font-size: 14px; font-weight: 600; color: var(--ph-stone); white-space: nowrap; }
.ph-input-phone { border-radius: 0 var(--ph-r-md) var(--ph-r-md) 0; }
.ph-phone-wrap:focus-within .ph-phone-prefix { border-color: var(--ph-gold); background: var(--ph-gold-pale); }
.ph-error-box { display: flex; align-items: center; gap: var(--ph-space-2); background: var(--ph-ember-pale); border: 1px solid rgba(192,57,43,.2); color: var(--ph-ember); padding: 12px 14px; border-radius: var(--ph-r-md); font-size: 13px; font-weight: 500; animation: ph-shake .4s var(--ph-ease); }
@keyframes ph-shake { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-5px)} 40%,80%{transform:translateX(5px)} }
.ph-login-footer { padding: var(--ph-space-4) var(--ph-space-6); border-top: 1px solid var(--ph-border); text-align: center; background: var(--ph-surface); display: flex; flex-direction: column; align-items: center; gap: var(--ph-space-3); }
.ph-login-footer p { font-size: 13px; color: var(--ph-stone); }
.ph-wa-login { font-size: 13px; padding: 9px 18px; }

/* ════════════════════════════════════════════════════════════
   DASHBOARD
════════════════════════════════════════════════════════════ */
.ph-dashboard { padding: var(--ph-space-5) var(--ph-space-4) var(--ph-space-8); animation: ph-fade-up .5s var(--ph-ease-out) both; }

.ph-welcome-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--ph-space-4); padding: var(--ph-space-5) 0; }
.ph-welcome-left { display: flex; align-items: center; gap: var(--ph-space-3); }
.ph-avatar { width: 48px; height: 48px; background: var(--ph-gold-pale); border: 2px solid var(--ph-gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 22px; }
.ph-welcome-label { font-size: 12px; color: var(--ph-stone); text-transform: uppercase; letter-spacing: .5px; }
.ph-welcome-name { font-family: var(--ph-font-display); font-size: 20px; font-weight: 700; color: var(--ph-forest); line-height: 1.2; }
.ph-welcome-right { display: flex; gap: var(--ph-space-2); align-items: center; flex-wrap: wrap; }

/* FIX: Export PDF button — always visible, proper styling */
#ph-export-pdf {
  display: inline-flex !important;
  align-items: center;
  gap: var(--ph-space-2);
  background: var(--ph-forest);
  color: var(--ph-white);
  border: 1.5px solid var(--ph-forest-mid);
  border-radius: var(--ph-r-sm);
  font-size: 13px;
  font-weight: 600;
  padding: 8px 14px;
  transition: all .2s;
  opacity: 1 !important;
  pointer-events: auto !important;
}
#ph-export-pdf:hover { background: var(--ph-forest-mid); }

.ph-logout-btn { color: var(--ph-ember); border: 1.5px solid var(--ph-ember); border-radius: var(--ph-r-sm); font-size: 13px; padding: 8px 14px; }
.ph-logout-btn:hover { background: var(--ph-ember); color: var(--ph-white); }

/* ── Stats strip — FIX: Net Position full-width on mobile ── */
.ph-stats-strip {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--ph-space-3);
  margin-bottom: var(--ph-space-5);
}
/* Net Position (6th card) spans full width on mobile */
.ph-stat-net {
  grid-column: 1 / -1;
}

.ph-stat-card { background: var(--ph-white); border: 1px solid var(--ph-border); border-radius: var(--ph-r-lg); padding: var(--ph-space-4); display: flex; align-items: center; gap: var(--ph-space-3); box-shadow: var(--ph-shadow-sm); transition: transform .2s, box-shadow .2s; }
.ph-stat-card:hover { transform: translateY(-2px); box-shadow: var(--ph-shadow-md); }
.ph-stat-icon { font-size: 24px; width: 44px; height: 44px; background: var(--ph-surface); border-radius: var(--ph-r-md); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ph-stat-label { font-size: 11px; font-weight: 600; color: var(--ph-stone); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 2px; }
.ph-stat-value { font-family: var(--ph-font-display); font-size: 17px; font-weight: 700; color: var(--ph-forest); }
.ph-stat-highlight { border-color: var(--ph-gold); background: var(--ph-gold-pale); }
.ph-stat-highlight .ph-stat-value { color: var(--ph-gold); }
.ph-stat-highlight .ph-stat-icon { background: rgba(200,152,26,.15); }
.ph-stat-danger .ph-stat-value { color: var(--ph-ember); }
.ph-stat-danger .ph-stat-icon { background: var(--ph-ember-pale); }

/* ── Tabs — FIX: scroll without clipping ── */
.ph-tabs {
  display: flex; gap: 0;
  background: var(--ph-white);
  border: 1px solid var(--ph-border);
  border-radius: var(--ph-r-lg) var(--ph-r-lg) 0 0;
  overflow-x: auto; overflow-y: hidden;
  scrollbar-width: none; -ms-overflow-style: none;
  /* FIX: -webkit-overflow-scrolling for iOS momentum */
  -webkit-overflow-scrolling: touch;
}
.ph-tabs::-webkit-scrollbar { display: none; }
.phoenix-tab-btn {
  /* FIX: min-width so tabs don't squish below readable size */
  flex: 0 0 auto;
  min-width: 90px;
  padding: 14px var(--ph-space-4);
  font-family: var(--ph-font-display); font-size: 13px; font-weight: 600;
  color: var(--ph-stone); border-bottom: 3px solid transparent;
  transition: color .2s, border-color .2s, background .2s;
  white-space: nowrap; letter-spacing: .2px; text-align: center;
}
.phoenix-tab-btn.active { color: var(--ph-forest); border-bottom-color: var(--ph-gold); background: var(--ph-gold-pale); }
.phoenix-tab-btn:hover:not(.active) { color: var(--ph-forest-mid); background: var(--ph-surface); }

.ph-tab-panels { background: var(--ph-white); border: 1px solid var(--ph-border); border-top: none; border-radius: 0 0 var(--ph-r-lg) var(--ph-r-lg); min-height: 200px; margin-bottom: var(--ph-space-5); }
.ph-tab-panel { padding: var(--ph-space-4); }
.ph-list-container { display: flex; flex-direction: column; }

.phoenix-list-item { display: flex; align-items: center; justify-content: space-between; padding: var(--ph-space-3) 0; border-bottom: 1px solid var(--ph-mist); gap: var(--ph-space-3); animation: ph-fade-up .3s var(--ph-ease-out) both; }
.phoenix-list-item:last-child { border-bottom: none; }
.phoenix-item-label { font-weight: 600; font-size: 14px; color: var(--ph-ink); }
.phoenix-item-meta { font-size: 12px; color: var(--ph-stone); flex: 1; text-align: center; }
.phoenix-item-amount { font-family: var(--ph-font-display); font-weight: 700; font-size: 15px; color: var(--ph-forest); white-space: nowrap; }
.phoenix-loan-amount { color: var(--ph-ember); }

.phoenix-txn { display: flex; align-items: flex-start; justify-content: space-between; padding: var(--ph-space-3) 0; border-bottom: 1px solid var(--ph-mist); gap: var(--ph-space-3); animation: ph-fade-up .3s var(--ph-ease-out) both; }
.phoenix-txn:last-child { border-bottom: none; }
.phoenix-txn-info { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.phoenix-txn-type { font-weight: 600; font-size: 13px; color: var(--ph-ink); }
.phoenix-txn-desc { font-size: 12px; color: var(--ph-stone); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.phoenix-txn-date { font-size: 11px; color: #a8b8b2; }
.phoenix-txn-amount { font-family: var(--ph-font-display); font-weight: 700; font-size: 14px; white-space: nowrap; }
.phoenix-txn-credit .phoenix-txn-amount { color: var(--ph-forest-lit); }
.phoenix-txn-debit  .phoenix-txn-amount { color: var(--ph-ember); }

.ph-skeleton-list { display: flex; flex-direction: column; gap: var(--ph-space-3); padding: var(--ph-space-4) 0; }
.ph-skeleton { height: 48px; background: linear-gradient(90deg, var(--ph-mist) 25%, var(--ph-border) 50%, var(--ph-mist) 75%); background-size: 200% 100%; border-radius: var(--ph-r-md); animation: ph-shimmer 1.5s infinite; }
@keyframes ph-shimmer { to { background-position: -200% 0; } }
.phoenix-empty { color: #a8b8b2; font-style: italic; font-size: 13px; padding: var(--ph-space-5) 0; text-align: center; }

.ph-support-strip { display: flex; flex-wrap: wrap; gap: var(--ph-space-3); justify-content: center; }
.ph-support-btn { font-size: 13px; padding: 10px 16px; }

/* ════════════════════════════════════════════════════════════
   SERVICES
════════════════════════════════════════════════════════════ */
.ph-services { padding: var(--ph-space-8) var(--ph-space-4); background: var(--ph-white); }
.ph-section-header { text-align: center; margin-bottom: var(--ph-space-7); }
.ph-section-header h2 { font-family: var(--ph-font-display); font-size: clamp(1.6rem, 5vw, 2.4rem); font-weight: 800; color: var(--ph-forest); margin-bottom: var(--ph-space-3); }
.ph-section-line { width: 60px; height: 4px; background: linear-gradient(90deg, var(--ph-gold), var(--ph-gold-lit)); border-radius: var(--ph-r-full); margin: 0 auto; }
.ph-services-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--ph-space-4); }
.ph-service-card { background: var(--ph-surface); border: 1px solid var(--ph-border); border-radius: var(--ph-r-xl); padding: var(--ph-space-5); transition: transform .25s, box-shadow .25s, border-color .25s; position: relative; overflow: hidden; }
.ph-service-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--ph-gold), var(--ph-forest-lit)); transform: scaleX(0); transform-origin: left; transition: transform .3s var(--ph-ease-out); }
.ph-service-card:hover { transform: translateY(-4px); box-shadow: var(--ph-shadow-md); border-color: var(--ph-gold); }
.ph-service-card:hover::before { transform: scaleX(1); }
.ph-service-icon { font-size: 32px; margin-bottom: var(--ph-space-3); }
.ph-service-card h3 { font-family: var(--ph-font-display); font-size: 16px; font-weight: 700; color: var(--ph-forest); margin-bottom: var(--ph-space-2); }
.ph-service-card p { font-size: 13px; color: var(--ph-stone); line-height: 1.6; }

/* ════════════════════════════════════════════════════════════
   CONTACT
════════════════════════════════════════════════════════════ */
.ph-contact { padding: var(--ph-space-8) var(--ph-space-4); background: var(--ph-surface); }
.ph-contact-card { background: linear-gradient(135deg, var(--ph-forest) 0%, var(--ph-forest-mid) 100%); border-radius: var(--ph-r-xl); padding: var(--ph-space-7) var(--ph-space-5); text-align: center; position: relative; overflow: hidden; }
.ph-contact-card::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(200,152,26,.15) 0%, transparent 60%); }
.ph-contact-wa-icon { margin-bottom: var(--ph-space-4); position: relative; }
.ph-contact-card h2 { font-family: var(--ph-font-display); font-size: 24px; font-weight: 700; color: var(--ph-white); margin-bottom: var(--ph-space-3); position: relative; }
.ph-contact-card p { color: rgba(255,255,255,.75); margin-bottom: var(--ph-space-5); font-size: 15px; position: relative; }

/* ════════════════════════════════════════════════════════════
   KENTE BAR
════════════════════════════════════════════════════════════ */
.phoenix-kente-bar { display: flex; height: 6px; width: 100%; overflow: hidden; }
.kente-stripe { flex: 1; position: relative; }
.kente-stripe::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,.3) 0%, transparent 60%); }
.kente-green { background: #1a5c38; }
.kente-gold  { background: var(--ph-gold); }
.kente-red   { background: #b71c1c; }

/* ════════════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════════ */
.phoenix-footer { background: var(--ph-forest); color: rgba(255,255,255,.8); }
.phoenix-footer-inner { display: grid; grid-template-columns: 1fr; gap: var(--ph-space-6); padding: var(--ph-space-7) var(--ph-space-4) var(--ph-space-6); max-width: 1100px; margin: 0 auto; }
.phoenix-footer-brand .phoenix-wordmark { color: var(--ph-white); margin-bottom: var(--ph-space-3); }
.phoenix-footer-tagline { font-size: 13px; color: rgba(255,255,255,.6); line-height: 1.6; margin-bottom: var(--ph-space-4); }
.phoenix-footer-list { display: flex; flex-direction: column; gap: var(--ph-space-2); }
.phoenix-footer-list a { color: rgba(255,255,255,.65); font-size: 14px; transition: color .2s; padding: 2px 0; }
.phoenix-footer-list a:hover { color: var(--ph-gold-lit); }
.phoenix-install-btn { display: inline-flex; align-items: center; gap: var(--ph-space-2); padding: 12px 20px; background: rgba(255,255,255,.1); color: var(--ph-white); border: 1px solid rgba(255,255,255,.2); border-radius: var(--ph-r-md); font-size: 14px; font-weight: 600; font-family: var(--ph-font-display); transition: all .2s; }
.phoenix-install-btn:hover { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.4); }
.phoenix-footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding: var(--ph-space-4); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--ph-space-2); font-size: 12px; color: rgba(255,255,255,.45); max-width: 1100px; margin: 0 auto; }

/* ════════════════════════════════════════════════════════════
   PWA INSTALL — Universal (Android + Desktop + iOS)
════════════════════════════════════════════════════════════ */

/* Floating install button — shown on Android/Desktop when prompt available */
.ph-install-fab {
  position: fixed;
  bottom: 80px; right: var(--ph-space-4);
  z-index: 8000;
  display: flex; align-items: center; gap: var(--ph-space-2);
  background: var(--ph-gold);
  color: var(--ph-ink);
  font-family: var(--ph-font-display); font-size: 14px; font-weight: 700;
  padding: 13px 20px; border-radius: var(--ph-r-full);
  box-shadow: 0 6px 24px rgba(200,152,26,.5);
  transition: all .3s var(--ph-ease-out);
  transform: translateY(120px); /* hidden by default */
  opacity: 0;
  border: none; cursor: pointer;
}
.ph-install-fab.is-visible { transform: translateY(0); opacity: 1; }
.ph-install-fab:hover { background: var(--ph-gold-lit); transform: translateY(-2px); box-shadow: 0 10px 32px rgba(200,152,26,.6); }
.ph-install-fab svg { flex-shrink: 0; }

/* iOS install bottom sheet */
.ph-ios-sheet {
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: 8500;
  background: var(--ph-white); border-radius: var(--ph-r-xl) var(--ph-r-xl) 0 0;
  padding: var(--ph-space-5) var(--ph-space-5) calc(var(--ph-space-6) + env(safe-area-inset-bottom));
  box-shadow: 0 -8px 40px rgba(0,0,0,.20);
  transform: translateY(100%);
  transition: transform .4s var(--ph-ease-out);
}
.ph-ios-sheet.is-visible { transform: translateY(0); }
.ph-ios-sheet-handle { width: 40px; height: 4px; background: var(--ph-border); border-radius: 2px; margin: 0 auto var(--ph-space-4); }
.ph-ios-sheet-header { display: flex; align-items: center; gap: var(--ph-space-4); margin-bottom: var(--ph-space-4); }
.ph-ios-sheet-icon { width: 56px; height: 56px; background: var(--ph-forest); border-radius: var(--ph-r-md); display: flex; align-items: center; justify-content: center; font-size: 30px; flex-shrink: 0; }
.ph-ios-sheet-title { font-family: var(--ph-font-display); font-size: 17px; font-weight: 700; color: var(--ph-ink); }
.ph-ios-sheet-sub { font-size: 13px; color: var(--ph-stone); margin-top: 2px; }
.ph-ios-sheet-instruction {
  background: var(--ph-surface); border: 1px solid var(--ph-border);
  border-radius: var(--ph-r-md); padding: var(--ph-space-4);
  font-size: 14px; color: var(--ph-ink); line-height: 1.6;
  margin-bottom: var(--ph-space-4); text-align: center;
}
.ph-ios-share-icon { display: inline-block; width: 20px; height: 20px; background: #007AFF; border-radius: 4px; color: white; font-size: 13px; line-height: 20px; text-align: center; vertical-align: middle; margin: 0 2px; }
.ph-ios-sheet-dismiss { width: 100%; padding: 14px; background: var(--ph-surface); border: 1.5px solid var(--ph-border); border-radius: var(--ph-r-md); font-family: var(--ph-font-display); font-size: 15px; font-weight: 600; color: var(--ph-stone); cursor: pointer; transition: background .2s; }
.ph-ios-sheet-dismiss:hover { background: var(--ph-mist); }

/* Dark backdrop for sheets */
.ph-sheet-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.4);
  z-index: 8400; opacity: 0; pointer-events: none; transition: opacity .3s;
}
.ph-sheet-overlay.is-visible { opacity: 1; pointer-events: all; }

/* Installed toast */
.ph-installed-toast {
  position: fixed; bottom: var(--ph-space-7); left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--ph-forest); color: var(--ph-white);
  padding: 12px 24px; border-radius: var(--ph-r-full);
  font-size: 14px; font-weight: 600;
  box-shadow: var(--ph-shadow-lg); z-index: 9000;
  transition: transform .4s var(--ph-ease-out);
  white-space: nowrap; display: flex; align-items: center; gap: var(--ph-space-2);
}
.ph-installed-toast.is-visible { transform: translateX(-50%) translateY(0); }

/* Offline toast */
.ph-offline-toast {
  position: fixed; bottom: var(--ph-space-4); left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--ph-ember); color: var(--ph-white);
  padding: 12px 20px; border-radius: var(--ph-r-full);
  font-size: 13px; font-weight: 600; box-shadow: var(--ph-shadow-lg);
  z-index: 9999; transition: transform .4s var(--ph-ease-out); white-space: nowrap;
}
.ph-offline-toast.is-visible { transform: translateX(-50%) translateY(0); }

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — TABLET ≥ 600px
════════════════════════════════════════════════════════════ */
@media (min-width: 600px) {
  .ph-stats-strip { grid-template-columns: repeat(3, 1fr); }
  /* Net Position no longer needs full span at tablet */
  .ph-stat-net { grid-column: auto; }
  .ph-services-grid { grid-template-columns: repeat(2, 1fr); }
  .phoenix-footer-inner { grid-template-columns: 1fr 1fr; }
}

/* ════════════════════════════════════════════════════════════
   RESPONSIVE — DESKTOP ≥ 900px
════════════════════════════════════════════════════════════ */
@media (min-width: 900px) {
  .phoenix-hamburger { display: none; }
  .phoenix-nav { display: flex; }
  .ph-stats-strip { grid-template-columns: repeat(6, 1fr); }
  .ph-services-grid { grid-template-columns: repeat(4, 1fr); }
  .phoenix-footer-inner { grid-template-columns: 2fr 1fr 1fr; }
  .ph-install-fab { bottom: var(--ph-space-6); right: var(--ph-space-6); }
}

/* ════════════════════════════════════════════════════════════
   PRINT
════════════════════════════════════════════════════════════ */
@media print {
  .phoenix-header, .phoenix-footer, .ph-hero,
  .ph-login-section, .ph-services, .ph-contact,
  .ph-support-strip, .ph-welcome-right,
  .ph-install-fab, .ph-ios-sheet { display: none !important; }
  .ph-dashboard { display: block !important; padding: 0; }
}

/* ── Hero compact on mobile ────────────────── */
@media (max-width: 480px) {
  .ph-hero { min-height: 50dvh !important; padding: 48px 16px 36px; }
  .ph-hero-title { font-size: clamp(1.8rem, 9vw, 2.8rem) !important; }
  .ph-hero-stats { padding: 12px 16px; gap: 12px; }
}
