/* ───────────────────────────────────────────────
   LUPO. Premium dark discipline tracker
─────────────────────────────────────────────── */
:root{
  --bg:#121726; --bg2:#0C1019;
  --card:#1B2132; --card2:#212a40; --card3:#2B3349;
  --gold:#F5B544; --gold2:#FFD37A;
  --gold-dim:rgba(245,181,68,0.16);
  --cream:#F0E9DA;
  --white:#EEF1F8; --gray:#9AA3B5; --gray2:#8E97AB; --gray3:#3A4459;
  --success:#34D17F; --danger:#F2685A;
  --border:rgba(255,255,255,0.08);
  --display:'Fredoka',-apple-system,system-ui,sans-serif;
  --body:'Nunito',-apple-system,system-ui,sans-serif;
  --mono:'Nunito',ui-monospace,monospace;
  --gold-lip:#C8902F; --success-lip:#1E9E5A; --danger-lip:#C24436;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
  --ease:cubic-bezier(.22,.61,.36,1);
  --spring:cubic-bezier(.34,1.56,.64,1);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;}
/* CRITICAL: make the hidden attribute always win over display:flex/grid */
[hidden]{display:none!important;}
html,body{height:100%;}
body{
  background:var(--bg);color:var(--white);font-family:var(--body);
  position:fixed;inset:0;overflow:hidden;overscroll-behavior:none;
}
#app{height:100%;width:100%;position:relative;max-width:520px;margin:0 auto;
  background:
    radial-gradient(120% 60% at 50% -10%,rgba(245,166,35,0.06),transparent 60%),
    var(--bg);
}
/* faint grain for depth */
#app::after{content:'';position:absolute;inset:0;pointer-events:none;z-index:1;opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
canvas{display:block;}

.screen{position:absolute;inset:0;z-index:2;}
.scroll{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;}
.scroll::-webkit-scrollbar{display:none;}
.spacer-bottom{height:130px;}

/* screen enter animation */
.screen.enter{animation:screenIn .42s var(--ease);}
@keyframes screenIn{from{opacity:0;transform:translateY(10px) scale(.99);}to{opacity:1;transform:none;}}
/* staggered child reveal */
.rise{opacity:0;animation:rise .5s var(--ease) forwards;}
@keyframes rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

/* ── Buttons ── */
/* Duolingo-style chunky 3D press button */
.btn-primary{
  position:relative;width:100%;height:56px;border:none;border-radius:16px;
  background:var(--gold);color:#231A06;
  font-family:var(--display);font-size:17px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  box-shadow:0 5px 0 0 var(--gold-lip);
  transition:transform .06s ease, box-shadow .06s ease, opacity .2s;
}
.btn-primary:active{transform:translateY(4px);box-shadow:0 1px 0 0 var(--gold-lip);}
.btn-primary:disabled{opacity:.4;}
.btn-primary.narrow{width:auto;padding:0 44px;height:54px;}
.btn-ghost{width:100%;height:50px;border-radius:14px;margin-top:30px;background:transparent;
  border:1px solid var(--gray3);color:var(--gray2);font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:1.5px;
  transition:border-color .2s,color .2s,background .2s;}
.btn-ghost:active{border-color:var(--danger);color:var(--danger);background:rgba(239,68,68,0.06);}

/* ─────────── ONBOARDING ─────────── */
.onboarding{display:flex;flex-direction:column;align-items:center;overflow:hidden;
  text-align:center;z-index:3;
  background:radial-gradient(ellipse 90% 55% at 50% 34%,rgba(245,166,35,0.09),transparent 70%),var(--bg);}
.ob-progress{position:absolute;top:calc(var(--safe-top) + 24px);left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:5;}
.ob-dot{width:7px;height:7px;border-radius:99px;background:var(--gray3);transition:width .35s var(--spring),background .35s;}
.ob-dot.active{width:24px;background:var(--gold);}
.ob-skip{position:absolute;top:calc(var(--safe-top) + 12px);right:14px;color:var(--gray);font-size:13px;z-index:5;padding:10px 12px;min-height:44px;display:inline-flex;align-items:center;}
.ob-page{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%;flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;justify-content:safe center;
  padding:calc(var(--safe-top) + 56px) 28px calc(var(--safe-bot) + 150px);animation:obIn .5s var(--ease);}
@keyframes obIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.ob-wolf-wrap{height:312px;width:100%;display:flex;align-items:center;justify-content:center;}
.ob-wolf-wrap.small{height:232px;}
.ob-title{font-family:var(--display);font-size:42px;font-weight:800;letter-spacing:-1.5px;line-height:1.02;}
.ob-title.small{font-size:34px;}
.ob-sub{font-size:15px;color:var(--gray);line-height:1.6;max-width:300px;}
.ob-tag{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--gold);letter-spacing:0.28em;margin-top:2px;}
.ob-input{width:100%;max-width:320px;height:62px;margin-top:6px;background:var(--card);
  border:1px solid var(--gray3);border-radius:16px;text-align:center;color:var(--white);
  font-family:var(--display);font-size:24px;font-weight:700;outline:none;transition:border-color .2s,box-shadow .2s;}
.ob-input:focus{border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-dim);}
.ob-footer{position:absolute;left:0;right:0;bottom:0;padding:0 28px calc(var(--safe-bot) + 38px);z-index:5;
  background:linear-gradient(180deg,transparent,var(--bg) 38%);}
.ob-habit-list{display:flex;flex-direction:column;gap:10px;width:100%;max-width:360px;margin-top:4px;}
.ob-habit{display:flex;align-items:center;gap:14px;padding:15px;border-radius:16px;background:var(--card);
  border:1px solid var(--border);text-align:left;transition:border-color .2s,background .2s,transform .12s var(--spring);}
