:root{
  --bg:#0b1020; --bg2:#0e1530; --card:#141c3a; --card2:#1a2348; --edge:#26315e;
  --text:#eef2ff; --muted:#93a0c8; --mutedDk:#65719c;
  --accent:#22D3EE; --aura:rgba(34,211,238,.22); --mood2:#60A5FA;
  --disp:'Sora',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif;
}
/* ===== MOOD durumları — UI tonu buna göre değişir ===== */
body.mood-thriving{--accent:#34D399;--mood2:#22D3EE;--aura:rgba(52,211,153,.34)}
body.mood-good{--accent:#22D3EE;--mood2:#60A5FA;--aura:rgba(34,211,238,.24)}
body.mood-wobbly{--accent:#FBBF24;--mood2:#FB7185;--aura:rgba(251,191,36,.22)}
body.mood-low{--accent:#FB7185;--mood2:#94a3b8;--aura:rgba(248,113,113,.20)}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{min-height:100%}
body{font-family:var(--body);background:var(--bg);color:var(--text);line-height:1.5;
  -webkit-font-smoothing:antialiased;padding-bottom:84px;transition:filter .5s}
body.mood-low{filter:saturate(.82) brightness(.97)}
.aura{position:fixed;inset:0;z-index:-1;pointer-events:none;transition:background .6s;
  background:
    radial-gradient(820px 520px at 50% -8%, var(--aura), transparent 60%),
    radial-gradient(640px 520px at 92% 100%, var(--aura), transparent 62%),
    linear-gradient(180deg,var(--bg2),var(--bg) 40%)}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}
.wrap{max-width:680px;margin:0 auto;padding:18px 16px 8px}

/* ===== HERO (büyüyen çayır + momentum halkası) ===== */
.hero{position:relative;overflow:hidden;border:1px solid var(--edge);border-radius:22px;min-height:208px;
  display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:0 0 0 1px rgba(255,255,255,.02), 0 18px 50px -20px var(--aura);transition:box-shadow .6s}
body.mood-thriving .hero{box-shadow:0 0 0 1px rgba(52,211,153,.25), 0 22px 60px -18px var(--aura)}
.garden{position:absolute;inset:0;z-index:0}
.garden svg{display:block;width:100%;height:100%}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(transparent 38%, rgba(7,11,20,.55) 74%, rgba(7,11,20,.9))}
.hero-ring{position:absolute;top:13px;right:13px;width:78px;height:78px;z-index:2}
.hero-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-trk{fill:none;stroke:rgba(255,255,255,.16);stroke-width:9}
.ring-bar{fill:none;stroke:var(--accent);stroke-width:9;stroke-linecap:round;
  stroke-dasharray:326.7;transition:stroke-dashoffset .7s cubic-bezier(.2,.8,.2,1),stroke .5s;
  filter:drop-shadow(0 0 5px var(--accent))}
.ring-mid{position:absolute;inset:0;display:grid;place-items:center;flex-direction:column;line-height:1}
.ring-mid b{font-family:var(--disp);font-weight:800;font-size:21px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6)}
.ring-mid span{font-size:10px;color:rgba(255,255,255,.85);font-weight:700}
.hero-txt{position:relative;z-index:2;padding:16px 18px}
.hero-em{font-size:24px;line-height:1;filter:drop-shadow(0 1px 4px rgba(0,0,0,.5))}
.hero-txt h1{font-family:var(--disp);font-weight:800;font-size:clamp(19px,5vw,25px);margin:3px 0 4px;letter-spacing:-.01em;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.55)}
.hero-txt p{color:rgba(238,242,255,.9);font-size:13.5px;text-shadow:0 1px 6px rgba(0,0,0,.5)}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px}
.chip{background:rgba(8,12,24,.5);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:5px 11px;font-size:12px;font-weight:600;color:rgba(238,242,255,.85);backdrop-filter:blur(3px)}
.chip b{color:#fff;font-family:var(--disp)}
.plant{transform-origin:center bottom}
.plant.sprout{animation:sprout .55s cubic-bezier(.2,1.3,.4,1) both}
@keyframes sprout{0%{transform:scaleY(0) scaleX(.4);opacity:0}60%{opacity:1}100%{transform:scale(1)}}

/* ===== bölüm başlığı ===== */
.sec-h{font-family:var(--disp);font-weight:700;font-size:15px;margin:24px 4px 12px;letter-spacing:.01em}
.sec-h .muted{font-weight:500;font-size:13px}

/* ===== BUGÜN listesi ===== */
.hlist{display:flex;flex-direction:column;gap:10px}
.hcard{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--edge);
  border-radius:18px;padding:13px 15px;transition:border-color .2s,background .2s,transform .1s}
