:root{--bg:#f7f0df;--bg-soft:#fffaf0;--card:#fffdf7;--ink:#21312d;--muted:#6e7b72;--brand:#1f7a6b;--brand-dark:#15594e;--accent:#f5b84b;--danger:#b65a4b;--line:#eadfc9;--shadow:0 18px 55px rgba(72,62,38,0.12)}*{box-sizing:border-box}html{background:var(--bg)}body,html{min-height:100%}body{margin:0;color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top left,rgba(245,184,75,.25),transparent 34rem),linear-gradient(180deg,#f9f3e4 0,var(--bg) 45%,#edf6ef 100%)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.shell{width:min(1080px,100%);margin:0 auto;padding:1rem}.topbar{align-items:center;display:flex;justify-content:space-between;gap:1rem;margin-bottom:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:5;background:rgba(247,240,223,.86);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);padding:.7rem 0}.brand,.danger,.ghost,.primary,.secondary{border:0;border-radius:999px;font-weight:800;min-height:44px;padding:.75rem 1rem}.brand{align-items:center;background:transparent;color:var(--ink);display:inline-flex;gap:.45rem;font-size:1rem;padding-left:0}.ghost{background:#ffffff91;color:var(--brand-dark);border:1px solid var(--line)}.primary{background:var(--brand);color:#fff;box-shadow:0 10px 20px rgba(31,122,107,.18)}.secondary{background:#e4f4ee;color:var(--brand-dark)}.danger{background:#fde7df;color:var(--danger)}.back{margin-bottom:1rem}.card{background:rgba(255,253,247,.94);border:1px solid rgba(234,223,201,.9);border-radius:28px;box-shadow:var(--shadow);padding:1.1rem}.hero{margin-bottom:1.25rem}.hero h1{font-size:clamp(2.15rem,10vw,4.7rem);letter-spacing:-.07em;line-height:.95;margin:.3rem 0 1rem}.hero p{font-size:1.05rem;line-height:1.55;max-width:760px}h1,h2,h3,p{margin-top:0}p{color:var(--muted)}.eyebrow,.pill{color:var(--brand-dark);font-size:.76rem;font-weight:900;letter-spacing:.09em;text-transform:uppercase}.pill{background:#e9f6ef;border-radius:999px;display:inline-block;padding:.35rem .6rem}.grid{display:grid;grid-gap:1rem;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))}.inset{background:var(--bg-soft);box-shadow:none}.actions,.card-heading,.section-title,.stats{align-items:center;display:flex;gap:.75rem}.card-heading,.section-title{justify-content:space-between}.section-title{margin:1.25rem 0 .75rem}.actions,.stats{flex-wrap:wrap}.stat{background:#f6efdf;border-radius:20px;min-width:105px;padding:.8rem}.stat strong{display:block;font-size:1.25rem}.stat span{color:var(--muted);font-size:.82rem}.progress-block{margin:1rem 0}.progress-label{display:flex;justify-content:space-between;color:var(--muted);font-size:.9rem;margin-bottom:.35rem}.progress-track{background:#ebe1cc;border-radius:999px;height:13px;overflow:hidden}.progress-track span{background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:inherit;display:block;height:100%;transition:width .25s ease}.reward-preview{align-items:flex-start;background:#fff5d9;border:1px solid #f2deb0;border-radius:22px;display:flex;gap:.8rem;margin:1rem 0;padding:.9rem}.reward-preview span{font-size:1.8rem;line-height:1}.reward-preview p{margin:.2rem 0 0}.large span{font-size:2.3rem}.status{background:#f3ead8;border-radius:999px;color:#80663f;display:inline-flex;flex-shrink:0;font-size:.72rem;font-weight:900;padding:.38rem .6rem;text-transform:uppercase}.status.done{background:#dff4e9;color:#176247}.status.open{background:#e5f0ff;color:#285c9c}.status.locked{background:#f2e2e2;color:#9b463c}.list{display:grid;grid-gap:.8rem;gap:.8rem}.challenge-card{align-items:center;background:var(--card);border:1px solid var(--line);border-radius:24px;color:var(--ink);display:grid;grid-gap:.75rem;gap:.75rem;grid-template-columns:auto 1fr auto;padding:1rem;text-align:left;width:100%}.challenge-card small{color:var(--muted);display:block;line-height:1.45;margin-top:.2rem}.challenge-icon{font-size:1.45rem}.field{color:var(--ink);display:grid;font-weight:800;grid-gap:.45rem;gap:.45rem;margin:1rem 0}input,select,textarea{background:#fffaf0;border:1px solid var(--line);border-radius:18px;color:var(--ink);min-height:48px;padding:.85rem;width:100%}textarea{min-height:130px;resize:vertical}.message{border-radius:18px;font-weight:700;padding:.8rem}.message.good{background:#ddf6e8;color:#176247}.message.warn{background:#fff0d7;color:#8a5a12}.message.calm{background:#e8f0ff;color:#285c9c}.completed,.journal-entry{background:#f8f1e3;border-radius:20px;padding:.9rem}.completed p{color:var(--ink);font-weight:700;margin-bottom:.5rem}.completed small,.footer-note,.muted{color:var(--muted)}.journal-list{display:grid;grid-gap:.85rem;gap:.85rem}.journal-entry h3{margin:.5rem 0}.empty{text-align:center}@media (max-width:640px){.shell{padding:.8rem}.card{border-radius:22px;padding:1rem}.card-heading,.section-title{align-items:flex-start;flex-direction:column}.challenge-card{grid-template-columns:auto 1fr}.challenge-card .status{grid-column:2;justify-self:start}.danger,.primary,.secondary{width:100%}}.reward-image{align-items:center;background:linear-gradient(135deg,#fff9dc,#efe7ff);border:2px solid #f2deb0;border-radius:20px;display:grid;flex:0 0 auto;height:74px;justify-items:center;overflow:hidden;position:relative;width:74px}.reward-image img{height:100%;object-fit:cover;width:100%}.reward-image span{background:rgba(255,253,247,.82);border-radius:999px;bottom:.25rem;font-size:1.25rem;line-height:1;padding:.18rem;position:absolute;right:.25rem}.large .reward-image{height:96px;width:96px}.content-image,.discovery-photo img{border:1px solid var(--line);border-radius:22px;display:block;margin:1rem 0;max-height:320px;object-fit:cover;width:100%}.discovery-photo{margin:0}.discovery-photo figcaption{color:var(--muted);font-size:.82rem;font-weight:700}