.ob-habit:active{transform:scale(.97);}
.ob-habit-desc{display:flex;align-items:center;gap:8px;margin-top:5px;}
.ob-step{width:28px;height:28px;font-size:16px;}
.ob-val{font-size:13px;color:var(--gray);min-width:92px;text-align:left;}
.ob-habit.on{border-color:var(--gold);background:var(--gold-dim);}
.ob-habit-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--card3);flex-shrink:0;}
.ob-habit-body{flex:1;min-width:0;}
.ob-habit-name{font-size:15px;font-weight:700;}
.ob-habit-desc{font-size:12px;color:var(--gray2);margin-top:2px;}
.ob-check{width:27px;height:27px;border-radius:50%;border:2px solid var(--gray3);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .25s var(--spring),border-color .2s;}
.ob-habit.on .ob-check,.ob-habit.locked .ob-check{background:var(--gold);border-color:var(--gold);}
.ob-check svg{width:13px;height:10px;opacity:0;transform:scale(.4);transition:opacity .2s,transform .25s var(--spring);}
.ob-habit.on .ob-check svg,.ob-habit.locked .ob-check svg{opacity:1;transform:scale(1);}
.ob-lock{font-size:9px;font-family:var(--mono);color:var(--gold);letter-spacing:1px;margin-top:3px;}

/* ─────────── HOME ─────────── */
.app-main{height:100%;position:relative;z-index:2;}
.home-top{display:flex;align-items:center;justify-content:space-between;padding:calc(var(--safe-top) + 20px) 22px 10px;}
.home-name{font-family:var(--display);font-size:26px;font-weight:800;letter-spacing:0px;}
.home-date{font-size:12px;color:var(--gray);margin-top:1px;}
.streak-badge{display:flex;align-items:center;gap:6px;background:var(--gold-dim);border:1px solid rgba(245,166,35,0.3);
  border-radius:99px;padding:8px 14px;font-family:var(--mono);font-size:14px;font-weight:800;color:var(--gold);box-shadow:0 0 14px rgba(245,181,68,.18);}
.streak-badge .flame{display:inline-block;font-size:15px;transform-origin:50% 80%;animation:flameIdle 2.4s ease-in-out infinite;}
@keyframes flameIdle{0%,100%{transform:scale(1) rotate(0);}50%{transform:scale(1.12) rotate(-3deg);}}
.mood-msg{text-align:center;font-size:13.5px;font-style:italic;color:var(--cream);opacity:.8;padding:6px 34px 14px;line-height:1.5;}
.wolf-card{position:relative;margin:0 18px 18px;border-radius:26px;
  background:linear-gradient(180deg,#1C2334,#11151f);border:1px solid rgba(255,255,255,0.07);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.06),0 20px 50px rgba(0,0,0,0.5),0 0 60px rgba(245,166,35,0.05);
  padding:8px 0 18px;display:flex;flex-direction:column;align-items:center;overflow:hidden;}
.wolf-card::before{content:'';position:absolute;top:-40%;left:50%;transform:translateX(-50%);width:70%;height:70%;
  background:radial-gradient(ellipse at center,rgba(245,166,35,0.10),transparent 70%);pointer-events:none;}
.wolf-breathe{width:100%;display:flex;justify-content:center;}
.stage-line{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--gold);letter-spacing:2px;}
.stage-tag{font-size:11.5px;color:var(--gray);margin-top:6px;padding:0 40px;text-align:center;line-height:1.45;font-style:italic;}

.meter{margin:0 24px 14px;}
.meter-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px;}
.meter-label{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:1.2px;color:var(--gray2);}
.meter-val{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--gray);}
.meter-val.gold{color:var(--gold);}
.meter-track{height:11px;border-radius:99px;background:var(--card3);overflow:hidden;box-shadow:inset 0 2px 3px rgba(0,0,0,0.55);border:1px solid rgba(0,0,0,.25);}
.meter-fill{height:100%;border-radius:99px;width:0;transition:width .8s var(--ease);}
.meter-fill.gold{background:linear-gradient(90deg,var(--gold),var(--gold2));box-shadow:0 0 12px rgba(245,166,35,0.5);}
.meter-fill.energy{background:linear-gradient(90deg,var(--danger),var(--gold),var(--success));}

.quick-row{display:flex;gap:6px;margin:4px 18px 16px;padding:15px 8px;background:var(--card);border:1px solid var(--border);border-radius:18px;}
.quick-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;}
.quick-ico{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--card3);border:1px solid var(--gray3);transition:.3s var(--spring);}
.quick-ico.done{background:rgba(34,197,94,0.16);border-color:rgba(34,197,94,0.5);transform:scale(1.04);}
.quick-dot{width:5px;height:5px;border-radius:50%;background:var(--gray3);transition:.3s;}
.quick-dot.done{background:var(--gold);box-shadow:0 0 6px var(--gold);}

.cta-done{display:flex;align-items:center;justify-content:center;gap:8px;margin:0 18px;padding:18px;border-radius:18px;
  color:var(--gold);font-size:14px;font-weight:700;background:var(--gold-dim);border:1px solid rgba(245,166,35,0.25);}
