/* =========================================================
   GOOD COCKTAILS, GREAT COCKTAILS — kawaii pastel, soigné
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Quicksand:wght@500;600;700&display=swap');

:root{
  --walls:#ffe3ec; --floor:#f0d9b5; --accent:#ff7aa2;
  --cream:#fff7f0; --ink:#7a5c66; --ink-soft:#a98a93;
  --shadow:0 10px 26px rgba(214,138,160,.28);
  --soft:0 4px 12px rgba(214,138,160,.2);
  font-family:'Quicksand',system-ui,sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;height:100%;}
body{
  background:linear-gradient(160deg,var(--walls),#e6daf7 130%);
  color:var(--ink);overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:manipulation;
  padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}
h1,h2,.result-tier,.title-card span{font-family:'Baloo 2',cursive;}
#app{height:100vh;height:100dvh;overflow:hidden;}
.screen{height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative;}

/* ---------- boutons ---------- */
.btn{border:none;border-radius:999px;padding:14px 26px;font-size:1rem;font-weight:700;background:#fff;color:var(--ink);
  box-shadow:var(--shadow);cursor:pointer;transition:transform .12s;font-family:inherit;}
.btn:active{transform:scale(.94);}
.btn-primary{background:var(--accent);color:#fff;}
.btn-ghost{background:transparent;box-shadow:none;color:var(--ink-soft);}
.btn-mini{padding:8px 16px;font-size:.85rem;}
.btn.disabled{opacity:.45;pointer-events:none;}

/* ---------- TITRE (sans carte centrée) ---------- */
.title-screen{justify-content:flex-end;align-items:flex-start;}
.title-scene{position:absolute;inset:0;z-index:0;}
.title-scene .scene-svg{width:100%;height:100%;}
.title-passerby{position:absolute;right:-30px;bottom:34%;z-index:1;opacity:.85;filter:blur(.6px) drop-shadow(0 6px 12px rgba(122,90,102,.2));animation:strollBy 11s ease-in-out infinite;}
.title-passerby .char-svg{height:280px;width:auto;}
@keyframes strollBy{0%{transform:translateX(40px) scaleX(-1);opacity:0;}12%,80%{opacity:.85;}50%{transform:translateX(-12px) scaleX(-1);}100%{transform:translateX(40px) scaleX(-1);opacity:0;}}
.neon-sign{position:absolute;top:6%;left:0;right:0;z-index:3;text-align:center;}
.neon-sign h1{display:inline-flex;flex-direction:column;margin:0;font-size:2.5rem;line-height:.96;color:#fff;
  text-shadow:0 0 6px #ff9bd0,0 0 16px #ff7aa2,0 0 30px #ff7aa2;transform:rotate(-2deg);}
.neon-sign h1 span{font-size:1.5rem;color:#fff;text-shadow:0 0 6px #c9a3ff,0 0 16px #a98bdd;}
.neon-sub{display:inline-block;margin-top:10px;color:#fff;font-style:normal;font-weight:700;font-size:.82rem;letter-spacing:.08em;
  background:rgba(122,90,102,.35);padding:4px 14px;border-radius:999px;text-shadow:0 1px 2px rgba(0,0,0,.2);}
.title-ribbon{position:absolute;top:8px;right:10px;z-index:4;display:flex;gap:8px;flex-wrap:wrap;}
.title-ribbon span{background:rgba(255,255,255,.9);padding:5px 12px;border-radius:999px;font-weight:700;font-size:.82rem;box-shadow:var(--soft);}
.title-tags{position:relative;z-index:4;display:flex;flex-direction:column;gap:14px;align-items:flex-start;padding:0 0 8vh 7vw;}
.tag{border:none;cursor:pointer;font-family:'Baloo 2',cursive;font-weight:700;font-size:1.05rem;color:var(--ink);
  background:#fff;padding:14px 30px 14px 22px;border-radius:8px 22px 22px 8px;box-shadow:var(--shadow);
  border-left:7px solid var(--accent);transition:transform .14s ease, filter .14s;}
.tag:nth-child(1){transform:rotate(-2.5deg);} .tag:nth-child(2){transform:rotate(1.5deg) translateX(18px);}
.tag:nth-child(3){transform:rotate(-1.5deg) translateX(6px);} .tag:nth-child(4){transform:rotate(2deg) translateX(24px);}
.tag:hover{filter:brightness(1.03);} .tag:active{transform:scale(.95);}
.tag-primary{background:var(--accent);color:#fff;border-left-color:#fff;font-size:1.2rem;padding-right:38px;}

/* ---------- HUD ---------- */
.hud{position:relative;z-index:6;display:flex;align-items:center;gap:8px;padding:12px 14px;}
.hud-pill{background:rgba(255,255,255,.9);border-radius:999px;padding:6px 13px;font-weight:700;box-shadow:var(--soft);font-size:.9rem;}
.hud-back,.hud-mini{background:rgba(255,255,255,.9);border:none;border-radius:999px;width:38px;height:38px;font-size:1.1rem;font-weight:800;
  color:var(--ink);box-shadow:var(--soft);cursor:pointer;}
.hud-back{margin-right:auto;}
.hud-mini{margin-left:auto;}

/* ---------- SCÈNE ---------- */
.bar-screen{background:linear-gradient(180deg,var(--walls),var(--floor));}
.scene-bg{position:absolute;top:0;left:0;right:0;height:60%;z-index:0;overflow:hidden;}
.scene-bg .scene-svg{width:100%;height:100%;display:block;}
/* SALLE VIVANTE : client(e)s assis(es) en parallèle, sélectionnables */
.lounge-layer{position:absolute;top:0;left:0;right:0;height:62%;z-index:5;pointer-events:none;}
.lounge-seat{position:absolute;display:flex;flex-direction:column;align-items:center;}
.lounge-seat .char-svg{height:116px;width:auto;filter:drop-shadow(0 6px 8px rgba(122,90,102,.18));}
.lounge-seat.seatable{pointer-events:auto;cursor:pointer;border:none;background:none;padding:0;transition:transform .12s;}
.lounge-seat.seatable:active{transform:scale(.95);}
.lounge-seat.seat-l{left:2%;bottom:5%;}
.lounge-seat.seat-r{right:1%;bottom:5%;}
.lounge-seat.seat-back{right:19%;top:23%;}
.lounge-seat.seat-back .char-svg{height:88px;}
.lounge-seat.seat-back .seat-ticket{font-size:.56rem;max-width:88px;}
.lounge-seat.walk-in{animation:walkIn .5s cubic-bezier(.2,.9,.3,1.2);}
@keyframes walkIn{0%{opacity:0;transform:translateY(18px) scale(.88);}100%{opacity:1;transform:none;}}
/* file d'attente à la porte */
.door-queue{position:absolute;top:13%;left:1.5%;z-index:3;display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;}
.dq-heads{display:flex;}
.dq-head{width:26px;margin-left:-9px;opacity:.82;filter:saturate(.7);}
.dq-head:first-child{margin-left:0;}
.dq-head .char-svg{height:50px;width:auto;}
.dq-pill{background:rgba(255,255,255,.92);border-radius:999px;padding:2px 9px;font-family:'Baloo 2',cursive;font-weight:800;font-size:.62rem;color:var(--ink);box-shadow:var(--soft);}
.seat-ticket{margin-top:-4px;background:#fff;border-radius:10px;padding:2px 9px;font-family:'Baloo 2',cursive;
  font-weight:800;font-size:.64rem;color:var(--ink);box-shadow:var(--soft);white-space:nowrap;max-width:104px;
  overflow:hidden;text-overflow:ellipsis;border-bottom:2px solid var(--accent);}
.lounge-seat.done .seat-ticket{border-bottom-color:#7bc47f;color:#3a8a4a;}
.lounge-seat.done{animation:seatReady 1.4s ease-in-out infinite;}
@keyframes seatReady{0%,100%{filter:drop-shadow(0 0 0 rgba(123,196,127,0));}50%{filter:drop-shadow(0 0 8px rgba(123,196,127,.6));}}
/* meubles posés (salle configurable) rendus dans le bar */
.decor-layer{position:absolute;top:0;left:0;right:0;height:60%;z-index:1;pointer-events:none;}
.decor-item{position:absolute;transform:translate(-50%,-50%);}
.decor-item svg{height:84px;width:auto;filter:drop-shadow(0 5px 7px rgba(122,90,102,.2));}
/* écran « Ma salle » : placement des meubles */
.decorate-screen{overflow-y:auto;padding:0 14px 20px;background:linear-gradient(180deg,var(--walls),#efe6ff 140%);}
.dec-room{position:relative;width:100%;aspect-ratio:16/10;border-radius:18px;overflow:hidden;box-shadow:var(--soft);margin-bottom:6px;background:var(--walls);}
.dec-room .scene-bg{position:absolute;inset:0;height:100%;}
.dec-items{position:absolute;inset:0;}
.dec-piece{position:absolute;transform:translate(-50%,-50%);cursor:grab;touch-action:none;}
.dec-piece svg{height:76px;width:auto;filter:drop-shadow(0 4px 6px rgba(122,90,102,.22));pointer-events:none;}
.dec-piece.dragging{z-index:5;filter:brightness(1.06) drop-shadow(0 8px 12px rgba(122,90,102,.3));}
.dec-del{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;border:none;background:#fff;color:var(--accent);font-weight:800;font-size:.7rem;box-shadow:var(--soft);cursor:pointer;}
.dec-tray{display:flex;gap:8px;overflow-x:auto;padding:6px 2px 2px;-webkit-overflow-scrolling:touch;}
.dec-tray-item{flex:0 0 auto;border:none;background:#fff;border-radius:14px;padding:6px 8px;display:flex;flex-direction:column;align-items:center;gap:2px;box-shadow:var(--soft);cursor:pointer;min-width:66px;font-family:inherit;transition:transform .1s;}
.dec-tray-item:active{transform:scale(.93);}
.dec-tray-item small{font-size:.6rem;font-weight:700;color:var(--ink-soft);max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.dt-ico{height:40px;display:grid;place-items:center;}
.dt-ico svg{height:38px;width:auto;}
.dec-empty{padding:22px;text-align:center;color:var(--ink-soft);font-weight:600;line-height:1.5;}
/* ambiance qui bouge : lumière + poussières + vapeur */
.ambiance-layer{position:absolute;inset:0;z-index:1;pointer-events:none;}
.ambiance-layer > svg{position:absolute;inset:0;width:100%;height:100%;}
.motes-wrap{position:absolute;top:0;left:0;width:100%;height:60%;}
.motes-wrap svg{width:100%;height:100%;}
.mote{animation:moteFloat 5s ease-in-out infinite;animation-delay:var(--d,0s);transform-box:fill-box;transform-origin:center;}
@keyframes moteFloat{0%,100%{opacity:.18;transform:translateY(0);}50%{opacity:.7;transform:translateY(-7px);}}
.steam{animation:steamRise 3.2s ease-in-out infinite;transform-box:fill-box;}
@keyframes steamRise{0%{opacity:0;transform:translateY(5px) scaleY(.8);}40%{opacity:.65;}100%{opacity:0;transform:translateY(-12px) scaleY(1.1);}}
/* presse-agrumes animé */
.juice-anim{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:6;pointer-events:none;}
.juice-anim .juicer-svg{height:58%;width:auto;animation:juiceA .62s ease;}
@keyframes juiceA{0%{opacity:0;transform:scale(.7) rotate(-8deg);}40%{opacity:1;transform:scale(1) rotate(0);}100%{opacity:0;transform:scale(1.06);}}
/* verre porté à la table */
.flying-drink{position:fixed;z-index:9000;transform:translate(-50%,-50%);pointer-events:none;
  transition:left .62s cubic-bezier(.45,0,.3,1),top .62s cubic-bezier(.3,-.3,.4,1),transform .62s ease;}
.flying-drink svg,.flying-drink .drink-svg{height:96px;width:auto;display:block;filter:drop-shadow(0 8px 10px rgba(122,90,102,.3));}
.flying-drink.go{transform:translate(-50%,-50%) scale(.66) rotate(-6deg);}
.scene-svg .fairy{animation:twinkle 2.4s ease-in-out infinite;animation-delay:var(--d);}
@keyframes twinkle{0%,100%{opacity:.45;}50%{opacity:1;filter:drop-shadow(0 0 5px #ffe7a8);}}

/* ---------- ZONE DE JEU ---------- */
.stage-area{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;min-height:0;padding-bottom:4px;}
.customer-slot{position:relative;display:flex;flex-direction:column;align-items:center;width:100%;}
.character{position:relative;display:flex;flex-direction:column;align-items:center;}
.character .char-svg{height:188px;width:auto;display:block;filter:drop-shadow(0 8px 12px rgba(122,90,102,.22));overflow:visible;}
.char-breathe{transform-box:fill-box;transform-origin:50% 90%;animation:breathe 4.5s ease-in-out infinite;}
@keyframes breathe{0%,100%{transform:scale(1) translateY(0);}50%{transform:scale(1.018) translateY(-2px);}}
.character.enter{animation:charEnter .6s cubic-bezier(.2,.9,.25,1.25);}
.character.leave{animation:charLeave .36s ease forwards;}
@keyframes charEnter{0%{transform:translateX(90px) rotate(4deg) scale(.92);opacity:0;}60%{transform:translateX(-8px) rotate(-1deg);}100%{transform:none;opacity:1;}}
@keyframes charLeave{100%{transform:translateX(-100px) rotate(-4deg) scale(.9);opacity:0;}}
.char-eyes{transform-box:fill-box;transform-origin:center;animation:blink 4.6s infinite;}
@keyframes blink{0%,92%,100%{transform:scaleY(1);}95%{transform:scaleY(.1);}}
/* plaque nom — détachée, sous le perso */
.name-tag{display:flex;flex-direction:column;align-items:center;background:#fff;border-radius:16px;
  padding:4px 16px;margin-top:8px;box-shadow:var(--soft);border-bottom:3px solid var(--accent);}
.name-tag b{font-size:.96rem;}
.name-tag .hearts{color:var(--accent);font-size:.74rem;font-style:normal;letter-spacing:1px;}
.name-tag span{font-size:.68rem;color:var(--ink-soft);}

/* bulle manga avec pointe vers le perso */
.speech{position:relative;background:#fff;border-radius:22px;padding:12px 18px;max-width:min(420px,80vw);
  box-shadow:var(--shadow);font-weight:600;text-align:center;margin-bottom:16px;opacity:0;transform:translateY(8px) scale(.9);border:2.5px solid #ffe1ec;}
.speech::after{content:"";position:absolute;left:50%;bottom:-15px;transform:translateX(-50%);
  border:9px solid transparent;border-top-color:#fff;filter:drop-shadow(0 3px 2px rgba(214,138,160,.18));}
.speech::before{content:"";position:absolute;left:50%;bottom:-19px;transform:translateX(-50%);border:11px solid transparent;border-top-color:#ffe1ec;}
.speech.show{animation:pop .34s cubic-bezier(.2,.9,.3,1.5) forwards;}
.speech .hint{margin-top:7px;font-size:.82rem;color:var(--accent);background:#f3ecff;border-radius:10px;padding:4px 10px;display:inline-block;}
.liquid-top{animation:slosh 3.2s ease-in-out infinite;transform-box:fill-box;transform-origin:center;}
@keyframes slosh{0%,100%{transform:translateX(-1px) scaleY(1);}50%{transform:translateX(1px) scaleY(1.08);}}

/* ---------- VERRE ---------- */
.glass-zone{position:relative;z-index:3;height:clamp(150px,19vh,205px);margin-top:-4px;display:flex;align-items:flex-end;justify-content:center;}
.glass-zone.drop-hot::after{content:"";position:absolute;inset:-6px;border:3px dashed var(--accent);border-radius:24px;opacity:.7;}
.drink-svg,.ghost-glass{height:100%;width:auto;overflow:visible;filter:drop-shadow(0 6px 8px rgba(122,90,102,.2));}
.empty-stage{display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;gap:2px;}
.empty-stage .ghost-glass{opacity:.7;height:130px;}
.empty-hint{font-weight:700;color:var(--ink-soft);background:rgba(255,255,255,.78);padding:5px 14px;border-radius:14px;font-size:.82rem;box-shadow:var(--soft);}
.glass-zone.do-plop .drink-svg{animation:plop .4s cubic-bezier(.2,.9,.3,1.4);}
@keyframes plop{0%{transform:translateY(-30px) scale(.8);opacity:.4;}60%{transform:translateY(0) scale(1.05);}100%{transform:none;}}
.drink-svg.do-shake{animation:shakeAnim .55s ease;}
.glass-zone.do-shake{animation:shakeBig .6s ease;}
.shaker-anim{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:6;pointer-events:none;}
.shaker-anim .shaker-svg{height:86%;width:auto;filter:drop-shadow(0 6px 10px rgba(122,90,102,.28));animation:shakerShake .7s ease;transform-origin:center bottom;}
@keyframes shakerShake{0%,100%{transform:translateY(0) rotate(0);}12%{transform:translate(-9px,-8px) rotate(-13deg);}30%{transform:translate(10px,-5px) rotate(13deg);}48%{transform:translate(-8px,-4px) rotate(-10deg);}66%{transform:translate(7px,-3px) rotate(8deg);}84%{transform:translate(-4px,-1px) rotate(-4deg);}}
@keyframes shakeBig{0%,100%{transform:translateX(0) rotate(0);}12%{transform:translateX(-12px) rotate(-7deg);}28%{transform:translateX(12px) rotate(7deg);}44%{transform:translateX(-10px) rotate(-5deg);}60%{transform:translateX(9px) rotate(5deg);}78%{transform:translateX(-5px) rotate(-2deg);}}
@keyframes shakeAnim{0%,100%{transform:none;}15%{transform:translate(-6px,-3px) rotate(-6deg);}35%{transform:translate(6px,-2px) rotate(6deg);}55%{transform:translate(-5px,-2px) rotate(-4deg);}75%{transform:translate(4px,-1px) rotate(3deg);}}
.liquid-layer{opacity:.95;}
.ice-cube{animation:fadeIn .35s ease backwards;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.pour-stream{position:absolute;top:-2px;left:50%;transform:translateX(-50%);width:9px;height:55%;border-radius:6px;opacity:0;transition:opacity .12s;}
.pour-stream.on{opacity:.85;animation:pourwig .25s ease-in-out infinite alternate;}
@keyframes pourwig{from{transform:translateX(-52%);}to{transform:translateX(-48%);}}

/* ---------- ÉTABLI ---------- */
.workshop{position:relative;z-index:6;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border-radius:28px 28px 0 0;box-shadow:0 -6px 22px rgba(214,138,160,.22);
  max-height:0;padding:0 12px;overflow:hidden;transition:max-height .4s ease,padding .4s ease;}
.bar-screen.station-open .workshop{max-height:46vh;padding:8px 12px calc(10px + env(safe-area-inset-bottom));overflow-y:auto;}
/* bouton « Préparer au bar » (visible quand la station est repliée) */
.bar-open-btn{position:fixed;left:50%;bottom:calc(92px + env(safe-area-inset-bottom));transform:translateX(-50%);
  z-index:8;border:none;background:var(--accent);color:#fff;font-family:'Baloo 2',cursive;font-weight:800;font-size:1.05rem;
  padding:14px 30px;border-radius:999px;box-shadow:var(--shadow);cursor:pointer;display:none;animation:pop .3s ease;}
.bar-screen:not(.station-open) .bar-open-btn{display:block;}
.ws-head{display:flex;align-items:center;justify-content:space-between;margin:0 2px 6px;}
.ws-title{font-family:'Baloo 2',cursive;font-weight:800;color:var(--accent);font-size:.92rem;}
.ws-close{border:none;background:#f3eef1;color:var(--ink);border-radius:50%;width:28px;height:28px;font-weight:800;cursor:pointer;box-shadow:var(--soft);}
.glass-zone.zoomed{transform:scale(1.18);}
/* feedback de prépa : +1 qui monte, garniture qui tombe, badge "à servir" */
.dose-plus{position:fixed;z-index:9000;font-family:'Baloo 2',cursive;font-weight:800;font-size:1.15rem;
  transform:translate(-50%,-50%);pointer-events:none;text-shadow:0 1px 3px #fff,0 0 6px #fff;animation:dosePlus .72s ease forwards;}
@keyframes dosePlus{0%{opacity:0;transform:translate(-50%,-50%) scale(.5);}25%{opacity:1;}100%{opacity:0;transform:translate(-50%,-180%) scale(1.15);}}
.garnish-drop{position:fixed;z-index:9000;transform:translate(-50%,-50%);pointer-events:none;animation:garnishDrop .56s cubic-bezier(.5,0,.7,1.5) forwards;}
.garnish-drop svg{width:38px;height:38px;display:block;}
@keyframes garnishDrop{0%{opacity:0;transform:translate(-50%,-150%) rotate(-22deg);}35%{opacity:1;}100%{opacity:1;transform:translate(-50%,10%) rotate(12deg);}}
.active-badge{position:absolute;top:-2px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;
  font-family:'Baloo 2',cursive;font-weight:800;font-size:.6rem;padding:2px 10px;border-radius:999px;box-shadow:var(--soft);z-index:4;white-space:nowrap;}
.glass-zone{transition:transform .3s ease;}
.drink-svg.pop-z{animation:popZ .32s ease;}
@keyframes popZ{0%{transform:scale(1);}45%{transform:scale(1.14);}100%{transform:scale(1);}}
.shelf{margin-bottom:6px;}
/* station compacte : Servir toujours collé en bas */
.workshop .actions{position:sticky;bottom:0;z-index:3;margin:2px 0 0;padding-top:8px;
  background:linear-gradient(rgba(255,255,255,0),rgba(255,255,255,.95) 40%);}
.bar-posts{margin-bottom:6px;}
.shelf-label{margin:2px 4px 4px;}
.shelf-label{font-size:.68rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);margin:2px 4px 5px;}
.shelf-items{display:flex;gap:8px;overflow-x:auto;padding-bottom:3px;-webkit-overflow-scrolling:touch;}
.chip{flex:0 0 auto;border:none;background:#fff;border-radius:16px;padding:6px 8px;display:flex;flex-direction:column;align-items:center;gap:1px;
  box-shadow:var(--soft);cursor:pointer;font-family:inherit;transition:transform .1s;position:relative;}
.chip:active{transform:scale(.9);}
.chip small{font-size:.6rem;font-weight:700;color:var(--ink-soft);}
.chip svg{width:34px;height:40px;display:block;}
.chip .glass-mini{width:30px;height:42px;}
.bottle-ico{width:30px;height:42px;}
.garnish-chip svg{width:34px;height:34px;}
.pour-chip.alco{background:linear-gradient(180deg,#fffdf6,#fff6e0);}
.badge18{position:absolute;top:2px;right:2px;background:var(--accent);color:#fff;font-size:.5rem;font-weight:800;
  padding:1px 4px;border-radius:6px;font-style:normal;}
.toggle.on{background:var(--accent);color:#fff;}
.chip.toggle{padding:10px 16px;font-weight:700;}

.actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:6px;}
.act{flex:1 1 auto;border:none;border-radius:15px;padding:13px 8px;font-weight:800;font-size:.88rem;background:#fff;color:var(--ink);
  box-shadow:var(--soft);cursor:pointer;font-family:inherit;transition:transform .1s;}
.act:active{transform:scale(.93);}
.act-serve{flex:1 1 100%;background:var(--accent);color:#fff;font-size:1.05rem;padding:15px;}
.act-ice{background:#eaf4ff;}.act-shake{background:#f1ecff;}.act-stir{background:#fff0e2;}.act-trash{background:#f5eef1;}

/* ---------- drag ghost ---------- */
.drag-ghost{position:fixed;width:50px;height:50px;margin:-25px;pointer-events:none;z-index:9998;
  filter:drop-shadow(0 4px 6px rgba(0,0,0,.2));transform:scale(1.2);}
.drag-ghost svg{width:100%;height:100%;}

/* ---------- OVERLAYS / RÉSULTAT ---------- */
.overlay{position:fixed;inset:0;background:rgba(122,90,102,.34);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:50;padding:20px;}
.result-card{background:#fff;border-radius:28px;padding:24px 26px;text-align:center;box-shadow:var(--shadow);max-width:420px;width:100%;border:5px solid var(--tier,#ffd1dc);}
.result-tier{font-size:1.7rem;font-weight:800;color:var(--tier,var(--accent));}
.result-stars{font-size:1.4rem;color:#ffce4a;margin:4px 0;}
.result-stars .dim{color:#e7ddd2;}
.result-bubble{background:var(--cream);border-radius:16px;padding:12px;font-weight:600;margin:12px 0;}
.result-pay{display:flex;gap:16px;justify-content:center;font-weight:700;margin-bottom:16px;flex-wrap:wrap;}
.result-pay b{color:var(--accent);}
.dayend-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-weight:700;margin:14px 0;}
.dayend-stats div{background:var(--cream);border-radius:12px;padding:8px;}
.dayend-tip{font-size:.85rem;color:var(--ink-soft);}
.result-card .btn{margin-top:6px;width:100%;}

/* ---------- PAGES (boutique / perso / réglages) ---------- */
.page-screen{overflow-y:auto;padding:0 16px 30px;background:linear-gradient(180deg,var(--walls),#efe6ff 140%);}
.page-head{display:flex;align-items:center;gap:12px;padding:14px 0;position:sticky;top:0;background:linear-gradient(180deg,var(--walls),transparent);z-index:3;}
.page-head h2{margin:0;flex:1;color:var(--accent);}
.page-sub{color:var(--ink-soft);font-weight:600;margin:0 0 14px;font-size:.88rem;}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:12px;}
.shop-item{background:#fff;border-radius:20px;padding:12px;text-align:center;box-shadow:var(--soft);display:flex;flex-direction:column;align-items:center;gap:5px;}
.shop-item.owned{opacity:.65;}
.shop-ico{width:52px;height:52px;display:grid;place-items:center;}
.shop-ico svg{width:46px;height:50px;}
.shop-name{font-weight:800;font-size:.88rem;}
.shop-meta{font-size:.78rem;color:var(--ink-soft);font-weight:700;}

.bar-preview{border-radius:22px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:16px;aspect-ratio:16/9;}
.bar-preview .scene-svg{width:100%;height:100%;}
.custom-sec{margin-bottom:16px;}
.swatch-row{display:flex;gap:10px;flex-wrap:wrap;}
.swatch{width:84px;height:58px;border-radius:14px;border:4px solid #fff;box-shadow:var(--soft);cursor:pointer;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;}
.swatch small{background:rgba(255,255,255,.85);border-radius:8px;padding:1px 6px;font-size:.62rem;font-weight:800;color:var(--ink);}
.swatch.active{border-color:var(--accent);transform:scale(1.05);}

.settings-list{display:flex;flex-direction:column;gap:14px;}
.set-row{display:flex;align-items:center;gap:12px;background:#fff;border-radius:18px;padding:14px 16px;box-shadow:var(--soft);}
.set-row div{flex:1;display:flex;flex-direction:column;}
.set-row small{color:var(--ink-soft);font-size:.78rem;}
.switch{width:54px;height:30px;border-radius:999px;border:none;background:#e2d6da;position:relative;cursor:pointer;transition:background .2s;flex:0 0 auto;}
.switch i{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;box-shadow:0 2px 4px rgba(0,0,0,.2);transition:left .2s;}
.switch.on{background:var(--accent);}
.switch.on i{left:27px;}

/* ---------- toast ---------- */
.toast{position:fixed;bottom:48vh;left:50%;transform:translateX(-50%) translateY(10px);background:rgba(122,90,102,.92);color:#fff;
  padding:10px 18px;border-radius:999px;font-weight:700;z-index:9997;opacity:0;transition:opacity .25s,transform .25s;font-size:.9rem;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ---------- particules ---------- */
.fx-layer{position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden;}
.fx{position:absolute;width:26px;height:26px;margin:-13px;animation:fxfly var(--dur) ease-out forwards;will-change:transform,opacity;}
.fx svg{width:100%;height:100%;}
.fx-spark{width:20px;height:20px;}
.fx-coin{width:26px;height:26px;animation:fxfall var(--dur) ease-in forwards;}
.fx-conf{width:12px;height:16px;animation:fxfall var(--dur) ease-in forwards;}
.fx-bub .bub{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.8);box-shadow:0 0 4px rgba(255,255,255,.6);}
@keyframes fxfly{from{transform:translate(0,0) rotate(0);opacity:1;}to{transform:translate(var(--dx),var(--dy)) rotate(var(--rot));opacity:0;}}
@keyframes fxfall{from{transform:translate(0,0) rotate(0);opacity:1;}to{transform:translate(var(--dx),var(--dy)) rotate(var(--rot));opacity:0;}}

/* ---------- anim générique ---------- */
@keyframes pop{0%{transform:scale(.7);opacity:0;}70%{transform:scale(1.06);}100%{transform:scale(1);opacity:1;}}
.pop{animation:pop .32s ease;}
::-webkit-scrollbar{height:6px;width:6px;}
::-webkit-scrollbar-thumb{background:rgba(214,138,160,.4);border-radius:6px;}

/* ===== INTÉGRATION v3 (refonte rendu) ===== */
.hud{display:flex;align-items:center;gap:8px;}
#hudcaps{flex:1;min-width:0;overflow:hidden;display:flex;justify-content:center;}

/* BANDE BULLE — sous le HUD, toujours visible (jamais derrière le HUD) */
/* bulle ancrée EN HAUT (ne couvre plus le perso) */
.bubble-band{position:absolute;top:52px;left:50%;transform:translateX(-50%);z-index:8;
  width:max-content;max-width:92vw;padding:0;pointer-events:none;}
.bubble-band > *{pointer-events:auto;}
.bubble-band .dlg-bubble{max-width:min(440px,86vw);margin:0;}
.bubble-band .dlg-bubble__text{font-size:clamp(.9rem,2.7vw,1.05rem);line-height:1.35;}

/* zone scène : cliente posée plus bas (derrière le comptoir), bien sous la bulle */
.stage-area{padding-top:2px;}
.bubble-band{margin-bottom:10px;}
.customer-slot{overflow:visible;flex:1 1 auto;justify-content:flex-end;min-height:0;padding-bottom:2px;}
.character .char-svg{height:clamp(108px,19vh,176px);width:auto;overflow:visible;}

/* écrans courts (paysage / petites fenêtres) : tout se compacte pour que
   le PERSONNAGE + la BULLE restent entièrement visibles, jamais rognés */
@media (max-height:980px){
  .bar-screen.station-open .workshop{max-height:35vh;}
  .character .char-svg{height:clamp(150px,24vh,210px);}
  .glass-zone{height:clamp(96px,12vh,128px);}
  .bubble-band{margin-bottom:4px;}
  .bubble-band .dlg-bubble__text{font-size:clamp(.82rem,2.2vw,.98rem);}
}
@media (max-height:760px){
  .bar-screen.station-open .workshop{max-height:32vh;}
  .character .char-svg{height:clamp(128px,21vh,180px);}
  .glass-zone{height:clamp(82px,10vh,108px);}
  .order-bar{padding:4px 8px;}
  .order-bar .ob-head{margin-bottom:2px;}
  .bubble-band{margin-bottom:2px;}
  .bubble-band .dlg-bubble__text{font-size:clamp(.76rem,2vw,.9rem);}
  .bubble-band .dlg-bubble{padding:8px 14px;}
}
/* la plaque-nom ne chevauche jamais le corps */
.name-tag{margin-top:2px;position:relative;z-index:4;}
@media (max-width:460px){
  .hud{gap:5px;padding:8px 8px;}
  .hudbar{gap:5px;}
  .hud-cap{padding:4px 8px;font-size:.78rem;}
  .hud-back,.hud-mini{width:34px;height:34px;}
}

/* chips de station */
.chip svg{width:auto;height:auto;}
.glass-chip svg{width:30px;height:48px;}
.pump-chip svg{width:36px;height:54px;}
.tray-chip svg{width:44px;height:36px;}
.act-ico{display:inline-flex;vertical-align:middle;}
.act-ico svg{width:24px;height:24px;margin-right:3px;}
.act-cold{background:#eaf4ff;}

/* étagère bois (pompes) + bacs (toppings) façon Good Coffee */
.shelf-wood{background:linear-gradient(#e6c79c,#d9b58a);border-radius:14px;padding:9px 8px 7px;border-bottom:5px solid #c79c6e;box-shadow:inset 0 2px 0 #f0d6b0;}
.shelf-wood .chip{background:rgba(255,255,255,.9);}
.shelf-trays{background:#efe2d2;border-radius:14px;padding:8px;border-bottom:4px solid #d8c4ac;}
.alco-label{color:#a06fd0;}
/* rail de bouteilles : barre métal + on "attrape" la bouteille en versant */
.shelf-items.rail{position:relative;padding-top:12px;}
.shelf-items.rail::before{content:'';position:absolute;top:5px;left:8px;right:8px;height:6px;border-radius:4px;
  background:linear-gradient(#eef2f7,#aeb6c2);box-shadow:0 2px 3px rgba(122,90,102,.2),inset 0 1px 0 #fff;z-index:0;}
.pump-chip{transition:transform .14s ease;position:relative;z-index:1;}
.pump-chip.grabbed{transform:translateY(-12px) rotate(-7deg) scale(1.06);z-index:3;
  filter:drop-shadow(0 9px 8px rgba(122,90,102,.28));}
.glass-special{background:linear-gradient(#fff,#fff0f6);border:1.5px solid #ffd9ea;}
/* tutoriel one-shot */
.tuto-overlay{position:absolute;inset:0;z-index:50;background:rgba(122,90,102,.4);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px);padding:18px;animation:pop .3s ease;}
.tuto-card{background:#fff;border-radius:24px;padding:22px 24px 20px;max-width:360px;box-shadow:var(--shadow);text-align:center;}
.tuto-card h3{margin:0 0 12px;color:var(--accent);font-family:'Baloo 2',cursive;font-size:1.3rem;}
.tuto-steps{text-align:left;margin:0 0 16px;padding-left:20px;color:var(--ink);font-size:.92rem;line-height:1.5;}
.tuto-steps li{margin-bottom:8px;}
.tuto-steps b{color:var(--accent);}
.glass-special .gs-ico{display:grid;place-items:center;height:42px;}
.glass-special .gs-ico svg{height:40px;width:auto;}
/* postes du bar (gestes réels) */
.bar-posts{margin-bottom:8px;}
.post-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:3px;}
.post{flex:1 1 0;min-width:62px;border:none;background:#fff;border-radius:16px;padding:6px 4px;display:flex;flex-direction:column;align-items:center;gap:2px;box-shadow:var(--soft);cursor:pointer;font-family:inherit;transition:transform .1s;}
.post:active{transform:scale(.92);}
.post small{font-size:.66rem;font-weight:800;color:var(--ink-soft);}
.post-art{width:42px;height:42px;display:grid;place-items:center;}
.post-art svg{width:40px;height:40px;}
.post-sink{background:#eaf4ff;}.post-ice{background:#eef8ff;}.post-shake{background:#f1ecff;}.post-stir{background:#fff0e2;}.post-trash{background:#f5eef1;}
.rinse-anim,.scoop-anim{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:6;pointer-events:none;}
.rinse-anim .rinse-splash{height:62%;width:auto;animation:rinseA .72s ease;}
@keyframes rinseA{0%{opacity:0;transform:translateY(-22px) scale(.7);}30%{opacity:1;transform:translateY(0) scale(1);}100%{opacity:0;transform:scale(1.12);}}
.scoop-anim .scoop-svg{height:56%;width:auto;animation:scoopA .52s ease;}
@keyframes scoopA{0%{opacity:0;transform:translate(-28px,-28px) rotate(-18deg);}40%{opacity:1;transform:translate(0,-6px) rotate(0);}100%{opacity:0;transform:translate(0,12px) rotate(8deg);}}
.sink-water{animation:waterFlow .5s ease-in-out infinite alternate;}
@keyframes waterFlow{from{opacity:.55;}to{opacity:1;}}
/* doseur (jigger) qui verse au-dessus du verre */
.jigger-pour{position:absolute;left:50%;top:-2px;z-index:5;pointer-events:none;opacity:0;transition:opacity .15s;}
.jigger-pour.on{opacity:1;}
.jigger-pour .jigger-svg{height:62px;width:auto;display:block;transform-origin:bottom center;
  filter:drop-shadow(0 4px 6px rgba(122,90,102,.25));animation:jiggerTip .5s ease-in-out infinite alternate;}
@keyframes jiggerTip{from{transform:translateX(-46%) rotate(20deg);}to{transform:translateX(-54%) rotate(34deg);}}
.shelf-alco{background:linear-gradient(#efe0c0,#e3cfa0);border-bottom-color:#c9a86e;}

/* carnet de recettes (overlay) */
.recipes-ov{align-items:stretch;}
.recipes-panel{background:linear-gradient(180deg,#fff6ef,#ffe9f0);border-radius:26px;max-width:700px;width:100%;max-height:88vh;overflow:auto;margin:auto;padding:4px 16px 20px;box-shadow:var(--shadow);}
.recipes-panel .page-head{position:sticky;top:0;background:linear-gradient(#fff6ef,#fff6efe6);z-index:2;}
.recipes-panel .page-head h2{color:var(--accent);}
.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px;}
.recipe-tile{background:#fff;border:3px solid #e7d2bf;border-radius:18px;padding:8px 6px;text-align:center;cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:var(--soft);}
.recipe-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.recipe-tile.locked{filter:grayscale(.65);opacity:.7;cursor:default;}
.rt-art{height:86px;display:flex;align-items:center;justify-content:center;}
.rt-art svg{height:100%;width:auto;}
.rt-lock{font-size:.7rem;color:var(--ink-soft);}
.rt-name{font-weight:800;font-size:.78rem;color:var(--ink);margin-top:4px;}
.recipe-card-wrap{max-width:600px;width:100%;display:flex;flex-direction:column;gap:12px;}
.recipe-card-wrap .btn{align-self:center;}

/* ===== TABLETTE DE COMMANDE — ticket de bar dessiné ===== */
.order-bar{position:relative;z-index:5;flex:0 0 auto;background:#fffdf8;padding:10px 12px 8px;
  box-shadow:0 -3px 10px rgba(214,138,160,.16);
  border-top:3px dashed var(--accent);
  background-image:radial-gradient(circle at 8px -4px, transparent 6px, #fffdf8 6px);}
.order-bar::before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px;
  background:repeating-linear-gradient(135deg,transparent 0 9px,#fffdf8 9px 18px);}
.ob-head{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:6px;}
.ob-title{font-family:'Baloo 2',cursive;font-weight:800;color:var(--accent);font-size:1.05rem;margin-right:auto;
  display:inline-flex;align-items:center;gap:6px;}
.ob-title::before{content:"";width:14px;height:18px;border:2px solid var(--accent);border-radius:3px;
  background:repeating-linear-gradient(#fff 0 3px,#ffe0ec 3px 5px);display:inline-block;flex:0 0 auto;}
.ob-meta{background:#fff;border:2px solid #ecd8c6;border-radius:999px;padding:3px 11px;font-size:.74rem;font-weight:700;color:var(--ink-soft);box-shadow:0 1px 0 #f0e2d2;}
.ob-meta.done{background:#e6f6e6;border-color:#9fd6a0;color:#4e9a4e;}
.ob-replay{border:none;background:var(--accent);color:#fff;border-radius:50%;width:32px;height:32px;cursor:pointer;box-shadow:var(--soft);display:grid;place-items:center;}
.ob-ings{display:flex;gap:8px;overflow-x:auto;padding-bottom:3px;}
.oc{flex:0 0 auto;display:flex;align-items:center;gap:5px;background:#fff;border:2px solid #ecd8c6;border-radius:14px;
  padding:5px 11px;font-size:.78rem;font-weight:700;color:var(--ink);white-space:nowrap;transition:all .15s;box-shadow:0 2px 0 #f3e6d6;}
.oc.done{background:#e9f8e9;border-color:#a9e0a9;color:#4e9a4e;}
.oc .ocdot{width:10px;height:10px;border-radius:50%;display:inline-block;border:1.5px solid rgba(122,92,102,.3);}
.pips{display:inline-flex;gap:3px;}
.pip{width:8px;height:8px;border-radius:50%;background:#e7d8c8;transition:transform .15s,background .15s;}
.pip.on{background:var(--accent);transform:scale(1.18);}
.oc.done .pip.on{background:#4e9a4e;}
.over{color:#e0556e;font-size:.7rem;}

/* ===== RÉGLAGES cosy ===== */
.settings-hero{border-radius:20px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:16px;aspect-ratio:20/7;}
.settings-hero .scene-svg{width:100%;height:100%;}
.set-row{border:2px solid #f0e0d2;}
.settings-list .btn-ghost{margin-top:6px;}

/* ===== BOUTIQUE vitrine ===== */
.shop-vitrine{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px 12px;}
.vitrine-item{position:relative;text-align:center;cursor:pointer;padding-top:6px;}
.vitrine-item .vi-art{display:flex;justify-content:center;align-items:flex-end;height:64px;transition:transform .15s ease;}
.vitrine-item .vi-art svg{height:60px;width:auto;}
.vitrine-item:hover .vi-art{transform:translateY(-5px);}
.vitrine-item .vi-pedestal,.vitrine-item .vi-base{margin-top:-6px;}
.vitrine-item .vi-pedestal svg,.vitrine-item .vi-base svg{height:18px;width:auto;}
.vi-label{font-weight:800;font-size:.78rem;color:var(--ink);margin-top:2px;}
.vi-row{position:relative;margin-bottom:10px;padding:0 4px 14px;}
.vi-shelf{position:absolute;left:0;right:0;bottom:0;height:18px;z-index:0;}
.vi-shelf svg{width:100%;height:100%;}
.vi-tag{margin-top:2px;}
.vi-tag svg{height:34px;width:auto;}
.vitrine-item.locked{filter:grayscale(.6);opacity:.7;cursor:default;}
.shop-vitrine-wrap{display:flex;flex-direction:column;gap:6px;}
.vi-row .shop-vitrine{position:relative;z-index:1;}
.vi-sub{font-size:.66rem;color:var(--ink-soft);font-weight:700;}
.vitrine-item .btn-mini{margin-top:4px;}
.vitrine-item.owned .vi-art{opacity:.8;}

/* ===== BOUTIQUE À ONGLETS ===== */
.shop-cur{display:flex;gap:8px;}
.shop-cur .cur{background:#fff;border-radius:999px;padding:5px 12px;font-weight:800;box-shadow:var(--soft);font-size:.85rem;}
.c-gems{color:#a06fd0;}
.shop-tabs{display:flex;gap:7px;overflow-x:auto;padding:4px 2px 10px;margin-bottom:2px;
  -webkit-overflow-scrolling:touch;}
.shop-tab{flex:0 0 auto;border:none;background:#fff;border-radius:14px;padding:7px 12px;font-weight:700;font-size:.82rem;
  color:var(--ink);box-shadow:var(--soft);cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:5px;transition:transform .1s;}
.shop-tab .st-dot{width:11px;height:11px;border-radius:50%;display:inline-block;border:1.5px solid rgba(122,92,102,.25);}
.hud-heart{color:#ff7aa2;}
/* caisse : bouton « Encaisser » qui n'apparaît QUE quand il y a de l'argent à prendre */
.zone-caisse{position:absolute;left:4%;top:46%;z-index:7;border:none;cursor:pointer;
  background:var(--accent);color:#fff;border-radius:999px;display:none;align-items:center;gap:6px;
  padding:10px 18px;font-family:'Baloo 2',cursive;font-weight:800;font-size:.95rem;box-shadow:var(--shadow);}
.zone-caisse .zc-coin{font-size:1.1rem;color:#ffe9b0;}
.zone-caisse:active{transform:scale(.94);}
.zone-caisse.active{display:inline-flex;animation:caissePulse 1s ease-in-out infinite;}
@keyframes caissePulse{0%,100%{box-shadow:0 6px 18px rgba(255,122,162,.5),0 0 0 0 rgba(255,207,107,.6);}50%{box-shadow:0 6px 18px rgba(255,122,162,.5),0 0 0 10px rgba(255,207,107,0);}}
/* badge note flottant */
.result-flash{position:fixed;transform:translate(-50%,-50%);z-index:9998;background:#fff;border-radius:999px;
  padding:8px 18px;box-shadow:var(--shadow);font-family:'Baloo 2',cursive;font-weight:800;white-space:nowrap;
  display:flex;align-items:center;gap:8px;border:3px solid #ffe1ec;transition:opacity .4s,transform .4s;}
.result-flash .rf-stars{color:#ffce4a;font-size:.95rem;}
.result-flash .rf-dim{color:#e7ddd2;}
.result-flash.out{opacity:0;transform:translate(-50%,-90%);}
/* bouton ✕ pour masquer la bulle */
.bubble-x{position:absolute;top:-8px;right:-8px;z-index:9;width:26px;height:26px;border:none;border-radius:50%;
  background:#fff;color:#b5708a;font-weight:800;font-size:.8rem;cursor:pointer;box-shadow:var(--soft);border:2px solid #ffe1ec;}
.dlg-bubble .rk{font-family:'Baloo 2',cursive;}
.inv-empty{text-align:center;color:var(--ink-soft);font-weight:700;background:#fff;border-radius:20px;padding:36px 20px;box-shadow:var(--soft);line-height:1.6;margin-top:10px;}
.shop-tab.active{background:var(--accent);color:#fff;}
.shop-tab.locked{opacity:.5;cursor:default;}
.shop-tab .st-lock{font-size:.66rem;font-style:normal;opacity:.8;}
.shop-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;}
.cat-card{background:#fff;border-radius:20px;padding:12px 10px 10px;text-align:center;box-shadow:var(--soft);
  display:flex;flex-direction:column;align-items:center;gap:5px;position:relative;}
.cat-ico{width:64px;height:64px;display:grid;place-items:center;background:color-mix(in srgb,var(--c) 30%,white);border-radius:16px;}
.cat-ico svg{width:54px;height:54px;}
.cat-badges{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;}
.cat-rar,.cat-coll{font-size:.6rem;font-weight:800;color:#fff;border-radius:999px;padding:1px 8px;text-shadow:0 1px 1px rgba(0,0,0,.15);}
.cat-coll{color:var(--ink);}
.cat-name{font-weight:800;font-size:.85rem;line-height:1.1;}
.cat-name small{font-weight:700;color:var(--ink-soft);font-size:.72rem;}
.cat-desc{font-size:.7rem;color:var(--ink-soft);font-weight:600;line-height:1.25;min-height:2.2em;}
.cat-foot{margin-top:2px;}
.cat-price{font-weight:800;font-size:.9rem;}
.cat-price.gems{color:#a06fd0;}.cat-price.coins{color:var(--accent);}
.cat-owned{font-weight:800;color:#5a9a5a;font-size:.85rem;}
.cat-card .btn-mini{margin-top:4px;}
