/* QUACKADE member area — an integrated, responsive section of the website.
   Shares the marketing site's editorial black/lime/Anton design. Desktop &
   iPad get a wide dashboard; phones reflow to a single column. */
:root{
  --black:#000; --ink:#08080a; --card:#0e0e11; --card2:#15151a;
  --lime:#c6f135; --lime-bright:#d6ff4f;
  --white:#fff; --grey:#9a9a9a; --grey2:#6b6b6b;
  --line:rgba(255,255,255,.13); --line2:rgba(255,255,255,.07);
  --danger:#ff5a5a;
  --disp:'Anton',sans-serif; --grotesk:'Archivo',sans-serif; --mono:'Space Mono',monospace;
  --ease:cubic-bezier(.4,0,.2,1);
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{background:var(--black);color:var(--white);font-family:var(--grotesk);-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100dvh}
img,svg{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em}
.lime{color:var(--lime)}
.icon{width:22px;height:22px;stroke-width:1.9;fill:none;stroke:currentColor;flex:none}
:focus-visible{outline:2px solid var(--lime);outline-offset:3px}
.hidden{display:none!important}

/* ============ site header (shared look with marketing site) ============ */
.site-header{position:sticky;top:0;z-index:50;background:rgba(0,0,0,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line2)}
.site-header .bar{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:16px 24px;gap:20px}
.brand{display:flex;align-items:center;gap:11px}
.brand img{width:40px;height:40px;border-radius:50%}
.brand .name{font-family:var(--disp);font-size:24px;letter-spacing:.05em;line-height:1}
.hnav{display:flex;align-items:center;gap:6px}
.hnav a{font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:var(--grey);padding:9px 14px;border-radius:9px;transition:.15s var(--ease)}
.hnav a:hover{color:#fff}
.hnav a.on{color:#000;background:var(--lime)}
.hnav-right{display:flex;align-items:center;gap:12px}
.signout{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.1em;color:var(--grey);border:1px solid var(--line);padding:9px 14px;border-radius:9px;transition:.15s var(--ease)}
.signout:hover{border-color:var(--lime);color:var(--lime)}

/* ============ page wrapper ============ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:34px 24px 120px}
.screen{display:none;animation:fade .25s var(--ease)}
.screen.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.eyebrow{font-family:var(--mono);text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--grey)}
.page-title{font-family:var(--disp);text-transform:uppercase;font-size:clamp(34px,5vw,58px);line-height:.95;letter-spacing:.01em;margin:8px 0 26px}
.sec-title{font-family:var(--disp);text-transform:uppercase;font-size:clamp(22px,2.6vw,30px);letter-spacing:.02em;margin:44px 0 18px;display:flex;align-items:center;gap:11px}
.sec-title .icon{width:26px;height:26px;color:var(--lime)}

/* ============ HOME: balance hero + sections ============ */
.hero{display:grid;grid-template-columns:1.3fr .9fr;gap:22px;align-items:stretch}
.balance{position:relative;overflow:hidden;border-radius:26px;padding:38px 40px;background:linear-gradient(120deg,#e39a17 0%,#c6f135 115%);color:#0a0a0a;min-height:230px;display:flex;flex-direction:column;justify-content:center}
.balance::after{content:"";position:absolute;inset:0;background:radial-gradient(130% 130% at 100% 0%,rgba(255,255,255,.4),transparent 55%);pointer-events:none}
.balance .lab{font-family:var(--mono);text-transform:uppercase;letter-spacing:.18em;font-size:12px;opacity:.72}
.balance .tok{font-family:var(--disp);font-size:clamp(60px,9vw,104px);line-height:.86;margin:8px 0 4px}
.balance .tok small{font-size:.28em;font-family:var(--mono);letter-spacing:.1em;opacity:.62;margin-left:12px}
.balance .pts{font-family:var(--mono);font-weight:700;font-size:17px;margin-top:10px}
.balance .duck{position:absolute;right:26px;bottom:22px;width:120px;height:120px;opacity:.96}
.hero-side{display:flex;flex-direction:column;gap:14px}
.reload-cta{flex:1;border-radius:26px;background:var(--card);border:1px solid var(--line2);padding:30px;display:flex;flex-direction:column;justify-content:center;gap:16px;transition:.15s var(--ease)}
.reload-cta:hover{border-color:var(--lime)}
.reload-cta h3{font-family:var(--disp);text-transform:uppercase;font-size:26px;line-height:.98}
.reload-cta p{color:var(--grey);font-size:14px;line-height:1.5}

/* quick tiles */
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:22px}
.quick button{display:flex;align-items:center;gap:12px;padding:18px 20px;border:1px solid var(--line2);border-radius:16px;background:var(--card);transition:.15s var(--ease)}
.quick button:hover{border-color:var(--lime);transform:translateY(-2px)}
.quick .q-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:rgba(198,241,53,.12);color:var(--lime)}
.quick .q-t{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em}

/* ============ packages ============ */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.pkg{position:relative;text-align:left;background:var(--card);border:1px solid var(--line2);border-radius:18px;padding:24px;transition:.15s var(--ease);display:flex;flex-direction:column;gap:6px}
.pkg:hover{border-color:var(--lime);transform:translateY(-3px)}
.pkg .badge{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;background:var(--lime);color:#000;padding:4px 9px;border-radius:20px}
.pkg .p-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(198,241,53,.12);color:var(--lime);margin-bottom:12px}
.pkg .p-tok{font-family:var(--disp);font-size:40px;line-height:.9}
.pkg .p-tok span{font-size:.4em;font-family:var(--mono);color:var(--grey);letter-spacing:.06em;margin-left:6px}
.pkg .p-sub{font-family:var(--mono);font-size:11px;color:var(--grey);text-transform:uppercase;letter-spacing:.06em}
.pkg .p-buy{margin-top:16px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line2);padding-top:16px}
.pkg .p-price{font-family:var(--disp);font-size:28px}
.pkg .p-go{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--lime);display:flex;align-items:center;gap:6px}
/* visual (coin) package cards */
.pkg-visual{align-items:center;text-align:center;padding:22px 20px 22px}
.pkg-visual .coin-art{font-size:56px;line-height:1;margin:4px auto 10px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.4))}
.pkg-visual .p-tok{font-size:34px}
.pkg-visual .p-buy{width:100%}