.cta-log{display:block;width:auto;min-width:200px;max-width:300px;margin:18px auto 0;padding:0 44px;}
/* inline goal steppers on each habit card so you can tune sleep/focus/workout right where you see them */
.habit-card-target.adj{display:flex;align-items:center;gap:10px;margin-top:5px;}
.ht-step{width:30px;height:30px;border-radius:9px;background:var(--card3);border:1px solid var(--gray3);color:var(--gold);font-size:17px;font-weight:800;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .1s;}
.ht-step:active{transform:scale(.88);}
.ht-val{font-size:13px;color:var(--cream);min-width:96px;}
.count-ctl{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.habit-card-body>.count-ctl{margin-top:10px;}
.cup-step{width:30px;height:30px;border-radius:9px;background:var(--gold-dim);border:1px solid rgba(245,181,68,.4);color:var(--gold);font-size:18px;font-weight:800;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cup-step:active{transform:scale(.88);}
.cup-n{font-family:var(--mono);font-size:13px;font-weight:800;color:var(--gold);min-width:96px;text-align:center;}
.micro-lbl{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.14em;color:var(--gray2);width:38px;flex-shrink:0;}
/* add a habit (Today screen) */
.add-habit{margin-top:16px;}
.add-habit-h{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--gray2);margin:0 2px 10px;}
.add-habit-row{display:flex;flex-wrap:wrap;gap:8px;}
.add-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:13px;background:var(--card);border:1px solid var(--border);color:var(--cream);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:transform .12s,border-color .2s,background .2s;}
.add-chip:hover{border-color:var(--gold);}
.add-chip:active{transform:scale(.95);}
.add-plus{color:var(--gold);font-weight:800;font-size:16px;line-height:1;}
/* achievements */
.ach-count{font-family:var(--mono);font-size:10px;color:var(--gold);font-weight:700;letter-spacing:1px;}
.ach-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.ach{background:var(--card);border:1px solid var(--border);border-top:1px solid rgba(120,140,200,.10);border-radius:16px;padding:14px 12px;text-align:center;box-shadow:0 3px 0 #0A1027;}
.ach.locked{opacity:.45;}
.ach-ico{font-size:30px;line-height:1;}
.ach-name{font-family:var(--display);font-weight:700;font-size:14px;margin-top:7px;color:var(--gold);}
.ach.locked .ach-name{color:var(--gray);}
.ach-desc{font-size:11px;color:var(--gray);margin-top:3px;line-height:1.35;}
.ach-toast{position:fixed;left:50%;bottom:calc(var(--safe-bot) + 84px);transform:translateX(-50%) translateY(16px);z-index:120;display:flex;align-items:center;gap:12px;pointer-events:none;max-width:90vw;
  background:linear-gradient(135deg,#2A2138,#1B2132);border:1px solid rgba(245,181,68,.5);box-shadow:0 8px 28px rgba(0,0,0,.5),0 0 22px rgba(245,181,68,.22);
  padding:12px 18px;border-radius:16px;opacity:0;transition:opacity .35s,transform .35s;}
.ach-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.ach-toast .at-ico{font-size:30px;}
.ach-toast .at-txt{display:flex;flex-direction:column;line-height:1.25;font-family:var(--display);font-weight:700;font-size:15px;color:#fff;}
.ach-toast .at-txt b{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:1.5px;color:var(--gold);}

/* ─────────── page heads ─────────── */
.page-head{padding:calc(var(--safe-top) + 22px) 22px 18px;}
.page-title{font-family:var(--display);font-size:34px;font-weight:800;letter-spacing:-1px;}
.page-sub{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;color:var(--gray);margin-top:4px;}
.section-label{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:2px;color:var(--gray2);padding:0 22px;margin:26px 0 12px;}

/* ─────────── HABITS ─────────── */
.banner{display:flex;align-items:center;gap:10px;margin:0 20px 14px;padding:14px 16px;border-radius:14px;
  color:var(--success);font-weight:700;font-size:14px;background:rgba(34,197,94,0.1);border-left:3px solid var(--success);
  animation:rise .4s var(--ease);}
.habit-list{display:flex;flex-direction:column;gap:11px;padding:0 20px;}
.habit-card{display:flex;align-items:center;gap:14px;padding:16px;border-radius:18px;background:var(--card);
  border:1px solid var(--border);border-left:3px solid var(--gray3);transition:border-color .25s,transform .14s var(--spring),background .25s;}
.habit-card:active{transform:scale(.985);}
.habit-card.done{border-left-color:var(--success);background:linear-gradient(90deg,rgba(34,197,94,0.06),var(--card) 40%);}
.habit-card-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:23px;flex-shrink:0;background:var(--card3);}
.habit-card-body{flex:1;min-width:0;}
.habit-card-name{font-size:15.5px;font-weight:700;}
.habit-card-target{font-size:13px;color:var(--gray);margin-top:2px;}
.habit-card-auto{font-size:11px;color:var(--gray2);font-style:italic;margin-top:3px;}
.habit-check{width:32px;height:32px;border-radius:50%;border:2px solid var(--gray3);flex-shrink:0;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 0 rgba(0,0,0,.28);transition:background .25s var(--spring),border-color .25s,transform .2s var(--spring),box-shadow .25s;}
.habit-check.checked{background:var(--success);border-color:var(--success);transform:scale(1.1);box-shadow:0 0 16px rgba(52,209,127,.5);}
.habit-check svg{width:15px;height:11px;opacity:0;transform:scale(.4);transition:opacity .2s,transform .3s var(--spring);}
.habit-check.checked svg{opacity:1;transform:scale(1);}
.completion-card{margin:20px 20px 0;padding:17px;border-radius:18px;background:var(--card);border:1px solid var(--border);}
#saveBtn{width:calc(100% - 40px);margin:20px;}

/* ─────────── STATS ─────────── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 20px;}
.stat-card{padding:17px;border-radius:18px;background:var(--card);border:1px solid var(--border);display:flex;flex-direction:column;gap:8px;}
.stat-card-head{display:flex;align-items:center;gap:7px;}
.stat-card-ico{font-size:13px;}
.stat-card-label{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:1.2px;color:var(--gray);}
.stat-card-val{font-family:var(--display);font-size:36px;font-weight:800;line-height:1;letter-spacing:-1px;}
.stat-card-sub{font-family:var(--mono);font-size:9px;letter-spacing:1px;color:var(--gray2);}
.growth-row{display:flex;gap:0;overflow-x:auto;padding:0 16px;}
.growth-row::-webkit-scrollbar{display:none;}
.growth-cell{display:flex;flex-direction:column;align-items:center;gap:8px;width:74px;flex-shrink:0;}
.growth-node{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--card2);border:1px solid var(--gray3);transition:.3s;}
.growth-node.cur{border:2px solid var(--gold);background:var(--gold-dim);box-shadow:0 0 16px rgba(245,166,35,0.35);}
.growth-node canvas{width:44px;height:44px;}
.growth-name{font-family:var(--mono);font-size:8px;font-weight:600;letter-spacing:.5px;color:var(--gray2);text-align:center;}
.growth-cell.ach .growth-name{color:var(--gray);}
.growth-cell.cur .growth-name{color:var(--gold);font-weight:700;}
.growth-link{flex:1;min-width:14px;height:2px;margin-top:28px;background:var(--gray3);}
.growth-link.ach{background:var(--gold);}
.heatmap{display:flex;gap:5px;padding:0 20px;overflow-x:auto;}
.heatmap::-webkit-scrollbar{display:none;}
.heat-cell{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;}
.heat-track{width:16px;height:54px;display:flex;align-items:flex-end;justify-content:center;}
.heat-bar{width:100%;min-height:5px;border-radius:4px;background:var(--card3);transform:scaleY(0);transform-origin:bottom;opacity:0;transition:transform .45s var(--spring),opacity .3s;}
.heat-bar.show{transform:scaleY(1);opacity:1;}
.heat-bar.today{box-shadow:0 0 0 2px var(--gold),0 0 8px rgba(245,181,68,.4);}
.heat-d{font-family:var(--mono);font-size:7px;color:var(--gray2);}
.week-list{display:flex;flex-direction:column;gap:8px;padding:0 20px;}
.week-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--card);border:1px solid var(--border);}
.week-day{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--gray);width:34px;}
.week-dots{display:flex;gap:7px;flex:1;}
.week-dot{width:8px;height:8px;border-radius:50%;background:var(--gray3);}
.week-none{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:1px;color:var(--gray);}
.week-empty{text-align:center;color:var(--gray);font-size:13px;line-height:1.5;padding:22px 18px;}
.week-end{font-size:14px;}
#resetBtn{width:calc(100% - 40px);margin:30px 20px 0;}

/* ─────────── TAB BAR ─────────── */
.tab-bar{position:absolute;left:0;right:0;bottom:0;height:calc(66px + var(--safe-bot));padding-bottom:var(--safe-bot);
  display:flex;background:rgba(13,17,27,0.9);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-top:1px solid var(--border);z-index:20;}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--gray2);transition:color .25s;position:relative;}
