/* Irie Action OS — Companion App design system
   Pro-tracker world: dark slate, semantic color (green=handled, amber=attention).
   Mobile-first. No brand gold here by design. */

:root{
  --bg:#0E1116; --s1:#171B22; --s2:#1F242D; --s3:#262C36;
  --txt:#F2F4F7; --mut:#9AA4B2; --dim:#6B7480;
  --good:#3FB984; --good-bg:rgba(63,185,132,.14);
  --att:#E6A93C;  --att-bg:rgba(230,169,60,.15);
  --bad:#E66363;  --bad-bg:rgba(230,99,99,.14);
  --line:rgba(255,255,255,.08);
  --accent:var(--good);
  --radius:16px;
  --font:'DM Sans',system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:#05070A;color:var(--txt);font-family:var(--font);line-height:1.5;
     display:flex;flex-direction:column;align-items:center;min-height:100%;}

/* ---- view toggling: home (front door) vs device (an open pack) ---- */
#home{display:none}
#device{display:none}

/* ---- the front door ---- */
.home{width:100%;min-height:100vh;flex-direction:column;align-items:center;justify-content:center;padding:44px 20px}
.home-inner{width:100%;max-width:440px;text-align:center}
.home-mark{width:58px;height:58px;border-radius:17px;background:var(--s1);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-size:27px;color:var(--good);margin:0 auto 18px;
  box-shadow:0 0 24px rgba(63,185,132,.25)}
.home-eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mut);font-weight:700}
.home-title{font-size:27px;font-weight:700;color:#fff;margin:6px 0 8px}
.home-sub{font-size:14px;color:var(--mut);margin:0 auto 26px;max-width:25rem;line-height:1.55}
.home-grid{display:flex;flex-direction:column;gap:11px;text-align:left}
.home-card{display:flex;align-items:center;gap:14px;background:var(--s1);border:1px solid var(--line);
  border-left:3px solid var(--c);border-radius:16px;padding:15px 16px;cursor:pointer;font-family:var(--font);transition:.15s}
.home-card:hover{transform:translateY(-2px);border-color:var(--c);box-shadow:0 12px 32px rgba(0,0,0,.45)}
.home-ic{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:21px;flex:none;background:var(--s2)}
.home-meta{flex:1;display:flex;flex-direction:column}
.home-name{font-size:15px;font-weight:700;color:var(--txt)}
.home-shelf{font-size:11.5px;color:var(--mut);margin-top:1px}
.home-go{color:var(--c);font-size:22px;font-weight:700}
.home-foot{margin-top:24px;font-size:11px;color:var(--dim)}

/* ---- top bar inside an open pack ---- */
.topbar{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line);
  background:rgba(5,7,10,.85);backdrop-filter:blur(8px);flex:none}
.topbar .tb-back{font-family:var(--font);font-size:12.5px;font-weight:600;color:var(--mut);cursor:pointer;
  background:var(--s1);border:1px solid var(--line);border-radius:999px;padding:6px 13px;transition:.15s}
.topbar .tb-back:hover{color:var(--txt)}
.topbar .tb-brand{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}
.topbar .tb-title{font-size:13px;font-weight:700;color:var(--txt);margin-left:auto}

/* ---- phone frame ---- */
.device{width:100%;max-width:420px;flex:1;display:flex;flex-direction:column;
  background:var(--bg);position:relative;overflow:hidden;}
@media(min-width:460px){
  .device{margin:22px 0;height:860px;flex:none;border-radius:38px;border:1px solid var(--line);
    box-shadow:0 30px 80px rgba(0,0,0,.6);}
}

.screen{flex:1;overflow-y:auto;padding:20px 17px 96px;-webkit-overflow-scrolling:touch;}
.screen::-webkit-scrollbar{width:0}

