:root{font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;color:#172b4d;background:#fff;--line: #dfe1e6;--line-strong: #c1c7d0;--text: #172b4d;--muted: #6b778c;--surface: #ffffff;--surface-muted: #f4f5f7;--hover: #ebecf0;--active: #f3f0ff;--blue: #7a5af8;--coral: #fc636b;--coral-soft: #fff0ee;--green: #4ea67d;--green-soft: #edf8f2;--orange: #f6a31a;--orange-soft: #fff5e8;--red: #e35d6a;--red-soft: #fff0f3;--purple: #8d85ff;--purple-soft: #f3f0ff}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;background:#fff}body{color:var(--text)}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app-shell{display:grid;grid-template-columns:260px minmax(0,1fr);height:100vh;background:#fff;overflow:hidden}.app-shell.sidebar-collapsed{grid-template-columns:72px minmax(0,1fr)}.sidebar{border-right:1px solid var(--line);background:#fff;padding:12px 0;display:flex;flex-direction:column;height:100vh;position:sticky;top:0;overflow:hidden}.sidebar-top{display:grid;grid-template-columns:56px minmax(0,1fr) 48px;align-items:center;gap:14px;padding:12px 18px 22px;border-bottom:1px solid #eef0f2;margin-bottom:14px}.collapse-button{width:48px;height:48px;border:0;background:transparent;border-radius:10px;cursor:pointer;color:#7d8592;display:inline-flex;align-items:center;justify-content:center}.collapse-button:hover{background:#f4f5f7}.brand-mark{width:56px;height:56px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.brand-copy{min-width:0;display:flex;flex-direction:column}.sidebar-title{font-size:1.05rem;font-weight:700;color:#1f2937;line-height:1.2;white-space:nowrap}.sidebar-nav{display:flex;flex-direction:column;gap:4px;padding:0 10px;flex:1 1 auto}.sidebar-nav-main,.sidebar-nav-footer{display:flex;flex-direction:column;gap:4px}.sidebar-nav-footer{margin-top:auto;padding-top:14px}.sidebar-link{display:flex;align-items:center;gap:14px;min-height:54px;padding:0 14px;border-radius:14px;color:#4b5563;font-size:.98rem;font-weight:600}.sidebar-action-link{width:100%;border:1px solid #9488ff;background:linear-gradient(180deg,#8d85ff,#7a5af8);text-align:left;color:#fff;font-weight:700}.sidebar-action-link .sidebar-link-icon{color:#fff}.sidebar-action-link:hover{background:linear-gradient(180deg,#8179ff,#694ce0)}.sidebar-link:hover{background:var(--hover)}.sidebar-link.active{background:var(--active);color:var(--blue);font-weight:600}.sidebar-link-icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;color:#5b6472;flex:0 0 auto}.sidebar-collapsed .sidebar-link{justify-content:center;padding:0;width:52px;margin-inline:auto;gap:0}.sidebar-collapsed .sidebar-link>span:not(.sidebar-link-icon){display:none}.sidebar-collapsed .sidebar-link-icon{width:24px;height:24px;margin:0 auto}.sidebar-collapsed .sidebar-nav{padding-inline:0;align-items:center}.sidebar-collapsed .sidebar-nav-main,.sidebar-collapsed .sidebar-nav-footer{width:100%;align-items:center}.sidebar-collapsed .brand-copy{display:none}.sidebar-collapsed .sidebar-top{flex-direction:column;justify-content:flex-start;align-items:center;gap:10px;padding:12px 10px 16px;display:flex}.sidebar-collapsed .brand-mark{width:44px;height:44px}.sidebar-collapsed .collapse-button{margin-left:0;width:40px;height:40px}.sidebar-collapsed .sidebar-action-link{width:52px;margin-inline:auto;padding:0;justify-content:center;gap:0}.main-content{min-width:0;background:#fff;height:100vh;overflow:auto;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;border-bottom:1px solid var(--line)}.topbar h1,.page-header h2,.surface-header h3,.surface-header h4{margin:0}.topbar h1,.topbar-title{font-size:1.9rem;line-height:1.1}.topbar-title.with-mark{display:inline-flex;align-items:center;gap:10px}.topbar-mark{font-size:1.05rem;line-height:1}.topbar-actions{display:flex;align-items:center;gap:12px}.topbar-user{color:var(--muted);font-size:.95rem;font-weight:600}.topbar-logout{min-height:36px;padding:0 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--text);font-weight:600;cursor:pointer}.topbar-logout:hover{background:#f8f9fb}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(180deg,#f8f7ff,#fff)}.auth-card{width:min(420px,100%);padding:28px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 18px 48px #172b4d14}.auth-brand{display:flex;align-items:center;gap:16px;margin-bottom:24px}.auth-title{margin:0 0 4px;font-size:1.75rem;line-height:1.05}.auth-subtitle{margin:0;color:var(--muted);line-height:1.45}.auth-form{display:grid;gap:16px}.auth-field{display:grid;gap:8px;font-weight:600}.auth-field input{width:100%;min-height:48px;padding:0 14px;border:1px solid var(--line-strong);border-radius:12px;outline:none}.auth-field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #7a5af81f}.auth-error{padding:12px 14px;border:1px solid #fecaca;border-radius:12px;background:#fff1f1;color:#b42318}.auth-actions{display:flex;gap:12px}.auth-submit,.auth-secondary{min-height:46px;padding:0 16px;border-radius:12px;font-weight:700;cursor:pointer}.auth-submit{border:0;background:linear-gradient(180deg,#8d85ff,#7a5af8);color:#fff}.auth-secondary{border:1px solid var(--line);background:#fff;color:var(--text)}.content-page{padding:24px}.page-header{display:flex;justify-content:flex-end;align-items:center;gap:16px;margin-bottom:20px}.task-management-switcher{display:inline-flex;align-items:center;gap:6px;margin-bottom:18px;padding:4px;border:1px solid var(--line);border-radius:10px;background:#f7f8fa}.task-management-view{min-height:34px;padding:0 12px;border:0;border-radius:8px;background:transparent;color:var(--muted);font-size:.92rem;font-weight:700}.task-management-view:hover{background:#eef1f5}.task-management-view.active{background:#fff;color:var(--text);box-shadow:0 1px 2px #091e4214}.surface,.planning-column,.task-column,.subsurface{border:1px solid var(--line);border-radius:10px;background:var(--surface);overflow:visible}.surface,.task-column{padding:16px}.compact-surface{margin-bottom:16px}.backlog-list{display:flex;flex-direction:column;gap:12px;max-width:920px}.backlog-project-card-body{padding:14px 16px}.backlog-drop-placeholder{max-width:920px}.surface-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px}.surface-header p{margin:6px 0 0;color:var(--muted);font-size:.92rem}.planner-create-row,.form-grid,.settings-grid{display:grid;gap:12px}.planner-create-row{grid-template-columns:minmax(220px,2fr) repeat(3,minmax(150px,1fr)) auto}.planning-grid,.kanban-scroll{display:grid;gap:16px}.roadmap-surface{padding:18px 18px 22px}.roadmap{display:flex;flex-direction:column;gap:12px}.roadmap-filters{display:flex;align-items:flex-start;flex-direction:column;gap:10px;margin-top:2px;margin-bottom:4px}.roadmap-filter-label{color:var(--muted);font-size:.82rem;font-weight:600}.roadmap-filter-list{display:flex;flex-wrap:wrap;gap:8px}.roadmap-filter-chip{display:inline-flex;align-items:center;gap:8px;min-height:30px;padding:0 10px;border-radius:999px;border:1px solid #d8dde6;background:#fff;color:#5b6472;font-size:.82rem;font-weight:600}.roadmap-filter-chip:hover{border-color:#c6ccd6;background:#fafbfc}.roadmap-filter-chip.active{background:#f7f5ff;border-color:#cfc7ff;color:#312e81}.roadmap-filter-chip-dot{width:8px;height:8px;border-radius:999px;background:currentColor;opacity:.85}.roadmap-filter-chip.status-backlog.active{background:var(--purple-soft);border-color:#7a5af82e;color:var(--purple)}.roadmap-filter-chip.status-active.active{background:#eef4ff;border-color:#5b8def2e;color:#5b8def}.roadmap-filter-chip.status-on_hold.active{background:var(--red-soft);border-color:#e35d6a2e;color:var(--red)}.roadmap-filter-chip.status-track_impact.active{background:var(--orange-soft);border-color:#f6a31a2e;color:var(--orange)}.roadmap-filter-chip.status-done.active{background:var(--green-soft);border-color:#4ea67d2e;color:var(--green)}.roadmap-viewport{width:min(100%,1496px);overflow-x:auto;overflow-y:hidden;padding-bottom:8px}.roadmap-canvas{min-width:100%}.roadmap-header-row{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;margin-bottom:6px}.roadmap-header-spacer{min-height:1px;position:sticky;left:0;z-index:3;background:#fff}.roadmap-grid,.roadmap-quarter-row,.roadmap-week-row{position:relative}.roadmap-quarter-row{height:22px}.roadmap-week-row{height:28px;border-top:1px solid #edf0f4;border-bottom:1px solid #edf0f4;background-image:repeating-linear-gradient(to right,transparent 0,transparent 75px,#eef1f6 75px,#eef1f6 76px)}.roadmap-quarter-label,.roadmap-week-label,.roadmap-current-week{position:absolute}.roadmap-quarter-label{top:0;transform:translate(8px);color:#4f46e5;font-size:.72rem;font-weight:700;white-space:nowrap}.roadmap-week-label{top:5px;transform:translate(8px);color:var(--muted);font-size:.66rem;white-space:nowrap}.roadmap-current-week{top:0;bottom:0;width:2px;background:#7a5af8;box-shadow:0 0 0 1px #7a5af81f}.roadmap-list{display:block}.roadmap-body{position:relative}.roadmap-body-grid{position:absolute;top:0;bottom:0;border-left:1px solid #edf0f4;border-right:1px solid #edf0f4;background-image:repeating-linear-gradient(to right,transparent 0,transparent 75px,rgba(229,232,239,.95) 75px,rgba(229,232,239,.95) 76px);pointer-events:none}.roadmap-body-current-week{position:absolute;top:0;bottom:0;width:2px;background:#7a5af8b8;pointer-events:none;z-index:1}.roadmap-row{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;align-items:center;padding:3px 0;border-bottom:1px solid #f0f2f5;position:relative;z-index:2}.roadmap-row-meta{display:flex;flex-direction:column;gap:2px;min-width:0;position:sticky;left:0;z-index:2;background:#fff;padding-right:12px;min-height:42px;justify-content:center}.roadmap-row-title-line{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0}.roadmap-row-title-wrap{display:flex;align-items:center;gap:10px;min-width:0}.roadmap-row-meta strong,.roadmap-row-subtitle,.roadmap-project-code{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.roadmap-row-meta strong{font-size:.98rem;font-weight:700}.roadmap-row-subtitle{color:var(--muted);font-size:.77rem}.roadmap-project-code{flex:0 0 auto;font-size:.78rem}.roadmap-status-indicator{width:20px;height:20px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;border:1px solid transparent;flex:0 0 auto}.roadmap-status-indicator.backlog{background:#f1eeff;border-color:#d6ccff;color:#7a5af8}.roadmap-status-indicator.active{background:#eef4ff;border-color:#cfe0ff;color:#5b8def}.roadmap-status-indicator.on_hold{background:#fff0f2;border-color:#f7c7cf;color:#e35d6a}.roadmap-status-indicator.track_impact{background:#fff5e8;border-color:#ffd79c;color:#f6a31a}.roadmap-status-indicator.done{background:#ecfbf3;border-color:#bfe7d1;color:#4ea67d}.roadmap-row-track{position:relative;height:34px;background:transparent}.roadmap-bar{position:absolute;top:6px;bottom:6px;border-radius:999px;min-width:26px;display:inline-flex;align-items:center;padding:0 10px;color:#fff;font-size:.72rem;font-weight:700;box-shadow:0 1px 3px #091e421f;white-space:nowrap;overflow:hidden;border:1px solid rgba(255,255,255,.28)}.roadmap-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#ffffff29,#fff0);pointer-events:none}.planning-grid,.kanban-scroll{grid-auto-flow:column;grid-auto-columns:280px;overflow-x:auto;align-items:start;padding-bottom:8px}.planning-column{min-height:360px;width:280px;background:var(--surface-muted);padding:10px;border-radius:8px;border-color:#eceff3;transition:border-color .12s ease,box-shadow .12s ease,background-color .12s ease}.planning-column.drag-target{border-color:#b9afff;box-shadow:inset 0 0 0 1px #7a5af826;background:#f8f7ff}.board-scroll{display:grid;grid-auto-flow:column;grid-auto-columns:280px;gap:16px;overflow-x:auto;align-items:start;padding-bottom:8px}.compact-head{margin-bottom:8px}.compact-head h3{font-size:1rem;line-height:1.2}.column-product{margin-bottom:10px;color:var(--muted);font-size:.88rem}.week-stack{display:flex;flex-direction:column;gap:12px;max-width:960px;width:100%}.today-list{display:flex;flex-direction:column;gap:14px;max-width:760px;width:100%}.today-task-row{display:grid;grid-template-columns:24px minmax(0,1fr);gap:10px;align-items:start;cursor:grab}.today-task-row.dragging{opacity:.55}.today-task-row .task-checkbox-ui{width:20px;height:20px;border-width:1.8px}.today-task-row .task-checkbox input:checked+.task-checkbox-ui:after{width:5px;height:3px;border-left-width:1.8px;border-bottom-width:1.8px}.today-task-copy{min-width:0}.today-task-title{color:var(--text);font-size:1rem;font-weight:700;line-height:1.2}.today-task-title.is-done{text-decoration:line-through}.today-task-context{display:inline-block;margin-top:2px;color:var(--muted);font-size:.9rem;line-height:1.2}a.today-task-context:hover{color:var(--blue)}.today-list.done-list{margin-top:8px}.today-drop-placeholder{height:18px;border:1.5px dashed #b9afff;border-radius:10px;background:#7a5af80f}.today-add-form{margin-top:10px}.today-add-form input{width:100%;min-height:40px;padding:9px 12px;border:1px solid #dfe1e6;border-radius:10px;background:#fff}.planning-mini-timeline{margin-top:10px;padding-left:176px}.planning-mini-timeline-track{height:10px;border-radius:999px;background:#eff2f7;overflow:hidden}.planning-mini-timeline-bar{height:100%;min-width:56px;border-radius:inherit;background:linear-gradient(90deg,#8d85ff,#5b7cff)}.planning-mini-timeline-meta{display:flex;justify-content:space-between;gap:12px;margin-top:8px;color:var(--muted);font-size:.78rem;line-height:1.3}.todo-list-layout{display:flex;flex-direction:column;gap:18px;width:100%;max-width:none}.todo-group{display:flex;flex-direction:column;gap:8px}.todo-group.drop-target{outline:2px dashed #b9afff;outline-offset:6px;border-radius:10px}.task-list-dropzone{position:relative;min-height:18px;transition:background-color .12s ease,border-color .12s ease}.task-list-dropzone.active{background:#7a5af808;border-radius:10px}.task-list-drop-placeholder{height:38px;border:1.5px dashed #b9afff;border-radius:10px;background:#7a5af80f}.todo-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.group-add-button{width:26px;height:26px;padding:0;border:1px solid #d9dce3;border-radius:999px;background:#fff;color:#6b778c;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.group-add-button:hover{color:var(--blue);border-color:#c8bfff;background:#faf8ff}.inline-task-creator{margin:2px 0 4px}.inline-task-creator input{min-height:36px;padding:8px 10px;border-radius:8px}.week-list-group h3,.done-section h3{margin:0 0 8px;font-size:1rem}.done-group{display:flex;flex-direction:column;gap:8px}.this-week-page .done-section h3{display:block;margin:0 0 8px;color:#2b2f3a;font-size:1.05rem;font-weight:700}.this-week-page .done-section{margin-top:20px}.todo-done-section{margin-top:24px;padding:0;border:0;background:transparent}.todo-done-section .done-group+.done-group{margin-top:16px}.planning-grid .planning-column:nth-child(1) .surface-header h3{color:var(--purple)}.planning-grid .planning-column:nth-child(2) .surface-header h3{color:#5b8def}.planning-grid .planning-column:nth-child(3) .surface-header h3{color:var(--red)}.planning-grid .planning-column:nth-child(4) .surface-header h3{color:var(--orange)}.planning-grid .planning-column:nth-child(5) .surface-header h3{color:var(--green)}.planning-cards,.group-stack,.outcome-stack,.checklist,.related-links{display:flex;flex-direction:column;gap:10px}.project-card,.subsurface{padding:14px;background:#fff;border:1px solid var(--line);border-radius:8px}.project-card-code{font-size:.76rem;font-weight:400;letter-spacing:.03em;text-transform:uppercase;color:var(--muted)}.project-card-topline{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:6px}.project-card-phase{min-width:0;color:var(--muted);font-size:.76rem;font-weight:600;text-align:right}.project-card-phase-badge{display:inline-flex;align-items:center;max-width:132px;min-height:22px;padding:0 8px;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.04em;line-height:1;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.planning-column .surface-header{margin-bottom:10px;padding:2px 2px 0}.planning-column .surface-header h3{font-size:.98rem;font-weight:700}.planning-column .surface-header span{color:var(--muted);font-size:.85rem}.status-label{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.75rem;text-transform:capitalize;border:1px solid transparent}.status-label.backlog,.status-label.open{background:var(--purple-soft);color:var(--purple)}.status-label.active{background:#eef4ff;color:#5b8def}.status-label.on_hold{background:var(--red-soft);color:var(--red)}.status-label.done{background:var(--green-soft);color:var(--green)}.status-label.track_impact{background:var(--orange-soft);color:var(--orange)}.project-card-title{display:inline-block;font-weight:700;margin-bottom:8px;font-size:.98rem;line-height:1.3}.project-card-title:hover,.text-link:hover{color:var(--blue)}.project-card{padding:0;border-radius:6px;box-shadow:0 1px 2px #091e420f;display:grid;grid-template-columns:4px minmax(0,1fr);overflow:hidden}.project-card.dragging{opacity:.65}.project-card-accent{background:var(--project-accent, #dfe1e6)}.project-card-body{min-width:0;padding:12px 13px}.project-card-meta{display:flex;align-items:center;gap:8px;min-width:0}.project-card-meta+.project-card-meta{margin-top:4px}.project-card-meta.single-line{flex-wrap:nowrap}.meta-key{flex:0 0 auto;font-size:.76rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--muted)}.meta-line{color:var(--muted);font-size:.84rem;line-height:1.4;font-weight:500}.meta-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.color-text{font-size:.88rem;font-weight:600}.truncate{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-drop-placeholder{height:76px;border:1.5px dashed #b9afff;border-radius:8px;background:#7a5af80f;transition:height .12s ease,background-color .12s ease,border-color .12s ease}.group-link-title{display:inline-block;color:#172b4d;font-weight:700;font-size:1rem}.group-link-title:hover{color:var(--blue)}.task-input-row input,input,select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:8px;padding:10px 12px;background:#fff;color:var(--text)}.task-input-row{margin-bottom:10px}.task-column-header{min-height:52px;display:grid;align-content:start;gap:4px}.task-column-title{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;line-height:1.25;margin:0}.task-column-meta{min-height:20px;margin:0;color:var(--muted);font-size:.88rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-project-card{display:grid;grid-template-columns:4px minmax(0,1fr);overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:8px}.task-project-stack{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.task-project-status{align-self:flex-start}.task-project-card-body{min-height:148px}.task-project-title{min-height:50px}.task-project-phase{max-width:128px}.task-project-goal{min-height:40px;margin-top:8px;color:var(--muted);font-size:.82rem;line-height:1.35;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.todo-create-row{display:flex;flex-direction:column;gap:10px}.todo-create-row-bottom{gap:0}.todo-create-trigger{display:flex;align-items:center;gap:12px;min-height:42px;padding:0 14px;border:1px solid #dfe1e6;border-radius:10px;background:#f7f8f9}.todo-create-trigger input{border:0;padding:0;background:transparent}.todo-create-trigger input:focus{outline:none;border:0}.todo-create-plus{color:#5b6c8f;font-size:1.4rem;line-height:1;flex:0 0 auto}input:focus,select:focus,textarea:focus{outline:2px solid rgba(122,90,248,.18);border-color:var(--blue)}button{border:1px solid var(--line-strong);background:#f7f8f9;color:var(--text);border-radius:8px;padding:10px 14px;cursor:pointer}button:hover{background:var(--hover)}.secondary-button,.text-button{background:#fff}.text-button{border:0;padding:0;color:var(--muted)}.field{display:flex;flex-direction:column;gap:6px}.field span{font-size:.86rem;color:var(--muted)}.detail-form{display:flex;flex-direction:column;gap:18px}.detail-form-single{max-width:980px}.detail-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px}.detail-page-title-block h2{margin:4px 0 0;font-size:2.1rem;line-height:1.08}.detail-page-subtitle{margin:8px 0 0;max-width:760px;color:var(--muted);font-size:.98rem;line-height:1.45}.detail-page-title-block .page-kicker{font-size:.88rem;font-weight:700;letter-spacing:.02em;color:var(--blue)}.detail-page-actions{display:flex;align-items:center;gap:10px}.detail-tabs{display:flex;align-items:center;gap:18px;margin:0 0 22px;padding-bottom:10px;border-bottom:1px solid var(--line)}.detail-tab{border:0;border-radius:0;padding:0 0 10px;background:transparent;color:var(--muted);font-size:.98rem;font-weight:600;border-bottom:2px solid transparent}.detail-tab:hover{background:transparent;color:var(--text)}.detail-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.neutral-icon-button{width:36px;height:36px;min-width:36px;min-height:36px;padding:0;color:var(--muted);background:#fff;border-color:var(--line)}.neutral-icon-button:hover{color:var(--text);background:#f8f9fb}.project-detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:32px;align-items:start}.project-detail-layout-impact{grid-template-columns:minmax(0,860px)}.issue-layout{padding:0;background:transparent;border:0;gap:30px}.issue-section{border-top:1px solid var(--line);padding-top:14px}.issue-section-accent{position:relative;border-top:0;padding-top:0;padding-left:14px}.issue-section-accent:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:999px;background:var(--section-accent, #dfe1e6)}.issue-section:first-of-type{border-top:0;padding-top:0}.issue-section-header{margin-bottom:10px}.issue-section-header h3{margin:0;font-size:1.03rem}.detail-item{display:grid;grid-template-columns:170px minmax(0,1fr);gap:14px;align-items:start;padding:6px 0}.detail-item-stack{grid-template-columns:1fr;gap:6px}.detail-item-label{color:var(--muted);font-size:.9rem;font-weight:600}.detail-item-value{min-width:0}.detail-item-value .chip-select,.detail-item-value .country-row{padding-top:2px}.detail-read{color:var(--text);font-size:.94rem;line-height:1.45}.detail-read.strong{font-size:.98rem;font-weight:600}.detail-read-multiline{white-space:pre-wrap}.detail-bullet-list{margin:0;padding-left:18px;color:var(--text);font-size:.9rem;line-height:1.45}.detail-bullet-list li+li{margin-top:4px}.detail-empty{color:#97a0af;font-size:.94rem}.detail-link{color:#0c66e4;word-break:break-word}.issue-layout:not(.issue-edit-mode){gap:22px}.issue-layout:not(.issue-edit-mode) .issue-section{padding-top:10px}.issue-layout:not(.issue-edit-mode) .issue-section-header{margin-bottom:8px}.issue-layout:not(.issue-edit-mode) .issue-section-header h3{font-size:.98rem}.issue-layout:not(.issue-edit-mode) .detail-item{gap:12px;padding:4px 0}.issue-layout:not(.issue-edit-mode) .detail-item-label{font-size:.85rem}.issue-layout:not(.issue-edit-mode) .detail-read{font-size:.9rem;line-height:1.38}.issue-layout:not(.issue-edit-mode) .detail-read.strong{font-size:.94rem}.issue-layout:not(.issue-edit-mode) .detail-empty{font-size:.9rem}.issue-edit-mode .detail-item{align-items:center}.issue-edit-mode .detail-item-stack{align-items:start}.issue-edit-mode .detail-item-value .chip-select,.issue-edit-mode .detail-item-value .country-row{padding-top:0}.issue-edit-mode input,.issue-edit-mode select,.issue-edit-mode textarea{min-height:34px;padding:7px 10px;border-radius:6px;font-size:.93rem;border-color:#c6ccd6;box-shadow:none}.issue-edit-mode textarea{min-height:92px}.issue-sidebar{position:sticky;top:24px;align-self:start;display:flex;flex-direction:column;gap:0}.issue-meta-panel{margin:0;border-top:1px solid var(--line);padding-top:12px}.issue-meta-panel .detail-item{grid-template-columns:140px minmax(0,1fr);gap:12px;padding:4px 0}.issue-tasks-panel{margin:24px 0 0;border-top:1px solid var(--line);padding-top:24px}.issue-tasks-panel .issue-section-header{margin-bottom:10px}.issue-tasks-panel .checklist{gap:8px}.issue-tasks-panel .task-input-row{margin-bottom:12px}.issue-tasks-panel .task-input-row input{min-height:36px;padding:8px 10px;border-radius:8px}.issue-tasks-panel .task-checkbox-row.compact{min-height:38px;padding:7px 8px;border-radius:10px}.issue-sidebar .issue-section-header h3{font-size:.98rem}.issue-sidebar .detail-item-label{font-size:.85rem}.issue-sidebar .detail-read,.issue-sidebar .detail-empty{font-size:.9rem;line-height:1.38}.detail-phase-badge{max-width:none}.detail-chip-list{display:flex;flex-wrap:wrap;gap:6px}.detail-chip{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#f4f5f7;border:1px solid #e3e6eb;color:var(--text);font-size:.8rem;font-weight:600;white-space:nowrap}.detail-flag-list{display:inline-flex;align-items:center;gap:8px;min-height:24px;flex-wrap:wrap}.detail-flag{font-size:1.05rem;line-height:1}.project-size-badge{display:inline-flex;align-items:center;color:var(--text)}.project-size-shirt-shape{fill:#f7f8fa;stroke:#bfc7d4}.project-size-shirt-text{fill:#172b4d;font-size:13px;font-weight:700;letter-spacing:.02em;dominant-baseline:middle}.week-picker-field{display:flex;flex-direction:column;gap:6px}.week-picker-field input[type=week]{min-height:36px}.week-picker-meta{color:var(--muted);font-size:.82rem;line-height:1.3}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-section{display:flex;flex-direction:column;gap:12px;padding-bottom:4px}.form-section+.form-section{padding-top:12px;border-top:1px solid var(--line)}.side-form{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.task-management-done{margin-top:12px;padding-top:12px;border-top:1px solid #dfe1e6;display:flex;flex-direction:column;gap:10px}.task-drag-shell{cursor:grab;transition:opacity .12s ease,transform .12s ease}.task-drag-shell.dragging{opacity:.55;transform:scale(.985)}.section-toggle{display:inline-flex;align-items:center;gap:8px;padding:0;border:0;background:transparent;color:var(--text);font-size:.98rem;font-weight:700;align-self:flex-start}.section-toggle:hover{color:var(--blue)}.section-toggle-caret{width:12px;color:var(--muted);text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a47;display:grid;place-items:center;z-index:999998;padding:24px}.modal-card{width:min(860px,100%);max-height:calc(100vh - 48px);overflow:auto;background:#fff;border:1px solid #dfe1e6;border-radius:18px;padding:20px;box-shadow:0 24px 60px #0f172a33}.modal-card-issue{width:min(980px,100%)}.wizard-detail-form{gap:22px}.wizard-actions{display:flex;justify-content:space-between;gap:12px}.inline-check,.check-row{display:flex;align-items:center;gap:10px}.check-row input,.inline-check input{width:auto}.pin-mark{margin-left:auto;font-size:.95rem}.chip-select,.country-row{display:flex;flex-wrap:wrap;gap:8px}.task-checkbox-row{display:flex;align-items:center;gap:18px;min-height:78px;padding:18px 20px;background:#fff;border:1px solid #dfe1e6;border-radius:18px;box-shadow:0 1px 2px #091e4214}.task-checkbox-row.compact{min-height:42px;padding:8px 10px;gap:10px;border-radius:12px;box-shadow:none}.task-checkbox-row.pressing{background:#f7f8f9}.task-checkbox{position:relative;display:inline-flex;flex:0 0 auto}.task-checkbox input{position:absolute;opacity:0;top:0;right:0;bottom:0;left:0;margin:0}.task-checkbox-ui{width:36px;height:36px;border:2px solid #7a869a;border-radius:999px;background:#fff;position:relative}.task-checkbox-row.compact .task-checkbox-ui{width:20px;height:20px;border-width:1.8px;border-radius:999px}.task-checkbox input:checked+.task-checkbox-ui{background:var(--purple-soft);border-color:var(--blue)}.task-checkbox input:checked+.task-checkbox-ui:after{content:"";position:absolute;left:50%;top:50%;width:9px;height:5px;border-left:2.2px solid var(--blue);border-bottom:2.2px solid var(--blue);transform:translate(-50%,-58%) rotate(-45deg)}.task-checkbox-row.compact .task-checkbox input:checked+.task-checkbox-ui:after{width:5px;height:3px;border-left-width:1.8px;border-bottom-width:1.8px}.task-checkbox-row.done{background:var(--purple-soft);border-color:#c9c1ff}.task-title{font-size:1.1rem;line-height:1.3}.task-title-button{display:flex;align-items:center;flex:1 1 auto;min-width:0;padding:0;border:0;background:transparent;text-align:left}.task-title-button:hover{background:transparent}.task-title-input{flex:1 1 auto;min-width:0;border:0;outline:none;padding:0;background:transparent;color:var(--text);font-size:1.1rem;line-height:1.3}.task-title-input:focus{outline:none;border:0}.task-checkbox-row.compact .task-title{font-size:.95rem;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto}.task-checkbox-row.compact .task-title-input{font-size:.95rem;line-height:1.15}.chip-option,.country-pill{border:1px solid var(--line-strong);border-radius:999px;background:#fff;padding:8px 12px}.chip-option.active,.country-pill.active{border-color:#a5c4ff}.country-pill{display:inline-flex;align-items:center;gap:8px}.country-pill input{width:auto}.settings-list-editor{display:flex;flex-direction:column;gap:10px}.settings-layout{display:grid;grid-template-columns:240px minmax(0,1fr);gap:16px}.settings-subnav{display:flex;flex-direction:column;gap:6px;padding:10px;height:fit-content}.settings-subnav-link{padding:10px 12px;border-radius:8px}.settings-subnav-link:hover{background:var(--hover)}.settings-subnav-link.active{background:var(--active);color:var(--blue);font-weight:600}.settings-content,.settings-stack{display:flex;flex-direction:column;gap:16px}.settings-content{max-width:880px}.settings-stack>.surface,.settings-content>.surface{max-width:880px}.settings-item-row{display:grid;grid-template-columns:92px minmax(0,420px) minmax(120px,180px) auto;gap:10px;align-items:center;position:relative;z-index:0}.settings-item-row-draft input::placeholder{color:#7a869a}.settings-item-row-draft{grid-template-columns:minmax(0,420px) minmax(120px,180px) auto}.settings-item-row-draft .settings-draft-input{grid-column:1}.color-select-wrap{position:relative;display:inline-flex;align-items:center;min-width:92px;z-index:30}.color-select-trigger{position:relative;display:inline-flex;align-items:center;justify-content:flex-start;min-width:64px;height:40px;border:1px solid var(--line-strong);border-radius:8px;background:#fff;padding:0 30px 0 12px;color:var(--text)}.color-preview-only{pointer-events:none}.icon-button{position:relative;color:#c9372c;background:#fff5f5;border-color:#f1b3ad;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;min-width:34px;min-height:34px;padding:0}.icon-button:hover{background:#ffeceb}.color-dot{display:block;width:18px;height:18px;border-radius:999px;border:1px solid rgba(9,30,66,.14);flex:0 0 auto}.color-dot.large{width:28px;height:28px}.color-chevron{position:absolute;right:8px;color:var(--muted);display:inline-flex;pointer-events:none}.color-popover{position:absolute;width:330px;padding:12px;border:1px solid rgba(9,30,66,.16);border-radius:14px;background:#fff;box-shadow:0 14px 28px #091e422e;display:grid;grid-template-columns:repeat(8,1fr);gap:12px 10px}.color-popover-portal{position:fixed;z-index:999999}.color-popover-title{grid-column:1 / -1;font-size:.78rem;font-weight:700;text-transform:uppercase;color:var(--muted)}.color-option{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;min-height:28px;padding:0;border-radius:999px;background:transparent;border:2px solid transparent}.color-option.active{border-color:#1f2937}.color-option:hover{transform:scale(1.06)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.settings-toggle{margin-top:4px}.settings-subtitle{margin:4px 0 0;color:var(--muted);font-size:.86rem}.is-done{text-decoration:line-through;color:#4b6385}.save-note,.settings-help,.empty-note{color:var(--muted);font-size:.9rem}.small{font-size:.84rem}.related-links a{padding:6px 0;color:var(--text)}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.impact-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:16px}.impact-list{display:flex;flex-direction:column;gap:8px;padding:12px}.impact-list-item{width:100%;text-align:left;display:flex;flex-direction:column;gap:4px;background:#fff}.impact-list-item.active{background:var(--active);border-color:#a5c4ff}.impact-list-item span{color:var(--muted);font-size:.88rem}.impact-detail{display:flex;flex-direction:column;gap:16px}.impact-summary-grid,.impact-outcome-grid{display:grid;gap:12px}.impact-summary-grid,.impact-outcome-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.impact-stat{border:1px solid var(--line);border-radius:8px;padding:14px}.impact-label{display:block;color:var(--muted);font-size:.82rem;margin-bottom:8px}.impact-outcomes{display:flex;flex-direction:column;gap:12px}.app-loading{min-height:100vh;display:grid;place-items:center;background:#fff}@media(max-width:1120px){.planning-grid,.planner-create-row,.settings-grid,.settings-layout,.impact-layout,.impact-summary-grid,.impact-outcome-grid,.form-grid,.project-detail-layout,.project-detail-layout-impact{grid-template-columns:1fr}.issue-sidebar{position:static}.planning-mini-timeline{padding-left:0}.roadmap-viewport{width:100%}}@media(max-width:820px){.app-shell,.app-shell.sidebar-collapsed{grid-template-columns:72px minmax(0,1fr);height:100vh;min-height:0;overflow:hidden}.sidebar{border-right:1px solid var(--line);border-bottom:0;height:100vh;position:sticky;overflow:hidden}.main-content{height:100vh;overflow:auto}.sidebar-top{flex-direction:column;justify-content:flex-start;align-items:center;gap:10px;padding:12px 10px 16px;display:flex}.brand-copy{display:none}.brand-mark{width:44px;height:44px}.collapse-button{margin-left:0;width:40px;height:40px}.sidebar-link{justify-content:center;padding:0;width:52px;margin-inline:auto;gap:0}.sidebar-link>span:not(.sidebar-link-icon){display:none}.sidebar-link-icon{width:24px;height:24px;margin:0 auto}.sidebar-nav{padding-inline:0;align-items:center}.sidebar-nav-main,.sidebar-nav-footer{width:100%;align-items:center}.sidebar-action-link{width:52px;margin-inline:auto;padding:0;justify-content:center;gap:0}.page-header{justify-content:flex-start}.content-page,.topbar{padding:16px}.detail-page-header{flex-direction:column;align-items:flex-start}.detail-item{grid-template-columns:1fr;gap:8px}.roadmap-row,.roadmap-header-row{grid-template-columns:220px minmax(0,1fr);gap:14px}}body.is-dragging-project,body.is-dragging-project *,body.is-dragging-task,body.is-dragging-task *{cursor:move!important}.project-card{cursor:grab}.project-card:active{cursor:grabbing}@media(max-width:720px){.settings-item-row{grid-template-columns:1fr}}