/* ============ gifts ============ */
.gift-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.gift{background:var(--card);border:1px solid var(--line2);border-radius:20px;overflow:hidden;display:flex;flex-direction:column;transition:.15s var(--ease)}
.gift:hover{border-color:var(--lime);transform:translateY(-3px)}
.gift .g-thumb{aspect-ratio:16/11;background:linear-gradient(135deg,#1c1c22,#0d0d10);display:grid;place-items:center;color:var(--lime);position:relative}
.gift .g-thumb .icon{width:44px;height:44px}
.gift .g-badge{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;background:var(--lime);color:#000;padding:4px 9px;border-radius:20px}
.gift .g-body{padding:16px 16px 18px;display:flex;flex-direction:column;flex:1}
.gift .g-name{font-weight:700;font-size:15px;line-height:1.3;flex:1}
.gift .g-cost{font-family:var(--disp);font-size:24px;color:var(--lime);margin:12px 0}
.gift .g-cost small{font-family:var(--mono);font-size:11px;color:var(--grey);letter-spacing:.08em;margin-left:5px}

/* ============ buttons / inputs ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:15px 22px;border-radius:13px;font-family:var(--mono);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:13px;transition:.15s var(--ease)}
.btn-block{width:100%}
.btn-lime{background:var(--lime);color:#000}
.btn-lime:hover{background:var(--lime-bright);transform:translateY(-2px);box-shadow:0 10px 30px rgba(198,241,53,.26)}
.btn-lime:disabled{opacity:.5;transform:none;box-shadow:none;cursor:not-allowed}
.btn-ghost{border:1px solid var(--line);color:#fff}
.btn-ghost:hover{border-color:var(--lime);color:var(--lime)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--grey);margin-bottom:9px}
.input{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:12px;padding:15px 16px;background:var(--ink);transition:.15s var(--ease)}
.input:focus-within{border-color:var(--lime)}
.input .cc{font-family:var(--mono);color:var(--grey);font-size:15px;padding-right:11px;border-right:1px solid var(--line2)}
.input input{flex:1;background:none;border:none;color:#fff;font-size:16px;outline:none}
.input input::placeholder{color:var(--grey2)}
.otp{letter-spacing:.55em!important;font-family:var(--mono)!important;font-size:22px!important;text-align:center}

/* ============ login ============ */
.login-wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;min-height:calc(100dvh - 74px);display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:60px}
.login-hero{padding:40px 0}
.login-hero .eyebrow{margin-bottom:14px}
.login-hero h1{font-family:var(--disp);text-transform:uppercase;font-size:clamp(44px,6vw,84px);line-height:.92}
.login-hero p{color:var(--grey);font-size:16px;line-height:1.6;margin-top:18px;max-width:44ch}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:36px}
.login-card h2{font-family:var(--disp);text-transform:uppercase;font-size:26px;margin-bottom:6px}
.login-card .muted{color:var(--grey);font-size:14px;margin-bottom:26px}
.login-card .foot{margin-top:20px;font-size:12px;color:var(--grey2);line-height:1.6}
.login-card .foot a{color:var(--lime)}

/* ============ history ============ */
.hist{display:flex;align-items:center;gap:15px;padding:17px 4px;border-bottom:1px solid var(--line2)}
.hist .h-ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--card2);color:var(--grey)}
.hist .h-main{flex:1}
.hist .h-t{font-weight:600;font-size:15px}
.hist .h-d{font-family:var(--mono);font-size:11px;color:var(--grey);margin-top:3px}
.hist .h-amt{font-family:var(--disp);font-size:20px}
.hist .h-amt.plus{color:var(--lime)}
.hist .h-amt.minus{color:var(--grey)}

