:root{--bg:#eef5ee;--card:#ffffffee;--ink:#183027;--muted:#6b7b73;--line:#d7e6dd;--green:#39c97d;--deep:#15251f;--soft:#e5f7ed;--warn:#fff4dc;--bad:#ffdede;--shadow:0 18px 55px rgba(18,46,33,.12);--r:26px}*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:radial-gradient(circle at 20% -10%,#fff 0,#f8fbef 30%,#edf6ef 70%,#eef5ee 100%)}body{overscroll-behavior-y:none}.app{max-width:520px;margin:0 auto;min-height:100svh;padding:18px 14px 96px}.hero{position:relative;padding:26px 18px;border-radius:32px;background:linear-gradient(155deg,#fafff9,#e8f6ef);box-shadow:var(--shadow);overflow:hidden}.hero:after{content:"";position:absolute;right:-50px;top:-40px;width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,#baf5d1,#ffffff00)}.top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.brand{display:flex;align-items:center;gap:12px}.logo{width:44px;height:44px;border-radius:16px;background:var(--deep);color:white;display:grid;place-items:center;font-weight:900;font-size:24px;letter-spacing:-1px}.brand b{display:block;font-size:19px}.brand span{display:block;color:var(--muted);font-size:12px}.pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#ffffffb8;border-radius:999px;padding:8px 10px;font-weight:800;font-size:12px}.h1{font-size:39px;line-height:.96;font-weight:900;letter-spacing:-1.8px;margin:8px 0 12px}.lead{font-size:16px;line-height:1.45;color:#415149;margin:0}.card{background:var(--card);border:1px solid rgba(196,220,207,.9);border-radius:var(--r);box-shadow:0 12px 42px rgba(26,64,43,.08);padding:18px;margin-top:14px}.card h2{font-size:22px;line-height:1.1;margin:0 0 10px;letter-spacing:-.5px}.card h3{font-size:16px;margin:0 0 10px}.muted{color:var(--muted);font-size:13px;line-height:1.45}.label{display:block;font-weight:800;font-size:13px;margin:14px 0 7px}.input,.select,.textarea{width:100%;border:1px solid var(--line);background:white;border-radius:18px;padding:15px 16px;font-size:16px;color:var(--ink);outline:none}.textarea{resize:vertical;min-height:110px}.input:focus,.select:focus,.textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(57,201,125,.14)}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.choices{display:grid;gap:9px}.choice{border:1px solid var(--line);background:#fff;border-radius:18px;padding:14px 13px;text-align:center;font-weight:800;color:#405148}.choice.active{border-color:var(--green);background:var(--soft);color:#163327}.btn{width:100%;border:0;border-radius:20px;padding:16px 18px;background:linear-gradient(180deg,#9ef1bf,#52cf88);color:#12251d;font-weight:900;font-size:16px;box-shadow:0 16px 34px rgba(52,191,113,.24);cursor:pointer}.btn:active{transform:translateY(1px)}.btn.secondary{background:#fff;border:1px solid var(--line);box-shadow:none}.btn.dark{background:var(--deep);color:white;box-shadow:none}.btn.warn{background:var(--warn);box-shadow:none}.btn.small{width:auto;padding:11px 13px;border-radius:15px;font-size:13px}.row{display:flex;gap:10px;align-items:center;justify-content:space-between}.today{padding:22px;border-radius:32px;background:linear-gradient(160deg,#173228,#1d4434);color:#fff;box-shadow:0 18px 44px rgba(15,45,31,.25);margin-top:14px}.today .muted{color:#cfe3d7}.meter{height:14px;background:rgba(255,255,255,.16);border-radius:999px;overflow:hidden;margin:18px 0}.meter span{display:block;height:100%;background:linear-gradient(90deg,#a2f3bd,#3bd081);width:0;border-radius:999px}.numbers{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.num{padding:12px;border-radius:18px;background:rgba(255,255,255,.1);text-align:center}.num b{display:block;font-size:23px}.num span{font-size:12px;color:#cfe3d7}.puffs{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}.puff{border:0;border-radius:20px;padding:17px 8px;font-weight:900;font-size:20px;background:white;color:#143023}.manual{display:flex;gap:10px;margin-top:10px}.manual input{flex:1}.manual button{width:132px}.tabs{position:fixed;left:50%;bottom:12px;transform:translateX(-50%);z-index:20;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;width:min(500px,calc(100vw - 20px));padding:7px;border-radius:24px;background:rgba(255,255,255,.86);backdrop-filter:blur(18px);box-shadow:0 10px 34px rgba(24,48,39,.15);border:1px solid rgba(210,228,218,.9)}.tab{border:0;background:transparent;border-radius:17px;padding:9px 3px;color:#718178;font-size:11px;font-weight:800}.tab.active{background:var(--deep);color:white}.history{display:grid;gap:8px}.barrow{display:grid;grid-template-columns:74px 1fr 50px;gap:10px;align-items:center}.bar{height:14px;background:#e8f1eb;border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;background:#74d99b;border-radius:999px}.procard{background:linear-gradient(155deg,#111f1a,#254535);color:white;border:0}.procard .muted{color:#cde0d6}.feature{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.12)}.feature:last-child{border-bottom:0}.check{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:#77df9d;color:#10261c;font-weight:900;flex:0 0 24px}.notice{padding:13px 14px;border-radius:18px;background:#f3f8f5;border:1px solid var(--line);font-size:13px;color:#526259;line-height:1.4}.notice.good{background:#e7f9ee;color:#173b29;border-color:#b9efce}.notice.bad{background:#fff0ee;color:#733127;border-color:#ffc9c2}.timer{font-size:54px;font-weight:900;letter-spacing:-2px;text-align:center;margin:14px 0}.triggergrid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.trigger{border:1px solid var(--line);background:white;border-radius:16px;padding:12px;font-weight:800}.links{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}.links a{color:#284238;background:#f2f7f4;border:1px solid var(--line);padding:9px 11px;border-radius:999px;text-decoration:none;font-size:12px;font-weight:800}.hide{display:none!important}.fade{animation:fade .18s ease-out}@keyframes fade{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:none}}@media(max-width:380px){.h1{font-size:34px}.app{padding-left:10px;padding-right:10px}.card{padding:15px}.numbers{gap:7px}.num b{font-size:20px}.puff{font-size:18px}.manual{display:block}.manual button{width:100%;margin-top:8px}.tabs{bottom:8px}.tab{font-size:10px}.grid2{grid-template-columns:1fr}}.legal{max-width:760px;margin:0 auto;padding:26px 14px 70px}.legal h1{font-size:38px;line-height:1;margin:10px 0 18px}.legal .card{background:white}.back{display:inline-flex;text-decoration:none;color:#173327;background:white;border:1px solid var(--line);border-radius:999px;padding:10px 14px;font-weight:900}.button{display:inline-flex;text-decoration:none;color:#10251d;background:#7ee2a2;border-radius:18px;padding:14px 16px;font-weight:900}.adminwrap{max-width:880px;margin:0 auto;padding:20px}.table{width:100%;border-collapse:collapse;font-size:13px}.table td,.table th{border-bottom:1px solid var(--line);padding:9px;text-align:left}pre{white-space:pre-wrap;word-break:break-word}
.pro-pill{background:linear-gradient(180deg,#111f1a,#254535);color:white;border-color:#254535}.route-card{background:linear-gradient(155deg,#fbfffb,#edf8f1)}.route-status{display:inline-flex;margin-top:6px;border-radius:999px;padding:8px 10px;font-size:12px;font-weight:900;border:1px solid var(--line);background:#fff}.route-status.on_track{background:#e7f9ee;color:#173b29;border-color:#b9efce}.route-status.hard_day{background:#fff4dc;color:#6c4712;border-color:#f4d38d}.route-status.ahead{background:#e7f3ff;color:#1d4875;border-color:#b8d9ff}.route-status.not_enough_data{background:#f3f8f5;color:#526259}.mini-kpi{min-width:86px;border-radius:20px;background:var(--deep);color:#fff;text-align:center;padding:10px 12px}.mini-kpi span{display:block;font-size:11px;color:#cfe3d7;font-weight:800}.mini-kpi b{font-size:28px;line-height:1}.mission-card{background:linear-gradient(155deg,#fffaf0,#f1fff5)}.mission-card p{font-size:17px;line-height:1.35;font-weight:900;margin:0}.hint{font-size:12px;line-height:1.35;color:var(--muted);margin:7px 2px 0}.recovery-box code{display:block;margin:8px 0;padding:11px;border-radius:14px;background:#fff;color:#173327;font-weight:900;letter-spacing:.7px}.plan .bar span{background:#a9c8b7}.barrow.plan{opacity:.72;margin-top:-4px}.adminwrap .brand span{font-size:12px}@media(max-width:380px){.mini-kpi{min-width:76px}.mini-kpi b{font-size:24px}.mission-card p{font-size:16px}}

/* 3.4.5 theme settings */
:root[data-accent="blue"]{--green:#5aa7ff;--soft:#e8f3ff;--deep:#12283f;--bg:#eef5fb;--line:#d5e4f4}
:root[data-accent="peach"]{--green:#ffb36c;--soft:#fff1e4;--deep:#352218;--bg:#fbf1ea;--line:#eedbcf}
:root[data-theme="dark"]{--bg:#0f1713;--card:#16231dee;--ink:#edf8f2;--muted:#9fb3a9;--line:#2b4236;--soft:#193426;--warn:#3b2f18;--bad:#43201f;--shadow:0 18px 55px rgba(0,0,0,.35)}
:root[data-theme="dark"] html,:root[data-theme="dark"] body,html[data-theme="dark"] body{background:radial-gradient(circle at 20% -10%,#24372d 0,#17241e 45%,#0f1713 100%)}
:root[data-theme="dark"] .card,:root[data-theme="dark"] .input,:root[data-theme="dark"] .select,:root[data-theme="dark"] .textarea,:root[data-theme="dark"] .trigger,:root[data-theme="dark"] .choice,:root[data-theme="dark"] .btn.secondary,:root[data-theme="dark"] .back{background:#16231d;color:var(--ink)}
:root[data-theme="dark"] .hero{background:linear-gradient(155deg,#17261f,#20392d)}
:root[data-theme="dark"] .links a{background:#16231d;color:#d8ede2}
:root[data-theme="dark"] .notice{background:#17251f;color:#b8cabf;border-color:#2b4236}
:root[data-theme="dark"] .procard{background:linear-gradient(155deg,#0a1110,#172b22)}


/* 3.4.5 readable product fix */
:root{color-scheme:light;--bg:#f2f7f3;--card:#ffffff;--ink:#14241d;--muted:#5e6f66;--line:#cbdcd2;--soft:#eef8f2;--shadow:0 14px 44px rgba(18,46,33,.10)}
body{background:#f2f7f3;color:var(--ink)}
.card,.notice,.input,.select,.textarea,.choice,.trigger,.btn.secondary{color:var(--ink);background:#fff;border-color:var(--line)}
.input::placeholder,.textarea::placeholder{color:#8a9a91}.muted{color:var(--muted)}
.notice.good{background:#eaf8ef;color:#173b29;border-color:#aadfbe}.notice.bad{background:#fff1ee;color:#6e2c22;border-color:#efb6ad}
.today,.procard{color:#fff}.today .muted,.procard .muted{color:#d9eadf}.today .pill{color:#fff}.pill{color:#183126;background:#fff}
.bar{border:1px solid #d8e6de}.table td,.table th{border-color:var(--line)}
.recovery-box code,.notice code{display:block;margin:8px 0;padding:11px;border-radius:14px;background:#f7fbf8;color:#173327;font-weight:900;letter-spacing:.7px;word-break:break-word}
.notice-pro{background:#f1fff5;border-color:#bdeccf}
a{color:#155f3a}.legal footer{color:#66776d;margin-top:24px}
:root[data-theme="dark"]{color-scheme:dark;--bg:#101813;--card:#17241e;--ink:#f1fbf5;--muted:#b8cac0;--line:#3d594a;--soft:#193426;--warn:#3b2f18;--bad:#43201f;--shadow:0 18px 55px rgba(0,0,0,.35)}
:root[data-theme="dark"] body{background:#101813;color:var(--ink)}
:root[data-theme="dark"] .card,:root[data-theme="dark"] .input,:root[data-theme="dark"] .select,:root[data-theme="dark"] .textarea,:root[data-theme="dark"] .trigger,:root[data-theme="dark"] .choice,:root[data-theme="dark"] .btn.secondary,:root[data-theme="dark"] .notice{background:#17241e;color:var(--ink);border-color:#3d594a}
:root[data-theme="dark"] .hero{background:linear-gradient(155deg,#17261f,#20392d)}
:root[data-theme="dark"] .links a{background:#17241e;color:#e3f2ea;border-color:#3d594a}
:root[data-theme="dark"] .notice.good{background:#183725;color:#ddf8e7;border-color:#2f7049}
:root[data-theme="dark"] .notice.bad{background:#3b1d19;color:#ffe0dc;border-color:#7a3a31}
:root[data-theme="dark"] .route-card,:root[data-theme="dark"] .mission-card,:root[data-theme="dark"] .notice-pro{background:#17241e;color:var(--ink)}
@media(max-width:430px){.app{padding-bottom:106px}.tabs{width:calc(100vw - 14px)}.top{align-items:flex-start}.h1{font-size:34px}.hero{padding:22px 16px}.card{border-radius:22px}.manual{display:block}.manual button{width:100%;margin-top:8px}.grid2{grid-template-columns:1fr}.triggergrid{grid-template-columns:1fr 1fr}.barrow{grid-template-columns:68px 1fr 42px}.links a{font-size:12px}}


/* 3.4.5 rc cleanup */
.mini-refresh{border:1px solid rgba(255,255,255,.24);background:rgba(255,255,255,.14);color:#fff;border-radius:999px;padding:9px 11px;font-size:12px;font-weight:900;white-space:nowrap}
.mini-refresh:active{transform:translateY(1px)}
@media(max-width:430px){.mini-refresh{padding:8px 9px;font-size:11px}.today .row{align-items:flex-start}}


/* 3.4.5 final readability and mobile stabilization */
html[data-theme="light"],:root[data-theme="light"]{color-scheme:light;--bg:#f4faf6;--card:#ffffff;--ink:#11251c;--muted:#52665c;--line:#c7dbd0;--soft:#edf8f1;--deep:#13281f;--shadow:0 12px 38px rgba(18,46,33,.10)}
html[data-theme="light"] body{background:#f4faf6;color:var(--ink)}
.card,.notice,.input,.select,.textarea,.choice,.trigger,.btn.secondary,.legal .card{background:#fff!important;color:var(--ink)!important;border-color:var(--line)!important}
.hero,.route-card,.mission-card,.notice-pro{color:var(--ink)!important;background:linear-gradient(155deg,#ffffff,#eef8f2)!important}
.hero .lead,.hero .muted,.route-card .muted,.mission-card .muted,.notice .muted,.card .muted{color:var(--muted)!important}
.procard,.today{color:#fff!important;background:linear-gradient(155deg,#10241c,#244633)!important}
.procard b,.today b,.procard h2,.today h2,.procard h3,.today h3{color:#fff!important}.procard .muted,.today .muted{color:#dbece3!important}
.input,.select,.textarea{min-height:52px;font-size:16px!important}.btn{min-height:52px}.btn.secondary.small,.btn.small{min-height:0}.btn.warn{background:#fff3da!important;color:#563b0b!important;border:1px solid #eed39e!important;box-shadow:none!important}
.links a{background:#fff!important;color:#183126!important}.pill{color:#183126!important}.pro-pill{color:#fff!important}
.row{flex-wrap:wrap}.row>*{min-width:0}.manual{align-items:stretch}.manual .input{min-width:0}.toast,.notice{overflow-wrap:anywhere}
.table{display:block;overflow-x:auto}.table tbody,.table thead{min-width:680px}.mini-refresh{background:rgba(255,255,255,.18)!important;color:#fff!important;border-color:rgba(255,255,255,.35)!important}
@media(max-width:430px){.app{max-width:none;width:100%;padding:14px 10px 112px}.top{gap:8px}.brand{min-width:0}.brand b{font-size:17px}.brand span{font-size:11px}.logo{width:40px;height:40px;border-radius:14px}.h1{font-size:32px;letter-spacing:-1.2px}.lead{font-size:15px}.card{padding:15px;margin-top:12px}.today{padding:18px;border-radius:26px}.numbers{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}.num{padding:10px 6px}.num b{font-size:20px}.num span{font-size:11px}.puffs{gap:7px}.puff{font-size:18px;padding:15px 6px}.manual{display:grid;grid-template-columns:1fr}.manual button{width:100%;margin-top:0}.grid2{grid-template-columns:1fr}.triggergrid{grid-template-columns:1fr 1fr}.tabs{bottom:8px;width:calc(100vw - 12px);border-radius:22px;padding:6px}.tab{font-size:10px;padding:9px 2px}.btn.small{width:100%;margin-top:6px}.notice .btn.small{width:100%}.barrow{grid-template-columns:64px 1fr 38px;gap:7px}.timer{font-size:48px}.legal h1{font-size:31px}.adminwrap{padding:12px}}

/* 3.4.6 history stability and readability */
.history-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0 14px}
.history-summary>div{border:1px solid var(--line);background:#f8fcf9;border-radius:18px;padding:11px 8px;text-align:center;min-width:0}
.history-summary b{display:block;font-size:20px;line-height:1.1;color:var(--ink)}
.history-summary span{display:block;margin-top:3px;font-size:11px;font-weight:800;color:var(--muted)}
.history-day{border:1px solid var(--line);background:#fff;border-radius:18px;padding:11px 10px;overflow:hidden}
.history-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.history-head b{font-size:14px;color:var(--ink)}
.history .barrow b{font-size:13px;text-align:right;color:var(--ink)}
.history .barrow .muted{font-size:12px;white-space:nowrap}
@media(max-width:430px){.history-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.history-summary>div{padding:9px 5px;border-radius:15px}.history-summary b{font-size:17px}.history-summary span{font-size:10px}.history-day{padding:10px 8px;border-radius:16px}.history-head{display:block}.history-head .muted{display:block;margin-top:3px}.history .barrow{grid-template-columns:46px 1fr 34px;gap:6px}.history .barrow .muted{font-size:11px}.history .barrow b{font-size:12px}}


/* 3.4.7 product polish: stable Pro badge, mobile polish, faster visual feedback */
.top{position:relative}.top>.pill{flex:0 0 auto;white-space:nowrap;max-width:104px;justify-content:center;line-height:1.05}.wait-pill{background:#fff4dc!important;color:#6c4712!important;border-color:#efd08a!important}.pro-soft{background:#f0fff5!important;color:#173b29!important;border-color:#b9efce!important}.pro-pill{box-shadow:0 8px 24px rgba(19,40,31,.16)}
button,.btn,.puff,.tab,.trigger,.mini-refresh{touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn,.puff,.trigger,.tab,.mini-refresh{transition:transform .08s ease,filter .12s ease}.btn:disabled{opacity:.55;cursor:not-allowed}
.card h2,.card h3,.today h2,.procard h2{overflow-wrap:anywhere}.brand{min-width:0}.brand>div:last-child{min-width:0}.brand span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:310px}.notice,.muted{overflow-wrap:anywhere}.history-day{box-shadow:0 6px 20px rgba(18,46,33,.05)}.bar span{min-width:3px}.route-card .notice,.mission-card{border-color:#c7e7d3!important}.manual .input{background:#fff!important;color:#11251c!important}
@media(max-width:430px){.top>.pill{max-width:92px;padding:8px 9px;font-size:11px}.brand span{max-width:190px}.today .row{gap:8px}.mini-refresh{max-width:100%;white-space:normal;text-align:center}.history-summary{margin-top:10px}.route-card .row{align-items:flex-start}.mini-kpi{margin-left:auto}.puffs{grid-template-columns:repeat(3,minmax(0,1fr))}.puff{min-width:0}.links{display:grid;grid-template-columns:1fr 1fr}.links a{text-align:center}}
@media(max-width:360px){.brand span{max-width:156px}.top>.pill{max-width:82px}.h1{font-size:30px}.timer{font-size:44px}.links{grid-template-columns:1fr}.history .barrow{grid-template-columns:42px 1fr 32px}}
