/* ═══════════════════════════════════════════════════
   VAULT — assets/style.css
   ═══════════════════════════════════════════════════ */
:root {
  --bg:      #07070f;
  --bg2:     #0d0d1c;
  --bg3:     #12122a;
  --bg4:     #1a1a35;
  --gold:    #c9a84c;
  --gold2:   #f0d080;
  --gold3:   #7a5c1e;
  --text:    #e0e4f8;
  --text2:   #6b7299;
  --common:  #6b7280;
  --uncommon:#22c55e;
  --rare:    #3b82f6;
  --epic:    #a855f7;
  --legendary:#f59e0b;
  --red:     #ef4444;
  --green:   #22c55e;
  --border:  rgba(201,168,76,.16);
  --radius:  10px;
}

/* ── Reset & Base ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--text); font-family:'Rajdhani',sans-serif; min-height:100vh; overflow-x:hidden; }

/* Starfield */
.stars {
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(1px 1px at 5%  10%, rgba(255,255,255,.28) 0%, transparent 100%),
    radial-gradient(1px 1px at 20% 70%, rgba(255,255,255,.18) 0%, transparent 100%),
    radial-gradient(1px 1px at 35% 30%, rgba(255,255,255,.22) 0%, transparent 100%),
    radial-gradient(1px 1px at 50% 85%, rgba(255,255,255,.15) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 20%, rgba(255,255,255,.20) 0%, transparent 100%),
    radial-gradient(1px 1px at 80% 55%, rgba(255,255,255,.18) 0%, transparent 100%),
    radial-gradient(1px 1px at 92% 8%,  rgba(255,255,255,.25) 0%, transparent 100%),
    radial-gradient(1px 1px at 12% 92%, rgba(255,255,255,.15) 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 78%, rgba(255,255,255,.20) 0%, transparent 100%),
    radial-gradient(1px 1px at 48% 48%, rgba(255,255,255,.12) 0%, transparent 100%);
}