.hcard.done{border-color:color-mix(in srgb,var(--c) 60%,var(--edge));background:color-mix(in srgb,var(--c) 12%,var(--card))}
.hcard{cursor:pointer}
.hcard:active{transform:scale(.99)}
.hcard.pop{animation:pop .4s}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.015)}100%{transform:scale(1)}}
.check{position:relative;width:54px;height:54px;flex:none;border:none;cursor:pointer;border-radius:16px;
  background:rgba(255,255,255,.05);border:2px solid var(--edge);display:grid;place-items:center;transition:.18s}
.check .emoji{font-size:24px;transition:.18s}
.check .tick{position:absolute;inset:0;display:grid;place-items:center;font-size:26px;font-weight:800;color:#06131f;opacity:0;transform:scale(.5);transition:.2s}
.hcard.done .check{background:var(--c);border-color:var(--c);box-shadow:0 8px 22px -8px var(--c)}
.hcard.done .check .emoji{opacity:0;transform:scale(.5)}
.hcard.done .check .tick{opacity:1;transform:scale(1)}
.check:active{transform:scale(.92)}
.hmeta{min-width:0;flex:1}
.hname{font-weight:700;font-size:16px}
.hsub{display:flex;align-items:center;gap:12px;margin-top:3px;font-size:12.5px;color:var(--muted)}
.flame{font-weight:700;color:var(--accent)}
.hcard:not(.done) .flame{color:var(--muted)}
.wkdots{display:flex;gap:4px;margin-left:auto}
.wkdots i{width:8px;height:8px;border-radius:3px;background:rgba(255,255,255,.1)}
.wkdots i.on{background:var(--c)}
.empty{color:var(--muted);text-align:center;padding:26px;border:1px dashed var(--edge);border-radius:16px}
.empty a{color:var(--accent);font-weight:700}

/* ===== ISI HARİTASI ===== */
.heat{margin-top:6px}
.heatgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;background:var(--card);border:1px solid var(--edge);border-radius:16px;padding:14px}
.hc{aspect-ratio:1;border-radius:5px;background:rgba(255,255,255,.06)}
.hc.lv0{background:rgba(255,255,255,.06)}
.hc.lv1{background:color-mix(in srgb,var(--accent) 25%,transparent)}
.hc.lv2{background:color-mix(in srgb,var(--accent) 50%,transparent)}
.hc.lv3{background:color-mix(in srgb,var(--accent) 75%,transparent)}
.hc.lv4{background:var(--accent)}
.heatlegend{display:flex;align-items:center;gap:5px;justify-content:flex-end;margin-top:8px;color:var(--mutedDk);font-size:11px}
.heatlegend .hc{width:13px;height:13px;aspect-ratio:auto}

