/* ============================================================
   chatwithLisa.app  —  styles.css
   LISA core: hot-pink + cyan TikTok neon
   BAGS accent: acid lime (reserved for money / stats / rewards)
   ============================================================ */

:root{
  --bg:#08070d;
  --bg-2:#0d0c16;
  --pink:#ff4fd8;
  --cyan:#00e5ff;
  --lime:#c6ff2e;            /* BAGS money accent */
  --fg:#ffffff;
  --muted:rgba(255,255,255,.66);
  --faint:rgba(255,255,255,.40);
  --line:rgba(255,255,255,.10);
  --card:rgba(20,18,30,.62);
  --card-bd:rgba(255,255,255,.10);
  --grid:rgba(255,79,216,.13);
  --up:#37e29a;
  --down:#ff5e7d;
  --shadow:0 18px 60px rgba(0,0,0,.5);
  --r:18px;
}
body.light{
  --bg:#f6f5fb; --bg-2:#ffffff;
  --cyan:#0a84ff; --fg:#0b0a14;
  --muted:rgba(10,10,20,.66); --faint:rgba(10,10,20,.40);
  --line:rgba(10,10,20,.10); --card:rgba(255,255,255,.85);
  --card-bd:rgba(10,10,20,.10); --grid:rgba(10,132,255,.12);
}

*{box-sizing:border-box;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
html{scroll-behavior:smooth}
html,body{margin:0}
body{
  color:var(--fg);
  background:var(--bg);
  font-family:Nunito,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Inter,Arial;
  min-height:100dvh;
  overflow-x:hidden;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  transition:background .5s,color .5s;
}
a{color:inherit}
img{max-width:100%;display:block}

/* ---------- animated atmosphere ---------- */
.scene{position:fixed;inset:0;z-index:-1;
  background:
    linear-gradient(90deg,var(--grid) 1px,transparent 1px) 0 0/clamp(38px,5vw,52px) clamp(38px,5vw,52px),
    linear-gradient(0deg,var(--grid) 1px,transparent 1px) 0 0/clamp(38px,5vw,52px) clamp(38px,5vw,52px),
    radial-gradient(1100px 560px at 18% 120%,rgba(255,79,216,.14),transparent 46%),
    radial-gradient(820px 460px at 120% -8%,rgba(0,229,255,.12),transparent 46%),
    var(--bg);
  animation:drift 22s linear infinite;
}
@keyframes drift{0%{background-position:0 0,0 0,18% 120%,120% -8%}100%{background-position:52px 52px,52px 52px,28% 110%,108% 2%}}
.scene::after{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(transparent 0 2px,rgba(255,255,255,.025) 2px 3px);
  opacity:.4;animation:flicker 3s steps(7,end) infinite}
@keyframes flicker{0%,19%,22%,63%,100%{opacity:.3}20%,62%{opacity:.5}}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;
  padding:12px clamp(14px,4vw,32px);
  backdrop-filter:blur(10px);background:linear-gradient(to bottom,rgba(8,7,13,.7),transparent);
  border-bottom:1px solid var(--line)}
