@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--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-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--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;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--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;--color-cyan-600:oklch(60.9% .126 221.723);--color-cyan-700:oklch(52% .105 223.128);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-gray-900:oklch(21% .034 264.665);--color-white:#fff;--spacing:.25rem;--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-sm:.25rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-in-out:cubic-bezier(.4, 0, .2, 1);--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{*,:after,:before,::backdrop{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}html,:host{-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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{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}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,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{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-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{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.invisible{visibility:hidden}.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)}.top-0{top:calc(var(--spacing) * 0)}.left-0{left:calc(var(--spacing) * 0)}.z-50{z-index:50}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.ml-4{margin-left:calc(var(--spacing) * 4)}.contents{display:contents}.flex{display:flex}.grid{display:grid}.inline{display:inline}.table{display:table}.h-10{height:calc(var(--spacing) * 10)}.h-full{height:100%}.w-80{width:calc(var(--spacing) * 80)}.flex-1{flex:1}.grow{flex-grow:1}.-translate-x-full{--tw-translate-x:-100%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-x-0{--tw-translate-x:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-3{gap:calc(var(--spacing) * 3)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-gray-700{border-color:var(--color-gray-700)}.bg-cyan-600{background-color:var(--color-cyan-600)}.bg-gray-800{background-color:var(--color-gray-800)}.bg-gray-900{background-color:var(--color-gray-900)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-white{color:var(--color-white)}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.blur{--tw-blur:blur(8px);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,)}.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-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.hover\:bg-cyan-700:hover{background-color:var(--color-cyan-700)}.hover\:bg-gray-700:hover{background-color:var(--color-gray-700)}.hover\:bg-gray-800:hover{background-color:var(--color-gray-800)}}}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0a0a0b;--bg-raised:#111114;--bg-overlay:#161619;--bg-inset:#0e0e10;--bg-hover:#ffffff08;--border:#1e1e24;--border-strong:#2a2a32;--border-focus:#d4a85366;--text:#e8e4df;--text-secondary:#7a7a85;--text-tertiary:#4e4e58;--accent:#d4a853;--accent-hover:#e6be6a;--accent-muted:#d4a8531f;--accent-glow:#d4a85314;--danger:#cf6b5e;--danger-muted:#cf6b5e1f;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 12px 40px #0009;--radius:12px;--radius-sm:8px;--radius-xs:6px;--ease:cubic-bezier(.4, 0, .2, 1);--duration:.18s;--sidebar-width:220px;--header-height:56px}*{box-sizing:border-box;margin:0}body{background:var(--bg);min-height:100vh;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:DM Sans,sans-serif;font-size:14px;line-height:1.5}button,input{font:inherit;color:inherit}a{color:inherit;text-decoration:none}#root{min-height:100vh}.login-screen{background:radial-gradient(ellipse 60% 50% at 50% 0%, #d4a8530a, transparent), var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.login-form-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);width:min(400px,100%);box-shadow:var(--shadow-lg);padding:32px}.login-form-card h1{letter-spacing:-.01em;margin-bottom:24px;font-size:1.15rem;font-weight:700}.form-stack{gap:16px;display:grid}.field{gap:6px;display:grid}.field-label{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;font-size:.8rem;font-weight:600}.input{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease);padding:10px 12px}.input::placeholder{color:var(--text-tertiary)}.input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.input-with-action{position:relative}.input-with-action-field{padding-right:42px}.input-action{width:24px;height:24px;color:var(--text-tertiary);cursor:pointer;transition:color var(--duration) var(--ease);background:0 0;border:none;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.input-action:hover{color:var(--text-secondary)}.input-action:focus-visible{color:var(--text);outline:none}.input-file{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:border-color var(--duration) var(--ease);padding:10px 12px}.input-file:hover{border-color:var(--border-strong)}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration) var(--ease);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:9px 14px;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#0a0a0b;font-weight:700}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-ghost{border-color:var(--border);color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){border-color:var(--border-strong);color:var(--text);background:var(--bg-hover)}.btn-danger{color:var(--danger);background:0 0;border-color:#cf6b5e40}.btn-danger:hover:not(:disabled){background:var(--danger-muted);border-color:#cf6b5e73}.btn-sm{padding:6px 10px;font-size:.8rem}.btn-full{width:100%}.alert{border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 12px;font-size:.875rem;display:flex}.alert-error{background:var(--danger-muted);color:#f0b4a4;border:1px solid #cf6b5e2e}.alert-info{color:var(--text-secondary);border:1px solid var(--border);background:#ffffff08}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-raised);border-right:1px solid var(--border);z-index:40;transition:transform .3s var(--ease);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 16px;display:flex}.sidebar-brand-icon{border-radius:var(--radius-sm);background:var(--accent-muted);width:32px;height:32px;color:var(--accent);border:1px solid #d4a85326;flex-shrink:0;place-items:center;display:grid}.sidebar-brand h1{letter-spacing:-.01em;font-size:.95rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.sidebar-link{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease);text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{color:var(--text);background:var(--bg-hover)}.sidebar-link--active{color:var(--text);background:#d4a8530f;border-color:#d4a8531a}.sidebar-link--active .sidebar-link-icon{color:var(--accent)}.sidebar-link-icon{transition:color var(--duration) var(--ease);flex-shrink:0}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding:12px;display:flex}.sidebar-user{color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;padding:4px 8px;font-size:.78rem;overflow:hidden}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.page{max-width:900px;margin:0 auto;padding:32px 28px}.page-header{margin-bottom:24px}.page-title{letter-spacing:-.02em;font-size:1.25rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:4px;font-size:.875rem}.upload-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);max-width:520px;box-shadow:var(--shadow-sm);padding:24px}.drop-zone{border:2px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-tertiary);text-align:center;transition:all var(--duration) var(--ease);cursor:pointer;flex-direction:column;align-items:center;gap:10px;margin-bottom:16px;padding:36px 20px;display:flex}.drop-zone:hover{border-color:var(--accent-muted);color:var(--text-secondary);background:var(--accent-glow)}.drop-zone--active{border-color:var(--accent);background:var(--accent-muted);color:var(--accent)}.drop-zone--active .drop-zone-icon{color:var(--accent);transform:scale(1.1)}.drop-zone-icon{color:var(--text-tertiary);transition:all var(--duration) var(--ease)}.drop-zone-text{font-size:.875rem;font-weight:500}.drop-zone-hint{color:var(--text-tertiary);font-size:.78rem}.page--upload-editor{max-width:980px}.upload-workspace{gap:18px;display:grid}.upload-drop-zone{background:var(--bg-inset);text-align:left;border-width:1px;border-radius:8px;align-items:stretch;gap:16px;margin-bottom:0;padding:18px 20px}.upload-drop-main{grid-template-columns:1fr;align-items:center;gap:14px;min-height:172px;display:grid}.upload-drop-zone--filled .upload-drop-main{grid-template-columns:180px minmax(0,1fr);min-height:0}.upload-drop-empty-icon{background:#d4a85314;border:1px solid #d4a85324;border-radius:8px;place-items:center;width:44px;height:44px;display:grid}.upload-drop-copy{gap:6px;min-width:0;display:grid}.upload-preview{object-fit:cover;border:1px solid var(--border);background:var(--bg-surface);border-radius:6px;width:180px;height:132px}.upload-drop-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.upload-editor-head{gap:14px;padding-top:2px;display:grid}.upload-form-row{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr)}.file-pill{background:var(--accent-glow);border-radius:var(--radius-sm);color:var(--accent-hover);border:1px solid #d4a8531f;align-items:center;gap:8px;padding:8px 12px;font-size:.82rem;display:inline-flex}.file-pill-remove{color:var(--text-tertiary);cursor:pointer;transition:color var(--duration) var(--ease);background:0 0;border:none;place-items:center;padding:0;display:grid}.file-pill-remove:hover{color:var(--danger)}.search-bar{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--duration) var(--ease), box-shadow var(--duration) var(--ease);align-items:center;gap:10px;padding:0 14px;display:flex}.search-bar:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.search-bar-icon{color:var(--text-tertiary);transition:color var(--duration) var(--ease);flex-shrink:0}.search-bar:focus-within .search-bar-icon{color:var(--accent)}.search-bar input{background:0 0;border:none;outline:none;flex:1;padding:11px 0}.search-bar input::placeholder{color:var(--text-tertiary)}.toolbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.toolbar-left{flex:1;min-width:0}.image-list{flex-direction:column;gap:12px;padding-bottom:18px;display:flex}.image-row{width:100%;transition:background var(--duration) var(--ease), border-color var(--duration) var(--ease), transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);cursor:pointer;appearance:none;text-align:left;background:linear-gradient(180deg, #ffffff07, #ffffff04), var(--bg-raised);border:1px solid #ffffff0d;border-radius:18px;align-items:flex-start;gap:14px;padding:16px 18px;display:flex;position:relative;box-shadow:0 10px 24px #0000002e}.image-row:focus-visible{border-color:#d4a85338;outline:none;box-shadow:0 0 0 3px #d4a85314,0 14px 32px #0000003d}.image-row:hover{background:linear-gradient(#ffffff0a,#ffffff06),#17171b;border-color:#d4a8531f;transform:translateY(-1px);box-shadow:0 14px 32px #0000003d}.image-row-thumb-link{flex-shrink:0;display:block}.image-row-thumb{border-radius:var(--radius-sm);background:var(--bg-inset);border:1px solid var(--border);width:100px;height:72px;transition:border-color var(--duration) var(--ease);overflow:hidden}.image-row:hover .image-row-thumb{border-color:var(--border-strong)}.image-row-thumb img{object-fit:cover;width:100%;height:100%;transition:transform .25s var(--ease)}.image-row:hover .image-row-thumb img{transform:scale(1.04)}.image-row-body{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.image-row-title-line{flex-wrap:wrap;justify-content:flex-start;align-items:baseline;gap:6px 10px;display:flex}.image-row-title{white-space:nowrap;text-overflow:ellipsis;font-size:.925rem;font-weight:600;overflow:hidden}.image-row-date{color:var(--text-tertiary);flex-shrink:0;font-size:.78rem}.image-row-url{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;transition:color var(--duration) var(--ease);font-size:.8rem;overflow:hidden}.image-row-url:hover{color:var(--accent-hover);text-underline-offset:3px;text-decoration:underline}.image-row-tags{flex-wrap:wrap;gap:5px;margin-top:2px;display:flex}.image-row-footer{justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.image-row-hint,.image-row-size{color:var(--text-tertiary);font-size:.76rem}.image-row-size{flex-shrink:0}.tag{background:var(--accent-muted);color:var(--accent-hover);letter-spacing:.01em;border:1px solid #d4a8531a;border-radius:20px;padding:2px 8px;font-size:.72rem;font-weight:500}.tag--empty{color:var(--text-tertiary);background:#ffffff08;border-color:#ffffff0d}.tag-remove{color:inherit;opacity:.6;cursor:pointer;transition:opacity var(--duration) var(--ease);background:0 0;border:none;justify-content:center;align-items:center;margin-left:4px;padding:0;display:inline-flex}.tag-remove:hover{opacity:1}.tag-input{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius);cursor:text;min-height:40px;transition:border-color var(--duration) var(--ease);padding:6px 8px}.tag-input:focus-within{border-color:var(--border-focus)}.tag-input-chips{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.tag-input-chips .tag{align-items:center;display:inline-flex}.tag-input-field{min-width:120px;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:2px 4px;font-size:.875rem}.tag-input-field::placeholder{color:var(--text-tertiary)}.image-row-actions{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.edit-fields{flex-direction:column;gap:6px;margin-top:4px;display:flex}.page--detail{padding-bottom:40px}.detail-toolbar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;display:flex}.detail-back{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:color var(--duration) var(--ease), background var(--duration) var(--ease);background:0 0;border:none;align-items:center;gap:6px;padding:6px 10px;font-size:.875rem;display:inline-flex}.detail-back:hover{color:var(--text);background:var(--bg-hover)}.detail-actions-inline{flex-wrap:wrap;gap:6px;display:flex}.detail-layout{grid-template-columns:1fr 320px;align-items:start;gap:32px;display:grid}.detail-preview{border-radius:var(--radius);background:var(--bg-inset);border:1px solid var(--border);position:sticky;top:20px;overflow:hidden}.detail-preview img{object-fit:contain;width:100%;max-height:calc(100vh - 160px);display:block}.detail-sidebar{flex-direction:column;gap:0;display:flex}.detail-title-block{flex-direction:column;gap:10px;display:flex}.detail-title{letter-spacing:-.02em;font-size:1.35rem;font-weight:600;line-height:1.2}.detail-tag-row{flex-wrap:wrap;gap:6px;display:flex}.detail-divider{background:var(--border);height:1px;margin:16px 0}.detail-meta-row{flex-direction:column;gap:10px;display:flex}.detail-meta-item{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.detail-meta-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;font-size:.75rem}.detail-meta-value{color:var(--text-secondary);text-align:right;font-size:.875rem}.detail-section{flex-direction:column;gap:12px;display:flex}.detail-section-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.detail-section-header h3{color:var(--text-secondary);font-size:.875rem;font-weight:600}.detail-data-list{flex-direction:column;gap:8px;display:flex}.detail-data-item{flex-direction:column;gap:3px;display:flex}.detail-data-item dt{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem}.detail-data-item dd{color:var(--text-secondary);word-break:break-all;font-size:.8rem}.detail-section-actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}@media (width<=900px){.detail-layout{grid-template-columns:1fr}.detail-preview{position:static}.detail-preview img{max-height:50vh}}.state-block{text-align:center;color:var(--text-secondary);flex-direction:column;align-items:center;gap:10px;padding:48px 20px;display:flex}.state-block-icon{color:var(--text-tertiary)}.state-block h3{color:var(--text);font-size:.95rem;font-weight:600}.state-block p{max-width:300px;color:var(--text-secondary);font-size:.85rem}.drag-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;animation:fadeIn .15s var(--ease);background:#0a0a0bd9;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:fixed;inset:0}.drag-overlay-icon{color:var(--accent);animation:1.5s ease-in-out infinite dragBounce}.drag-overlay-text{color:var(--text);font-size:1.1rem;font-weight:600}.drag-overlay-hint{color:var(--text-secondary);font-size:.85rem}@keyframes dragBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.count-badge{background:var(--accent-muted);min-width:20px;height:20px;color:var(--accent);border-radius:10px;justify-content:center;align-items:center;margin-left:auto;padding:0 6px;font-size:.7rem;font-weight:700;display:inline-flex}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-header,.sidebar-backdrop{display:none}@media (width<=768px){:root{--sidebar-width:260px}.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}.sidebar-backdrop{z-index:35;animation:fadeIn .2s var(--ease);background:#00000080;display:block;position:fixed;inset:0}.mobile-header{border-bottom:1px solid var(--border);background:var(--bg-raised);z-index:30;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.mobile-header h1{font-size:.95rem;font-weight:700}.main-content{margin-left:0}.page{padding:20px 16px}.detail-layout{grid-template-columns:1fr}.detail-preview-frame{min-height:280px}.detail-meta-grid{grid-template-columns:1fr}.detail-section-header,.image-row-footer{flex-direction:column;align-items:flex-start}.image-row{gap:10px}.image-row-thumb{width:72px;height:54px}.image-row-actions{flex-direction:row}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-header-content{flex-direction:column;display:flex}.form-row{grid-template-columns:1fr 140px;gap:12px;display:grid}.form-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.code-textarea{resize:vertical;min-height:300px;font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,Consolas,monospace;font-size:.875rem;line-height:1.6}.script-index-summary{color:var(--text-tertiary);border-bottom:1px solid var(--border);justify-content:space-between;gap:16px;margin-bottom:18px;padding:0 0 14px;font-size:.78rem;display:flex}.tag-filter{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.tag-filter-btn{color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease);background:#ffffff08;border:1px solid #ffffff0f;border-radius:20px;padding:4px 10px;font-size:.75rem;font-weight:500}.tag-filter-btn:hover{color:var(--text);background:#ffffff0f}.tag-filter-btn--active{background:var(--accent-muted);color:var(--accent-hover);border-color:#d4a85333}.tag-filter-btn--active:hover{color:var(--accent-hover);background:#d4a85326}.script-list{border-top:1px solid var(--border);flex-direction:column;display:flex}.script-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:18px;padding:18px 0;display:flex}.script-row-main{flex:1;gap:14px;min-width:0;display:flex}.script-row-icon{width:34px;height:34px;color:var(--accent);background:#d4a85314;border:1px solid #d4a8531f;border-radius:10px;flex-shrink:0;place-items:center;display:grid}.script-row-body{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.script-row-topline{flex-wrap:wrap;align-items:baseline;gap:8px 12px;display:flex}.script-row-name{color:var(--text);transition:color var(--duration) var(--ease);font-size:.98rem;font-weight:600}.script-row-name:hover{color:var(--accent-hover)}.script-row-ext,.script-row-date,.script-row-hint{color:var(--text-tertiary);font-size:.78rem}.script-row-tags{flex-wrap:wrap;gap:6px;display:flex}.script-row-url{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;min-width:0;font-size:.8rem;display:flex;overflow:hidden}.script-row-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.page--script-detail,.page--script-editor{max-width:1080px}.script-detail-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:20px;padding:2px 0 14px;display:flex}.script-detail-heading{flex-direction:column;gap:6px;min-width:0;display:flex}.script-detail-title-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.script-detail-title{letter-spacing:-.025em;font-size:1.4rem;font-weight:620;line-height:1.1}.script-detail-subtitle{max-width:760px;color:var(--text-secondary);font-size:.9rem}.script-detail-meta{border-bottom:1px solid var(--border);color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:10px 18px;padding:12px 0;font-size:.78rem;display:flex}.script-code-toolbar{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:14px;padding:12px 0 10px;font-size:.79rem;display:flex}.script-code-stage,.script-preview-frame{border:1px solid var(--border);background:var(--bg-inset);border-radius:8px;overflow:hidden}.code-viewer{font-variant-ligatures:none;font-feature-settings:"liga" 0, "calt" 0;min-height:0;font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,Consolas,monospace;font-size:.84rem;line-height:1.45}.code-viewer .shiki,.code-viewer pre{min-height:inherit;margin:0;padding:14px 0;overflow:auto;background:0 0!important}.code-viewer code,.code-viewer .shiki code,.code-viewer .shiki-pre .shiki-code{counter-reset:code-line;tab-size:4;min-width:max-content;display:block;white-space:normal!important}.code-viewer .shiki .line,.code-viewer-fallback-line{white-space:pre;padding:0 20px 0 72px;display:block;position:relative}.code-viewer[data-line-numbers=true] .shiki .line:before{counter-increment:code-line;content:counter(code-line);text-align:right;width:52px;color:var(--text-tertiary);border-right:1px solid var(--border);padding-right:14px;position:absolute;top:0;left:0}@supports (color:color-mix(in lab, red, red)){.code-viewer[data-line-numbers=true] .shiki .line:before{border-right:1px solid color-mix(in srgb, var(--border) 88%, transparent)}}.code-viewer[data-line-numbers=true] .shiki .line:before{-webkit-user-select:none;user-select:none}.code-viewer--wrap .shiki .line,.code-viewer--wrap .code-viewer-fallback-line-content{white-space:pre-wrap;overflow-wrap:anywhere}.code-viewer--wrap code,.code-viewer--wrap .shiki code,.code-viewer--wrap .shiki-pre .shiki-code{min-width:0}.code-viewer-fallback-line{padding-left:20px;display:flex}.code-viewer-fallback-line-number{text-align:right;min-width:52px;color:var(--text-tertiary);border-right:1px solid var(--border);-webkit-user-select:none;user-select:none;flex-shrink:0;margin-right:16px;padding-right:14px;display:inline-block}.code-viewer-fallback-line-content{white-space:pre;flex:1}.detail-title-icon{flex-shrink:0}.script-ext{color:var(--text-tertiary);margin-left:8px;font-size:.75rem;font-weight:500}.script-url-link{max-width:min(420px,100%);color:var(--accent);transition:color var(--duration) var(--ease);word-break:break-all;align-items:center;gap:8px;padding:10px 0;font-size:.82rem;display:flex}.script-url-link:hover{color:var(--accent-hover)}.script-editor-head{border-bottom:1px solid var(--border);gap:14px;margin-bottom:18px;padding-bottom:18px;display:grid}.page--script-create .page-header{margin-bottom:18px}.page--script-create .script-editor-head{margin-bottom:14px}.page--script-create .script-editor-textarea{min-height:520px}.script-pane{gap:10px;min-width:0;display:grid}.script-preview-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.script-preview-meta{color:var(--text-tertiary);font-size:.76rem}.script-editor-textarea{border:1px solid var(--border);background:linear-gradient(180deg, #ffffff04, #fff0), var(--bg-inset);width:100%;min-height:460px;color:var(--text);resize:vertical;white-space:pre;border-radius:10px;padding:18px 20px;font-family:SF Mono,Fira Code,Fira Mono,Roboto Mono,Consolas,monospace;font-size:.88rem;line-height:1.6}.script-editor-textarea--wrap{white-space:pre-wrap}.script-editor-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.script-pane--preview-below{margin-top:18px}.toolbar-right{align-items:center;gap:8px;display:flex}@media (width<=768px){.script-index-summary,.page-header{flex-direction:column;align-items:flex-start}.form-row{grid-template-columns:1fr}.script-row{flex-direction:column;align-items:stretch}.script-row-actions,.script-detail-header,.script-code-toolbar{flex-direction:column;align-items:flex-start}.script-editor-textarea{min-height:360px}.upload-drop-zone--filled .upload-drop-main,.upload-form-row{grid-template-columns:1fr}.upload-preview{width:100%;max-width:240px;height:180px}}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@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-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@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}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}
