:root{--bg: #F4ECE0;--surface: #FCF7EF;--surface-2: #FBEFD9;--ink: #2E2620;--ink-2: #87796A;--ink-3: #978977;--line: rgba(50,38,24,.09);--accent: #E8A94E;--accent-2: #CE7E2E;--accent-ink: #231509;--good: #6F8B3C;--bad: #D2734A;--bad-2: #E0875E;--cat-1: #E8A94E;--cat-2: #6FA8A0;--cat-3: #D2734A;--cat-4: #6F8B3C;--cat-5: #B58BB0;--cat-6: #C77F86}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg)}body{font-family:Noto Sans TC,system-ui,sans-serif;color:var(--ink);-webkit-font-smoothing:antialiased}#root{min-height:100vh}input,select,textarea,button{font-family:inherit}.app-shell{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg);display:flex;flex-direction:column;position:relative}.page{flex:1;overflow-y:auto;padding:calc(env(safe-area-inset-top) + 18px) 18px 100px}.page-title{font-size:24px;font-weight:700;margin:0 0 18px}.card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:16px}.row{display:flex;align-items:center;justify-content:space-between;padding:13px 4px;border-bottom:1px solid var(--line)}.row:last-child{border-bottom:none}.label{font-size:14px;color:var(--ink-2)}.value{font-size:14.5px;font-weight:500}.muted{color:var(--ink-2)}.faint{color:var(--ink-3)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:14px;padding:14px 18px;font-size:15px;font-weight:700;cursor:pointer}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:disabled{opacity:.5;cursor:default}.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}.btn-block{width:100%}.tabbar{position:sticky;bottom:0;left:0;right:0;display:flex;align-items:flex-end;justify-content:space-around;padding:9px 14px calc(env(safe-area-inset-bottom) + 14px);background:#fbf6ee;border-top:1px solid var(--line)}.tab-item{display:flex;flex-direction:column;align-items:center;gap:4px;width:52px;color:var(--ink-3);text-decoration:none;font-size:10px}.tab-item.active{color:var(--accent-2);font-weight:700}.tab-fab{width:54px;height:54px;border-radius:18px;background:var(--accent);display:flex;align-items:center;justify-content:center;margin-top:-24px;box-shadow:0 10px 22px #e8a94e66;text-decoration:none}.seg{display:flex;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:4px;gap:4px}.seg-btn{flex:1;text-align:center;padding:9px 0;border-radius:11px;font-size:13.5px;font-weight:600;color:var(--ink-2);cursor:pointer;border:none;background:transparent}.seg-btn.active{background:var(--accent);color:var(--accent-ink)}.icon-chip{width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex:none}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;color:var(--ink-2);font-weight:600}.field input,.field select,.field textarea{border:1px solid var(--line);background:var(--surface);border-radius:12px;padding:12px 14px;font-size:15px;color:var(--ink)}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--accent)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;text-align:center}.cal-cell{position:relative;padding:8px 0 10px;font-size:13px;border-radius:10px;cursor:pointer}.cal-cell.selected{background:var(--accent);color:var(--accent-ink);font-weight:700}.cal-cell .dot{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:4px;height:4px;border-radius:50%;background:var(--bad)}.cal-cell.selected .dot{background:var(--accent-ink)}.empty{text-align:center;color:var(--ink-3);font-size:13.5px;padding:40px 0}.home-desktop{display:none}@media (min-width:900px){.home-mobile{display:none}.home-desktop{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:var(--bg)}}.desktop-sidebar{width:228px;flex:none;background:#efe6d8;border-right:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column}.desktop-main{flex:1;min-width:0;overflow-y:auto;padding:26px 30px}.desktop-nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink-2);margin-bottom:4px;text-decoration:none;font-size:14px}.login-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:24px;text-align:center}.login-logo{width:54px;height:54px;border-radius:16px;background:var(--accent-2);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #e8a94e4d}