body.light .topbar{background:linear-gradient(to bottom,rgba(255,255,255,.8),transparent)}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.3px;text-decoration:none}
.brand img{width:34px;height:34px;border-radius:50%;box-shadow:0 0 0 2px var(--pink)}
.brand b{font-size:clamp(15px,2.4vw,18px)}
.brand .dot{color:var(--lime)}
.spacer{flex:1}
.toggle{padding:8px 12px;border-radius:999px;border:1px solid var(--card-bd);
  background:var(--card);color:var(--fg);font-weight:800;font-size:13px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.nav-buy{padding:9px 16px;border-radius:999px;border:none;font-weight:900;font-size:13px;text-decoration:none;
  color:#0a0a12;background:linear-gradient(90deg,var(--lime),#7dff8a);box-shadow:0 6px 20px rgba(198,255,46,.28)}
.nav-buy[aria-disabled="true"]{filter:grayscale(.5);opacity:.6;pointer-events:none}

/* ---------- layout ---------- */
.container{width:min(1080px,94vw);margin:0 auto;padding:0 0 80px}
section{scroll-margin-top:84px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:900;
  letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--pink)}
.h2{font-size:clamp(22px,4.4vw,38px);margin:.4em 0 .2em;letter-spacing:.3px}
.lead{color:var(--muted);max-width:62ch}

/* ---------- HERO ---------- */
.hero{display:grid;place-items:center;text-align:center;padding:clamp(28px,7vw,72px) 0 clamp(16px,4vw,36px);
  opacity:0;transform:translateY(20px);animation:rise .9s ease forwards}
@keyframes rise{to{opacity:1;transform:none}}
.avatar-ring{width:clamp(150px,34vw,250px);height:clamp(150px,34vw,250px);
  border-radius:50%;padding:5px;margin-bottom:clamp(14px,2.6vw,22px);
  background:conic-gradient(from 0deg,var(--pink),var(--cyan),var(--lime),var(--pink));
  box-shadow:0 0 26px var(--pink),0 0 70px rgba(0,229,255,.28);
  animation:spin 7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.avatar-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;animation:spin 7s linear infinite reverse}
.hero h1{font-size:clamp(30px,7vw,62px);margin:0;letter-spacing:.4px;
  text-shadow:0 0 22px rgba(255,79,216,.5)}
.hero h1 span{background:linear-gradient(90deg,var(--pink),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .tagline{color:var(--muted);font-size:clamp(14px,2.8vw,20px);margin:8px 0 4px}
.live{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:12px;color:var(--lime);
  border:1px solid rgba(198,255,46,.4);border-radius:999px;padding:5px 12px;margin-top:12px}
.live .pip{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 10px var(--lime);animation:blink 1.4s ease-in-out infinite}
@keyframes blink{50%{opacity:.25}}

.cta-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:clamp(16px,3vw,26px)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 18px;border-radius:999px;border:1px solid var(--card-bd);
  background:var(--card);color:var(--fg);text-decoration:none;font-weight:800;font-size:14px;cursor:pointer;
  transition:transform .15s,box-shadow .2s,border-color .2s;-webkit-tap-highlight-color:transparent}
.btn:hover{transform:translateY(-2px);border-color:rgba(255,79,216,.4);box-shadow:0 0 18px rgba(255,79,216,.25)}
.btn.primary{border:none;color:#0a0a12;background:linear-gradient(90deg,var(--pink),var(--cyan));font-weight:900}
.btn.buy{border:none;color:#0a0a12;background:linear-gradient(90deg,var(--lime),#7dff8a);font-weight:900;box-shadow:0 6px 22px rgba(198,255,46,.28)}
.btn.buy[aria-disabled="true"]{filter:grayscale(.6);opacity:.55;pointer-events:none}

/* ---------- contract banner ---------- */
.ca{margin:22px auto 0;max-width:680px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;
  background:var(--card);border:1px solid var(--card-bd);border-radius:14px;padding:10px 14px;font-weight:800;font-size:13px}
.ca .label{color:var(--faint)}
.ca code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--cyan);word-break:break-all;font-size:12.5px}
.ca button{border:1px solid var(--card-bd);background:transparent;color:var(--fg);border-radius:8px;padding:5px 10px;font-weight:800;cursor:pointer;font-size:12px}
.ca .soon{color:var(--lime)}

/* ---------- STATS ---------- */
.grid{display:grid;gap:14px}
.stats-grid{grid-template-columns:repeat(4,1fr)}
.stat{background:var(--card);border:1px solid var(--card-bd);border-radius:var(--r);padding:16px 16px 14px;position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--pink),var(--cyan))}
.stat.money::before{background:linear-gradient(90deg,var(--lime),#7dff8a)}
.stat .k{font-size:12px;font-weight:800;color:var(--faint);letter-spacing:.06em;text-transform:uppercase}
.stat .v{font-size:clamp(20px,3.4vw,30px);font-weight:900;margin-top:6px;line-height:1.05}
.stat .v.money{color:var(--lime)}
.stat .sub{font-size:12px;color:var(--muted);margin-top:4px}
.pos{color:var(--up)} .neg{color:var(--down)}
.audit-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.tag{font-size:12px;font-weight:800;padding:6px 11px;border-radius:999px;border:1px solid var(--card-bd);background:var(--card);color:var(--muted)}
.tag.good{color:var(--up);border-color:rgba(55,226,154,.35)}
.tag.warn{color:var(--down);border-color:rgba(255,94,125,.35)}

/* ---------- REWARDS ---------- */
.rewards{margin-top:clamp(26px,5vw,46px);border-radius:24px;overflow:hidden;position:relative;
  border:1px solid rgba(198,255,46,.35);
  background:radial-gradient(120% 140% at 0% 0%,rgba(198,255,46,.16),transparent 55%),
             radial-gradient(120% 140% at 100% 100%,rgba(255,79,216,.16),transparent 55%),var(--bg-2)}
.rewards .inner{padding:clamp(22px,5vw,44px);display:grid;gap:18px;align-items:center;grid-template-columns:1.1fr .9fr}
.rewards .big{font-size:clamp(40px,11vw,104px);line-height:.92;font-weight:900;letter-spacing:-.02em;
  background:linear-gradient(90deg,var(--lime),#9dff6a,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 40px rgba(198,255,46,.25)}
.rewards h3{margin:.1em 0;font-size:clamp(18px,3.2vw,26px)}
.rewards p{color:var(--muted);margin:.3em 0}
.reward-points{display:grid;gap:10px;margin-top:6px}
.reward-points li{list-style:none;display:flex;gap:10px;align-items:flex-start;font-weight:700;font-size:14px}
.reward-points li::before{content:"✦";color:var(--lime);font-size:15px;line-height:1.3}
.coins{font-size:0}
.coins span{display:inline-block;animation:bob 3s ease-in-out infinite}
@keyframes bob{50%{transform:translateY(-8px)}}

/* ---------- HOLDERS ---------- */
.holders-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.holders-head .count{margin-left:auto;font-weight:900;color:var(--lime)}
.table{margin-top:14px;border:1px solid var(--card-bd);border-radius:var(--r);overflow:hidden;background:var(--card)}
.row{display:grid;grid-template-columns:54px 1fr 132px 96px;gap:10px;align-items:center;
  padding:12px 16px;border-top:1px solid var(--line);font-size:14px}
.row.head{border-top:none;font-size:11.5px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);background:rgba(255,255,255,.02)}
.row .rank{font-weight:900;color:var(--faint)}
.row .rank.top{color:var(--lime)}
.row .addr{font-family:ui-monospace,Menlo,monospace;font-size:13px;display:flex;align-items:center;gap:8px;min-width:0}
.row .addr a{color:var(--cyan);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row .amt{text-align:right;font-weight:800}
.row .pct{text-align:right;font-weight:900;color:var(--lime)}
.minitag{font-size:10px;font-weight:900;padding:2px 7px;border-radius:999px;border:1px solid var(--card-bd);color:var(--muted);white-space:nowrap}
.minitag.bc{color:var(--pink);border-color:rgba(255,79,216,.4)}
.minitag.elig{color:var(--lime);border-color:rgba(198,255,46,.4)}
.more{display:block;width:100%;padding:13px;border:none;border-top:1px solid var(--line);background:transparent;color:var(--cyan);font-weight:900;cursor:pointer}
.skeleton{height:48px;border-top:1px solid var(--line);background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);background-size:200% 100%;animation:sweep 1.3s linear infinite}
@keyframes sweep{to{background-position:-200% 0}}

/* ---------- pending / empty ---------- */
.pending{margin-top:14px;background:var(--card);border:1px dashed rgba(198,255,46,.4);border-radius:var(--r);
  padding:22px;text-align:center;color:var(--muted);font-weight:700}
.pending b{color:var(--lime)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--line);margin-top:60px;padding:26px clamp(14px,4vw,32px);color:var(--muted)}
.foot-wrap{width:min(1080px,94vw);margin:0 auto;display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.foot-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-links a{color:var(--muted);text-decoration:none;font-weight:800;font-size:14px}
.foot-links a:hover{color:var(--cyan)}
.disclaimer{flex-basis:100%;font-size:12px;color:var(--faint);line-height:1.5;margin-top:6px}

/* ---------- FLOATING CHAT ---------- */
.chat-fab{position:fixed;right:18px;bottom:18px;z-index:30;display:inline-flex;align-items:center;gap:8px;
  padding:13px 18px;border-radius:999px;border:none;cursor:pointer;font-weight:900;color:#0a0a12;
  background:linear-gradient(90deg,var(--pink),var(--cyan));box-shadow:var(--shadow);
  animation:fabin .6s .4s both}
@keyframes fabin{from{transform:translateY(30px);opacity:0}}
.chat-fab img{width:24px;height:24px;border-radius:50%}

.modal{position:fixed;inset:0;z-index:40;display:none;align-items:flex-end;justify-content:center;
  background:rgba(0,0,0,.55);backdrop-filter:blur(5px)}
.modal.open{display:flex}
@media(min-width:680px){.modal{align-items:center}}
.chat{width:min(96vw,560px);height:min(86dvh,680px);display:flex;flex-direction:column;overflow:hidden;
  background:linear-gradient(180deg,rgba(255,79,216,.07),rgba(0,229,255,.03)),var(--bg-2);
  border:1px solid var(--card-bd);border-radius:20px 20px 0 0;box-shadow:var(--shadow)}
@media(min-width:680px){.chat{border-radius:20px}}
.chat-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}
.chat-header img{width:38px;height:38px;border-radius:50%}
.chat-header .who b{font-size:15px}
.chat-header .who span{font-size:12px;color:var(--muted)}
.chat-header .close{margin-left:auto;border:1px solid var(--card-bd);background:transparent;color:var(--fg);
  width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:16px}
.messages{flex:1;overflow:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.msg{display:flex;gap:10px;align-items:flex-start;max-width:88%}
.msg.user{align-self:flex-end;flex-direction:row-reverse}
.msg img{width:30px;height:30px;border-radius:50%;flex:0 0 30px}
.bubble{padding:11px 14px;border-radius:14px;background:var(--card);border:1px solid var(--card-bd);font-weight:600;line-height:1.4;font-size:14.5px;white-space:pre-wrap}
.msg.user .bubble{background:linear-gradient(90deg,rgba(255,79,216,.18),rgba(0,229,255,.12))}
.typing .bubble{opacity:.7;font-style:italic}
.suggest{display:flex;gap:8px;flex-wrap:wrap;padding:0 16px 6px}
.suggest button{font-size:12px;font-weight:800;border:1px solid var(--card-bd);background:var(--card);color:var(--muted);
  border-radius:999px;padding:7px 12px;cursor:pointer}
.suggest button:hover{color:var(--cyan);border-color:rgba(0,229,255,.4)}
.chat-input{display:flex;gap:10px;padding:12px;border-top:1px solid var(--line)}
.chat-input input{flex:1;padding:12px 15px;border-radius:999px;border:1px solid var(--card-bd);background:var(--card);color:var(--fg);font-weight:700;font-size:15px}
.chat-input button{padding:0 18px;border-radius:999px;border:none;background:linear-gradient(90deg,var(--pink),var(--cyan));color:#0a0a12;font-weight:900;cursor:pointer}

/* ---------- legal pages ---------- */
.legal{width:min(760px,92vw);margin:0 auto;padding:40px 0 80px}
.legal h1{font-size:clamp(26px,5vw,40px);margin:.2em 0}
.legal h2{margin-top:1.6em;font-size:clamp(17px,3vw,22px)}
.legal p,.legal li{color:var(--muted);line-height:1.7;font-size:15px}
.legal a{color:var(--cyan)}
.legal .updated{color:var(--faint);font-size:13px}

/* ---------- responsive ---------- */
@media(max-width:860px){.stats-grid{grid-template-columns:repeat(2,1fr)}.rewards .inner{grid-template-columns:1fr;text-align:center}.reward-points li{justify-content:center}}
@media(max-width:560px){
  .row{grid-template-columns:40px 1fr 78px;gap:8px;padding:11px 12px}
  .row .amt{display:none}
  .nav-buy{display:none}
}
@media(prefers-reduced-motion:reduce){
  .scene,.scene::after,.avatar-ring,.avatar-ring img,.live .pip,.coins span,.skeleton{animation:none}
  .hero{opacity:1;transform:none;animation:none}
}