.tab span{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.6px;}
.tab-ico{width:24px;height:24px;fill:currentColor;transition:transform .3s var(--spring);}
.tab-ico.stroke{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.tab.active{color:var(--gold);}
.tab.active .tab-ico{transform:translateY(-2px) scale(1.12);}
.tab.active::before{content:'';position:absolute;top:0;width:30px;height:3px;border-radius:0 0 3px 3px;background:var(--gold);box-shadow:0 0 10px var(--gold);animation:tabPop .3s var(--spring);}
@keyframes tabPop{from{transform:scaleX(0);}to{transform:scaleX(1);}}

/* ─────────── STAGE UP ─────────── */
.stageup{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;overflow-y:auto;
  background:radial-gradient(ellipse at center,rgba(36,31,17,0.97),#0B0E15 80%);animation:fadeBg .4s ease;}
@keyframes fadeBg{from{opacity:0;}to{opacity:1;}}
.stageup-inner{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;position:relative;z-index:1;
  padding:calc(var(--safe-top) + 24px) 24px calc(var(--safe-bot) + 24px);max-height:100%;box-sizing:border-box;}
.su-bloom{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:30px;height:30px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(circle,rgba(255,246,222,.95),rgba(245,200,90,.45) 38%,transparent 70%);animation:bloom .9s ease-out forwards;}
@keyframes bloom{0%{transform:translate(-50%,-50%) scale(.2);opacity:1;}100%{transform:translate(-50%,-50%) scale(16);opacity:0;}}
.streak-big{display:flex;align-items:center;justify-content:center;gap:6px;font-family:var(--display);font-size:76px;font-weight:800;color:var(--gold);line-height:1;text-shadow:0 0 32px rgba(245,181,68,.55);}
.streak-big .streak-flame{font-size:56px;animation:flameIdle 2.2s ease-in-out infinite;}
.stageup-kicker{font-family:var(--display);font-size:40px;font-weight:800;letter-spacing:4px;color:var(--gold);
  text-shadow:0 0 30px rgba(245,166,35,0.6);animation:rise .5s var(--ease);}
.stageup-name{font-family:var(--mono);font-size:20px;font-weight:700;letter-spacing:3px;animation:rise .5s var(--ease) .1s both;}
.stageup-tag{font-size:13px;font-style:italic;color:var(--gray);max-width:300px;line-height:1.5;animation:rise .5s var(--ease) .2s both;}
#wolfStageUp{animation:popIn .6s var(--spring);}
@keyframes popIn{from{transform:scale(.4) rotate(-6deg);opacity:0;}to{transform:none;opacity:1;}}
#stageUpBtn{animation:rise .5s var(--ease) .3s both;}

/* confetti */
.confetti{position:absolute;width:9px;height:9px;border-radius:2px;top:40%;left:50%;pointer-events:none;}
.spark{position:fixed;z-index:60;color:var(--gold);font-size:14px;pointer-events:none;text-shadow:0 0 6px rgba(245,181,68,.8);will-change:transform,opacity;}

/* ── Duolingo-style chunky depth on cards + buttons ── */
.habit-card,.stat-card,.info-card,.tier-row,.manage-row,.week-row,.quick-row,.completion-card{
  border-radius:18px;box-shadow:0 3px 0 #0A1027,0 10px 22px rgba(0,0,0,0.34);border-top:1px solid rgba(120,140,200,0.10);}
.habit-card{border-radius:20px;}
.mini-btn{box-shadow:0 4px 0 var(--gold-lip);}
.mini-btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--gold-lip);}
.timer-pill{box-shadow:0 3px 0 rgba(245,181,68,.35);}
.timer-pill:active{transform:translateY(2px);box-shadow:0 1px 0 rgba(245,181,68,.35);}
.tab.active .tab-ico{transform:translateY(-3px) scale(1.16);}
.page-title{letter-spacing:0;}

/* launch splash */
#splash{position:fixed;inset:0;z-index:200;pointer-events:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  background:radial-gradient(120% 70% at 50% 40%,rgba(245,181,68,.10),transparent 60%),var(--bg);
  animation:splashOut .5s ease 1.1s forwards;}
#splash .splash-logo{width:118px;height:118px;border-radius:28px;box-shadow:0 20px 60px rgba(0,0,0,.5),0 0 70px rgba(245,181,68,.2);animation:splashPop .6s var(--spring);}
#splash .splash-name{font-family:var(--display);font-size:34px;font-weight:800;letter-spacing:2px;animation:rise .5s ease .15s both;}
#splash .splash-tag{font-family:var(--mono);font-size:11px;letter-spacing:.35em;color:var(--gold);animation:rise .5s ease .25s both;}
@keyframes splashPop{0%{transform:scale(.7);opacity:0;}60%{transform:scale(1.06);}100%{transform:scale(1);opacity:1;}}
@keyframes splashOut{to{opacity:0;visibility:hidden;}}

/* day-complete + tutorial overlays */
.oc-emoji{font-size:54px;animation:popIn .55s var(--spring);}
.oc-title{font-family:var(--display);font-size:27px;font-weight:800;letter-spacing:-.5px;}
.tut-step{font-family:var(--mono);font-size:11px;letter-spacing:2px;color:var(--gold);}
#tutWolf{display:flex;justify-content:center;}
#tutWolf .wolf-svg-el{height:184px;}

/* tap-to-pet sparks */
.pet-heart{position:absolute;top:54%;font-size:18px;color:var(--gold);pointer-events:none;z-index:3;text-shadow:0 0 8px rgba(245,181,68,.6);animation:heartUp 1.1s ease-out forwards;}
@keyframes heartUp{0%{opacity:0;transform:translateY(6px) scale(.5);}20%{opacity:1;}100%{opacity:0;transform:translateY(-72px) scale(1.25);}}

/* ─────────── real illustrated wolf image ─────────── */
.wolf-portrait{display:flex;align-items:center;justify-content:center;position:relative;width:100%;}
.wolf-img{height:200px;width:auto;max-width:92%;object-fit:contain;border-radius:26px;
  box-shadow:0 18px 44px rgba(0,0,0,0.55),0 0 64px rgba(245,166,35,0.12);
  animation:float 4.6s ease-in-out infinite;will-change:transform;}
@keyframes float{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-9px) scale(1.012);}}
.wolf-img.pop{animation:wolfPop .65s var(--spring);}
@keyframes wolfPop{0%{transform:scale(.82);}55%{transform:scale(1.1);}100%{transform:scale(1);}}
.ob-wolf-wrap .wolf-img{height:248px;}
.ob-wolf-wrap.small .wolf-img,.wolf-portrait.sm .wolf-img{height:176px;}