/* ── Navbar ── */
.navbar {
  position:sticky; top:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 28px; height:58px;
  background:rgba(7,7,15,.92); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-logo {
  font-family:'Cinzel Decorative',serif; font-size:1.3rem; font-weight:900;
  background:linear-gradient(135deg,#7a5c1e,#c9a84c,#f0d080,#c9a84c,#7a5c1e);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  text-decoration:none; letter-spacing:.1em;
}
.nav-links { display:flex; align-items:center; gap:4px; }
.nav-link {
  padding:6px 12px; color:var(--text2); text-decoration:none; font-size:.88rem;
  letter-spacing:.05em; border-radius:6px; transition:all .2s; position:relative;
}
.nav-link:hover, .nav-link.active { color:var(--gold); background:rgba(201,168,76,.08); }
.nav-logout { color:var(--text2); }
.nav-logout:hover { color:var(--red); background:rgba(239,68,68,.08); }
.nav-register { border:1px solid rgba(201,168,76,.3); color:var(--gold); }
.nav-register:hover { background:rgba(201,168,76,.12); }
.nav-coins { font-family:'Cinzel',serif; font-size:.9rem; color:var(--gold2); padding:0 8px; font-weight:600; }
.badge {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:16px; height:16px; background:var(--red); color:#fff;
  font-size:.6rem; font-weight:700; border-radius:8px; padding:0 4px;
  position:absolute; top:2px; right:2px;
}

/* ── Page layout ── */
.page-content { position:relative; z-index:1; }

/* ── Containers ── */
.container { max-width:1200px; margin:0 auto; padding:28px 20px; }
.container-sm { max-width:520px; margin:0 auto; padding:40px 20px; }
.container-md { max-width:780px; margin:0 auto; padding:28px 20px; }

/* ── Cards / Panels ── */
.card {
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius);
  padding:24px;
}
.card-title {
  font-family:'Cinzel',serif; font-size:.72rem; letter-spacing:.3em;
  color:var(--gold); text-transform:uppercase; margin-bottom:16px;
  padding-bottom:10px; border-bottom:1px solid var(--border);
}

/* ── Form elements ── */
.field { margin-bottom:18px; }
.field label { display:block; font-size:.72rem; letter-spacing:.12em; color:var(--text2); margin-bottom:6px; text-transform:uppercase; }
.field input, .field select, .field textarea {
  width:100%; padding:11px 14px; background:rgba(255,255,255,.04);
  border:1px solid rgba(201,168,76,.2); border-radius:8px;
  color:var(--text); font-family:'Rajdhani',sans-serif; font-size:1rem; outline:none;
  transition:border-color .2s;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color:var(--gold); }
.field textarea { resize:vertical; min-height:80px; }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:11px 26px; border:none; border-radius:8px;
  font-family:'Cinzel',serif; font-size:.82rem; font-weight:700;
  letter-spacing:.12em; cursor:pointer; transition:all .25s; text-decoration:none;
}
.btn-gold {
  background:linear-gradient(135deg,#7a5c1e,#c9a84c,#f0d080,#c9a84c,#7a5c1e);
  background-size:200% 100%; color:#07070f;
  box-shadow:0 3px 16px rgba(201,168,76,.25);
}
.btn-gold:hover { background-position:100% 0; box-shadow:0 5px 24px rgba(201,168,76,.45); transform:translateY(-1px); }
.btn-ghost { background:transparent; border:1px solid var(--border); color:var(--text2); }
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); }
.btn-red { background:rgba(239,68,68,.15); border:1px solid rgba(239,68,68,.35); color:var(--red); }
.btn-red:hover { background:rgba(239,68,68,.25); }
.btn-green { background:rgba(34,197,94,.15); border:1px solid rgba(34,197,94,.35); color:var(--green); }
.btn-green:hover { background:rgba(34,197,94,.25); }
.btn-blue { background:rgba(59,130,246,.15); border:1px solid rgba(59,130,246,.35); color:var(--rare); }
.btn-blue:hover { background:rgba(59,130,246,.25); }
.btn:disabled { opacity:.4; cursor:not-allowed; transform:none !important; }
.btn-sm { padding:7px 16px; font-size:.72rem; }
.btn-full { width:100%; }

/* ── Alerts ── */
.alert { padding:12px 16px; border-radius:8px; font-size:.9rem; margin-bottom:16px; }
.alert-error   { background:rgba(239,68,68,.1);  border:1px solid rgba(239,68,68,.3);  color:var(--red);   }
.alert-success { background:rgba(34,197,94,.1);  border:1px solid rgba(34,197,94,.3);  color:var(--green); }
.alert-info    { background:rgba(59,130,246,.1); border:1px solid rgba(59,130,246,.3); color:var(--rare);  }
.alert-gold    { background:rgba(201,168,76,.1); border:1px solid rgba(201,168,76,.3); color:var(--gold2); }

/* ── Tables ── */
.data-table { width:100%; border-collapse:collapse; }
.data-table th {
  padding:10px 14px; font-family:'Cinzel',serif; font-size:.58rem; letter-spacing:.15em;
  color:var(--text2); text-align:left; border-bottom:1px solid rgba(255,255,255,.07);
}
.data-table td { padding:10px 14px; font-size:.9rem; border-bottom:1px solid rgba(255,255,255,.04); vertical-align:middle; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(255,255,255,.02); }

