:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f8f7;color:#121816;--panel: #ffffff;--line: #dce5e2;--muted: #65746f;--accent: #1f8fd3;--accent-strong: #0b69b3;--mint: #65dcb4;--warm: #ff7658;--danger: #b94242;--shadow: 0 14px 36px rgba(27, 47, 43, .1)}*{box-sizing:border-box}[hidden]{display:none!important}html,body{width:100%;height:100%;overflow:hidden;overscroll-behavior:none}body{margin:0;background:#e9efed;color:#121816;touch-action:manipulation}button,input,select,textarea{font:inherit}.app-shell{width:min(100vw,480px);height:100dvh;margin:0 auto;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:#f6f8f7;box-shadow:0 0 0 1px #1218160d;overflow:hidden}.app-topbar{position:relative;z-index:20;min-height:calc(56px + env(safe-area-inset-top));padding:env(safe-area-inset-top) 14px 0;display:grid;grid-template-columns:88px minmax(0,1fr) 88px;align-items:center;background:#fffffff0;border-bottom:1px solid rgba(220,229,226,.85);backdrop-filter:blur(18px)}.brand{color:#121816;font-weight:900;text-decoration:none}.profile-button{border:0;background:transparent;color:var(--accent-strong);font-weight:700;text-decoration:none}.topbar-title{margin:0;min-width:0;text-align:center;font-size:1.05rem;font-weight:850;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-left,.topbar-actions{display:flex;align-items:center;gap:8px}.topbar-actions{justify-content:flex-end}.app-content{min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;padding:14px 14px 18px}.bottom-nav{position:relative;z-index:30;min-height:calc(66px + env(safe-area-inset-bottom));padding:7px 12px env(safe-area-inset-bottom);display:grid;grid-template-columns:repeat(4,minmax(0,1fr));align-items:center;border-top:1px solid rgba(220,229,226,.92);background:#fffffff5;backdrop-filter:blur(18px)}.bottom-nav a{min-width:0;min-height:52px;display:grid;justify-items:center;align-content:center;gap:3px;color:#65746f;text-decoration:none;font-size:.76rem;font-weight:750}.bottom-nav a.is-active,.bottom-nav a:hover{color:#0b69b3}.bottom-nav span[aria-hidden=true]{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;font-size:1.35rem;line-height:1}.panel{border:1px solid var(--line);border-radius:8px;background:var(--panel)}.grid{display:grid;gap:16px}.field{display:grid;gap:6px}.field input,.field select,.field textarea{width:100%;min-height:38px;border:1px solid var(--line);border-radius:6px;padding:8px 10px;background:#fff}.primary,.secondary,.danger{min-height:42px;border-radius:8px;padding:9px 14px;display:inline-grid;place-items:center;text-decoration:none;font-weight:820}.primary{border:0;background:#1f8fd3;color:#fff}.secondary{border:1px solid #dce5e2;background:#fff;color:#18211b}.danger{border:1px solid #b94242;background:#fff;color:#b94242}.field-error{color:var(--danger);font-size:.85rem;min-height:1.1em}.auth-page{width:min(100vw,480px);height:100dvh;min-height:0;margin:0 auto;display:grid;background:#f6f8f7;overflow:hidden;box-shadow:0 0 0 1px #1218160d}.auth-shell{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr)}.auth-brandbar{min-height:calc(54px + env(safe-area-inset-top));padding:env(safe-area-inset-top) 14px 0;display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;background:#fffffff0;border-bottom:1px solid rgba(220,229,226,.85);backdrop-filter:blur(18px)}.auth-brandbar span{color:var(--muted);font-size:.92rem;font-weight:800}.auth-content{min-height:0;overflow:auto;-webkit-overflow-scrolling:touch;padding:18px 18px max(18px,env(safe-area-inset-bottom));display:grid;align-items:center}.auth-panel{width:100%;display:grid;justify-items:center;gap:12px;padding:8px 0;background:transparent;border:0}.auth-mark{display:grid;place-items:center;width:68px;height:68px;border-radius:20px;background:#fff1df;color:var(--warm);font-size:2.15rem;box-shadow:var(--shadow)}.auth-panel h1{margin:0;color:#18211b;font-size:2rem;line-height:1.08;text-align:center}.auth-panel p{margin:-4px 0 6px;color:var(--muted);font-size:.98rem;text-align:center}.auth-form{width:100%;gap:12px}.auth-form input{min-height:52px;border-radius:14px;padding:0 16px;background:#fff}.auth-form .primary{min-height:52px;border-radius:14px;background:var(--warm);font-size:1.04rem;font-weight:900}.auth-form .secondary{min-height:40px;border:0;background:transparent;color:#765746;text-align:center}@media(max-height:640px){.auth-content{align-items:start;padding-top:12px;padding-bottom:12px}.auth-panel{gap:8px}.auth-mark{width:54px;height:54px;border-radius:16px;font-size:1.7rem}.auth-panel h1{font-size:1.6rem}.auth-panel p{margin-bottom:2px;font-size:.9rem}.auth-form{gap:9px}.auth-form input,.auth-form .primary{min-height:46px}}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.page-head h1{margin:0;font-size:1.8rem}.icon-button{width:40px;height:40px;display:grid;place-items:center;border:1px solid rgba(220,229,226,.95);border-radius:50%;background:#fff;color:#18211b;text-decoration:none;font-weight:850}.timeline-hero{position:relative;display:grid;gap:18px;margin-bottom:22px}.timeline-hero h1{margin:16px 56px 0 0;font-size:clamp(2.4rem,8vw,4rem);line-height:1.05;font-weight:950}.filter-trigger{position:absolute;top:12px;right:0}.search-shell{display:grid;gap:0}.quick-search{display:flex;align-items:center;gap:10px;min-height:56px;padding:0 16px;border-radius:18px;background:#e2e8e6e0;color:#7b8582}.quick-search input{width:100%;border:0;outline:0;background:transparent;font-size:1.08rem;color:#121816}.quick-search input::placeholder{color:#7b8582}.filter-panel{position:fixed;top:88px;right:max(14px,calc((100vw - 760px)/2));z-index:40;display:none;width:min(560px,calc(100vw - 28px));max-height:calc(100vh - 120px);overflow:auto;padding:24px;border:1px solid rgba(220,229,226,.8);border-radius:28px;background:#fffdf4;box-shadow:var(--shadow)}.filter-panel.is-open{display:grid;gap:20px}body.filter-open:before{content:"";position:fixed;inset:0;z-index:35;background:#12181652}.drawer-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.drawer-head h2{margin:0;font-size:1.2rem}.compact{min-height:34px;padding:6px 12px}.sheet-backdrop{position:fixed;inset:0;z-index:40;display:none;background:#12181657}.sheet-backdrop.is-open{display:block}.bottom-sheet{position:fixed;left:50%;bottom:0;z-index:45;width:min(100vw,480px);max-height:min(78dvh,680px);transform:translate(-50%,100%);display:grid;grid-template-rows:auto minmax(0,1fr) auto;border-radius:18px 18px 0 0;background:#fff;box-shadow:0 -18px 44px #1218162e;transition:transform .18s ease;overflow:hidden}.bottom-sheet.is-open{transform:translate(-50%)}.sheet-head,.sheet-actions,.fixed-actions{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fff}.sheet-head{justify-content:space-between;border-bottom:1px solid #dce5e2}.sheet-body{min-height:0;overflow:auto;padding:14px}.sheet-actions,.fixed-actions{border-top:1px solid #dce5e2;padding-bottom:max(12px,env(safe-area-inset-bottom))}.fixed-actions{position:sticky;bottom:0;z-index:10}.fixed-actions>*{flex:1}.filter-groups{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.drawer-submit{justify-self:stretch;min-height:48px;border-radius:999px}.timeline-screen{display:grid;gap:12px}.type-chip-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.type-chip{flex:0 0 auto;min-height:36px;border:1px solid #dce5e2;border-radius:999px;padding:0 14px;background:#fff;color:#365141;font-weight:820}.type-chip.is-active{border-color:#121816;background:#121816;color:#fff}.timeline-list{position:relative;display:grid;gap:10px}.timeline-card{border:1px solid rgba(220,229,226,.9);border-radius:8px;background:#fff;box-shadow:0 6px 18px #1b2f2b0d}.timeline-card-link{display:grid;grid-template-columns:52px minmax(0,1fr);gap:10px;padding:12px;color:inherit;text-decoration:none}.avatar{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#c5eef2,#ffe0d7);font-weight:900}.timeline-card-body{display:grid;gap:12px;min-width:0}.timeline-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;color:var(--muted);font-size:.9rem}.timeline-card-top>div{display:grid;gap:3px;min-width:0}.timeline-card-top strong{color:#121816;font-size:1rem;overflow-wrap:anywhere}.timeline-card-top time{color:var(--muted)}.record-type{display:inline-flex;flex:0 0 auto;align-items:center;gap:5px;border:1px solid rgba(220,229,226,.88);border-radius:999px;padding:5px 9px;background:#f8fbf8;color:#365141;font-weight:700}.timeline-card h2{margin:0;font-size:1.08rem;line-height:1.25;overflow-wrap:anywhere}.tag-list{display:flex;flex-wrap:wrap;gap:8px;align-items:center;color:var(--muted);font-size:.88rem}.tag,.attachment-badge{border:1px solid var(--line);border-radius:999px;padding:3px 8px;background:#f8fbf8;color:#365141}.attachment-badge{background:#fff4ee;border-color:#ffd6c9;color:#985036}.empty-state{border:1px dashed var(--line);border-radius:8px;padding:28px;text-align:center;color:var(--muted);background:#ffffff8f}.people-layout{display:grid;gap:18px}.person-form{box-shadow:var(--shadow)}.person-form .field-error:empty{display:none}.person-form .sheet-actions>*{flex:1}.people-list{display:grid;gap:14px}.person-row{display:grid;grid-template-columns:78px minmax(0,1fr) 24px;align-items:center;gap:12px;border:1px solid var(--line);border-radius:16px;background:var(--panel);padding:16px}.person-avatar{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#ffe1dc,#d9f3ff);font-size:1.3rem;font-weight:900}.person-copy{display:grid;gap:4px;min-width:0}.person-copy strong{font-size:1.25rem}.person-copy span,.person-copy p{margin:0;color:var(--muted);overflow-wrap:anywhere}.person-arrow{color:#a4aaa8;font-size:2rem}.person-note-empty{opacity:.75}.me-layout{display:grid;gap:18px}.me-section{display:grid;gap:14px;padding:18px;border-radius:18px;box-shadow:var(--shadow)}.me-section h2{margin:0;font-size:1.22rem}.account-card{display:grid;grid-template-columns:68px minmax(0,1fr);gap:14px;align-items:center}.account-avatar{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,#d5f6ea,#ffe0d7);font-size:1.35rem;font-weight:900}.account-copy{display:grid;gap:4px;min-width:0}.account-copy span,.logout-section p{margin:0;color:var(--muted)}.account-copy strong{overflow-wrap:anywhere;font-size:1.35rem}.account-card-error{grid-template-columns:1fr}.quick-link-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.quick-link{display:grid;gap:8px;min-height:92px;align-content:center;justify-items:center;border:1px solid var(--line);border-radius:14px;background:#f8fbf8;color:#18211b;text-align:center;text-decoration:none}.quick-link span{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:#fff;color:var(--accent-strong);font-size:1.2rem}.quick-link strong{font-size:.98rem}.logout-section{grid-template-columns:minmax(0,1fr) auto;align-items:center}.logout-section .danger{min-width:120px}.page-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:flex-end}.record-form{display:grid;gap:18px;padding:0;border:0;background:transparent}.record-wizard{min-height:100%;display:grid;grid-template-rows:minmax(0,1fr) auto auto;gap:12px}.step-indicator{min-width:44px;min-height:30px;display:grid;place-items:center;border-radius:999px;background:#eef6fb;color:#0b69b3;font-weight:850}.wizard-step{display:grid;align-content:start;gap:14px;min-height:0}.wizard-step h2{margin:0;font-size:1.15rem}.wizard-actions .secondary:disabled{opacity:.45}.form-section{display:grid;gap:14px;padding:18px;border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:var(--shadow)}.form-section h2{margin:0;font-size:1.22rem}.form-grid{display:grid;gap:12px}.selected-tags{display:flex;flex-wrap:wrap;gap:8px;margin:0;color:#27604f;font-weight:700}.record-submit{width:min(430px,100%);justify-self:center;min-height:56px;border-radius:999px;font-size:1.15rem;font-weight:900;background:var(--mint)}.form-error:empty,.detail-error:empty{display:none}.form-hint,.empty-note{margin:0;color:var(--muted);line-height:1.6}.detail-shell{min-height:0;display:grid;gap:12px}.record-detail{display:grid;gap:12px}.detail-summary,.detail-section{border:1px solid #dce5e2;border-radius:8px;background:#fff;padding:14px}.summary-meta{display:flex;flex-wrap:wrap;gap:6px;color:#65746f;font-size:.86rem}.detail-summary h1{margin:8px 0 0;font-size:1.35rem;line-height:1.2;overflow-wrap:anywhere}.detail-section h2{margin:0 0 8px;font-size:1rem}.detail-section p{margin:0;line-height:1.7;white-space:pre-wrap;overflow-wrap:anywhere}.detail-actions .primary,.detail-actions .danger{min-height:46px;text-align:center}.attachment-list{display:grid;gap:8px}.attachment-list a{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:6px;padding:10px;background:#fff;color:#18211b;text-decoration:none}.attachment-list a:hover{border-color:var(--accent)}.attachment-list strong,.attachment-list span{overflow-wrap:anywhere}.attachment-list span{color:var(--muted);text-align:right}@media(max-width:820px){.people-layout{grid-template-columns:1fr}.person-row{display:grid}.person-row p{max-width:none;text-align:left}}@media(max-width:760px){.form-grid{grid-template-columns:1fr}.page-head{align-items:flex-start;flex-direction:column}.page-actions{justify-content:flex-start}.quick-link-grid,.logout-section{grid-template-columns:1fr}.logout-section .danger{width:100%;min-height:48px}.attachment-list a{display:grid}.attachment-list span{text-align:left}}@media(max-width:720px){.app-main{width:min(100vw - 20px,760px);margin-top:14px}}
