:root{
  --forest:#0a3d2c; --forest-2:#0f5038; --forest-3:#136a48;
  --leaf:#2fe07a; --leaf-dk:#16a85a; --leaf-shadow:#0c7a3f;
  --pink:#ff4d9d; --pink-dk:#c81f6e;
  --cyan:#1fd9e6; --cyan-dk:#0a9aa6;
  --sun:#ffd23f; --sun-dk:#e0a500;
  --cream:#fbfdf4; --ink:#072a1d; --panel:#ffffff; --score-bg:#06291c;
  font-size:16px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{margin:0;padding:0;}
body{
  font-family:'Rubik',system-ui,sans-serif;
  background:radial-gradient(120% 80% at 50% -10%, #15734d 0%, var(--forest-2) 45%, var(--forest) 100%);
  color:var(--ink); min-height:100vh; overflow-x:hidden; position:relative;
}
.bg-deco{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden;}
.bg-deco span{position:absolute;border-radius:50% 0 50% 50%;opacity:.10;transform:rotate(20deg);}
#root{position:relative;z-index:1;}
.app{max-width:560px;margin:0 auto;padding:16px 14px 90px;}
button{font-family:inherit;}

/* ---------- generic ---------- */
.center-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 18px;position:relative;z-index:1;}
.card{background:var(--panel);border-radius:24px;padding:24px 20px;box-shadow:0 14px 40px rgba(0,0,0,.28);width:100%;max-width:420px;}
.brandmark{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:22px;}
.brandmark .logo{
  width:74px;height:74px;border-radius:22px;
  background:linear-gradient(150deg,var(--leaf),var(--leaf-dk));
  box-shadow:0 6px 0 var(--leaf-shadow),0 12px 20px rgba(0,0,0,.32);
  display:grid;place-items:center;transform:rotate(-5deg);overflow:hidden;
}
.brandmark .logo img{width:100%;height:100%;object-fit:cover;display:block;}
.brandmark h1{font-family:'Varela Round',sans-serif;margin:0;color:var(--cream);font-size:1.7rem;text-shadow:0 2px 0 rgba(0,0,0,.25);text-align:center;}
.brandmark p{margin:0;color:#bdf0d2;font-size:.85rem;font-weight:600;}

label.fld{display:block;margin-bottom:12px;}
label.fld .lab{font-size:.8rem;font-weight:800;color:var(--ink);margin-bottom:5px;display:block;}
.input{
  width:100%;font-family:'Rubik';font-weight:600;border:2px solid #e3eee6;border-radius:13px;
  padding:12px 13px;font-size:1rem;color:var(--ink);background:#f5faf6;transition:border-color .15s;
}
.input:focus{outline:none;border-color:var(--leaf);}
.btn{
  width:100%;border:none;border-radius:15px;cursor:pointer;font-weight:800;font-size:1.05rem;
  padding:14px;color:#fff;background:linear-gradient(160deg,#5bf0a0,var(--leaf));
  box-shadow:0 5px 0 var(--leaf-shadow);transition:transform .08s,box-shadow .08s,opacity .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn:active{transform:translateY(5px);box-shadow:0 0 0;}
.btn:disabled{opacity:.55;pointer-events:none;}
.btn.pink{background:linear-gradient(160deg,#ff7aa8,var(--pink));box-shadow:0 5px 0 var(--pink-dk);}
.btn.cyan{background:linear-gradient(160deg,#5be8f0,var(--cyan));box-shadow:0 5px 0 var(--cyan-dk);}
.btn.ghost{background:rgba(255,255,255,.1);box-shadow:none;border:2px solid rgba(255,255,255,.25);color:var(--cream);}
.btn.soft{background:#eef7f0;box-shadow:none;border:1.5px solid #d6eadd;color:var(--leaf-dk);}
.btn.sm{font-size:.9rem;padding:10px 14px;width:auto;}
.linkbtn{background:none;border:none;color:var(--leaf-dk);font-weight:800;cursor:pointer;font-size:.92rem;text-decoration:underline;padding:6px;}
.err{background:#ffe3ee;color:var(--pink-dk);border-radius:12px;padding:10px 12px;font-size:.84rem;font-weight:700;margin-bottom:12px;text-align:center;}
.muted{color:#7c8f84;font-size:.82rem;font-weight:600;}
.divider{display:flex;align-items:center;gap:10px;margin:16px 0;color:#9bb0a4;font-size:.78rem;font-weight:700;}
.divider::before,.divider::after{content:"";flex:1;height:2px;background:#e3eee6;border-radius:2px;}

/* ---------- avatars ---------- */
.ava-img{border-radius:50%;display:grid;place-items:center;overflow:hidden;flex:none;background:#0d4a34;border:2px solid rgba(255,255,255,.85);}
.ava-img img{width:100%;height:100%;object-fit:cover;display:block;}
.ava-img .em{line-height:1;}
.ava-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(58px,1fr));gap:10px;margin:8px 0 4px;max-height:240px;overflow-y:auto;padding:4px;}
.ava-pick{border:3px solid transparent;border-radius:50%;cursor:pointer;padding:0;background:none;transition:transform .12s;}
.ava-pick:active{transform:scale(.9);}
.ava-pick.sel{border-color:var(--sun);transform:scale(1.06);}
.ava-upload{border:2px dashed #cfe4d6;border-radius:50%;width:58px;height:58px;display:grid;place-items:center;cursor:pointer;color:var(--leaf-dk);font-size:1.3rem;background:#f3faf5;}

/* ---------- group hub ---------- */
.hub-groups{display:flex;flex-direction:column;gap:10px;margin-bottom:6px;}
.group-pill{
  display:flex;align-items:center;gap:12px;background:var(--panel);border-radius:16px;padding:12px 14px;
  cursor:pointer;box-shadow:0 5px 14px rgba(0,0,0,.14);border:2px solid transparent;transition:transform .1s;
  text-align:start;width:100%;
}
.group-pill:active{transform:scale(.98);}
.group-pill .gp-info{flex:1;min-width:0;}
.group-pill .gp-name{font-weight:800;color:var(--ink);font-size:1rem;}
.group-pill .gp-sub{font-size:.74rem;color:#7c8f84;font-weight:600;}
.group-pill .gp-arrow{color:var(--leaf-dk);font-size:1.2rem;}

/* ---------- group view header + tabs ---------- */
.gv-top{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.gv-back{width:42px;height:42px;border:none;border-radius:13px;flex:none;cursor:pointer;background:linear-gradient(150deg,var(--leaf),var(--leaf-dk));color:var(--cream);font-size:1.3rem;display:grid;place-items:center;overflow:hidden;padding:0;box-shadow:0 3px 0 var(--leaf-shadow);}
.gv-back img{width:100%;height:100%;object-fit:cover;display:block;}
.gv-title{flex:1;min-width:0;}
.gv-title h2{font-family:'Varela Round';margin:0;color:var(--cream);font-size:1.2rem;line-height:1.1;text-shadow:0 2px 0 rgba(0,0,0,.22);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.gv-title .gv-members{display:flex;gap:-6px;margin-top:4px;}
.gv-icon{width:42px;height:42px;border:none;border-radius:13px;flex:none;cursor:pointer;background:rgba(255,255,255,.12);color:var(--cream);font-size:1.1rem;display:grid;place-items:center;}
.gv-icon.on{background:var(--sun);color:var(--ink);}

.tabbar{
  position:fixed;bottom:0;left:0;right:0;z-index:30;
  display:flex;justify-content:center;gap:6px;padding:8px 10px calc(8px + env(safe-area-inset-bottom));
  background:linear-gradient(0deg,var(--forest) 60%,transparent);
}
.tabbar .inner{display:flex;gap:3px;background:rgba(6,41,28,.92);border:2px solid rgba(47,224,122,.22);border-radius:18px;padding:6px;box-shadow:0 8px 22px rgba(0,0,0,.4);backdrop-filter:blur(6px);}
.tab{border:none;background:none;color:#8fe6b6;font-weight:800;font-size:.72rem;padding:8px 7px;border-radius:13px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;transition:background .15s,color .15s;position:relative;flex:1;}
.tab .ti{font-size:1.2rem;line-height:1;}
.tab.active{background:linear-gradient(160deg,var(--leaf),var(--leaf-dk));color:#fff;}
.tab .badge{position:absolute;top:2px;inset-inline-end:8px;background:var(--pink);color:#fff;font-size:.6rem;font-weight:900;min-width:16px;height:16px;border-radius:9px;display:grid;place-items:center;padding:0 4px;}

/* ---------- info / rights + locator ---------- */
.info-card{display:flex;gap:12px;background:var(--panel);border-radius:16px;padding:13px 15px;box-shadow:0 4px 12px rgba(0,0,0,.1);margin-bottom:10px;}
.info-card .ic-emoji{font-size:1.5rem;flex:none;width:42px;height:42px;display:grid;place-items:center;background:#f0f7f2;border-radius:12px;}
.info-card .ic-body{flex:1;min-width:0;}
.info-card .ic-title{font-weight:800;color:var(--ink);font-size:.96rem;margin-bottom:2px;}
.info-card .ic-text{color:#4a6356;font-size:.84rem;font-weight:600;line-height:1.5;text-wrap:pretty;}
.locator{background:linear-gradient(150deg,#e8f7fb,#eafaf0);border:2px solid #bfe7ef;border-radius:18px;padding:18px;margin-bottom:16px;text-align:center;}
.loc-pts{display:flex;flex-direction:column;gap:8px;margin-top:12px;}
.loc-pt{display:flex;align-items:center;gap:10px;background:#fff;border:2px solid #e3eee6;border-radius:13px;padding:11px 13px;cursor:pointer;font-weight:800;color:var(--ink);font-size:.92rem;text-align:start;transition:transform .1s;text-decoration:none;}
.loc-pt .lp-emoji{font-size:1.3rem;flex:none;}
.loc-pt .lp-arrow{margin-inline-start:auto;color:var(--cyan-dk);font-size:1.1rem;}
.loc-pt:active{transform:scale(.98);}
.info-links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:10px;}
.info-links a{color:var(--leaf);font-weight:800;font-size:.82rem;}

/* avatar stack */
.ava-stack{display:flex;}
.ava-stack .ava-img{margin-inline-start:-8px;border:2px solid var(--forest-2);}
.ava-stack .ava-img:first-child{margin-inline-start:0;}

/* ---------- chat ---------- */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 200px);min-height:340px;}
.chat-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:6px 2px 12px;}
.msg{display:flex;gap:9px;align-items:flex-end;max-width:85%;}
.msg .bubble{background:var(--panel);border-radius:16px 16px 16px 5px;padding:8px 12px;box-shadow:0 3px 10px rgba(0,0,0,.14);}
.msg .who{font-size:.7rem;font-weight:800;color:var(--leaf-dk);margin-bottom:2px;}
.msg .txt{font-size:.95rem;color:var(--ink);font-weight:500;word-break:break-word;}
.msg .time{font-size:.6rem;color:#9bb0a4;margin-top:2px;font-weight:600;direction:ltr;text-align:start;}
.msg.mine{align-self:flex-end;flex-direction:row-reverse;}
.msg.mine .bubble{background:linear-gradient(160deg,#d8fbe8,#c4f5dd);border-radius:16px 16px 5px 16px;}
.msg.mine .who{color:var(--cyan-dk);text-align:end;}
.chat-input{display:flex;gap:8px;align-items:center;padding-top:8px;}
.chat-input .input{border-radius:999px;}
.chat-send{width:48px;height:48px;flex:none;border:none;border-radius:50%;background:linear-gradient(160deg,#5bf0a0,var(--leaf));box-shadow:0 4px 0 var(--leaf-shadow);color:#fff;font-size:1.2rem;cursor:pointer;display:grid;place-items:center;}
.chat-send:active{transform:translateY(4px);box-shadow:0 0 0;}
.chat-empty{text-align:center;color:#8fe6b6;font-weight:700;margin:auto;font-size:.9rem;}

/* members tab */
.member-row{display:flex;align-items:center;gap:12px;background:var(--panel);border-radius:16px;padding:11px 13px;box-shadow:0 4px 12px rgba(0,0,0,.12);}
.member-row .mr-name{font-weight:800;color:var(--ink);flex:1;}
.member-row .mr-you{font-size:.7rem;font-weight:800;color:var(--cyan-dk);background:#e0f7fa;padding:3px 8px;border-radius:999px;}
.invite-box{background:linear-gradient(160deg,rgba(255,210,63,.16),rgba(255,210,63,.06));border:2px solid var(--sun);border-radius:18px;padding:16px;text-align:center;margin-bottom:14px;}
.invite-box .code{font-family:'Varela Round';font-size:2rem;letter-spacing:.18em;color:var(--ink);font-weight:700;direction:ltr;margin:6px 0;}

/* ---------- SCOREBOARD (reused calc) ---------- */
.scoreboard{background:linear-gradient(180deg,#0a3322,var(--score-bg));border:3px solid rgba(47,224,122,.25);border-radius:22px;padding:16px 16px 14px;box-shadow:inset 0 2px 14px rgba(0,0,0,.5),0 10px 24px rgba(0,0,0,.32);position:relative;overflow:hidden;}
.scoreboard::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;background:repeating-linear-gradient(0deg,transparent 0 3px,rgba(0,0,0,.18) 3px 4px);}
.level-strip{display:flex;align-items:center;justify-content:space-between;gap:10px;position:relative;}
.level-badge{display:flex;align-items:center;gap:8px;background:rgba(255,210,63,.14);border:2px solid var(--sun);border-radius:999px;padding:5px 12px 5px 8px;}
.level-badge .star{width:24px;height:24px;flex:none;}
.level-badge b{color:var(--sun);font-size:.74rem;font-weight:800;line-height:1;}
.level-badge span{color:#dff7e6;font-size:.62rem;font-weight:600;display:block;margin-top:1px;}
.cans-count{color:#8fe6b6;font-size:.72rem;font-weight:700;text-align:left;}
.cans-count b{display:block;color:var(--cream);font-size:1.05rem;font-weight:900;}
.score-main{position:relative;text-align:center;margin:14px 0 4px;}
.score-label{color:#7fd8a6;font-size:.78rem;font-weight:700;letter-spacing:.04em;margin-bottom:2px;}
.score-total{font-weight:900;color:var(--sun);line-height:.95;font-size:clamp(3.2rem,17vw,4.6rem);text-shadow:0 0 18px rgba(255,210,63,.55),0 4px 0 #7a5a00,0 5px 1px rgba(0,0,0,.4);letter-spacing:-.01em;direction:ltr;}
.score-total .sh{font-size:.5em;vertical-align:.18em;margin-inline-end:.04em;}
.breakdown{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:stretch;margin-top:12px;position:relative;}
.bd{background:rgba(255,255,255,.06);border-radius:14px;padding:9px 8px;text-align:center;border:1.5px solid rgba(255,255,255,.08);}
.bd .t{font-size:.66rem;font-weight:700;margin-bottom:3px;display:flex;align-items:center;justify-content:center;gap:4px;}
.bd .v{font-size:1.18rem;font-weight:900;direction:ltr;line-height:1;}
.bd.bottles .t{color:#9fe9c1;} .bd.bottles .v{color:var(--cream);}
.bd.babi{background:linear-gradient(160deg,rgba(255,77,157,.22),rgba(255,77,157,.08));border-color:rgba(255,77,157,.4);}
.bd.babi .t{color:#ffb4d6;} .bd.babi .v{color:#ff8fc2;}
.bd-x{display:grid;place-items:center;color:var(--cyan);font-weight:900;font-size:1.1rem;}

/* personal tally — always-visible "what I collected" */
.my-tally{display:flex;align-items:center;gap:12px;margin-top:12px;background:linear-gradient(160deg,rgba(47,224,122,.2),rgba(47,224,122,.05));border:1.6px solid rgba(47,224,122,.36);border-radius:16px;padding:11px 14px;}
.my-tally .mt-ic{font-size:1.55rem;flex:none;line-height:1;}
.my-tally .mt-body{flex:1;min-width:0;}
.my-tally .mt-label{font-size:.7rem;font-weight:800;color:#9fe9c1;letter-spacing:.02em;}
.my-tally .mt-stats{font-size:1.08rem;font-weight:800;color:var(--cream);margin-top:1px;}
.my-tally .mt-stats b{color:var(--leaf);font-weight:900;}

/* add-mode toggle (mine / whole group) */
.seg.add-mode{margin:2px 0 8px;}
.row.group{outline:2px solid rgba(31,217,230,.4);outline-offset:-2px;}
.row.group .count-box{color:#0c8fa0;}
.add-mode-note{margin:0 4px 12px;font-size:.74rem;font-weight:600;color:#8fe6b6;line-height:1.5;text-align:center;}

/* goal */
.goal-card{background:var(--panel);border-radius:20px;padding:14px 14px 16px;margin-top:14px;box-shadow:0 8px 20px rgba(0,0,0,.18);}
.goal-head{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
.goal-head .flag{width:26px;height:26px;flex:none;}
.goal-head .gt{flex:1;font-weight:800;font-size:.92rem;color:var(--ink);}
.goal-inputs{display:flex;gap:8px;margin-bottom:12px;}
.goal-inputs input{font-family:'Rubik';font-weight:600;border:2px solid #e3eee6;border-radius:12px;padding:9px 11px;font-size:.92rem;color:var(--ink);background:#f5faf6;min-width:0;transition:border-color .15s;}
.goal-inputs input:focus{outline:none;border-color:var(--leaf);}
.goal-inputs .gname{flex:1;} .goal-inputs .gamt{width:96px;text-align:center;}
.progress-track{height:30px;border-radius:999px;background:#e9f2eb;overflow:hidden;position:relative;border:2px solid #dcebe0;}
.progress-fill{height:100%;border-radius:999px;position:relative;background:linear-gradient(90deg,var(--cyan),var(--leaf) 60%,var(--sun));background-size:200% 100%;box-shadow:0 0 14px rgba(47,224,122,.5);transition:width .7s cubic-bezier(.34,1.56,.5,1);display:flex;align-items:center;animation:flow 3s linear infinite;}
@keyframes flow{to{background-position:200% 0;}}
.progress-fill::after{content:"";position:absolute;inset:0;opacity:.4;background:repeating-linear-gradient(115deg,transparent 0 9px,rgba(255,255,255,.45) 9px 16px);}
.progress-coin{margin-inline-start:auto;margin-inline-end:6px;font-size:1.1rem;z-index:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3));}
.progress-label{display:flex;justify-content:space-between;margin-top:7px;font-size:.74rem;font-weight:700;color:#5e7468;}
.progress-label b{color:var(--leaf-dk);}
.goal-done{color:var(--pink-dk)!important;}
.goal-dist{margin-top:10px;display:flex;justify-content:center;min-height:38px;}
.goal-dist-inner{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#eafaf0,#e3f6fb);border:2px solid #d3eede;border-radius:999px;padding:7px 16px 7px 12px;font-weight:800;font-size:.92rem;color:var(--ink);text-align:center;opacity:0;transform:translateY(6px) scale(.96);transition:opacity .28s,transform .28s cubic-bezier(.34,1.56,.5,1);box-shadow:0 3px 10px rgba(0,0,0,.06);}
.goal-dist-inner.show{opacity:1;transform:translateY(0) scale(1);}
.gd-emoji{font-size:1.2rem;line-height:1;flex:none;} .gd-text{color:#236b48;}

/* section + rows */
.sec-title{display:flex;align-items:center;gap:8px;margin:20px 4px 10px;color:var(--cream);}
.sec-title h2{font-family:'Varela Round';margin:0;font-size:1rem;text-shadow:0 1px 0 rgba(0,0,0,.2);}
.sec-title .ln{flex:1;height:3px;border-radius:3px;background:rgba(255,255,255,.14);}
.rows{display:flex;flex-direction:column;gap:11px;}
.row{background:var(--panel);border-radius:18px;padding:11px 12px;display:flex;align-items:center;gap:11px;box-shadow:0 6px 16px rgba(0,0,0,.16);position:relative;overflow:hidden;}
.row.bump{animation:rowbump .35s cubic-bezier(.34,1.56,.5,1);}
@keyframes rowbump{0%{transform:scale(1);}40%{transform:scale(1.025);}100%{transform:scale(1);}}
.row-accent{position:absolute;inset-inline-start:0;top:0;bottom:0;width:6px;}
.ico{width:46px;height:54px;flex:none;display:grid;place-items:center;}
.row-info{flex:1;min-width:0;}
.row-info .nm{font-weight:800;font-size:.94rem;color:var(--ink);line-height:1.1;}
.row-info .sb{font-size:.7rem;color:#7c8f84;font-weight:600;margin-top:2px;}
.rate-chip{display:inline-flex;align-items:center;gap:3px;margin-top:5px;background:#eef7f0;border-radius:999px;padding:2px 8px;font-size:.68rem;font-weight:800;color:var(--leaf-dk);direction:ltr;}
.stepper-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:none;}
.stepper{display:flex;align-items:center;gap:6px;}
.step-btn{width:42px;height:42px;border:none;border-radius:13px;cursor:pointer;flex:none;font-size:1.5rem;font-weight:900;color:#fff;line-height:1;display:grid;place-items:center;transition:transform .08s,box-shadow .08s;user-select:none;}
.step-btn.minus{background:linear-gradient(160deg,#ff7aa8,var(--pink));box-shadow:0 4px 0 var(--pink-dk);}
.step-btn.plus{background:linear-gradient(160deg,#5bf0a0,var(--leaf));box-shadow:0 4px 0 var(--leaf-shadow);}
.step-btn:active{transform:translateY(4px);box-shadow:0 0 0;}
.step-btn:disabled{opacity:.4;box-shadow:0 4px 0 rgba(0,0,0,.15);pointer-events:none;}
.count-box{width:46px;text-align:center;font-weight:900;font-size:1.5rem;color:var(--ink);direction:ltr;font-variant-numeric:tabular-nums;}
.line-total{font-size:.74rem;font-weight:900;color:var(--leaf-dk);direction:ltr;line-height:1;min-height:.8rem;}
.float-money{position:absolute;font-weight:900;font-size:1rem;color:var(--leaf);direction:ltr;pointer-events:none;z-index:5;text-shadow:0 1px 2px rgba(0,0,0,.2);animation:floatup 1s ease-out forwards;}
@keyframes floatup{0%{transform:translateY(0) scale(.6);opacity:0;}20%{opacity:1;transform:translateY(-6px) scale(1.1);}100%{transform:translateY(-42px) scale(1);opacity:0;}}

/* fx (shared) */
#confetti{position:fixed;inset:0;pointer-events:none;z-index:40;}
.fx{position:fixed;z-index:45;pointer-events:none;will-change:transform;line-height:1;user-select:none;}
.fx-fall{top:-50px;animation-name:fxfall;animation-timing-function:linear;animation-fill-mode:forwards;}
@keyframes fxfall{from{transform:translateY(0) rotate(0);opacity:1;}85%{opacity:1;}to{transform:translateY(108vh) rotate(380deg);opacity:.9;}}
.fx-burst{animation-name:fxburst;animation-timing-function:cubic-bezier(.2,.7,.3,1);animation-fill-mode:forwards;transform:translate(-50%,-50%);}
@keyframes fxburst{0%{transform:translate(-50%,-50%) scale(.3);opacity:0;}15%{opacity:1;}70%{opacity:1;}100%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(1.1) rotate(var(--r));opacity:0;}}
.fx-bubble{top:auto;animation-name:fxbubble;animation-timing-function:ease-in;animation-fill-mode:forwards;}
@keyframes fxbubble{from{transform:translateY(0) scale(.6);opacity:.95;}to{transform:translateY(-92vh) scale(1.15);opacity:0;}}
.praise{position:fixed;z-index:48;pointer-events:none;font-family:'Varela Round',sans-serif;font-weight:700;color:#fff;text-shadow:0 3px 0 rgba(0,0,0,.22),0 0 22px currentColor;white-space:nowrap;transform:translate(-50%,-50%);animation:praisepop 1.6s cubic-bezier(.34,1.56,.5,1) forwards;}
@keyframes praisepop{0%{transform:translate(-50%,-50%) scale(0) rotate(-8deg);opacity:0;}18%{transform:translate(-50%,-55%) scale(1.25) rotate(3deg);opacity:1;}38%{transform:translate(-50%,-62%) scale(1) rotate(-2deg);}78%{opacity:1;transform:translate(-50%,-95%) scale(1);}100%{opacity:0;transform:translate(-50%,-140%) scale(1);}}
.shake{animation:shake .6s ease;}
@keyframes shake{0%,100%{transform:translateX(0);}15%{transform:translate(-7px,3px) rotate(-1deg);}30%{transform:translate(7px,-3px) rotate(1deg);}45%{transform:translate(-6px,2px) rotate(-1deg);}60%{transform:translate(6px,-2px) rotate(1deg);}75%{transform:translate(-3px,1px);}}

/* goal celebration */
.goal-celebrate{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 90% at 50% 40%,rgba(10,61,44,.78),rgba(4,20,14,.93));backdrop-filter:blur(3px);cursor:pointer;animation:gcfade .3s ease;}
@keyframes gcfade{from{opacity:0;}to{opacity:1;}}
.gc-inner{text-align:center;padding:20px;}
.gc-trophy{font-size:clamp(4rem,20vw,7rem);line-height:1;animation:gctrophy 1s cubic-bezier(.34,1.56,.5,1) infinite alternate;filter:drop-shadow(0 10px 18px rgba(0,0,0,.4));}
@keyframes gctrophy{0%{transform:translateY(0) rotate(-6deg) scale(1);}100%{transform:translateY(-14px) rotate(6deg) scale(1.06);}}
.gc-title{font-family:'Varela Round',sans-serif;font-weight:700;font-size:clamp(2.6rem,15vw,6rem);line-height:.95;margin:6px 0 2px;color:var(--sun);text-shadow:0 0 28px rgba(255,210,63,.7),0 5px 0 #7a5a00,0 7px 2px rgba(0,0,0,.45);animation:gctitle .7s cubic-bezier(.34,1.7,.5,1) both;}
@keyframes gctitle{0%{transform:scale(0) rotate(-10deg);opacity:0;}55%{transform:scale(1.18) rotate(4deg);}75%{transform:scale(.96) rotate(-2deg);}100%{transform:scale(1) rotate(0);opacity:1;}}
.gc-sub{color:#bdf0d2;font-size:clamp(1rem,5vw,1.5rem);font-weight:700;margin-bottom:14px;}
.gc-amount{display:inline-block;background:linear-gradient(150deg,var(--pink),#ff77b3);color:#fff;font-weight:900;font-size:clamp(1.6rem,8vw,2.6rem);direction:ltr;padding:6px 22px;border-radius:999px;box-shadow:0 8px 22px rgba(0,0,0,.35);animation:gctitle .7s .15s cubic-bezier(.34,1.7,.5,1) both;}
.gc-tap{color:#8fe6b6;font-size:.85rem;font-weight:700;margin-top:18px;animation:gcblink 1.2s ease-in-out infinite;}
@keyframes gcblink{0%,100%{opacity:.5;}50%{opacity:1;}}

/* sheet / modal */
.sheet-bg{position:fixed;inset:0;z-index:55;background:rgba(4,20,14,.6);backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;animation:gcfade .25s ease;}
.sheet{background:var(--panel);border-radius:24px 24px 0 0;width:100%;max-width:560px;padding:20px 18px calc(24px + env(safe-area-inset-bottom));box-shadow:0 -10px 30px rgba(0,0,0,.3);animation:sheetup .3s cubic-bezier(.34,1.4,.5,1);max-height:88vh;overflow-y:auto;}
@keyframes sheetup{from{transform:translateY(100%);}to{transform:translateY(0);}}
.sheet h3{font-family:'Varela Round';margin:0 0 14px;font-size:1.25rem;color:var(--ink);}
.sheet-handle{width:44px;height:5px;border-radius:3px;background:#d8e6dc;margin:0 auto 14px;}
.seg{display:flex;gap:6px;background:#eef5f0;border-radius:13px;padding:4px;margin-bottom:12px;}
.seg button{flex:1;border:none;background:none;border-radius:10px;padding:9px;font-weight:800;font-size:.86rem;color:#5e7468;cursor:pointer;}
.seg button.on{background:#fff;color:var(--ink);box-shadow:0 2px 6px rgba(0,0,0,.1);}

.toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%);background:#06291c;color:var(--cream);padding:10px 18px;border-radius:999px;font-weight:700;font-size:.85rem;z-index:70;box-shadow:0 8px 20px rgba(0,0,0,.4);border:1.5px solid rgba(47,224,122,.3);animation:toastin .3s ease;}
@keyframes toastin{from{opacity:0;transform:translate(-50%,12px);}to{opacity:1;transform:translate(-50%,0);}}
.spin{width:34px;height:34px;border:4px solid rgba(255,255,255,.25);border-top-color:var(--leaf);border-radius:50%;animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.center-load{min-height:100vh;display:grid;place-items:center;position:relative;z-index:1;}

/* ---------- member strip (above the total) ---------- */
.mstrip{display:flex;justify-content:center;gap:16px;margin:4px 0 14px;flex-wrap:wrap;}
.mstrip.scroll{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;padding:2px 2px 8px;-webkit-overflow-scrolling:touch;}
.mava{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;background:none;border:none;flex:none;padding:0;}
.mava-ring{width:58px;height:58px;border-radius:50%;padding:3px;background:linear-gradient(140deg,var(--leaf),var(--cyan));box-shadow:0 4px 0 rgba(0,0,0,.22),0 8px 16px rgba(0,0,0,.3);transition:transform .18s cubic-bezier(.34,1.56,.5,1);}
.mava:nth-child(3n+2) .mava-ring{background:linear-gradient(140deg,var(--pink),var(--sun));}
.mava:nth-child(3n+3) .mava-ring{background:linear-gradient(140deg,var(--sun),var(--leaf));}
.mava.me .mava-ring{box-shadow:0 0 0 3px var(--sun),0 4px 0 rgba(0,0,0,.22),0 8px 16px rgba(0,0,0,.3);}
.mava:hover .mava-ring,.mava:active .mava-ring{transform:translateY(-3px) scale(1.07) rotate(-3deg);}
.mava.pop .mava-ring{animation:avapop .55s cubic-bezier(.34,1.56,.5,1);}
@keyframes avapop{0%{transform:scale(1);}45%{transform:scale(1.22) rotate(9deg);}70%{transform:scale(.96) rotate(-4deg);}100%{transform:scale(1) rotate(0);}}
.mava-name{color:var(--cream);font-size:.72rem;font-weight:800;max-width:66px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 0 rgba(0,0,0,.25);}
.mava-money{color:var(--sun);font-size:.74rem;font-weight:900;direction:ltr;line-height:1;}

/* member detail sheet */
.md-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.mava-ring.lg{width:78px;height:78px;}
.md-totals{color:var(--leaf-dk);font-weight:800;font-size:.92rem;margin-top:4px;}
.md-empty{text-align:center;color:#7c8f84;font-weight:700;padding:20px 0;line-height:1.7;}
.md-empty span{font-size:.82rem;color:#9bb0a4;}
.md-rows{display:flex;flex-direction:column;gap:9px;}
.md-row{display:flex;align-items:center;gap:12px;background:#f5faf6;border-radius:14px;padding:9px 13px;}
.md-ico{width:38px;height:46px;flex:none;display:grid;place-items:center;}
.md-info{flex:1;min-width:0;}
.md-nm{font-weight:800;color:var(--ink);font-size:.94rem;}
.md-rate{font-size:.72rem;color:#7c8f84;font-weight:700;margin-top:1px;}
.md-val{font-weight:900;color:var(--leaf-dk);font-size:1.05rem;direction:ltr;}

/* ---------- group icon picker ---------- */
.gicon-grid{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 4px;}
.gicon-pick{border:3px solid transparent;border-radius:16px;cursor:pointer;padding:0;background:none;transition:transform .12s;}
.gicon-pick:active{transform:scale(.9);}
.gicon-pick.sel{border-color:var(--sun);transform:scale(1.06);}
.gicon-upload{border:2px dashed #cfe4d6;border-radius:16px;width:54px;height:54px;display:grid;place-items:center;cursor:pointer;color:var(--leaf-dk);font-size:1.3rem;background:#f3faf5;flex:none;}

/* ---------- google sign-in button ---------- */
.btn.google{background:#fff;color:#3c4043;box-shadow:0 5px 0 #d3e0d7;border:2px solid #e3eee6;}
.btn.google:active{box-shadow:0 0 0;}

/* ---------- chat emoji picker + join requests ---------- */
.emoji-btn{width:48px;height:48px;flex:none;border:none;border-radius:50%;background:#eef5f0;font-size:1.4rem;cursor:pointer;display:grid;place-items:center;transition:transform .1s;}
.emoji-btn:active{transform:scale(.9);}
.emoji-pop{position:absolute;bottom:64px;inset-inline-end:0;width:min(330px,86vw);background:#fff;border-radius:18px;box-shadow:0 12px 30px rgba(0,0,0,.22);padding:8px;z-index:30;border:1.5px solid #e3eee6;}
.emoji-cats{display:flex;gap:2px;border-bottom:1.5px solid #eef5f0;padding-bottom:6px;margin-bottom:6px;overflow-x:auto;}
.emoji-cats button{border:none;background:none;font-size:1.25rem;cursor:pointer;border-radius:10px;padding:5px 7px;flex:none;opacity:.5;transition:opacity .12s,background .12s;}
.emoji-cats button.on{opacity:1;background:#eef5f0;}
.emoji-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;max-height:178px;overflow-y:auto;}
.emoji-grid button{border:none;background:none;font-size:1.45rem;cursor:pointer;border-radius:10px;padding:5px;transition:transform .1s,background .1s;}
.emoji-grid button:active{transform:scale(.85);background:#eef5f0;}
.chat-input{position:relative;}
.pending-box{background:linear-gradient(160deg,rgba(31,217,230,.14),rgba(31,217,230,.05));border:2px solid var(--cyan);border-radius:18px;padding:14px;margin-bottom:14px;}
.pending-box .ph{font-weight:800;color:var(--ink);margin-bottom:10px;font-size:.92rem;display:flex;align-items:center;gap:7px;}
.pending-row{display:flex;align-items:center;gap:11px;background:#fff;border-radius:14px;padding:9px 11px;margin-bottom:8px;box-shadow:0 3px 9px rgba(0,0,0,.08);}
.pending-row .pr-name{font-weight:800;color:var(--ink);flex:1;min-width:0;}
.pending-row .pr-act{display:flex;gap:6px;flex:none;}
.pr-btn{border:none;border-radius:11px;width:40px;height:40px;font-size:1.1rem;font-weight:900;cursor:pointer;display:grid;place-items:center;color:#fff;transition:transform .1s;}
.pr-btn:active{transform:scale(.88);}
.pr-btn.ok{background:linear-gradient(160deg,#5bf0a0,var(--leaf));box-shadow:0 3px 0 var(--leaf-shadow);}
.pr-btn.no{background:linear-gradient(160deg,#ff7aa8,var(--pink));box-shadow:0 3px 0 var(--pink-dk);}
.pending-wait{text-align:center;}
.pending-wait .pw-emoji{font-size:3.4rem;margin-bottom:8px;}
.tab .badge{position:absolute;top:2px;inset-inline-end:8px;background:var(--pink);color:#fff;font-size:.6rem;font-weight:900;min-width:16px;height:16px;border-radius:9px;display:grid;place-items:center;padding:0 4px;}

/* ---------- group icon in header + hub ---------- */
.gv-gicon{margin-inline-end:2px;}

/* ---------- ko-fi support button ---------- */
.btn.kofi{background:linear-gradient(160deg,#ff8e69,#ff5e5b);box-shadow:0 5px 0 #c23b39;color:#fff;font-size:1rem;}
.btn.kofi:active{box-shadow:0 0 0;}
.kofi-cup{font-size:1.25rem;animation:kofibob 1.6s ease-in-out infinite;display:inline-block;}
@keyframes kofibob{0%,100%{transform:translateY(0) rotate(-4deg);}50%{transform:translateY(-3px) rotate(4deg);}}

/* ---------- verification: card, badges, receipts ---------- */
.verify-card{display:flex;align-items:center;gap:12px;background:#ffffff;border:2px solid #cdeede;border-radius:18px;padding:13px 15px;margin-bottom:16px;box-shadow:0 4px 14px rgba(0,0,0,.13);}
.verify-card.verified{border-color:var(--leaf);}
.verify-card.expired{border-color:var(--sun);}
.verify-card .vc-ic{width:46px;height:46px;flex:none;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;background:#f0f7f2;box-shadow:0 3px 9px rgba(0,0,0,.08);}
.verify-card.verified .vc-ic{background:var(--leaf);color:#fff;font-weight:900;}
.verify-card .vc-txt{flex:1;min-width:0;}
.verify-card .vc-txt b{display:block;color:var(--ink);font-size:.96rem;font-weight:800;}
.verify-card .vc-txt span{display:block;color:#4a6356;font-size:.78rem;font-weight:600;line-height:1.4;margin-top:2px;}
.verify-card .btn{flex:none;}
.vc-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px;}
.vc-chip{font-size:.68rem;font-weight:800;border-radius:999px;padding:2px 9px;background:#eef7f0;color:var(--leaf-dk);}
.vc-chip.warn{background:#fff3d6;color:#9a6b00;}
.vc-chip.expired{background:#ffe3ee;color:var(--pink-dk);}
.vc-refresh{background:none;border:none;color:var(--cyan-dk);font-weight:800;font-size:.76rem;cursor:pointer;text-decoration:underline;padding:4px 0 0;}
.md-verify{font-size:.8rem;font-weight:800;margin-top:3px;}
.md-verify.ok{color:var(--leaf-dk);}
.md-verify.expired{color:var(--sun-dk);}

.vbadge{display:inline-grid;place-items:center;width:17px;height:17px;border-radius:50%;background:var(--leaf);color:#fff;font-size:.62rem;font-weight:900;margin-inline-start:6px;vertical-align:middle;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.mava-vbadge{position:absolute;top:-2px;inset-inline-end:-2px;width:20px;height:20px;border-radius:50%;background:var(--leaf);color:#fff;font-size:.7rem;font-weight:900;display:grid;place-items:center;border:2px solid #fff;z-index:2;box-shadow:0 2px 5px rgba(0,0,0,.25);}
.mava-ring{position:relative;}

.rcpt-thumb{width:46px;height:46px;flex:none;border-radius:11px;object-fit:cover;cursor:pointer;border:2px solid #e3eee6;}
.rcpt-full{width:100%;max-height:52vh;object-fit:contain;border-radius:14px;background:#f0f5f1;border:1.5px solid #e3eee6;}
.rcpt-report{margin-top:12px;background:#f5faf6;border:1.5px solid #e3eee6;border-radius:13px;padding:10px 13px;font-weight:800;color:var(--ink);font-size:.9rem;}

/* ---------- INTRO splash (on app open) ---------- */
.intro{
  position:fixed;inset:0;z-index:200;overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:radial-gradient(120% 75% at 50% 0%, #15734d 0%, var(--forest-2) 45%, var(--forest) 100%);
  animation:introIn .4s ease both;
}
@keyframes introIn{from{opacity:0;}to{opacity:1;}}
.intro.leaving{animation:introOut .5s cubic-bezier(.5,0,.6,1) forwards;}
@keyframes introOut{to{opacity:0;transform:scale(1.06);}}

.intro-deco{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.intro-deco span{position:absolute;border-radius:50% 0 50% 50%;opacity:.12;animation:introDrift linear infinite;}
@keyframes introDrift{0%{transform:translateY(0) rotate(0);}50%{transform:translateY(-22px) rotate(180deg);}100%{transform:translateY(0) rotate(360deg);}}

.intro-skip{
  position:absolute;top:calc(16px + env(safe-area-inset-top));inset-inline-end:16px;z-index:5;
  border:2px solid rgba(255,255,255,.28);background:rgba(6,41,28,.5);color:var(--cream);
  font-family:'Rubik';font-weight:800;font-size:.92rem;padding:9px 18px;border-radius:999px;cursor:pointer;
  backdrop-filter:blur(4px);transition:transform .1s,background .15s;
}
.intro-skip:active{transform:scale(.94);}
.intro-skip:hover{background:rgba(6,41,28,.78);}
@keyframes introFade{from{opacity:0;}to{opacity:1;}}

.intro-stage{position:relative;z-index:2;text-align:center;padding:24px;}
.intro-logo{
  width:160px;height:160px;margin:0 auto 22px;border-radius:42px;overflow:hidden;
  box-shadow:0 26px 60px rgba(0,0,0,.4),0 0 0 6px rgba(255,255,255,.06);
}
.intro-logo img{width:100%;height:100%;object-fit:cover;display:block;}
@keyframes introPop{0%{transform:scale(.2) rotate(-14deg);opacity:0;}60%{transform:scale(1.12) rotate(5deg);opacity:1;}80%{transform:scale(.97) rotate(-2deg);}100%{transform:scale(1) rotate(0);opacity:1;}}

.intro-name{
  font-family:'Varela Round',sans-serif;font-weight:700;margin:0;color:var(--cream);
  font-size:clamp(2.8rem,15vw,4rem);line-height:1;letter-spacing:.01em;
  text-shadow:0 3px 0 rgba(0,0,0,.25),0 0 30px rgba(47,224,122,.25);
}
.intro-tag{
  margin-top:14px;color:var(--leaf);font-weight:800;font-size:clamp(1.1rem,5.5vw,1.5rem);
}
.intro-chips{
  display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;
  color:#bdf0d2;font-weight:700;font-size:clamp(.95rem,4.4vw,1.18rem);
}
.intro-chips span{display:inline-block;}
.intro-chips i{font-style:normal;color:var(--sun);display:inline-block;}
@keyframes introChip{from{opacity:0;transform:translateY(10px) scale(.8);}to{opacity:1;transform:translateY(0) scale(1);}}
@keyframes introRise{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:translateY(0);}}

.intro-confetti{position:absolute;inset:0;pointer-events:none;z-index:3;overflow:hidden;}
.intro-confetti span{position:absolute;top:-40px;border-radius:3px;opacity:0;}
@keyframes introFall{
  0%{opacity:0;transform:translate(0,-10px) rotate(0);}
  10%{opacity:1;}
  100%{opacity:.9;transform:translate(var(--drift),96vh) rotate(var(--rot));}
}

/* Entrance animations only when motion is welcome — base state above stays visible
   for print, reduced-motion, and any environment that doesn't run animations. */
@media (prefers-reduced-motion: no-preference){
  .intro-skip{animation:introFade .4s 1.4s both;}
  .intro-logo{animation:introPop .8s cubic-bezier(.34,1.7,.5,1) both;}
  .intro-name{animation:introRise .7s .35s cubic-bezier(.34,1.5,.5,1) both;}
  .intro-tag{animation:introRise .7s .55s cubic-bezier(.34,1.5,.5,1) both;}
  .intro-chips span,.intro-chips i{animation:introChip .5s both;}
  .intro-confetti span{animation:introFall linear forwards;}
}

@media (prefers-reduced-motion: reduce){
  .intro-deco span{animation:none;}
}

/* ---------- INSTALL banner (add to home screen) ---------- */
.install-bar{
  position:fixed;z-index:80;left:12px;right:12px;bottom:calc(14px + env(safe-area-inset-bottom));
  max-width:520px;margin:0 auto;background:rgba(7,42,29,.97);
  border:2px solid rgba(47,224,122,.32);border-radius:20px;
  padding:13px 14px;box-shadow:0 16px 40px rgba(0,0,0,.5);backdrop-filter:blur(8px);
  animation:installUp .42s cubic-bezier(.34,1.5,.5,1) both;
}
.install-bar.lifted{bottom:calc(92px + env(safe-area-inset-bottom));}
@keyframes installUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
.install-top{display:flex;align-items:center;gap:12px;}
.install-logo{width:48px;height:48px;border-radius:13px;flex:none;box-shadow:0 4px 12px rgba(0,0,0,.35);}
.install-body{flex:1;min-width:0;padding-inline-end:18px;}
.install-body b{display:block;color:var(--cream);font-family:'Varela Round',sans-serif;font-size:1rem;font-weight:700;line-height:1.15;}
.install-body span{display:block;color:#9fe9c1;font-size:.76rem;font-weight:600;line-height:1.35;margin-top:3px;text-wrap:pretty;}
.install-go{
  flex:none;border:none;cursor:pointer;border-radius:13px;padding:11px 18px;
  font-family:'Rubik';font-weight:800;font-size:.92rem;color:#062a1c;
  background:linear-gradient(160deg,#5bf0a0,var(--leaf));box-shadow:0 4px 0 var(--leaf-shadow);
  transition:transform .08s,box-shadow .08s;white-space:nowrap;
}
.install-go:active{transform:translateY(4px);box-shadow:0 0 0;}
.install-x{
  position:absolute;top:8px;inset-inline-end:10px;border:none;background:none;cursor:pointer;
  color:#7fbf9e;font-size:.95rem;font-weight:800;padding:4px 6px;line-height:1;border-radius:8px;
}
.install-x:active{transform:scale(.88);}
.install-steps{
  margin:12px 4px 2px;padding-inline-start:22px;display:flex;flex-direction:column;gap:7px;
  color:#dff7e6;font-size:.86rem;font-weight:600;line-height:1.45;
}
.install-steps li{padding-inline-start:4px;}
.install-steps b{color:var(--sun);font-weight:800;}

/* ---------- KIDS MODE: "who are you?" picker + entry button ---------- */
.kids-entry-btn{
  position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:30;
  border:none;border-radius:999px;cursor:pointer;font-family:'Rubik';font-weight:900;font-size:1rem;
  padding:13px 26px;color:var(--ink);background:linear-gradient(160deg,var(--sun),var(--sun-dk));
  box-shadow:0 5px 0 #b07f00,0 10px 22px rgba(0,0,0,.32);display:flex;align-items:center;gap:8px;
}
.kids-entry-btn:active{transform:translateX(-50%) translateY(4px);box-shadow:0 1px 0 #b07f00;}

.kids-pick .brandmark h1{font-size:2.1rem;}
.kids-grid-card{padding:18px;}
.kids-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
@media(min-width:430px){ .kids-grid{grid-template-columns:repeat(3,1fr);} }
.kid-tile{
  border:none;background:linear-gradient(165deg,#ffffff,#f1faf3);border-radius:22px;cursor:pointer;
  padding:16px 10px 13px;display:flex;flex-direction:column;align-items:center;gap:10px;
  box-shadow:0 5px 0 #dcebe1,0 8px 18px rgba(7,42,29,.12);transition:transform .1s,box-shadow .1s;
}
.kid-tile:active{transform:translateY(4px);box-shadow:0 1px 0 #dcebe1,0 4px 10px rgba(7,42,29,.12);}
.kid-face{width:92px;height:92px;border-radius:50%;overflow:hidden;box-shadow:0 0 0 4px #fff,0 4px 12px rgba(0,0,0,.18);display:grid;place-items:center;background:#eafaf0;}
.kid-face.plus{font-size:2.6rem;font-weight:800;color:var(--leaf-dk);background:#eafaf0;border:3px dashed #bfe3cd;box-shadow:none;}
.kid-tile.add{background:linear-gradient(165deg,#f3faf5,#eaf6ee);box-shadow:0 5px 0 #dcebe1;}
.kid-name{font-family:'Varela Round';font-weight:700;font-size:1.15rem;color:var(--ink);line-height:1;}

/* acting-as-child banner + family box + in-group kids overlay */
.acting-banner{display:flex;align-items:center;gap:10px;background:linear-gradient(160deg,#fff,#eafaf0);border:2px solid var(--cyan);border-radius:16px;padding:8px 12px;margin-bottom:12px;box-shadow:0 4px 12px rgba(0,0,0,.1);}
.acting-banner span{flex:1;font-weight:700;color:var(--ink);font-size:.92rem;}
.acting-banner b{color:var(--cyan-dk);}
.acting-banner button{border:none;background:#eef7f0;color:var(--ink);font-family:'Rubik';font-weight:800;font-size:.8rem;padding:7px 11px;border-radius:10px;cursor:pointer;}
.acting-banner button:active{transform:scale(.95);}
.family-box{background:linear-gradient(160deg,rgba(31,217,230,.14),rgba(31,217,230,.05));border-color:var(--cyan);text-align:start;font-weight:700;color:var(--ink);font-size:.9rem;line-height:1.5;}
.addpart{background:var(--panel);border:1.5px solid #e3eee6;border-radius:16px;padding:13px 14px;margin-bottom:14px;}
.addpart-txt{color:#5e7468;font-size:.82rem;font-weight:600;line-height:1.5;text-wrap:pretty;}
.kids-overlay{position:fixed;inset:0;z-index:60;background:radial-gradient(120% 80% at 50% -10%, #15734d 0%, var(--forest-2) 45%, var(--forest) 100%);padding:22px 18px;overflow-y:auto;}
.ko-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.ko-head h2{font-family:'Varela Round';font-weight:700;color:var(--cream);font-size:1.5rem;margin:0;}
.ko-x{width:42px;height:42px;border:none;border-radius:13px;background:rgba(255,255,255,.14);color:var(--cream);font-size:1.5rem;cursor:pointer;flex:none;}
.kids-overlay .kids-grid{max-width:460px;margin:0 auto;}

/* ============ accessibility: visible keyboard focus ============ */
:focus-visible{outline:3px solid var(--cyan);outline-offset:2px;border-radius:8px;}
.btn:focus-visible,.linkbtn:focus-visible{outline-offset:3px;}

/* ============ member management (admin) ============ */
.member-row.tappable{cursor:pointer;transition:transform .08s,box-shadow .12s;}
.member-row.tappable:hover{box-shadow:0 6px 16px rgba(0,0,0,.16);}
.member-row.tappable:active{transform:scale(.99);}
.member-row .mr-child{font-size:.66rem;font-weight:800;color:var(--cyan-dk);background:#e0f7fa;padding:2px 7px;border-radius:999px;margin-inline-start:6px;}
.member-row .mr-gear{font-size:1rem;opacity:.5;flex:none;}
.adm-actions{display:flex;flex-direction:column;gap:8px;margin-top:6px;}
.adm-row{display:flex;align-items:center;gap:12px;width:100%;border:1.5px solid #e3eee6;background:#f7fbf8;border-radius:14px;padding:13px 14px;cursor:pointer;font-family:'Rubik';text-align:start;}
.adm-row:hover{background:#eef7f0;}
.adm-row:active{transform:scale(.99);}
.adm-row .ai{font-size:1.2rem;flex:none;}
.adm-row .al{flex:1;font-weight:800;color:var(--ink);font-size:.96rem;}
.adm-row .ar{color:#b7c8bd;font-weight:800;font-size:1.2rem;}
.adm-row.danger{border-color:#ffd2e3;background:#fff3f8;}
.adm-row.danger .al{color:var(--pink-dk);}
.adm-row:disabled{opacity:.5;pointer-events:none;}
.btn.ghost.dark{color:var(--ink);border-color:#d6eadd;background:#f3faf5;}
.btn.ghost.danger-line{color:var(--pink-dk);border:2px solid #ffd2e3;background:#fff3f8;}
.adm-counts{display:flex;flex-direction:column;gap:8px;}
.adm-cnt-row{display:flex;align-items:center;gap:10px;background:#f7fbf8;border:1.5px solid #e3eee6;border-radius:13px;padding:8px 10px;}
.acc-emoji{font-size:1.4rem;flex:none;}
.acc-name{flex:1;font-weight:800;color:var(--ink);font-size:.9rem;}
.acc-step{display:flex;align-items:center;gap:6px;flex:none;}
.acc-step button{width:34px;height:34px;border:none;border-radius:10px;background:#e7f3ea;color:var(--leaf-dk);font-size:1.3rem;font-weight:800;cursor:pointer;line-height:1;}
.acc-step button:active{transform:scale(.92);}
.acc-num{width:58px;text-align:center;padding:7px 4px;font-weight:800;}
.adm-cnt-total{margin-top:12px;text-align:center;font-weight:700;color:var(--ink);background:#eef7f0;border-radius:12px;padding:9px;}
.adm-cnt-total b{color:var(--leaf-dk);}

/* ============ confirm dialog ============ */
.confirm-card{background:var(--panel);border-radius:22px;width:calc(100% - 36px);max-width:380px;padding:22px 20px;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.4);animation:gcfade .2s ease;}
.confirm-ico{font-size:2.4rem;line-height:1;margin-bottom:8px;}
.confirm-card h3{font-family:'Varela Round';margin:0 0 8px;font-size:1.2rem;color:var(--ink);}
.confirm-body{color:#5e7468;font-weight:600;line-height:1.55;margin:0 0 16px;font-size:.92rem;text-wrap:pretty;}
.confirm-acts{display:flex;gap:10px;}
.confirm-acts .btn{flex:1;}

/* ============ owner super-admin panel ============ */
.owner-panel{position:fixed;inset:0;z-index:62;background:radial-gradient(120% 80% at 50% -10%, #15734d 0%, var(--forest-2) 45%, var(--forest) 100%);padding:20px 16px calc(24px + env(safe-area-inset-bottom));overflow-y:auto;}
.op-top{display:flex;align-items:center;justify-content:space-between;max-width:560px;margin:0 auto 14px;}
.op-top h2{font-family:'Varela Round';color:var(--cream);margin:0;font-size:1.5rem;}
.op-sub{color:#bdf0d2;font-size:.78rem;font-weight:600;direction:ltr;text-align:start;}
.op-stats{display:flex;gap:10px;max-width:560px;margin:0 auto 14px;}
.op-stat{flex:1;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.18);border-radius:16px;padding:12px 8px;text-align:center;}
.op-stat b{display:block;color:var(--sun);font-size:1.3rem;font-family:'Varela Round';}
.op-stat span{color:#cdeedd;font-size:.74rem;font-weight:700;}
.op-search{max-width:560px;margin:0 auto 14px;display:block;}
.op-list,.op-leads{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:9px;}
.op-row{display:flex;align-items:center;gap:11px;background:var(--panel);border-radius:15px;padding:10px 12px;box-shadow:0 4px 12px rgba(0,0,0,.14);}
.op-info{flex:1;min-width:0;}
.op-name{font-weight:800;color:var(--ink);display:flex;align-items:center;gap:6px;}
.op-tag{font-size:.62rem;font-weight:800;color:var(--cyan-dk);background:#e0f7fa;padding:2px 6px;border-radius:999px;}
.op-meta{color:#7c8f84;font-size:.76rem;font-weight:600;}
.op-act{width:40px;height:40px;border:none;border-radius:12px;cursor:pointer;font-size:1.1rem;flex:none;}
.op-act.enter{background:#e7f3ea;color:var(--leaf-dk);}
.op-act.del{background:#fff3f8;}
.op-act:active{transform:scale(.92);}
.op-sectitle{max-width:560px;margin:24px auto 12px;color:var(--cream);font-weight:800;font-size:1rem;border-top:2px solid rgba(255,255,255,.14);padding-top:16px;}
.lead-row{display:flex;align-items:flex-start;gap:10px;background:var(--panel);border-radius:15px;padding:11px 13px;box-shadow:0 4px 12px rgba(0,0,0,.14);}
.lead-main{flex:1;min-width:0;}
.lead-name{font-weight:800;color:var(--ink);}
.lead-org{color:var(--leaf-dk);font-weight:700;}
.lead-date{color:#9bb0a4;font-size:.72rem;font-weight:700;margin-inline-start:8px;}
.lead-contact{display:inline-block;color:var(--cyan-dk);font-weight:700;font-size:.84rem;margin-top:2px;direction:ltr;word-break:break-all;}
.lead-msg{color:#5e7468;font-weight:600;font-size:.86rem;line-height:1.5;margin-top:4px;text-wrap:pretty;}
.owner-btn{color:var(--cream);border-color:rgba(255,255,255,.3);}

/* ============ chat moderation + safety ============ */
.bubble{position:relative;}
.msg-kebab{position:absolute;top:2px;inset-inline-end:4px;width:22px;height:22px;border:none;background:transparent;color:inherit;opacity:.4;font-size:1rem;line-height:1;cursor:pointer;border-radius:6px;}
.msg-kebab:hover{opacity:.85;}
.msg-menu{position:absolute;top:24px;inset-inline-end:2px;z-index:5;background:#fff;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.22);overflow:hidden;display:flex;flex-direction:column;min-width:120px;border:1px solid #e3eee6;}
.msg-menu button{border:none;background:none;padding:11px 14px;font-family:'Rubik';font-weight:700;font-size:.86rem;color:var(--ink);text-align:start;cursor:pointer;}
.msg-menu button:hover{background:#f3faf5;}
.msg-menu button.del{color:var(--pink-dk);}
.chat-warn{max-width:560px;margin:0 auto;background:#fff7e0;color:#9a6b00;border:1.5px solid var(--sun);border-radius:12px;padding:9px 12px;font-weight:700;font-size:.84rem;text-align:center;margin-bottom:6px;}

/* ============ reports box (admin) ============ */
.report-row{background:#fff;border:1.5px solid #ffe0ec;border-radius:13px;padding:11px 12px;margin-bottom:8px;}
.rr-meta{font-weight:800;color:var(--ink);font-size:.86rem;}
.rr-text{color:#5e7468;font-weight:600;font-size:.86rem;line-height:1.45;margin-top:4px;background:#f7fbf8;border-radius:9px;padding:7px 9px;text-wrap:pretty;}
.rr-acts{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:9px;}
.rr-acts .btn{width:auto;}

/* ============ legal modal + consent ============ */
.legal-modal{background:var(--panel);width:100%;max-width:600px;margin:auto;border-radius:22px;max-height:calc(100vh - 40px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);}
.legal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1.5px solid #eef5f0;}
.legal-head h3{font-family:'Varela Round';margin:0;color:var(--ink);font-size:1.2rem;}
.legal-tabs{display:flex;gap:6px;padding:10px 14px;background:#f7fbf8;}
.legal-tabs button{flex:1;border:none;background:#fff;border-radius:11px;padding:9px;font-family:'Rubik';font-weight:800;font-size:.82rem;color:#5e7468;cursor:pointer;border:1.5px solid #e3eee6;}
.legal-tabs button.on{background:var(--leaf-dk);color:#fff;border-color:var(--leaf-dk);}
.legal-body{padding:16px 18px 22px;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.legal-intro{color:var(--ink);font-weight:700;line-height:1.6;margin:0 0 16px;text-wrap:pretty;}
.legal-sec{margin-bottom:16px;}
.legal-sec h4{margin:0 0 5px;color:var(--leaf-dk);font-size:.98rem;font-family:'Varela Round';}
.legal-sec p{margin:0 0 7px;color:#41584c;font-weight:500;line-height:1.6;font-size:.9rem;text-wrap:pretty;}
.legal-links{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;color:#9bb0a4;font-size:.8rem;}
.legal-links .linkbtn{color:#cdeedd;font-size:.82rem;}
.consent-check{display:flex;align-items:flex-start;gap:10px;background:#f7fbf8;border:1.5px solid #e3eee6;border-radius:13px;padding:12px 13px;cursor:pointer;}
.consent-check input{width:22px;height:22px;flex:none;margin-top:1px;accent-color:var(--leaf-dk);cursor:pointer;}
.consent-check span{font-weight:600;color:var(--ink);line-height:1.5;font-size:.88rem;text-wrap:pretty;}
.free-love{display:flex;gap:10px;align-items:flex-start;background:linear-gradient(160deg,rgba(47,224,122,.14),rgba(47,224,122,.05));border:1.5px solid #bfeccf;border-radius:14px;padding:12px 13px;margin-bottom:14px;}
.free-love .fl-emoji{font-size:1.3rem;flex:none;}
.free-love div{color:#1e5e3c;font-weight:700;font-size:.86rem;line-height:1.55;text-wrap:pretty;}

/* ============ collaboration invite ============ */
.collab-card{background:linear-gradient(165deg,#fff,#f3faf5);border:2px solid #d6eadd;border-radius:20px;padding:18px 16px;margin-top:18px;text-align:center;}
.collab-emoji{font-size:2.4rem;line-height:1;}
.collab-card h3{font-family:'Varela Round';margin:6px 0 6px;color:var(--ink);font-size:1.25rem;}
.collab-lead{color:#5e7468;font-weight:600;line-height:1.6;margin:0 0 14px;font-size:.9rem;text-wrap:pretty;}
.collab-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:14px;}
.collab-chip{display:inline-flex;align-items:center;gap:5px;background:#eef7f0;color:var(--leaf-dk);border:1.5px solid #d6eadd;border-radius:999px;padding:8px 13px;font-weight:800;font-size:.84rem;text-decoration:none;direction:ltr;}
.collab-chip:active{transform:scale(.96);}
.collab-or{color:#9bb0a4;font-weight:700;font-size:.8rem;margin-bottom:10px;}
.collab-form{display:flex;flex-direction:column;gap:8px;text-align:start;}
.collab-msg{resize:vertical;min-height:64px;font-family:'Rubik';line-height:1.5;}
.collab-thanks{background:#e3f9ec;color:var(--leaf-dk);border-radius:13px;padding:14px;font-weight:800;line-height:1.5;}

/* respect reduced-motion for the press animations */
@media (prefers-reduced-motion: reduce){
  .btn,.adm-row,.acc-step button,.op-act,.member-row.tappable{transition:none;}
}

/* ============ promo / explainer video ============ */
.promo{position:fixed;inset:0;z-index:80;background:radial-gradient(120% 80% at 50% -10%, #15734d 0%, var(--forest-2) 45%, var(--forest) 100%);display:flex;align-items:center;justify-content:center;padding:18px;animation:gcfade .3s ease;}
.promo.leaving{animation:promoOut .42s ease forwards;}
@keyframes promoOut{to{opacity:0;}}
.promo-skip{position:fixed;top:max(14px,env(safe-area-inset-top));inset-inline-end:14px;z-index:3;border:none;background:rgba(255,255,255,.16);color:var(--cream);font-family:'Rubik';font-weight:800;font-size:.95rem;padding:10px 16px;border-radius:999px;cursor:pointer;backdrop-filter:blur(4px);}
.promo-skip:active{transform:scale(.95);}
.promo-stage{position:relative;display:flex;align-items:center;justify-content:center;max-width:100%;max-height:100%;}
.promo-video{max-width:min(440px,100%);max-height:84vh;width:auto;height:auto;border-radius:20px;background:#000;box-shadow:0 18px 50px rgba(0,0,0,.45);display:block;}
.promo-unmute{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);border:none;background:rgba(7,42,29,.6);color:var(--cream);font-family:'Rubik';font-weight:800;font-size:.95rem;padding:11px 18px;border-radius:999px;cursor:pointer;backdrop-filter:blur(4px);box-shadow:0 6px 18px rgba(0,0,0,.4);animation:unmutePulse 1.8s ease-in-out infinite;}
.promo-unmute:active{transform:translateX(-50%) scale(.95);}
@keyframes unmutePulse{0%,100%{box-shadow:0 6px 18px rgba(0,0,0,.4);}50%{box-shadow:0 6px 26px rgba(47,224,122,.55);}}
@media (prefers-reduced-motion: reduce){ .promo-unmute{animation:none;} }