/* ============ profile ============ */
.prof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;max-width:720px}
.prof-card{background:var(--card);border:1px solid var(--line2);border-radius:16px;padding:22px}
.prof-card .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--grey)}
.prof-card .v{font-size:20px;font-weight:700;margin-top:6px}
.prof-card .v.big{font-family:var(--disp);font-size:34px;color:var(--lime)}

/* ============ misc: empty / spinner / toast / sheet ============ */
.empty{text-align:center;color:var(--grey);padding:60px 20px;grid-column:1/-1}
.empty .icon{width:46px;height:46px;margin:0 auto 16px;color:var(--grey2)}
.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.18);border-top-color:var(--lime);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.toast{position:fixed;left:50%;bottom:40px;transform:translateX(-50%) translateY(20px);z-index:80;background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:14px 20px;font-size:14px;font-weight:600;opacity:0;transition:.25s var(--ease);pointer-events:none;max-width:90%;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{border-color:var(--danger);color:#ffb3b3}
.toast.ok{border-color:var(--lime);color:var(--lime)}
.sheet-bg{position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.66);backdrop-filter:blur(4px);display:none}
.sheet-bg.show{display:block}
.sheet{position:fixed;z-index:91;background:var(--ink);border:1px solid var(--line);transition:.28s var(--ease)}
/* desktop: centered modal; mobile: bottom sheet */
.sheet{left:50%;top:50%;transform:translate(-50%,-46%) scale(.98);opacity:0;width:min(460px,92vw);border-radius:22px;padding:30px}
.sheet.show{transform:translate(-50%,-50%) scale(1);opacity:1}
.sheet h3{font-family:var(--disp);text-transform:uppercase;font-size:24px;margin-bottom:6px}
.sheet .muted{color:var(--grey);font-size:13px;margin-bottom:20px}
.card{background:var(--card);border:1px solid var(--line2);border-radius:14px;padding:16px 18px}

/* ============ bottom nav (mobile only) ============ */
.botnav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:60;background:rgba(6,6,7,.94);backdrop-filter:blur(14px);border-top:1px solid var(--line2)}
.botnav .inner{display:grid;grid-template-columns:repeat(4,1fr);padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
.botnav button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 0;color:var(--grey2)}
.botnav button span{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.05em}
.botnav button.on{color:var(--lime)}

/* ============ responsive ============ */
@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero-side{flex-direction:row}
  .login-wrap{grid-template-columns:1fr;gap:24px;padding-top:24px;min-height:auto}
  .login-hero{display:none}
}
@media (max-width:680px){
  .site-header .bar{padding:11px 16px}
  .brand img{width:34px;height:34px}
  .brand .name{font-size:19px}
  .signout{padding:8px 12px;font-size:10px}
  .hnav{display:none}                 /* tabs move to the bottom nav on phones */
  .wrap{padding:18px 16px 92px}
  .eyebrow{font-size:10px}
  .page-title{font-size:clamp(26px,8vw,34px);margin:6px 0 16px}
  .sec-title{font-size:19px;margin:28px 0 12px}
  .sec-title .icon{width:22px;height:22px}
  /* balance card — smaller number + tighter */
  .balance{padding:22px 22px;min-height:0;border-radius:20px}
  .balance .tok{font-size:clamp(40px,12vw,56px)}
  .balance .lab{font-size:11px}
  .balance .pts{font-size:15px}
  .balance .duck{width:74px;height:74px;right:16px;bottom:14px}
  /* reload cards — compact */
  .hero{gap:12px}
  .hero-side{flex-direction:column;gap:12px}
  .reload-cta{padding:20px;border-radius:18px}
  .reload-cta h3{font-size:20px}
  .reload-cta p{font-size:13px}
  /* quick tiles — 2 cols, tighter */
  .quick{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px}
  .quick button{padding:14px 14px}
  .quick .q-ic{width:38px;height:38px}
  /* packages / gifts — tighter */
  .pkg-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
  .pkg{padding:18px}
  .pkg .p-tok{font-size:32px}
  .pkg-visual .coin-art{font-size:46px}
  .gift-grid{gap:12px}
  .prof-card{padding:18px}
  .prof-card .v.big{font-size:28px}
  .botnav{display:block}
  .toast{bottom:84px}
  .sheet{left:0;right:0;bottom:0;top:auto;transform:translateY(100%);width:100%;max-width:520px;margin:0 auto;border-radius:22px 22px 0 0;padding:26px 22px calc(28px + env(safe-area-inset-bottom))}
  .sheet.show{transform:translateY(0)}
}
