:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,sans-serif;line-height:1.6;font-weight:400;font-size:16px;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 999px;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=light]{--brand-primary: #3b5773;--brand-secondary: #f06543;--brand-tertiary: #9fc2cc;--brand-alternate: #f4bb41;--background-primary: #f5f7fa;--background-secondary: #e8ecf0;--text-primary: #222831;--text-secondary: #4b5563;--semantic-success: #30b37b;--semantic-warning: #e98c2f;--semantic-info: #2d9cdb;--semantic-error: #c63c22;--accent-accent1: #5c7aea;--accent-accent2: #5dd39e;--accent-accent3: #e66b4e;--accent-accent4: #3e8ca1;--custom-divider: #cbd5e1;--bg-gradient-top: var(--background-primary);--bg-gradient-bottom: var(--background-secondary);--bg: var(--background-primary);--bg-secondary: var(--background-secondary);--surface-bg: var(--background-primary);--surface-bg-secondary: var(--background-secondary);--surface-fg: var(--text-primary);--surface-fg-muted: var(--text-secondary);--surface-border: var(--custom-divider);--fg: var(--text-primary);--fg-muted: var(--text-secondary);--card: var(--background-primary);--card-elevated: var(--background-secondary);--card-border: var(--custom-divider);--accent: var(--accent-accent1);--accent-hover: var(--brand-primary);--accent-soft: var(--accent-accent4);--accent-gold: var(--brand-alternate);--accent-gold-soft: rgba(244, 187, 65, .25);--ok: var(--semantic-success);--warn: var(--semantic-warning);--bad: var(--semantic-error);--info: var(--semantic-info);--nav-inactive: var(--text-secondary);--nav-active: var(--semantic-info);--input-bg: var(--background-primary);--input-border: var(--custom-divider);--input-border-focus: var(--accent)}:root[data-theme=dark]{--brand-primary: #253b52;--brand-secondary: #b24a33;--brand-tertiary: #4b7f85;--brand-alternate: #b57f28;--background-primary: #01172a;--background-secondary: #111827;--text-primary: #f9fafb;--text-secondary: #94a3b8;--semantic-success: #1e8b66;--semantic-warning: #b4661e;--semantic-info: #1d6ba3;--semantic-error: #8e2a17;--accent-accent1: #2f4bcf;--accent-accent2: #2e9c77;--accent-accent3: #a84432;--accent-accent4: #235c67;--custom-divider: #334155;--bg-gradient-top: var(--background-primary);--bg-gradient-bottom: var(--background-secondary);--bg: var(--background-primary);--bg-secondary: var(--background-secondary);--surface-bg: var(--brand-primary);--surface-bg-secondary: var(--background-secondary);--surface-fg: var(--text-primary);--surface-fg-muted: var(--text-secondary);--surface-border: var(--custom-divider);--fg: var(--text-primary);--fg-muted: var(--text-secondary);--card: var(--brand-primary);--card-elevated: var(--brand-tertiary);--card-border: var(--custom-divider);--accent: var(--accent-accent1);--accent-hover: var(--accent-accent4);--accent-soft: var(--accent-accent4);--accent-gold: var(--brand-alternate);--accent-gold-soft: rgba(181, 127, 40, .25);--ok: var(--semantic-success);--warn: var(--semantic-warning);--bad: var(--semantic-error);--info: var(--semantic-info);--nav-inactive: var(--text-secondary);--nav-active: var(--semantic-info);--input-bg: var(--background-secondary);--input-border: var(--custom-divider);--input-border-focus: var(--accent)}:root{color:var(--fg)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(to bottom,var(--bg-gradient-top),var(--bg-gradient-bottom));color:var(--fg)}h1,h2,h3,h4,h5,h6{margin:0 0 var(--space-md) 0;font-weight:600;line-height:1.3;color:var(--fg)}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}p{margin:0 0 var(--space-md) 0;line-height:1.6}small{font-size:.875rem;color:var(--fg-muted)}strong{font-weight:600}a{color:var(--accent);text-decoration:none;font-weight:500}a:hover{color:var(--accent-hover);text-decoration:underline}button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-lg);font-size:1rem;font-weight:500;font-family:inherit;border-radius:var(--radius-md);border:1px solid transparent;background-color:var(--accent);color:#fff;cursor:pointer;transition:all .2s ease}button:hover:not(:disabled){background-color:var(--accent-hover);transform:translateY(-1px)}button:active:not(:disabled){transform:translateY(0)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.recharts-wrapper,.recharts-wrapper *{outline:none;-webkit-tap-highlight-color:transparent}.recharts-wrapper:focus,.recharts-surface:focus,.recharts-layer:focus,.recharts-sector:focus{outline:none}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--nav-inactive);text-decoration:none;border:none;background:transparent;padding:var(--space-xs) var(--space-sm);margin:0;transition:color .2s ease}.nav-item.active{color:var(--nav-active)}.nav-label{font-size:.75rem;font-weight:500;color:inherit}.nav-icon{width:24px;height:24px;color:inherit}.nav-icon-brand-alt{color:var(--accent)}.nav-icon-info{color:var(--info)}.nav-item.active .nav-label{color:var(--nav-active)}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background-color:var(--surface-bg-secondary);color:var(--surface-fg);border-color:var(--surface-border)}button.secondary:hover:not(:disabled){background-color:#dde4f0;border-color:var(--accent-soft)}input,textarea,select{width:100%;padding:var(--space-sm) var(--space-md);font-size:1rem;font-family:inherit;border-radius:var(--radius-md);border:1px solid var(--input-border);background-color:var(--input-bg);color:var(--surface-fg);transition:border-color .2s ease,box-shadow .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--input-border-focus);box-shadow:0 0 0 3px #0066cc1a}input:disabled,textarea:disabled,select:disabled{background-color:var(--bg-secondary);cursor:not-allowed;opacity:.6}textarea{min-height:90px;resize:vertical;line-height:1.6}label{display:block;font-size:.875rem;font-weight:600;color:var(--surface-fg);margin-bottom:var(--space-xs)}.card{background-color:var(--card);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:var(--space-lg);color:var(--surface-fg);box-shadow:0 12px 30px #0000002e;transition:border-color .2s ease,box-shadow .2s ease}.card:hover{border-color:var(--input-border);box-shadow:0 2px 8px #0000000f}.card h1,.card h2,.card h3,.card h4,.card h5,.card h6,.panel h1,.panel h2,.panel h3,.panel h4,.panel h5,.panel h6,.card p,.panel p{color:var(--surface-fg)}.panel{background-color:var(--card-elevated);border:1px solid var(--accent-gold-soft);border-radius:var(--radius-lg);padding:var(--space-xl);color:var(--surface-fg)}.panel-muted{background-color:var(--surface-bg);border-color:var(--surface-border)}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.badge-active{background-color:#0066cc1a;color:#0052a3;border:1px solid rgba(0,102,204,.2)}.badge-kept{background-color:#28a7451a;color:#1e7e34;border:1px solid rgba(40,167,69,.2)}.badge-broken{background-color:#dc35451a;color:#bd2130;border:1px solid rgba(220,53,69,.2)}.badge-disputed{background-color:#f39c121a;color:#c87f0a;border:1px solid rgba(243,156,18,.2)}.badge-unresolved,.badge-pending{background-color:#5a6c841a;color:#3d4f66;border:1px solid rgba(90,108,132,.2)}.badge-in_progress{background-color:#0066cc1a;color:#0052a3;border:1px solid rgba(0,102,204,.2)}.badge-completed{background-color:#28a7451a;color:#1e7e34;border:1px solid rgba(40,167,69,.2)}.badge-cancelled{background-color:#5a6c841a;color:#3d4f66;border:1px solid rgba(90,108,132,.2)}.alert{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--surface-border);margin-bottom:var(--space-lg);background-color:var(--card);color:var(--surface-fg)}.alert-error{border-color:#dc35454d;color:#bd2130}.alert-info{border-color:#0066cc4d;color:var(--surface-fg)}.alert-success{border-color:#28a7454d;color:#1e7e34}.alert-info strong{color:var(--accent)}.container{max-width:480px;margin:0 auto;padding:var(--space-xl) var(--space-lg)}.grid{display:grid;gap:var(--space-lg)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.flex-row{display:flex;gap:var(--space-sm)}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-wrap{flex-wrap:wrap}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.mb-2xl{margin-bottom:var(--space-2xl)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.text-muted{color:var(--fg-muted)}.card .text-muted,.panel .text-muted,.card small,.panel small,.card .meta,.panel .meta{color:var(--surface-fg-muted)}.text-small{font-size:.875rem}.text-center{text-align:center}.font-semibold{font-weight:600}.empty-state{padding:var(--space-2xl);text-align:center;border:2px dashed var(--card-border);border-radius:var(--radius-lg);color:var(--fg-muted)}.empty-state h3{color:var(--fg-muted);margin-bottom:var(--space-sm)}.meta{font-size:.875rem;color:var(--fg-muted)}.promise-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md);gap:var(--space-md)}.promise-card-title{flex:1;font-size:1.125rem;font-weight:600;margin:0;line-height:1.4}.promise-card-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-sm);font-size:.875rem;color:var(--surface-fg-muted);margin-top:var(--space-sm)}.promise-card-meta-item{display:flex;flex-direction:column;gap:var(--space-xs)}.promise-card-meta-label{font-weight:600;color:var(--surface-fg);font-size:.75rem;text-transform:uppercase;letter-spacing:.025em}.back-link{display:inline-flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-lg);color:var(--accent);text-decoration:none;font-weight:500;font-size:.875rem}.back-link:hover{color:var(--accent-hover)}.control-bar{display:flex;gap:var(--space-lg);flex-wrap:wrap;align-items:center;padding:var(--space-lg);background-color:var(--surface-bg);border:1px solid var(--surface-border);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);color:var(--surface-fg)}.control-group{display:flex;align-items:center;gap:var(--space-sm)}.control-group label{margin-bottom:0;font-size:.875rem;font-weight:500}@media(max-width:768px){:root{font-size:14px}.container{padding:var(--space-md)}.promise-card-header{flex-direction:column}.control-bar{flex-direction:column;align-items:stretch}.control-group{flex-direction:column;align-items:flex-start}}.mobile-bottom-nav{display:none}@media(max-width:768px){.mobile-bottom-nav{display:flex;position:sticky;bottom:0;left:0;right:0;z-index:20}.desktop-nav{display:none!important}}@media(max-width:768px){.nav-item{flex-direction:column;gap:4px;font-size:.7rem}.nav-icon{width:24px;height:24px}}.diary-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.diary-author{font-weight:600;color:var(--fg);font-size:1rem}.diary-time{font-size:.875rem;color:var(--surface-fg-muted)}.diary-meta-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xs);align-items:center;margin-bottom:var(--space-md);min-height:20px}.diary-meta-row>:first-child{justify-self:start}.diary-meta-row>:last-child{justify-self:end}.diary-meta-row>:nth-child(2),.diary-meta-row>:nth-child(3){justify-self:center}.meta-invisible{visibility:hidden}.diary-meta-item{display:inline-flex;align-items:center;gap:4px;color:var(--surface-fg-muted);font-size:.875rem}.icon-success{color:var(--ok)}.icon-warn{color:var(--warn)}.icon-error{color:var(--bad)}.text-success{color:var(--ok)}.text-warning{color:var(--warn)}.text-error{color:var(--bad)}.text-info{color:var(--info)}.text-brand-alt{color:var(--accent)}.mr-md{margin-right:var(--space-md)}.icon-info{color:var(--info)}.icon-accent{color:var(--accent)}.icon-muted{color:var(--surface-fg-muted)}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.text-toggle{display:inline-block;margin-top:var(--space-xs);color:var(--accent);font-size:.875rem;cursor:pointer;background:none;border:none;padding:0;text-decoration:underline}.text-toggle:hover{color:var(--accent-hover)}.loading-overlay{position:fixed;inset:0;background-color:var(--bg-gradient-top);opacity:.9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;gap:var(--space-lg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spinner{width:40px;height:40px;border:4px solid var(--accent-soft);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.project-members{margin-top:var(--space-md)}.project-members-list{display:flex;flex-wrap:wrap;gap:var(--space-xs);align-items:center}.project-member{position:relative}.project-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;border:2px solid var(--card-border);background:var(--card-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-avatar-image{width:100%;height:100%;object-fit:cover}.project-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;letter-spacing:-.02em}.project-member-name{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.spinner-overlay{position:fixed;inset:0;background-color:#ffffffb3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:center;justify-content:center}:root[data-theme=dark] .spinner-overlay{background-color:#000000b3}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);color:var(--accent)}.spinner-icon{animation:spin 1s linear infinite}.spinner-message{font-weight:500;font-size:1.125rem;color:var(--fg);margin:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.theme-switch{display:flex;align-items:center;background-color:var(--surface-bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-full);padding:2px;cursor:pointer;position:relative;width:64px;height:32px;transition:all .3s ease}.theme-switch-slider{position:absolute;top:2px;left:2px;width:26px;height:26px;background-color:var(--card);border-radius:50%;box-shadow:0 1px 3px #0000001a;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:2;display:flex;align-items:center;justify-content:center}:root[data-theme=dark] .theme-switch-slider{transform:translate(32px);background-color:var(--brand-primary);color:#fff}.nav-item,.nav-item:hover{background:transparent!important}.nav-item.active{background:transparent!important;color:var(--nav-active)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.modal-content{background:var(--card);border-radius:var(--radius-lg);box-shadow:0 10px 40px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--card-border)}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;gap:var(--space-md);padding:var(--space-lg);border-top:1px solid var(--card-border);justify-content:flex-end}#root{min-height:100vh}