/* flat SVG wolf */
.wolf-svg{display:flex;align-items:center;justify-content:center;width:100%;}
.wolf-svg-el{height:212px;width:auto;overflow:visible;}
.w-all{transform-box:fill-box;transform-origin:50% 96%;animation:wBreathe 4.2s ease-in-out infinite;}
@keyframes wBreathe{0%,100%{transform:translateY(0);}50%{transform:translateY(-3px);}}
.w-eyes{transform-box:fill-box;transform-origin:center;animation:wBlink 5.4s infinite;}
@keyframes wBlink{0%,92%,100%{transform:scaleY(1);}96%{transform:scaleY(.08);}}
.w-tail{transform-box:fill-box;transform-origin:10% 90%;animation:wWag 1.7s ease-in-out infinite;}
@keyframes wWag{0%,100%{transform:rotate(-7deg);}50%{transform:rotate(10deg);}}
.w-head{transform-box:fill-box;transform-origin:50% 92%;animation:wHead 5.5s ease-in-out infinite;}
@keyframes wHead{0%,100%{transform:rotate(0) translateY(0);}50%{transform:rotate(-1.5deg) translateY(-1px);}}
.w-ear{transform-box:fill-box;transform-origin:50% 100%;animation:wEar 6.5s ease-in-out infinite;}
@keyframes wEar{0%,84%,100%{transform:rotate(0);}88%{transform:rotate(-5deg);}93%{transform:rotate(4deg);}}
.wolf-svg.pop .w-all{animation:wPop .65s var(--spring);}
@keyframes wPop{0%{transform:scale(.85);}55%{transform:scale(1.1);}100%{transform:scale(1);}}
.ob-wolf-wrap .wolf-svg-el{height:250px;}
.ob-wolf-wrap.small .wolf-svg-el,.wolf-portrait.sm .wolf-svg-el{height:184px;}
#wolfStageUp .wolf-svg-el{height:200px;}
.growth-img{width:50px;height:50px;display:flex;align-items:center;justify-content:center;}
.growth-img .wolf-svg-el{height:50px;}

