:root{--forest:#1b3a2d;--forest-lt:#2a5541;--gold:#c9973a;--gold-light:#f5e9cf;--gold-deep:#a27820;--cream:#faf8f4;--white:#fff;--border:#ddd8ce;--text:#1c1c1c;--text-mid:#4a4a4a;--text-muted:#7a7a7a;--success:#1a6b35;--success-bg:#f0faf4;--danger:#b03030;--danger-bg:#fdf0f0;--shadow-sm:0 2px 8px rgba(27,58,45,.08);--shadow-md:0 8px 24px rgba(27,58,45,.12);--shadow-lg:0 20px 60px rgba(27,58,45,.18);--radius:8px;--radius-lg:16px;--radius-xl:24px;--copper:#b87333;--copper-dk:#7a4a1e;--silver:#c9ccd1;--silver-dk:#8a8f96;--coin-gold:#d4a857;--coin-gold-dk:#8f6e2a;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Lato',sans-serif;background:var(--cream);color:var(--text);line-height:1.6;overflow-x:hidden;}a{text-decoration:none;color:inherit;}
.site-nav{background:var(--forest);padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:100;}
.nav-brand{font-family:'Playfair Display',serif;font-size:1.1rem;color:#fff;}.nav-brand span{color:var(--gold);}
.nav-links{display:flex;gap:24px;align-items:center;}.nav-links a{font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.75);transition:color .2s;}.nav-links a:hover{color:var(--gold);}
.hero{background:linear-gradient(135deg,var(--forest) 0%,#0f2a20 100%);padding:56px 32px 48px;text-align:center;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(212,168,87,.08) 0,transparent 40%),radial-gradient(circle at 80% 60%,rgba(212,168,87,.06) 0,transparent 40%);pointer-events:none;}
.hero-coins{position:absolute;inset:0;pointer-events:none;opacity:.12;}
.hero .age-badge{display:inline-block;background:var(--gold-light);color:var(--forest);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border-radius:20px;margin-bottom:16px;position:relative;z-index:1;}
.hero h1{font-family:'Playfair Display',serif;font-size:2.6rem;color:#fff;margin-bottom:10px;position:relative;z-index:1;}
.hero p{color:rgba(255,255,255,.75);font-size:.98rem;max-width:560px;margin:0 auto;position:relative;z-index:1;}
.star-bar{background:rgba(255,255,255,.06);border-top:1px solid rgba(255,255,255,.06);padding:18px 32px;text-align:center;font-size:.88rem;color:rgba(255,255,255,.7);position:sticky;top:60px;background-color:var(--forest);z-index:50;}
.star-bar .stars{color:var(--gold);font-size:1.25rem;margin-right:10px;letter-spacing:2px;}
.star-bar .tally{font-weight:700;color:var(--gold);}
.games-wrap{max-width:920px;margin:0 auto;padding:40px 20px 60px;}
.game{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin-bottom:26px;box-shadow:var(--shadow-sm);transition:box-shadow .25s,transform .25s;position:relative;}
.game:hover{box-shadow:var(--shadow-md);}
.game.done{border-color:var(--gold);}
.game.done::before{content:'⭐';position:absolute;top:-12px;right:-12px;background:var(--gold);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 4px 12px rgba(201,151,58,.35);animation:popIn .4s cubic-bezier(.34,1.56,.64,1);}
@keyframes popIn{from{transform:scale(0) rotate(-180deg);}to{transform:scale(1) rotate(0);}}
.game-header{display:flex;align-items:center;gap:14px;margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--border);}
.game-icon{font-size:2.2rem;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12));}
.game-header h2{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--forest);line-height:1.2;}
.game-header .sub{font-size:.82rem;color:var(--text-muted);margin-top:2px;}
.game-header .gh-pts{margin-left:auto;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);background:var(--gold-light);padding:5px 12px;border-radius:20px;white-space:nowrap;}
.btn{display:inline-flex;align-items:center;gap:6px;padding:11px 22px;border-radius:var(--radius);font-size:.85rem;font-weight:700;cursor:pointer;border:none;font-family:'Lato',sans-serif;transition:all .2s;}
.btn-forest{background:var(--forest);color:#fff;}.btn-forest:hover{background:var(--forest-lt);transform:translateY(-1px);}
.btn-gold{background:var(--gold);color:var(--forest);}.btn-gold:hover{background:#daa840;}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted);}.btn-ghost:hover{border-color:var(--forest);color:var(--forest);}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.mini-btn{padding:9px 16px;border-radius:10px;border:2px solid var(--border);background:var(--white);cursor:pointer;font-size:.85rem;font-weight:700;transition:all .15s;font-family:'Lato',sans-serif;color:var(--text);}
.mini-btn:hover{border-color:var(--forest);background:var(--cream);transform:translateY(-1px);}
.coin-stage{display:flex;flex-direction:column;align-items:center;padding:14px 0 8px;}
.coin-svg{display:block;}
.coin-svg.spin{animation:coinSpin .8s ease-out;}
@keyframes coinSpin{0%{transform:rotateY(0) scale(1);}50%{transform:rotateY(180deg) scale(1.1);}100%{transform:rotateY(360deg) scale(1);}}
.coin-svg.wiggle{animation:wiggle .5s ease;}
@keyframes wiggle{0%,100%{transform:rotate(0);}25%{transform:rotate(-8deg);}75%{transform:rotate(8deg);}}
.coin-svg.bounce{animation:bounce .5s ease;}
@keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-14px);}}
.coin-label{margin-top:8px;font-size:.75rem;color:var(--text-muted);font-weight:700;letter-spacing:.05em;text-transform:uppercase;}
.coin-opts{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:16px;}
.coin-opt{padding:11px 22px;border:2px solid var(--border);border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:700;transition:all .18s;background:var(--white);color:var(--text);font-family:'Lato',sans-serif;}
.coin-opt:hover:not(:disabled){border-color:var(--forest);transform:translateY(-1px);}
.coin-opt:active{transform:scale(.96);}
.coin-opt.correct-ans{border-color:var(--success);background:var(--success-bg);color:var(--success);animation:pulseGreen .5s;}
.coin-opt.wrong-ans{border-color:var(--danger);background:var(--danger-bg);color:var(--danger);animation:shake .4s;}
@keyframes pulseGreen{0%{box-shadow:0 0 0 0 rgba(26,107,53,.4);}100%{box-shadow:0 0 0 12px rgba(26,107,53,0);}}
@keyframes shake{0%,100%{transform:translateX(0);}20%,60%{transform:translateX(-6px);}40%,80%{transform:translateX(6px);}}
.nw-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0;}
.nw-drop{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:18px;min-height:150px;text-align:center;transition:all .2s;}
.nw-drop.over{border-color:var(--forest);background:var(--cream);}
.nw-drop h3{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;}
.nw-drop.need-zone h3{color:var(--success);}
.nw-drop.want-zone h3{color:var(--gold-deep);}
.nw-items{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:14px 0;min-height:50px;}
.nw-item{padding:9px 14px;background:var(--white);border:2px solid var(--border);border-radius:20px;cursor:grab;font-size:.88rem;font-weight:700;transition:all .18s;user-select:none;}
.nw-item:hover{border-color:var(--forest);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.nw-item:active{cursor:grabbing;}
.nw-item.dragging{opacity:.5;}
.nw-zone-items{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;}
.nw-zone-item{padding:6px 11px;border-radius:20px;font-size:.78rem;font-weight:700;animation:popIn .3s cubic-bezier(.34,1.56,.64,1);}
.nw-zone-item.need{background:var(--success-bg);color:var(--success);border:1px solid rgba(26,107,53,.2);}
.nw-zone-item.want{background:var(--gold-light);color:var(--gold-deep);border:1px solid rgba(162,120,32,.2);}
.piggy-wrap{text-align:center;}
.piggy-visual{font-size:5rem;margin:10px 0;filter:drop-shadow(0 6px 16px rgba(0,0,0,.12));display:inline-block;transition:transform .3s;}
.piggy-visual.shake{animation:wiggle .4s;}
.goal-bar{background:var(--border);border-radius:20px;height:22px;margin:12px auto;overflow:hidden;max-width:420px;position:relative;}
.goal-fill{height:100%;background:linear-gradient(90deg,var(--forest),var(--success));border-radius:20px;transition:width .6s cubic-bezier(.34,1.56,.64,1);position:relative;}
.goal-fill::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite;}
@keyframes shimmer{from{transform:translateX(-100%);}to{transform:translateX(100%);}}
.coin-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:14px 0;}
.coin-btn{padding:10px 16px;border-radius:10px;border:2px solid var(--border);background:var(--white);cursor:pointer;font-size:.85rem;font-weight:700;transition:all .15s;display:flex;align-items:center;gap:6px;font-family:'Lato',sans-serif;color:var(--text);}
.coin-btn:hover{border-color:var(--forest);background:var(--cream);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.coin-btn:active{transform:scale(.94);}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:16px 0;}
.shop-item{background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);padding:18px;text-align:center;cursor:pointer;transition:all .2s;}
.shop-item:hover:not(.bought){border-color:var(--forest);transform:translateY(-3px);box-shadow:var(--shadow-sm);}
.shop-item.bought{border-color:var(--success);background:var(--success-bg);opacity:.85;cursor:default;}
.shop-item.bought::after{content:'✓';position:absolute;}
.shop-icon{font-size:2.2rem;margin-bottom:6px;display:block;}
.shop-name{font-size:.88rem;font-weight:700;color:var(--text);}
.shop-price{font-size:.82rem;color:var(--gold-deep);font-weight:700;margin-top:2px;}
.wallet-display{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--forest);text-align:center;margin:12px 0;}
.wallet-display span{color:var(--gold-deep);}
.fb-box{padding:12px 16px;border-radius:var(--radius);font-size:.9rem;margin-top:12px;}
.fb-correct{background:var(--success-bg);color:var(--success);border:1px solid rgba(26,107,53,.25);}
.fb-wrong{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(176,48,48,.2);}
.score-strip{text-align:center;font-size:.85rem;color:var(--text-muted);margin-top:14px;}
.score-strip span{font-weight:700;color:var(--gold-deep);}
.coin-pile{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:18px;background:var(--cream);border-radius:var(--radius-lg);margin:14px 0;min-height:100px;align-items:center;}
.coin-pile .coin-svg{transition:transform .2s;}
.coin-pile .coin-svg:hover{transform:translateY(-4px) rotate(4deg);}
.hl-pair{display:flex;gap:24px;justify-content:center;align-items:center;margin:20px 0;flex-wrap:wrap;}
.hl-card{background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);padding:22px 28px;cursor:pointer;text-align:center;transition:all .2s;min-width:150px;}
.hl-card:hover:not(.correct-ans):not(.wrong-ans){border-color:var(--forest);transform:translateY(-3px);box-shadow:var(--shadow-sm);}
.hl-card.correct-ans{border-color:var(--success);background:var(--success-bg);animation:pulseGreen .5s;}
.hl-card.wrong-ans{border-color:var(--danger);background:var(--danger-bg);animation:shake .4s;}
.hl-vs{font-family:'Playfair Display',serif;color:var(--gold);font-size:1.5rem;}
.p2p-row{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:12px 0;align-items:center;}
.p2p-total{font-family:'Playfair Display',serif;font-size:1.6rem;color:var(--forest);text-align:center;}
.p2p-bar{background:var(--border);border-radius:20px;height:18px;margin:10px auto;overflow:hidden;max-width:420px;position:relative;}
.p2p-fill{height:100%;background:linear-gradient(90deg,var(--gold),#e6c070);transition:width .4s cubic-bezier(.34,1.56,.64,1);}
.ctc-grid{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin:26px 0 14px;}
.ctc-swatch{width:68px;height:68px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .2s;position:relative;}
.ctc-swatch:hover{transform:scale(1.1) translateY(-2px);box-shadow:var(--shadow-sm);}
.ctc-swatch.chosen{border-color:var(--forest);box-shadow:0 0 0 4px var(--gold-light);}
.ctc-label{position:absolute;bottom:-26px;left:50%;transform:translateX(-50%);font-size:.72rem;color:var(--text-muted);white-space:nowrap;font-weight:700;}
.share-scene{display:flex;justify-content:space-around;align-items:flex-end;gap:14px;flex-wrap:wrap;margin:18px 0;}
.share-kid{text-align:center;padding:14px;background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);min-width:90px;transition:all .3s;}
.share-kid.gotone{border-color:var(--success);background:var(--success-bg);}
.share-kid .kid-face{font-size:2.4rem;}
.share-kid .kid-sweets{font-size:1.1rem;margin-top:6px;color:var(--gold-deep);font-weight:700;min-height:22px;}
.share-opts{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.odd-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:14px 0;}
.odd-card{background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);padding:16px 8px;text-align:center;cursor:pointer;transition:all .2s;}
.odd-card:hover:not(.correct-ans):not(.wrong-ans){border-color:var(--forest);transform:translateY(-3px);}
.odd-card.correct-ans{border-color:var(--success);background:var(--success-bg);animation:pulseGreen .5s;}
.odd-card.wrong-ans{border-color:var(--danger);background:var(--danger-bg);animation:shake .4s;}
@media(max-width:520px){.odd-grid{grid-template-columns:repeat(2,1fr);}}
.mem-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:14px auto;max-width:420px;}
.mem-card{aspect-ratio:1/1;background:var(--forest);border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;position:relative;overflow:hidden;perspective:600px;}
.mem-card.flipped{background:var(--white);border:2px solid var(--gold);transform:rotateY(180deg);}
.mem-card.matched{background:var(--success-bg);border:2px solid var(--success);cursor:default;animation:matchPop .4s;}
@keyframes matchPop{0%,100%{transform:scale(1);}50%{transform:scale(1.08);}}
.mem-card.flipped .mem-back,.mem-card.matched .mem-back{display:none;}
.mem-card:not(.flipped):not(.matched) .mem-face{display:none;}
.mem-back{color:var(--gold);font-size:1.8rem;font-weight:700;font-family:'Playfair Display',serif;}
.mem-face{display:flex;align-items:center;justify-content:center;transform:rotateY(180deg);}
.treasure-q{background:linear-gradient(135deg,var(--cream),#fff);border-radius:var(--radius-lg);padding:22px;border:2px solid var(--border);text-align:center;}
.treasure-q p.tq-text{font-size:1.1rem;color:var(--forest);font-weight:700;margin-bottom:14px;}
.treasure-chest{text-align:center;padding:14px 0 8px;}
.treasure-coins{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--coin-gold-dk);}
.q-text{font-size:1.05rem;font-weight:700;color:var(--forest);text-align:center;margin:6px 0 12px;}
/* NEW GAME STYLES */
.rain-arena{position:relative;height:340px;background:linear-gradient(180deg,#e6f4ff 0%,#c9e8ff 100%);border-radius:var(--radius-lg);margin:14px 0;overflow:hidden;border:2px solid var(--border);}
.rain-coin{position:absolute;top:-60px;cursor:pointer;transition:transform .15s;}
.rain-coin:active{transform:scale(.9);}
.rain-coin.hit{animation:coinPop .35s ease forwards;pointer-events:none;}
@keyframes coinPop{0%{transform:scale(1);opacity:1;}100%{transform:scale(2) rotate(180deg);opacity:0;}}
.rain-hud{position:absolute;top:10px;left:10px;right:10px;display:flex;justify-content:space-between;font-family:'Playfair Display',serif;font-size:1rem;color:var(--forest);background:rgba(255,255,255,.85);padding:6px 12px;border-radius:10px;font-weight:700;}
.rain-target{text-align:center;font-size:.85rem;color:var(--text-muted);margin:4px 0;}
.rain-target strong{color:var(--gold-deep);font-size:1.05rem;}
.rain-overlay{position:absolute;inset:0;background:rgba(27,58,45,.9);color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;padding:20px;font-family:'Playfair Display',serif;}
.rain-overlay h3{font-size:1.6rem;margin-bottom:8px;}
.rain-overlay p{font-size:.95rem;color:rgba(255,255,255,.8);margin-bottom:16px;font-family:'Lato',sans-serif;font-weight:400;}
.snap-deck{display:flex;gap:14px;justify-content:center;align-items:center;margin:18px 0;min-height:140px;}
.snap-card{background:var(--cream);border:3px solid var(--border);border-radius:var(--radius-lg);padding:18px 24px;text-align:center;min-width:140px;transition:all .3s;}
.snap-card.flash-match{border-color:var(--success);background:var(--success-bg);animation:matchPop .5s;}
.snap-card.flash-miss{border-color:var(--danger);background:var(--danger-bg);animation:shake .4s;}
.snap-value{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--forest);margin-top:8px;}
.snap-controls{display:flex;gap:14px;justify-content:center;margin-top:14px;}
.snap-btn{padding:14px 28px;border-radius:12px;border:none;font-family:'Lato',sans-serif;font-weight:700;font-size:1rem;cursor:pointer;transition:all .15s;letter-spacing:.5px;text-transform:uppercase;}
.snap-btn.snap{background:var(--gold);color:var(--forest);box-shadow:0 4px 12px rgba(201,151,58,.3);}
.snap-btn.snap:hover{background:#daa840;transform:translateY(-2px);}
.snap-btn.pass{background:var(--white);color:var(--text-mid);border:2px solid var(--border);}
.snap-btn.pass:hover{border-color:var(--forest);}
.snap-hud{text-align:center;font-size:.9rem;color:var(--text-muted);margin-top:8px;}
.snap-hud span{color:var(--gold-deep);font-weight:700;}
.tag-wrap{margin:14px 0;}
.tag-row{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:10px;gap:12px;transition:all .2s;}
.tag-row.correct{border-color:var(--success);background:var(--success-bg);}
.tag-row.wrong{border-color:var(--danger);}
.tag-item{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1rem;}
.tag-item .ti-icon{font-size:1.6rem;}
.tag-drop{border:2px dashed var(--border);border-radius:10px;padding:8px 14px;min-width:80px;text-align:center;font-weight:700;color:var(--text-muted);background:var(--white);transition:all .2s;}
.tag-drop.over{border-color:var(--forest);background:var(--gold-light);}
.tag-drop.filled{border-style:solid;color:var(--forest);background:var(--gold-light);}
.tag-prices{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:14px;background:var(--cream);border-radius:var(--radius-lg);margin:10px 0;}
.tag-price{padding:10px 16px;background:var(--white);border:2px solid var(--border);border-radius:20px;cursor:grab;font-weight:700;color:var(--gold-deep);font-size:.95rem;user-select:none;transition:all .18s;}
.tag-price:hover{border-color:var(--forest);transform:translateY(-2px);}
.tag-price.used{opacity:.35;cursor:default;}
.tag-price.dragging{opacity:.5;}
.stack-arena{background:linear-gradient(180deg,#fef6e0,#faf8f4);border-radius:var(--radius-lg);padding:18px;margin:14px 0;border:2px solid var(--border);}
.stack-target{text-align:center;font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--forest);margin-bottom:6px;}
.stack-current{text-align:center;font-size:1rem;color:var(--gold-deep);font-weight:700;margin-bottom:10px;}
.stack-tower{min-height:180px;display:flex;flex-direction:column-reverse;align-items:center;gap:2px;padding:8px;border-bottom:3px solid var(--forest);}
.stack-tower .coin-svg{animation:dropIn .4s cubic-bezier(.34,1.56,.64,1);}
@keyframes dropIn{0%{transform:translateY(-60px) rotate(-20deg);opacity:0;}100%{transform:translateY(0) rotate(0);opacity:1;}}
.stack-picker{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:12px;}
.basket-hud{display:flex;justify-content:space-between;align-items:center;background:var(--forest);color:#fff;padding:14px 20px;border-radius:var(--radius-lg);margin:10px 0;font-family:'Playfair Display',serif;font-size:1.05rem;}
.basket-hud .budget-left{color:var(--gold);}
.basket-hud .budget-left.warn{color:#ffb347;}
.basket-hud .budget-left.over{color:#ff8080;}
.basket-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;margin:12px 0;}
.basket-item{background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);padding:14px 8px;text-align:center;cursor:pointer;transition:all .2s;}
.basket-item:hover{border-color:var(--forest);transform:translateY(-2px);}
.basket-item.inbasket{border-color:var(--gold);background:var(--gold-light);}
.basket-bag{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:12px;background:var(--cream);border-radius:var(--radius-lg);min-height:60px;margin:10px 0;}
.basket-bag-item{background:var(--white);border:1px solid var(--gold);border-radius:14px;padding:5px 10px;font-size:.82rem;font-weight:700;display:flex;align-items:center;gap:4px;animation:popIn .3s cubic-bezier(.34,1.56,.64,1);}
.basket-bag-item .rm{margin-left:4px;color:var(--danger);cursor:pointer;font-weight:900;}
.timer-bar{background:var(--border);border-radius:10px;height:8px;overflow:hidden;margin:10px 0;}
.timer-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--gold),var(--danger));transition:width .1s linear;}
.race-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:14px 0;}
.race-lane{background:var(--cream);border:2px solid var(--border);border-radius:var(--radius-lg);padding:16px;text-align:center;}
.race-lane.you{border-color:var(--forest);}
.race-lane h4{font-family:'Playfair Display',serif;color:var(--forest);margin-bottom:8px;font-size:1.05rem;}
.race-piggy{font-size:3.5rem;transition:transform .3s;display:inline-block;}
.race-piggy.grow{transform:scale(1.15);}
.race-fill-outer{background:var(--border);border-radius:14px;height:14px;overflow:hidden;margin:8px 0;}
.race-fill{height:100%;transition:width .5s;border-radius:14px;}
.race-fill.you-fill{background:linear-gradient(90deg,var(--forest),var(--success));}
.race-fill.cpu-fill{background:linear-gradient(90deg,#b87333,#d4a857);}
.confetti{position:fixed;top:-10px;width:10px;height:14px;pointer-events:none;z-index:9999;animation:confFall 2.5s cubic-bezier(.1,.5,.3,1) forwards;}
@keyframes confFall{from{transform:translateY(-10px) rotate(0);opacity:1;}to{transform:translateY(110vh) rotate(720deg);opacity:.4;}}
@media(max-width:520px){.race-grid{grid-template-columns:1fr;}}
.site-footer{background:var(--forest);padding:32px 24px 24px;color:rgba(255,255,255,.6);text-align:center;font-size:.82rem;margin-top:40px;}
.site-footer a{color:var(--gold);}
.site-footer .fb2{font-family:'Playfair Display',serif;font-size:1.15rem;color:#fff;margin-bottom:8px;}
