@import url('https://fonts.googleapis.com/css2?family=Satisfy&family=Bebas+Neue&family=Outfit:wght@300;400;500;600;700&family=Playfair+Display:wght@400;600&display=swap');

:root {
  --gold:#B07800;--gold-bright:#D49200;--gold-light:#C08200;--gold-dim:#6B3E06;
  --gold-pale:rgba(176,122,0,0.08);--gold-glow:rgba(176,122,0,0.25);--gold-glow2:rgba(176,122,0,0.12);
  --bg:#07060A;--bg2:#0D0B10;--bg3:#131118;
  --surface:#181520;--surface2:#201D2A;--surface3:#2A2638;
  --border:rgba(176,122,0,0.12);--border2:rgba(176,122,0,0.28);--border3:rgba(255,255,255,0.06);
  --text:#F0EAD6;--text-mid:#C8BFA8;--text-dim:#7A7068;--text-faint:#3A3530;
  --success:#4ADE80;--danger:#F87171;--warning:#FBBF24;--info:#60A5FA;
  --radius-xs:8px;--radius-sm:12px;--radius-md:16px;--radius-lg:20px;--radius-xl:28px;
  --nav-h:72px;
}
[data-theme="light"] {
  --bg:#FAF6EE;--bg2:#F2EDE2;--bg3:#EAE3D4;
  --surface:#FFFFFF;--surface2:#F5F0E8;--surface3:#EDE8DE;
  --border:rgba(180,140,50,0.18);--border2:rgba(180,140,50,0.35);--border3:rgba(0,0,0,0.06);
  --text:#1A1408;--text-mid:#4A3F2A;--text-dim:#6B5C40;--text-faint:#A89878;
  /* Gold overrides — light bg needs dark amber so gold text stays legible */
  --gold:#8B6914;
  --gold-bright:#6B4E0B;
  --gold-light:#7A5C10;
  --gold-dim:#5C3E08;
  --gold-pale:rgba(139,105,20,0.08);
  --gold-glow:rgba(139,105,20,0.22);
  --gold-glow2:rgba(139,105,20,0.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{
  font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);
  min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;
  padding-bottom:var(--nav-h);
}
body::before{
  content:'';position:fixed;top:-40%;left:-20%;width:80%;height:80%;
  background:radial-gradient(ellipse,rgba(176,122,0,0.04) 0%,transparent 65%);
  pointer-events:none;z-index:0;animation:bgPulse 8s ease-in-out infinite alternate;
}
@keyframes bgPulse{0%{opacity:.6;transform:scale(1);}100%{opacity:1;transform:scale(1.1);}}
::-webkit-scrollbar{width:3px;height:3px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px;}

.topbar{
  position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;background:rgba(7,6,10,0.85);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);
}
[data-theme="light"] .topbar{background:rgba(250,246,238,0.85);}
.back-btn{
  font-family:'Bebas Neue',sans-serif;font-size:15px;letter-spacing:2px;color:var(--text-mid);
  text-decoration:none;background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:6px;transition:color .2s;
}
.back-btn:hover{color:var(--gold-light);}
.hero-header{
  padding:24px 20px 20px;
  background:linear-gradient(180deg,rgba(176,122,0,0.06) 0%,transparent 100%);
  border-bottom:1px solid var(--border);position:relative;overflow:hidden;
}
.hero-header::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  animation:scanLine 4s ease-in-out infinite;
}
@keyframes scanLine{0%,100%{opacity:.3;}50%{opacity:1;}}
.page{padding:20px 18px 40px;position:relative;z-index:1;max-width:540px;margin:0 auto;}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(17px,3.5vw,22px);letter-spacing:3px;color:var(--text);margin-bottom:8px;}
.gold-line{height:1px;background:linear-gradient(90deg,var(--gold),rgba(176,122,0,0.1));margin-bottom:18px;position:relative;}
.gold-line::after{content:'';position:absolute;left:0;top:0;height:1px;width:40px;background:var(--gold-bright);animation:glide 3s ease-in-out infinite;}
@keyframes glide{0%{left:0;opacity:1;}100%{left:100%;opacity:0;}}
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);
  padding:18px;margin-bottom:14px;position:relative;overflow:hidden;transition:border-color .3s,transform .2s;
}
.card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(176,122,0,0.04) 0%,transparent 60%);pointer-events:none;}
.card:hover{border-color:var(--border2);transform:translateY(-1px);}
.card-glow{border-color:var(--border2);box-shadow:0 0 30px rgba(176,122,0,0.08),inset 0 1px 0 rgba(176,122,0,0.1);}
.stat-box{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 18px;min-width:100px;flex-shrink:0;position:relative;overflow:hidden;transition:all .3s;
}
.stat-box::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transform:scaleX(0);transform-origin:left;transition:transform .4s ease;}
.stat-box:hover::after{transform:scaleX(1);}
.stat-number{font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,5.5vw,48px);letter-spacing:2px;color:var(--gold-bright);line-height:1;animation:countUp .6s ease both;}
@keyframes countUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.stat-label{font-size:11px;color:var(--text-dim);letter-spacing:1.5px;text-transform:uppercase;margin-top:3px;}
.stat-sub{font-size:11px;color:var(--gold);margin-top:2px;}
.btn{
  font-family:'Bebas Neue',sans-serif;letter-spacing:2px;font-size:15px;border-radius:var(--radius-xs);
  padding:14px 20px;cursor:pointer;width:100%;border:none;transition:all .2s ease;
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn:active{transform:scale(0.97);}
.btn-gold{background:linear-gradient(135deg,#6B3E06 0%,#D49200 45%,#F0B830 55%,#6B3E06 100%);background-size:200% 100%;color:#1A0A00;animation:shimmerBg 3s ease infinite;}
@keyframes shimmerBg{0%{background-position:100% 0;}50%{background-position:0% 0;}100%{background-position:100% 0;}}
.btn-gold:hover{filter:brightness(1.1);box-shadow:0 4px 24px rgba(176,122,0,0.4);}
.btn-outline{background:transparent;border:1px solid var(--border2);color:var(--gold-light);}
.btn-outline:hover{background:var(--gold-pale);border-color:var(--gold);}
.btn-ghost{background:var(--surface2);border:1px solid var(--border3);color:var(--text-mid);}
.btn-ghost:hover{background:var(--surface3);color:var(--text);}
.btn-success{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;}
.btn-success:hover{box-shadow:0 4px 20px rgba(34,197,94,0.35);}
.btn-xs{font-size:12px;padding:8px 14px;width:auto;border-radius:6px;}
.btn-sm{font-size:13px;padding:11px 16px;}
.badge{font-family:'Outfit',sans-serif;font-size:10px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;padding:4px 10px;border-radius:99px;white-space:nowrap;}
.badge-new{background:rgba(96,165,250,0.15);color:#93C5FD;border:1px solid rgba(96,165,250,0.3);}
.badge-contacted{background:rgba(176,122,0,0.15);color:var(--gold-light);border:1px solid var(--border2);}
.badge-qualified{background:rgba(74,222,128,0.12);color:#86EFAC;border:1px solid rgba(74,222,128,0.3);}
.badge-closed{background:rgba(167,139,250,0.15);color:#C4B5FD;border:1px solid rgba(167,139,250,0.3);}
.badge-live{background:rgba(74,222,128,0.12);color:#86EFAC;border:1px solid rgba(74,222,128,0.3);animation:livePulse 2s infinite;}
.badge-draft{background:rgba(148,163,184,0.1);color:#94A3B8;border:1px solid rgba(148,163,184,0.2);}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,0);}50%{box-shadow:0 0 0 4px rgba(74,222,128,0.1);}}
.input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-family:'Outfit',sans-serif;font-size:15px;padding:13px 16px;outline:none;transition:border-color .2s,box-shadow .2s;}
.input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-glow2);}
.input::placeholder{color:var(--text-dim);}
textarea.input{resize:vertical;min-height:90px;}
.pwd-wrap{position:relative;display:flex;align-items:center;}
.pwd-wrap .input{padding-right:46px;}
.pwd-eye{position:absolute;right:0;top:0;bottom:0;width:44px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-dim);transition:color .2s;line-height:0;}
.pwd-eye:hover{color:var(--gold-light);}
.form-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);display:block;margin-bottom:8px;}
.chip{display:inline-flex;align-items:center;font-family:'Outfit',sans-serif;font-size:12px;font-weight:500;padding:7px 14px;border-radius:99px;border:1px solid var(--border);background:var(--surface2);color:var(--text-dim);cursor:pointer;white-space:nowrap;transition:all .2s;user-select:none;}
.chip:hover{border-color:var(--border2);color:var(--text-mid);}
.chip.active{border-color:var(--gold);background:rgba(176,122,0,0.12);color:var(--gold-light);box-shadow:0 0 12px rgba(176,122,0,0.15);}
.scroll-row{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px;}
.scroll-row::-webkit-scrollbar{display:none;}
.lead-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:10px;text-decoration:none;color:var(--text);transition:all .25s ease;position:relative;overflow:hidden;}
.lead-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .3s ease;}
.lead-card:hover{border-color:var(--border2);transform:translateX(4px);background:var(--surface2);}
.lead-card:hover::before{transform:scaleY(1);}
.lead-name{font-weight:600;font-size:15px;margin-bottom:3px;}
.lead-sub{font-size:13px;color:var(--text-dim);margin-bottom:4px;}
.lead-budget{font-size:12px;color:var(--gold);font-weight:500;margin-top:4px;}
.inv-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border3);}
.inv-row:last-child{border-bottom:none;padding-bottom:0;}
.inv-name{font-size:14px;font-weight:500;margin-bottom:3px;}
.inv-meta{font-size:12px;color:var(--text-dim);}
.qa-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:72px;text-decoration:none;color:var(--text);flex-shrink:0;transition:all .3s ease;position:relative;overflow:hidden;}
.qa-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at center,var(--gold-glow2),transparent);opacity:0;transition:opacity .3s;}
.qa-card:hover{border-color:var(--border2);transform:translateY(-4px);box-shadow:0 8px 24px rgba(176,122,0,0.12);}
.qa-card:hover::after{opacity:1;}
.qa-icon{font-size:22px;color:var(--gold-light);}
.qa-label{font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:1.5px;color:var(--text-dim);}
.switch-row{display:flex;gap:6px;margin-bottom:20px;background:var(--surface);padding:5px;border-radius:var(--radius-xs);border:1px solid var(--border);}
.switch-btn{flex:1;padding:9px 8px;border:none;border-radius:6px;background:transparent;color:var(--text-dim);font-family:'Bebas Neue',sans-serif;font-size:13px;letter-spacing:1.5px;cursor:pointer;transition:all .2s;}
.switch-btn.active{background:rgba(176,122,0,0.15);color:var(--gold-bright);box-shadow:inset 0 0 0 1px rgba(176,122,0,0.3);}
.upload-box{border:1.5px dashed var(--border2);border-radius:var(--radius-md);padding:40px 24px;text-align:center;cursor:pointer;transition:all .3s;background:var(--gold-pale);position:relative;overflow:hidden;}
.upload-box::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,rgba(176,122,0,0.06),transparent 70%);animation:uploadPulse 3s ease-in-out infinite;}
@keyframes uploadPulse{0%,100%{transform:scale(1);opacity:.5;}50%{transform:scale(1.05);opacity:1;}}
.upload-box:hover{border-color:var(--gold);background:rgba(176,122,0,0.1);transform:scale(1.01);}
.progress-bar{height:5px;background:var(--surface3);border-radius:99px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold-bright));border-radius:99px;transition:width .8s ease;position:relative;overflow:hidden;}
.progress-fill::after{content:'';position:absolute;top:0;left:-100%;right:-100%;bottom:0;background:linear-gradient(90deg,transparent 30%,rgba(255,255,255,0.5) 50%,transparent 70%);animation:sweep 2s ease-in-out infinite;}
@keyframes sweep{0%{transform:translateX(-60%);}100%{transform:translateX(60%);}}
.divider{height:1px;background:var(--border3);margin:14px 0;}
.chat-row{display:flex;margin-bottom:14px;}
.chat-row.user{justify-content:flex-end;}
.bubble-ai{background:var(--surface2);border:1px solid var(--border);border-radius:4px 18px 18px 18px;padding:12px 16px;font-size:14px;max-width:82%;line-height:1.6;animation:bubbleIn .3s ease both;}
.bubble-user{background:linear-gradient(135deg,var(--gold-dim),var(--gold));color:#0A0800;border-radius:18px 4px 18px 18px;padding:12px 16px;font-size:14px;max-width:82%;animation:bubbleIn .3s ease both;}
@keyframes bubbleIn{from{opacity:0;transform:translateY(6px) scale(.95);}to{opacity:1;transform:none;}}
.quick-replies{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding-left:4px;}
.qr-btn{background:var(--surface2);border:1px solid var(--border2);border-radius:99px;color:var(--gold-light);font-family:'Outfit',sans-serif;font-size:13px;padding:8px 14px;cursor:pointer;transition:all .2s;}
.qr-btn:hover{background:var(--gold-pale);border-color:var(--gold);transform:translateY(-1px);}
.typing{display:flex;gap:5px;align-items:center;padding:4px 0;}
.dot{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:typingBounce 1.2s ease infinite;}
.dot:nth-child(2){animation-delay:.2s;}.dot:nth-child(3){animation-delay:.4s;}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);opacity:.4;}30%{transform:translateY(-6px);opacity:1;}}
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:rgba(13,11,16,0.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:center;padding:0 6px 8px;z-index:200;}
[data-theme="light"] .bottom-nav{background:rgba(250,246,238,0.92);}
.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;color:var(--text-dim);flex:1;padding:10px 4px;border-radius:var(--radius-xs);transition:all .2s;position:relative;}
.nav-item::before{content:'';position:absolute;top:0;left:25%;right:25%;height:2px;background:var(--gold);border-radius:0 0 2px 2px;transform:scaleX(0);transition:transform .3s;}
.nav-item.active::before{transform:scaleX(1);}
.nav-item.active{color:var(--gold-light);}
.nav-item:hover{color:var(--text-mid);}
.nav-icon{font-size:18px;line-height:1;}
.nav-item .label{font-family:'Bebas Neue',sans-serif;font-size:10px;letter-spacing:1.5px;}
@media(max-width:420px){.nav-item .label{display:none;}.nav-item{padding:12px 4px;gap:0;}}
.ornament{font-size:12px;color:var(--gold-dim);letter-spacing:8px;text-align:center;margin-bottom:8px;animation:ornamentFade 3s ease-in-out infinite alternate;}
@keyframes ornamentFade{0%{opacity:.4;}100%{opacity:1;letter-spacing:10px;}}
.theme-toggle{width:36px;height:36px;background:var(--surface2);border:1px solid var(--border);border-radius:50%;color:var(--gold-light);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;}
.theme-toggle:hover{background:var(--surface3);border-color:var(--border2);transform:rotate(30deg);}
.fade-up  {animation:fadeUp .5s ease both;}
.fade-up-2{animation:fadeUp .5s ease .1s both;}
.fade-up-3{animation:fadeUp .5s ease .2s both;}
.fade-up-4{animation:fadeUp .5s ease .3s both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.glow-text{text-shadow:0 0 20px rgba(176,122,0,0.5),0 0 40px rgba(176,122,0,0.2);}

/* ── Focus spotlight — fires on click, draws eye to the tapped element ────── */


/* ── Glassmorphism cards ──────────────────────────────────────────────────── */
.card{
  background:rgba(24,21,32,0.7);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid rgba(176,122,0,0.13);
  box-shadow:0 4px 24px rgba(0,0,0,0.18), inset 0 1px 0 rgba(176,122,0,0.06);
}
.card:hover{
  border-color:rgba(176,122,0,0.32);
  box-shadow:0 8px 32px rgba(0,0,0,0.22), 0 0 0 1px rgba(176,122,0,0.08), inset 0 1px 0 rgba(176,122,0,0.1);
}
[data-theme="light"] .card{background:rgba(255,255,255,0.8);box-shadow:0 4px 24px rgba(180,140,50,0.08),inset 0 1px 0 rgba(176,122,0,0.08);}

/* ── Light mode: fix hardcoded light-pastel text on pale backgrounds ─────── */
[data-theme="light"] .badge-new     {color:#1D4ED8;background:rgba(37,99,235,0.1); border-color:rgba(37,99,235,0.25);}
[data-theme="light"] .badge-contacted{color:var(--gold-light);}
[data-theme="light"] .badge-qualified{color:#15803D;background:rgba(21,128,61,0.1); border-color:rgba(21,128,61,0.25);}
[data-theme="light"] .badge-closed  {color:#6D28D9;background:rgba(109,40,217,0.1);border-color:rgba(109,40,217,0.25);}
[data-theme="light"] .badge-live    {color:#15803D;background:rgba(21,128,61,0.1); border-color:rgba(21,128,61,0.25);}
[data-theme="light"] .badge-draft   {color:#475569;background:rgba(71,85,105,0.1); border-color:rgba(71,85,105,0.2);}
[data-theme="light"] .tier-hot  {color:#B91C1C;background:rgba(185,28,28,0.1);border-color:rgba(185,28,28,0.25);}
[data-theme="light"] .tier-warm {color:#92400E;background:rgba(146,64,14,0.1);border-color:rgba(146,64,14,0.25);}
[data-theme="light"] .tier-cold {color:#334155;background:rgba(51,65,85,0.08); border-color:rgba(51,65,85,0.2);}
[data-theme="light"] .qr-btn    {color:var(--gold-light);}
[data-theme="light"] .chip.active{color:var(--gold-light);}
[data-theme="light"] .switch-btn.active{color:var(--gold-light);}
[data-theme="light"] .stat-number{color:var(--gold-bright);}
[data-theme="light"] .stat-sub   {color:var(--gold);}
[data-theme="light"] .ai-mode-dot{background:#15803D;}
[data-theme="light"] .ai-mode-dot.mock{background:#6B5C40;}

/* ── Scroll reveal ────────────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .55s ease, transform .55s cubic-bezier(.22,1,.36,1);}
.reveal.visible{opacity:1;transform:none;}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity .5s ease, transform .5s cubic-bezier(.22,1,.36,1);}
.reveal-left.visible{opacity:1;transform:none;}
.reveal-scale{opacity:0;transform:scale(.94);transition:opacity .45s ease, transform .45s cubic-bezier(.34,1.56,.64,1);}
.reveal-scale.visible{opacity:1;transform:scale(1);}

/* ── Stagger children ─────────────────────────────────────────────────────── */
.stagger > *{opacity:0;transform:translateY(14px);transition:opacity .4s ease, transform .4s cubic-bezier(.22,1,.36,1);}
.stagger.visible > *{opacity:1;transform:none;}
.stagger.visible > *:nth-child(1){transition-delay:.04s;}
.stagger.visible > *:nth-child(2){transition-delay:.10s;}
.stagger.visible > *:nth-child(3){transition-delay:.16s;}
.stagger.visible > *:nth-child(4){transition-delay:.22s;}
.stagger.visible > *:nth-child(5){transition-delay:.28s;}
.stagger.visible > *:nth-child(6){transition-delay:.34s;}

/* ── Enhanced bottom nav ─────────────────────────────────────────────────── */
.nav-item.active .nav-icon-wrap{
  background:rgba(176,122,0,0.14);
  border-radius:10px;
  box-shadow:0 0 14px rgba(176,122,0,0.2);
  transform:translateY(-2px);
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
}
.nav-item .nav-icon-wrap{
  width:36px;height:30px;display:flex;align-items:center;justify-content:center;
  border-radius:10px;transition:all .25s ease;
}
.nav-item.active .label{color:var(--gold-bright);}

/* ── Hero header shine ────────────────────────────────────────────────────── */
.hero-header{position:relative;}
.hero-header::before{
  content:'';position:absolute;top:-60%;left:-20%;width:140%;height:140%;
  background:radial-gradient(ellipse at 50% 0%,rgba(176,122,0,0.07) 0%,transparent 60%);
  pointer-events:none;animation:heroPulse 6s ease-in-out infinite alternate;
}
@keyframes heroPulse{0%{opacity:.5;transform:scale(1);}100%{opacity:1;transform:scale(1.08);}}

/* ── Stat box glow on hover ───────────────────────────────────────────────── */
.stat-box:hover{
  border-color:var(--border2);
  box-shadow:0 0 20px rgba(176,122,0,0.12), inset 0 0 20px rgba(176,122,0,0.04);
  transform:translateY(-2px);
}
.stat-box{transition:all .3s cubic-bezier(.22,1,.36,1);}

/* ── Lead card left bar ───────────────────────────────────────────────────── */
.lead-card{transition:all .28s cubic-bezier(.22,1,.36,1);}
.lead-card:hover{transform:translateX(5px);box-shadow:0 4px 20px rgba(176,122,0,0.08);}

/* ── Quick action card glow ───────────────────────────────────────────────── */
.qa-card:hover{
  box-shadow:0 12px 32px rgba(176,122,0,0.15);
  border-color:var(--border2);
  transform:translateY(-5px);
}

/* ── Input focus glow ─────────────────────────────────────────────────────── */
.input:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(176,122,0,0.15), 0 0 16px rgba(176,122,0,0.08);
}

/* ── Section title underline animation ───────────────────────────────────── */
.section-title{position:relative;display:inline-block;}

/* ── Badge pulse (new items) ─────────────────────────────────────────────── */
.badge-new{animation:badgePulse 2.5s ease-in-out infinite;}
@keyframes badgePulse{0%,100%{box-shadow:0 0 0 0 rgba(96,165,250,0);}50%{box-shadow:0 0 0 4px rgba(96,165,250,0.12);}}

/* ── Topbar gradient border ───────────────────────────────────────────────── */
.topbar::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(176,122,0,0.4),transparent);
}
.topbar{position:relative;}

/* ── Toast flash messages ─────────────────────────────────────────────────── */
.flash-msg{
  animation:toastIn .4s cubic-bezier(.34,1.56,.64,1) both;
  box-shadow:0 8px 32px rgba(0,0,0,0.3);
  border-radius:12px;
}
@keyframes toastIn{from{opacity:0;transform:translateY(-20px) scale(.92);}to{opacity:1;transform:none;}}

/* ── Shimmer loading skeleton ─────────────────────────────────────────────── */
.skeleton{
  background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);
  background-size:200% 100%;
  animation:shimmer 1.5s infinite;
  border-radius:8px;
}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}

/* ── Ripple effect ───────────────────────────────────────────────────────── */
.ripple-host{position:relative;overflow:hidden;}
.ripple-wave{
  position:absolute;border-radius:50%;pointer-events:none;
  background:rgba(176,122,0,0.35);
  transform:scale(0);animation:rippleAnim .55s ease-out forwards;
}
@keyframes rippleAnim{
  to{transform:scale(4);opacity:0;}
}

/* ── Page transition ─────────────────────────────────────────────────────── */
body{animation:pageIn .32s ease both;}
@keyframes pageIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
body.page-exit{animation:pageOut .18s ease forwards;pointer-events:none;}
@keyframes pageOut{to{opacity:0;transform:translateY(-4px);}}

/* ── Nav item tap spring ─────────────────────────────────────────────────── */
.nav-item:active{transform:scale(.85);transition:transform .12s ease;}
.nav-item{transition:color .2s, transform .15s ease;}

/* ── Card / button press feel ────────────────────────────────────────────── */
.card{transition:border-color .3s, transform .18s cubic-bezier(.34,1.56,.64,1), box-shadow .2s;}
.card:active{transform:scale(.983);}
.lead-card:active{transform:translateX(2px) scale(.99);}
.qa-card:active{transform:translateY(-2px) scale(.96);}
.btn:active{transform:scale(0.95);}
.chip:active{transform:scale(.94);}
.qr-btn:active{transform:scale(.94);}

/* ── Responsive grid helpers ─────────────────────────────────────────────── */
.field-row{display:grid;gap:10px;margin-bottom:12px;}
.col2{grid-template-columns:1fr 1fr;}
.col3{grid-template-columns:1fr 1fr 1fr;}

/* ── Responsive breakpoints ──────────────────────────────────────────────── */

/* Tablet (768px+) — widen the content column, expand grids */
@media (min-width:768px){
  .page{max-width:720px;padding:24px 28px 60px;}
  .hero-header{padding:32px 28px 24px;}
  .topbar{padding:16px 28px;}
  .stat-box{min-width:130px;}
  .bottom-nav{max-width:720px;left:50%;transform:translateX(-50%);border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--border);border-bottom:none;}
  .lead-card{padding:18px 22px;}
  .card{padding:22px;}
  .col2{grid-template-columns:1fr 1fr;}
  .col3{grid-template-columns:1fr 1fr 1fr;}
  .admin-stat-grid{grid-template-columns:repeat(4,1fr)!important;}
  .bubble-ai,.bubble-user{max-width:68%;}
  #hamburger-btn{top:28px;}
}

/* Desktop (1024px+) */
@media (min-width:1024px){
  .page{max-width:860px;}
  .hero-header{padding:36px 32px 28px;}
  .topbar{padding:18px 32px;}
  .bottom-nav{max-width:860px;}
  .stat-box{min-width:150px;}
}

/* ── Mobile (< 640px) ────────────────────────────────────────────────────── */
@media (max-width:640px){
  /* Stack all 2/3-col grids into 1-col */
  .col2,.col3{grid-template-columns:1fr!important;}

  /* Page padding */
  .page{padding:14px 14px 40px;}
  .topbar{padding:12px 14px;}
  .hero-header{padding:20px 16px 18px;}

  /* Typography scale-down */
  .stat-box{min-width:80px;padding:10px 12px;}
  .btn{font-size:13px;padding:12px 16px;}

  /* Admin hero */
  .admin-title{font-size:26px!important;letter-spacing:2px!important;}
  .admin-hero{padding:16px 14px!important;}
  .admin-hero-left{padding-left:30px!important;}

  /* Hide secondary buttons in admin hero on mobile — reachable via sidebar */
  .admin-hero-actions .hide-mobile{display:none!important;}

  /* Make remaining admin hero buttons smaller */
  .admin-hero-actions a, .admin-hero-actions button{
    font-size:10px!important;padding:6px 10px!important;letter-spacing:1px!important;
  }

  /* Admin stat grid always 2×2 on mobile */
  .admin-stat-grid{grid-template-columns:repeat(2,1fr)!important;}

  /* Leads / enquiry tab row */
  .enquiry-tabs a{padding:8px 4px!important;font-size:8px!important;}

  /* Topbar back+title row: don't overflow */
  .topbar{flex-wrap:wrap;gap:6px;}

  /* Flash toasts full width */
  #flash-container{width:96%!important;max-width:none!important;}

  /* Inventory row — shrink action buttons */
  .inv-row{flex-wrap:wrap;gap:6px;}

  /* Log table */
  .log-table .hide-mobile{display:none;}
  .log-table td,.log-table th{padding:8px 6px;font-size:12px;}
}

/* ── Very small phones (< 380px) ─────────────────────────────────────────── */
@media (max-width:380px){
  .admin-title{font-size:22px!important;}
  .btn{padding:10px 12px;}
  .nav-item .label{font-size:9px;}
}

/* ── Activity log table — hide details on small screens ─────────────────── */
@media (max-width:600px){
  .log-table .hide-mobile{display:none;}
  .log-table td,.log-table th{padding:8px 6px;font-size:12px;}
}

/* ── Large desktop (1280px+) ─────────────────────────────────────────────── */
@media (min-width:1280px){
  .page{max-width:1060px;padding:32px 48px 60px;}
  .hero-header{padding:40px 48px 32px;}
  .topbar{padding:20px 48px;}
  .bottom-nav{max-width:1060px;}
  .stat-box{min-width:160px;}
  .stat-number{font-size:52px;}
  .section-title{font-size:24px;}
  .card{padding:28px;}
  .lead-card{padding:20px 26px;}
  .bubble-ai,.bubble-user{max-width:55%;}
  .admin-stat-grid{grid-template-columns:repeat(4,1fr)!important;}
}

/* ── Responsive Modal System ─────────────────────────────────────────────── */
.modal-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.78);
  z-index:500;
  align-items:flex-end;justify-content:center;
}
.modal-overlay.open{display:flex;}
.modal-box{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  padding:24px 20px 44px;
  width:100%;max-width:560px;
  max-height:90vh;overflow-y:auto;
  animation:slideUp .26s cubic-bezier(.22,1,.36,1);
}
@keyframes slideUp{from{transform:translateY(40px);opacity:0;}to{transform:none;opacity:1;}}
@media(min-width:768px){
  .modal-overlay{align-items:center;padding:16px;}
  .modal-box{
    border-radius:var(--radius-xl);
    max-height:84vh;padding-bottom:28px;
    box-shadow:0 24px 64px rgba(0,0,0,.55);
    animation:modalIn .22s cubic-bezier(.34,1.56,.64,1);
  }
}
@keyframes modalIn{from{transform:scale(.93);opacity:0;}to{transform:scale(1);opacity:1;}}

/* ── Member grid — 2 cols on tablet+ ───────────────────────────────────── */
.member-grid{display:flex;flex-direction:column;gap:10px;}
@media(min-width:768px){
  .member-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
  .member-grid .card{margin-bottom:0!important;}
}

/* ── Form date / field grids ────────────────────────────────────────────── */
.form-grid{display:grid;gap:10px;margin-bottom:14px;grid-template-columns:1fr;}
@media(min-width:480px){
  .form-grid.col2{grid-template-columns:1fr 1fr;}
  .form-grid.col3{grid-template-columns:1fr 1fr 1fr;}
}

/* ── Anchored Popover Panel ─────────────────────────────────────────────── */
/* Desktop: floats near the trigger. Mobile: slides up as bottom-sheet.     */
.popover-back{display:none;position:fixed;inset:0;z-index:598;}
.popover-back.open{display:block;}
.popover-panel{
  position:fixed;z-index:599;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--radius-xl);
  box-shadow:0 8px 40px rgba(0,0,0,.55);
  max-height:82vh;overflow-y:auto;overscroll-behavior:contain;
  width:360px;max-width:calc(100vw - 32px);
  padding:20px 20px 28px;
  opacity:0;pointer-events:none;
  transform:translateY(-8px) scale(.97);
  transition:opacity .18s ease,transform .2s cubic-bezier(.22,1,.36,1);
}
.popover-panel.open{
  opacity:1;pointer-events:auto;
  transform:translateY(0) scale(1);
}
/* Mobile: use display:none/block for reliability (opacity trick is flaky on Android) */
@keyframes popoverSheetUp{
  from{transform:translateY(44px);opacity:.5;}
  to{transform:translateY(0);opacity:1;}
}
/* Tablet + Desktop: centered modal with backdrop */
@media(min-width:480px){
  .popover-back.open{background:rgba(0,0,0,.6);}
  .popover-panel.popover-centered{
    left:50%!important;top:50%!important;
    right:auto!important;bottom:auto!important;
    transform:translate(-50%,-50%) scale(.94)!important;
    opacity:0;
    transition:opacity .2s ease,transform .22s cubic-bezier(.34,1.2,.64,1)!important;
  }
  .popover-panel.popover-centered.open{
    transform:translate(-50%,-50%) scale(1)!important;
    opacity:1!important;
  }
}
/* Mobile: bottom-sheet */
@media(max-width:479px){
  .popover-back.open{background:rgba(0,0,0,.55);}
  .popover-panel{
    display:none!important;
    left:0!important;right:0!important;
    bottom:0!important;top:auto!important;
    width:100%!important;max-width:100%!important;
    max-height:88vh!important;
    overflow-y:auto!important;
    overscroll-behavior:contain;
    border-radius:var(--radius-xl) var(--radius-xl) 0 0;
    padding-bottom:calc(var(--nav-h,64px) + 8px);
    opacity:1!important;pointer-events:auto!important;
    transform:none!important;
    transition:none!important;
  }
  .popover-panel.open{
    display:block!important;
    animation:popoverSheetUp .28s cubic-bezier(.22,1,.36,1) forwards;
  }
}

/* ── Sticky filter drawer footer ────────────────────────────────────────── */
.drawer-foot{
  position:sticky;bottom:0;
  background:var(--surface);
  padding:14px 18px 20px;
  border-top:1px solid var(--border);
}
