*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-display: "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, "Times New Roman", serif;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}:root,:root[data-theme=dark]{color-scheme:dark;--bg: #0f1115;--bg-deep: #0b0d11;--surface: #1a1d23;--surface-2: #15181e;--surface-3: #262b34;--border: #262b34;--border-strong: #353b47;--text: #e8eaed;--text-secondary: #b4b9c2;--text-muted: #8b919c;--text-faint: #5c626c;--accent: #3b82f6;--accent-hover: #2f6fd6;--accent-text: #93b4f7;--accent-soft: rgba(59, 130, 246, .14);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .12);--success: #22c55e;--success-hover: #16a34a;--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .12);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .55)}:root[data-theme=light]{color-scheme:light;--bg: #f7f8fa;--bg-deep: #eef1f5;--surface: #ffffff;--surface-2: #ffffff;--surface-3: #eef1f5;--border: #e3e6ea;--border-strong: #d4d9e0;--text: #1a1d23;--text-secondary: #4a5159;--text-muted: #6b727c;--text-faint: #9aa0a9;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-text: #2563eb;--accent-soft: rgba(37, 99, 235, .1);--warning: #d97706;--warning-soft: rgba(217, 119, 6, .1);--success: #16a34a;--success-hover: #15803d;--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .08);--shadow-md: 0 4px 16px rgba(15, 23, 42, .08);--shadow-lg: 0 16px 48px rgba(15, 23, 42, .16)}:root[data-theme=warm]{color-scheme:light;--bg: #faf6f0;--bg-deep: #f1e9dd;--surface: #ffffff;--surface-2: #fdfaf5;--surface-3: #f2e9dc;--border: #e8ddcd;--border-strong: #d8c7ad;--text: #2b2420;--text-secondary: #5c5249;--text-muted: #867a6c;--text-faint: #ab9c89;--accent: #c2603f;--accent-hover: #a84e30;--accent-text: #b0512f;--accent-soft: rgba(194, 96, 63, .12);--warning: #c77d2c;--warning-soft: rgba(199, 125, 44, .12);--success: #5f8a5e;--success-hover: #4c7049;--danger: #c0392b;--danger-soft: rgba(192, 57, 43, .1);--shadow-md: 0 4px 16px rgba(80, 56, 36, .1);--shadow-lg: 0 16px 48px rgba(80, 56, 36, .18)}html,body{height:100vh;height:100dvh}body{font-family:var(--font-ui);background:var(--bg);color:var(--text);overflow:hidden;-webkit-font-smoothing:antialiased;transition:background .2s ease,color .2s ease;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}#root{height:100vh;height:100dvh;display:flex;flex-direction:column}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.text-input:focus-visible{outline:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.login-screen{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-theme-toggle{position:fixed;top:20px;right:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:40px;width:360px;box-shadow:var(--shadow-lg)}.login-title{font-family:var(--font-display);font-size:1.7rem;font-weight:600;color:var(--text);margin-bottom:6px;letter-spacing:.01em}.login-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:28px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-error{font-size:.82rem;color:var(--danger);background:var(--danger-soft);border:1px solid var(--danger);border-radius:6px;padding:8px 12px}.login-submit{width:100%;padding:10px}.project-selector{display:flex;flex-direction:column;height:100vh;background:var(--bg)}.selector-body{flex:1;overflow-y:auto;padding:32px 40px}.selector-heading{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--text);margin-bottom:24px;letter-spacing:.01em}.selector-empty{color:var(--text-muted);font-size:.9rem}.new-project-form{display:flex;gap:8px;align-items:center;margin-bottom:24px}.new-project-form .text-input{flex:1}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s}.project-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.project-card-thumb{height:140px;background:var(--bg-deep);display:flex;align-items:center;justify-content:center;overflow:hidden}.project-card-thumb img{width:100%;height:100%;object-fit:cover}.project-card-placeholder{font-size:.75rem;color:var(--text-faint)}.project-card-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-top:1px solid var(--border)}.project-card-text{display:flex;flex-direction:column;gap:2px;min-width:0}.project-card-name{font-size:.85rem;font-weight:600;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-rename-input{font-size:.85rem;font-weight:600;padding:4px 8px}.project-card-actions{display:flex;gap:2px;flex-shrink:0}.project-card-action{width:30px;height:30px;font-size:.8rem}.project-card-action{opacity:.55}.project-card:hover .project-card-action{opacity:1}.project-card-meta{font-size:.68rem;color:var(--text-faint)}.app-title-btn{background:none;border:none;color:var(--accent-text);font-family:var(--font-display);font-weight:600;font-size:1.1rem;cursor:pointer;letter-spacing:.01em;padding:0;transition:color .15s}.app-title-btn:hover{color:var(--accent)}.project-name-label{font-size:.85rem;color:var(--text-muted);border-left:1px solid var(--border);padding-left:12px}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg)}.toolbar{display:flex;align-items:center;gap:16px;padding:10px 20px;background:var(--surface-2);border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}.app-title{font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--accent-text);letter-spacing:.01em}.toolbar-divider{width:1px;height:22px;background:var(--border);flex-shrink:0}.toolbar-actions{display:flex;align-items:center;gap:10px;margin-left:auto}.anchor-count{font-size:.8rem;color:var(--text-muted);padding:4px 10px;background:var(--surface-3);border-radius:20px}.main-area{flex:1;overflow:hidden;position:relative}.viewer-layout{display:flex;height:100%;overflow:hidden;position:relative}.canvas-container{width:100%;height:100%;overflow:hidden;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center;touch-action:none}.canvas-inner{position:relative;display:inline-block;transform-origin:center center;transition:none}.floor-plan-img{display:block;max-width:90vw;max-height:85vh;width:auto;height:auto}.anchor-wrapper{position:absolute;transform:translate(-50%,-50%);z-index:20}.anchor-pin{position:relative;width:clamp(16px,3vw,28px);height:clamp(16px,3vw,28px);border-radius:50% 50% 50% 0;transform:rotate(-45deg);background:var(--accent);border:2px solid #fff;box-shadow:0 2px 8px #0006;cursor:pointer;transition:transform .15s,background .15s}.anchor-pin:hover{transform:rotate(-45deg) scale(1.15)}.anchor-pin.edit-mode{cursor:grab}.anchor-pin.edit-mode:hover{background:var(--warning)}.anchor-pin.dragging{cursor:grabbing;transform:rotate(-45deg) scale(1.2);box-shadow:0 4px 14px #00000080}.anchor-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(45deg);font-size:9px;font-weight:700;color:#fff;white-space:nowrap;pointer-events:none;display:none}.candidate-badge{position:absolute;top:-6px;right:-6px;transform:rotate(45deg);background:var(--danger);color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.legend{position:absolute;top:50%;left:20px;transform:translateY(-50%);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-md);z-index:30}.legend-title{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);padding:2px 6px 4px}.legend-item{display:flex;align-items:center;gap:10px;background:none;border:none;padding:4px 6px;border-radius:6px;cursor:pointer;text-align:left;transition:background .12s}.legend-item:hover{background:var(--surface-3)}.legend-item-off .legend-dot{opacity:.25}.legend-item-off .legend-label{color:var(--text-faint);text-decoration:line-through}.legend-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.2);transition:opacity .12s}.legend-label{font-size:.88rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.candidate-popover{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%) rotate(0);background:var(--surface);border:1px solid var(--border-strong);border-radius:12px;padding:12px;min-width:220px;max-width:340px;box-shadow:var(--shadow-lg);z-index:100;pointer-events:none;animation:fade-in .12s ease-out}.popover-header{font-size:.75rem;font-weight:700;color:var(--accent-text);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;border-bottom:1px solid var(--border);padding-bottom:6px}.candidate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.candidate-card{position:relative;width:100%;aspect-ratio:1;border-radius:6px;overflow:hidden;pointer-events:auto}.candidate-card.chosen{outline:2px solid #c99a3c;outline-offset:-2px}.candidate-chosen-corner{position:absolute;top:4px;left:4px;color:#c99a3c;font-size:.9rem;text-shadow:0 1px 3px rgba(0,0,0,.8);z-index:2}.candidate-card img{width:100%;height:100%;object-fit:cover;display:block}.candidate-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0c12e0;border-radius:6px;opacity:0;transition:opacity .15s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px;text-align:center}.candidate-card:hover .candidate-overlay{opacity:1}.candidate-name{font-size:.68rem;font-weight:600;color:#e8eaed;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-meta{font-size:.6rem;color:#b4b9c2}.candidate-price{font-size:.72rem;font-weight:700;color:#4ade80}.candidate-link{font-size:.62rem;color:#93b4f7;text-decoration:none;pointer-events:auto}.candidate-link:hover{text-decoration:underline}.popover-empty{font-size:.75rem;color:var(--text-faint);margin-top:4px}.popover-category{margin-left:8px;font-size:.65rem;font-weight:600;color:var(--text-muted);text-transform:none;letter-spacing:0;background:var(--surface-3);padding:1px 6px;border-radius:10px}.empty-state{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-muted)}.empty-icon{font-size:4rem;opacity:.85}.empty-state p{font-size:1rem}.app-sidebar{width:300px;flex-shrink:0;background:var(--surface-2);border-left:1px solid var(--border);overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.app-sidebar-empty{font-size:.8rem;color:var(--text-faint);padding:20px 0;text-align:center}.app-sidebar-anchor{border:1px solid var(--border);border-radius:10px;overflow:hidden}.app-sidebar-anchor-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:var(--surface);border:none;border-bottom:1px solid var(--border);border-left:3px solid transparent;font:inherit;text-align:left;cursor:pointer;transition:background .12s}.app-sidebar-anchor-header:hover{background:var(--surface-3)}.app-sidebar-locate{color:var(--text-faint);font-size:.9rem;flex-shrink:0;opacity:0;transition:opacity .12s}.app-sidebar-anchor-header:hover .app-sidebar-locate{opacity:1;color:var(--accent-text)}.sidebar-flash{animation:sidebar-flash 1.6s ease-out}@keyframes sidebar-flash{0%,40%{box-shadow:0 0 0 2px var(--accent)}to{box-shadow:0 0 0 2px transparent}}.app-sidebar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.app-sidebar-anchor-name{font-size:.82rem;font-weight:700;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-sidebar-tag{font-size:.62rem;color:var(--text-muted);background:var(--surface-3);padding:1px 6px;border-radius:10px;white-space:nowrap}.app-sidebar-candidates{display:flex;flex-direction:column}.app-sidebar-candidate{display:flex;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border)}.app-sidebar-candidate:last-child{border-bottom:none}.app-sidebar-candidate img,.app-sidebar-no-img{width:52px;height:52px;object-fit:cover;border-radius:6px;flex-shrink:0;border:1px solid var(--border)}.app-sidebar-no-img{background:var(--bg-deep)}.app-sidebar-candidate-info{flex:1;display:flex;flex-direction:column;gap:3px;justify-content:center;min-width:0}.app-sidebar-candidate-name{font-size:.78rem;font-weight:600;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-sidebar-candidate-desc{font-size:.65rem;color:var(--text-muted);line-height:1.3;white-space:normal}.app-sidebar-candidate-dims{font-size:.65rem;color:var(--text-faint)}.app-sidebar-candidate-price{font-size:.72rem;font-weight:700;color:var(--success)}.app-sidebar-candidate-link{font-size:.65rem;color:var(--accent-text);text-decoration:none}.app-sidebar-candidate-link:hover{text-decoration:underline}.app-sidebar-no-candidates{font-size:.72rem;color:var(--text-faint);padding:8px 12px}.candidate-collapsed-row{display:flex;align-items:center;gap:10px;padding:8px 10px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s}.candidate-collapsed-row:hover{background:var(--surface-3)}.candidate-collapsed-thumb{width:56px;height:56px;object-fit:cover;border-radius:6px;flex-shrink:0;border:1px solid var(--border)}.candidate-collapsed-info{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.candidate-collapsed-name{font-size:.82rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:6px}.candidate-unsaved-badge{font-size:.62rem;font-weight:500;color:var(--warning);background:var(--warning-soft);border:1px solid var(--warning);border-radius:4px;padding:1px 5px;flex-shrink:0}.candidate-collapsed-meta{font-size:.7rem;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-expand-icon{font-size:.6rem;color:var(--text-faint);flex-shrink:0}.candidate-shared-warning{font-size:.7rem;color:var(--warning);background:var(--warning-soft);border:1px solid var(--warning);border-radius:5px;padding:4px 8px;margin-bottom:8px}.candidate-collapsed-desc{font-size:.65rem;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidates-section-header{display:flex;align-items:center;justify-content:space-between;margin-top:16px;margin-bottom:8px}.btn-add-candidate{width:28px;height:28px;border-radius:50%;background:var(--success);color:#fff;border:none;font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s;flex-shrink:0}.btn-add-candidate:hover{background:var(--success-hover);transform:scale(1.1)}.btn-reuse-candidate{background:var(--surface-3);border:1px solid var(--border);color:var(--text-secondary);font-size:.74rem;font-weight:600;padding:5px 10px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-reuse-candidate:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-strong)}.candidate-choose-star{background:none;border:none;cursor:pointer;font-size:1.1rem;line-height:1;color:var(--text-faint);padding:0 2px;flex-shrink:0;transition:color .15s,transform .1s}.candidate-choose-star:hover{transform:scale(1.2);color:#f1c40f}.candidate-choose-star.chosen{color:#f1c40f}.candidate-list-item.chosen{border-color:#f1c40f;box-shadow:0 0 0 1px #f1c40f33}.pick-candidate-row{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--border);border-radius:8px;margin-bottom:6px}.btn-back{background:none;border:none;color:var(--accent-text);font-size:.85rem;font-weight:600;cursor:pointer;padding:0;margin-right:8px;transition:color .15s}.btn-back:hover{color:var(--accent)}.btn-back:disabled{opacity:.5;cursor:not-allowed}.candidate-drop-zone{display:flex;align-items:center;gap:10px;border:2px dashed var(--border-strong);border-radius:8px;padding:12px 16px;margin-bottom:10px;color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:border-color .15s,color .15s}.candidate-drop-zone:hover{border-color:var(--success);color:var(--text-secondary)}.candidate-drop-icon{font-size:1.2rem}.add-image-shortcut{font-size:.72rem;color:var(--text-faint)}.btn-paste-clipboard{margin-top:8px;background:var(--surface-3);border:1px solid var(--border-strong);color:var(--text-secondary);border-radius:6px;padding:5px 12px;font-size:.75rem;cursor:pointer;transition:background .15s,color .15s}.btn-paste-clipboard:hover{background:var(--border-strong);color:var(--text)}.add-image-area{width:100%;height:200px;border:2px dashed var(--border-strong);border-radius:10px;overflow:hidden;position:relative;cursor:pointer;transition:border-color .15s;display:flex;align-items:center;justify-content:center;background:var(--bg-deep)}.add-image-area:not(.has-image):hover{border-color:var(--accent)}.add-image-area.has-image{border-style:solid;border-color:var(--border);cursor:default}.add-image-placeholder{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-muted);font-size:.85rem;pointer-events:none}.add-image-icon{font-size:2rem}.add-image-preview{width:100%;height:100%;object-fit:contain;display:block}.add-image-replace{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#e8eaed;border:1px solid var(--border-strong);border-radius:5px;padding:4px 10px;font-size:.72rem;cursor:pointer;transition:background .15s}.add-image-replace:hover{background:#000000e6;color:#fff}.text-area{resize:vertical;min-height:60px;line-height:1.5}.candidate-expanded-fields{padding:0 10px 10px;border-top:1px solid var(--border)}.candidate-list-item{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--bg-deep)}.candidate-list-item.expanded{border-color:var(--border-strong)}.view-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:800px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modal-in .16s ease-out}.view-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:2px solid var(--border);flex-shrink:0}.view-modal-title{display:flex;align-items:center;gap:10px}.view-modal-title h2{font-family:var(--font-display);font-size:1.1rem;font-weight:600;letter-spacing:.01em}.view-modal-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.view-modal-body{padding:20px;overflow-y:auto;flex:1}.view-modal-empty{color:var(--text-faint);font-size:.875rem;text-align:center;padding:40px 0}.view-candidate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.view-candidate-card{background:var(--bg-deep);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s,transform .15s}.view-candidate-card:hover{border-color:var(--accent);transform:translateY(-2px)}.view-candidate-img-wrap{width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg-deep);position:relative;display:block;border:none;padding:0;cursor:zoom-in}.view-candidate-img-count{position:absolute;bottom:6px;right:6px;background:#0a0c12bf;color:#e8eaed;font-size:.65rem;font-weight:600;padding:2px 7px;border-radius:10px;pointer-events:none}.view-candidate-rejected{opacity:.55}.view-candidate-card.compare-selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.view-candidate-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.view-candidate-card:hover .view-candidate-img-wrap img{transform:scale(1.04)}.view-candidate-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-faint)}.add-image-strip{display:flex;gap:8px;padding:12px;flex-wrap:wrap;align-items:center;width:100%}.add-image-thumb-wrap{position:relative;width:80px;height:80px;border-radius:6px;overflow:hidden;flex-shrink:0}.add-image-thumb{width:100%;height:100%;object-fit:cover;display:block}.add-image-thumb-remove{position:absolute;top:2px;right:2px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.add-image-thumb-add{width:80px;height:80px;border-radius:6px;border:2px dashed var(--border-strong);background:none;color:var(--text-faint);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,color .15s}.add-image-thumb-add:hover{border-color:var(--success);color:var(--success)}.candidate-images-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:6px 0}.candidate-img-thumb-wrap{width:52px;height:52px;border-radius:5px;overflow:hidden;flex-shrink:0}.candidate-img-thumb{width:100%;height:100%;object-fit:cover;display:block}.candidate-img-add-btn{width:52px;height:52px;border-radius:5px;border:2px dashed var(--border-strong);background:none;color:var(--text-faint);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s,color .15s}.candidate-img-add-btn:hover{border-color:var(--success);color:var(--success)}.view-candidate-info{padding:10px 12px;display:flex;flex-direction:column;gap:4px}.view-candidate-name{font-size:.82rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view-candidate-desc{font-size:.72rem;color:var(--text-muted);line-height:1.4}.view-candidate-dims{font-size:.7rem;color:var(--text-faint)}.view-candidate-price{font-size:.82rem;font-weight:700;color:var(--success)}.view-candidate-link{font-size:.72rem;color:var(--accent-text);text-decoration:none;margin-top:2px}.view-candidate-link:hover{text-decoration:underline}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fade-in .15s ease-out}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:600px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modal-in .16s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h2{font-family:var(--font-display);font-size:1.1rem;font-weight:600;letter-spacing:.01em}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border)}.field-label{display:block;font-size:.75rem;font-weight:600;color:var(--accent-text);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.text-input{width:100%;background:var(--bg-deep);border:1px solid var(--border-strong);border-radius:6px;padding:8px 12px;color:var(--text);font-size:.9rem;outline:none;transition:border-color .15s,box-shadow .15s}.text-input::placeholder{color:var(--text-faint)}.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.drop-zone{margin-top:4px;border:2px dashed var(--border-strong);border-radius:8px;padding:24px;text-align:center;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:border-color .15s,color .15s}.drop-zone:hover{border-color:var(--accent);color:var(--accent)}.drop-zone-hint{display:block;font-size:.72rem;color:var(--text-faint);margin-top:4px}button:disabled{opacity:.5;cursor:not-allowed}.candidate-list{margin-top:14px;display:flex;flex-direction:column;gap:6px}.candidate-list-item{display:flex;flex-direction:column;gap:8px;background:var(--bg-deep);border-radius:8px;padding:10px;border:1px solid var(--border)}.candidate-item-top{display:flex;align-items:center;gap:10px}.candidate-item-top img{width:48px;height:48px;object-fit:cover;border-radius:4px;flex-shrink:0}.candidate-name-input{flex:1}.candidate-item-fields{display:flex;flex-direction:column;gap:0}.dim-row{display:flex;gap:6px;align-items:center}.dim-field,.price-field{display:flex;align-items:center;gap:4px;flex:1}.dim-group{display:flex;align-items:center;gap:6px;flex:3}.dim-x{color:var(--text-faint);font-size:.8rem;flex-shrink:0}.dim-label{font-size:.7rem;font-weight:700;color:var(--text-faint);flex-shrink:0}.dim-input{width:100%;padding:5px 7px;font-size:.78rem}.btn-save-candidate{background:var(--surface-3);color:var(--accent-text);border:1px solid var(--border-strong);border-radius:5px;padding:4px 9px;font-size:.72rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s;flex-shrink:0}.btn-save-candidate:hover:not(:disabled){background:var(--border-strong)}.btn-save-candidate:disabled{opacity:.5;cursor:not-allowed}.remove-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:.85rem;padding:2px 6px;border-radius:4px;transition:color .15s,background .15s}.remove-btn:hover{color:var(--danger);background:var(--danger-soft)}.btn-primary{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.btn-secondary:hover{background:var(--border-strong);color:var(--text)}.btn-toggle{background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border);border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s}.btn-toggle.active{background:var(--warning);color:#fff;border-color:var(--warning)}.btn-danger{background:none;color:var(--danger);border:1px solid var(--danger);border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-danger:hover{background:var(--danger-soft)}.icon-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s}.icon-btn:hover{color:var(--text);background:var(--surface-3)}.theme-toggle{position:absolute;bottom:20px;right:20px;z-index:30;background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);width:42px;height:42px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2rem;line-height:1;box-shadow:var(--shadow-md);transition:background .15s,color .15s,border-color .15s,transform .15s}.theme-toggle:hover{background:var(--surface-3);color:var(--text);border-color:var(--border-strong);transform:scale(1.1)}.login-theme-toggle .theme-toggle{position:static;transform:none;box-shadow:none}.spinner{width:18px;height:18px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.spinner-lg{width:34px;height:34px;border-width:3px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--text-muted);font-size:.9rem}.anchor-pin.pending{background:var(--warning);opacity:.85;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #f59e0b80}50%{box-shadow:0 0 0 8px #f59e0b00}}.pending-confirm{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%) rotate(0);display:flex;gap:6px;align-items:center;white-space:nowrap;z-index:50}.confirm-btn{background:var(--success);color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:.78rem;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md);transition:background .15s}.confirm-btn:hover{background:var(--success-hover)}.cancel-btn{background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border-strong);border-radius:6px;padding:5px 8px;font-size:.75rem;cursor:pointer;box-shadow:var(--shadow-md);transition:background .15s,color .15s}.cancel-btn:hover{background:var(--border-strong);color:var(--text)}.toast-host{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:1000;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;min-width:260px;max-width:380px;padding:12px 14px;border-radius:10px;background:var(--surface);border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);color:var(--text);font-size:.85rem;line-height:1.4;pointer-events:auto;animation:toast-in .2s ease-out}.toast.leaving{animation:toast-out .18s ease-in forwards}.toast-bar{width:4px;align-self:stretch;border-radius:4px;flex-shrink:0}.toast.success .toast-bar{background:var(--success)}.toast.error .toast-bar{background:var(--danger)}.toast.info .toast-bar{background:var(--accent)}.toast-icon{font-size:1rem;flex-shrink:0}.toast-msg{flex:1}.toast-close{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:.85rem;padding:2px 4px;border-radius:4px;flex-shrink:0;transition:color .15s}.toast-close:hover{color:var(--text)}.confirm-dialog{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:420px;max-width:92vw;box-shadow:var(--shadow-lg);animation:modal-in .16s ease-out;overflow:hidden}.confirm-dialog-body{padding:22px 22px 8px}.confirm-dialog-title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:8px}.confirm-dialog-message{font-size:.875rem;color:var(--text-secondary);line-height:1.5}.confirm-dialog-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 22px 20px}.skeleton{background:linear-gradient(90deg,var(--surface-3) 25%,var(--border) 37%,var(--surface-3) 63%);background-size:400% 100%;animation:skeleton 1.4s ease infinite;border-radius:8px}.skeleton-card{height:188px;border-radius:12px}.budget-table{width:100%;border-collapse:collapse;font-size:.875rem;margin-bottom:16px}.budget-th{text-align:left;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:6px 8px;border-bottom:1px solid var(--border-strong)}.budget-th-right{text-align:right}.budget-row{transition:background .1s}.budget-row:hover{background:var(--surface-3)}.budget-td{padding:9px 8px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.budget-td-right{text-align:right}.budget-amount{font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.budget-total-row{background:var(--surface-3)}.budget-total-label{font-weight:700;color:var(--text)}.budget-total-amount{font-size:1rem;font-weight:700;color:var(--success);font-variant-numeric:tabular-nums}.budget-th-chosen{color:#f1c40f}.budget-chosen-cell{background:#f1c40f11;border-left:2px solid #f1c40f55;color:#f1c40f}.budget-total-row .budget-chosen-cell{color:#f1c40f}.budget-note{font-size:.78rem;color:var(--text-faint);line-height:1.5;margin-top:8px}.zoom-controls{position:absolute;bottom:20px;right:20px;display:flex;align-items:stretch;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-md);overflow:hidden;z-index:30}.zoom-btn{background:none;border:none;color:var(--text-secondary);width:34px;height:32px;font-size:1.05rem;line-height:1;cursor:pointer;transition:background .12s,color .12s}.zoom-btn:hover{background:var(--surface-3);color:var(--text)}.zoom-readout{background:none;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);color:var(--text-muted);font-size:.72rem;font-weight:600;font-variant-numeric:tabular-nums;min-width:52px;cursor:pointer;transition:background .12s,color .12s}.zoom-readout:hover{background:var(--surface-3);color:var(--text)}.edit-hint{position:absolute;top:14px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--warning);color:var(--text-secondary);font-size:.78rem;padding:7px 14px;border-radius:20px;box-shadow:var(--shadow-md);pointer-events:none;white-space:nowrap;z-index:30;animation:fade-in .15s ease-out}.edit-hint-dot{width:8px;height:8px;border-radius:50%;background:var(--warning);flex-shrink:0;animation:pulse 1.4s ease-in-out infinite}.menu-root{position:relative}.menu-trigger{display:flex;align-items:center;gap:6px}.menu-trigger-open{background:var(--border-strong);color:var(--text)}.menu-caret{font-size:.65rem;opacity:.7}.menu-popup{position:absolute;top:calc(100% + 6px);right:0;min-width:240px;background:var(--surface);border:1px solid var(--border-strong);border-radius:10px;box-shadow:var(--shadow-lg);padding:6px;display:flex;flex-direction:column;gap:2px;z-index:150;animation:modal-in .12s ease-out}.menu-item{display:flex;align-items:flex-start;gap:10px;background:none;border:none;border-radius:7px;padding:8px 10px;font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background .12s,color .12s}.menu-item:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.menu-item-icon{font-size:.9rem;width:18px;text-align:center;flex-shrink:0;margin-top:1px}.menu-item-hint{display:block;font-size:.68rem;font-weight:400;color:var(--text-faint);margin-top:2px}.app-sidebar-header{display:flex;align-items:baseline;justify-content:space-between;padding-bottom:2px}.app-sidebar-title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text);letter-spacing:.01em}.app-sidebar-count{font-size:.72rem;color:var(--text-muted);background:var(--surface-3);padding:2px 8px;border-radius:10px}.app-sidebar-search{font-size:.82rem;padding:7px 10px}.app-sidebar-subtotal{font-size:.72rem;font-weight:700;color:var(--success);font-variant-numeric:tabular-nums;white-space:nowrap}.empty-hint{font-size:.82rem;color:var(--text-faint);margin-top:-8px}.empty-state-drop{margin:24px;height:calc(100% - 48px);border:2px dashed var(--border-strong);border-radius:16px;transition:border-color .15s,background .15s}.empty-state-drop.drag-over{border-color:var(--accent);background:var(--accent-soft)}.view-tabs{display:flex;align-items:center;gap:2px;background:var(--surface-3);border:1px solid var(--border);border-radius:8px;padding:2px}.view-tab{background:none;border:none;border-radius:6px;padding:5px 14px;font-size:.8rem;font-weight:600;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:background .12s,color .12s}.view-tab:hover{color:var(--text)}.view-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000026}.canvas-animating{transition:transform .45s cubic-bezier(.25,.8,.35,1)}.anchor-pin.has-chosen{border-color:var(--success)}.candidate-badge.badge-chosen{background:var(--success)}.anchor-pin.highlighted{animation:pin-pulse 1s ease-out 2}@keyframes pin-pulse{0%{box-shadow:0 2px 8px #0006,0 0 0 0 var(--accent)}70%{box-shadow:0 2px 8px #0006,0 0 0 14px transparent}to{box-shadow:0 2px 8px #0006,0 0 0 0 transparent}}.viewer-layout{position:relative}.coach-mark{position:absolute;top:24px;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border-strong);border-radius:14px;padding:18px 22px;max-width:320px;text-align:center;box-shadow:var(--shadow-lg);z-index:40;animation:modal-in .2s ease-out}.coach-mark-title{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text);margin-bottom:6px}.coach-mark-text{font-size:.82rem;color:var(--text-muted);line-height:1.5;margin-bottom:14px}.status-badge{display:inline-block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:1px 7px;border-radius:9px;vertical-align:middle}.status-chosen{color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);border:1px solid var(--success)}.status-shortlisted{color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent)}.status-rejected{color:var(--text-faint);background:var(--surface-3);border:1px solid var(--border-strong);text-decoration:line-through}.status-picker{display:inline-flex;gap:4px;margin-top:6px}.status-pick{background:none;border:1px solid var(--border-strong);border-radius:12px;padding:2px 9px;font-size:.68rem;font-weight:600;color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:background .12s,color .12s,border-color .12s}.status-pick:hover:not(:disabled){color:var(--text);border-color:var(--text-faint)}.status-pick-chosen.active{background:var(--success);border-color:var(--success);color:#fff}.status-pick-shortlisted.active{background:var(--accent);border-color:var(--accent);color:#fff}.status-pick-rejected.active{background:var(--text-faint);border-color:var(--text-faint);color:var(--bg)}.save-indicator{display:inline-flex;align-items:center;gap:7px;font-size:.75rem;color:var(--text-faint);min-height:18px}.save-indicator-saved{color:var(--success)}.save-indicator-error{color:var(--danger)}.spinner-sm{width:12px;height:12px;border-width:2px}.lightbox-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#08090ceb;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:400;animation:fade-in .15s ease-out}.lightbox-figure{max-width:88vw;max-height:82vh;display:flex;flex-direction:column;align-items:center;gap:10px}.lightbox-img{max-width:88vw;max-height:74vh;object-fit:contain;border-radius:6px;box-shadow:0 24px 80px #0009}.lightbox-caption{color:#d7dae0;font-size:.85rem;display:flex;align-items:center;gap:12px}.lightbox-counter{color:#8b919c;font-size:.75rem;font-variant-numeric:tabular-nums}.lightbox-close{position:absolute;top:18px;right:22px;background:none;border:none;color:#b4b9c2;font-size:1.3rem;cursor:pointer;padding:6px 10px;border-radius:8px;transition:color .12s,background .12s}.lightbox-close:hover{color:#fff;background:#ffffff1a}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff14;border:none;color:#e8eaed;font-size:2rem;line-height:1;width:48px;height:64px;border-radius:10px;cursor:pointer;transition:background .12s}.lightbox-nav:hover{background:#ffffff2e}.lightbox-prev{left:18px}.lightbox-next{right:18px}.lightbox-thumbs{display:flex;gap:6px;margin-top:14px;max-width:88vw;overflow-x:auto;padding:4px}.lightbox-thumb{width:52px;height:52px;object-fit:cover;border-radius:5px;cursor:pointer;opacity:.45;border:2px solid transparent;flex-shrink:0;transition:opacity .12s,border-color .12s}.lightbox-thumb.active,.lightbox-thumb:hover{opacity:1;border-color:var(--accent)}.compare-check{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;color:var(--text-muted);padding:6px 12px 0;cursor:pointer;-webkit-user-select:none;user-select:none}.compare-check input{accent-color:var(--accent);cursor:pointer}.compare-bar{display:flex;align-items:center;gap:10px;padding:12px 20px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 14px 14px}.compare-bar-label{flex:1;font-size:.8rem;color:var(--text-muted)}.compare-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:1040px;max-width:96vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modal-in .16s ease-out}.compare-body{display:flex;gap:14px;padding:20px;overflow:auto;flex:1}.compare-col{flex:1;min-width:200px;background:var(--bg-deep);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.compare-col-chosen{border-color:var(--success);box-shadow:0 0 0 2px color-mix(in srgb,var(--success) 25%,transparent)}.compare-img-wrap{width:100%;aspect-ratio:1;overflow:hidden;background:var(--surface-3);border:none;padding:0;cursor:zoom-in;position:relative;display:block;flex-shrink:0}.compare-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.compare-img-wrap:hover img{transform:scale(1.03)}.compare-img-count{position:absolute;bottom:6px;right:6px;background:#0a0c12bf;color:#e8eaed;font-size:.65rem;font-weight:600;padding:2px 7px;border-radius:10px;pointer-events:none}.compare-col-info{padding:12px 14px 14px;display:flex;flex-direction:column;gap:8px;flex:1}.compare-name{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.3}.compare-price{font-size:1.05rem;font-weight:700;color:var(--text-secondary);font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:8px}.compare-price-best{color:var(--success)}.compare-best-tag{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--success);background:color-mix(in srgb,var(--success) 14%,transparent);border:1px solid var(--success);padding:1px 7px;border-radius:9px}.compare-dims{display:flex;gap:14px;margin:0}.compare-dims>div{display:flex;align-items:baseline;gap:5px}.compare-dims dt{font-size:.65rem;font-weight:700;color:var(--text-faint)}.compare-dims dd{font-size:.8rem;color:var(--text-secondary);margin:0;font-variant-numeric:tabular-nums}.compare-desc{font-size:.75rem;color:var(--text-muted);line-height:1.5}.compare-status{margin-top:auto}.items-table-view{height:100%;overflow-y:auto;padding:24px 32px 40px}.items-table-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px}.items-table-heading{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--text);letter-spacing:.01em}.items-table-search{max-width:320px;margin-left:auto;font-size:.82rem;padding:7px 12px}.items-table-scroll{overflow-x:auto}.items-table{min-width:760px}.table-sort-btn{background:none;border:none;padding:0;font:inherit;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);cursor:pointer;transition:color .12s}.table-sort-btn:hover{color:var(--text)}.items-table-thumb-cell{width:56px}.items-table-thumb-btn{background:none;border:none;padding:0;cursor:zoom-in;display:block}.items-table-thumb{width:44px;height:44px;object-fit:cover;border-radius:6px;display:block;border:1px solid var(--border)}.items-table-no-thumb{background:var(--surface-3)}.items-table-name{font-weight:600;color:var(--text)}.items-table-anchor{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}.items-table-dims{font-variant-numeric:tabular-nums;color:var(--text-muted);white-space:nowrap}.items-table .status-picker{margin-top:0}.row-rejected td{opacity:.55}.btn-compact{padding:4px 10px;font-size:.75rem}.budget-view{height:100%;overflow-y:auto;padding:24px 32px 48px}.budget-view-inner{max-width:720px;margin:0 auto}.budget-view-inner .items-table-heading{margin-bottom:18px}.budget-target-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:26px;box-shadow:var(--shadow-md)}.budget-target-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.budget-target-input-wrap{display:flex;align-items:center;gap:6px}.budget-target-input{width:140px;font-variant-numeric:tabular-nums}.budget-figures{display:flex;gap:28px;margin-bottom:12px}.budget-figure{display:flex;flex-direction:column;gap:2px}.budget-figure-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-faint)}.budget-figure-value{font-size:1.25rem;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.budget-figure-chosen{color:var(--success)}.budget-figure-over{color:var(--danger)}.budget-bar{height:8px;background:var(--surface-3);border-radius:6px;overflow:hidden;margin-bottom:10px}.budget-bar-fill{height:100%;background:var(--success);border-radius:6px;transition:width .3s ease}.budget-bar-over{background:var(--danger)}.budget-section-heading{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--text);margin:22px 0 10px;letter-spacing:.01em}.budget-amount-chosen{color:var(--success)}.budget-decided{color:var(--success);font-weight:600}.budget-undecided{color:var(--text-faint)}@media (max-width: 760px){.toolbar{flex-wrap:wrap;gap:8px;padding:8px 12px}.toolbar-actions{gap:6px;flex-wrap:wrap;margin-left:auto}.project-name-label,.toolbar-divider{display:none}.app-title-btn{font-size:.95rem}.btn-primary,.btn-secondary,.btn-toggle{padding:8px 11px;font-size:.8rem}.view-tabs{order:5;flex-basis:100%;width:100%}.view-tab{flex:1;text-align:center;padding:9px 8px}.app-sidebar{position:absolute;top:0;right:0;bottom:0;width:min(88vw,360px);box-shadow:var(--shadow-lg);z-index:60;border-left:1px solid var(--border-strong)}.modal,.view-modal,.compare-modal{width:100vw;max-width:100vw;max-height:100vh;max-height:100dvh;height:100vh;height:100dvh;border-radius:0;border-left:none;border-right:none}.modal-backdrop{align-items:stretch}.compare-body{flex-direction:column}.compare-col{min-width:0}.text-input,.text-area{font-size:16px}.items-table-view,.budget-view{padding:16px 14px 40px}.items-table-toolbar{flex-wrap:wrap}.items-table-search{max-width:none;width:100%;margin-left:0}.items-table-scroll{overflow-x:visible}.items-table{min-width:0}.items-table thead{display:none}.items-table,.items-table tbody,.items-table tr,.items-table td{display:block;width:100%}.items-table tr{border:1px solid var(--border);border-radius:10px;background:var(--surface);margin-bottom:12px;padding:10px 12px;overflow:hidden}.items-table td{border:none;padding:4px 0;display:flex;align-items:center;justify-content:space-between;gap:12px;text-align:right}.items-table td[data-label]:before{content:attr(data-label);font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;text-align:left;flex-shrink:0}.items-table .items-table-thumb-cell{padding:0 0 8px}.items-table .items-table-thumb,.items-table .items-table-thumb-btn{width:100%;height:160px;border-radius:8px}.items-table .items-table-thumb-btn img{width:100%;height:100%;object-fit:cover}.items-table-edit-cell{padding-top:8px!important}.items-table-edit-cell .btn-compact{width:100%;padding:10px}.items-table td .status-picker{justify-content:flex-end}.view-modal-body{padding:14px}.view-candidate-grid{grid-template-columns:1fr;gap:12px}.view-candidate-img-wrap{aspect-ratio:16 / 9}.view-modal-header{padding:12px 14px}.view-modal-header h2{font-size:1.05rem}.budget-figures{gap:18px;flex-wrap:wrap}.budget-target-row{flex-wrap:wrap;gap:10px}.budget-view .budget-table{font-size:.82rem}.budget-view{padding:20px 14px 48px}.dim-row{gap:6px}.dim-field,.price-field{min-width:0}.legend{top:auto;bottom:12px;left:12px;transform:none;max-width:46vw;padding:8px 10px}.legend-label{font-size:.78rem}.zoom-controls{bottom:12px;right:12px}.edit-hint{font-size:.7rem;padding:6px 10px;max-width:92vw;white-space:normal;text-align:center}.selector-body{padding:20px 16px 40px}.project-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}}@media (hover: none) and (pointer: coarse){.btn-primary,.btn-secondary,.btn-toggle,.icon-btn,.menu-trigger,.view-tab{min-height:40px}.status-pick{min-height:34px;padding-left:12px;padding-right:12px}.project-card-action{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}@keyframes toast-out{to{opacity:0;transform:translate(20px)}}@keyframes skeleton{0%{background-position:100% 50%}to{background-position:0 50%}}.user-menu-trigger{width:34px;height:34px;border-radius:50%;border:1px solid var(--border-strong);background:var(--surface-3);color:var(--text);font-size:.85rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s,transform .1s}.user-menu-trigger:hover{background:var(--surface-2);border-color:var(--accent);transform:scale(1.06)}.user-menu-identity{font-size:.75rem;color:var(--text-secondary);padding:8px 10px 6px;border-bottom:1px solid var(--border);margin-bottom:4px}.users-list{display:flex;flex-direction:column;gap:6px}.users-list-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:8px}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--surface-3);border:1px solid var(--border-strong);color:var(--text);font-size:.75rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.users-list-name{flex:1;font-size:.85rem;font-weight:600;color:var(--text)}.users-list-you{font-weight:400;color:var(--text-faint)}.users-add-form{display:flex;gap:8px;margin-top:6px}.users-add-form .text-input{flex:1;min-width:0}.help-modal{max-width:520px}.help-body{min-height:230px;font-size:.88rem;line-height:1.6;color:var(--text-secondary)}.help-body p{margin-bottom:10px}.help-body ul{margin:0 0 10px 18px;display:flex;flex-direction:column;gap:6px}.help-body strong{color:var(--text)}.help-footer{display:flex;align-items:center;justify-content:space-between}.help-dots{display:flex;gap:6px}.help-dot{width:9px;height:9px;border-radius:50%;border:none;background:var(--border-strong);cursor:pointer;padding:0;transition:background .15s,transform .15s}.help-dot.active{background:var(--accent);transform:scale(1.3)}.share-qr{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:16px;padding:14px;background:#fff;border-radius:10px}.share-qr-hint{font-size:.72rem;color:#555}.cat-list{display:flex;flex-direction:column;gap:6px}.cat-row{display:flex;align-items:center;gap:8px}.cat-swatch{width:30px;height:30px;padding:0;border:1px solid var(--border-strong);border-radius:6px;background:none;cursor:pointer;flex-shrink:0}.cat-swatch::-webkit-color-swatch-wrapper{padding:2px}.cat-swatch::-webkit-color-swatch{border:none;border-radius:4px}.cat-name-input{flex:1;min-width:0}.cat-usage{font-size:.7rem;color:var(--text-faint);min-width:14px;text-align:right}.cat-add-form{display:flex;align-items:center;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.cat-add-form .text-input{flex:1;min-width:0}.users-list-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-text);background:var(--accent-soft);border-radius:4px;padding:2px 6px;flex-shrink:0}