/* ---- header ---- */
.apphead{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.apphead .who{display:flex;align-items:center;gap:10px}
.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:15px;background:linear-gradient(135deg,#3a4350,#252b34);flex:none}
.apphead .name{font-size:14px;font-weight:600;line-height:1.1}
.eyebrow{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);font-weight:600}

/* ---- chips / tags ---- */
.tag{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:4px 10px;border-radius:8px}
.tag.good{background:var(--good-bg);color:var(--good)}
.tag.att{background:var(--att-bg);color:var(--att)}
.tag.dot::before{content:'●';font-size:8px}

/* ---- cards ---- */
.card{background:var(--s1);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;margin-bottom:11px}
.card.bridge{border-color:rgba(63,185,132,.32)}
.card-h{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--good);font-weight:700;margin-bottom:6px}
.card-h.att{color:var(--att)}

/* ---- hero ring (pets) ---- */
.hero-ring{display:flex;flex-direction:column;align-items:center;margin:6px 0 16px}
.ring{border-radius:50%;display:flex;align-items:center;justify-content:center}
.ring .inner{border-radius:50%;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .big{font-size:40px;font-weight:700;line-height:.9}
.ring .big small{font-size:17px;color:var(--mut);font-weight:600}
.hero-sub{font-size:12px;color:var(--mut);margin-top:10px;text-align:center}

/* ---- hero number (money) ---- */
.hero-num{text-align:center;margin:8px 0 16px}
.hero-num .val{font-size:48px;font-weight:700;line-height:.95}
.hero-num .val.over{color:var(--att)}
.bar{height:8px;border-radius:8px;background:var(--s3);overflow:hidden;margin:14px 6px 0}
.bar > i{display:block;height:100%;background:var(--accent);border-radius:8px;transition:width .4s ease}
.bar > i.over{background:var(--att)}

/* ---- insight ---- */
.insight{font-size:12.5px;line-height:1.55}
.insight b{color:var(--good)}
.insight .muted{color:var(--mut)}

/* ---- rows / tasks ---- */
.row{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line);font-size:13px}
.row:last-child{border-bottom:none}
.row .ck{width:20px;height:20px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  font-size:10px;border:1.6px solid var(--dim);cursor:pointer;transition:.15s;background:transparent;color:transparent}
.row .ck.done{background:var(--good);border-color:var(--good);color:#08110C}
.row .lbl{flex:1}
.row.done .lbl{color:var(--mut);text-decoration:line-through}
.row .meta{margin-left:auto;flex:none}

/* ---- quick log buttons ---- */
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:4px}
.quick button{font-family:var(--font);cursor:pointer;background:var(--s2);border:1px solid var(--line);
  border-radius:13px;padding:11px 4px;color:var(--txt);display:flex;flex-direction:column;align-items:center;gap:5px;
  font-size:10px;font-weight:600;transition:.15s}
.quick button:hover{border-color:var(--accent);transform:translateY(-2px)}
.quick button .ic{font-size:18px}
.quick button:active{transform:scale(.95)}