/* ─────────── JOURNEY ─────────── */
.journey-hero{display:flex;flex-direction:column;align-items:center;padding:0 28px 6px;}
.journey-hero .wolf-svg-el{height:206px;}
.journey-level{font-family:var(--display);font-size:42px;font-weight:800;letter-spacing:-1.5px;line-height:1;}
.journey-tier{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--gold);letter-spacing:2px;margin-top:4px;}
.tier-list{display:flex;flex-direction:column;gap:9px;padding:0 20px;}
.tier-row{display:flex;align-items:center;gap:14px;padding:10px 14px;border-radius:16px;background:var(--card);border:1px solid var(--border);opacity:.8;transition:opacity .2s;}
.tier-row.reached{opacity:1;}
.tier-row.current{border-color:var(--gold);background:var(--gold-dim);box-shadow:0 0 18px rgba(245,166,35,.18);opacity:1;}
.tier-thumb{width:54px;height:54px;border-radius:13px;background:radial-gradient(circle at 50% 32%,rgba(245,181,68,.22),rgba(43,51,73,.95) 72%);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.tier-wolf{display:flex;align-items:center;justify-content:center;}
.tier-thumb .wolf-svg-el{height:52px;}
.tier-info{flex:1;min-width:0;}
.tier-name{font-size:15px;font-weight:700;}
.tier-lvl{font-family:var(--mono);font-size:10px;color:var(--gray);letter-spacing:1px;margin-top:2px;}
.tier-mark{font-size:14px;opacity:.9;}

/* winding "lesson path" of forms (Duolingo-style) */
.path{position:relative;padding:8px 0 14px;}
.path::before{content:'';position:absolute;left:50%;top:34px;bottom:48px;width:0;border-left:3px dashed rgba(245,181,68,.30);transform:translateX(-50%);}
.path-row{display:flex;margin-bottom:22px;position:relative;z-index:1;}
.path-row.left{justify-content:flex-start;padding-left:9%;}
.path-row.right{justify-content:flex-end;padding-right:9%;}
.path-node{position:relative;display:flex;flex-direction:column;align-items:center;gap:5px;width:122px;}
.node-disc{width:94px;height:94px;border-radius:50%;position:relative;overflow:visible;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 30%,rgba(245,181,68,.22),rgba(27,36,56,.96) 72%);
  border:3px solid var(--card3);box-shadow:0 4px 0 #0A1027;}
.path-node.reached .node-disc{border-color:var(--gold);box-shadow:0 0 16px rgba(245,181,68,.28),0 4px 0 var(--gold-lip);}
.path-node.current .node-disc{border-color:var(--gold2);animation:nodePulse 2.2s ease-in-out infinite;}
@keyframes nodePulse{0%,100%{box-shadow:0 0 0 0 rgba(245,181,68,.45),0 4px 0 var(--gold-lip);}70%{box-shadow:0 0 0 14px rgba(245,181,68,0),0 4px 0 var(--gold-lip);}}
.node-wolf{width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
.node-disc .wolf-photo{width:auto;height:auto;max-width:84%;max-height:96%;object-fit:contain;padding:0;border-radius:0;animation:none;filter:drop-shadow(0 3px 5px rgba(0,0,0,.5));}
.node-lock{border-radius:50%;}
.node-lock{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(11,15,28,.5);font-size:22px;}
.node-you{position:absolute;top:-11px;left:50%;transform:translateX(-50%);z-index:2;background:var(--gold);color:#121726;font-family:var(--mono);font-size:8px;font-weight:800;letter-spacing:1.5px;padding:3px 8px;border-radius:7px;box-shadow:0 2px 0 var(--gold-lip);animation:youBob 2.2s ease-in-out infinite;}
@keyframes youBob{0%,100%{transform:translateX(-50%) translateY(0);}50%{transform:translateX(-50%) translateY(-3px);}}
.node-name{font-family:var(--display);font-weight:700;font-size:15px;}
.path-node.locked .node-name{color:var(--gray2);}
.node-lvl{font-family:var(--mono);font-size:9px;color:var(--gold);letter-spacing:1.5px;font-weight:700;}
.path-node.locked .node-lvl{color:var(--gray2);}

/* ─────────── PROFILE ─────────── */
.info-card{margin:0 20px;padding:16px;border-radius:16px;background:var(--card);border:1px solid var(--border);}
.field-row{display:flex;gap:10px;align-items:center;}
.field-input{flex:1;height:46px;background:var(--card3);border:1px solid var(--gray3);border-radius:12px;color:#fff;padding:0 14px;font-size:16px;font-weight:600;outline:none;transition:border-color .2s;}
.field-input:focus{border-color:var(--gold);}
.mini-btn{height:42px;padding:0 18px;border-radius:12px;background:var(--gold);color:#0A0A0A;font-family:var(--mono);font-size:12px;font-weight:800;letter-spacing:1px;flex-shrink:0;transition:transform .12s;}
.mini-btn:active{transform:scale(.95);}
.mini-btn.ghost{background:transparent;border:1px solid var(--gray3);color:var(--gray2);margin-top:14px;width:100%;}
.mini-btn:disabled{opacity:.5;cursor:default;box-shadow:none;}
.ic-title{font-size:14px;font-weight:700;}
.ic-sub{font-size:12px;color:var(--gray);line-height:1.5;margin-top:4px;}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.about-line{text-align:center;font-family:var(--mono);font-size:10px;color:var(--gray);margin-top:22px;letter-spacing:1px;}
.legal-line{text-align:center;font-family:var(--mono);font-size:9px;color:var(--gray2);margin-top:8px;letter-spacing:.5px;}
.legal-line a{color:var(--gray2);text-decoration:none;display:inline-block;padding:6px 4px;}
.legal-line #buildTag{color:var(--gray);}
.manage-list{display:flex;flex-direction:column;gap:8px;padding:0 20px;}
.manage-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;background:var(--card);border:1px solid var(--border);}
.manage-ico{width:38px;height:38px;border-radius:11px;background:var(--card3);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.manage-name{flex:1;font-size:14px;font-weight:600;display:flex;align-items:center;}
.lock-tag{font-family:var(--mono);font-size:8px;color:var(--gold);letter-spacing:1px;border:1px solid rgba(245,166,35,.4);border-radius:6px;padding:2px 5px;margin-left:8px;}
.switch{width:48px;height:28px;border-radius:99px;background:var(--gray3);position:relative;flex-shrink:0;transition:background .25s;}
.switch::after{content:'';position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;transition:transform .25s var(--spring);}
.switch.on{background:var(--gold);}
.switch.on::after{transform:translateX(20px);}
.switch:disabled{opacity:.45;}
#resetBtn{width:calc(100% - 40px);margin:0 20px;}

/* wolf art uploader */
.art-slots{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:12px;}
.art-slot{position:relative;aspect-ratio:1;border-radius:12px;background:var(--card3);border:1px dashed var(--gray3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;overflow:hidden;}
.art-slot.filled{border-style:solid;border-color:var(--gold);}
.art-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.art-slot .as-plus{font-size:18px;color:var(--gray2);font-weight:700;}
.art-slot .as-lbl{position:relative;font-family:var(--mono);font-size:7px;color:var(--gray2);letter-spacing:.5px;}
.art-slot.filled .as-lbl{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.5);color:#fff;padding:2px 0;text-align:center;}
.wolf-photo{height:auto;width:auto;max-width:92%;object-fit:contain;border-radius:18px;animation:float 4.6s ease-in-out infinite;filter:drop-shadow(0 18px 40px rgba(0,0,0,.55));}
.wolf-card .wolf-photo,.journey-hero .wolf-photo{max-height:300px;}
.ob-wolf-wrap .wolf-photo{max-height:280px;}
.ob-wolf-wrap.small .wolf-photo,.wolf-portrait.sm .wolf-photo{max-height:208px;}
#wolfStageUp .wolf-photo{max-height:232px;}
#tutWolf .wolf-photo{max-height:210px;}
.tier-thumb .wolf-photo,.growth-img .wolf-photo{width:100%;height:100%;max-width:none;padding:4px;border-radius:11px;object-fit:contain;object-position:center bottom;animation:none;filter:drop-shadow(0 3px 5px rgba(0,0,0,.45));}

/* ── animated wolf scene (cutout on a live background) ── */
.scene{position:relative;width:100%;height:100%;min-height:300px;overflow:hidden;display:flex;align-items:flex-end;justify-content:center;
  padding-bottom:16px;box-sizing:border-box;border-radius:inherit;
  background:radial-gradient(125% 82% at 50% 14%,#1E2748 0%,#141A2E 46%,#0B0F1C 100%);}
/* ambient warm orb behind the wolf = a lit den, not flat dark */
.scene::before{content:'';position:absolute;top:5%;left:50%;width:80%;height:64%;transform:translateX(-50%);z-index:0;pointer-events:none;
  background:radial-gradient(circle at 50% 44%,rgba(245,181,68,.13),rgba(72,120,182,.06) 38%,transparent 70%);filter:blur(34px);}
/* corner vignette to frame the scene (sits below the wolf, above the sky) */
.scene::after{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(135% 116% at 50% 42%,transparent 54%,rgba(6,9,15,.55) 100%);}
/* sky tint shifts with the real time of day, all within the navy family */
.scene[data-tod="dawn"]{background:radial-gradient(125% 82% at 50% 14%,#3A2C46 0%,#1E1A2E 46%,#0C0A16 100%);}
.scene[data-tod="day"]{background:radial-gradient(125% 82% at 50% 14%,#26345E 0%,#18203A 46%,#0C1222 100%);}
.scene[data-tod="dusk"]{background:radial-gradient(125% 82% at 50% 14%,#3A2A42 0%,#1F1A30 46%,#0E0B18 100%);}
/* soft luminous moon: a glow that fades to nothing so it never reads as a hard disc or a clipped box */
.scene-moon{position:absolute;top:4%;left:50%;transform:translateX(-50%);width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle at 50% 46%,rgba(255,246,222,.95) 0%,rgba(248,214,128,.55) 26%,rgba(245,200,90,.20) 46%,transparent 70%);
  animation:moonGlow 6s ease-in-out infinite;pointer-events:none;}
@keyframes moonGlow{0%,100%{opacity:.85;}50%{opacity:1;}}
.scene-star{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.7);box-shadow:0 0 4px rgba(255,255,255,.6);animation:twinkle 4s ease-in-out infinite;}
@keyframes twinkle{0%,100%{opacity:.2;transform:scale(.7);}50%{opacity:.95;transform:scale(1);}}
/* grounded pool of light + a soft contact shadow so the wolf stands on something */
.scene-ground{position:absolute;bottom:0;left:0;right:0;height:40%;pointer-events:none;
  background:radial-gradient(ellipse 58% 70% at 50% 116%,rgba(245,181,68,.20),rgba(245,181,68,.06) 45%,transparent 72%);}
.scene-ground::after{content:'';position:absolute;bottom:34px;left:50%;transform:translateX(-50%);width:44%;height:15px;border-radius:50%;z-index:1;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.5),transparent 72%);filter:blur(2.5px);animation:shadowPulse 4.6s ease-in-out infinite;}
@keyframes shadowPulse{0%,100%{transform:translateX(-50%) scaleX(1);opacity:.9;}50%{transform:translateX(-50%) scaleX(.9);opacity:.62;}}
.mote{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(248,224,170,.55);filter:blur(.5px);pointer-events:none;z-index:1;animation:moteDrift 17s ease-in-out infinite;}
@keyframes moteDrift{0%{transform:translate(0,0);opacity:0;}16%{opacity:.6;}100%{transform:translate(10px,-74px);opacity:0;}}
/* distant pine treeline (two layers for depth) so the wolf stands in a night forest, not a void */
.scene-ridge{position:absolute;left:0;right:0;bottom:0;height:38%;z-index:0;pointer-events:none;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 34' preserveAspectRatio='none'><path d='M0 34 L0 17 L6 9 L12 16 L19 6 L26 15 L34 8 L42 16 L50 7 L58 16 L66 8 L74 15 L81 7 L88 15 L94 10 L100 16 L100 34 Z' fill='%23070B14'/></svg>") bottom/100% 100% no-repeat;}
.scene-ridge.back{height:46%;opacity:.55;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 30' preserveAspectRatio='none'><path d='M0 30 L0 15 L10 10 L18 15 L28 8 L38 14 L48 9 L58 15 L68 9 L78 14 L88 10 L100 15 L100 30 Z' fill='%23141C32'/></svg>") bottom/100% 100% no-repeat;}
:root{--wolf-rim:drop-shadow(0 -2px 2px rgba(248,224,170,.42)) drop-shadow(2px 0 2px rgba(120,150,210,.12)) drop-shadow(0 16px 20px rgba(0,0,0,.55));}
.wolf-cut{position:relative;z-index:2;width:auto;max-width:96%;object-fit:contain;display:block;cursor:pointer;
  filter:var(--wolf-rim);transition:filter .6s ease;
  animation:wolfIdle 4.6s ease-in-out infinite;transform-origin:50% 100%;}
/* the wolf brightens when you keep your streak and dims (recoverable) when neglected */
.scene[data-mood="thriving"] .wolf-cut{filter:var(--wolf-rim) saturate(1.08) brightness(1.06);}
.scene[data-mood="good"] .wolf-cut{filter:var(--wolf-rim) saturate(1.02) brightness(1.01);}
.scene[data-mood="neutral"] .wolf-cut{filter:var(--wolf-rim) saturate(.9) brightness(.97);}
.scene[data-mood="disappointed"] .wolf-cut{filter:var(--wolf-rim) saturate(.72) brightness(.9);}
.scene[data-mood="struggling"] .wolf-cut{filter:var(--wolf-rim) saturate(.55) brightness(.83);}
.scene[data-mood="thriving"]::before{opacity:1.1;}
.scene[data-mood="struggling"]::before,.scene[data-mood="disappointed"]::before{opacity:.4;}
@keyframes wolfIdle{0%,100%{transform:translateY(0) scaleY(1) rotate(0);}50%{transform:translateY(-4px) scaleY(1.014) scaleX(.995) rotate(.3deg);}}
.wolf-cut.pet{animation:wolfPet .6s var(--spring);}
@keyframes wolfPet{0%{transform:scale(.9);}55%{transform:scale(1.09) translateY(-8px);}100%{transform:scale(1);}}
/* wolf render heights kept well under the scene height so the FULL body (ears to paws) always shows with air, even at the top of the idle bob */
.wolf-card .scene{min-height:336px;} .wolf-card .wolf-cut{height:228px;}
.journey-hero .scene{min-height:336px;} .journey-hero .wolf-cut{height:228px;}
#wolfStageUp .scene{min-height:262px;} #wolfStageUp .wolf-cut{height:178px;}
#tutWolf .scene{min-height:246px;} #tutWolf .wolf-cut{height:166px;}
.ob-wolf-wrap .scene{min-height:300px;} .ob-wolf-wrap .wolf-cut{height:214px;}
.ob-wolf-wrap.small .scene,.wolf-portrait.sm .scene{min-height:224px;} .wolf-portrait.sm .wolf-cut{height:158px;}

/* film grain so the dark gradients read as filmic texture, not flat vector banding */
#grain{position:fixed;inset:0;z-index:80;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='140' height='140'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");}

/* ── Accessibility ── */
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:8px;}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
  .scene-star,.scene-moon,.wolf-cut,.mote,.scene-ground::after{animation:none!important;}
  .mote{opacity:0!important;}
  #grain{display:none!important;}
}

/* ─────────── TIMER ─────────── */
.timer-pill{height:42px;padding:0 16px;border-radius:13px;background:var(--gold-dim);border:1px solid rgba(245,181,68,.4);color:var(--gold);font-family:var(--mono);font-size:12px;font-weight:800;letter-spacing:.5px;flex-shrink:0;transition:transform .12s;}
.timer-pill:active{transform:scale(.95);}
.timer-pill.stop{background:rgba(242,104,90,.14);border-color:rgba(242,104,90,.5);color:var(--danger);min-width:78px;}
.habit-card-body>.timer-pill{display:flex;align-items:center;justify-content:center;width:100%;margin-top:11px;}
.habit-card.running{border-left-color:var(--gold);background:linear-gradient(90deg,rgba(245,181,68,.07),var(--card) 40%);}
.timer-card{display:flex;align-items:center;gap:14px;margin:0 20px 14px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,rgba(245,181,68,.13),var(--card));border:1px solid rgba(245,181,68,.32);animation:rise .4s var(--ease);}
.timer-ring{width:58px;height:58px;flex-shrink:0;transform:rotate(-90deg);}
.timer-ring .ring-bg{fill:none;stroke:var(--card3);stroke-width:6;}
.timer-ring .ring-fg{fill:none;stroke:var(--gold);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .95s linear;}
.timer-info{flex:1;min-width:0;}
.timer-name{font-size:13px;font-weight:700;}
.timer-clock{font-family:var(--mono);font-size:20px;font-weight:800;color:var(--gold);margin-top:1px;}
.timer-clock span{font-variant-numeric:tabular-nums;}
.timer-sub{font-size:11px;color:var(--gray);margin-top:2px;line-height:1.3;}
.timer-stop{height:38px;padding:0 14px;border-radius:11px;background:transparent;border:1px solid var(--gray3);color:var(--gray);font-family:var(--mono);font-size:11px;font-weight:700;flex-shrink:0;}
.timer-stop:active{border-color:var(--danger);color:var(--danger);}

/* ─────────── STEPPER / MANAGE (2-row) ─────────── */
.manage-row{display:flex;flex-direction:column;align-items:stretch;gap:10px;}
.manage-top{display:flex;align-items:center;gap:12px;}
.manage-bot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-left:50px;}
.manage-target{font-size:11.5px;color:var(--gray);}
.stepper{display:flex;align-items:center;background:var(--card3);border-radius:12px;overflow:hidden;border:1px solid var(--gray3);}
.step-btn{width:44px;height:44px;font-size:18px;font-weight:700;color:var(--gold);background:transparent;}
.step-btn:active{background:var(--gold-dim);}
.step-val{min-width:70px;text-align:center;font-family:var(--mono);font-size:12px;font-weight:700;color:#fff;}

/* ─────────── misc UI ─────────── */
.cta-done.partial{color:var(--cream);background:var(--card2);border-color:var(--border);}
.ob-hint{color:var(--gold);font-size:12.5px;font-weight:600;margin-top:10px;max-width:320px;}
.toast{position:fixed;left:50%;bottom:calc(var(--safe-bot) + 22px);transform:translateX(-50%) translateY(16px);
  max-width:min(420px,90vw);background:var(--danger);color:#fff;font-size:13px;font-weight:600;line-height:1.4;
  padding:13px 16px;border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:120;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
