:root{color:#09090b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--background:#fafafa;--foreground:#09090b;--muted:#71717a;--muted-foreground:#52525b;--card:#ffffffeb;--card-foreground:#09090b;--border:#e4e4e7eb;--border-strong:#d4d4d8f2;--accent:#111827;--accent-foreground:#fafafa;--surface-soft:#f4f4f5;--shadow:0 8px 30px #0f172a0f;--success:#166534;--success-bg:#dcfce7;--destructive:#b91c1c;--destructive-bg:#fee2e2;--info:#4338ca;--info-bg:#e0e7ff;--neutral:#52525b;--neutral-bg:#f4f4f5;background:#fafafa;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%}body{background:radial-gradient(circle at top,#fffc,#0000 36%),linear-gradient(#fcfcfd 0%,#fafafa 48%,#f4f4f5 100%);margin:0}button,input,select,code{font:inherit}button{cursor:pointer}code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.app{max-width:1120px;margin:0 auto;padding:28px 20px 64px}.page-header{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;display:flex}.page-header-copy{max-width:720px}.page-header h1{letter-spacing:-.06em;margin:0;font-size:clamp(2.4rem,4vw,4rem);line-height:.98}.page-subtitle{max-width:640px;color:var(--muted-foreground);margin:10px 0 0;font-size:1rem;line-height:1.6}.page-header-actions{align-items:center;gap:10px;display:flex}.project-pill,.counter-chip,.badge,.row-chip{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.project-pill{border:1px solid var(--border);min-height:36px;color:var(--muted-foreground);background:#ffffffeb;padding:0 12px}.kicker,.label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin:0 0 6px;font-size:.75rem;font-weight:700}.tabs{border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffdb;border-radius:14px;align-items:center;gap:6px;margin-bottom:24px;padding:6px;display:inline-flex}.tab{min-width:96px;color:var(--muted-foreground);background:0 0;border:0;border-radius:10px;padding:10px 14px;font-weight:600}.tab.is-active{color:var(--foreground);background:#fff;box-shadow:0 1px 2px #0f172a14}.page-grid{gap:18px;display:grid}.two-column-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.card,.notice-card,.alert-banner{border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:20px}.card{padding:22px}.card h2,.card h3,.notice-card h3,.alert-banner h3{letter-spacing:-.03em;margin:0}.card-header,.hero-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.subtle-copy,.muted,.alert-copy p,.notice-copy p{color:var(--muted-foreground)}.hero-card{background:linear-gradient(#fffffff5 0%,#f9fafbeb 100%);gap:18px;display:grid}.hero-card h2{font-size:clamp(2rem,3vw,2.9rem);line-height:1}.hero-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.summary-chip,.meta-tile,.detail-tile,.note-item{border:1px solid var(--border);background:#fff;border-radius:16px;padding:14px 16px}.summary-chip strong,.meta-tile strong,.progress-card strong,.detail-tile dd,.note-item strong{color:var(--foreground);font-size:.95rem;font-weight:700;line-height:1.4;display:block}.hero-description{color:var(--muted-foreground);margin:0;line-height:1.6}.hero-meta-grid,.detail-grid,.field-grid{gap:12px;display:grid}.hero-meta-grid,.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.action-group{gap:12px;display:grid}.action-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.button{border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;min-height:44px;padding:0 16px;font-weight:600;transition:background-color .14s,border-color .14s,transform .14s;display:inline-flex}.button:hover{transform:translateY(-1px)}.button:disabled{opacity:.45;cursor:not-allowed;transform:none}.button-primary{background:var(--accent);color:var(--accent-foreground)}.button-secondary{color:var(--foreground);border-color:var(--border-strong);background:#fff}.button-ghost{color:var(--muted-foreground);border-color:var(--border);background:0 0}.badge,.row-chip,.counter-chip{min-height:30px;padding:0 10px;font-size:.8rem}.badge-accent{background:var(--info-bg);color:var(--info)}.badge-success{background:var(--success-bg);color:var(--success)}.badge-destructive{background:var(--destructive-bg);color:var(--destructive)}.badge-muted,.row-chip,.counter-chip{background:var(--neutral-bg);color:var(--neutral)}.progress-card{gap:14px;display:grid}.progress-track{background:#e4e4e7;border-radius:999px;height:8px;overflow:hidden}.progress-indicator{border-radius:inherit;background:linear-gradient(90deg,#111827 0%,#52525b 100%);height:100%}.timeline-strip{scrollbar-width:none;gap:12px;padding-bottom:2px;display:flex;overflow-x:auto}.timeline-strip::-webkit-scrollbar{display:none}.timeline-item{flex:none;justify-items:center;gap:8px;min-width:58px;display:grid}.timeline-weekday,.timeline-status,.calendar-weekday{color:var(--muted);font-size:.75rem}.timeline-circle,.calendar-day{border:1px solid var(--border);width:48px;height:48px;color:var(--foreground);background:#fff;border-radius:14px;place-items:center;font-weight:700;display:grid}.timeline-success,.calendar-success{background:var(--success-bg);color:var(--success)}.timeline-accent,.calendar-accent{background:var(--info-bg);color:var(--info)}.timeline-destructive,.calendar-destructive{background:var(--destructive-bg);color:var(--destructive)}.timeline-muted,.calendar-muted{background:var(--neutral-bg);color:var(--neutral)}.timeline-circle.is-current,.calendar-day.is-current{box-shadow:inset 0 0 0 2px}.list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.list-row{border:1px solid var(--border);background:#fff;border-radius:16px;justify-content:space-between;align-items:flex-start;gap:16px;padding:14px 16px;display:flex}.list-row strong{margin-bottom:4px;display:block}.list-row p,.row-meta time{margin:0}.row-meta{justify-items:end;gap:6px;display:grid}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:10px;display:grid}.calendar-item{justify-items:center;gap:6px;display:grid}.legend{color:var(--muted-foreground);flex-wrap:wrap;gap:12px 16px;margin-top:16px;font-size:.84rem;display:flex}.legend span{align-items:center;gap:6px;display:inline-flex}.legend-dot{border-radius:999px;width:8px;height:8px}.dot-success{background:var(--success)}.dot-accent{background:var(--info)}.dot-destructive{background:var(--destructive)}.dot-muted{background:var(--neutral)}.detail-tile dt{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 6px;font-size:.78rem;font-weight:700}.detail-tile dd{margin:0}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.field{gap:8px;display:grid}.field.span-2{grid-column:span 2}.field span{color:var(--muted-foreground);font-size:.84rem;font-weight:600}.field input,.field select{border:1px solid var(--border-strong);width:100%;min-height:44px;color:var(--foreground);background:#fff;border-radius:12px;outline:none;padding:0 14px}.field input:focus,.field select:focus{border-color:#18181b;box-shadow:0 0 0 3px #18181b14}.settings-actions,.note-stack{gap:12px;display:grid}.empty-state,.loading-card{color:var(--muted-foreground);text-align:center;justify-items:center;gap:12px;display:grid}.skeleton-dot{background:linear-gradient(90deg,#e4e4e7,#f4f4f5,#e4e4e7) 0 0/200% 100%;border-radius:999px;width:32px;height:32px;animation:1.6s linear infinite pulse}@keyframes pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.notice-card,.alert-banner{justify-content:space-between;align-items:flex-start;gap:20px;padding:18px 20px;display:flex}.notice-card{background:linear-gradient(#fffffffa 0%,#fafafaeb 100%);margin-bottom:18px}.notice-copy,.alert-copy{max-width:680px}.notice-copy p,.alert-copy p{margin:8px 0 0}.notice-list{color:var(--muted-foreground);margin:0;padding-left:20px;line-height:1.6}.alert-banner{background:linear-gradient(#fff4e5fa 0%,#fff8eef0 100%);border-color:#fbbf2438}.error-banner{color:var(--destructive);background:#fef2f2fa;border:1px solid #f8717140;border-radius:16px;margin-bottom:18px;padding:14px 16px;font-weight:600}.page-footer{color:var(--muted);text-align:center;margin-top:20px;font-size:.84rem}@media (width<=900px){.page-header,.notice-card,.alert-banner,.card-header,.hero-header{flex-direction:column;align-items:stretch}.page-header-actions{justify-content:space-between}.two-column-grid,.hero-summary,.hero-meta-grid,.detail-grid,.field-grid,.action-row{grid-template-columns:1fr}.field.span-2{grid-column:auto}}@media (width<=640px){.app{padding:18px 14px 52px}.tabs{grid-template-columns:repeat(3,1fr);width:100%;display:grid}.tab{min-width:0}.list-row{flex-direction:column}.row-meta{justify-items:start}.calendar-grid{gap:8px}.calendar-day,.timeline-circle{width:44px;height:44px}}
