@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Fira+Code:wght@400;500&display=swap";:root{--color-primary: #3172E0;--color-primary-hover: #1a5cc4;--color-primary-light: rgba(49, 114, 224, .08);--color-bg-base: #F8F9FA;--color-bg-surface: #FFFFFF;--color-bg-alt: #F1F3F5;--color-border: #DEE2E6;--color-border-hover: #C8CDD3;--color-text-1: #1A1D21;--color-text-2: #495057;--color-text-3: #868E96;--color-green: #2F9E44;--color-red: #E03131;--color-amber: #E67700;--color-purple: #6741D9;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--shadow-card: 0 1px 4px rgba(0, 0, 0, .06);--shadow-hover: 0 2px 8px rgba(0, 0, 0, .1);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .1);--font-sans: "Pretendard", "Inter", system-ui, sans-serif;--font-mono: "Fira Code", monospace;--transition: all .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg-base);color:var(--color-text-1);font-family:var(--font-sans);letter-spacing:-.01em;line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;max-width:1180px;margin:0 auto;width:100%;padding:36px 24px;display:flex;flex-direction:column;gap:24px}.app-header{background:var(--color-bg-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.header-inner{max-width:1180px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:10px}.brand-logo{width:32px;height:32px;background:var(--color-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;color:#fff;flex-shrink:0}.brand-name{font-size:1rem;font-weight:700;color:var(--color-text-1);letter-spacing:-.02em}.brand-tag{font-size:.7rem;font-weight:500;color:var(--color-text-3);margin-left:6px}.header-controls{display:flex;align-items:center;gap:8px}.btn-primary{background:var(--color-primary);border:none;color:#fff;padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;font-weight:600;cursor:pointer;letter-spacing:-.01em;transition:var(--transition)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:active{opacity:.9}.btn-create{padding:9px 18px;font-size:.85rem}.btn-secondary{background:var(--color-bg-surface);border:1px solid var(--color-border);color:var(--color-text-2);padding:10px 20px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-secondary:hover{background:var(--color-bg-alt);border-color:var(--color-border-hover)}.btn-link{color:var(--color-primary);font-size:.8rem;font-weight:500;text-decoration:none;padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-sans);transition:var(--transition)}.btn-link:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px 28px;box-shadow:var(--shadow-card)}.stat-label{color:var(--color-text-3);font-size:.75rem;font-weight:500;letter-spacing:.02em}.stat-row{display:flex;align-items:baseline;gap:5px;margin-top:8px}.stat-value{font-size:2rem;font-weight:700;letter-spacing:-.03em}.stat-color-blue{color:var(--color-primary)}.stat-color-green{color:var(--color-green)}.stat-color-purple{color:var(--color-purple)}.stat-unit{font-size:.85rem;color:var(--color-text-3);font-weight:400}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.filter-tabs{display:flex;gap:2px;background:var(--color-bg-alt);padding:3px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.filter-btn{background:transparent;border:none;color:var(--color-text-3);font-family:var(--font-sans);font-size:.84rem;font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap}.filter-btn.active{background:var(--color-bg-surface);color:var(--color-text-1);font-weight:600;box-shadow:0 1px 3px #0000000f}.filter-btn:not(.active):hover{color:var(--color-text-1)}.search-wrap{position:relative;flex:0 1 260px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:.8rem;pointer-events:none}.search-input{width:100%;padding:9px 14px 9px 34px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:.875rem;color:var(--color-text-1);outline:none;transition:var(--transition)}.search-input::placeholder{color:var(--color-text-3)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.error-banner{background:#e031310d;border:1px solid rgba(224,49,49,.2);border-radius:var(--radius-md);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;color:var(--color-red);font-size:.875rem;font-weight:500}.btn-retry{background:var(--color-red);color:#fff;border:none;padding:6px 14px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:var(--transition)}.btn-retry:hover{opacity:.85}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.portfolio-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:16px;transition:border-color .15s ease}.portfolio-card:hover{border-color:var(--color-border-hover)}.card-top{display:flex;flex-direction:column;gap:4px}.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.card-meta{min-width:0}.card-name{font-size:1.05rem;font-weight:700;color:var(--color-text-1);letter-spacing:-.02em;line-height:1.3}.card-subtitle{font-size:.82rem;color:var(--color-text-2);margin-top:2px;line-height:1.45}.card-period{font-size:.75rem;color:var(--color-text-3);margin-top:5px}.card-role{font-size:.85rem;color:var(--color-text-2)}.card-desc{font-size:.875rem;line-height:1.55;color:var(--color-text-2);white-space:pre-line}.card-links{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.card-stacks{display:flex;flex-wrap:wrap;gap:5px}.badge-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;white-space:nowrap;flex-shrink:0}.badge-status.active{background:#2f9e4414;color:var(--color-green);border:1px solid rgba(47,158,68,.15)}.badge-status.inactive{background:var(--color-bg-alt);color:var(--color-text-3);border:1px solid var(--color-border)}.badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.stack-badge{background:var(--color-bg-alt);color:var(--color-text-2);padding:3px 8px;border-radius:4px;font-size:.73rem;font-weight:500;border:1px solid var(--color-border)}.card-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;border-top:1px solid var(--color-border);padding-top:14px}.card-actions{display:flex;gap:4px}.btn-icon{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px 10px;font-family:var(--font-sans);font-size:.75rem;font-weight:500;cursor:pointer;transition:var(--transition);color:var(--color-text-3)}.btn-icon:hover{background:var(--color-bg-alt);color:var(--color-text-2)}.btn-edit:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.btn-activate:hover{border-color:var(--color-green);color:var(--color-green);background:#2f9e440f}.btn-deactivate:hover{border-color:var(--color-amber);color:var(--color-amber);background:#e677000f}.btn-delete:hover{border-color:var(--color-red);color:var(--color-red);background:#e031310f}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;gap:12px}.empty-title{font-size:.95rem;font-weight:500;color:var(--color-text-3)}.empty-spinner{width:32px;height:32px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;padding:24px;z-index:200;animation:fade-in .12s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--color-bg-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);width:100%;max-width:480px;padding:32px;box-shadow:var(--shadow-modal);animation:slide-up .18s ease;max-height:90vh;overflow-y:auto}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:1.05rem;font-weight:700;color:var(--color-text-1);letter-spacing:-.02em}.modal-close{background:var(--color-bg-alt);border:1px solid var(--color-border);width:30px;height:30px;border-radius:var(--radius-sm);font-size:.85rem;color:var(--color-text-3);cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--color-border);color:var(--color-text-1)}.form-stack{display:flex;flex-direction:column;gap:18px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8rem;font-weight:600;color:var(--color-text-2)}.form-input{width:100%;padding:10px 14px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-1);font-family:var(--font-sans);font-size:.9rem;outline:none;transition:var(--transition)}.form-input::placeholder{color:var(--color-text-3)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-input[type=number]::-webkit-inner-spin-button,.form-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.form-hint{font-size:.8rem;color:var(--color-text-3)}.link-editor{display:flex;flex-direction:column;gap:8px}.link-editor-row{display:flex;gap:8px;align-items:center}.link-type-select{flex:0 0 130px;min-width:0}.link-label-input{flex:0 0 120px;min-width:0}.link-url-input{flex:1;min-width:0}.btn-add-link{align-self:flex-start;padding:6px 14px;font-size:.82rem;margin-top:2px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}.stack-selected-wrap{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.stack-tag-selected{display:inline-flex;align-items:center;gap:4px;background:var(--color-primary-light);color:var(--color-primary);border:1px solid rgba(49,114,224,.2);padding:3px 8px;border-radius:4px;font-size:.78rem;font-weight:500}.stack-tag-remove{background:none;border:none;cursor:pointer;color:var(--color-primary);font-size:.9rem;line-height:1;padding:0;opacity:.7;transition:opacity .1s}.stack-tag-remove:hover{opacity:1}.stack-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);z-index:300;max-height:280px;overflow-y:auto;padding:6px}.stack-category-label{font-size:.68rem;font-weight:700;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.06em;padding:8px 10px 4px}.stack-category-items{display:flex;flex-wrap:wrap;gap:4px;padding:0 6px 8px}.stack-option-btn{background:var(--color-bg-alt);border:1px solid var(--color-border);color:var(--color-text-2);padding:4px 10px;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:var(--transition)}.stack-option-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.landing-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:72px 24px 80px;gap:64px}.landing-hero{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:680px;gap:20px}.landing-hero-badge{display:inline-block;background:var(--color-primary-light);color:var(--color-primary);border:1px solid rgba(49,114,224,.2);border-radius:20px;padding:5px 16px;font-size:.78rem;font-weight:600;letter-spacing:.02em}.landing-title{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800;color:var(--color-text-1);letter-spacing:-.03em;line-height:1.25}.landing-subtitle{font-size:1rem;line-height:1.7;color:var(--color-text-2)}.landing-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:8px}.landing-btn-lg{padding:13px 32px;font-size:.95rem;font-weight:600;border-radius:var(--radius-lg);text-decoration:none;transition:var(--transition);display:inline-block}a.btn-primary.landing-btn-lg:hover{background:var(--color-primary-hover)}a.btn-secondary.landing-btn-lg:hover{background:var(--color-bg-alt);border-color:var(--color-border-hover)}.landing-hint{font-size:.85rem;color:var(--color-text-3);margin-top:4px}.landing-link{color:var(--color-primary);text-decoration:none;font-weight:500}.landing-link:hover{text-decoration:underline}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;width:100%;max-width:860px}.landing-feature-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px 24px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:12px;transition:border-color .15s ease,box-shadow .15s ease}.landing-feature-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-hover)}.landing-feature-icon{font-size:1.75rem;line-height:1}.landing-feature-title{font-size:.95rem;font-weight:700;color:var(--color-text-1);letter-spacing:-.01em}.landing-feature-desc{font-size:.875rem;line-height:1.6;color:var(--color-text-2)}.card-body{display:flex;flex-direction:column;flex:1}.card-section{display:flex;flex-direction:column;gap:4px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.card-section-label{font-size:.67rem;font-weight:700;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.08em}.card-desc-clamp{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.gantt-wrapper{display:flex;flex-direction:column;gap:16px}.gantt-container{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;overflow-x:auto;box-shadow:var(--shadow-card)}.gantt-header-wrapper{position:sticky;top:60px;z-index:10;background:var(--color-bg-alt);border-bottom:2px solid var(--color-border)}.gantt-header-row{display:flex;background:var(--color-bg-alt)}.gantt-label-col{width:220px;min-width:220px;padding:0 16px;border-right:1px solid var(--color-border);display:flex;align-items:center;gap:8px;flex-shrink:0;overflow:hidden}.gantt-timeline-col{flex:1;position:relative;min-width:0;min-height:52px}.gantt-header-label-col{font-size:.68rem;font-weight:700;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.07em;min-height:28px}.gantt-header-month-label-col{min-height:28px}.gantt-header-timeline-col{display:flex;flex:1;min-width:0}.gantt-year-row{border-bottom:1px solid var(--color-border)}.gantt-year-cell{display:flex;align-items:center;justify-content:center;min-height:28px;border-right:1px solid var(--color-border);font-size:.72rem;font-weight:700;color:var(--color-text-2);letter-spacing:.02em;flex-shrink:0;overflow:hidden}.gantt-year-cell:last-child{border-right:none}.gantt-month-cell{display:flex;align-items:center;justify-content:center;min-height:28px;border-right:1px solid var(--color-border);flex-shrink:0;overflow:hidden}.gantt-month-cell:last-child{border-right:none}.gantt-month-text{font-size:.68rem;font-weight:500;color:var(--color-text-3);white-space:nowrap}.gantt-data-row{display:flex;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .1s ease;min-height:52px}.gantt-data-row:last-child{border-bottom:none}.gantt-data-row:hover{background:var(--color-bg-alt)}.gantt-project-name{font-size:.82rem;font-weight:600;color:var(--color-text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:128px}.gantt-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--color-border);pointer-events:none}.gantt-today-marker{position:absolute;top:0;bottom:0;transform:translate(-50%);pointer-events:none;z-index:5}.gantt-today-line{position:absolute;top:0;bottom:0;left:0;width:2px;background:var(--color-red);opacity:.75}.gantt-today-dot{position:absolute;top:4px;left:-4px;width:8px;height:8px;background:var(--color-red);border-radius:50%}.gantt-bar{position:absolute;top:50%;transform:translateY(-50%);height:28px;border-radius:6px;display:flex;align-items:center;padding:0 10px;overflow:hidden;transition:opacity .15s ease,filter .15s ease;min-width:4px;cursor:pointer}.gantt-data-row:hover .gantt-bar{filter:brightness(.92)}.gantt-bar-active{background:var(--color-primary)}.gantt-bar-inactive{background:var(--color-bg-alt);border:1px solid var(--color-border)}.gantt-bar-ongoing{background:linear-gradient(90deg,var(--color-primary) 80%,rgba(49,114,224,.3) 100%)}.gantt-bar-text{font-size:.73rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.gantt-bar-active .gantt-bar-text,.gantt-bar-ongoing .gantt-bar-text{color:#fff}.gantt-bar-inactive .gantt-bar-text{color:var(--color-text-3)}.gantt-no-date-section{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-card)}.gantt-no-date-title{font-size:.7rem;font-weight:700;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}.gantt-no-date-list{display:flex;flex-direction:column;gap:6px}.gantt-no-date-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--color-bg-alt);border-radius:var(--radius-sm);cursor:pointer;transition:background .1s ease}.gantt-no-date-item:hover{background:var(--color-border)}.detail-body{display:flex;flex-direction:column;gap:0}.detail-section{display:flex;flex-direction:column;gap:6px;padding:16px 0;border-bottom:1px solid var(--color-border)}.detail-section:first-child{padding-top:0}.detail-section:last-child{border-bottom:none}.detail-section-header{font-size:.67rem;font-weight:700;color:var(--color-text-3);text-transform:uppercase;letter-spacing:.09em}.detail-value{font-size:.9rem;color:var(--color-text-1);line-height:1.6}.detail-desc{white-space:pre-line;color:var(--color-text-2)}.detail-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.detail-link-btn{display:inline-flex;align-items:center;gap:4px;color:var(--color-primary);font-size:.83rem;font-weight:500;text-decoration:none;padding:5px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);transition:var(--transition)}.detail-link-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.detail-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid var(--color-border)}.stack-badge-lg{font-size:.8rem;padding:4px 10px}.portfolio-card{cursor:pointer;justify-content:space-between}.app-footer{border-top:1px solid var(--color-border);padding:16px 24px;text-align:center;font-size:.78rem;color:var(--color-text-3);background:var(--color-bg-surface)}@media (prefers-color-scheme: dark){:root{--color-bg-base: #111418;--color-bg-surface: #1C2128;--color-bg-alt: #252B33;--color-border: #30363D;--color-border-hover: #484F58;--color-text-1: #E6EDF3;--color-text-2: #8B949E;--color-text-3: #484F58;--shadow-card: 0 1px 4px rgba(0, 0, 0, .3);--shadow-hover: 0 2px 8px rgba(0, 0, 0, .4);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .4)}}body.dark-mode{--color-bg-base: #111418;--color-bg-surface: #1C2128;--color-bg-alt: #252B33;--color-border: #30363D;--color-border-hover: #484F58;--color-text-1: #E6EDF3;--color-text-2: #8B949E;--color-text-3: #484F58;--shadow-card: 0 1px 4px rgba(0, 0, 0, .3);--shadow-hover: 0 2px 8px rgba(0, 0, 0, .4);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .4)}body.light-mode{--color-bg-base: #F8F9FA;--color-bg-surface: #FFFFFF;--color-bg-alt: #F1F3F5;--color-border: #DEE2E6;--color-border-hover: #C8CDD3;--color-text-1: #1A1D21;--color-text-2: #495057;--color-text-3: #868E96;--shadow-card: 0 1px 4px rgba(0, 0, 0, .06);--shadow-hover: 0 2px 8px rgba(0, 0, 0, .1);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .1)}.header-nav-tabs{display:flex;gap:4px;background:var(--color-bg-alt);border-radius:8px;padding:3px;border:1px solid var(--color-border)}.nav-tab{padding:6px 16px;border:none;background:none;border-radius:6px;font-size:.84rem;font-weight:500;color:var(--color-text-3);cursor:pointer;transition:all .15s}.nav-tab:hover{color:var(--color-text-1)}.nav-tab.active{background:var(--color-bg-surface);color:var(--color-text-1);box-shadow:0 1px 3px #0000001a}.sync-page{display:flex;flex-direction:column;gap:24px}.sync-section{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px}.sync-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sync-section-title{font-size:1rem;font-weight:600;color:var(--color-text-1)}.sync-summary-box{background:var(--color-bg-alt);border-radius:var(--radius-sm);padding:16px;min-height:60px;border:1px solid var(--color-border)}.sync-site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.sync-site-card{background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:10px}.sync-site-top{display:flex;align-items:center;gap:8px}.sync-site-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sync-site-name{font-size:.9rem;font-weight:600;color:var(--color-text-1);flex:1}.sync-registered-badge{font-size:.7rem;padding:2px 7px;border-radius:999px;background:var(--color-primary-light);color:var(--color-primary);font-weight:600}.sync-session-badge{font-size:.7rem;padding:2px 7px;border-radius:999px;font-weight:600}.sync-session-badge.active{background:#d3f9d8;color:#2f9e44}.sync-session-badge.inactive{background:#fff3bf;color:#e67700}.sync-site-id{font-size:.8rem;color:var(--color-text-3);font-family:Fira Code,monospace}.sync-site-actions{display:flex;gap:6px;flex-wrap:wrap}.sync-history-list{display:flex;flex-direction:column;gap:6px}.sync-history-item{display:grid;grid-template-columns:80px 80px 1fr auto;gap:10px;align-items:center;padding:10px 14px;background:var(--color-bg-alt);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:.83rem}.sync-status-badge{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:999px;text-align:center}.sync-status-success{background:#d3f9d8;color:#2f9e44}.sync-status-failed{background:#ffe3e3;color:#e03131}.sync-status-running{background:#fff3bf;color:#e67700}.sync-history-site{font-weight:600;color:var(--color-text-2)}.sync-history-msg{color:var(--color-text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sync-history-dt{color:var(--color-text-3);font-size:.75rem;white-space:nowrap}.manual-login-modal{background:var(--color-bg-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;max-width:100vw;max-height:100vh;overflow:hidden}.manual-login-browser{position:relative;overflow:hidden;background:#000;flex-shrink:0}.manual-login-browser img{display:block}.manual-login-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-3);font-size:.9rem}.manual-login-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center}.manual-login-toolbar{padding:12px 16px;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:10px;background:var(--color-bg-surface)}.manual-login-input-row{display:flex;gap:6px;align-items:center}.manual-login-footer{display:flex;justify-content:space-between;align-items:center;gap:12px}.sync-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:900;display:flex;align-items:center;justify-content:center;padding:16px}.sync-modal{background:var(--color-bg-surface);border-radius:12px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 48px #0006;overflow:hidden}.sync-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--color-border);flex-shrink:0}.sync-modal-title{font-size:1rem;font-weight:600}.sync-phase-tag{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.74rem;font-weight:500}.sync-phase-starting{background:var(--color-bg-hover);color:var(--color-text-3)}.sync-phase-login{background:#fff3cd;color:#856404}.sync-phase-ai{background:#d1ecf1;color:#0c5460}.sync-phase-done{background:#d4edda;color:#155724}.dark .sync-phase-login{background:#3d3000;color:#ffc107}.dark .sync-phase-ai{background:#003040;color:#17a2b8}.dark .sync-phase-done{background:#003010;color:#28a745}.sync-modal-body{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:12px;padding:14px 18px}.sync-browser-wrap{width:100%;border-radius:6px;overflow:hidden;border:1px solid var(--color-border);background:#000}.sync-browser-img{display:block;width:100%;height:auto}.sync-browser-interactive{cursor:crosshair}.sync-browser-placeholder{height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-bg-hover);border-radius:6px}.sync-login-ctrl{display:flex;flex-direction:column;gap:8px}.sync-login-input{width:100%}.sync-key-btns{display:flex;gap:6px}.sync-log-box{background:#0f1117;color:#c9d1d9;border-radius:6px;padding:10px 14px;font-family:monospace;font-size:.75rem;line-height:1.6;max-height:180px;overflow-y:auto;flex-shrink:0}.sync-log-line{white-space:pre-wrap;word-break:break-all}.sync-result{padding:10px 14px;border-radius:6px;font-size:.88rem;font-weight:500}.sync-result-ok{background:#d4edda;color:#155724}.sync-result-fail{background:#f8d7da;color:#721c24}.dark .sync-result-ok{background:#003010;color:#7ddf9a}.dark .sync-result-fail{background:#3d0010;color:#f77}@media (max-width: 640px){.sync-history-item{grid-template-columns:70px 70px 1fr}.sync-history-dt,.header-nav-tabs{display:none}}
