:root{
  --bg:#f4efe7;
  --card:#fffdf8;
  --card2:#f8f1e7;
  --ink:#231f1a;
  --muted:#736b60;
  --line:#e5d8c9;
  --accent:#2c5d50;
  --accent2:#bf8154;
  --accent-soft:#e1eee9;
  --danger:#9f3d35;
  --good:#2f6f58;
  --shadow:0 18px 55px rgba(45,36,24,.12);
  --radius:26px;
  --safe-bottom: env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;min-height:100%;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif}
body{overflow-x:hidden}
button,input,select{font:inherit}
button{border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
#app{min-height:100vh}
.shell{max-width:520px;margin:0 auto;min-height:100vh;padding:18px 14px calc(92px + var(--safe-bottom));position:relative}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:4px 0 18px}
.brand{display:flex;align-items:center;gap:10px;font-weight:850;letter-spacing:-.04em;font-size:25px}
.logo{width:40px;height:40px;border-radius:14px;background:linear-gradient(145deg,#2c5d50,#132c26);display:grid;place-items:center;color:#fff;box-shadow:0 12px 28px rgba(44,93,80,.25);font-weight:900;font-size:23px;line-height:1}
.status-pill{border:1px solid var(--line);background:rgba(255,253,248,.7);border-radius:999px;padding:8px 11px;font-size:12px;color:var(--muted);white-space:nowrap;max-width:58%;overflow:hidden;text-overflow:ellipsis}
.card{background:var(--card);border:1px solid rgba(229,216,201,.85);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin:0 0 14px}
.card.flat{box-shadow:none;background:rgba(255,253,248,.72)}
.hero{padding:24px 20px 20px;border-radius:32px;background:radial-gradient(circle at 12% 0%,#fff8ef,transparent 46%),linear-gradient(160deg,#fffdf8 0%,#f3eadf 100%);box-shadow:var(--shadow);border:1px solid rgba(229,216,201,.9)}
.h1{font-size:31px;line-height:1.04;font-weight:900;letter-spacing:-.06em;margin:0 0 10px}
.h2{font-size:23px;line-height:1.1;font-weight:850;letter-spacing:-.045em;margin:0 0 8px}
.h3{font-size:17px;font-weight:850;letter-spacing:-.025em;margin:0 0 10px}
.muted{color:var(--muted);font-size:14px;line-height:1.45}
.small{font-size:12px;line-height:1.38;color:var(--muted)}
.grid{display:grid;gap:10px}.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:repeat(3,1fr)}
.field{display:grid;gap:7px;margin:0 0 12px}.field label{font-weight:800;font-size:13px;color:#342f28}.field input,.field select{width:100%;min-height:50px;border:1px solid var(--line);border-radius:18px;background:#fffaf3;color:var(--ink);padding:0 14px;outline:none}.field input:focus,.field select:focus{border-color:rgba(44,93,80,.55);box-shadow:0 0 0 4px rgba(44,93,80,.09)}.field input::placeholder{color:transparent}.hint{font-size:12px;color:var(--muted);margin-top:-5px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:0 16px;border-radius:18px;font-weight:850;letter-spacing:-.015em;background:#ede3d5;color:var(--ink);width:100%}.btn.primary{background:var(--accent);color:#fff;box-shadow:0 16px 30px rgba(44,93,80,.22)}.btn.ghost{background:transparent;border:1px solid var(--line)}.btn.soft{background:var(--accent-soft);color:#194139}.btn.danger{background:#f7e2dc;color:var(--danger)}.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}
.tabs{position:fixed;z-index:20;left:50%;bottom:0;transform:translateX(-50%);width:100%;max-width:520px;padding:9px 11px calc(10px + var(--safe-bottom));background:rgba(244,239,231,.82);backdrop-filter:blur(16px);border-top:1px solid rgba(229,216,201,.8);display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.tab{height:56px;border-radius:17px;background:transparent;color:var(--muted);display:grid;place-items:center;font-size:11px;font-weight:800}.tab b{font-size:19px;line-height:17px}.tab.active{background:#fffdf8;color:var(--ink);box-shadow:0 8px 22px rgba(45,36,24,.08)}
.progress-wrap{display:grid;gap:11px;margin:16px 0}.bar{height:13px;border-radius:999px;background:#eadfce;overflow:hidden}.bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),#6ba28e);width:0%;transition:width .25s ease}.today-numbers{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.num{background:rgba(255,250,243,.85);border:1px solid var(--line);border-radius:20px;padding:12px;text-align:center}.num strong{display:block;font-size:24px;letter-spacing:-.04em}.num span{font-size:12px;color:var(--muted);font-weight:750}.puff-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:15px 0 10px}.puff{min-height:70px;border-radius:24px;background:#2c5d50;color:#fff;font-size:24px;font-weight:900;box-shadow:0 15px 28px rgba(44,93,80,.22)}.puff:nth-child(2){background:#366a5c}.puff:nth-child(3){background:#477a69}.manual-row{display:grid;grid-template-columns:1fr 140px;gap:10px}.manual-row input{min-height:50px;border:1px solid var(--line);border-radius:18px;background:#fffaf3;padding:0 14px;outline:none}.quote{font-weight:800;letter-spacing:-.02em;color:#3a332b;background:#f5ece0;border-radius:20px;padding:13px 14px}.over{color:var(--danger)}.good{color:var(--good)}
.timeline{display:grid;gap:9px}.day-row{display:grid;grid-template-columns:58px 1fr 48px;align-items:center;gap:10px;background:rgba(255,253,248,.72);border:1px solid var(--line);border-radius:18px;padding:10px}.mini-bar{height:9px;border-radius:999px;background:#eadfce;overflow:hidden}.mini-bar span{display:block;height:100%;border-radius:999px;background:var(--accent);width:0}.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:800;background:#efe4d5;color:#4e463c}.badge.pro{background:#1e3f37;color:#fff}.badge.lock{background:#f4e4d8;color:#8a5236}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.locked{position:relative;overflow:hidden}.locked:after{content:"Pro";position:absolute;right:14px;top:14px;background:#1e3f37;color:#fff;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:900}.trigger-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.trigger{border:1px solid var(--line);background:#fffaf3;border-radius:17px;min-height:46px;font-weight:800}.timer-circle{width:190px;height:190px;margin:10px auto 14px;border-radius:50%;background:radial-gradient(circle,#fffaf3 0 56%,transparent 57%),conic-gradient(var(--accent) var(--timer-deg,0deg),#eadfce 0);display:grid;place-items:center;box-shadow:inset 0 0 0 1px var(--line)}.timer-time{font-size:38px;font-weight:900;letter-spacing:-.06em}.pro-list{display:grid;gap:9px;margin:12px 0}.pro-item{display:flex;gap:10px;align-items:flex-start;background:#fffaf3;border:1px solid var(--line);border-radius:17px;padding:11px}.pro-item b{font-size:14px}.toast{position:fixed;z-index:60;left:50%;bottom:calc(92px + var(--safe-bottom));transform:translateX(-50%) translateY(16px);max-width:480px;width:calc(100% - 28px);background:#1e1b17;color:#fff;border-radius:18px;padding:13px 15px;font-weight:750;opacity:0;pointer-events:none;transition:.2s}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.install{background:#1e3f37;color:#fff;border-radius:28px;padding:18px;margin-bottom:14px;box-shadow:0 18px 40px rgba(30,63,55,.22)}.install .muted{color:rgba(255,255,255,.78)}.steps{display:grid;gap:8px;margin-top:10px}.step{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:16px;padding:10px 12px;font-weight:800}.footer-links{display:flex;flex-wrap:wrap;gap:9px;margin:14px 0 4px}.footer-links a{font-size:12px;color:var(--muted);border-bottom:1px solid rgba(115,107,96,.35)}
.empty{padding:20px;border:1px dashed var(--line);border-radius:20px;text-align:center;color:var(--muted);background:rgba(255,253,248,.5)}
.debug{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px;white-space:pre-wrap;background:#201b16;color:#f8ead7;border-radius:18px;padding:12px;overflow:auto;max-height:260px}.hidden{display:none!important}
@media (max-width:390px){.shell{padding-left:11px;padding-right:11px}.h1{font-size:28px}.today-numbers{gap:7px}.num{padding:10px 7px}.num strong{font-size:21px}.puff{min-height:64px}.manual-row{grid-template-columns:1fr}.tabs{gap:4px}.tab{height:54px;font-size:10px}}
@media (display-mode: standalone){.install{display:none}}