/* ── Rarity colours ── */
.r-common    { color:var(--common); }
.r-uncommon  { color:var(--uncommon); }
.r-rare      { color:var(--rare); }
.r-epic      { color:var(--epic); }
.r-legendary { color:var(--legendary); }
.rb { display:inline-block; padding:2px 7px; border-radius:4px; font-size:.62rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.rb-common    { background:rgba(107,114,128,.18); color:var(--common); }
.rb-uncommon  { background:rgba(34,197,94,.14);  color:var(--uncommon); }
.rb-rare      { background:rgba(59,130,246,.14); color:var(--rare); }
.rb-epic      { background:rgba(168,85,247,.14); color:var(--epic); }
.rb-legendary { background:rgba(245,158,11,.14); color:var(--legendary); }

/* ── Medal ranks ── */
.rank-1 { color:var(--legendary); }
.rank-2 { color:var(--text); }
.rank-3 { color:var(--gold); }

/* ── Progress bar ── */
.progress-wrap { background:rgba(255,255,255,.08); border-radius:4px; overflow:hidden; height:6px; }
.progress-fill { height:100%; background:linear-gradient(90deg,var(--gold3),var(--gold2)); border-radius:4px; transition:width .6s; }

/* ── Stat grid ── */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:14px; }
.stat-box { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:16px; }
.stat-box-label { font-size:.62rem; letter-spacing:.2em; color:var(--text2); text-transform:uppercase; margin-bottom:6px; }
.stat-box-val { font-family:'Cinzel',serif; font-size:1.5rem; color:var(--gold2); font-weight:600; }

/* ── Badge grid ── */
.badge-grid { display:flex; flex-wrap:wrap; gap:10px; }
.badge-item {
  display:flex; align-items:center; gap:10px;
  background:var(--bg3); border:1px solid var(--border); border-radius:8px;
  padding:10px 14px; min-width:200px;
}
.badge-item.locked { opacity:.35; filter:grayscale(1); }
.badge-icon { font-size:1.4rem; }
.badge-name { font-family:'Cinzel',serif; font-size:.72rem; color:var(--gold); }
.badge-desc { font-size:.75rem; color:var(--text2); }

/* ── Pack opening stage (play.php) ── */
.play-layout { display:flex; gap:18px; padding:18px; max-width:1400px; margin:0 auto; }
.play-sidebar { width:200px; flex-shrink:0; display:flex; flex-direction:column; gap:14px; }
.play-stage   { flex:1; display:flex; flex-direction:column; align-items:center; gap:18px; min-width:0; }
.play-history { width:220px; flex-shrink:0; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:14px; max-height:700px; overflow:hidden; display:flex; flex-direction:column; }

.odds-banner { background:linear-gradient(90deg,transparent,rgba(201,168,76,.07),transparent); border:1px solid var(--border); border-radius:6px; padding:7px 22px; font-size:.85rem; color:var(--gold); text-align:center; }
.odds-banner span { color:var(--gold2); font-weight:700; }

.pack-img {
  width:152px; height:214px;
  background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460,#533483);
  border-radius:14px; border:2px solid rgba(201,168,76,.4);
  box-shadow:0 0 30px rgba(83,52,131,.4),0 0 60px rgba(83,52,131,.2),inset 0 1px 0 rgba(255,255,255,.1);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  cursor:pointer; transition:transform .2s, box-shadow .2s; position:relative; overflow:hidden;
}
.pack-img::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,transparent 50%); }
.pack-img::after  { content:''; position:absolute; width:80%; height:1px; background:linear-gradient(90deg,transparent,rgba(201,168,76,.5),transparent); top:50%; }
.pack-img:hover   { transform:translateY(-4px) scale(1.02); box-shadow:0 8px 40px rgba(83,52,131,.6),0 0 80px rgba(201,168,76,.15); border-color:rgba(201,168,76,.7); }
.pack-symbol { font-size:2.2rem; filter:drop-shadow(0 0 12px rgba(201,168,76,.8)); z-index:1; }
.pack-label  { font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.2em; color:var(--gold); z-index:1; }
.pack-cost   { font-size:1rem; font-weight:700; color:var(--gold2); z-index:1; }

@keyframes packShake {
  0%,100%{transform:rotate(0)} 15%{transform:rotate(-3deg) scale(1.05)} 30%{transform:rotate(3deg) scale(1.05)}
  45%{transform:rotate(-3deg) scale(1.08)} 60%{transform:rotate(3deg) scale(1.08)}
  75%{transform:rotate(-2deg) scale(1.05)} 90%{transform:rotate(2deg)}
}
.pack-img.shaking { animation:packShake .65s ease-in-out; }