/* ===== HAFTA ızgarası ===== */
.weeknav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:6px 0 14px}
.wlabel{font-family:var(--disp);font-weight:700;font-size:15px}
.wbtn{width:40px;height:40px;border-radius:12px;border:1px solid var(--edge);background:var(--card);display:grid;place-items:center;font-size:22px;color:var(--text)}
.wbtn.dis{opacity:.35;pointer-events:none}
.wgrid{display:flex;flex-direction:column;gap:7px}
.wrow{display:grid;grid-template-columns:1.5fr repeat(7,1fr) .7fr;align-items:center;gap:6px;background:var(--card);border:1px solid var(--edge);border-radius:14px;padding:9px 10px}
.wrow.whead{background:transparent;border:none;padding:0 10px;color:var(--mutedDk)}
.wday{text-align:center;font-size:11px;font-weight:700}
.wname{display:flex;align-items:center;gap:7px;font-weight:600;font-size:13.5px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wname span{font-size:17px}
.wcell{aspect-ratio:1;max-width:34px;margin:0 auto;width:100%;border-radius:9px;background:rgba(255,255,255,.05);
  border:1px solid var(--edge);display:grid;place-items:center;cursor:pointer;transition:.15s}
.wcell i{width:10px;height:10px;border-radius:50%;background:transparent;transition:.15s}
.wcell.done{background:var(--c);border-color:var(--c)}
.wcell.done i{background:#06131f;width:7px;height:7px}
.wcell.istoday{outline:2px solid var(--accent);outline-offset:1px}
.wcell.future{opacity:.3;pointer-events:none}
.wcell.pop{animation:pop .4s}
.wsum{text-align:center;font-size:12px;color:var(--muted)}
.wsum b{color:var(--text);font-family:var(--disp)}

/* ===== YÖNET + modal ===== */
.mrow{display:flex;align-items:center;gap:13px;background:var(--card);border:1px solid var(--edge);border-radius:16px;padding:12px 14px}
.mrow.arch{opacity:.5}
.memoji{font-size:24px;width:44px;height:44px;flex:none;display:grid;place-items:center;border-radius:12px;background:color-mix(in srgb,var(--c) 16%,var(--card2))}
.mmeta{flex:1;min-width:0}
.tag{font-size:10px;background:var(--edge);color:var(--muted);padding:2px 7px;border-radius:6px;font-weight:700;vertical-align:middle}
.mact{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.mini{border:1px solid var(--edge);background:var(--card2);color:var(--text);border-radius:10px;padding:8px 13px;font-weight:600;font-size:13px;cursor:pointer}
.mini.ghost{background:transparent;color:var(--muted)}
.mini.go{background:var(--accent);border-color:var(--accent);color:#06131f}
.mini.danger{background:transparent;border-color:#5a2330;color:#fb7185}
.addbtn{margin-top:16px;width:100%;border:1.5px dashed var(--edge);background:transparent;color:var(--accent);
  border-radius:16px;padding:15px;font-weight:700;font-size:15px;cursor:pointer;font-family:var(--disp)}
.modal{position:fixed;inset:0;z-index:50;background:rgba(4,8,20,.6);backdrop-filter:blur(4px);display:none;align-items:flex-end;justify-content:center}
.modal.on{display:flex;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.sheet{background:var(--bg2);border:1px solid var(--edge);border-radius:22px 22px 0 0;width:100%;max-width:680px;padding:22px 18px 28px;animation:up .25s}
@keyframes up{from{transform:translateY(20px)}to{transform:none}}
.sheet-h{font-family:var(--disp);font-weight:700;font-size:17px;margin-bottom:6px}
.sheet label{display:block;color:var(--muted);font-weight:600;font-size:13px;margin:14px 0 7px}
.sheet input[type=text],.sheet input[name=name]{width:100%;background:var(--card);border:1px solid var(--edge);border-radius:12px;color:var(--text);font:inherit;font-size:16px;padding:12px 14px;outline:none}
.sheet input:focus{border-color:var(--accent)}
input[type=range]{width:100%;accent-color:var(--accent)}
.picks{display:flex;gap:8px;flex-wrap:wrap}
.pk{width:42px;height:42px;border-radius:12px;border:2px solid var(--edge);background:var(--card);font-size:20px;cursor:pointer;display:grid;place-items:center}
.pk.col{width:38px;height:38px}
.pk.on{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}
.row2{display:grid;gap:10px}
.sheet-act{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;flex-wrap:wrap}

/* ===== TABBAR ===== */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:40;display:flex;background:rgba(11,16,32,.92);
  backdrop-filter:blur(12px);border-top:1px solid var(--edge);padding:6px 6px calc(6px + env(safe-area-inset-bottom))}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border-radius:12px;
  color:var(--mutedDk);font-size:11px;font-weight:600;transition:.15s}
.tabbar a span{font-size:18px;line-height:1}
.tabbar a.on{color:var(--accent);background:rgba(255,255,255,.04)}

/* ===== LOGIN ===== */
.login-body{display:grid;place-items:center;min-height:100vh;padding-bottom:0}
.loginwrap{text-align:center;padding:30px;max-width:360px;width:100%}
.loginlogo{width:72px;height:72px;border-radius:20px;margin:0 auto 18px;display:grid;place-items:center;font-size:36px;
  background:linear-gradient(135deg,var(--accent),var(--mood2));box-shadow:0 16px 40px -10px var(--aura)}
.loginwrap h1{font-family:var(--disp);font-weight:800;font-size:24px}
.loginwrap form{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.loginwrap input{background:var(--card);border:1px solid var(--edge);border-radius:14px;color:var(--text);font:inherit;font-size:16px;padding:14px 16px;outline:none;text-align:center}
.loginwrap input:focus{border-color:var(--accent)}
.loginwrap button{background:linear-gradient(135deg,var(--accent),var(--mood2));border:none;color:#06131f;font-family:var(--disp);font-weight:800;font-size:17px;padding:14px;border-radius:14px;cursor:pointer}
.lerr{background:rgba(248,113,113,.15);border:1px solid rgba(248,113,113,.4);color:#fb7185;border-radius:12px;padding:10px;font-weight:600;font-size:14px;margin-top:14px}

/* ===== Kart ekstra: play ipucu + geri al ===== */
.playhint{margin-left:auto;align-self:center;color:var(--muted);opacity:.45;font-size:12px}
.hcard.done .playhint{color:var(--accent);opacity:.85}
.undo{background:none;border:none;color:var(--muted);font-size:11px;text-decoration:underline;cursor:pointer;padding:0;display:none}
.hcard.done .undo{display:inline}
.pk.vibe{width:auto;padding:0 13px;height:40px;font-size:12.5px;font-weight:700;color:var(--text)}
body.noscroll{overflow:hidden}

/* ===== ODAK SEANSI ===== */
.session{position:fixed;inset:0;z-index:60;display:none;--c:#22D3EE;
  background:radial-gradient(circle at 50% 28%, color-mix(in srgb,var(--c) 16%, #0a1224), #060a14 72%)}
.session.on{display:flex;align-items:center;justify-content:center;animation:fade .3s}
.sxn{text-align:center;padding:24px;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:440px;width:100%}
.sxn-close{position:absolute;top:16px;right:18px;width:44px;height:44px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.08);border:1px solid var(--edge);color:#fff;font-size:18px}
.sxn-vibe{font-family:var(--disp);font-weight:700;color:var(--c);letter-spacing:.03em;font-size:15px}
.orb{position:relative;width:min(64vw,230px);aspect-ratio:1;border-radius:50%;display:grid;place-items:center;margin:6px 0;
  background:radial-gradient(circle at 50% 38%, color-mix(in srgb,var(--c) 50%,#10162e), #0b1020 72%);
  box-shadow:0 0 80px -12px var(--c), inset 0 0 48px -12px color-mix(in srgb,var(--c) 70%,transparent)}
.orb::before{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid color-mix(in srgb,var(--c) 65%,transparent);
  opacity:.4;animation:halo 3.6s ease-in-out infinite}
.orb.paused::before{animation-play-state:paused}
@keyframes halo{0%,100%{transform:scale(1);opacity:.3}50%{transform:scale(1.07);opacity:.6}}
.orb.beat{animation:beatpop .24s ease-out}
@keyframes beatpop{0%{transform:scale(1)}34%{transform:scale(1.055)}100%{transform:scale(1)}}
.orb-em{font-size:clamp(48px,16vw,72px);line-height:1;filter:drop-shadow(0 4px 14px rgba(0,0,0,.55))}
.sxn-name{font-family:var(--disp);font-weight:800;font-size:23px}
.sxn-time{font-family:var(--disp);font-weight:800;font-size:clamp(44px,13vw,58px);font-variant-numeric:tabular-nums;letter-spacing:.02em}
.sxn-hint{color:var(--muted);font-size:14.5px;max-width:280px}
.sxn-act{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;justify-content:center}
