/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--radius-sm:.25rem;--radius-md:.375rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.h-full{height:100%}.min-h-full{min-height:100%}.w-9{width:calc(var(--spacing) * 9)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-col{flex-direction:column}.border{border-style:var(--tw-border-style);border-width:1px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px)}.blur,.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.\[m\:��\1f \11 ��jA���\]{m:�� ��jA���}}:root{--color-bg-primary:#1a1b1e;--color-bg-secondary:#25262b;--color-bg-tertiary:#2c2d33;--color-bg-hover:#373840;--color-border:#373840;--color-border-subtle:#2e2f35;--color-text-primary:#e8e9ec;--color-text-secondary:#9ca3af;--color-text-muted:#6b7280;--color-accent:#4a9eff;--color-accent-hover:#6ab0ff;--color-accent-active:#3a8ef0;--color-accent-dark:#3a7bd5;--color-success:#22c55e;--color-warning:#f59e0b;--color-error:#ef4444;--color-error-dark:#d32f2f;--color-selected:#0c4;--color-net-highlight:#4a9eff;--font-ui:"Inter",system-ui,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--radius-sm:3px;--radius-md:4px;--radius-lg:6px;--toolbar-height:48px;--sidebar-width:280px;--panel-width:220px}*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:var(--font-ui);background:var(--color-bg-primary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}.editor-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.editor-layout__body{flex:1;display:flex;overflow:hidden}.editor-layout__left{width:var(--panel-width);background:var(--color-bg-secondary);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.editor-layout__canvas{background:var(--color-bg-primary);flex:1;overflow:hidden}.editor-error,.editor-loading{height:100vh;color:var(--color-text-secondary);justify-content:center;align-items:center;font-size:16px;display:flex}.toolbar{height:var(--toolbar-height);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:4px;padding:0 8px;display:flex}.toolbar__logo{border-right:1px solid var(--color-border);margin-right:4px;padding:0 12px 0 4px}.toolbar__logo-text{color:var(--color-accent);letter-spacing:-.3px;font-size:15px;font-weight:700;font-family:var(--font-mono)}.toolbar__tools{flex:1}.toolbar__btn,.toolbar__tools{align-items:center;gap:2px;display:flex}.toolbar__btn{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;justify-content:center;min-width:52px;padding:4px 8px;transition:color .1s,background .1s,border-color .1s}.toolbar__btn:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary);border-color:var(--color-border)}.toolbar__btn--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent-hover)}.toolbar__btn--active:hover{background:var(--color-accent-hover);color:#fff}.toolbar__btn:disabled{opacity:.35;cursor:not-allowed}.toolbar__btn-label{white-space:nowrap;font-size:10px;font-weight:500}.toolbar__actions{border-left:1px solid var(--color-border);align-items:center;gap:8px;margin-left:4px;padding-left:8px;display:flex}.toolbar__btn--lock{min-width:36px;padding:4px 6px}.toolbar__btn--locked{color:var(--color-warning)}.status{font-size:12px;font-family:var(--font-mono)}.status--saving{color:var(--color-warning)}.status--saved{color:var(--color-success)}.status--pending{color:#facc15}.status--error{color:var(--color-error)}.layer-manager{border-bottom:1px solid var(--color-border);flex-shrink:0}.layer-manager__header{background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border-subtle);justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.layer-manager__title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);font-size:11px;font-weight:600}.layer-manager__add-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-items:center;padding:2px 4px;display:flex}.layer-manager__add-btn:hover{background:var(--color-bg-hover);color:var(--color-accent)}.layer-manager__add-btn:disabled{opacity:.5;cursor:not-allowed}.layer-manager__add-btn:disabled:hover{color:var(--color-text-secondary);background:0 0}.layer-manager__actions{gap:4px;display:flex}.layer-manager__list{max-height:180px;overflow-y:auto}.layer-manager__item{cursor:pointer;border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-secondary);align-items:center;gap:6px;padding:6px 10px;font-size:13px;display:flex}.layer-manager__item--active,.layer-manager__item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.layer-manager__item--active{border-left:2px solid var(--color-accent)}.layer-manager__grip{color:var(--color-text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1}.layer-manager__grip:hover{color:var(--color-text)}.layer-manager__name{cursor:default;flex:1;font-size:12px}.layer-manager__name-input{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--accent);border-radius:3px;outline:none;flex:1;min-width:0;padding:1px 4px;font-size:12px}.layer-manager__count{font-size:11px;font-family:var(--font-mono);color:var(--color-text-muted)}.layer-manager__remove{cursor:pointer;color:var(--color-text-muted);opacity:0;background:0 0;border:none;align-items:center;padding:2px;display:flex}.layer-manager__item:hover .layer-manager__remove{opacity:1}.layer-manager__remove:hover{color:var(--color-error)}.replace-image-dialog__overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.replace-image-dialog__content{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:90%;max-width:400px;padding:20px;box-shadow:0 4px 20px #0000004d}.replace-image-dialog__header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.replace-image-dialog__icon{color:var(--color-warning)}.replace-image-dialog__header h3{color:var(--color-text-primary);margin:0;font-size:16px;font-weight:600}.replace-image-dialog__message{color:var(--color-text-secondary);margin-bottom:12px;font-size:14px}.replace-image-dialog__warning{color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);margin-bottom:16px;padding:12px;font-size:13px}.replace-image-dialog__warning strong{color:var(--color-warning)}.replace-image-dialog__actions{justify-content:flex-end;gap:8px;display:flex}.replace-image-dialog__btn{border-radius:var(--radius-sm);cursor:pointer;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.replace-image-dialog__btn--secondary{border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0}.replace-image-dialog__btn--secondary:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.replace-image-dialog__btn--primary{background:var(--color-error);border:1px solid var(--color-error);color:#fff}.replace-image-dialog__btn--primary:hover{background:var(--color-error-dark);border-color:var(--color-error-dark)}.replace-image-dialog__btn--tertiary{background:var(--color-accent);border:1px solid var(--color-accent);color:#fff}.replace-image-dialog__btn--tertiary:hover{background:var(--color-accent-dark);border-color:var(--color-accent-dark)}.item-list{flex-direction:column;flex:1;display:flex;overflow:hidden}.item-list__header{background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.item-list__title{text-transform:uppercase;letter-spacing:.5px;font-weight:600}.item-list__count,.item-list__title{color:var(--color-text-muted);font-size:11px}.item-list__count{font-family:var(--font-mono);background:var(--color-bg-hover);border-radius:9px;padding:1px 6px}.item-list__body{flex:1;overflow-y:auto}.item-list__empty{color:var(--color-text-muted);padding:12px 10px;font-size:12px}.item-list__row{cursor:pointer;border-bottom:1px solid var(--color-border-subtle);align-items:center;gap:6px;padding:5px 10px;font-size:12px;display:flex}.item-list__row--selected,.item-list__row:hover{background:var(--color-bg-hover)}.item-list__row--selected{border-left:2px solid var(--color-selected)}.item-list__color{border-radius:2px;flex-shrink:0;width:8px;height:8px}.item-list__tipo{color:var(--color-text-muted);font-size:10px}.item-list__ref,.item-list__tipo{font-family:var(--font-mono);min-width:32px}.item-list__ref{color:var(--color-accent);font-size:11px}.item-list__nome{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.item-list__label{font-size:10px;font-family:var(--font-mono);background:var(--color-bg-primary);border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:2px;padding:1px 4px}.sidebar{background:var(--color-bg-secondary);border-left:1px solid var(--color-border);flex-direction:column;display:flex}.sidebar__empty{color:var(--color-text-muted);padding:16px;font-size:12px}.sidebar__section{border-bottom:1px solid var(--color-border-subtle);padding:12px}.sidebar__section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);margin-bottom:10px;font-size:11px;font-weight:600}.sidebar__field{margin-bottom:8px}.sidebar__field--row{align-items:flex-end;gap:12px;display:flex}.sidebar__label{display:block}.sidebar__label,.sidebar__label-row{color:var(--color-text-muted);margin-bottom:3px;font-size:11px}.sidebar__label-row{align-items:center;gap:4px;display:flex}.sidebar__label-tooltip{cursor:pointer;opacity:.65;align-items:center;transition:opacity .1s;display:inline-flex;position:relative}.sidebar__label-tooltip:focus-visible,.sidebar__label-tooltip:hover{opacity:1}.sidebar__label-tooltip .tooltip-text{z-index:100;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);white-space:normal;pointer-events:none;width:220px;margin-top:4px;padding:6px 8px;font-size:11px;line-height:1.4;position:absolute;top:100%;left:0;box-shadow:0 2px 8px #0000004d}.sidebar__input,.sidebar__value{color:var(--color-text-primary);font-size:13px}.sidebar__input{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;font-family:var(--font-ui);padding:5px 8px;transition:border-color .1s}.sidebar__input:focus{border-color:var(--color-accent);outline:none}.sidebar__input:disabled{opacity:.5;cursor:not-allowed}.sidebar__input--mono{font-family:var(--font-mono);font-size:12px}.sidebar__input--sm{width:60px}.sidebar__textarea{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text-primary);font-size:12px;font-family:var(--font-ui);resize:vertical;padding:5px 8px}.sidebar__textarea:focus{border-color:var(--color-accent);outline:none}.sidebar__color{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:var(--color-bg-primary);width:36px;height:28px;padding:2px}.sidebar__color:disabled{opacity:.5;cursor:not-allowed}.sidebar__photos{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.sidebar__photo-wrap{position:relative}.sidebar__photo-thumb{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--color-border);width:48px;height:48px;display:block}.sidebar__photo-remove{background:var(--color-error);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.sidebar__dim-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.sidebar__align-grid{grid-template-columns:repeat(3,1fr);gap:4px;display:grid}.sidebar__align-grid--dist{grid-template-columns:1fr 1fr}.sidebar__align-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;text-align:center;padding:5px 4px;font-size:13px;transition:background .1s,color .1s}.sidebar__align-btn:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar__align-btn:disabled{opacity:.35;cursor:not-allowed}.sidebar__align-btn--wide{font-size:11px}.sidebar__btn-secondary{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text-secondary);cursor:pointer;padding:6px;font-size:12px}.sidebar__btn-secondary:hover:not(:disabled){background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar__btn-secondary:disabled{opacity:.5;cursor:not-allowed}.sidebar__link{color:var(--color-accent);font-size:13px;text-decoration:none}.sidebar__link:hover{text-decoration:underline}.sidebar__link-toggle{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:2px;transition:all .15s;display:flex}.sidebar__link-toggle:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.sidebar__link-toggle.active{color:var(--color-accent)}.sidebar__link-toggle:disabled{opacity:.3;cursor:not-allowed}.sidebar__hint{color:var(--color-text-muted);font-size:12px}.sidebar__sync-badge{text-transform:none;letter-spacing:0;border-radius:8px;padding:1px 6px;font-size:10px;font-weight:500;line-height:1.4}.sidebar__sync-badge--pending{color:var(--color-warning);background:#f59e0b26;border:1px solid #f59e0b4d}.sidebar__sync-badge--synced{color:var(--color-success);background:#22c55e1f;border:1px solid #22c55e40}.sidebar__photo-sync-dot{border:1px solid #00000080;border-radius:50%;width:8px;height:8px;position:absolute;top:3px;left:3px}.sidebar__photo-sync-dot--pending{background:var(--color-warning);box-shadow:0 0 4px #f59e0b99}.map-canvas{width:100%;height:100%;overflow:hidden}.map-canvas__stage{display:block}.context-menu{z-index:1000;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:180px;position:fixed;overflow:hidden;box-shadow:0 4px 16px #0006}.context-menu__item{width:100%;color:var(--color-text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 12px;font-size:13px;display:flex}.context-menu__item:hover{background:var(--color-bg-hover)}.context-menu__icon{color:var(--color-text-muted);flex-shrink:0}.context-menu__icon--pending{color:var(--color-warning)}.canvas-tooltip{z-index:500;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);pointer-events:none;min-width:120px;max-width:220px;padding:8px 10px;position:fixed;box-shadow:0 4px 16px #00000080}.canvas-tooltip__name{color:var(--color-text-primary);margin-bottom:2px;font-size:13px;font-weight:600}.canvas-tooltip__ref{font-size:11px;font-family:var(--font-mono);color:var(--color-accent);margin-bottom:2px}.canvas-tooltip__label{font-size:11px;font-family:var(--font-mono);color:var(--color-net-highlight);margin-bottom:4px}.canvas-tooltip__desc{color:var(--color-text-secondary);white-space:pre-wrap;margin-bottom:4px;font-size:11px}.canvas-tooltip__meta{color:var(--color-text-muted);border-top:1px solid var(--color-border-subtle);gap:8px;margin-top:4px;padding-top:4px;font-size:11px;display:flex}.hidden{display:none!important}.photo-viewer{z-index:2000;background:#000000eb;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.photo-viewer__header{border-bottom:1px solid var(--color-border);z-index:10;background:#1a1b1ef2;justify-content:space-between;align-items:center;height:52px;padding:0 16px;display:flex;position:absolute;top:0;left:0;right:0}.photo-viewer__title{color:var(--color-text-primary);font-size:14px;font-weight:600}.photo-viewer__header-actions{align-items:center;gap:8px;display:flex}.photo-viewer__counter{color:var(--color-text-muted);font-size:12px;font-family:var(--font-mono)}.photo-viewer__mode-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:4px 8px;font-size:16px;transition:background .15s}.photo-viewer__mode-btn:hover{background:var(--color-bg-hover)}.photo-viewer__mode-btn--edit{border-color:var(--color-warning)}.photo-viewer__delete-btn{border:1px solid var(--color-error);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-error);background:0 0;padding:4px 10px;font-size:12px}.photo-viewer__delete-btn:hover{background:var(--color-error);color:#fff}.photo-viewer__close-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px;line-height:1}.photo-viewer__close-btn:hover{color:var(--color-text-primary)}.photo-viewer__stage{flex:1;justify-content:center;align-items:center;width:100%;padding:52px 60px 80px;display:flex;position:relative;overflow:hidden}.photo-viewer__img-wrap{transform-origin:50%;line-height:0;transition:transform 80ms ease-out;display:inline-block;position:relative}.photo-viewer__img{object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;max-width:80vw;max-height:70vh;display:block}.photo-viewer__nav{border:1px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;border-radius:var(--radius-md);z-index:5;background:#1a1b1ecc;justify-content:center;align-items:center;width:44px;height:60px;font-size:28px;transition:background .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.photo-viewer__nav:hover{background:var(--color-bg-secondary)}.photo-viewer__nav--prev{left:8px}.photo-viewer__nav--next{right:8px}.photo-viewer__thumbs{flex-wrap:nowrap;justify-content:center;gap:6px;padding:0 16px;display:flex;position:absolute;bottom:12px;left:0;right:0;overflow-x:auto}.photo-viewer__thumb{object-fit:cover;border-radius:var(--radius-sm);cursor:pointer;opacity:.6;border:2px solid #0000;width:52px;height:40px;transition:opacity .15s,border-color .15s}.photo-viewer__thumb:hover{opacity:.9}.photo-viewer__thumb--active{border-color:var(--color-accent);opacity:1}.photo-viewer__hint{color:var(--color-text-muted);pointer-events:none;background:#1a1b1ecc;border-radius:20px;padding:4px 10px;font-size:12px;position:absolute;bottom:56px}.photo-viewer__ann-marker{cursor:pointer;z-index:5;align-items:center;gap:4px;display:flex;position:absolute;transform:translate(-50%,-50%)}.photo-viewer__ann-dot{background:var(--color-net-highlight);border:2px solid #0009;border-radius:50%;flex-shrink:0;width:12px;height:12px;display:block;box-shadow:0 0 4px #fc09}.photo-viewer__ann-label{color:var(--color-net-highlight);white-space:nowrap;text-overflow:ellipsis;background:#000000bf;border-radius:3px;max-width:160px;padding:2px 5px;font-size:11px;overflow:hidden}.photo-viewer__ann-marker--editing .photo-viewer__ann-dot{background:var(--color-accent)}.photo-viewer__ann-input-wrap{z-index:20;flex-direction:column;gap:4px;min-width:180px;display:flex;position:absolute;transform:translate(-50%,-100%)}.photo-viewer__ann-textarea{background:var(--color-bg-secondary);border:1px solid var(--color-accent);border-radius:var(--radius-sm);width:180px;color:var(--color-text-primary);resize:none;font-size:12px;font-family:var(--font-ui);padding:6px}.photo-viewer__ann-textarea:focus{outline:none}.photo-viewer__ann-delete{border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);cursor:pointer;background:0 0;align-self:flex-start;padding:2px 6px;font-size:11px}.photo-viewer__ann-delete:hover{background:var(--color-error);color:#fff}.crop-studio{z-index:2100;background:#000000f2;flex-direction:column;display:flex;position:fixed;inset:0}.crop-studio__header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:flex}.crop-studio__title{color:var(--color-text-primary);margin-right:8px;font-size:14px;font-weight:600}.crop-studio__modes{gap:4px;display:flex}.crop-studio__mode-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;padding:4px 10px;font-size:12px}.crop-studio__mode-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.crop-studio__mode-btn--active{border-color:var(--color-accent);color:var(--color-accent);background:#4a9eff1a}.crop-studio__rotations{align-items:center;gap:4px;margin-left:8px;display:flex}.crop-studio__rotation-label{color:var(--color-text-muted);font-size:11px;font-family:var(--font-mono);min-width:28px}.crop-studio__icon-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;padding:4px 8px;font-size:12px}.crop-studio__icon-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.crop-studio__icon-btn--active{border-color:var(--color-warning);color:var(--color-warning)}.crop-studio__save-btn{background:var(--color-accent);border-radius:var(--radius-sm);color:#fff;cursor:pointer;border:none;padding:6px 14px;font-size:13px;font-weight:500}.crop-studio__save-btn:hover{background:var(--color-accent-hover)}.crop-studio__close-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:20px;line-height:1}.crop-studio__close-btn:hover{color:var(--color-text-primary)}.crop-studio__stage-wrap{flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.crop-studio__footer{color:var(--color-text-muted);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);text-align:center;flex-shrink:0;padding:8px 16px;font-size:12px}.mosaic-studio{z-index:2100;background:#000000f2;flex-direction:column;display:flex;position:fixed;inset:0}.mosaic-studio__header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:flex}.mosaic-studio__title{color:var(--color-text-primary);font-size:14px;font-weight:600}.mosaic-studio__body{display:flex}.mosaic-studio__body,.mosaic-studio__canvas{flex:1;overflow:hidden}.mosaic-studio__sidebar{background:var(--color-bg-secondary);border-left:1px solid var(--color-border);flex-shrink:0;width:220px;padding:12px;overflow-y:auto}.mosaic-studio__piece-info{margin-bottom:12px}.mosaic-studio__piece-label{color:var(--color-text-muted);margin-bottom:4px;font-size:11px;display:block}.mosaic-studio__piece-value{color:var(--color-text-primary);font-size:12px;font-family:var(--font-mono)}.mosaic-studio__opacity-slider{width:100%;margin:4px 0}.mosaic-studio__btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text-secondary);cursor:pointer;text-align:center;margin-bottom:6px;padding:7px;font-size:12px}.mosaic-studio__btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.mosaic-studio__btn--primary{background:var(--color-accent);border-color:var(--color-accent);color:#fff;font-weight:500}.mosaic-studio__btn--primary:hover{background:var(--color-accent-hover)}.mosaic-studio__btn--danger{border-color:var(--color-error);color:var(--color-error)}.mosaic-studio__btn--danger:hover{background:var(--color-error);color:#fff}.mosaic-studio__btn:disabled{opacity:.5;cursor:not-allowed}.mosaic-studio__close-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:4px 8px;font-size:20px;line-height:1}.mosaic-studio__close-btn:hover{color:var(--color-text-primary)}.opencv-analyzing{color:#f59e0b;z-index:200;pointer-events:none;will-change:opacity;background:#000c;border-radius:6px;padding:8px 16px;font-size:13px;animation:fadeInOut 2s ease-in-out infinite;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}@keyframes fadeInOut{0%,to{opacity:.6}50%{opacity:1}}.diagram-editor{background:var(--color-bg);flex-direction:column;height:100vh;display:flex;overflow:hidden}.diagram-toolbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;display:flex}.diagram-toolbar button{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;white-space:nowrap;border-radius:4px;padding:5px 10px;font-size:12px}.diagram-toolbar button:hover{background:var(--color-hover)}.diagram-toolbar button.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.diagram-toolbar label{color:var(--color-text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.diagram-toolbar input[type=range]{width:80px}.diagram-canvas-container{background:#0a0f1e;flex:1;position:relative;overflow:hidden}.toolbar__diagram-btn{border:1px solid var(--color-accent);color:var(--color-accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;align-items:center;padding:5px 10px;font-size:12px;text-decoration:none;display:inline-flex}.toolbar__diagram-btn:hover{background:var(--color-accent);color:#fff}.toolbar__btn--marketplace{text-decoration:none;color:#f59e0b!important}.toolbar__btn--marketplace:hover{background:#f59e0b26!important}.modal-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:12px;min-width:320px;padding:24px;display:flex}.modal__title{color:var(--color-text-primary);margin:0;font-size:16px;font-weight:600}.modal__desc{color:var(--color-text-muted);margin:0;font-size:13px}.modal__input{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);font-size:13px;font-family:var(--font-mono);box-sizing:border-box;padding:8px 10px}.modal__input:focus{border-color:var(--color-accent);outline:none}.modal__actions{justify-content:flex-end;gap:8px;display:flex}.modal__btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--color-border);padding:7px 16px;font-size:13px}.modal__btn--cancel{color:var(--color-text-muted);background:0 0}.modal__btn--cancel:hover{background:var(--color-hover)}.modal__btn--confirm{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.modal__btn--confirm:hover:not(:disabled){background:var(--color-accent-hover)}.modal__btn--confirm:disabled{opacity:.4;cursor:not-allowed}.search-modal-overlay{z-index:2000;background:#00000080;justify-content:center;align-items:flex-start;padding-top:15vh;display:flex;position:fixed;inset:0}.search-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;max-width:560px;overflow:hidden;box-shadow:0 20px 40px #0000004d}.search-modal__input-wrapper{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:12px 16px;display:flex}.search-modal__icon{color:var(--color-text-muted);flex-shrink:0}.search-modal__input{color:var(--color-text-primary);background:0 0;border:none;outline:none;flex:1;font-size:16px}.search-modal__input::placeholder{color:var(--color-text-muted)}.search-modal__close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:4px;display:flex}.search-modal__close:hover{color:var(--color-text-primary)}.search-modal__empty{text-align:center;color:var(--color-text-muted);padding:24px;font-size:14px}.search-modal__results{max-height:320px;overflow-y:auto}.search-modal__result{cursor:pointer;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.search-modal__result--selected,.search-modal__result:hover{background:var(--color-hover)}.search-modal__result-label{color:var(--color-text-primary);font-size:14px}.search-modal__result-field{color:var(--color-text-muted);background:var(--color-bg);border-radius:var(--radius-sm);padding:2px 8px;font-size:12px}.search-modal__hint{border-top:1px solid var(--color-border);color:var(--color-text-muted);gap:8px;padding:10px 16px;font-size:12px;display:flex}.search-modal__hint span{background:var(--color-bg);border-radius:var(--radius-sm);font-family:var(--font-mono);padding:2px 6px}.toolbar__dirty-badge{color:#f59e0b;will-change:opacity;font-size:16px;line-height:1;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:.5}50%{opacity:1}}.sidebar{width:var(--sidebar-width);flex-shrink:0;transition:width .3s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden}.sidebar--collapsed{width:40px}.sidebar--collapsed .sidebar__content{opacity:0;pointer-events:none}.sidebar__content{height:100%;transition:opacity .2s;overflow-y:auto}.sidebar__pin-btn{z-index:10;cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:14px;line-height:1;position:absolute;top:6px;right:6px}.sidebar__pin-btn:hover{opacity:1;background:var(--color-hover)}.sidebar__pin-btn--auto{opacity:.8;color:#f59e0b}.scan-overlay{z-index:100;pointer-events:none;position:absolute;inset:0}.scan-overlay__panel{pointer-events:all;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:10px;min-width:340px;max-width:500px;padding:16px 20px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #0006}.scan-overlay__title{color:var(--color-text-primary);margin:0;font-size:14px;font-weight:600}.scan-overlay__summary{flex-wrap:wrap;gap:6px;display:flex}.scan-overlay__class-badge{background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:10px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:11px}.scan-overlay__actions{gap:8px;display:flex}.scan-overlay__footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;padding-top:6px;display:flex}.scan-overlay__btn{border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:12px;transition:background .15s,color .15s}.scan-overlay__btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.scan-overlay__btn--confirm{color:#fff;background:#3b82f6;border-color:#3b82f6}.scan-overlay__btn--confirm:hover{background:#2563eb}.scan-overlay__btn--confirm:disabled{opacity:.4;cursor:not-allowed}.scan-overlay__btn--cancel{background:0 0}.scan-overlay__loading{pointer-events:all;background:var(--color-bg-secondary);border:1px solid var(--color-border);text-align:center;border-radius:12px;padding:24px 32px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 32px #00000080}.scan-overlay__loading-text{color:var(--color-text-primary);margin-top:8px;font-size:14px}.scan-overlay__spinner{border:3px solid var(--color-border);border-top:3px solid #3b82f6;border-radius:50%;width:32px;height:32px;margin:0 auto;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.auth-page{background:#0a0a0a;justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:100%;max-width:400px;padding:2rem}.auth-card__title{color:#fff;text-align:center;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.auth-card__subtitle{color:#888;text-align:center;margin-bottom:1.5rem;font-size:.875rem}.auth-form{gap:1rem}.auth-form,.auth-form__label{flex-direction:column;display:flex}.auth-form__label{color:#aaa;gap:.25rem;font-size:.8rem}.auth-form__input{color:#fff;background:#111;border:1px solid #333;border-radius:6px;outline:none;padding:.6rem .75rem;font-size:.875rem;transition:border-color .15s}.auth-form__input:focus{border-color:#3b82f6}.auth-form__error{color:#ef4444;margin:0;font-size:.8rem}.auth-form__btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;padding:.65rem;font-size:.875rem;font-weight:600;transition:background .15s}.auth-form__btn:hover{background:#2563eb}.auth-form__btn:disabled{opacity:.5;cursor:not-allowed}.auth-card__footer{text-align:center;color:#888;margin-top:1rem;font-size:.8rem}.auth-card__footer a{color:#3b82f6;text-decoration:none}.auth-card__footer a:hover{text-decoration:underline}.auth-google{margin-top:1rem}.auth-google__divider{color:#777;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:.78rem;display:flex}.auth-google__divider:after,.auth-google__divider:before{content:"";background:#2f2f2f;flex:1;height:1px}.auth-google__btn-wrap{justify-content:center;min-height:42px;display:flex}.auth-google__btn-wrap--disabled{opacity:.65;pointer-events:none}.auth-google__hint{text-align:center;color:#888;margin-top:.5rem;font-size:.75rem}.auth-google__hint--error{color:#ef4444}.projects-page{color:#fff;background:#0a0a0a;min-height:100vh;padding:2rem 1.25rem}.projects-page__inner{width:min(1600px,100%);margin:0 auto}.projects-page__loading{text-align:center;color:#888;padding:4rem}.projects-page__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.1rem;display:flex}.projects-page__title{font-size:1.5rem;font-weight:700}.projects-page__actions{flex-wrap:wrap;gap:.5rem;display:flex}.projects-page__offline-toggle{color:#cbd5e1;cursor:pointer;-webkit-user-select:none;user-select:none;background:#0f172a;border:1px solid #334155;border-radius:8px;align-items:center;gap:.55rem;padding:.45rem .6rem;display:inline-flex;position:relative}.projects-page__offline-toggle-label{white-space:nowrap;font-size:.78rem;font-weight:600}.projects-page__offline-toggle input{opacity:0;width:0;height:0;position:absolute}.projects-page__offline-toggle-track{background:#334155;border-radius:999px;width:34px;height:20px;transition:background .15s;position:relative}.projects-page__offline-toggle-track:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .15s;position:absolute;top:2px;left:2px}.projects-page__offline-toggle input:checked+.projects-page__offline-toggle-track{background:#2563eb}.projects-page__offline-toggle input:checked+.projects-page__offline-toggle-track:after{transform:translate(14px)}.projects-page__offline-toggle.is-busy{opacity:.6;cursor:not-allowed}.projects-page__columns{grid-template-columns:1fr;align-items:start;gap:1rem;width:100%;display:grid}.projects-page__btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:6px;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.8rem;text-decoration:none;transition:background .15s;display:inline-flex}.projects-page__btn:hover{background:#222}.projects-page__btn--new{background:#3b82f6;border-color:#3b82f6}.projects-page__btn--new:hover{background:#2563eb}.projects-page__btn--login{color:#3b82f6;background:0 0;border-color:#3b82f6}.projects-page__btn--logout{color:#ef4444;background:0 0;border-color:#ef4444}.projects-page__banner{color:#94a3b8;background:#1e293b;border:1px solid #334155;border-radius:8px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem}.projects-page__banner--info{align-items:center;gap:.35rem;display:flex}.projects-page__banner--warning{color:#fde68a;background:#3b2f12;border-color:#8b6f25}.projects-page__banner a{color:#3b82f6;font-weight:600;text-decoration:none}.projects-page__banner a:hover{text-decoration:underline}.projects-page__empty{text-align:center;color:#888;padding:4rem 2rem}.projects-page__empty p{margin-bottom:1rem}.projects-page__grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.projects-page__section{background:#111319;border:1px solid #252a36;border-radius:10px;margin-bottom:0;padding:.9rem}.projects-page__section-title{color:#c7d2fe;align-items:center;gap:.45rem;margin-bottom:.7rem;font-size:.95rem;display:flex}.projects-page__section-empty{color:#9ca3af;background:#121212;border:1px dashed #2a2a2a;border-radius:8px;margin-bottom:.8rem;padding:.8rem}.project-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;transition:border-color .15s;overflow:hidden}.project-card:hover{border-color:#3b82f6}.project-card--local{border-color:#2f3a2f}.project-card--cloud{border-color:#2b3550}.project-card__header{background:#111;justify-content:space-between;padding:.5rem .75rem;display:flex}.project-card__origin{color:#888;align-items:center;gap:.25rem;font-size:.75rem;display:inline-flex}.project-card__origin--local{color:#9ad7a6}.project-card__origin--cloud{color:#9fc3ff}.project-card__delete{color:#555;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px;transition:color .15s}.project-card__delete:hover{color:#ef4444}.project-card__sync-badge{background:#ffffff0d;border-radius:4px;align-items:center;gap:4px;padding:2px 6px;font-size:11px;font-weight:500;display:flex}.project-card__sync-badge span{white-space:nowrap}.sync-badge--synced{color:#4ade80}.sync-badge--pending{color:#facc15}.sync-badge--conflict{color:#f87171}.sync-badge--local{color:#94a3b8}.sync-badge--syncing{color:#60a5fa}.sync-badge__spinner{animation:spin 1s linear infinite}.project-card__body{cursor:pointer;padding:.75rem}.project-card__name{color:#fff;margin-bottom:.25rem;font-size:.95rem;font-weight:600}.project-card__desc{color:#888;white-space:nowrap;text-overflow:ellipsis;margin-bottom:.5rem;font-size:.8rem;overflow:hidden}.project-card__date{color:#666;font-size:.7rem}.projects-debug{color:#cbd5e1;background:#0f172a;border:1px solid #334155;border-radius:8px;margin-bottom:1rem;padding:.65rem .8rem;font-size:.78rem}.projects-debug summary{cursor:pointer;color:#93c5fd;font-weight:600}.projects-debug pre{white-space:pre-wrap;word-break:break-word;max-height:280px;margin-top:.6rem;overflow:auto}@media (min-width:1024px){.projects-page__columns{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:1.25rem}.projects-page__grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media (min-width:1400px){.projects-page__columns{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.projects-page__grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:700px){.projects-page{padding:1rem}.projects-page__title{font-size:1.2rem}.projects-page__banner--info{flex-wrap:wrap;row-gap:.25rem}.projects-page__grid{grid-template-columns:1fr}}.search-bar{background:#1a1a1a;border:1px solid #333;border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem .75rem;transition:border-color .15s;display:flex}.search-bar:focus-within{border-color:#3b82f6}.search-bar__icon{color:#666;flex-shrink:0}.search-bar__input{color:#fff;background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:.9rem}.search-bar__input::placeholder{color:#666}.search-bar__clear{color:#666;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:2px;transition:color .15s;display:flex}.search-bar__clear:hover{color:#ef4444}.search-bar__submit{color:#fff;cursor:pointer;white-space:nowrap;background:#3b82f6;border:none;border-radius:6px;padding:.35rem .75rem;font-size:.8rem;transition:background .15s}.search-bar__submit:hover{background:#2563eb}.search-bar__submit:disabled{opacity:.5;cursor:not-allowed}.pagination{justify-content:center;align-items:center;gap:.75rem;margin-top:1rem;padding:.5rem 0;display:flex}.pagination__btn{color:#fff;cursor:pointer;background:#1a1a1a;border:1px solid #333;border-radius:6px;align-items:center;gap:.25rem;padding:.4rem .75rem;font-size:.8rem;transition:background .15s,border-color .15s;display:inline-flex}.pagination__btn:hover:not(:disabled){background:#222;border-color:#3b82f6}.pagination__btn:disabled{opacity:.35;cursor:not-allowed}.pagination__info{color:#888;font-size:.8rem}.pagination__info strong{color:#c7d2fe}.projects-page__search-label{color:#93c5fd;font-style:italic}.toolbar__btn--login{color:#3b82f6;background:0 0;border:1px solid #3b82f6;border-radius:4px;padding:4px 10px;font-size:.75rem}.toolbar__btn--login:hover{background:#3b82f620}.toolbar__btn--logout{color:#ef4444;background:0 0;border:1px solid #ef4444;border-radius:4px;padding:4px 10px;font-size:.75rem}.toolbar__btn--logout:hover{background:#ef444420}.save-banner{color:#94a3b8;z-index:1000;background:#1e293b;border:1px solid #334155;border-radius:8px;align-items:center;gap:.75rem;padding:.6rem 1.25rem;font-size:.8rem;display:flex;position:fixed;bottom:1rem;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.save-banner--warning{color:#fde68a;background:#3b2f12;border-color:#8b6f25}.save-banner--syncing{color:#bfdbfe;background:#1e3a5f;border-color:#2563eb}.save-banner a{color:#3b82f6;white-space:nowrap;font-weight:600;text-decoration:none}.save-banner a:hover{text-decoration:underline}.save-banner__close{color:#555;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.1rem;line-height:1}.save-banner__close:hover{color:#fff}.migration-dialog{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;width:100%;max-width:440px;margin:auto;padding:1.5rem}.migration-dialog__icon{color:#3b82f6;justify-content:center;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.25rem;display:flex}.migration-dialog__title{color:#fff;text-align:center;margin-bottom:.5rem;font-size:1.1rem;font-weight:600}.migration-dialog__desc{color:#888;text-align:center;margin-bottom:1rem;font-size:.85rem}.migration-dialog__desc strong{color:#fff}.migration-dialog__list{flex-direction:column;gap:.35rem;max-height:150px;margin-bottom:1rem;display:flex;overflow-y:auto}.migration-dialog__item{color:#ccc;gap:.5rem;padding:.35rem .5rem;font-size:.8rem}.migration-dialog__item,.migration-dialog__progress{background:#111;border-radius:4px;align-items:center;display:flex}.migration-dialog__progress{justify-content:center;height:24px;margin-bottom:.75rem;position:relative;overflow:hidden}.migration-dialog__bar{background:#3b82f6;height:100%;transition:width .3s;position:absolute;top:0;left:0}.migration-dialog__progress span{z-index:1;color:#fff;font-size:.75rem;position:relative}.migration-dialog__error{color:#ef4444;text-align:center;margin-bottom:.5rem;font-size:.8rem}.migration-dialog__actions{justify-content:flex-end;gap:.5rem;display:flex}.migration-dialog__btn{cursor:pointer;border:1px solid #333;border-radius:6px;align-items:center;gap:.35rem;padding:.5rem 1rem;font-size:.8rem;transition:background .15s;display:inline-flex}.migration-dialog__btn--secondary{color:#888;background:0 0;border-color:#333}.migration-dialog__btn--secondary:hover{background:#222}.migration-dialog__btn--primary{color:#fff;background:#3b82f6;border-color:#3b82f6}.migration-dialog__btn--primary:hover{background:#2563eb}.migration-dialog__btn:disabled{opacity:.5;cursor:not-allowed}.network-banner{color:#1a1a1a;z-index:1000;background:#f59e0b;justify-content:center;width:100%;padding:6px 16px;font-weight:500;display:flex;position:sticky;top:0;left:0}.network-banner,.network-reconnect-toast{align-items:center;gap:8px;font-size:13px}.network-reconnect-toast{color:#d1fae5;z-index:1100;background:#0f2d1c;border:1px solid #1f7a46;border-radius:8px;padding:10px 12px;font-weight:600;display:inline-flex;position:fixed;bottom:16px;right:16px;box-shadow:0 8px 22px #00000059}.network-reconnect-toast--info{color:#dbeafe;background:#0f2447;border-color:#1d4ed8}.network-reconnect-toast--success{color:#d1fae5;background:#0f2d1c;border-color:#1f7a46}.network-reconnect-toast--error{color:#fecaca;background:#3a1010;border-color:#991b1b}.sync-auth-banner{color:#fde68a;z-index:1001;background:#3b2f12;border-top:1px solid #8b6f25;border-bottom:1px solid #8b6f25;justify-content:center;align-items:center;gap:10px;padding:8px 16px;font-size:13px;font-weight:600;display:flex}.sync-auth-banner a{color:#fef3c7;text-decoration:underline}.sync-status-indicator{background:#1a1a1a;border-bottom:1px solid #2a2a2a;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:500;display:flex}.sync-status-indicator span{opacity:.8}.sync-status-indicator__offline{color:#f59e0b;margin-left:4px}.sync-status--synced{color:#4ade80}.sync-status--pending{color:#facc15}.sync-status--conflict{color:#f87171}.sync-status--local{color:#94a3b8}.sync-status--syncing{color:#60a5fa}.sync-status--spinning{animation:spin 1s linear infinite}.sync-status-indicator__badge{color:#000;background:#facc15;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;line-height:1;display:inline-flex}.conflict-dialog-overlay{z-index:9999;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.conflict-dialog{color:#e0e0e0;background:#1e1e1e;border:1px solid #333;border-radius:12px;width:90%;max-width:440px;padding:24px}.conflict-dialog__header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.conflict-dialog__header h3{margin:0;font-size:18px;font-weight:600}.conflict-dialog__icon{color:#f59e0b}.conflict-dialog__description{color:#aaa;margin-bottom:16px;font-size:14px;line-height:1.5}.conflict-dialog__versions{gap:12px;margin-bottom:20px;display:flex}.conflict-dialog__version{background:#2a2a2a;border-radius:8px;flex-direction:column;flex:1;gap:4px;padding:12px;display:flex}.conflict-dialog__version strong{font-size:13px}.conflict-dialog__version span{color:#888;font-size:12px}.conflict-dialog__actions{gap:10px;display:flex}.conflict-dialog__btn{color:#e0e0e0;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:8px;flex:1;padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s}.conflict-dialog__btn:hover{background:#333}.conflict-dialog__btn:disabled{opacity:.5;cursor:not-allowed}.conflict-dialog__btn--local{border-color:#3b82f6}.conflict-dialog__btn--local:hover{background:#1e3a5f}.conflict-dialog__btn--server{border-color:#10b981}.conflict-dialog__btn--server:hover{background:#1a3a2a}.conflict-dialog__project-id{color:#555;text-align:center;margin-top:12px;font-size:11px}.exit-confirm-overlay{z-index:9999;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.exit-confirm{color:#e0e0e0;background:#1e1e1e;border:1px solid #333;border-radius:12px;width:90%;max-width:420px;padding:24px}.exit-confirm__header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.exit-confirm__header h3{margin:0;font-size:18px;font-weight:600}.exit-confirm__icon{color:#f59e0b}.exit-confirm__description{color:#aaa;margin-bottom:20px;font-size:14px;line-height:1.5}.exit-confirm__actions{gap:10px;display:flex}.exit-confirm__btn{color:#e0e0e0;cursor:pointer;background:#2a2a2a;border:1px solid #444;border-radius:8px;flex:1;padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s}.exit-confirm__btn:hover{background:#333}.exit-confirm__btn--stay{color:#60a5fa;border-color:#3b82f6}.exit-confirm__btn--stay:hover{background:#1e3a5f}.exit-confirm__btn--leave{color:#f87171;border-color:#ef4444}.exit-confirm__btn--leave:hover{background:#3f1e1e}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8d697b304b401681-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba015fad6dcf6784-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/4cf2300e9c8272f7-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Fallback;src:local("Arial");ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.00%;size-adjust:104.76%}.__className_188709{font-family:Geist,Geist Fallback;font-style:normal}.__variable_188709{--font-geist-sans:"Geist","Geist Fallback"}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/9610d9e46709d722-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/747892c23ea88013-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/93f479601ee12b01-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Geist Mono Fallback;src:local("Arial");ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.00%;size-adjust:134.59%}.__className_9a8899{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.__variable_9a8899{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}