@layer properties;@layer theme,base,components,utilities;@layer theme{:root,:host{--font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-500: oklch(63.7% .237 25.331);--color-red-600: oklch(57.7% .245 27.325);--color-green-500: oklch(72.3% .219 149.579);--color-gray-50: oklch(98.5% .002 247.839);--color-gray-100: oklch(96.7% .003 264.542);--color-gray-200: oklch(92.8% .006 264.531);--color-gray-600: oklch(44.6% .03 256.802);--color-gray-900: oklch(21% .034 264.665);--color-white: #fff;--spacing: .25rem;--text-sm: .875rem;--text-sm--line-height: calc(1.25 / .875);--text-2xl: 1.5rem;--text-2xl--line-height: calc(2 / 1.5);--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--tracking-wider: .05em;--radius-sm: .25rem;--radius-md: .375rem;--radius-lg: .5rem;--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--default-transition-duration: .15s;--default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);--default-font-family: var(--font-sans);--default-mono-font-family: var(--font-mono)}}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings, normal);font-variation-settings:var(--default-font-variation-settings, normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings, normal);font-variation-settings:var(--default-mono-font-variation-settings, normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:currentcolor}@supports (color: color-mix(in lab,red,red)){{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.absolute{position:absolute}.fixed{position:fixed}.static{position:static}.right-4{right:calc(var(--spacing) * 4)}.bottom-4{bottom:calc(var(--spacing) * 4)}.z-50{z-index:50}.mr-2{margin-right:calc(var(--spacing) * 2)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.flex{display:flex}.hidden{display:none}.table{display:table}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.flex-1{flex:1}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.items-center{align-items:center}.justify-between{justify-content:space-between}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse: 0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-2>:not(:last-child)){--tw-space-x-reverse: 0;margin-inline-start:calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)))}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-gray-200{border-color:var(--color-gray-200)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-green-500{background-color:var(--color-green-500)}.bg-red-500{background-color:var(--color-red-500)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-6{padding-block:calc(var(--spacing) * 6)}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading, var(--text-2xl--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading, var(--text-sm--line-height))}.font-bold{--tw-font-weight: var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight: var(--font-weight-medium);font-weight:var(--font-weight-medium)}.tracking-wider{--tw-tracking: var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-gray-600{color:var(--color-gray-600)}.text-gray-900{color:var(--color-gray-900)}.text-red-600{color:var(--color-red-600)}.text-white{color:var(--color-white)}.opacity-25{opacity:25%}.opacity-75{opacity:75%}.shadow-lg{--tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / .1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / .1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease, var(--default-transition-timing-function));transition-duration:var(--tw-duration, var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease, var(--default-transition-timing-function));transition-duration:var(--tw-duration, var(--default-transition-duration))}@media (hover: hover){.hover\:bg-gray-200:hover{background-color:var(--color-gray-200)}}}.detail-page{padding:24px;max-width:960px;margin:0 auto}.back-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;color:#6366f1;font-size:.9rem;font-weight:500;padding:0;margin-bottom:20px;transition:color .15s}.back-btn:hover{color:#4f46e5}.detail-header{margin-bottom:20px}.header-main{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px;width:100%}.header-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-info{flex:1;min-width:0}.header-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.header-row h1{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.header-desc{font-size:.95rem;color:#64748b;margin:6px 0 0}.type-chip{font-size:.8rem;font-weight:600;padding:3px 10px;border-radius:999px}.archived-chip{display:inline-flex;align-items:center;gap:4px;font-size:.8rem;color:#94a3b8;background:#f1f5f9;padding:3px 10px;border-radius:999px}.header-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;align-items:flex-start;margin-left:auto;flex-shrink:0}.review-bar{margin-bottom:20px}.review-bar-inner{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0;font-size:.85rem;color:#64748b}.review-bar-inner.overdue{background:#fef2f2;border-color:#fecaca;color:#dc2626}.review-bar-inner.soon{background:#fffbeb;border-color:#fde68a;color:#b45309}.divider{opacity:.4}.review-cadence-label{color:#94a3b8;font-size:.8rem}.summary-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:20px}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .15s;text-align:center}.stat-card:hover{border-color:#6366f1;box-shadow:0 2px 8px #6366f11a}.stat-number{display:block;font-size:1.5rem;font-weight:700;color:#1e293b}.stat-label{font-size:.78rem;color:#64748b}.stat-card.done .stat-number{color:#10b981}.stat-card.upcoming .stat-number{color:#f59e0b}.stat-card.docs .stat-number{color:#6366f1}.quick-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}.action-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px dashed #c7d2fe;border-radius:8px;background:#f5f3ff;color:#6366f1;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.action-btn:hover{background:#ede9fe;border-color:#6366f1}.action-btn-upload{cursor:pointer}.action-btn-wrap{position:relative}.template-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:200;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 30px #0000001f;min-width:220px;overflow:hidden}.template-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;font-size:.85rem;color:#374151;text-align:left;transition:background .1s}.template-item:hover{background:#f5f3ff;color:#6366f1}.template-count{margin-left:auto;background:#e0e7ff;color:#6366f1;font-size:.7rem;padding:1px 6px;border-radius:999px}.finance-hint{margin-top:20px}.hint-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;font-size:.85rem;color:#374151;line-height:1.5}.tabs{display:flex;gap:4px;border-bottom:2px solid #e2e8f0;margin-bottom:20px}.tab-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:none;border:none;cursor:pointer;font-size:.9rem;color:#64748b;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab-btn.active{color:#6366f1;border-bottom-color:#6366f1}.tab-badge{background:#6366f1;color:#fff;font-size:.7rem;padding:1px 6px;border-radius:999px;font-weight:600}.tab-content{min-height:200px}.tab-pane{animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:24px}.info-card{background:#f8fafc;border-radius:8px;padding:12px 14px}.info-card h4{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 4px}.info-card p{margin:0;font-size:.9rem;color:#1e293b}.tag-list{display:flex;flex-wrap:wrap;gap:6px}.tag{background:#e0e7ff;color:#6366f1;font-size:.78rem;padding:2px 8px;border-radius:999px}.recent-section h3{font-size:1rem;font-weight:600;color:#475569;margin:0 0 12px}.btn-link{background:none;border:none;cursor:pointer;color:#6366f1;font-size:.875rem;padding:8px 0;font-weight:500}.btn-link:hover{text-decoration:underline}.timeline-list{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.timeline-item{display:flex;align-items:center;gap:12px;padding:6px 8px;border-radius:8px;transition:background .15s}.timeline-item:hover{background:#f8fafc}.timeline-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-content{flex:1;min-width:0;display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid #f1f5f9;gap:12px}.timeline-title{font-size:.9rem;color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.timeline-date{font-size:.78rem;color:#94a3b8;white-space:nowrap;flex-shrink:0}.doc-list{display:flex;flex-direction:column;gap:8px}.doc-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;transition:box-shadow .15s}.doc-row:hover{box-shadow:0 2px 8px #0000000f}.doc-icon{width:36px;height:36px;background:#eef2ff;border-radius:8px;display:flex;align-items:center;justify-content:center}.doc-info{flex:1;min-width:0}.doc-name{display:block;font-size:.9rem;color:#1e293b;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-meta{display:block;font-size:.78rem;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checklist-list{display:flex;flex-direction:column;gap:8px}.checklist-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;transition:border-color .15s,box-shadow .15s}.checklist-row:hover{border-color:#a5b4fc;box-shadow:0 1px 4px #6366f114}.checklist-icon{width:36px;height:36px;background:#eef2ff;border-radius:8px;display:flex;align-items:center;justify-content:center}.checklist-info{flex:1;min-width:0}.checklist-title{display:block;font-size:.9rem;color:#1e293b;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checklist-meta{display:block;font-size:.78rem;color:#94a3b8;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checklist-status{font-size:.78rem;font-weight:500;color:#10b981;background:#d1fae5;padding:2px 8px;border-radius:999px}.checklist-status.done{color:#94a3b8;background:#f1f5f9}.empty-tab{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 0;text-align:center;color:#94a3b8}.empty-tab p{margin:0;font-size:.9rem}.state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;gap:16px;text-align:center;color:#64748b}.state-container.error{color:#ef4444}.btn{padding:9px 16px;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;border:none;display:inline-flex;align-items:center;gap:6px;transition:all .15s}.btn-sm{padding:7px 12px;font-size:.82rem}.btn-primary{background:#6366f1;color:#fff}.btn-primary:hover{background:#4f46e5}.btn-secondary{background:#f1f5f9;color:#374151;border:1px solid #e2e8f0}.btn-secondary:hover{background:#e2e8f0}.btn-accent{background:#d1fae5;color:#059669}.btn-accent:hover{background:#a7f3d0}.btn-accent.overdue{background:#fef2f2;color:#dc2626}.btn-danger{background:#fff1f2;color:#dc2626}.btn-danger:hover{background:#fee2e2}.btn-icon-sm{width:32px;height:32px;background:none;border:none;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s}.btn-icon-sm:hover{color:#475569;background:#f1f5f9}.spinner,.spinner-lg{border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:currentColor}.spinner-lg{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#6366f1}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-btn{white-space:nowrap;flex-shrink:0}@media (max-width: 640px){.detail-page{padding:16px 12px}.header-main{gap:12px;flex-wrap:wrap}.header-icon{width:44px;height:44px;border-radius:10px}.header-row h1{font-size:1.2rem}.header-actions{width:100%;margin-left:0;display:grid;grid-template-columns:1fr 1fr;justify-content:stretch}.header-actions .btn{justify-content:center;font-size:.78rem;padding:7px 8px}.review-bar-inner{flex-wrap:wrap;gap:4px;font-size:.8rem}.review-bar-inner .divider{display:none}.summary-row{grid-template-columns:repeat(2,1fr)}.quick-actions{flex-direction:column}.action-btn{width:100%;justify-content:center}.tab-btn{padding:10px 12px;font-size:.82rem}.timeline-content{flex-direction:column;align-items:flex-start;gap:2px}.timeline-date{white-space:normal}.doc-row{flex-wrap:wrap}.doc-info{min-width:0;flex:1 1 0}.doc-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-grid{grid-template-columns:1fr 1fr}.od-apt-row{grid-template-columns:48px minmax(0,1fr) 18px;column-gap:10px;padding:10px 12px}.od-apt-date{width:48px;height:48px}}.linked-row{cursor:pointer}.linked-row-main{flex:1;min-width:0}.linked-row-chevron{flex-shrink:0;margin-left:4px}.tab-pane-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.tab-pane-header h3{font-size:1rem;font-weight:600;color:#1e293b;margin:0}.overview-description{padding:12px 16px;background:#f8fafc;border-radius:10px;color:#475569;font-size:.92rem;line-height:1.55;margin-bottom:20px}.overview-section{margin-top:20px}.section-title{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin:0 0 10px}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-header-row .section-title{margin:0}.type-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.overdue-text{color:#ef4444;font-weight:600}.overview-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 0;color:#94a3b8}.overview-empty p{margin:0}.hint-text{font-size:.85rem}.task-preview-list{display:flex;flex-direction:column;gap:6px}.task-preview-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border-radius:8px;cursor:pointer;transition:background .15s;font-size:.875rem}.task-preview-item:hover{background:#f1f5f9}.task-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-title{flex:1;color:#1e293b}.task-due{font-size:.78rem;color:#94a3b8;flex-shrink:0}.task-status-chip{font-size:.72rem;font-weight:500;padding:2px 8px;border-radius:10px;background:#e2e8f0;color:#475569;flex-shrink:0}.task-status-chip.doing{background:#dbeafe;color:#2563eb}.btn-link.small{font-size:.8rem}.od-apt-list{display:flex;flex-direction:column;align-items:stretch;gap:8px;width:100%}.od-apt-row{display:grid;grid-template-columns:52px minmax(0,1fr) 20px;align-items:center;column-gap:12px;width:100%;box-sizing:border-box;padding:10px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.od-apt-row:hover{border-color:#a5b4fc;box-shadow:0 1px 4px #6366f114}.od-apt-row--past{opacity:.65}.od-apt-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:52px;height:52px;background:#6366f1;border-radius:8px;color:#fff;box-sizing:border-box}.od-apt-date--past{background:#94a3b8}.od-apt-date-day{font-size:1.05rem;font-weight:700;line-height:1.1}.od-apt-date-month{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;line-height:1.2}.od-apt-content{min-width:0;overflow:hidden}.od-apt-title{font-size:.9375rem;font-weight:600;color:#1e293b;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.od-apt-sub{margin-top:2px;font-size:.78rem;color:#64748b;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.od-apt-chevron{justify-self:end}.task-section{margin-bottom:20px}.task-section-title{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin:0 0 8px}.task-section-title.done-title{color:#cbd5e1}.task-list{display:flex;flex-direction:column;gap:6px}.task-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s}.task-row:hover{border-color:#a5b4fc;box-shadow:0 1px 4px #6366f114}.task-row.done{opacity:.55}.task-row-info{flex:1;min-width:0}.task-row-title{display:block;font-size:.9rem;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-row-title.done-text{text-decoration:line-through;color:#94a3b8}.task-row-desc{display:block;font-size:.78rem;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-row-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.done-dot{background:#10b981}.done-chip{background:#d1fae5;color:#065f46}.done-list .task-row-title{text-decoration:line-through}.apt-section{margin-bottom:24px}.apt-section-title{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin:0 0 8px}.apt-section-title.past-title{color:#cbd5e1}.overview-section .od-apt-row{background:#f8fafc;border-color:transparent}.overview-section .od-apt-row:hover{background:#f1f5f9;border-color:#e2e8f0}*,*:before,*:after{box-sizing:border-box}:root{--app-content-max: 1200px;--app-page-padding: clamp(.75rem, 3vw, 2rem);--app-touch-target: 44px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--primary-blue: #4A90E2;--primary-blue-light: #6BA3E8;--primary-blue-dark: #357ABD;--primary-green: #7ED321;--primary-green-light: #95D94A;--primary-green-dark: #6BB91A;--primary-orange: #F5A623;--primary-orange-light: #F7B84A;--primary-orange-dark: #E0941A;--neutral-100: #F8F9FA;--neutral-200: #E9ECEF;--neutral-300: #DEE2E6;--neutral-400: #CED4DA;--neutral-500: #ADB5BD;--neutral-600: #6C757D;--neutral-700: #495057;--neutral-800: #343A40;--neutral-900: #212529;--accent-purple: #9B59B6;--accent-red: #E74C3C;--accent-yellow: #F1C40F;--accent-teal: #1ABC9C;--success: var(--primary-green);--warning: var(--primary-orange);--error: var(--accent-red);--info: var(--primary-blue);--text-primary: var(--neutral-900);--text-secondary: var(--neutral-600);--text-muted: var(--neutral-500);--text-inverse: #FFFFFF;--bg-primary: #FFFFFF;--bg-secondary: var(--neutral-100);--bg-tertiary: var(--neutral-200);--font-family-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-base: 16px;--font-size-h1: 2.5rem;--font-size-h2: 2rem;--font-size-h3: 1.5rem;--font-size-h4: 1.25rem;--font-size-h5: 1.125rem;--font-size-h6: 1rem;--font-size-lg: 1.125rem;--font-size-sm: .875rem;--font-size-xs: .75rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem;--border-radius-none: 0;--border-radius-sm: .125rem;--border-radius-md: .375rem;--border-radius-lg: .5rem;--border-radius-xl: .75rem;--border-radius-2xl: 1rem;--border-radius-full: 9999px}body{font-family:var(--font-family-primary);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-primary);margin:0;overflow-x:hidden;-webkit-text-size-adjust:100%}h1{font-size:clamp(1.5rem,5vw,var(--font-size-h1))}h2{font-size:clamp(1.25rem,4vw,var(--font-size-h2))}h3{font-size:clamp(1.1rem,3vw,var(--font-size-h3))}.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-family-primary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--border-radius-md);padding:var(--spacing-sm) var(--spacing-lg);border:none;cursor:pointer;transition:background .2s,color .2s,box-shadow .2s;box-shadow:0 1px 3px #00000012;min-height:var(--app-touch-target);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-blue);color:var(--text-inverse)}.btn-primary:hover,.btn-primary:focus{background:var(--primary-blue-dark)}.btn-secondary{background:var(--bg-secondary);color:var(--primary-blue);border:1px solid var(--primary-blue)}.btn-secondary:hover,.btn-secondary:focus{background:var(--primary-blue-light);color:var(--text-inverse)}.btn-success{background:var(--success);color:var(--text-inverse)}.btn-success:hover,.btn-success:focus{background:var(--primary-green-dark)}.btn-ghost{background:transparent;color:var(--primary-blue);border:1px solid var(--primary-blue)}.btn-ghost:hover,.btn-ghost:focus{background:var(--primary-blue-light);color:var(--text-inverse)}.btn-danger{background:var(--error);color:var(--text-inverse)}.btn-danger:hover,.btn-danger:focus{background:#c0392b}.btn-sm{font-size:var(--font-size-sm);padding:var(--spacing-xs) var(--spacing-md)}.btn-xs{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm)}.btn-lg{font-size:var(--font-size-lg);padding:var(--spacing-md) var(--spacing-xl)}.card{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:0 1px 6px #50007814;padding:var(--spacing-lg);border:1px solid var(--neutral-200);transition:box-shadow .2s,background .2s}.card:hover{box-shadow:0 4px 20px #4a90e221;background:var(--bg-secondary)}.card-header{padding-bottom:var(--spacing-md);border-bottom:1px solid var(--neutral-200);margin-bottom:var(--spacing-md);font-weight:var(--font-weight-bold);font-size:var(--font-size-h4)}.card-body{padding:var(--spacing-md) 0}.card-footer{padding-top:var(--spacing-md);border-top:1px solid var(--neutral-200);margin-top:var(--spacing-md)}.chat-message-bubble{background:var(--bg-secondary);border-radius:var(--border-radius-xl);box-shadow:0 1px 3px #5000780f;padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-xs);border:1px solid var(--neutral-200);font-size:var(--font-size-base);transition:box-shadow .15s,background .15s}.chat-message-bubble .author{font-weight:var(--font-weight-semibold);color:var(--primary-blue);margin-bottom:var(--spacing-xs)}.chat-message-bubble .timestamp{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:var(--spacing-xs)}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-xs);color:var(--text-primary)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--neutral-300);border-radius:var(--border-radius-md);font-size:var(--font-size-base);transition:border-color .2s,box-shadow .2s;min-height:var(--app-touch-target);touch-action:manipulation;-webkit-appearance:none}.form-input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #4a90e21a}.form-error{color:var(--error);font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.form-container{background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl);border:1px solid var(--neutral-200);width:100%}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--neutral-200)}.form-close-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--neutral-300);background:var(--bg-primary);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.form-close-btn:hover{background:var(--neutral-100);color:var(--text-primary);border-color:var(--neutral-400)}h1{font-weight:var(--font-weight-extrabold);color:var(--primary-blue);margin-bottom:var(--spacing-lg)}h2{font-weight:var(--font-weight-bold);color:var(--primary-blue);margin-bottom:var(--spacing-md)}h3{font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-md)}h4{font-size:var(--font-size-h4);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--spacing-sm)}h5{font-size:var(--font-size-h5);font-weight:var(--font-weight-semibold);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}h6{font-size:var(--font-size-h6);font-weight:var(--font-weight-semibold);color:var(--text-secondary);margin-bottom:var(--spacing-xs)}ul{list-style:none;padding:0;margin:0}li{margin-bottom:var(--spacing-sm);padding:var(--spacing-xs) 0;border-bottom:1px solid var(--neutral-200)}li:last-child{border-bottom:none;margin-bottom:0}ul.checkbox-list li{padding:var(--spacing-xs) 0;border-bottom:none}ul.checkbox-list li label{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;font-size:var(--font-size-sm);color:var(--text-primary)}ul.checkbox-list li input[type=checkbox]{margin:0;cursor:pointer}.filter-section{background:var(--bg-secondary);border-radius:var(--border-radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.filter-section>label{font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--spacing-xs);display:block;font-size:var(--font-size-sm)}.filter-section .filter-buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.filter-section .filter-list{margin-top:var(--spacing-xs)}.page-wrapper{width:100%;max-width:var(--app-content-max);margin:0 auto;padding:0 var(--app-page-padding)}.text-clamp{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-clamp-2,.text-clamp-3{display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.text-clamp-2{-webkit-line-clamp:2}.text-clamp-3{-webkit-line-clamp:3}.text-wrap-safe{overflow-wrap:anywhere;word-break:break-word}.text-clamp-2.text-wrap-safe,.text-clamp-3.text-wrap-safe{word-break:break-all}.min-w-0{min-width:0}.form-check-label{min-height:var(--app-touch-target);display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;touch-action:manipulation}@media (max-width: 480px){.form-container{padding:var(--spacing-md);border-radius:var(--border-radius-md)}}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-sm)}@media (max-width: 480px){.modal-backdrop{align-items:flex-end;padding:0}}.cdk-drag-preview.task-drag-preview{box-sizing:border-box;width:min(320px,calc(100vw - 48px))!important;border-radius:8px;box-shadow:0 12px 28px #0f172a2e;opacity:.98;pointer-events:none}.cdk-drag-preview.task-drag-preview .task-card{margin:0;transform:none!important;transition:none!important}@property --tw-rotate-x{syntax: "*"; inherits: false;}@property --tw-rotate-y{syntax: "*"; inherits: false;}@property --tw-rotate-z{syntax: "*"; inherits: false;}@property --tw-skew-x{syntax: "*"; inherits: false;}@property --tw-skew-y{syntax: "*"; inherits: false;}@property --tw-space-y-reverse{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-space-x-reverse{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-border-style{syntax: "*"; inherits: false; initial-value: solid;}@property --tw-font-weight{syntax: "*"; inherits: false;}@property --tw-tracking{syntax: "*"; inherits: false;}@property --tw-shadow{syntax: "*"; inherits: false; initial-value: 0 0 #0000;}@property --tw-shadow-color{syntax: "*"; inherits: false;}@property --tw-shadow-alpha{syntax: "<percentage>"; inherits: false; initial-value: 100%;}@property --tw-inset-shadow{syntax: "*"; inherits: false; initial-value: 0 0 #0000;}@property --tw-inset-shadow-color{syntax: "*"; inherits: false;}@property --tw-inset-shadow-alpha{syntax: "<percentage>"; inherits: false; initial-value: 100%;}@property --tw-ring-color{syntax: "*"; inherits: false;}@property --tw-ring-shadow{syntax: "*"; inherits: false; initial-value: 0 0 #0000;}@property --tw-inset-ring-color{syntax: "*"; inherits: false;}@property --tw-inset-ring-shadow{syntax: "*"; inherits: false; initial-value: 0 0 #0000;}@property --tw-ring-inset{syntax: "*"; inherits: false;}@property --tw-ring-offset-width{syntax: "<length>"; inherits: false; initial-value: 0px;}@property --tw-ring-offset-color{syntax: "*"; inherits: false; initial-value: #fff;}@property --tw-ring-offset-shadow{syntax: "*"; inherits: false; initial-value: 0 0 #0000;}@property --tw-outline-style{syntax: "*"; inherits: false; initial-value: solid;}@property --tw-blur{syntax: "*"; inherits: false;}@property --tw-brightness{syntax: "*"; inherits: false;}@property --tw-contrast{syntax: "*"; inherits: false;}@property --tw-grayscale{syntax: "*"; inherits: false;}@property --tw-hue-rotate{syntax: "*"; inherits: false;}@property --tw-invert{syntax: "*"; inherits: false;}@property --tw-opacity{syntax: "*"; inherits: false;}@property --tw-saturate{syntax: "*"; inherits: false;}@property --tw-sepia{syntax: "*"; inherits: false;}@property --tw-drop-shadow{syntax: "*"; inherits: false;}@property --tw-drop-shadow-color{syntax: "*"; inherits: false;}@property --tw-drop-shadow-alpha{syntax: "<percentage>"; inherits: false; initial-value: 100%;}@property --tw-drop-shadow-size{syntax: "*"; inherits: false;}@keyframes spin{to{transform:rotate(360deg)}}@layer properties{@supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x: initial;--tw-rotate-y: initial;--tw-rotate-z: initial;--tw-skew-x: initial;--tw-skew-y: initial;--tw-space-y-reverse: 0;--tw-space-x-reverse: 0;--tw-border-style: solid;--tw-font-weight: initial;--tw-tracking: initial;--tw-shadow: 0 0 #0000;--tw-shadow-color: initial;--tw-shadow-alpha: 100%;--tw-inset-shadow: 0 0 #0000;--tw-inset-shadow-color: initial;--tw-inset-shadow-alpha: 100%;--tw-ring-color: initial;--tw-ring-shadow: 0 0 #0000;--tw-inset-ring-color: initial;--tw-inset-ring-shadow: 0 0 #0000;--tw-ring-inset: initial;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-offset-shadow: 0 0 #0000;--tw-outline-style: solid;--tw-blur: initial;--tw-brightness: initial;--tw-contrast: initial;--tw-grayscale: initial;--tw-hue-rotate: initial;--tw-invert: initial;--tw-opacity: initial;--tw-saturate: initial;--tw-sepia: initial;--tw-drop-shadow: initial;--tw-drop-shadow-color: initial;--tw-drop-shadow-alpha: 100%;--tw-drop-shadow-size: initial}}}