/* ---- badges ---- */
.badges{display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.badge{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;
  border:1px solid var(--line);position:relative}
.badge.on{border-color:var(--accent);box-shadow:0 0 14px rgba(63,185,132,.25)}
.badge.off{color:var(--dim);opacity:.45}
.badge .pop{position:absolute;inset:0;border-radius:50%;animation:pop .5s ease}
@keyframes pop{0%{transform:scale(.4);opacity:0}60%{transform:scale(1.15)}100%{transform:scale(1);opacity:1}}

/* ---- primary action ---- */
.cta{display:block;width:100%;text-align:center;font-family:var(--font);font-weight:700;font-size:14px;cursor:pointer;
  background:var(--accent);color:#08110C;border:none;border-radius:13px;padding:14px;margin-top:4px;transition:.15s}
.cta:hover{filter:brightness(1.06)}
.cta.ghost{background:transparent;color:var(--good);border:1px solid rgba(63,185,132,.4)}

/* ---- trends ---- */
.spark{display:flex;align-items:flex-end;gap:5px;height:120px;padding-top:8px}
.spark .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
.spark .col .b{width:100%;border-radius:5px 5px 0 0;background:linear-gradient(180deg,var(--good),rgba(63,185,132,.25));min-height:4px;transition:height .4s}
.spark .col .b.att{background:linear-gradient(180deg,var(--att),rgba(230,169,60,.25))}
.spark .col .d{font-size:9px;color:var(--dim)}
.stat-row{display:flex;gap:9px;margin-bottom:11px}
.stat{flex:1;background:var(--s1);border:1px solid var(--line);border-radius:14px;padding:13px}
.stat .n{font-size:24px;font-weight:700}
.stat .k{font-size:10px;color:var(--mut);margin-top:2px}
.delta{font-size:11px;font-weight:700}
.delta.up{color:var(--good)} .delta.down{color:var(--att)}

/* ---- history ---- */
.hist{display:flex;gap:11px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line)}
.hist:last-child{border-bottom:none}
.hist .ic{width:30px;height:30px;border-radius:9px;background:var(--s2);display:flex;align-items:center;justify-content:center;font-size:14px;flex:none}
.hist .t{font-size:13px}
.hist .when{font-size:10.5px;color:var(--dim);margin-top:1px}
.hist .v{margin-left:auto;font-size:12px;color:var(--mut)}

/* ---- section title ---- */
.sec-title{font-size:13px;font-weight:700;margin:18px 2px 9px}
.empty{color:var(--mut);font-size:12.5px;text-align:center;padding:30px 10px}

/* ---- bottom tab bar ---- */
.tabs{position:absolute;left:0;right:0;bottom:0;display:flex;background:rgba(14,17,22,.96);
  backdrop-filter:blur(8px);border-top:1px solid var(--line)}
.tabs button{flex:1;background:none;border:none;cursor:pointer;color:var(--mut);font-family:var(--font);
  padding:11px 0 16px;font-size:10px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:4px}
.tabs button .ic{font-size:17px}
.tabs button.active{color:var(--txt)}
.tabs button.active .ic{filter:drop-shadow(0 0 6px rgba(63,185,132,.5))}

/* ---- toast ---- */
.toast{position:absolute;left:50%;bottom:84px;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--s3);border:1px solid var(--line);color:var(--txt);font-size:12.5px;font-weight:600;
  padding:10px 16px;border-radius:999px;pointer-events:none;transition:.3s;white-space:nowrap;z-index:30}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---- utility ---- */
.tiny{font-size:10.5px;color:var(--dim);text-align:center;margin-top:12px}
.linkrow{display:flex;gap:8px;margin-top:6px}
.linkrow .cta{margin-top:0}

/* ============ GAME LAYER ============ */

/* level + XP bar (always visible in header area) */
.levelband{background:linear-gradient(135deg,var(--s2),var(--s1));border:1px solid var(--line);
  border-radius:16px;padding:13px 15px;margin-bottom:14px;position:relative;overflow:hidden}
.levelband::after{content:'';position:absolute;inset:0;background:radial-gradient(120% 140% at 100% 0%,rgba(63,185,132,.16),transparent 55%);pointer-events:none}
.levelband .lv-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.lv-badge{display:flex;align-items:center;gap:9px}
.lv-num{width:30px;height:30px;border-radius:9px;background:var(--accent);color:#08110C;font-weight:800;
  font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 14px rgba(63,185,132,.4)}
.lv-name{font-size:14px;font-weight:700;line-height:1}
.lv-sub{font-size:10px;color:var(--mut);margin-top:2px}
.lv-xp{font-size:10.5px;color:var(--mut);font-weight:600}
.xpbar{height:9px;border-radius:9px;background:rgba(255,255,255,.07);overflow:hidden}
.xpbar > i{display:block;height:100%;width:0;border-radius:9px;
  background:var(--accent);box-shadow:0 0 10px rgba(255,255,255,.14)}
