:root{--green-900:#1b3a2b;--green-700:#2f6b46;--green-600:#3a8159;--green-500:#4caf7a;--green-100:#e3f3ea;--green-50:#f1f9f4;--earth:#8a6d4b;--bg:#f7faf7;--surface:#fff;--text:#1d2b22;--muted:#5d7068;--border:#e1e9e3;--danger:#c0392b;--amber:#c77f1a;--radius:14px;--shadow:0 1px 3px #1b3a2b14, 0 6px 18px #1b3a2b0f;--nav-h:60px;--header-h:54px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}h1,h2,h3{margin:0;line-height:1.2}a{color:inherit;text-decoration:none}.app-shell{flex-direction:column;min-height:100%;display:flex}.app-header{z-index:20;height:var(--header-h);background:var(--green-700);color:#fff;box-shadow:var(--shadow);justify-content:space-between;align-items:center;padding:0 16px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:flex}.header-actions{align-items:center;gap:2px;display:flex}.sync-badge{padding:6px;font-size:1rem;line-height:1}.account-box{flex-direction:column;gap:10px;display:flex}.app-main{width:100%;max-width:760px;padding:16px 16px calc(var(--nav-h) + 24px);flex:1;margin:0 auto}.bottom-nav{z-index:20;height:var(--nav-h);background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);display:flex;position:fixed;bottom:0;left:0;right:0}.nav-tab{color:var(--muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;font-size:.7rem;display:flex}.nav-tab.active{color:var(--green-700);font-weight:600}.nav-icon{font-size:1.3rem;line-height:1}.page{flex-direction:column;gap:18px;display:flex}.page-title{font-size:1.5rem}.title-sub{color:var(--muted);font-size:1rem;font-weight:400}.page-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.head-actions{gap:8px;display:flex}.section{flex-direction:column;gap:10px;display:flex}.section-head{justify-content:space-between;align-items:baseline;display:flex}.section-head h2,.section h2{font-size:1.05rem}.muted{color:var(--muted)}.small{font-size:.82rem}.center{text-align:center}.grow{flex:1;min-width:0}.back{display:inline-block}.link{color:var(--green-700);cursor:pointer;background:0 0;border:none;padding:0;font-size:.9rem;font-weight:600}.link.danger{color:var(--danger)}.prose{white-space:pre-wrap;margin:0;line-height:1.5}.clamp{-webkit-line-clamp:2;line-clamp:2;color:var(--muted);-webkit-box-orient:vertical;margin:0;font-size:.9rem;display:-webkit-box;overflow:hidden}.btn,.btn-ghost{font:inherit;cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:999px;padding:9px 16px;font-weight:600}.btn{background:var(--green-600);color:#fff}.btn:active{background:var(--green-700)}.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}.btn.danger{background:var(--danger)}.btn-ghost.danger{color:var(--danger);border-color:#eccac5}.icon-btn{color:inherit;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px;font-size:1.1rem;line-height:1}.app-header .icon-btn.active{background:#ffffff2e}.btn-stack{flex-direction:column;gap:10px;display:flex}.btn-stack .btn,.btn-stack .btn-ghost{text-align:center}.stat-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:2px;padding:16px;display:flex}.stat-num{color:var(--green-700);font-size:1.8rem;font-weight:700}.stat-label{color:var(--muted);font-size:.82rem}.list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.list-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:10px;padding:12px 14px;display:flex}.list-row.column{flex-direction:column;align-items:stretch;gap:6px}.list-row-top{justify-content:space-between;align-items:baseline;gap:10px;display:flex}.card-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.bed-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);border-left:4px solid var(--green-500);flex-direction:column;gap:6px;padding:14px;display:flex}.bed-card-top{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.bed-card h3{font-size:1.05rem}.badge{background:var(--green-100);color:var(--green-900);white-space:nowrap;border-radius:999px;align-items:center;gap:4px;padding:3px 9px;font-size:.78rem;font-weight:600;display:inline-flex}.badge.overdue{color:var(--danger);background:#fbe4df}.meta-row{flex-wrap:wrap;gap:6px;display:flex}.meta-row.tight{gap:4px}.chip-row{flex-wrap:wrap;gap:8px;display:flex}.total-chip{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:.85rem}.total-chip strong{color:var(--green-700)}.quick-actions{flex-wrap:wrap;gap:8px;display:flex}.chip{font:inherit;background:var(--green-50);border:1px solid var(--green-100);color:var(--green-900);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;font-weight:600;display:inline-flex}.file-label{cursor:pointer}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.status-active{background:var(--green-500)}.status-finished{background:var(--amber)}.status-removed{background:#b0bcb5}.status-badge.status-active{background:var(--green-100);color:var(--green-900)}.status-badge.status-finished{color:#7a5310;background:#f6e8cf}.status-badge.status-removed{color:var(--muted);background:#e7ece8}.empty{text-align:center;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:6px;padding:36px 16px;display:flex}.empty-icon{font-size:2.4rem}.empty-title{margin:0;font-weight:700}.empty-hint{color:var(--muted);max-width:36ch;margin:0;font-size:.9rem}.empty-action{margin-top:8px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;display:grid}.photo-thumb{aspect-ratio:1;background:var(--green-50);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;padding:0;display:flex;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%;display:block}.photo-thumb-placeholder{font-size:1.4rem}.photo-input{flex-direction:column;gap:8px;display:flex}.photo-input-trigger{font:inherit;border:1px dashed var(--border);background:var(--green-50);border-radius:var(--radius);cursor:pointer;color:var(--green-900);padding:14px;font-weight:600}.photo-input-preview{flex-direction:column;gap:8px;display:flex}.photo-input-preview img{object-fit:cover;border-radius:var(--radius);width:100%;max-height:220px}.photo-input-actions{gap:8px;display:flex}.timeline{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.timeline-item{border-bottom:1px solid var(--border);grid-template-columns:90px 1fr;gap:12px;padding:12px 0;display:grid}.timeline-date{color:var(--muted);font-size:.8rem;font-weight:600}.timeline-body{flex-direction:column;gap:6px;display:flex}.timeline-body p{white-space:pre-wrap;margin:0;line-height:1.45}.tl-tag{color:var(--green-700);font-size:.75rem;font-weight:700}.entry-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:8px;padding:14px;display:flex}.entry-foot{justify-content:flex-end;display:flex}.task-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.check{border:2px solid var(--green-500);cursor:pointer;color:#fff;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:1px;font-size:.8rem;display:flex}.check.checked{background:var(--green-500)}.task-row.done{opacity:.7}.strike{color:var(--muted);text-decoration:line-through}.form{flex-direction:column;gap:14px;display:flex}.form label{color:var(--muted);flex-direction:column;gap:5px;font-size:.85rem;font-weight:600;display:flex}.form-row{gap:12px;display:flex}.form-row label{flex:1}.form input,.form select,.form textarea{font:inherit;color:var(--text);border:1px solid var(--border);background:var(--bg);border-radius:10px;width:100%;padding:10px 12px;font-weight:400}.form input:focus,.form select:focus,.form textarea:focus{outline:2px solid var(--green-500);outline-offset:-1px;background:#fff}.form textarea{resize:vertical}.form-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.modal-backdrop{z-index:50;background:#14231c73;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-card{background:var(--surface);border-radius:18px 18px 0 0;width:100%;max-width:540px;max-height:92vh;padding:0 18px 22px;animation:.2s slide-up;overflow-y:auto}.modal-head{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:4px;padding:16px 0 12px;display:flex;position:sticky;top:0}.modal-head h2{font-size:1.15rem}@keyframes slide-up{0%{opacity:.6;transform:translateY(20px)}}.notice{border-radius:10px;margin:0;padding:10px 12px;font-size:.88rem}.notice.ok{background:var(--green-100);color:var(--green-900)}.notice.err{color:var(--danger);background:#fbe4df}.danger{color:var(--danger)}.tabs{background:var(--green-50);border:1px solid var(--green-100);border-radius:999px;gap:6px;padding:4px;display:flex}.tab{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:999px;flex:1;padding:8px 12px;font-size:.9rem;font-weight:600}.tab.active{background:var(--surface);color:var(--green-700);box-shadow:var(--shadow)}.search-input{font:inherit;border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:999px;padding:10px 14px}.search-input:focus{outline:2px solid var(--green-500);outline-offset:-1px}.mini-select{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:4px 10px;font-size:.85rem}.quick-links{grid-template-columns:1fr 1fr;gap:12px;display:grid}.quick-link{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--green-900);box-shadow:var(--shadow);align-items:center;gap:8px;padding:14px;font-weight:600;display:flex}.catalog-card{background:var(--surface);border:1px solid var(--border);border-left:4px solid var(--green-500);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:4px;padding:14px;display:flex}.catalog-card-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.catalog-card p{margin:0;line-height:1.35}.catalog-trigger{text-align:center;width:100%;color:var(--green-900);border-style:dashed}.catalog-group{margin-bottom:12px}.catalog-group-head{text-transform:uppercase;letter-spacing:.03em;color:var(--muted);margin:10px 0 6px;font-size:.78rem}.catalog-pick-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.catalog-pick-row{text-align:left;background:var(--green-50);border:1px solid var(--green-100);cursor:pointer;width:100%;font:inherit;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;display:flex}.catalog-pick-main{flex-direction:column;flex:1;min-width:0;display:flex}.catalog-pick-sow{margin-top:2px}.catalog-pick-add{color:var(--green-600);font-size:1.4rem;font-weight:700;line-height:1}.bar-chart{align-items:flex-end;gap:10px;height:200px;padding:20px 0 0;display:flex}.bar-col{flex-direction:column;flex:1;min-width:0;height:100%;display:flex}.bar-track{flex:1;justify-content:center;align-items:flex-end;display:flex}.bar-fill{background:linear-gradient(var(--green-500), var(--green-600));border-radius:6px 6px 0 0;width:100%;max-width:56px;min-height:4px;position:relative}.bar-value{text-align:center;color:var(--green-700);font-size:.72rem;font-weight:700;position:absolute;top:-17px;left:0;right:0}.bar-label{text-align:center;color:var(--muted);margin-top:4px;font-size:.75rem}.timeline-year{margin-bottom:14px}.timeline-year-label{color:var(--green-700);margin-bottom:8px;font-size:.95rem}.nav-icon{position:relative}.nav-dot{background:var(--danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.65rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-10px}@media (width>=720px){.modal-backdrop{align-items:center}.modal-card{border-radius:18px}.stat-grid{grid-template-columns:repeat(4,1fr)}}
