﻿:root{
    --bg1:#FBF6EE; --bg2:#F6E5D4; --bg3:#F2DBC6;
    --panel:#FFFDF9; --panel2:#FFF7ED; --panel-line:#EFE2D2;
    --ink:#48382F; --ink-soft:#9A8676; --ink-faint:#BCA999;
    --accent:#F0894C; --accent2:#E9762F; --accent-soft:#FCE2CD;
    --gold:#E3AE4F; --gold-soft:#F7E6C2;
    --green:#7DA88C; --green-soft:#E0EDE2;
    --rose:#E498A0; --rose-soft:#F8E2E4;
    --sky:#9FB7C9;
    --shadow-sm:0 4px 14px -8px rgba(72,56,47,.35);
    --shadow:0 14px 34px -16px rgba(72,56,47,.32);
    --shadow-lg:0 26px 60px -24px rgba(72,56,47,.40);
    --r:20px; --r-sm:14px; --r-lg:28px;
    --disp:'Fredoka','Nunito','Trebuchet MS',sans-serif;
    --body:'Nunito',system-ui,-apple-system,sans-serif;
  }
  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  html,body{margin:0;padding:0}
  body{
    font-family:var(--body);
    color:var(--ink);
    background:
      radial-gradient(1200px 700px at 18% -10%, #FFF6E9 0%, transparent 55%),
      radial-gradient(1000px 800px at 110% 10%, #FBE6D2 0%, transparent 50%),
      linear-gradient(165deg, var(--bg1) 0%, var(--bg2) 60%, var(--bg3) 100%);
    min-height:100vh; overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  .wrap{max-width:1200px;margin:0 auto;padding:18px 16px 40px}

  /* ---------- top bar ---------- */
  .topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
  .brand{display:flex;align-items:center;gap:11px;min-width:0}
  .brand .logo{
    width:46px;height:46px;border-radius:14px;flex:none;
    background:linear-gradient(140deg,var(--accent),var(--accent2));
    display:grid;place-items:center;font-size:25px;box-shadow:var(--shadow-sm);
    position:relative;
  }
  .brand .logo::after{content:"";position:absolute;inset:0;border-radius:14px;border:1.5px solid rgba(255,255,255,.45)}
  .brand h1{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:.3px;margin:0;line-height:1.15}
  .brand-tagline{margin:3px 0 0;font-size:11.5px;color:var(--ink-soft);font-weight:700;letter-spacing:.2px;line-height:1.3;max-width:280px}
  .topbtns{display:flex;gap:8px}
  .icon-btn{
    border:1px solid var(--panel-line);background:var(--panel);color:var(--ink);
    width:42px;height:42px;border-radius:13px;cursor:pointer;font-size:18px;
    display:grid;place-items:center;transition:.18s;box-shadow:var(--shadow-sm);font-family:var(--body)
  }
  .icon-btn:hover{transform:translateY(-2px);background:var(--panel2)}
  .icon-btn:active{transform:translateY(0)}

  /* ---------- grid ---------- */
  .grid{display:grid;grid-template-columns:300px minmax(0,1fr) 318px;gap:16px;align-items:start}
  .panel{
    background:var(--panel);border:1px solid var(--panel-line);border-radius:var(--r);
    box-shadow:var(--shadow);overflow:hidden;
  }
  .panel-head{
    display:flex;align-items:center;justify-content:space-between;
    padding:15px 18px 13px;border-bottom:1px solid var(--panel-line);
  }
  .panel-head .ttl{font-family:var(--disp);font-weight:600;font-size:15.5px;letter-spacing:.4px;text-transform:uppercase}
  .panel-head .sub{font-size:11.5px;color:var(--ink-faint);font-weight:800;letter-spacing:.3px}

  /* ---------- shop ---------- */
  .shop-list{max-height:560px;overflow-y:auto;padding:9px}
  .shop-list::-webkit-scrollbar{width:8px}
  .shop-list::-webkit-scrollbar-thumb{background:#E6D7C5;border-radius:8px}
  .up{
    display:flex;align-items:center;gap:11px;padding:11px 11px;border-radius:var(--r-sm);
    cursor:pointer;transition:.14s;border:1px solid transparent;position:relative;margin-bottom:3px;
  }
  .up:hover{background:var(--panel2);border-color:var(--panel-line)}
  .up.locked{opacity:.5;filter:grayscale(.5)}
  .up.cant{cursor:not-allowed}
  .up.cant:not(.locked){opacity:.62}
  .up .ic{
    width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;font-size:21px;
    background:linear-gradient(145deg,var(--accent-soft),#FFF1E4);border:1px solid #F4DcC6;
  }
  .up.mult .ic{background:linear-gradient(145deg,var(--green-soft),#EFF6F0);border-color:#D6E7DB}
  .up .mid{flex:1;min-width:0}
  .up .nm{font-weight:800;font-size:13.5px;line-height:1.15;display:flex;align-items:center;gap:6px}
  .up .nm .own{font-size:11px;color:var(--accent2);font-weight:900;background:var(--accent-soft);padding:1px 7px;border-radius:20px}
  .up .ds{font-size:11.5px;color:var(--ink-soft);font-weight:700;margin-top:2px}
  .up .pr{display:flex;flex-direction:column;align-items:flex-end;flex:none;gap:2px}
  .up .cost{font-weight:900;font-size:13.5px;font-family:var(--disp);white-space:nowrap}
  .up .cost.ok{color:var(--ink)}
  .up .cost.no{color:var(--ink-faint)}
  .up .cost::before{content:"🐾 ";font-size:10px}
  .up .lvl{font-size:10px;color:var(--ink-faint);font-weight:800}
  .up .flash{position:absolute;inset:0;border-radius:var(--r-sm);background:var(--accent);opacity:0;pointer-events:none}
  .up.bought .flash{animation:buyflash .5s ease}
  .up.owned{background:linear-gradient(160deg,#F8FDF9,#FFFDF9);border-color:var(--green-soft)}
  .up.equipped,.up.active-cat{background:linear-gradient(160deg,#FFF8EA,#FFFDF8);border-color:var(--gold-soft)}
  .up .cost.text::before{content:none}
  .up .cost.text{font-size:11px;font-family:var(--body);font-weight:900}
  .up .lvl.on{color:var(--gold)}
  @keyframes buyflash{0%{opacity:.28}100%{opacity:0}}

  /* ---------- center / game ---------- */
  .stage-center{display:flex;flex-direction:column;gap:14px}
  .hud{
    background:var(--panel);border:1px solid var(--panel-line);border-radius:var(--r-lg);
    box-shadow:var(--shadow);padding:18px 22px 20px;text-align:center;position:relative;overflow:hidden;
  }
  .hud .eyebrow{font-size:11px;letter-spacing:2.4px;font-weight:900;color:var(--ink-faint);text-transform:uppercase}
  .bignum{font-family:var(--disp);font-weight:700;font-size:64px;line-height:.98;margin:4px 0 0;letter-spacing:-1px;
    background:linear-gradient(180deg,var(--ink),#6A5547);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
  .persec{font-size:14.5px;font-weight:800;color:var(--accent2);margin-top:2px;height:19px}
  .persec b{font-family:var(--disp);font-weight:600}
  .lvlbar-wrap{margin-top:15px}
  .lvlbar-top{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;font-weight:800;margin-bottom:6px}
  .lvlbar-top .lname{color:var(--ink);font-weight:900}
  .lvlbar-top .lname span{color:var(--ink-faint);font-weight:800}
  .lvlbar-top .lnext{color:var(--ink-soft)}
  .bar{height:11px;border-radius:20px;background:#F0E5D6;overflow:hidden;position:relative}
  .bar > i{display:block;height:100%;border-radius:20px;
    background:linear-gradient(90deg,var(--accent),var(--gold));transition:width .35s cubic-bezier(.4,0,.2,1);
    box-shadow:0 0 12px -2px var(--accent)}

  .scene-card{
    background:
      radial-gradient(120% 90% at 50% 8%, #FFF3E2 0%, transparent 60%),
      linear-gradient(180deg,#FDEFDD 0%, #F6DEC4 100%);
    border:1px solid var(--panel-line);border-radius:var(--r-lg);box-shadow:var(--shadow);
    position:relative;overflow:hidden;min-height:340px;
  }
  /* string lights */
  .lights{position:absolute;top:0;left:0;right:0;height:60px;pointer-events:none;z-index:2}
  .lights svg{width:100%;height:100%}
  .menu-board{position:absolute;left:16px;bottom:18px;width:70px;height:92px;transform:rotate(-5deg);z-index:2;
    background:linear-gradient(160deg,#5b4636,#3f3024);border-radius:8px;border:3px solid #d9b27f;
    box-shadow:var(--shadow-sm);padding:8px 6px;color:#f3e7d4;font-size:8px;line-height:1.7;text-align:center;font-weight:800;letter-spacing:.4px}
  .menu-board .mt{font-family:var(--disp);font-size:9px;color:var(--rose);margin-bottom:3px}
  .plant{position:absolute;right:14px;bottom:14px;font-size:34px;z-index:2;transform:rotate(4deg);filter:drop-shadow(0 6px 8px rgba(0,0,0,.12))}
  .scene-window{position:absolute;right:-6%;top:8%;width:42%;height:60%;border-radius:14px;z-index:1;opacity:.6;
    background:linear-gradient(180deg,#cfe0e8,#e6d6c4);border:6px solid #efe2d0;box-shadow:inset 0 0 0 3px #d9c6b0}

  .scene-stage{position:absolute;inset:0;display:grid;place-items:center;z-index:3}
  .cat-aura{position:absolute;width:300px;height:300px;border-radius:50%;
    background:radial-gradient(circle, rgba(157,144,224,.55) 0%, transparent 62%);
    opacity:0;transition:opacity .5s;pointer-events:none;animation:pulse 3.2s ease-in-out infinite;z-index:2}
  @keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
  .scene-stage.cosmic .cat-aura{opacity:1}
  .stars{position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity .6s;z-index:2}
  .scene-stage.cosmic .stars{opacity:1}

  .cat-clic{position:relative;cursor:pointer;z-index:4;transition:transform .12s;will-change:transform;
    user-select:none;-webkit-user-select:none;display:grid;place-items:center;width:230px;height:240px}
  .cat-clic:active{transform:scale(.97)}
  .cat-scale{transition:transform .5s cubic-bezier(.34,1.56,.64,1);transform-origin:bottom center}
  .cat-bounce{transform-origin:bottom center}
  .cat-bounce.nom{animation:nom .26s ease}
  @keyframes nom{0%{transform:scaleX(1) scaleY(1)}35%{transform:scaleX(1.12) scaleY(.86)}70%{transform:scaleX(.95) scaleY(1.06)}100%{transform:scaleX(1) scaleY(1)}}
  .cat-bounce.levelup{animation:levelup .7s cubic-bezier(.34,1.56,.64,1)}
  @keyframes levelup{0%{transform:scale(1)}40%{transform:scale(1.22) rotate(-3deg)}70%{transform:scale(.96) rotate(2deg)}100%{transform:scale(1) rotate(0)}}
  .cat-svg{width:200px;height:200px;display:block;overflow:visible}
  .cat-img{
    width:200px;height:200px;display:block;object-fit:contain;
    pointer-events:none;user-select:none;-webkit-user-select:none;
    filter:drop-shadow(0 4px 10px rgba(72,56,47,.14));
  }
  .cat-scale.use-fallback .cat-img{display:none}
  .cat-scale:not(.use-fallback) .cat-svg-fallback{display:none}
  .cat-shadow{position:absolute;bottom:30px;width:150px;height:26px;border-radius:50%;
    background:radial-gradient(ellipse,rgba(80,56,40,.26),transparent 70%);z-index:3;transition:width .5s,transform .5s}

  /* combo / purr */
  .purr{display:flex;align-items:center;gap:9px;justify-content:center}
  .purr .plabel{font-size:11.5px;font-weight:900;color:var(--rose);letter-spacing:.4px;white-space:nowrap;display:flex;align-items:center;gap:4px}
  .purr .pbar{flex:1;max-width:260px;height:9px;border-radius:20px;background:#F4E2E4;overflow:hidden}
  .purr .pbar > i{display:block;height:100%;width:0;border-radius:20px;background:linear-gradient(90deg,var(--rose),#F0B45C);transition:width .12s}
  .purr .pmult{font-family:var(--disp);font-weight:600;font-size:13px;color:var(--rose);min-width:42px;text-align:right}

  .feed-btn{
    width:100%;border:none;cursor:pointer;border-radius:var(--r);
    background:linear-gradient(160deg,var(--accent) 0%, var(--accent2) 100%);
    color:#fff;font-family:var(--disp);font-weight:600;font-size:21px;letter-spacing:.6px;
    padding:18px;box-shadow:0 14px 26px -10px rgba(233,118,47,.65), inset 0 2px 0 rgba(255,255,255,.35);
    display:flex;align-items:center;justify-content:center;gap:11px;transition:.12s;position:relative;overflow:hidden
  }
  .feed-btn:hover{transform:translateY(-2px);box-shadow:0 18px 30px -10px rgba(233,118,47,.7), inset 0 2px 0 rgba(255,255,255,.35)}
  .feed-btn:active{transform:translateY(1px) scale(.99)}
  .feed-btn .pl{background:rgba(255,255,255,.25);border-radius:30px;padding:3px 11px;font-size:14px;font-weight:600}
  .feed-btn .paw{font-size:22px}
  .feed-btn .ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.5);transform:translate(-50%,-50%);pointer-events:none;animation:rip .5s ease-out}
  @keyframes rip{from{width:0;height:0;opacity:.5}to{width:320px;height:320px;opacity:0}}

  /* floating + particles layer */
  .fx{position:absolute;inset:0;pointer-events:none;z-index:6;overflow:hidden}
  .float{position:absolute;font-family:var(--disp);font-weight:700;font-size:24px;color:var(--accent2);
    text-shadow:0 2px 6px rgba(255,255,255,.8);animation:floatUp 1s ease-out forwards;white-space:nowrap}
  .float.crit{font-size:30px;color:var(--gold);text-shadow:0 0 14px rgba(227,174,79,.9),0 2px 4px rgba(0,0,0,.15)}
  @keyframes floatUp{0%{transform:translateY(0) scale(.6);opacity:0}18%{transform:translateY(-8px) scale(1.1);opacity:1}100%{transform:translateY(-78px) scale(.95);opacity:0}}
  .part{position:absolute;font-size:18px;animation:burst .8s ease-out forwards;pointer-events:none}
  @keyframes burst{0%{transform:translate(0,0) scale(.4);opacity:1}100%{transform:translate(var(--dx),var(--dy)) scale(1) rotate(var(--rot));opacity:0}}
  .scene-flash{position:absolute;inset:0;background:radial-gradient(circle,rgba(227,174,79,.4),transparent 65%);opacity:0;pointer-events:none;z-index:5}
  .scene-flash.go{animation:flashfx .5s ease}
  @keyframes flashfx{0%{opacity:.9}100%{opacity:0}}

  /* ---------- right panel / tabs ---------- */
  .tabs{display:flex;gap:6px;padding:11px 11px 0}
  .tab{flex:1;border:none;cursor:pointer;background:transparent;color:var(--ink-soft);font-family:var(--body);
    font-weight:900;font-size:12.5px;padding:9px 6px;border-radius:11px 11px 0 0;transition:.15s;letter-spacing:.2px}
  .tab.on{background:var(--panel2);color:var(--ink)}
  .tab:hover:not(.on){color:var(--ink)}
  .tabwrap{padding:13px 14px 16px}
  .pane{display:none}
  .pane.on{display:block;animation:fade .25s ease}
  @keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

  .stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px}
  .stat{background:var(--panel2);border:1px solid var(--panel-line);border-radius:var(--r-sm);padding:11px 12px}
  .stat .k{font-size:10.5px;font-weight:900;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.5px}
  .stat .v{font-family:var(--disp);font-weight:600;font-size:19px;margin-top:3px;color:var(--ink);line-height:1}
  .stat.wide{grid-column:1/-1}
  .stat.accent .v{color:var(--accent2)}
  .stat.green .v{color:var(--green)}

  .ach-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .ach{background:var(--panel2);border:1px solid var(--panel-line);border-radius:var(--r-sm);padding:10px;text-align:center;position:relative;transition:.2s}
  .ach.locked{opacity:.45;filter:grayscale(.7)}
  .ach.unlocked{border-color:var(--gold-soft);background:linear-gradient(160deg,#FFF8EA,#FFFDF8)}
  .ach .ai{font-size:24px;line-height:1}
  .ach .an{font-size:11px;font-weight:900;margin-top:5px;line-height:1.15}
  .ach .ad{font-size:9.5px;color:var(--ink-soft);font-weight:700;margin-top:2px;line-height:1.2}
  .ach.unlocked::after{content:"✓";position:absolute;top:6px;right:7px;font-size:10px;color:#fff;background:var(--gold);width:16px;height:16px;border-radius:50%;display:grid;place-items:center;font-weight:900}
  .ach-prog{text-align:center;font-size:11.5px;font-weight:900;color:var(--ink-soft);margin-bottom:11px}

  .prestige{text-align:center}
  .prestige .crown{font-size:40px;margin-bottom:6px}
  .prestige h3{font-family:var(--disp);font-weight:600;font-size:18px;margin:0 0 4px}
  .prestige p{font-size:12px;color:var(--ink-soft);font-weight:700;line-height:1.5;margin:0 0 12px}
  .paw-box{background:linear-gradient(160deg,#FFF8EA,#FFFDF8);border:1px solid var(--gold-soft);border-radius:var(--r-sm);padding:13px;margin-bottom:12px}
  .paw-box .pn{font-family:var(--disp);font-weight:700;font-size:30px;color:var(--gold);line-height:1}
  .paw-box .pl{font-size:11px;font-weight:900;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.4px;margin-top:3px}
  .paw-box .pb{font-size:11.5px;color:var(--green);font-weight:800;margin-top:6px}
  .big-btn{width:100%;border:none;cursor:pointer;border-radius:var(--r-sm);font-family:var(--disp);font-weight:600;font-size:15px;
    padding:13px;transition:.15s;letter-spacing:.3px}
  .big-btn.gold{background:linear-gradient(160deg,var(--gold),#D49636);color:#fff;box-shadow:var(--shadow-sm)}
  .big-btn.gold:hover{transform:translateY(-2px)}
  .big-btn.gold:disabled{opacity:.5;cursor:not-allowed;transform:none}
  .big-btn.ghost{background:var(--panel2);color:var(--ink-soft);border:1px solid var(--panel-line);font-size:13px;margin-top:9px;font-weight:700;font-family:var(--body)}
  .big-btn.ghost:hover{color:#c0473a;border-color:#f0c9c4}
  .pre-next{font-size:11px;color:var(--ink-faint);font-weight:800;margin-top:9px}

  /* badges row */
  .badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:12px}
  .badge{font-size:11px;font-weight:800;color:var(--ink-soft);background:var(--panel2);border:1px solid var(--panel-line);
    padding:4px 10px;border-radius:30px;display:flex;align-items:center;gap:5px}
  .badge.on{color:var(--accent2);background:var(--accent-soft);border-color:#f3d6bf}

  /* toast */
  .toasts{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:9px;align-items:center;pointer-events:none}
  .toast{background:var(--ink);color:#fff;padding:12px 20px;border-radius:30px;font-weight:800;font-size:13.5px;
    box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;animation:toastIn .4s cubic-bezier(.34,1.56,.64,1);max-width:90vw}
  .toast .ti{font-size:20px}
  .toast.gold{background:linear-gradient(135deg,#C68B2A,#E3AE4F)}
  .toast.green{background:linear-gradient(135deg,#5C8A6E,#7DA88C)}
  @keyframes toastIn{from{transform:translateY(20px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
  .toast.out{animation:toastOut .35s ease forwards}
  @keyframes toastOut{to{transform:translateY(14px);opacity:0}}

  /* modal */
  .ov{position:fixed;inset:0;background:rgba(50,38,30,.5);backdrop-filter:blur(3px);z-index:80;display:none;place-items:center;padding:20px}
  .ov.on{display:grid}
  .modal{background:var(--panel);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);max-width:380px;width:100%;padding:26px;text-align:center;animation:toastIn .35s ease}
  .modal .mi{font-size:40px}
  .modal h3{font-family:var(--disp);font-weight:600;font-size:21px;margin:8px 0 6px}
  .modal p{font-size:13.5px;color:var(--ink-soft);font-weight:700;line-height:1.5;margin:0 0 18px}
  .modal .row{display:flex;gap:10px}
  .modal .row .big-btn{flex:1}
  .big-btn.danger{background:linear-gradient(160deg,#E07A6B,#C95846);color:#fff}

  /* cat speech bubble */
  .cat-bubble{
    position:absolute;top:18%;left:50%;transform:translateX(-50%) scale(.9);
    background:#fff;border:2px solid var(--panel-line);border-radius:16px;
    padding:8px 14px;font-size:12px;font-weight:800;color:var(--ink);
    box-shadow:var(--shadow-sm);z-index:7;pointer-events:none;opacity:0;
    max-width:200px;text-align:center;line-height:1.25;white-space:nowrap;
  }
  .cat-bubble::after{
    content:"";position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);
    border:8px solid transparent;border-top-color:#fff;border-bottom:0;
  }
  .cat-bubble.show{animation:bubblePop .35s cubic-bezier(.34,1.56,.64,1) forwards}
  @keyframes bubblePop{0%{opacity:0;transform:translateX(-50%) scale(.6) translateY(8px)}100%{opacity:1;transform:translateX(-50%) scale(1) translateY(0)}}

  /* random events banner */
  .event-bar{
    position:absolute;top:10px;left:10px;right:10px;z-index:8;
    background:rgba(255,253,249,.95);border:2px solid var(--accent-soft);
    border-radius:var(--r-sm);padding:10px 12px;box-shadow:var(--shadow-sm);
    animation:eventIn .3s ease;
  }
  .event-bar.danger{border-color:#f0c9c4;background:rgba(255,245,243,.97)}
  .event-bar.success{border-color:var(--green-soft);background:rgba(240,248,242,.97)}
  @keyframes eventIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
  .event-bar-inner{display:flex;align-items:center;gap:10px}
  .event-bar .event-ic{font-size:26px;flex:none;line-height:1}
  .event-bar .event-body{flex:1;min-width:0}
  .event-bar .event-txt{font-size:12.5px;font-weight:800;color:var(--ink);line-height:1.2}
  .event-bar .event-sub{font-size:10.5px;font-weight:700;color:var(--ink-soft);margin-top:2px}
  .event-bar .event-timer{font-family:var(--disp);font-weight:700;font-size:18px;color:var(--accent2);flex:none;min-width:36px;text-align:right}
  .event-bar .event-btn{
    border:none;cursor:pointer;border-radius:10px;padding:7px 12px;
    font-family:var(--body);font-weight:900;font-size:11px;background:var(--accent);color:#fff;flex:none;
  }
  .event-bar .event-btn:hover{filter:brightness(1.05)}
  .event-pigeon{
    position:absolute;right:8%;top:12%;font-size:36px;z-index:6;cursor:pointer;
    animation:pigeonPeck 1.2s ease-in-out infinite;filter:drop-shadow(0 4px 6px rgba(0,0,0,.15));
    user-select:none;-webkit-user-select:none;
  }
  @keyframes pigeonPeck{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(8deg) scale(1.05)}}
  .event-pigeon.hit{animation:pigeonFlee .5s ease forwards}
  @keyframes pigeonFlee{to{transform:translate(80px,-60px) scale(.3);opacity:0}}

  /* rival cats */
  .rivals{position:absolute;inset:0;pointer-events:none;z-index:5}
  .rival-cat{
    position:absolute;bottom:22%;font-size:42px;cursor:pointer;pointer-events:auto;
    background:none;border:none;padding:0;line-height:1;filter:drop-shadow(0 6px 10px rgba(0,0,0,.2));
    transition:transform .12s;user-select:none;-webkit-user-select:none;
    animation:rivalWiggle 1.8s ease-in-out infinite;
  }
  .rival-cat:nth-child(odd){animation-delay:.4s}
  .rival-cat:active{transform:scale(.88)}
  .rival-cat.shoo{animation:rivalFlee .45s ease forwards;pointer-events:none}
  @keyframes rivalWiggle{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg) translateY(-3px)}}
  @keyframes rivalFlee{to{transform:translateY(-80px) scale(.2);opacity:0}}
  .rival-cat .rival-hp{
    position:absolute;top:-6px;right:-4px;width:18px;height:18px;border-radius:50%;
    background:var(--rose);color:#fff;font-size:10px;font-weight:900;
    display:grid;place-items:center;font-family:var(--body);
  }

  /* cat flip easter egg */
  .cat-bounce.flip{animation:catFlip .65s cubic-bezier(.4,0,.2,1)}
  @keyframes catFlip{0%{transform:rotateY(0)}50%{transform:rotateY(180deg) scale(1.08)}100%{transform:rotateY(360deg)}}

  /* offended cat */
  .scene-stage.offended .c-eye{stroke:#8B6B5A;stroke-width:4px}
  .scene-stage.offended .c-cheek{opacity:.25}

  /* prestige career titles */
  .prestige-title{
    font-family:var(--disp);font-weight:600;font-size:14px;color:var(--gold);
    letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase;
  }

  /* secret shop item */
  .up.secret{background:linear-gradient(145deg,#E8F4E8,#F5FFF5);border-color:#C5E0C9}
  .up.secret .ic{background:linear-gradient(145deg,#D4EDD8,#EFF9F0);border-color:#B8D9BE}

  /* footer note */
  .foot{text-align:center;margin-top:22px;font-size:11.5px;color:var(--ink-faint);font-weight:700;line-height:1.7}
  .foot a{color:var(--accent2);text-decoration:none;font-weight:900}

  /* site footer */
  .site-foot{
    margin-top:0;padding:32px 16px 40px;
    border-top:1px solid var(--panel-line);
    background:linear-gradient(180deg, transparent, rgba(255,253,249,.6));
  }
  .site-foot-inner{max-width:720px;margin:0 auto}
  .foot-brand-line{
    text-align:center;font-size:12px;color:var(--ink-faint);font-weight:700;
    margin-bottom:24px;line-height:1.6;
  }
  .foot-brand-line a{color:var(--accent2);text-decoration:none;font-weight:900}
  .foot-section-title{
    font-family:var(--disp);font-size:1.1rem;font-weight:600;
    color:var(--ink);margin:0 0 14px;text-align:center;
  }
  .foot-contact-grid{
    display:grid;grid-template-columns:repeat(2, 1fr);gap:10px;margin-bottom:28px;
  }
  .foot-contact{
    display:flex;align-items:center;gap:10px;flex-wrap:wrap;
    padding:12px 14px;border-radius:var(--r-sm);
    background:var(--panel);border:1px solid var(--panel-line);
    box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink);
    transition:transform .14s, box-shadow .14s, border-color .14s;
  }
  a.foot-contact:hover{
    transform:translateY(-2px);border-color:var(--gold-soft);
    box-shadow:var(--shadow);
  }
  .foot-contact-ic{
    width:36px;height:36px;border-radius:10px;flex:none;
    display:grid;place-items:center;font-size:18px;
    background:var(--panel2);border:1px solid var(--panel-line);
  }
  .foot-contact-lbl{font-size:13px;font-weight:800;line-height:1.25;flex:1;min-width:0}
  .foot-contact-email{grid-column:1 / -1}
  .foot-email-link{color:var(--accent2);text-decoration:none;font-weight:900;word-break:break-all}
  .foot-email-link:hover{text-decoration:underline}
  .foot-copy-btn{
    flex:none;border:none;border-radius:10px;padding:8px 12px;
    font-family:var(--body);font-size:11px;font-weight:900;cursor:pointer;
    background:linear-gradient(160deg,var(--accent),var(--accent2));color:#fff;
    box-shadow:var(--shadow-sm);transition:transform .12s;
  }
  .foot-copy-btn:hover{transform:scale(1.04)}
  .foot-copy-btn:active{transform:scale(.97)}
  .foot-disclaimer{
    font-size:12.5px;line-height:1.65;color:var(--ink-soft);font-weight:600;
    margin:0 0 16px;text-align:center;
  }
  .foot-disclaimer a{color:var(--accent2);font-weight:800;text-decoration:none}
  .foot-disclaimer a:hover{text-decoration:underline}
  .foot-policy-links{
    text-align:center;font-size:12px;font-weight:800;margin:0;line-height:1.8;
  }
  .foot-policy-links a{color:var(--accent2);text-decoration:none}
  .foot-policy-links a:hover{text-decoration:underline}
  .foot-sep{color:var(--ink-faint);margin:0 6px}
  .visually-hidden{
    position:absolute;width:1px;height:1px;padding:0;margin:-1px;
    overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
  }
  @media(max-width:480px){
    .foot-contact-grid{grid-template-columns:1fr}
    .foot-contact-email{grid-column:auto}
  }

  /* ---------- responsive ---------- */
  @media(max-width:940px){
    .grid{grid-template-columns:1fr;gap:14px}
    .stage-center{order:-1}
    .shop-list{max-height:none}
    .bignum{font-size:54px}
    .cat-svg{width:180px;height:180px}
    .cat-img{width:180px;height:180px}
    .cat-clic{width:200px;height:210px}
  }
@media(max-width:420px){
  .wrap{padding:12px 11px 30px}
  .brand h1{font-size:17px}
  .brand-tagline{font-size:10.5px}
    .bignum{font-size:46px}
    .hud{padding:15px}
    .feed-btn{font-size:18px;padding:16px}
    .stat-grid{gap:7px}
    .ach-grid{grid-template-columns:1fr 1fr}
  }
  @media(prefers-reduced-motion:reduce){
    *{animation-duration:.001ms !important;transition-duration:.08s !important}
  }
