*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}ul,ol{list-style:none}button{font-family:inherit}a{text-decoration:none;color:inherit}html{scroll-behavior:smooth}::selection{background:#313d5a33;color:inherit}:root{--color-bg: #fafafa;--color-surface: #ffffff;--color-text-primary: #313D5A;--color-text-secondary: #5f5f5f;--color-text-muted: #8e8e8e;--color-border: #efefef;--color-border-hover: #e0e0e0;--color-accent: #313D5A;--color-accent-hover: #232b40;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-hover: 0 8px 20px rgba(0, 0, 0, .15);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: 12px;--font-size-sm: 15px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 21px;--font-size-2xl: 29px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--column-width: 280px;--grid-gap: 16px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--color-bg);color:var(--color-text-primary);line-height:1.5;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;gap:var(--spacing-xl);height:72px;box-sizing:border-box}.logo{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-accent);font-weight:600;font-size:var(--font-size-lg);flex-shrink:0}.logo svg{height:36px;width:auto}.category-shelf-container{position:sticky;top:72px;z-index:90;display:flex;align-items:flex-start;background:var(--color-surface);border-bottom:1px solid var(--color-border);padding-right:var(--spacing-xl)}.category-shelf{flex:1;padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;flex-wrap:wrap;gap:calc(var(--spacing-sm) - 1px)}.category-chip{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-full);background:var(--color-bg);border:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);cursor:pointer;white-space:nowrap;transition:all var(--transition-normal)}.category-chip:hover{background:var(--color-border)}.category-chip.active{background:var(--color-text-primary);color:var(--color-surface);border-color:var(--color-text-primary)}.add-category-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);border:1px dashed var(--color-text-muted);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.add-category-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.search-button-container{position:relative;display:flex;align-items:center}.search-btn{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-normal)}.search-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.search-input-wrapper{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-accent);border-radius:var(--radius-full);box-shadow:0 0 0 3px #313d5a1a;animation:searchExpand .2s ease}@keyframes searchExpand{0%{opacity:0;transform:scaleX(.5)}to{opacity:1;transform:scaleX(1)}}.search-input-wrapper svg{color:var(--color-text-muted);flex-shrink:0}.search-input{border:none;background:transparent;font-size:var(--font-size-sm);color:var(--color-text-primary);outline:none;width:160px}.search-input::placeholder{color:var(--color-text-muted)}.search-close-btn{width:24px;height:24px;border-radius:var(--radius-full);background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.search-close-btn:hover{background:var(--color-bg);color:var(--color-text-primary)}.sort-button-container{position:relative;display:flex;align-items:center}.sort-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}.sort-btn:hover,.sort-btn.active{background:var(--color-border);color:var(--color-text-primary)}.sort-btn svg:first-child{opacity:.7}.sort-btn .chevron{transition:transform var(--transition-normal);opacity:.5}.sort-btn .chevron.rotated{transform:rotate(180deg)}.sort-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;z-index:200;overflow:hidden;animation:dropdownAppear .2s ease}@keyframes dropdownAppear{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.sort-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md) var(--spacing-lg);border:none;background:transparent;text-align:left;font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.sort-option:hover{background:var(--color-bg)}.sort-option.selected{background:var(--color-bg);color:var(--color-accent);font-weight:500}.sort-option svg{color:var(--color-accent)}.category-shelf-actions{position:relative;display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0;z-index:100;padding:var(--spacing-md) 0;padding-right:var(--spacing-xl)}.category-settings-container{position:relative;display:flex;align-items:center;animation:buttonSlideIn .25s ease}@keyframes buttonSlideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.category-settings-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);background:var(--color-bg);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.category-settings-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.category-settings-btn svg{opacity:.7}.category-settings-btn span{white-space:nowrap}.category-settings-btn .chevron{transition:transform var(--transition-normal);opacity:.5}.category-settings-btn .chevron.rotated{transform:rotate(180deg)}.category-settings-btn.active{background:var(--color-border);color:var(--color-text-primary)}.category-action-dropdown{position:absolute;top:100%;right:0;margin-top:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:220px;z-index:200;overflow:hidden;animation:dropdownAppear .2s ease}.action-menu-item{display:flex;align-items:center;width:100%;padding:var(--spacing-md) var(--spacing-xl);border:none;background:transparent;text-align:left;font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast)}.action-menu-item:hover{background:var(--color-bg)}.action-menu-item.delete{color:var(--color-accent)}.action-menu-item.delete:hover{background:#313d5a1a}.action-menu-item svg{flex-shrink:0;margin-right:var(--spacing-sm)}.add-category-input-wrapper{display:flex;align-items:center;gap:var(--spacing-xs)}.inline-category-input{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg);font-size:var(--font-size-sm);color:var(--color-text-primary);outline:none;width:140px;transition:all var(--transition-fast)}.inline-category-input:focus{border-color:var(--color-accent)}.inline-category-input::placeholder{color:var(--color-text-muted)}.inline-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm);border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-fast)}.inline-btn.confirm{background:#f0544f;color:#fff}.inline-btn.confirm:hover{opacity:.9}.inline-btn.cancel{background:var(--color-bg);color:var(--color-text-muted)}.inline-btn.cancel:hover{background:var(--color-border);color:var(--color-text-primary)}.rename-category-form{padding:var(--spacing-md)}.rename-category-form .inline-category-input{width:100%;margin-bottom:var(--spacing-sm)}.rename-actions{display:flex;gap:var(--spacing-sm)}.rename-actions .inline-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.app-main{flex:1;padding:var(--spacing-xl);max-width:2000px;margin:0 auto;width:100%}.add-link-container{flex:1;max-width:600px;display:flex;align-items:center;background:var(--color-bg);border-radius:var(--radius-full);padding:var(--spacing-sm) var(--spacing-md);transition:all var(--transition-normal);border:2px solid transparent}.add-link-container.focused{background:var(--color-surface);border-color:var(--color-accent);box-shadow:0 0 0 4px #313d5a1a}.add-link-icon{color:var(--color-text-muted);display:flex;align-items:center;margin-right:var(--spacing-sm)}.add-link-input{flex:1;border:none;background:transparent;font-size:var(--font-size-base);color:var(--color-text-primary);outline:none}.add-link-input::placeholder{color:var(--color-text-muted)}.add-link-button{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:all var(--transition-normal)}.add-link-button.visible{opacity:1;transform:scale(1)}.add-link-button:hover:not(:disabled){background:var(--color-accent-hover);transform:scale(1.05)}.add-link-button:disabled{cursor:not-allowed;opacity:.5}.add-link-container.error{border-color:#dc3545}.add-link-container.error.focused{box-shadow:0 0 0 4px #dc354526}.add-link-container.valid{border-color:#28a745}.add-link-container.valid.focused{box-shadow:0 0 0 4px #28a74526}.add-link-error{font-size:var(--font-size-xs);color:#dc3545;white-space:nowrap;margin-right:var(--spacing-sm)}.masonry-grid{display:flex;gap:var(--grid-gap);align-items:flex-start}.masonry-column{flex:1;display:flex;flex-direction:column;gap:var(--grid-gap);min-width:0}.pin-card-wrapper{opacity:1;transform:translateY(0);will-change:transform,opacity}.animate-entrance .pin-card-wrapper{opacity:0;transform:translateY(20px);animation:cardAppear .4s ease forwards}@keyframes cardAppear{to{opacity:1;transform:translateY(0)}}.pin-card{break-inside:avoid;width:100%;background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:all var(--transition-normal);cursor:grab;position:relative}.pin-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.pin-card.drag-target{outline:2px dashed var(--color-accent);outline-offset:4px}.pin-card.loading{opacity:.7;cursor:not-allowed}.pin-card:active{cursor:grabbing}.pin-image-container{position:relative;cursor:pointer;overflow:hidden}.pin-image{width:100%;height:auto;display:block;transition:transform var(--transition-slow)}.pin-card:hover .pin-image{transform:scale(1.02)}.pin-placeholder{height:160px;background:linear-gradient(135deg,#f0f0f0,#e8e8e8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm)}.pin-favicon-large{width:48px;height:48px;border-radius:var(--radius-sm)}.pin-domain{color:var(--color-text-muted);font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90%;text-align:center}.pin-loading-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}.pin-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.3) 0%,transparent 40%,transparent 60%,rgba(0,0,0,.3) 100%);opacity:0;transition:opacity var(--transition-normal);display:flex;justify-content:flex-end;padding:var(--spacing-md);gap:var(--spacing-sm)}.pin-overlay.visible{opacity:1}.pin-action-button{width:36px;height:36px;border-radius:var(--radius-full);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.delete-button{background:#111111b3;color:#fff}.delete-button:hover{background:#f0544f;transform:scale(1.1)}.open-button{background:#ffffffe6;color:var(--color-text-primary)}.open-button:hover{background:#fff;transform:scale(1.1)}.pin-content{padding:var(--spacing-md)}.pin-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.pin-favicon{width:16px;height:16px;border-radius:4px}.pin-site-name{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.pin-title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm);cursor:pointer;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.pin-title:hover{color:var(--color-accent)}.pin-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.resume-card{margin-top:var(--spacing-md);border-top:1px solid var(--color-border);padding-top:var(--spacing-md)}.resume-toggle{display:flex;align-items:center;gap:var(--spacing-sm);background:none;border:none;cursor:pointer;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-xs) 0;transition:color var(--transition-fast)}.resume-toggle:hover{color:var(--color-text-primary)}.toggle-icon{transition:transform var(--transition-normal)}.toggle-icon.rotated{transform:rotate(180deg)}.resume-label{font-weight:500;background:linear-gradient(135deg,var(--color-accent) 0%,#4e5d7d 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.resume-content{max-height:0;overflow:hidden;transition:max-height var(--transition-normal),opacity var(--transition-normal);opacity:0}.resume-content.visible{max-height:500px;opacity:1}.resume-list{list-style:none;padding:var(--spacing-md) 0 0}.resume-item{position:relative;padding-left:var(--spacing-md);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.resume-item:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--color-accent);border-radius:50%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;min-height:400px}.empty-icon{color:var(--color-text-muted);margin-bottom:var(--spacing-lg);opacity:.5}.empty-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.empty-description{font-size:var(--font-size-base);color:var(--color-text-muted);max-width:300px}.onboarding{max-width:560px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-xl);animation:onboardingFadeIn .6s ease}@keyframes onboardingFadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.onboarding-hero{text-align:center;margin-bottom:var(--spacing-2xl)}.onboarding-logo{display:block;margin:0 auto var(--spacing-md);max-width:100%;height:auto}.onboarding-subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary);font-weight:500;margin-bottom:var(--spacing-lg)}.onboarding-intro{font-size:var(--font-size-base);color:var(--color-text-muted);line-height:1.7;max-width:460px;margin:0 auto}.onboarding-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg) var(--spacing-xl);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-sm)}.onboarding-section-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-lg);text-transform:uppercase;letter-spacing:.5px;font-size:var(--font-size-xs)}.onboarding-features{display:flex;flex-direction:column;gap:var(--spacing-lg)}.onboarding-feature{display:flex;align-items:flex-start;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.onboarding-feature strong{color:var(--color-text-primary)}.onboarding-feature-icon{font-size:22px;flex-shrink:0;width:32px;text-align:center}.onboarding-steps{display:flex;flex-direction:column;gap:var(--spacing-md)}.onboarding-step{display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.onboarding-step-number{width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:600;flex-shrink:0}@media(max-width:768px){.app-header{flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-md)}.add-link-container{max-width:none;width:100%}.app-main{padding:var(--spacing-md)}:root{--column-width: 160px;--grid-gap: 12px}}@media(max-width:480px){:root{--column-width: 100%}.masonry-grid{columns:1}}.pin-card[draggable=true]{-webkit-user-select:none;user-select:none}.pin-card.dragging{opacity:.5;transform:rotate(2deg)}.pin-resume-indicator{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-accent);opacity:.8}.pin-resume-indicator svg{opacity:.7}.pin-meta-row{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm);flex-wrap:wrap}.pin-category-indicator{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-bg);padding:4px 8px;border-radius:var(--radius-full);width:fit-content}.pin-category-indicator svg{opacity:.7;flex-shrink:0}.pin-time-indicator{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-bg);padding:4px 8px;border-radius:var(--radius-full);width:fit-content}.pin-time-indicator svg{opacity:.7;flex-shrink:0}.modal-backdrop{position:fixed;inset:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);animation:fadeIn .2s ease}.modal-container{position:relative;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;max-width:650px;max-height:85vh;width:95%;overflow:hidden;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:var(--spacing-md);right:var(--spacing-md);z-index:10;width:36px;height:36px;border-radius:var(--radius-full);background:#ffffffe6;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.modal-close:hover{background:#fff;transform:scale(1.05);box-shadow:var(--shadow-lg)}.modal-content{display:flex;flex-direction:column;height:auto;max-height:85vh;overflow:hidden}.modal-text-section{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.modal-scroll-container{flex:1;padding:var(--spacing-xl);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-md);scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.category-chip-container{position:relative;display:flex;align-items:center}.category-trash-zone{position:fixed;bottom:var(--spacing-2xl);left:50%;transform:translate(-50%) translateY(100px);background:var(--color-accent);color:#fff;padding:var(--spacing-md) var(--spacing-2xl);border-radius:var(--radius-full);display:flex;align-items:center;gap:var(--spacing-sm);box-shadow:var(--shadow-lg);z-index:2000;transition:all var(--transition-normal);pointer-events:none;opacity:0}.category-trash-zone.visible{transform:translate(-50%) translateY(0);opacity:1;pointer-events:all}.category-trash-zone.active{background:#313d5a;transform:translate(-50%) translateY(-10px) scale(1.1);box-shadow:0 0 20px #313d5a66}.category-trash-zone svg{animation:shake .5s infinite alternate}@keyframes shake{0%{transform:rotate(-5deg)}to{transform:rotate(5deg)}}.modal-chat-section{margin-top:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md);padding-bottom:0}.chat-message{display:flex;flex-direction:column;max-width:85%;animation:messageIn .3s ease}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{align-self:flex-end}.chat-message.assistant{align-self:flex-start}.message-content{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-base);line-height:1.5}.user .message-content{background:var(--color-accent);color:#fff;border-bottom-right-radius:4px}.assistant .message-content{background:var(--color-bg);color:var(--color-text-primary);border-bottom-left-radius:4px;border:1px solid var(--color-border)}.typing-indicator{display:flex;gap:4px;padding:12px 16px}.typing-indicator span{width:6px;height:6px;background:var(--color-text-muted);border-radius:50%;opacity:.4;animation:typing 1s infinite alternate}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%{opacity:.4;transform:translateY(0)}to{opacity:1;transform:translateY(-4px)}}.modal-footer{padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-border);background:var(--color-surface);display:flex;flex-direction:column;gap:var(--spacing-md)}.question-form{display:flex;gap:var(--spacing-sm);background:var(--color-bg);padding:4px;border-radius:var(--radius-full);border:1px solid var(--color-border);transition:all var(--transition-normal)}.question-form:focus-within{border-color:var(--color-accent);background:#fff;box-shadow:0 0 0 3px #313d5a1a}.question-input{flex:1;border:none;background:transparent;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);outline:none;color:var(--color-text-primary)}.question-submit{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0}.question-submit svg{width:16px;height:16px}.question-submit:hover:not(:disabled){background:var(--color-accent-hover);transform:scale(1.05)}.question-submit:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(1)}@media(max-width:768px){.modal-text-section{height:60vh}}.modal-header{position:relative;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);padding-right:48px}.modal-header-left{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0}.modal-header-favicon{width:20px;height:20px;border-radius:4px}.modal-site-name{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:20ch;flex-shrink:1}.modal-date-separator{color:var(--color-text-muted);opacity:.5;flex-shrink:0}.modal-date{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}.modal-category-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg);font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-category-btn:hover{border-color:var(--color-text-muted);background:var(--color-surface)}.modal-category-btn.active{border-color:var(--color-accent);background:var(--color-surface)}.modal-category-btn .chevron{transition:transform var(--transition-normal);opacity:.5}.modal-category-btn .chevron.rotated{transform:rotate(180deg)}.category-cloud{position:absolute;top:100%;right:0;margin-top:var(--spacing-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition-normal);min-width:240px;max-width:450px}.category-cloud.open{opacity:1;visibility:visible;transform:translateY(0)}.category-cloud-inner{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);padding:var(--spacing-md);align-items:flex-start;align-content:flex-start}.category-cloud-chip{padding:8px 16px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-bg);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.category-cloud-chip:hover{border-color:var(--color-text-muted);background:var(--color-surface);transform:translateY(-1px)}.category-cloud-chip.selected{background:var(--color-text-primary);color:var(--color-surface);border-color:var(--color-text-primary)}.modal-title{font-size:var(--font-size-2xl);font-weight:600;color:#252525;line-height:1.2}.modal-description{font-size:var(--font-size-base);color:#252525;line-height:1.6}.modal-resume{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.modal-resume-label{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#f0544f,#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-resume-label svg{stroke:#f0544f}.modal-resume-list{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-sm)}.modal-resume-item{position:relative;padding-left:var(--spacing-lg);font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6}.modal-resume-item:before{content:"";position:absolute;left:0;top:.8em;transform:translateY(-50%);width:8px;height:8px;background:#f0544f;border-radius:50%}.modal-open-button{margin-top:auto;padding:var(--spacing-md) var(--spacing-lg);background:#f0544f;color:#fff;border:none;border-radius:var(--radius-full);font-size:var(--font-size-base);font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);transition:all var(--transition-normal)}.modal-open-button:hover{background:#d6403c;transform:translateY(-2px);box-shadow:0 4px 12px #f0544f4d}@media(max-width:768px){.modal-backdrop{padding:0;align-items:flex-end}.modal-container{max-height:95vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-content{flex-direction:column}.modal-image-section{max-height:40vh}.modal-text-section{padding:var(--spacing-lg)}.modal-title{font-size:var(--font-size-xl)}}.settings-cog{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0;margin-left:auto}.settings-cog:hover{background:var(--color-bg);color:var(--color-text-primary);transform:rotate(45deg)}.settings-modal-container{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:650px;overflow:hidden;animation:slideUp .3s ease}.settings-modal-header{padding:var(--spacing-md) var(--spacing-xl);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.settings-modal-title-group{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-text-primary)}.settings-modal-title-group svg{color:var(--color-text-muted)}.settings-modal-header h2{font-size:var(--font-size-base);font-weight:600}.modal-close-small{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close-small:hover{background:var(--color-bg);color:var(--color-text-primary)}.settings-content{padding:var(--spacing-lg) var(--spacing-xl);display:flex;flex-direction:column;gap:var(--spacing-md)}.masonry-grid.grid-layout{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--column-width),1fr));gap:var(--grid-gap)}.masonry-grid.grid-layout .pin-card{height:100%;display:flex;flex-direction:column}.masonry-grid.grid-layout .pin-image-container{aspect-ratio:16 / 9;height:auto}.masonry-grid.grid-layout .pin-image{height:100%;object-fit:cover}.masonry-grid.grid-layout .pin-content{flex:1}.settings-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.settings-section-layout{border-top:1px solid var(--color-border);padding-top:var(--spacing-md)}.settings-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.settings-card-row{display:flex;gap:var(--spacing-sm)}.settings-provider-card{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:all var(--transition-fast);position:relative;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.settings-provider-card:hover{border-color:var(--color-accent);background:var(--color-surface);color:var(--color-text-primary)}.settings-provider-card.active{border-color:var(--color-accent);background:var(--color-surface);color:var(--color-text-primary);box-shadow:0 0 0 3px #313d5a14}.provider-logo{width:20px;height:20px;flex-shrink:0;opacity:.6;transition:opacity var(--transition-fast)}.settings-provider-card.active .provider-logo,.settings-provider-card:hover .provider-logo{opacity:1}.settings-provider-name{flex:1;text-align:left}.settings-provider-check{width:18px;height:18px;border-radius:50%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.settings-model-list{display:flex;flex-direction:column;gap:6px}.settings-model-card{display:flex;align-items:center;gap:var(--spacing-md);padding:10px var(--spacing-md);border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.settings-model-card:hover{border-color:var(--color-accent);background:var(--color-surface)}.settings-model-card.active{border-color:var(--color-accent);background:var(--color-surface);box-shadow:0 0 0 3px #313d5a14}.settings-model-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color var(--transition-fast)}.settings-model-card.active .settings-model-radio,.settings-model-card:hover .settings-model-radio{border-color:var(--color-accent)}.settings-model-radio-dot{width:7px;height:7px;border-radius:50%;background:var(--color-accent)}.settings-model-info{display:flex;flex-direction:column;gap:1px}.settings-model-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.settings-model-note{font-size:var(--font-size-xs);color:var(--color-text-muted)}.settings-input{width:100%;padding:10px 14px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);font-size:var(--font-size-sm);font-family:SF Mono,Fira Code,monospace;color:var(--color-text-primary);background:var(--color-bg);outline:none;transition:all var(--transition-fast)}.settings-input:focus{border-color:var(--color-accent);background:var(--color-surface);box-shadow:0 0 0 3px #313d5a14}.settings-key-wrapper{position:relative;display:flex;align-items:center}.settings-key-input{padding-right:44px}.settings-key-toggle{position:absolute;right:10px;width:28px;height:28px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.settings-key-toggle:hover{background:var(--color-border);color:var(--color-text-primary)}.settings-key-status{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);font-weight:500;padding:2px 0;animation:fadeIn .2s ease}.settings-key-status.checking{color:var(--color-text-muted)}.settings-key-status.valid{color:#22c55e}.settings-key-status.invalid{color:#f0544f}.settings-key-spinner{width:12px;height:12px;border:2px solid var(--color-border);border-top-color:var(--color-text-muted);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-layout-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:all var(--transition-fast);position:relative;color:var(--color-text-secondary)}.settings-layout-card:hover{border-color:var(--color-accent);background:var(--color-surface);color:var(--color-text-primary)}.settings-layout-card.active{border-color:var(--color-accent);background:var(--color-surface);color:var(--color-accent);box-shadow:0 0 0 3px #313d5a14}.settings-layout-icon{display:flex;align-items:center;justify-content:center}.settings-layout-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.settings-layout-card .settings-provider-check{position:absolute;top:8px;right:8px}.settings-footer{padding:var(--spacing-md) var(--spacing-xl);border-top:1px solid var(--color-border);background:var(--color-bg)}.settings-action-row{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.settings-danger-zone{display:flex;align-items:center;min-height:36px}.settings-danger-btns{display:flex;align-items:center;gap:4px}.settings-ghost-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.settings-ghost-btn:hover{background:var(--color-border);color:var(--color-text-secondary)}.settings-ghost-btn.danger{color:var(--color-text-muted)}.settings-ghost-btn.danger:hover{background:#fde8e8;color:#f0544f}.settings-confirm-inline{display:flex;align-items:center;gap:8px;animation:fadeIn .15s ease}.settings-confirm-inline span{font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.settings-confirm-danger span{color:#f0544f}.settings-confirm-yes{padding:4px 12px;border-radius:var(--radius-full);border:1px solid var(--color-text-muted);background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.settings-confirm-yes:hover{background:var(--color-text-secondary);color:#fff;border-color:var(--color-text-secondary)}.settings-confirm-yes.danger{border-color:#f0544f;color:#f0544f}.settings-confirm-yes.danger:hover{background:#f0544f;color:#fff}.settings-confirm-no{padding:4px 10px;border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-muted);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast)}.settings-confirm-no:hover{color:var(--color-text-primary)}.settings-save-group{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.settings-cancel-btn{padding:8px 18px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:transparent;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.settings-cancel-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.settings-save-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:8px 20px;border-radius:var(--radius-full);border:none;background:#f0544f;color:#fff;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.settings-save-btn:hover:not(:disabled){background:#d6403c;transform:translateY(-1px)}.settings-save-btn:disabled{opacity:.45;cursor:default}.toast-container{position:fixed;bottom:32px;left:50%;transform:translate(-50%);display:flex;flex-direction:column-reverse;align-items:center;gap:var(--spacing-md);z-index:10000;pointer-events:none;width:max-content;max-width:90vw}.toast-container>div{pointer-events:auto}.error-toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:#f0544f;color:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000004d;z-index:10000;animation:toastSlideUp .3s ease}.error-toast svg{flex-shrink:0}.error-toast span{font-size:var(--font-size-base);font-weight:500}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.success-toast{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:#313d5a;color:#fff;border-radius:var(--radius-lg);box-shadow:0 4px 20px #0000004d;z-index:10000;animation:toastSlideUp .3s ease}.success-toast svg{flex-shrink:0}.success-toast span{font-size:var(--font-size-base);font-weight:500}.undo-toast{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 4px 24px #00000040;z-index:10000;overflow:hidden;animation:toastSlideUp .3s ease;min-width:280px}.undo-toast-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);padding:var(--spacing-md) var(--spacing-lg)}.undo-toast-content span{font-size:var(--font-size-base);font-weight:500;color:var(--color-text-primary)}.undo-btn{padding:6px 16px;border-radius:var(--radius-full);border:none;background:#f0544f;color:#fff;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.undo-btn:hover{background:#d6403c;transform:scale(1.05)}.undo-progress-bar{height:4px;background:var(--color-border);width:100%;overflow:hidden}.undo-progress-fill{height:100%;background:#f0544f;width:100%;animation:undoCountdown 5s linear forwards;transform-origin:left}@keyframes undoCountdown{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.view-mode-switcher{display:inline-flex;gap:2px;padding:3px;background:var(--color-bg);border-radius:var(--radius-full);border:1px solid var(--color-border);flex-shrink:0}.view-mode-tab{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-full);border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}.view-mode-tab:hover{color:var(--color-text-primary);background:var(--color-surface)}.view-mode-tab.active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.view-mode-tab svg{opacity:.7;flex-shrink:0}.view-mode-tab.active svg{opacity:1;color:#f0544f}.view-mode-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:var(--color-bg);border-radius:var(--radius-full);font-size:11px;font-weight:600;color:var(--color-text-muted);transition:all var(--transition-normal)}.view-mode-tab.active .view-mode-count{background:#f0544f;color:#fff}.category-divider{width:1px;height:24px;background:var(--color-border);margin:0 var(--spacing-sm);flex-shrink:0}.archive-button{background:#111111b3;color:#fff}.archive-button:hover{background:#f0544f;color:#fff;transform:scale(1.1)}.category-chip{display:flex;align-items:center;gap:var(--spacing-sm)}.chip-counts{display:inline-flex;align-items:center;gap:4px;font-size:10px;opacity:.6;font-weight:600;background:#0000000d;padding:2px 6px;border-radius:var(--radius-full);margin-left:2px}.category-chip.active .chip-counts{background:#fff3;opacity:.9}.category-chip-container.reordering .category-chip{border:1px dashed var(--color-text-primary);cursor:move;background:transparent;color:var(--color-text-primary)}.category-chip-container.reordering .category-chip:hover{background:#0000000d}.category-chip-container.dragging{opacity:.4}.category-chip-container.drop-target .category-chip{background:var(--color-border);transform:scale(1.05);border-style:solid}.reorder-done-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);height:38px;background:#f0544f;color:#fff;border:none;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 8px #f0544f33}.reorder-done-btn:hover{background:#d6403c;transform:translateY(-1px);box-shadow:0 4px 12px #f0544f4d}.reorder-done-btn:active{transform:translateY(0)}.reorder-done-btn svg{flex-shrink:0}