.flame{font-size:11px;font-weight:700;color:var(--att)}

/* daily quest */
.quest{position:relative;border:1px solid rgba(230,169,60,.4);background:linear-gradient(135deg,rgba(230,169,60,.10),var(--s1));
  border-radius:16px;padding:13px 15px;margin-bottom:11px;overflow:hidden}
.quest.done{border-color:rgba(63,185,132,.45);background:linear-gradient(135deg,rgba(63,185,132,.12),var(--s1))}
.quest .qh{display:flex;align-items:center;gap:7px;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--att);font-weight:700;margin-bottom:6px}
.quest.done .qh{color:var(--good)}
.quest .qt{font-size:13px;font-weight:600;line-height:1.4}
.quest .qreward{position:absolute;right:13px;top:13px;font-size:10px;font-weight:700;color:var(--att)}
.quest.done .qreward{color:var(--good)}
.quest .qprog{margin-top:9px;height:6px;border-radius:6px;background:rgba(255,255,255,.07);overflow:hidden}
.quest .qprog > i{display:block;height:100%;background:var(--att);border-radius:6px;transition:width .5s ease}
.quest.done .qprog > i{background:var(--good)}

/* SVG ring (animated) */
.ringsvg{transform:rotate(-90deg)}
.ringsvg .track{stroke:var(--s3);fill:none}
.ringsvg .prog{stroke:var(--accent);fill:none;stroke-linecap:round;
  filter:drop-shadow(0 0 6px rgba(63,185,132,.55));transition:stroke-dashoffset .9s cubic-bezier(.22,.61,.36,1)}
.ringcore{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}

/* entrance + micro animations */
@keyframes cardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.stagger > *{animation:cardIn .5s cubic-bezier(.22,.61,.36,1) both}
.stagger > *:nth-child(2){animation-delay:.05s}
.stagger > *:nth-child(3){animation-delay:.1s}
.stagger > *:nth-child(4){animation-delay:.15s}
.stagger > *:nth-child(5){animation-delay:.2s}
.stagger > *:nth-child(6){animation-delay:.25s}
.stagger > *:nth-child(7){animation-delay:.3s}
.stagger > *:nth-child(n+8){animation-delay:.35s}
@keyframes ckpop{0%{transform:scale(.2)}60%{transform:scale(1.25)}100%{transform:scale(1)}}
.row .ck.done{animation:ckpop .35s ease}
.quick button:active{transform:scale(.9)}
.cta:active{transform:scale(.97)}
.badge.on{animation:badgeglow 2.6s ease-in-out infinite}
@keyframes badgeglow{0%,100%{box-shadow:0 0 10px rgba(63,185,132,.2)}50%{box-shadow:0 0 18px rgba(63,185,132,.45)}}

/* confetti + celebration overlay */
#fxcanvas{position:absolute;inset:0;pointer-events:none;z-index:40}
.levelup{position:absolute;inset:0;z-index:45;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:rgba(5,7,10,.82);backdrop-filter:blur(4px);text-align:center;padding:24px;opacity:0;animation:luIn .4s ease forwards;cursor:pointer}
@keyframes luIn{to{opacity:1}}
.levelup .burst{width:96px;height:96px;border-radius:50%;background:var(--accent);color:#08110C;font-size:40px;font-weight:800;
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;animation:luPop .6s cubic-bezier(.22,1.4,.4,1);box-shadow:0 0 40px rgba(63,185,132,.6)}
@keyframes luPop{0%{transform:scale(.2);opacity:0}100%{transform:scale(1);opacity:1}}
.levelup .lu-k{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--good);font-weight:700}
.levelup .lu-name{font-size:30px;font-weight:800;margin:6px 0 4px}
.levelup .lu-sub{font-size:13px;color:var(--mut)}
.levelup .lu-tap{margin-top:22px;font-size:11px;color:var(--dim)}