.btn-auto { padding:12px 20px; background:transparent; border:1px solid var(--border); border-radius:8px; color:var(--text2); font-family:'Rajdhani',sans-serif; font-size:.85rem; letter-spacing:.1em; cursor:pointer; transition:all .2s; }
.btn-auto:hover { border-color:var(--gold); color:var(--gold); }
.btn-auto.active { border-color:var(--red); color:var(--red); background:rgba(239,68,68,.05); }

/* Reveal zone */
.reveal-zone { width:100%; min-height:220px; display:flex; align-items:center; justify-content:center; gap:14px; perspective:1000px; }

/* Flip cards */
.card-slot { width:130px; height:188px; position:relative; }
@keyframes cardIn { from{opacity:0;transform:translateY(30px) scale(.8)} to{opacity:1;transform:translateY(0) scale(1)} }
.card-slot { animation:cardIn .4s ease-out both; }
.card-inner { width:100%; height:100%; position:relative; transform-style:preserve-3d; transition:transform .7s cubic-bezier(.4,0,.2,1); }
.card-inner.flipped { transform:rotateY(180deg); }
.card-face { position:absolute; inset:0; border-radius:11px; backface-visibility:hidden; -webkit-backface-visibility:hidden; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.card-back { background:linear-gradient(135deg,#0f0f1a,#1a1a2e); border:2px solid rgba(201,168,76,.3); }
.card-back::before { content:'✦'; font-size:1.7rem; color:rgba(201,168,76,.2); }
.card-front { transform:rotateY(180deg); border:2px solid; overflow:hidden; }
.card-front.common    { background:linear-gradient(135deg,#1a1f2e,#2a2f42); border-color:var(--common);    box-shadow:0 4px 20px rgba(107,114,128,.3); }
.card-front.uncommon  { background:linear-gradient(135deg,#0a1f15,#0d2d1e); border-color:var(--uncommon);  box-shadow:0 4px 28px rgba(34,197,94,.3); }
.card-front.rare      { background:linear-gradient(135deg,#0a1020,#0d1832); border-color:var(--rare);       box-shadow:0 4px 28px rgba(59,130,246,.4); }
.card-front.epic      { background:linear-gradient(135deg,#150a20,#200d32); border-color:var(--epic);       box-shadow:0 0 28px rgba(168,85,247,.5); }
.card-front.legendary { background:linear-gradient(135deg,#1a1000,#2a1a00); border-color:var(--legendary); animation:legPulse 2s infinite alternate; }
@keyframes legPulse { from{box-shadow:0 0 40px rgba(245,158,11,.6)} to{box-shadow:0 0 60px rgba(245,158,11,.9),0 0 120px rgba(245,158,11,.5)} }
.card-num   { font-size:.52rem; color:var(--text2); letter-spacing:.05em; align-self:flex-start; padding:4px 6px; opacity:.7; }
.card-name  { font-family:'Cinzel',serif; font-size:.56rem; letter-spacing:.07em; text-align:center; padding:0 5px; font-weight:600; line-height:1.3; }
.card-ph    { font-size:.4rem; color:var(--text2); opacity:.45; }
.card-rbadge { font-size:.46rem; letter-spacing:.12em; text-transform:uppercase; opacity:.6; }

/* Result banner */
.result-banner { width:100%; min-height:66px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; opacity:0; transition:opacity .5s; }
.result-banner.visible { opacity:1; }
.combo-lbl  { font-family:'Cinzel',serif; font-size:.88rem; letter-spacing:.15em; color:var(--text2); }
.payout-txt { font-family:'Cinzel Decorative',serif; font-size:1.7rem; font-weight:900; }
.payout-txt.win     { color:var(--gold2); text-shadow:0 0 18px rgba(240,208,128,.5); }
.payout-txt.loss    { color:var(--red); }
.payout-txt.jackpot { background:linear-gradient(90deg,var(--legendary),#fff,var(--legendary)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:shimmer 1.5s infinite; background-size:200% 100%; }
@keyframes shimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
.net-res      { font-size:.82rem; font-weight:500; }
.net-res.gain { color:var(--green); }
.net-res.lose { color:var(--red); }

/* History panel */
.history-list { overflow-y:auto; display:flex; flex-direction:column; gap:5px; margin-top:9px; flex:1; scrollbar-width:thin; scrollbar-color:var(--gold3) transparent; }
.hist-item { background:var(--bg3); border-radius:6px; padding:6px 8px; border-left:3px solid var(--common); animation:slideIn .3s ease-out; }
@keyframes slideIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }
.hist-item.uncommon  { border-left-color:var(--uncommon); }
.hist-item.rare      { border-left-color:var(--rare); }
.hist-item.epic      { border-left-color:var(--epic); }
.hist-item.legendary { border-left-color:var(--legendary); }
.hist-combo  { font-size:.73rem; color:var(--text2); }
.hist-names  { font-size:.63rem; color:var(--text2); opacity:.7; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hist-pay    { font-family:'Cinzel',serif; font-size:.82rem; font-weight:600; }
.hist-pay.win  { color:var(--gold2); }
.hist-pay.loss { color:var(--red); }

/* Collection grid */
.coll-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(95px,1fr)); gap:9px; }
.coll-card { background:var(--bg2); border:1px solid var(--border); border-radius:9px; padding:9px 5px 7px; display:flex; flex-direction:column; align-items:center; gap:3px; position:relative; transition:transform .15s; }
.coll-card.found { border-color:rgba(201,168,76,.3); }
.coll-card.found.uncommon  { border-color:rgba(34,197,94,.35);  box-shadow:0 2px 10px rgba(34,197,94,.12); }
.coll-card.found.rare      { border-color:rgba(59,130,246,.35); box-shadow:0 2px 10px rgba(59,130,246,.18); }
.coll-card.found.epic      { border-color:rgba(168,85,247,.35); box-shadow:0 2px 14px rgba(168,85,247,.22); }
.coll-card.found.legendary { border-color:rgba(245,158,11,.45); box-shadow:0 0 18px rgba(245,158,11,.28); }
.coll-card.found:hover { transform:translateY(-2px); }
.coll-card.missing { opacity:.35; filter:grayscale(1); }
.coll-num   { font-size:.48rem; color:var(--text2); opacity:.6; align-self:flex-start; }
.coll-emoji { font-size:1.9rem; line-height:1; }
.coll-card.missing .coll-emoji { filter:grayscale(1) brightness(.3) contrast(2); }
.coll-name  { font-family:'Cinzel',serif; font-size:.48rem; letter-spacing:.06em; text-align:center; font-weight:600; line-height:1.3; }
.coll-card.missing .coll-name { color:var(--text2); }
.coll-rar   { font-size:.42rem; letter-spacing:.1em; text-transform:uppercase; opacity:.55; }
.coll-cnt   { position:absolute; top:4px; right:5px; font-size:.46rem; background:rgba(201,168,76,.18); border-radius:3px; padding:1px 3px; color:var(--gold2); font-weight:600; }
.coll-ph    { font-size:.4rem; color:var(--text2); opacity:.4; }
@keyframes newBadge { 0%{transform:scale(0) rotate(-20deg)} 70%{transform:scale(1.2) rotate(5deg)} 100%{transform:scale(1) rotate(0)} }
.new-badge { position:absolute; top:3px; left:3px; background:var(--gold); color:#000; font-size:.42rem; font-weight:700; padding:1px 4px; border-radius:3px; animation:newBadge .4s; }

/* Particles */
.particles { position:fixed; inset:0; pointer-events:none; z-index:9999; }
.particle { position:absolute; width:6px; height:6px; border-radius:50%; animation:pFly 1.2s ease-out forwards; }
@keyframes pFly { 0%{opacity:1;transform:translate(0,0) scale(1)} 100%{opacity:0;transform:translate(var(--dx),var(--dy)) scale(0)} }

/* Jackpot overlay */
.jackpot-overlay { position:fixed; inset:0; background:rgba(0,0,0,.88); z-index:10000; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; opacity:0; pointer-events:none; transition:opacity .5s; }
.jackpot-overlay.show { opacity:1; pointer-events:all; }
.jackpot-title { font-family:'Cinzel Decorative',serif; font-size:clamp(2rem,7vw,4.5rem); font-weight:900; background:linear-gradient(90deg,var(--legendary),#fff,var(--legendary)); background-size:300% 100%; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation:shimFast 1s infinite linear; }
@keyframes shimFast { 0%{background-position:0%} 100%{background-position:300%} }
.jackpot-amount { font-family:'Cinzel',serif; font-size:clamp(1.2rem,3.5vw,2.3rem); color:var(--gold2); }

/* Save toast */
.toast { position:fixed; bottom:22px; right:22px; z-index:500; background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.4); border-radius:8px; padding:9px 18px; font-size:.8rem; color:var(--green); opacity:0; transition:opacity .3s; pointer-events:none; }
.toast.show { opacity:1; }

/* Landing / home */
.hero { text-align:center; padding:80px 20px 60px; }
.hero-logo { font-family:'Cinzel Decorative',serif; font-size:clamp(3rem,10vw,6rem); font-weight:900; background:linear-gradient(135deg,#7a5c1e 0%,#c9a84c 30%,#f0d080 50%,#c9a84c 70%,#7a5c1e 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; margin-bottom:12px; }
.hero-sub { font-family:'Cinzel',serif; font-size:clamp(.7rem,2vw,1rem); letter-spacing:.4em; color:var(--text2); text-transform:uppercase; margin-bottom:32px; }
.hero-buttons { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.feature-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:16px; padding:0 20px 60px; max-width:1100px; margin:0 auto; }
.feature-box { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:22px; }
.feature-icon { font-size:2rem; margin-bottom:10px; }
.feature-title { font-family:'Cinzel',serif; font-size:.78rem; letter-spacing:.15em; color:var(--gold); margin-bottom:8px; }
.feature-desc  { font-size:.88rem; color:var(--text2); line-height:1.6; }

/* Leaderboard */
.boards-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(340px,1fr)); gap:18px; }
.board-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.board-head { padding:13px 18px; background:rgba(201,168,76,.07); border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; }
.board-icon  { font-size:1.2rem; }
.board-title { font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.2em; color:var(--gold); text-transform:uppercase; }

/* Trades */
.trade-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:18px; margin-bottom:12px; }
.trade-cards { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.trade-mini-card { background:var(--bg3); border:1px solid var(--border); border-radius:8px; padding:10px 14px; text-align:center; min-width:110px; }

/* Daily */
.daily-box { text-align:center; background:var(--bg2); border:1px solid rgba(201,168,76,.35); border-radius:14px; padding:36px 24px; max-width:460px; margin:0 auto; }
.daily-streak { font-family:'Cinzel Decorative',serif; font-size:3rem; color:var(--legendary); }

/* Profile */
.profile-top { display:flex; gap:24px; align-items:flex-start; flex-wrap:wrap; margin-bottom:24px; }
.profile-avatar { width:80px; height:80px; background:linear-gradient(135deg,var(--bg3),var(--bg4)); border:2px solid var(--border); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:2.4rem; flex-shrink:0; }
.profile-name { font-family:'Cinzel',serif; font-size:1.5rem; color:var(--gold2); }
.profile-since { font-size:.82rem; color:var(--text2); margin-top:4px; }

/* Footer */
.site-footer { text-align:center; padding:28px; border-top:1px solid var(--border); font-size:.78rem; color:var(--text2); margin-top:60px; }
.site-footer a { color:var(--text2); text-decoration:none; }
.site-footer a:hover { color:var(--gold); }

/* Responsive */
@media(max-width:900px) {
  .play-layout { flex-direction:column; padding:12px; }
  .play-sidebar,.play-history { width:100%; }
  .play-history { max-height:240px; }
  .navbar { padding:0 14px; }
  .nav-link { padding:5px 8px; font-size:.8rem; }
}
@media(max-width:600px) {
  .boards-grid { grid-template-columns:1fr; }
  .hero-logo { font-size:3rem; }
  .stat-grid { grid-template-columns:1fr 1fr; }
}
