/* ===========================================================
   BUYGF $BUYGF — landing styles
   satire of dating sites + "hot singles in your area" ads,
   wrapped around a live browser RuneScape. all roads → the game.
   =========================================================== */

@font-face{
  font-family:'RuneScapeUF';
  src:url('../fonts/runescape.woff2') format('woff2'),
      url('../fonts/runescape.ttf') format('truetype');
  font-display:swap;
}
:root{
  --rs:'RuneScapeUF','Jersey 15','Pixelify Sans',system-ui,monospace;
  --pink:#ff1e8c;       /* hot pink primary */
  --pink-2:#ff5cae;
  --magenta:#c4129b;
  --purple:#1a0a1f;     /* deep bg */
  --purple-2:#270d2e;
  --ink:#1a0512;
  --cyan:#22e6c8;
  --gold:#ffd84d;
  --text:#ffe9f6;
  --muted:#d59bc4;
  --line:rgba(255,92,174,.22);
  --glow:0 0 18px rgba(255,30,140,.55);
}

*{box-sizing:border-box}
html,body{margin:0;height:100%;overflow:hidden;background:var(--purple);
  font-family:'Fredoka',system-ui,Arial,sans-serif;color:var(--text);
  -webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
b{font-weight:700}

body{
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(255,30,140,.18), transparent 60%),
    radial-gradient(900px 500px at 0% 110%, rgba(34,230,200,.10), transparent 55%),
    linear-gradient(160deg,#16060f 0%,#260b2c 60%,#16060f 100%);
}

.app{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden}

/* ---------------- TOP BAR ---------------- */
.bar{flex:0 0 56px;display:flex;align-items:center;gap:12px;padding:0 14px;
  background:linear-gradient(180deg,rgba(40,13,46,.96),rgba(26,10,31,.96));
  border-bottom:1px solid var(--line);box-shadow:0 6px 24px rgba(0,0,0,.45);z-index:30}

.brand{display:flex;align-items:center;gap:8px;white-space:nowrap;flex:0 0 auto}
.brand-face{width:34px;height:34px;border-radius:9px;object-fit:cover;border:2px solid var(--pink-2);
  box-shadow:var(--glow);background:#2a0c30;animation:wobble 4s ease-in-out infinite}
@keyframes wobble{0%,100%{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}
.brand-name{font-size:27px;font-weight:700;letter-spacing:.5px;color:#fff;text-shadow:var(--glow)}
.brand-name .gf{color:var(--pink);text-shadow:0 0 12px var(--pink)}
.brand small{color:var(--cyan);font-weight:700;font-size:13px;letter-spacing:1px;align-self:flex-start;margin-top:7px}

/* RuneScape-style font on the chrome/UI; body copy stays in Fredoka for legibility */
.brand-name,.brand small,.btn,.ticker-track .t,.online,.rail-label,.premium span,
.pc-info h1,.tags li,.swipe,.gf-card .nm,.tagline b,.open-popup,
.popup-flash,.popup-chat,.p-name,.pc-online,.pc-verified,.online b{ font-family:var(--rs); letter-spacing:.4px; }
.btn .ic{width:17px;height:17px;object-fit:contain;display:block;filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}

/* rolling-letters ticker = the online counter bar */
.ticker{flex:1 1 auto;min-width:0;height:34px;overflow:hidden;position:relative;
  background:linear-gradient(90deg,#2a0c2f,#3a0f33);border:1px solid var(--line);
  border-radius:8px;box-shadow:inset 0 0 18px rgba(0,0,0,.5)}
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:42px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,#2a0c2f,transparent)}
.ticker::after{right:0;background:linear-gradient(270deg,#3a0f33,transparent)}
.ticker-track{position:absolute;top:0;left:0;height:100%;display:flex;align-items:center;
  white-space:nowrap;will-change:transform;animation:roll 38s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes roll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-track .t{display:inline-flex;align-items:center;gap:7px;padding:0 22px;font-size:14px;font-weight:600;
  color:#ffd0ea;border-right:1px dashed rgba(255,92,174,.25)}
.ticker-track .t .hot{color:var(--gold)}
.ticker-track .t .num{color:var(--cyan);font-weight:700}

/* actions */
.actions{display:flex;align-items:center;gap:8px;flex:0 0 auto;white-space:nowrap}
.online{display:inline-flex;align-items:center;font-size:13px;color:#9bffcf}
.online b{color:#fff;margin:0 3px}
.dot{width:8px;height:8px;border-radius:50%;background:#3dff9a;display:inline-block;margin-right:6px;
  box-shadow:0 0 8px #3dff9a;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.btn{display:inline-flex;align-items:center;gap:5px;cursor:pointer;font-family:inherit;font-weight:700;
  font-size:13px;padding:7px 12px;border-radius:9px;border:1px solid var(--line);
  background:rgba(255,255,255,.05);color:var(--text);transition:.15s;white-space:nowrap}
.btn:hover{background:rgba(255,30,140,.14);border-color:var(--pink);transform:translateY(-1px)}
.btn.buy{background:linear-gradient(180deg,var(--pink),var(--magenta));border-color:var(--pink-2);
  color:#fff;box-shadow:var(--glow)}
.btn.buy:hover{filter:brightness(1.1)}
.btn.connected{color:#9bffcf;border-color:#3dff9a}
.btn.mini{padding:5px 8px;font-size:11px}
.ca{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted)}
.ca code{background:#180616;padding:5px 8px;border-radius:6px;max-width:340px;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;color:#ffb8e0;border:1px solid var(--line)}

/* ---------------- BODY ---------------- */
.body{flex:1 1 auto;display:flex;min-height:0}

/* left rail */
.rail{flex:0 0 116px;position:relative;background:linear-gradient(180deg,#1e0a23,#160611);border-right:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;gap:12px;padding:14px 8px;overflow:hidden}
.premium{width:100%;display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;
  padding:10px 4px;border-radius:11px;font-weight:700;font-size:11px;line-height:1.1;color:#3a1500;
  background:linear-gradient(180deg,var(--gold),#ffb01f);box-shadow:0 4px 14px rgba(255,184,31,.4);
  border:1px solid #fff3c4}
.premium span{font-size:11px}
.premium img{width:30px;height:30px;object-fit:contain;display:block;margin:0 auto;image-rendering:auto}
.premium:hover{filter:brightness(1.07);transform:translateY(-1px)}
.socials{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}
.socials a{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;font-size:15px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);transition:.15s}
.socials a:hover{background:rgba(255,30,140,.16);border-color:var(--pink);transform:translateY(-1px)}
.rail-label{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.3px;margin-top:2px}
.gf-stack{display:flex;flex-direction:column;gap:8px;width:100%;overflow-y:auto;overflow-x:hidden;
  flex:1 1 auto;padding-bottom:6px;scrollbar-width:thin}
.gf-stack::-webkit-scrollbar{width:5px}.gf-stack::-webkit-scrollbar-thumb{background:var(--magenta);border-radius:4px}
.gf-card{position:relative;background:linear-gradient(180deg,#2a0c30,#1d0820);border:1px solid var(--line);
  border-radius:11px;padding:8px 7px;text-align:center;cursor:pointer;transition:.15s;overflow:hidden}
.gf-card:hover{border-color:var(--pink);transform:translateY(-2px);box-shadow:var(--glow)}
.gf-card .ava{height:48px;display:flex;align-items:flex-end;justify-content:center}
.gf-card .ava img{max-height:48px;max-width:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.55))}
.gf-card .nm{font-size:12px;font-weight:700;color:#fff;margin-top:3px}
.gf-card .ds{font-size:9.5px;color:var(--muted);line-height:1.2;margin-top:2px}
.gf-card .livedot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;
  background:#3dff9a;box-shadow:0 0 6px #3dff9a;animation:pulse 1.5s infinite}

/* center / game */
.main{flex:1 1 auto;display:flex;flex-direction:column;min-width:0;min-height:0}
.stage{flex:1 1 auto;position:relative;min-height:0;background:#000;
  background-image:radial-gradient(circle at 50% 50%, #2a0c30, #000)}
.stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}

/* flirty profile gate over the game */
.gate{position:absolute;inset:0;z-index:10;display:grid;place-items:center;padding:18px;
  background:radial-gradient( circle at 50% 30%, rgba(255,30,140,.18), rgba(8,2,8,.92) 70%);
  backdrop-filter:blur(3px);transition:opacity .35s}
.gate.hide{opacity:0;pointer-events:none}
.profile-card{display:flex;gap:0;max-width:760px;width:100%;border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg,#2a0c30,#1a0712);border:1px solid var(--pink-2);
  box-shadow:0 24px 70px rgba(0,0,0,.6),0 0 40px rgba(255,30,140,.3)}
.pc-photo{position:relative;flex:0 0 230px;background:
  linear-gradient(180deg,rgba(255,30,140,.25),rgba(34,230,200,.12)),
  repeating-linear-gradient(45deg,#2c0c33,#2c0c33 12px,#300e38 12px,#300e38 24px);
  display:grid;place-items:center}
.pc-sprite{max-height:210px;max-width:92%;object-fit:contain;filter:drop-shadow(0 8px 22px rgba(0,0,0,.6))}
.pc-online{position:absolute;top:12px;left:12px;font-size:11px;font-weight:700;color:#072;background:#9bffcf;
  padding:3px 8px;border-radius:20px;display:inline-flex;align-items:center}
.pc-online .dot{width:7px;height:7px;background:#0a7;box-shadow:none;animation:none}
.pc-verified{position:absolute;bottom:12px;right:12px;font-size:10px;font-weight:700;color:#fff;
  background:rgba(34,150,255,.85);padding:3px 8px;border-radius:20px}
.pc-info{flex:1 1 auto;padding:18px 20px;min-width:0}
.pc-info h1{margin:0;font-size:26px;color:#fff;display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.pc-info h1 .pin{font-size:12px;color:var(--cyan);font-weight:600}
.bio{margin:10px 0;font-size:14.5px;line-height:1.5;color:#ffd8ee}
.tags{list-style:none;display:flex;flex-wrap:wrap;gap:6px;padding:0;margin:0 0 14px}
.tags li{font-size:11px;font-weight:600;color:#ffd0ea;background:rgba(255,30,140,.14);
  border:1px solid var(--line);padding:4px 9px;border-radius:20px}
.pc-actions{display:flex;gap:10px;flex-wrap:wrap}
.swipe{cursor:pointer;font-family:inherit;font-weight:700;font-size:15px;padding:12px 16px;border-radius:13px;border:0;transition:.15s}
.swipe.nope{background:rgba(255,255,255,.06);color:var(--muted);border:1px solid var(--line)}
.swipe.nope:hover{color:#fff}
.swipe.yes{flex:1 1 auto;background:linear-gradient(180deg,var(--pink),var(--magenta));color:#fff;
  box-shadow:var(--glow);min-width:240px}
.swipe.yes:hover{filter:brightness(1.1);transform:translateY(-1px)}

/* bottom strip */
.strip{flex:0 0 60px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:0 16px;background:linear-gradient(180deg,#1c0922,#150510);border-top:1px solid var(--line)}
.tagline{min-width:0;overflow:hidden}
.tagline b{color:var(--pink);font-size:15px;display:block;text-shadow:0 0 10px rgba(255,30,140,.4)}
.tagline span{font-size:11.5px;color:var(--muted);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.open-popup{flex:0 0 auto;cursor:pointer;font-family:inherit;font-weight:700;font-size:13px;color:#fff;
  padding:9px 14px;border-radius:11px;border:1px solid var(--pink-2);
  background:linear-gradient(180deg,var(--pink),var(--magenta));box-shadow:var(--glow);animation:nudge 2.4s ease-in-out infinite}
.open-popup b{background:#fff;color:var(--pink);border-radius:50%;padding:0 6px;margin:0 2px}
@keyframes nudge{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}

/* ---------------- HOT-SINGLES POPUP (ad satire) ---------------- */
.popup-wrap{position:fixed;inset:0;z-index:90;display:grid;place-items:center;
  background:rgba(6,1,8,.6);backdrop-filter:blur(2px)}
.popup-wrap[hidden]{display:none}
.popup{position:relative;width:min(420px,92vw);border-radius:14px;overflow:hidden;
  background:#15030f;font-family:'Comic Neue','Comic Sans MS',cursive;
  border:3px solid var(--pink);box-shadow:0 0 0 3px var(--gold),0 0 40px rgba(255,30,140,.7);
  animation:adpop .3s cubic-bezier(.2,1.4,.5,1)}
@keyframes adpop{from{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}
.popup-x{position:absolute;top:6px;right:6px;z-index:3;width:26px;height:26px;border-radius:50%;
  border:0;background:#000;color:#fff;font-weight:700;cursor:pointer;opacity:.7}
.popup-x:hover{opacity:1}
.popup-flash{text-align:center;font-weight:700;font-size:15px;color:#fff;padding:9px;letter-spacing:.5px;
  background:linear-gradient(90deg,var(--pink),var(--gold),var(--cyan),var(--pink));background-size:300% 100%;
  animation:flash 1.1s linear infinite}
@keyframes flash{from{background-position:0 0}to{background-position:300% 0}}
.popup-body{display:flex;gap:12px;padding:14px;align-items:center}
.popup-av{width:84px;height:auto;max-height:118px;object-fit:contain;flex:0 0 auto;
  animation:wobble 1.8s ease-in-out infinite;filter:drop-shadow(0 4px 10px rgba(0,0,0,.5))}
.popup-txt{min-width:0}
.p-name{margin:0;font-weight:700;font-size:16px;color:#fff}
.p-name span{color:var(--cyan);font-size:12px;font-weight:400}
.p-msg{margin:6px 0;font-size:13.5px;color:#ffd8ee;line-height:1.4}
.p-meta{margin:0;font-size:11px;color:#9bffcf}
.popup-cta{padding:0 14px 12px}
.popup-vid{width:100%;max-height:230px;object-fit:contain;display:block;background:#120310;border-bottom:2px solid var(--pink)}
.rail-fw{position:absolute;left:0;right:0;top:150px;bottom:0;z-index:7;pointer-events:none;
  background:url(../vid/firework.gif) center/cover no-repeat;mix-blend-mode:screen;opacity:.9}
.popup-chat{width:100%;cursor:pointer;font-family:inherit;font-weight:700;font-size:17px;color:#fff;
  padding:13px;border-radius:11px;border:0;background:linear-gradient(180deg,#ff3da0,#c4129b);
  box-shadow:0 4px 16px rgba(255,30,140,.6);animation:nudge 1.3s ease-in-out infinite}

/* ---------------- MOBILE ---------------- */
@media (max-width:880px){
  .ca{order:4;flex-basis:100%;justify-content:center;margin-top:2px}
  .ca code{max-width:78vw}
  .brand small{display:none}
  .online{display:none}
  .ticker{order:3;flex-basis:100%;height:30px}
  .bar{flex:0 0 auto;flex-wrap:wrap;gap:8px;padding:8px 10px}
  .actions{order:2}
  .profile-card{flex-direction:column;max-width:380px}
  .pc-photo{flex-basis:150px}
  .pixel-girl{font-size:74px}
  .swipe.yes{min-width:0}
}
@media (max-width:640px){
  .rail{flex-basis:84px}
  .rail-label{font-size:9px}
  .gf-card .ds{display:none}
  .tagline span{display:none}
  .btn{padding:7px 9px}
  .pc-info h1{font-size:21px}
}
