:root{--primary-color: #6366f1;--secondary-color: #22c55e;--background-color: #0f172a;--tenant-primary-color: var(--primary-color);--tenant-secondary-color: var(--secondary-color);--tenant-background-color: var(--background-color);--tenant-sidebar-color: color-mix(in srgb, var(--tenant-background-color), black 40%);--tenant-surface-color: color-mix(in srgb, var(--tenant-background-color), white 5%);--tenant-border-color: color-mix(in srgb, var(--tenant-background-color), white 15%)}html,body,#root{height:100%;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--tenant-background-color);color:#e5e7eb}.app-shell{display:flex;height:100vh}.side-nav{display:flex;flex-direction:column;background:var(--tenant-sidebar-color);color:#e5e7eb;padding:.75rem .5rem;transition:width .2s ease;border-right:1px solid var(--tenant-border-color)}.side-nav.expanded{width:220px}.side-nav.collapsed{width:64px}.side-nav.collapsed .menu-toggle,.side-nav.collapsed .nav-item{padding-left:.2rem;justify-content:center}.menu-toggle{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .7rem;background:transparent;border:none;color:inherit;cursor:pointer;font-size:.95rem;border-radius:.5rem;text-align:left}.menu-toggle:hover{background-color:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.nav-items{display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .7rem;background:transparent;border:none;color:inherit;text-align:left;border-radius:.5rem;cursor:pointer;font-size:.95rem}.nav-item:hover{background-color:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.nav-item.active{background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));color:#0b1120;font-weight:600}.nav-icon{width:1.5rem;display:inline-flex;justify-content:center}.version-display{margin-top:auto;padding:.75rem;text-align:center}.version-text{font-size:.7rem;color:#64748b;opacity:.6;font-weight:400}.mobile-hamburger{display:none;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--tenant-border-color);border-radius:8px;color:#e5e7eb;font-size:1.25rem;cursor:pointer;flex-shrink:0;transition:background .2s ease,border-color .2s ease;margin-right:.5rem}.mobile-hamburger:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:var(--tenant-primary-color)}.mobile-nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:999;animation:backdropFadeIn .2s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.mobile-nav-close{display:flex;align-items:center;gap:.75rem;width:100%;padding:.6rem .7rem;background:transparent;border:none;color:inherit;cursor:pointer;font-size:.95rem;border-radius:.5rem;text-align:left}.mobile-nav-close:hover{background-color:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid var(--tenant-border-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:radial-gradient(circle at top left,color-mix(in srgb,var(--tenant-primary-color),transparent 88%),transparent),radial-gradient(circle at top right,color-mix(in srgb,var(--tenant-secondary-color),transparent 88%),transparent),var(--tenant-surface-color)}.app-title{margin:0;font-size:1.15rem;letter-spacing:.03em}.topbar-left{display:flex;align-items:center;gap:.75rem;min-width:0;flex-shrink:1}.top-logo{height:50px;display:flex;align-items:center}.logo-image{height:130%;width:auto;object-fit:contain;display:block}.top-logo-text{color:#0b1120;font-weight:700;font-size:.75rem;letter-spacing:.04em}.tenant-logo{max-height:40px;height:auto}.tenant-name{margin-left:.75rem;font-size:1rem;font-weight:600;color:#e5e7eb;white-space:nowrap}.product-name{font-size:1.1rem;font-weight:600;letter-spacing:.02em;color:#e5e7eb}.global-search-container{position:relative;flex:1;max-width:500px;margin:0 2rem}.global-search-input-wrapper{position:relative;display:flex;align-items:center;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.5rem;padding:.5rem .75rem;transition:all .2s ease}.global-search-input-wrapper:focus-within{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 50%);background:var(--tenant-sidebar-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.search-icon{font-size:1rem;margin-right:.5rem;opacity:.6}.global-search-input{flex:1;background:transparent;border:none;outline:none;color:#e5e7eb;font-size:.9rem;padding:0}.global-search-input::placeholder{color:#64748b}.search-clear-button{background:transparent;border:none;color:#94a3b8;font-size:1rem;cursor:pointer;padding:0 .25rem;margin-left:.5rem;transition:color .2s ease}.search-clear-button:hover{color:#e5e7eb}.global-search-dropdown{position:absolute;top:calc(100% + .5rem);left:0;right:0;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.75rem;box-shadow:0 10px 40px #00000080;max-height:400px;overflow-y:auto;z-index:1000;animation:searchDropdownSlideIn .2s ease-out}@keyframes searchDropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.search-dropdown-loading,.search-dropdown-empty{padding:2rem;text-align:center;color:#9ca3af;font-size:.9rem}.search-suggestion-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;border-bottom:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);color:#e5e7eb;text-align:left;cursor:pointer;transition:background .15s ease}.search-suggestion-item:last-of-type{border-bottom:none}.search-suggestion-item:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.search-suggestion-icon{font-size:1rem;opacity:.5;flex-shrink:0}.search-suggestion-text{flex:1;font-size:.9rem;font-weight:500;color:#e5e7eb}.search-dropdown-footer{padding:.75rem 1rem;text-align:center;font-size:.8rem;color:#6b7280;border-top:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);background:color-mix(in srgb,var(--tenant-sidebar-color),transparent 50%)}.admin-mode-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;margin-right:1rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:2px solid var(--tenant-border-color);border-radius:.5rem;color:#9ca3af;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;flex-shrink:0}.admin-mode-toggle:hover{background:color-mix(in srgb,#dc2626,transparent 85%);border-color:color-mix(in srgb,#dc2626,transparent 60%);color:#fca5a5}.admin-mode-toggle.active{background:#dc2626;border-color:#dc2626;color:#fff;font-weight:600}.admin-toggle-icon{font-size:1.1rem}.top-bar.admin-mode{background:linear-gradient(135deg,#7f1d1d,#991b1b,#7f1d1d);border-bottom-color:#dc2626}.account-area{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.avatar{width:34px;height:34px;border-radius:999px;background:linear-gradient(135deg,#22c55e,#06b6d4);display:flex;align-items:center;justify-content:center;color:#0b1120;font-weight:600;font-size:.95rem}.avatar-button{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .6rem .4rem .4rem;border-radius:999px;border:1px solid var(--tenant-border-color);background:var(--tenant-sidebar-color);color:#e5e7eb;font-size:.9rem;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.avatar-button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--tenant-primary-color),transparent 80%)}.avatar-button:active{transform:translateY(0)}.avatar{width:36px;height:36px;border-radius:999px;background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));display:flex;align-items:center;justify-content:center;color:#0b1120;font-weight:700;font-size:1rem;flex-shrink:0;box-shadow:0 2px 8px color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.avatar-name{font-size:.9rem;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-menu-container{position:relative;display:inline-block}.account-dropdown{position:absolute;top:100%;right:0;min-width:180px;padding-top:.5rem;z-index:1000;animation:dropdownFadeIn .15s ease-out}.account-dropdown-menu{background:var(--tenant-background-color);border:1px solid var(--tenant-border-color);border-radius:12px;box-shadow:0 8px 24px #0006;overflow:hidden}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.account-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:#e5e7eb;font-size:.9rem;cursor:pointer;transition:background-color .15s ease;text-align:left}.account-dropdown-item:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.account-dropdown-item .dropdown-icon{font-size:1rem}.account-dropdown-divider{height:1px;background:var(--tenant-border-color);margin:.25rem 0}.account-dropdown-signout:hover{background:#ef444426;color:#ef4444}@media (max-width: 768px){.avatar-name,.admin-toggle-label{display:none}.admin-mode-toggle{padding:.5rem .6rem;margin-right:.5rem}.tenant-name{max-width:80px;overflow:hidden;text-overflow:ellipsis}}.sign-in-button{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:999px;border:1px solid var(--tenant-border-color);background:transparent;color:#e5e7eb;font-size:.9rem;cursor:pointer;transition:all .2s ease}.sign-in-button:hover{background-color:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%)}.sign-in-icon{font-size:1rem}.content{padding:1.25rem 1.5rem 2rem;overflow:auto}.section-title{margin:0 0 1rem;font-size:1.05rem;color:#e5e7eb}.sim-section{display:flex;flex-direction:column;gap:1rem}.sim-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.sim-card{background:radial-gradient(circle at top left,color-mix(in srgb,var(--tenant-primary-color),transparent 75%),transparent 55%),color-mix(in srgb,var(--tenant-background-color),transparent 5%);border-radius:.9rem;border:1px solid var(--tenant-border-color);padding:.85rem;display:flex;flex-direction:column;gap:.6rem;box-shadow:0 10px 30px #0f172ab3}.sim-thumbnail{position:relative;border-radius:.75rem;background:repeating-conic-gradient(from 0deg,#94a3b833,#94a3b833 10deg,#1e40af80 10deg,#1e40af80 20deg);height:160px;overflow:hidden;display:flex;align-items:center;justify-content:center}.sim-thumb-label{position:relative;z-index:1;padding:.25rem .6rem;border-radius:999px;background:#0f172ad9;color:#e5e7eb;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.sim-info h3{margin:0 0 .25rem;font-size:.98rem}.sim-info p{margin:0;font-size:.85rem;color:#cbd5f5;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.description-tooltip-wrapper{position:relative}.description-tooltip{position:absolute;left:0;right:0;top:calc(100% + 8px);background:linear-gradient(135deg,#1e293b,#0f172a);border:1px solid #334155;border-radius:8px;padding:12px 14px;font-size:.85rem;color:#e2e8f0;line-height:1.5;box-shadow:0 10px 40px #00000080,0 0 0 1px #ffffff0d;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease,visibility .2s;max-height:200px;overflow-y:auto}.description-tooltip:before{content:"";position:absolute;top:-6px;left:20px;width:12px;height:12px;background:#1e293b;border-left:1px solid #334155;border-top:1px solid #334155;transform:rotate(45deg)}.description-tooltip:after{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}.description-tooltip-wrapper:hover .description-tooltip{opacity:1;visibility:visible;transform:translateY(0)}@media (max-width: 768px){.top-bar{padding-inline:1rem;flex-wrap:wrap;gap:.75rem}.global-search-container{order:3;flex:0 0 100%;width:100%;max-width:none;margin:0}.content{padding-inline:1rem}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:1rem}.section-header-left{display:flex;align-items:center;gap:1rem}.section-title{margin:0;font-size:1.05rem;color:#e5e7eb}.inline-filters{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;padding:.75rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 60%);border:1px solid var(--tenant-border-color);border-radius:.75rem}.inline-search-wrapper{flex:1;max-width:400px;display:flex;align-items:center;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.5rem;padding:.5rem .75rem;transition:all .2s ease}.inline-search-wrapper:focus-within{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 50%);background:var(--tenant-surface-color)}.inline-search-icon{font-size:.95rem;margin-right:.5rem;opacity:.5}.inline-search-input{flex:1;background:transparent;border:none;outline:none;color:#e5e7eb;font-size:.9rem;padding:0}.inline-search-input::placeholder{color:#64748b}.inline-search-clear{background:transparent;border:none;color:#94a3b8;font-size:1rem;cursor:pointer;padding:0 .25rem;margin-left:.5rem;transition:color .2s ease}.inline-search-clear:hover{color:#e5e7eb}.search-results-banner{display:flex;align-items:center;justify-content:space-between;background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 60%);border-radius:.5rem;padding:.75rem 1rem;margin-bottom:1rem}.search-results-text{color:#e5e7eb;font-size:.95rem}.search-results-text strong{color:var(--tenant-primary-color)}.search-results-clear{background:transparent;border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 50%);color:var(--tenant-primary-color);font-size:.85rem;padding:.35rem .75rem;border-radius:.375rem;cursor:pointer;transition:all .2s ease}.search-results-clear:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);border-color:var(--tenant-primary-color)}.inline-filters-right{display:flex;align-items:center;gap:.75rem}.sort-select-wrapper{position:relative;display:flex;align-items:center}.sort-select-icon{display:none}.sort-select{padding:.5rem .75rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.5rem;color:#e5e7eb;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;outline:none}.sort-select:hover{border-color:var(--tenant-border-color);background:var(--tenant-surface-color)}.sort-select:focus{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 50%);background:var(--tenant-surface-color)}.sort-select option{background:var(--tenant-surface-color);color:#e5e7eb}.upload-button{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.25rem;background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));border:none;border-radius:.5rem;color:#0b1120;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.upload-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px color-mix(in srgb,var(--tenant-primary-color),transparent 60%)}.upload-button:active{transform:translateY(0)}.upload-icon{font-size:1rem}.upload-label{font-size:.9rem}.upload-button-inline{padding:.5rem 1rem;font-size:.85rem}.upload-button-inline .upload-icon{font-size:.9rem}.upload-button-inline .upload-label{font-size:.85rem}.upload-buttons-group{display:flex;gap:.75rem;align-items:center}.upload-buttons-group .upload-button{padding:.5rem 1rem;font-size:.85rem;box-shadow:0 2px 8px #6366f133}.upload-buttons-group .upload-icon{font-size:.9rem}.upload-buttons-group .upload-label{font-size:.85rem}.upload-button-ai{background:linear-gradient(135deg,#a855f7,#6366f1)!important;box-shadow:0 2px 8px #a855f74d!important}.upload-button-ai:hover{box-shadow:0 4px 16px #a855f766!important}.upload-button-files{background:linear-gradient(135deg,#6366f1,#22c55e)!important}.upload-button-external{background:linear-gradient(135deg,#3b82f6,#06b6d4)!important;box-shadow:0 2px 8px #3b82f64d!important}.upload-button-external:hover{box-shadow:0 4px 16px #3b82f666!important}.sim-card-menu-container{position:absolute;top:.75rem;right:.75rem;z-index:10}.sim-card-menu-button{background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:6px;color:#9ca3af;font-size:1.25rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;padding:0;line-height:1}.sim-card-menu-button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);color:#f3f4f6;border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%)}.sim-card-menu{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:8px;box-shadow:0 10px 25px #00000080;min-width:140px;overflow:hidden;animation:menuSlideIn .15s ease-out}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:#e5e7eb;font-size:.875rem;text-align:left;cursor:pointer;transition:background .15s}.menu-item:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.menu-item-delete{color:#ef4444}.menu-item-delete:hover{background:#ef44441a}.menu-item-disabled{opacity:.5;cursor:not-allowed}.menu-item-disabled:hover{background:transparent}.menu-divider{height:1px;background:var(--tenant-border-color);margin:.25rem 0}.pagination-container{display:flex;align-items:center;gap:1rem;padding:.5rem .75rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 70%);border-radius:.5rem;border:1px solid var(--tenant-border-color)}.pagination-info{font-size:.85rem;color:#94a3b8;font-weight:500;white-space:nowrap}.pagination-controls{display:flex;align-items:center;gap:.375rem;flex-wrap:nowrap}.pagination-bottom-container{display:flex;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--tenant-border-color)}.pagination-button{padding:.4rem .75rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.375rem;color:#cbd5e1;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.pagination-button:hover:not(:disabled){background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 50%);color:#e5e7eb}.pagination-button:disabled{opacity:.4;cursor:not-allowed}.pagination-pages{display:flex;align-items:center;gap:.25rem}.pagination-page{min-width:2rem;height:2rem;padding:.375rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.375rem;color:#cbd5e1;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.pagination-page:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 50%);color:#e5e7eb}.pagination-page.active{background:var(--tenant-primary-color);border-color:var(--tenant-primary-color);color:#fff;font-weight:600}.pagination-page.active:hover{background:color-mix(in srgb,var(--tenant-primary-color),black 10%);border-color:color-mix(in srgb,var(--tenant-primary-color),black 10%)}.pagination-ellipsis{padding:0 .25rem;color:#64748b;font-weight:500;-webkit-user-select:none;user-select:none;font-size:.85rem}@media (max-width: 768px){.section-header{flex-direction:column;align-items:stretch;gap:.75rem}.section-header-left{flex-wrap:wrap;gap:.75rem}.upload-buttons-group{gap:.5rem}.upload-buttons-group .upload-button{padding:.5rem;min-width:40px}.upload-buttons-group .upload-label{display:none}.upload-buttons-group .upload-icon{margin:0}.upload-button{width:100%;justify-content:center}.inline-filters{flex-direction:row;align-items:center;gap:.5rem}.inline-search-wrapper{flex:1;min-width:0;max-width:none}.inline-filters-right{flex-shrink:0}.sort-select-wrapper{position:relative;width:2.5rem;height:2.25rem}.sort-select-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:1.1rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.5rem;pointer-events:none}.sort-select{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.sort-select option{font-size:.875rem}.pagination-container{flex-direction:column;align-items:stretch;gap:.75rem;padding:1rem}.pagination-info{text-align:center}.pagination-controls{justify-content:center;flex-wrap:wrap}.pagination-button{font-size:.8rem;padding:.5rem .75rem}.pagination-page{min-width:2.25rem;height:2.25rem}}.end-of-list{text-align:center;padding:2rem;color:#6b7280;font-size:.9rem}@media (max-width: 767px){.mobile-hamburger{display:flex}.mobile-nav-backdrop{display:block}.side-nav{position:fixed;top:0;left:0;height:100vh;height:100dvh;width:280px;z-index:1000;transform:translate(-100%);transition:transform .3s ease;box-shadow:none}.side-nav.mobile-open{transform:translate(0);box-shadow:4px 0 20px #0000004d}.side-nav .nav-label{display:inline!important}.menu-toggle{display:none}.main-area{width:100%;overflow-x:hidden}.app-shell,.content{overflow-x:hidden}.top-bar{padding:.5rem .75rem}.sim-grid{grid-template-columns:1fr}.sim-card,.skeleton-card{max-width:none}}@media (min-width: 768px) and (max-width: 1023px){.top-bar{flex-wrap:wrap;gap:.75rem}.global-search-container{order:3;flex:0 0 100%;width:100%;max-width:none;margin:0}.side-nav{width:64px}.side-nav .nav-label,.side-nav .version-text{display:none}.side-nav .menu-toggle,.side-nav .nav-item{justify-content:center;padding-left:.2rem}.side-nav.expanded{width:220px}.side-nav.expanded .nav-label,.side-nav.expanded .version-text{display:inline}.side-nav.expanded .menu-toggle,.side-nav.expanded .nav-item{justify-content:flex-start;padding-left:.7rem}.sim-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}@media (max-width: 767px) and (max-height: 500px){.side-nav{width:220px}.nav-item{padding:.4rem .5rem;font-size:.85rem}.nav-icon{font-size:1rem}.version-display{padding:.25rem .5rem;font-size:.7rem}.sim-grid{grid-template-columns:repeat(2,1fr)}.sim-card-thumbnail,.skeleton-thumbnail{height:120px}}@media (max-width: 360px){.tenant-name{display:none}.top-logo{height:36px}.logo-image{height:100%}.top-bar{padding:.375rem .5rem;gap:.5rem}.mobile-hamburger{width:34px;height:34px;font-size:1.1rem}.avatar{width:30px;height:30px;font-size:.85rem}.avatar-button{padding:.25rem}}body:has(.mobile-nav-backdrop){overflow:hidden}.auth-loading-placeholder{min-height:200px}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.auth-modal{position:relative;background:radial-gradient(circle at top left,rgba(59,130,246,.15),transparent),#0f172afa;border:1px solid rgba(148,163,184,.3);border-radius:1rem;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#94a3b8;font-size:1.5rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;transition:all .2s ease}.auth-modal-close:hover{background:#94a3b833;color:#e5e7eb}.auth-modal-header{padding:2rem 2rem 1rem;border-bottom:1px solid rgba(148,163,184,.2)}.auth-modal-header h2{margin:0;font-size:1.5rem;color:#e5e7eb;font-weight:600}.auth-modal-body{padding:2rem}.auth-error{padding:.75rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#fca5a5;font-size:.875rem;margin-bottom:1rem}.auth-success{padding:.75rem 1rem;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:.5rem;color:#86efac;font-size:.875rem;margin-bottom:1rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;color:#cbd5e1;font-weight:500}.form-group input{padding:.75rem 1rem;background:#0f172a99;border:1px solid rgba(148,163,184,.3);border-radius:.5rem;color:#e5e7eb;font-size:.95rem;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#6366f199;background:#0f172acc;box-shadow:0 0 0 3px #6366f11a}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group input::placeholder{color:#64748b}.auth-submit-button{padding:.875rem 1.5rem;background:linear-gradient(135deg,#6366f1,#22c55e);border:none;border-radius:.5rem;color:#0b1120;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.auth-submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.auth-submit-button:active:not(:disabled){transform:translateY(0)}.auth-submit-button:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:#64748b;font-size:.875rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#94a3b833}.google-sign-in-button{width:100%;padding:.875rem 1.5rem;background:#fffffff2;border:1px solid rgba(148,163,184,.3);border-radius:.5rem;color:#0f172a;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .2s ease}.google-sign-in-button:hover:not(:disabled){background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.google-sign-in-button:active:not(:disabled){transform:translateY(0)}.google-sign-in-button:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(148,163,184,.2);display:flex;flex-direction:column;gap:.5rem;align-items:center}.auth-link{background:transparent;border:none;color:#60a5fa;font-size:.875rem;cursor:pointer;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:#93c5fd;text-decoration:underline}@media (max-width: 480px){.auth-modal{max-width:100%;border-radius:0;max-height:100vh}.auth-modal-header,.auth-modal-body{padding:1.5rem}}.upload-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;overflow-y:auto}.upload-container{background:radial-gradient(circle at top left,color-mix(in srgb,var(--tenant-primary-color),transparent 85%),transparent),color-mix(in srgb,var(--tenant-background-color),transparent 2%);border:1px solid var(--tenant-border-color);border-radius:1rem;width:100%;max-width:1800px;max-height:95vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.upload-header{display:flex;align-items:center;justify-content:space-between;padding:.625rem 1rem;border-bottom:1px solid var(--tenant-border-color);background:var(--tenant-sidebar-color)}.upload-header h2{margin:0;font-size:1.15rem;color:#e5e7eb;font-weight:600}.upload-close{background:transparent;border:none;color:#94a3b8;font-size:1.15rem;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.upload-close:hover{background:var(--tenant-surface-color);color:#e5e7eb}.upload-progress{display:flex;justify-content:space-between;padding:.5rem 1rem .4rem;border-bottom:1px solid var(--tenant-border-color);background:color-mix(in srgb,var(--tenant-sidebar-color),transparent 50%);position:relative}.upload-progress:before{content:"";position:absolute;top:50%;left:1rem;right:1rem;height:1px;background:var(--tenant-border-color);z-index:0}.progress-step{display:flex;flex-direction:column;align-items:center;gap:.2rem;position:relative;z-index:1;flex:1}.progress-circle{width:22px;height:22px;border-radius:50%;background:var(--tenant-sidebar-color);border:1.5px solid var(--tenant-border-color);display:flex;align-items:center;justify-content:center;font-weight:600;color:#94a3b8;font-size:.7rem;transition:all .3s ease}.progress-step.active .progress-circle{border-color:var(--tenant-primary-color);background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));color:#0b1120}.progress-step.completed .progress-circle{border-color:var(--tenant-secondary-color);background:var(--tenant-secondary-color);color:#0b1120}.progress-label{font-size:.6rem;color:#64748b;text-transform:capitalize;white-space:nowrap}.progress-step.active .progress-label{color:#e5e7eb;font-weight:500}.upload-content{flex:1;overflow-y:auto;padding:.625rem .875rem}.upload-step{display:flex;flex-direction:column;gap:.5rem;min-height:300px}.step-description{color:#94a3b8;font-size:.85rem;line-height:1.5;margin:0 0 .5rem}.drop-zone{border:2px dashed var(--tenant-border-color);border-radius:.75rem;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:color-mix(in srgb,var(--tenant-background-color),transparent 50%)}.drop-zone:hover{border-color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.drop-zone.dragging{border-color:var(--tenant-secondary-color);background:color-mix(in srgb,var(--tenant-secondary-color),transparent 90%)}.drop-zone-content{pointer-events:none}.drop-zone-icon{font-size:3rem;margin-bottom:1rem}.drop-zone-text{font-size:1.1rem;color:#e5e7eb;margin:0 0 .5rem;font-weight:500}.drop-zone-hint{font-size:.875rem;color:#94a3b8;margin:.25rem 0 1rem}.drop-zone-buttons{display:flex;gap:.75rem;justify-content:center;pointer-events:auto}.browse-button{padding:.75rem 1.5rem;background:color-mix(in srgb,var(--tenant-primary-color),transparent 70%);border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 40%);border-radius:.5rem;color:#e5e7eb;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.browse-button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 50%);border-color:var(--tenant-primary-color);transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.file-list{background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;padding:1.5rem}.file-list-title{font-size:.95rem;color:#cbd5e1;margin:0 0 1rem;font-weight:500}.file-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--tenant-sidebar-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;margin-bottom:.75rem;transition:all .2s ease}.file-item:last-child{margin-bottom:0}.file-item:hover{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.file-icon{font-size:1.5rem;flex-shrink:0}.file-details{flex:1;min-width:0}.file-key-input{width:100%;background:transparent;border:none;color:#e5e7eb;font-size:.95rem;padding:.25rem 0;font-family:Monaco,Consolas,monospace}.file-key-input:focus{outline:none;border-bottom:1px solid var(--tenant-primary-color)}.file-meta{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;font-size:.8rem;color:#94a3b8}.file-size{color:#94a3b8}.file-separator{color:#64748b}.file-type-select{background:var(--tenant-sidebar-color);border:1px solid var(--tenant-border-color);color:#e5e7eb;padding:.25rem .5rem;border-radius:.25rem;font-size:.8rem;cursor:pointer}.file-type-select:hover{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.file-remove{background:transparent;border:none;color:#94a3b8;cursor:pointer;width:28px;height:28px;border-radius:.25rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.file-remove:hover{background:#ef444433;color:#ef4444}.metadata-form{display:flex;flex-direction:column;gap:.5rem}.form-group{display:flex;flex-direction:column;gap:.15rem}.form-label{font-size:.75rem;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.02em}.label-hint{font-weight:400;color:#64748b;font-size:.75rem;text-transform:none;letter-spacing:normal}.form-input,.form-textarea{padding:.4rem .65rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:5px;color:#e5e7eb;font-size:.85rem;transition:all .2s ease;font-family:inherit}.form-input:focus,.form-textarea:focus{outline:none;border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 40%);background:var(--tenant-sidebar-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.form-input.error,.form-textarea.error{border-color:#ef444499}.form-textarea{resize:vertical;min-height:60px}.form-error{color:#fca5a5;font-size:.7rem;margin-top:1px}.form-hint{color:#64748b;font-size:.65rem;text-align:right;margin-top:1px}.tag-input-container{background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:5px;padding:.25rem .4rem;transition:all .2s ease}.tag-input-container:focus-within{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 40%);background:var(--tenant-sidebar-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.tag-list{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}.tag{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;background:linear-gradient(135deg,color-mix(in srgb,var(--tenant-primary-color),transparent 80%),color-mix(in srgb,var(--tenant-secondary-color),transparent 80%));border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 70%);border-radius:999px;color:#e5e7eb;font-size:.75rem;font-weight:500}.tag-remove{background:transparent;border:none;color:#94a3b8;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.tag-remove:hover{background:#ef44444d;color:#ef4444}.tag-input{border:none;background:transparent;color:#e5e7eb;font-size:.75rem;padding:.15rem .25rem;flex:1;min-width:120px;outline:none}.tag-input::placeholder{color:#64748b}.tag-suggestions{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;margin-top:.35rem}.suggestions-label{font-size:.65rem;color:#64748b;margin-right:.15rem}.suggestion-tag{padding:.1rem .4rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:999px;color:#94a3b8;font-size:.7rem;cursor:pointer;transition:all .2s ease}.suggestion-tag:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 70%);border-color:var(--tenant-primary-color);color:#e5e7eb}.visibility-group{margin-top:0}.visibility-group>.form-label{margin-bottom:.2rem}.visibility-toggle{display:inline-flex;position:relative;background:#00000040;border-radius:6px;padding:2px;gap:0}.visibility-toggle-option{position:relative;display:flex;align-items:center;justify-content:center;gap:5px;padding:5px 14px;background:transparent;border:none;border-radius:4px;color:#64748b;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;z-index:1}.visibility-toggle-option:hover:not(.active){color:#94a3b8}.visibility-toggle-option.active{background:var(--tenant-surface-color);color:#e5e7eb;box-shadow:0 1px 3px #0003,0 0 0 1px #ffffff0d}.visibility-toggle-option.active .toggle-icon{transform:scale(1.1)}.toggle-icon{font-size:.8rem;transition:transform .15s ease;line-height:1}.toggle-label{font-weight:500;letter-spacing:.01em}.visibility-hint{font-size:.65rem;color:#4b5563;margin-top:.2rem;font-style:italic}.thumbnail-step{display:flex;flex-direction:column;gap:1.5rem}.thumbnail-upload{border:2px dashed var(--tenant-border-color);border-radius:.75rem;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:color-mix(in srgb,var(--tenant-background-color),transparent 50%)}.thumbnail-upload:hover{border-color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.thumbnail-upload-content{pointer-events:none}.thumbnail-icon{font-size:3rem;margin-bottom:1rem}.thumbnail-text{font-size:1.1rem;color:#e5e7eb;margin:0 0 .5rem;font-weight:500}.thumbnail-hint{font-size:.875rem;color:#94a3b8;margin:.25rem 0}.thumbnail-preview{width:100%;max-width:600px;border-radius:.75rem;overflow:hidden;border:1px solid var(--tenant-border-color)}.thumbnail-tips{background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;padding:1.25rem}.tips-title{font-size:.95rem;color:#cbd5e1;margin:0 0 .75rem;font-weight:500}.tips-list{margin:0;padding-left:1.5rem;color:#94a3b8;font-size:.9rem;line-height:1.8}.preview-card{background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;overflow:hidden}.preview-thumbnail{width:100%;aspect-ratio:16/9;overflow:hidden;background:#0000004d}.preview-thumbnail img{width:100%;height:100%;object-fit:cover}.preview-metadata{padding:1.5rem}.preview-title{font-size:1.5rem;color:#e5e7eb;margin:0 0 .75rem;font-weight:600}.preview-description{color:#cbd5e1;font-size:.95rem;line-height:1.6;margin:0 0 1rem}.preview-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.preview-tag{padding:.4rem .75rem;background:linear-gradient(135deg,color-mix(in srgb,var(--tenant-primary-color),transparent 80%),color-mix(in srgb,var(--tenant-secondary-color),transparent 80%));border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 70%);border-radius:999px;color:#e5e7eb;font-size:.85rem}.visibility-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 70%);border-radius:.5rem;color:#e5e7eb;font-size:.9rem;font-weight:500}.preview-section{background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;padding:1.25rem}.preview-section-title{font-size:.95rem;color:#cbd5e1;margin:0 0 1rem;font-weight:500}.preview-files{display:flex;flex-direction:column;gap:.5rem}.preview-file{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--tenant-sidebar-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;font-size:.9rem}.preview-file-icon{font-size:1.2rem}.preview-file-name{flex:1;color:#e5e7eb;font-family:Monaco,Consolas,monospace}.preview-file-type{padding:.25rem .5rem;background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);border-radius:.25rem;color:#cbd5e1;font-size:.75rem;text-transform:uppercase}.preview-file-size{color:#94a3b8;font-size:.85rem}.preview-total-size{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--tenant-border-color);color:#cbd5e1;font-size:.9rem;text-align:right}.preview-info{display:flex;gap:1rem;padding:1.25rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:.75rem}.info-icon{font-size:1.5rem;flex-shrink:0}.info-content{flex:1}.info-title{font-size:.95rem;color:#e5e7eb;margin:0 0 .5rem;font-weight:600}.info-list{margin:0;padding-left:1.25rem;color:#cbd5e1;font-size:.9rem;line-height:1.8}.publish-step{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;min-height:400px}.publish-mode-selection{padding:2rem}.publish-options{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:500px}.publish-option-card{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:2px solid var(--tenant-border-color);border-radius:.75rem;cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.publish-option-card:hover{border-color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%);transform:translateY(-2px);box-shadow:0 4px 12px color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.publish-option-card .option-icon{font-size:2rem;flex-shrink:0}.publish-option-card .option-text{flex:1}.publish-option-card .option-title{font-size:1.1rem;color:#e5e7eb;font-weight:600;margin-bottom:.25rem}.publish-option-card .option-description{font-size:.875rem;color:#94a3b8;line-height:1.5}.publish-mode-selection .status-subtitle strong{color:var(--tenant-primary-color)}.publish-status{text-align:center}.status-icon{font-size:4rem;margin-bottom:1rem}.status-title{font-size:1.5rem;color:#e5e7eb;margin:0 0 .5rem;font-weight:600}.status-subtitle{color:#94a3b8;font-size:.95rem;margin:0}.progress-container{width:100%;max-width:400px;text-align:center}.progress-bar{width:100%;height:8px;background:var(--tenant-border-color);border-radius:999px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,var(--tenant-primary-color),var(--tenant-secondary-color));border-radius:999px;transition:width .3s ease}.progress-text{font-size:.9rem;color:#cbd5e1;font-weight:600}.success-message,.error-message{text-align:center;padding:1.5rem;border-radius:.75rem}.success-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac}.success-hint{font-size:.9rem;color:#94a3b8;margin-top:.5rem}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.publish-info{display:flex;gap:2rem;justify-content:center}.info-item{display:flex;flex-direction:column;gap:.25rem;text-align:center}.info-label{font-size:.8rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:1.1rem;color:#e5e7eb;font-weight:600}.uploading-notice{text-align:center;color:#94a3b8;font-size:.9rem;margin:0}.upload-actions{display:flex;justify-content:flex-end;gap:.5rem;padding:.75rem 1rem;border-top:1px solid var(--tenant-border-color);margin-top:auto}.btn-primary,.btn-secondary,.btn-text,.btn-sm{padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));color:#0b1120}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px color-mix(in srgb,var(--tenant-primary-color),transparent 60%)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--tenant-surface-color);color:#e5e7eb;border:1px solid var(--tenant-border-color)}.btn-secondary:hover{background:color-mix(in srgb,var(--tenant-surface-color),white 5%);border-color:color-mix(in srgb,var(--tenant-border-color),white 10%)}.btn-text{background:transparent;color:#94a3b8}.btn-text:hover{color:#e5e7eb;background:var(--tenant-surface-color)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.upload-error{padding:.75rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:#fca5a5;font-size:.875rem}@media (max-width: 768px){.upload-overlay{padding:0}.upload-container{max-width:100%;max-height:100%;height:100%;border-radius:0;display:flex;flex-direction:column}.upload-header{padding:.75rem 1rem;flex-shrink:0}.upload-header h2{font-size:1.1rem}.upload-content{padding:0;flex:1;overflow-y:auto;overflow-x:hidden}.upload-step{padding:.75rem 1rem;gap:.75rem;min-height:auto}.metadata-form{gap:.875rem}.form-group{gap:.25rem}.form-label{font-size:.85rem}.label-hint{display:none}.form-input,.form-textarea{font-size:16px;padding:.625rem .75rem}.form-textarea{min-height:80px}.form-hint{font-size:.7rem;margin-top:.125rem}.visibility-toggle{width:100%;display:flex}.visibility-toggle-option{flex:1;justify-content:center;padding:8px 12px}.visibility-hint{font-size:.65rem}.upload-actions{display:flex;flex-direction:row;gap:.5rem;padding:.625rem 1rem;flex-shrink:0;background:var(--tenant-sidebar-color);border-top:1px solid var(--tenant-border-color);position:sticky;bottom:0;z-index:10}.upload-actions .btn-primary,.upload-actions .btn-secondary{flex:1;padding:.625rem .875rem;font-size:.9rem}.upload-progress{padding:.75rem .5rem .5rem;flex-shrink:0}.progress-step{flex:0 1 auto}.progress-label{font-size:.65rem;display:none}.progress-circle{width:24px;height:24px;font-size:.7rem}.tag-input{min-width:100px}.tag-input-container{padding:.5rem}.tag-list{gap:.375rem}.tag{font-size:.8rem;padding:.25rem .5rem}.tag-suggestions{flex-wrap:wrap;gap:.375rem}.suggestion-tag{font-size:.8rem;padding:.25rem .5rem}.upload-confirm-dialog{width:95%;max-width:360px}.generate-metadata-section{padding:.5rem .625rem;margin-bottom:0;border-radius:8px;display:flex;align-items:center;gap:.5rem;text-align:left}.btn-generate-metadata{padding:.5rem .75rem;font-size:.8rem;flex-shrink:0;white-space:nowrap}.generate-hint{font-size:.7rem;margin:0;line-height:1.3}}.preview-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;color:#94a3b8}.loading-spinner{width:48px;height:48px;border:4px solid var(--tenant-border-color);border-top-color:var(--tenant-primary-color);border-radius:50%;animation:spin 1s linear infinite}.preview-error{text-align:center;padding:3rem 2rem;color:#cbd5e1}.error-icon{font-size:3rem;margin-bottom:1rem}.preview-error h3{margin:0 0 .5rem;color:#e5e7eb;font-size:1.25rem}.preview-error p{margin:.5rem 0;color:#94a3b8}.error-hint{font-size:.875rem;color:#64748b;margin-top:1rem!important}.step-header{margin-bottom:1.5rem}.step-header h2{margin:0 0 .5rem;font-size:1.5rem;color:#e5e7eb;font-weight:600}.simulation-preview-section{margin-bottom:2rem}.simulation-preview-container{background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.5rem;overflow:hidden;margin-bottom:1rem}.simulation-frame{position:relative;width:100%;padding-bottom:75%;background:#000}.preview-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;background:#fff}.capture-controls{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem 0}.btn-capture{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:.875rem 2rem;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #3b82f64d}.btn-capture:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.btn-capture:disabled{opacity:.6;cursor:not-allowed;transform:none}.capture-hint{margin:0;font-size:.875rem;color:#94a3b8;text-align:center}.thumbnail-preview-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--tenant-border-color)}.thumbnail-preview-section h3{margin:0 0 1rem;font-size:1.125rem;color:#e5e7eb;font-weight:600}.thumbnail-preview-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.thumbnail-preview{max-width:400px;width:100%;border-radius:.5rem;overflow:hidden;border:2px solid var(--tenant-border-color);background:var(--tenant-sidebar-color)}.thumbnail-preview img{width:100%;height:auto;display:block}.thumbnail-actions{display:flex;gap:.75rem}.btn-recapture{margin-top:.5rem}.thumbnail-required-notice{margin-top:1rem;padding:.875rem 1.25rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:.5rem;text-align:center;font-size:.875rem;color:#93c5fd}@media (max-width: 768px){.simulation-frame{padding-bottom:56.25%}.btn-capture{width:100%;padding:1rem}.thumbnail-preview{max-width:100%}.step-header h2{font-size:1.25rem}}.preview-step-loading,.preview-step-error{text-align:center;padding:3rem 2rem}.preview-step-loading .loading-spinner{font-size:3rem;margin-bottom:1rem}.preview-step-loading p,.preview-step-error p{color:#94a3b8;margin:.5rem 0}.preview-step{display:flex;flex-direction:column;gap:1.5rem}.simulation-preview-iframe{width:100%;height:600px;border:none;border-radius:.5rem;background:#000}.simulation-preview-loading{display:flex;align-items:center;justify-content:center;height:600px;color:#94a3b8;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border-radius:.5rem}.thumbnail-capture-section{background:color-mix(in srgb,var(--tenant-background-color),transparent 60%);border:1px solid var(--tenant-border-color);border-radius:.5rem;padding:1.5rem;text-align:center}.thumbnail-capture-section h4{margin:0 0 .5rem;color:#e5e7eb;font-size:1.125rem}.thumbnail-capture-section .capture-hint{margin-bottom:1rem;color:#94a3b8;font-size:.875rem}.thumbnail-preview-result{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--tenant-border-color)}.thumbnail-preview-result .success-message{color:#10b981;font-weight:600;margin-bottom:1rem}.thumbnail-preview-img{max-width:400px;width:100%;border-radius:.5rem;border:2px solid var(--tenant-border-color)}.preview-info-box{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:.5rem;padding:1rem;text-align:center}.preview-info-box p{margin:0;color:#93c5fd;font-size:.875rem}@media (max-width: 768px){.simulation-preview-iframe{height:400px}.thumbnail-preview-img{max-width:100%}}.type-selection-step{display:flex;flex-direction:column;gap:2rem;padding:2rem 0}.type-options{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.type-option-card{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem 2rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:2px solid var(--tenant-border-color);border-radius:1rem;cursor:pointer;transition:all .3s ease;text-align:center}.type-option-card:hover{border-color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);transform:translateY(-4px);box-shadow:0 8px 24px color-mix(in srgb,var(--tenant-primary-color),transparent 60%)}.type-icon{font-size:3.5rem;opacity:.9}.type-option-card h3{margin:0;font-size:1.25rem;color:#e5e7eb;font-weight:600}.type-option-card p{margin:0;font-size:.9rem;color:#94a3b8;line-height:1.5}.type-option-ai{background:linear-gradient(135deg,color-mix(in srgb,var(--tenant-primary-color),transparent 85%),color-mix(in srgb,#a855f7,transparent 85%));border-color:color-mix(in srgb,#a855f7,transparent 60%)}.type-option-ai:hover{border-color:#a855f7;background:linear-gradient(135deg,color-mix(in srgb,var(--tenant-primary-color),transparent 75%),color-mix(in srgb,#a855f7,transparent 75%));box-shadow:0 8px 24px color-mix(in srgb,#a855f7,transparent 70%)}.type-option-ai .type-icon{animation:sparkle 2s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.1);opacity:1}}.external-url-step{display:flex;flex-direction:column;gap:2rem}.url-input-section{display:flex;flex-direction:column;gap:1rem}.url-input-section label{font-size:.95rem;color:#cbd5e1;font-weight:500}.url-input-section input[type=url]{padding:.875rem 1rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:2px solid var(--tenant-border-color);border-radius:.5rem;color:#e5e7eb;font-size:1rem;transition:all .2s ease;font-family:Monaco,Consolas,monospace}.url-input-section input[type=url]:focus{outline:none;border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 40%);background:var(--tenant-sidebar-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}.url-input-section input[type=url].input-error{border-color:#ef444499}.error-message{color:#fca5a5;font-size:.875rem;margin-top:-.5rem;padding:.5rem .75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:.375rem}.url-examples{background:color-mix(in srgb,var(--tenant-background-color),transparent 60%);border:1px solid var(--tenant-border-color);border-radius:.5rem;padding:1rem}.examples-title{margin:0 0 .5rem;font-size:.875rem;color:#cbd5e1;font-weight:500}.url-examples ul{margin:0;padding-left:1.5rem;color:#94a3b8;font-size:.875rem;line-height:1.8}.url-examples li{font-family:Monaco,Consolas,monospace}.url-note{padding:.875rem 1rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:.5rem;font-size:.875rem;color:#93c5fd;line-height:1.6}.url-note strong{color:#60a5fa}@media (max-width: 768px){.type-options{grid-template-columns:1fr}.type-option-card{padding:2rem 1.5rem}}.generate-metadata-section{background:linear-gradient(135deg,#8b5cf614,#3b82f614);border:1px solid rgba(139,92,246,.2);border-radius:6px;padding:.5rem .75rem;margin-bottom:.25rem;display:flex;align-items:center;gap:.5rem}.btn-generate-metadata{display:inline-flex;align-items:center;gap:.35rem;padding:.375rem .75rem;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;border-radius:5px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #8b5cf640;white-space:nowrap}.btn-generate-metadata:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#4f46e5);transform:translateY(-1px);box-shadow:0 4px 10px #8b5cf659}.btn-generate-metadata:disabled{opacity:.7;cursor:not-allowed}.generate-hint{color:#6b7280;font-size:.75rem;margin:0;line-height:1.3}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .8s linear infinite}.upload-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .15s ease}.upload-confirm-dialog{background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.75rem;padding:1.5rem;max-width:400px;width:90%;box-shadow:0 20px 60px #00000080;animation:scaleIn .15s ease}.upload-confirm-dialog h3{margin:0 0 .75rem;color:#e5e7eb;font-size:1.25rem;font-weight:600}.upload-confirm-dialog p{margin:0 0 1.5rem;color:#9ca3af;font-size:.875rem;line-height:1.5}.upload-confirm-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.ai-generation-container{display:flex;flex-direction:column;height:100%;width:100%;min-height:70vh;max-height:70vh;overflow:hidden}.ai-split-layout{display:flex;flex:1;gap:0;overflow:hidden;min-height:0;max-height:100%}.ai-separator{width:4px;background:var(--tenant-border-color);cursor:col-resize;transition:background .2s;flex-shrink:0}.ai-separator:hover{background:var(--tenant-primary-color)}.ai-chat-panel{flex:0 0 40%;display:flex;flex-direction:column;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;overflow:hidden;min-height:0}.ai-chat-header{padding:.5rem .75rem;border-bottom:1px solid var(--tenant-border-color);background:var(--tenant-sidebar-color)}.ai-chat-title{display:flex;align-items:center;gap:.5rem}.ai-chat-title h3{margin:0;font-size:1rem;font-weight:600;color:#e2e8f0}.ai-icon{font-size:1.25rem}.ai-chat-messages{flex:1;overflow-y:auto;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.5rem;min-height:0}.ai-chat-messages::-webkit-scrollbar{width:8px}.ai-chat-messages::-webkit-scrollbar-track{background:color-mix(in srgb,var(--tenant-sidebar-color),transparent 60%);border-radius:4px}.ai-chat-messages::-webkit-scrollbar-thumb{background:var(--tenant-border-color);border-radius:4px}.ai-chat-messages::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--tenant-border-color),white 20%)}.ai-message{display:flex;gap:.5rem;animation:fadeIn .3s ease-in}.ai-message-avatar{font-size:1.5rem;flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.ai-message-content{flex:1;display:flex;flex-direction:column;gap:.25rem;overflow-x:hidden;min-width:0}.ai-message-text{background:var(--tenant-surface-color);padding:.5rem .75rem;border-radius:.5rem;color:#e2e8f0;line-height:1.4;word-wrap:break-word}.ai-message-assistant .ai-message-text{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.ai-message-user .ai-message-text{background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color)}.ai-message-time{font-size:.75rem;color:#94a3b8;padding:0 .5rem}.ai-streaming-wrapper{position:relative;overflow:hidden;max-width:100%;min-width:0;padding-right:.25rem;mask-image:linear-gradient(to right,transparent 0%,black 90px,black 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 90px,black 100%)}.ai-streaming{display:inline-block;font-style:italic;color:#cbd5e1;opacity:.9;animation:streamFadeIn .2s ease-in;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,Courier New,monospace;font-size:.9rem;letter-spacing:.02em;white-space:nowrap;transition:transform .25s ease-out;will-change:transform}.ai-streaming-cursor{display:inline-block;margin-left:4px;color:var(--tenant-primary-color);animation:streamingCursor 1s infinite}@keyframes streamFadeIn{0%{opacity:0}to{opacity:.9}}@keyframes streamingCursor{0%,to{opacity:1}50%{opacity:.2}}.ai-thinking{display:flex;gap:.5rem;align-items:center;padding:1rem}.ai-thinking-dot{width:8px;height:8px;background:var(--tenant-primary-color);border-radius:50%;animation:thinkingBounce 1.4s infinite ease-in-out both}.ai-thinking-dot:nth-child(1){animation-delay:-.32s}.ai-thinking-dot:nth-child(2){animation-delay:-.16s}@keyframes thinkingBounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.ai-suggestions-dropdown{position:relative}.ai-suggestions-button{width:38px;height:38px;background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border:1px solid color-mix(in srgb,var(--tenant-primary-color),transparent 70%);border-radius:.5rem;color:var(--tenant-primary-color);font-size:1.1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-suggestions-button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);border-color:var(--tenant-primary-color);transform:translateY(-1px);box-shadow:0 4px 12px color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.ai-suggestions-menu{position:absolute;bottom:100%;left:0;margin-bottom:.5rem;background:var(--tenant-sidebar-color);border:1px solid var(--tenant-border-color);border-radius:.75rem;min-width:400px;max-width:500px;max-height:350px;overflow-y:auto;overflow-x:hidden;box-shadow:0 8px 24px #0006;z-index:9999;animation:slideUp .2s ease-out}.ai-suggestions-header{position:sticky;top:0;background:linear-gradient(135deg,var(--tenant-surface-color),var(--tenant-sidebar-color));border-bottom:1px solid var(--tenant-border-color);padding:.625rem 1rem;display:flex;justify-content:space-between;align-items:center;z-index:1}.ai-suggestions-header-title{font-size:.8rem;font-weight:600;color:#e2e8f0}.ai-suggestions-header-hint{font-size:.7rem;color:#64748b;display:flex;align-items:center;gap:.25rem}.ai-suggestions-header-hint:before{content:"↕";font-size:.85rem}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ai-suggestions-menu::-webkit-scrollbar{width:6px}.ai-suggestions-menu::-webkit-scrollbar-track{background:color-mix(in srgb,var(--tenant-sidebar-color),transparent 60%);border-radius:3px}.ai-suggestions-menu::-webkit-scrollbar-thumb{background:var(--tenant-border-color);border-radius:3px}.ai-suggestion-item{width:100%;padding:.75rem 1rem;background:transparent;border:none;border-bottom:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 70%);color:#e2e8f0;font-size:.875rem;text-align:left;cursor:pointer;transition:all .2s;line-height:1.4}.ai-suggestion-item:last-child{border-bottom:none}.ai-suggestion-item:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);color:#fff}.ai-chat-input{display:flex;gap:.5rem;padding:.5rem .75rem;border-top:1px solid var(--tenant-border-color);background:var(--tenant-sidebar-color)}.ai-input-field{flex:1;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;padding:.5rem .75rem;color:#e2e8f0;font-size:.95rem;font-family:inherit;resize:none;min-height:38px;max-height:120px;transition:border-color .2s}.ai-input-field:focus{outline:none;border-color:var(--tenant-primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.ai-input-field:disabled{opacity:.5;cursor:not-allowed}.ai-input-field::placeholder{color:#64748b}.ai-send-button{width:38px;height:38px;background:linear-gradient(135deg,var(--tenant-primary-color),color-mix(in srgb,var(--tenant-primary-color),black 20%));border:none;border-radius:.5rem;color:#fff;font-size:1.25rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px color-mix(in srgb,var(--tenant-primary-color),transparent 60%)}.ai-send-button:disabled{opacity:.4;cursor:not-allowed}.ai-preview-panel{flex:0 0 60%;display:flex;flex-direction:column;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;overflow:hidden;min-height:0}.ai-preview-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-bottom:1px solid var(--tenant-border-color);background:var(--tenant-sidebar-color)}.ai-preview-title{display:flex;align-items:center;gap:.5rem}.ai-preview-title h3{margin:0;font-size:1rem;font-weight:600;color:#e2e8f0}.ai-refresh-button{width:36px;height:36px;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;color:#94a3b8;font-size:1.25rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.ai-refresh-button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);color:#e2e8f0;transform:rotate(180deg)}.ai-preview-content{flex:1;position:relative;background:var(--tenant-background-color);overflow:hidden}.ai-preview-iframe{width:100%;height:100%;border:none;background:#fff}.ai-preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;text-align:center;padding:2rem}.ai-preview-empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.ai-preview-empty p{margin:.5rem 0;font-size:1rem}.ai-preview-empty-hint{font-size:.875rem;opacity:.7}.ai-footer{display:flex;justify-content:flex-end;padding:1rem 0 0;margin-top:1rem;border-top:1px solid var(--tenant-border-color)}.ai-footer-right{display:flex;gap:.75rem}.ai-footer-button{padding:.75rem 1.5rem;border:1px solid var(--tenant-border-color);border-radius:.5rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--tenant-surface-color);color:#e2e8f0}.ai-footer-button:hover:not(:disabled){background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);transform:translateY(-1px)}.ai-footer-button:disabled{opacity:.4;cursor:not-allowed}.ai-save-draft{color:#fbbf24;border-color:#fbbf244d}.ai-save-draft:hover:not(:disabled){background:#fbbf2426;border-color:#fbbf2480}.ai-save-publish{background:linear-gradient(135deg,var(--tenant-secondary-color),color-mix(in srgb,var(--tenant-secondary-color),black 20%));border-color:color-mix(in srgb,var(--tenant-secondary-color),transparent 50%);color:#fff}.ai-save-publish:hover:not(:disabled){box-shadow:0 6px 16px color-mix(in srgb,var(--tenant-secondary-color),transparent 50%);transform:translateY(-2px)}.ai-back{background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%)}@media (max-width: 1024px){.ai-split-layout{flex-direction:column}.ai-chat-panel,.ai-preview-panel{flex:1 1 50%}}.ai-mobile-tabs{display:flex;gap:.5rem;padding:.5rem .75rem;background:var(--tenant-sidebar-color);border-bottom:1px solid var(--tenant-border-color)}.ai-mobile-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;color:#94a3b8;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.ai-mobile-tab:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%);border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 70%);color:#e2e8f0}.ai-mobile-tab.active{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);border-color:var(--tenant-primary-color);color:#fff}.ai-tab-icon{font-size:1.1rem}.ai-tab-label{font-weight:500}.ai-tab-badge{position:absolute;top:.375rem;right:.375rem;width:8px;height:8px;background:var(--tenant-secondary-color);border-radius:50%;animation:badgePulse 1.5s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.ai-chat-panel.hidden,.ai-preview-panel.hidden{display:none}@media (max-width: 1023px){.ai-generation-container.mobile{max-height:calc(100vh - 120px)}.ai-generation-container.mobile .ai-split-layout{flex-direction:column}.ai-generation-container.mobile .ai-chat-panel,.ai-generation-container.mobile .ai-preview-panel{flex:1;min-height:0;border-radius:0}.ai-generation-container.mobile .ai-chat-header,.ai-generation-container.mobile .ai-preview-header{display:none}.ai-footer{flex-direction:row;gap:.5rem;padding:.625rem 1rem;background:var(--tenant-sidebar-color);border-top:1px solid var(--tenant-border-color)}.ai-footer-right{width:100%;display:flex;gap:.5rem}.ai-footer-button{flex:1;padding:.625rem .875rem;font-size:.9rem}.ai-footer-button{border-radius:.5rem;font-weight:600}.ai-footer-button.ai-back{background:var(--tenant-surface-color);color:#e5e7eb;border:1px solid var(--tenant-border-color)}.ai-footer-button.ai-back:hover{background:color-mix(in srgb,var(--tenant-surface-color),white 5%);border-color:color-mix(in srgb,var(--tenant-border-color),white 10%)}.ai-footer-button.ai-save-publish{background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color))!important;color:#0b1120!important;border:none!important;box-shadow:none}.ai-footer-button.ai-save-publish:hover:not(:disabled){background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color))!important;transform:translateY(-2px);box-shadow:0 8px 20px color-mix(in srgb,var(--tenant-primary-color),transparent 60%)!important}.ai-footer-button.ai-save-publish:disabled{opacity:.5}.ai-input-field{min-height:48px;font-size:16px}.ai-send-button,.ai-suggestions-button{width:48px;height:48px}.ai-suggestions-menu{position:fixed;left:1rem;right:1rem;min-width:auto;max-width:none;width:auto;transform:none;bottom:190px;max-height:38vh}}@media (max-width: 768px) and (orientation: landscape){.ai-generation-container.mobile{max-height:calc(100vh - 80px)}.ai-mobile-tabs{padding:.375rem .5rem}.ai-mobile-tab{padding:.5rem .75rem;font-size:.85rem}.ai-footer{padding:.5rem .75rem}.ai-footer-button{padding:.5rem .625rem;font-size:.85rem}.ai-suggestions-menu{bottom:120px;max-height:35vh}}.ai-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:400px;gap:1rem}.ai-loading-spinner{width:50px;height:50px;border:4px solid var(--tenant-border-color);border-top-color:var(--tenant-primary-color);border-radius:50%;animation:ai-spin .8s linear infinite}@keyframes ai-spin{to{transform:rotate(360deg)}}.ai-loading p{color:#94a3b8;font-size:.95rem}.ai-confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:ai-fade-in .2s ease-out}@keyframes ai-fade-in{0%{opacity:0}to{opacity:1}}.ai-confirm-dialog{background:linear-gradient(135deg,var(--tenant-surface-color),var(--tenant-sidebar-color));border:1px solid var(--tenant-border-color);border-radius:1rem;padding:2rem;max-width:450px;width:90%;box-shadow:0 20px 60px #00000080;animation:ai-slide-up .3s ease-out}@keyframes ai-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.ai-confirm-dialog h3{margin:0 0 1rem;color:#e5e7eb;font-size:1.5rem;font-weight:600}.ai-confirm-dialog p{margin:0 0 1.5rem;color:#94a3b8;line-height:1.6}.ai-confirm-actions{display:flex;gap:1rem;justify-content:flex-end}.ai-confirm-button{padding:.625rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent;font-size:.95rem}.ai-confirm-no{background:var(--tenant-surface-color);color:#e5e7eb;border-color:var(--tenant-border-color)}.ai-confirm-no:hover{background:color-mix(in srgb,var(--tenant-surface-color),white 10%);border-color:color-mix(in srgb,var(--tenant-border-color),white 20%)}.ai-confirm-yes{background:#ef444433;color:#fca5a5;border-color:#ef444466}.ai-confirm-yes:hover{background:#ef44444d;border-color:#ef444499}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-delete-modal{background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:12px;padding:0;max-width:450px;width:90%;box-shadow:0 20px 25px -5px #00000080;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:1.5rem;border-bottom:1px solid var(--tenant-border-color)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#ef4444}.modal-body{padding:1.5rem}.simulation-title{font-size:1rem;font-weight:500;color:#f3f4f6;margin:0 0 1rem}.warning-text{color:#9ca3af;font-size:.875rem;margin:0;line-height:1.5}.modal-actions{padding:1rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid #374151}.btn-cancel,.btn-delete{padding:.5rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background:#374151;color:#f3f4f6}.btn-cancel:hover:not(:disabled){background:#4b5563}.btn-delete{background:#ef4444;color:#fff}.btn-delete:hover:not(:disabled){background:#dc2626}.btn-cancel:disabled,.btn-delete:disabled{opacity:.5;cursor:not-allowed}.thumbnail-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow:auto}.thumbnail-modal-container{background:var(--tenant-modal-bg, #1a1a2e);border-radius:12px;max-width:1340px;width:100%;max-height:95vh;overflow-y:auto;display:flex;flex-direction:column}.thumbnail-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--tenant-border-color, #2a2a4a)}.thumbnail-modal-header h2{margin:0;font-size:1.25rem;color:var(--tenant-text-color, #fff)}.thumbnail-modal-close{background:transparent;border:none;color:var(--tenant-text-secondary, #9ca3af);font-size:1.5rem;cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s}.thumbnail-modal-close:hover{color:var(--tenant-text-color, #fff)}.thumbnail-modal-content{padding:20px;flex:1;display:flex;flex-direction:column;align-items:center}.thumbnail-modal-description{color:var(--tenant-text-secondary, #9ca3af);margin:0 0 16px;font-size:.9rem;text-align:center}.thumbnail-iframe-container{position:relative;width:100%;max-width:1286px;height:60vh;min-height:300px;max-height:726px;display:flex;align-items:center;justify-content:center;background:#0b1020;border-radius:8px;border:3px solid transparent;transition:border-color .2s}.thumbnail-iframe-container.recording{border-color:#ef4444}.thumbnail-iframe-scaler{position:relative;overflow:hidden;border-radius:4px}.thumbnail-iframe{border:none;display:block}.recording-indicator{position:absolute;top:12px;left:12px;display:flex;align-items:center;gap:6px;background:#ef4444e6;color:#fff;padding:4px 10px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;pointer-events:none}.recording-dot{width:8px;height:8px;background:#fff;border-radius:50%;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.recording-stats{display:flex;gap:24px;margin-top:12px;color:var(--tenant-text-secondary, #9ca3af);font-size:.9rem;font-family:monospace}.thumbnail-success{text-align:center;padding:40px 20px}.thumbnail-success p{color:var(--tenant-text-color, #fff);margin:0 0 12px}.thumbnail-success p:first-child{color:#22c55e;font-weight:500;font-size:1.1rem}.thumbnail-error{color:#ef4444;text-align:center;margin-top:12px;font-size:.9rem}.thumbnail-modal-actions{display:flex;justify-content:center;gap:12px;padding:16px 20px;border-top:1px solid var(--tenant-border-color, #2a2a4a)}.thumbnail-modal-actions .btn-primary,.thumbnail-modal-actions .btn-secondary,.thumbnail-success .btn-primary{padding:10px 24px;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.thumbnail-modal-actions .btn-primary,.thumbnail-success .btn-primary{background:var(--tenant-primary-color, #6366f1);color:#fff;border:none}.thumbnail-modal-actions .btn-primary:hover:not(:disabled),.thumbnail-success .btn-primary:hover{background:var(--tenant-primary-hover, #4f46e5)}.thumbnail-modal-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.thumbnail-modal-actions .btn-secondary{background:transparent;color:var(--tenant-text-secondary, #9ca3af);border:1px solid var(--tenant-border-color, #2a2a4a)}.thumbnail-modal-actions .btn-secondary:hover:not(:disabled){background:var(--tenant-hover-bg, #2a2a4a);color:var(--tenant-text-color, #fff)}.thumbnail-modal-actions .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.thumbnail-modal-actions .btn-thumbnail{padding:10px 24px;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;background:#065f46;color:#a7f3d0;border:1px solid #059669}.thumbnail-modal-actions .btn-thumbnail:hover:not(:disabled){background:#047857;border-color:#10b981}.thumbnail-modal-actions .btn-thumbnail.marked{background:#059669;color:#fff;border-color:#10b981}.thumbnail-modal-actions .btn-thumbnail:disabled{opacity:.6;cursor:not-allowed}.thumbnail-marker-badge{background:#059669;color:#fff;padding:2px 8px;border-radius:4px;font-size:.85rem}.thumbnail-flash-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;pointer-events:none;animation:flash .2s ease-out forwards;border-radius:inherit}@keyframes flash{0%{opacity:.8}to{opacity:0}}.pre-recording-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;border-radius:inherit;cursor:default}.pre-recording-message{display:flex;flex-direction:column;align-items:center;gap:12px;color:#ffffffe6;font-size:1rem;font-weight:500;text-align:center;padding:20px}.pre-recording-message svg{color:#ffffffb3;animation:pulse-slow 2s ease-in-out infinite}@keyframes pulse-slow{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.resetting-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;border-radius:inherit;color:#ffffffe6;font-size:.95rem}.resetting-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.2);border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.simulation-viewer{max-width:1200px;margin:0 auto;padding:1rem;color:#e5e7eb;display:flex;flex-direction:column;min-height:calc(100vh - 80px)}.simulation-header{margin-bottom:.5rem;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.mobile-back-button{width:36px;height:36px;border-radius:8px;background:#1f2937f2;border:1px solid var(--tenant-border-color);color:#e5e7eb;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.mobile-back-button:hover{background:#374151f2;border-color:var(--tenant-primary-color)}.mobile-back-button:active{transform:scale(.95)}.mobile-back-button svg{width:18px;height:18px}.simulation-header h1{font-size:1.75rem;margin:0;color:#f3f4f6;flex:1;min-width:0}.simulation-meta{display:flex;gap:1rem;font-size:.85rem;color:#9ca3af;width:100%}.simulation-meta span{display:flex;align-items:center;gap:.25rem}.simulation-tags{display:flex;gap:.375rem;flex-wrap:wrap;margin-bottom:.5rem}.tag{background:var(--tenant-surface-color);color:color-mix(in srgb,var(--tenant-primary-color),white 40%);padding:.125rem .5rem;border-radius:10px;font-size:.8rem;border:1px solid var(--tenant-border-color)}.simulation-runner-container{position:relative;margin:.25rem 0;background:var(--tenant-surface-color);border:2px solid var(--tenant-border-color);border-radius:8px;overflow:hidden;transition:all .3s ease;flex:1;display:flex;flex-direction:column;min-height:520px}.simulation-runner-container.maximized{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;margin:0;border-radius:0;z-index:9999;border:none}.maximize-button{position:absolute;top:.75rem;right:.75rem;z-index:10;background:#1f2937e6;border:1px solid #4b5563;color:#e5e7eb;width:36px;height:36px;border-radius:6px;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:all .2s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.maximize-button:hover{background:#374151f2;border-color:#6b7280;transform:scale(1.05)}.simulation-runner-container.maximized .maximize-button{background:#1f2937f2;border-color:#6b7280}.simulation-runner-warning{background:#422006;border-bottom:1px solid #78350f;padding:.75rem 1rem;font-size:.85rem;color:#fbbf24;display:flex;align-items:center;gap:.5rem}.simulation-runner{width:100%;flex:1;min-height:400px;border:none;background:#111827;display:block}.simulation-runner-container.maximized .simulation-runner{height:100vh}.simulation-description{margin:2rem 0;padding:1.5rem;background:var(--tenant-surface-color);border-radius:8px;border:1px solid var(--tenant-border-color)}.simulation-description h2{margin:0 0 1rem;font-size:1.25rem;color:#f3f4f6}.simulation-description p{margin:0;line-height:1.6;color:#d1d5db}.simulation-actions{margin:2rem 0;display:flex;gap:1rem}.like-button{background:var(--tenant-surface-color);border:2px solid #374151;color:#e5e7eb;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;gap:.5rem}.like-button:hover{background:#374151;border-color:#4b5563;transform:scale(1.02)}.like-button.liked{background:#7c2d12;border-color:#dc2626;color:#fecaca}.like-button.liked:hover{background:#991b1b;border-color:#ef4444}.like-button:disabled{opacity:.5;cursor:not-allowed}.comments-section{margin:3rem 0;padding-top:2rem;border-top:2px solid #374151}.comments-section h2{font-size:1.5rem;margin:0 0 1.5rem;color:#f3f4f6}.comment-form{margin-bottom:2rem;display:flex;flex-direction:column;gap:.75rem}.comment-form textarea{background:var(--tenant-surface-color);border:2px solid #374151;border-radius:8px;padding:.75rem;color:#e5e7eb;font-size:.95rem;font-family:inherit;resize:vertical;transition:border-color .2s}.comment-form textarea:focus{outline:none;border-color:#60a5fa}.comment-form textarea:disabled{opacity:.5;cursor:not-allowed}.comment-form button{background:#2563eb;border:none;color:#fff;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.95rem;align-self:flex-start;transition:background .2s}.comment-form button:hover:not(:disabled){background:#1d4ed8}.comment-form button:disabled{background:#374151;cursor:not-allowed;opacity:.6}.comment-signin-prompt{padding:1.5rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:8px;text-align:center;color:#9ca3af;margin-bottom:2rem}.comments-list{display:flex;flex-direction:column;gap:1rem}.no-comments{text-align:center;color:#6b7280;padding:2rem;font-style:italic}.comment{background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:8px;padding:1rem}.comment-header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.85rem}.comment-author{font-weight:600;color:#60a5fa}.comment-date{color:#6b7280}.comment-content{color:#d1d5db;line-height:1.5;margin-bottom:.5rem}.comment-replies{margin-top:1rem;padding-left:1.5rem;border-left:2px solid #374151;display:flex;flex-direction:column;gap:1rem}.loading,.error{text-align:center;padding:4rem 2rem}.error{color:#f87171}.error h2{margin-bottom:1rem;color:#ef4444}.error button{background:#2563eb;border:none;color:#fff;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;margin-top:1rem}.error button:hover{background:#1d4ed8}.simulation-actions-bar{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;margin-bottom:1.5rem;padding:.75rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:8px}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;border:1px solid #374151;background:#1f2937;color:#e5e7eb}.action-btn:hover:not(:disabled){background:#374151;border-color:#4b5563}.action-btn:active:not(:disabled){transform:scale(.98)}.action-btn:disabled{opacity:.45;cursor:not-allowed;background:#111827;border-color:#1f2937;color:#6b7280}.action-btn-icon{font-size:1rem;line-height:1}.action-btn-label{white-space:nowrap}.action-btn-danger{border-color:#7f1d1d;background:#450a0a;color:#fca5a5}.action-btn-danger:hover:not(:disabled){background:#7f1d1d;border-color:#991b1b;color:#fecaca}.action-spacer{flex:1}@media (max-width: 768px){.simulation-viewer{padding:.5rem;min-height:calc(100vh - 60px)}.simulation-header{margin-bottom:.25rem}.simulation-header h1{font-size:1.1rem}.mobile-back-button{width:32px;height:32px}.mobile-back-button svg{width:16px;height:16px}.simulation-meta{font-size:.75rem;gap:.75rem}.simulation-tags{margin-bottom:.25rem}.simulation-runner-container{margin:.125rem 0;min-height:58vh}.simulation-runner{min-height:52vh}.simulation-description{margin:.5rem 0;padding:.75rem}.simulation-description h2{font-size:.9rem;margin-bottom:.25rem}.comment-replies{padding-left:.75rem}.simulation-actions-bar{flex-wrap:wrap;gap:.375rem;margin-top:.5rem;margin-bottom:.75rem;padding:.5rem}.action-spacer{display:none}.action-btn{flex:1 1 auto;justify-content:center;min-width:fit-content;padding:.375rem .5rem;font-size:.75rem}.action-btn-icon{font-size:.875rem}.action-btn-label{display:none}.action-btn-danger .action-btn-label{display:inline}.comments-section{margin:1rem 0;padding-top:.75rem}}@media (max-width: 480px){.simulation-viewer{padding:.375rem}.simulation-header h1{font-size:1rem}.simulation-runner-container{min-height:62vh}.simulation-runner{min-height:58vh}.close-button{padding:.25rem .5rem;font-size:.8rem}}@media (max-width: 768px) and (orientation: landscape){.simulation-viewer{padding:.25rem .375rem;min-height:calc(100vh - 40px)}.simulation-header{display:flex;align-items:center;gap:.5rem;margin-bottom:0}.simulation-header h1{font-size:.9rem;margin:0}.simulation-meta{font-size:.7rem}.simulation-tags,.close-button{display:none}.simulation-runner-container{margin:.125rem 0;min-height:68vh}.simulation-runner{min-height:64vh}.simulation-description,.comments-section{display:none}.simulation-actions-bar{margin:.25rem 0;padding:.375rem;gap:.25rem}.action-btn{padding:.25rem .375rem}}.external-simulation-container{display:flex;align-items:center;justify-content:center;min-height:400px;padding:3rem}.external-simulation-info{text-align:center;max-width:500px}.external-icon{font-size:4rem;margin-bottom:1rem;opacity:.8}.external-simulation-info h3{font-size:1.5rem;color:#f3f4f6;margin-bottom:.5rem}.external-simulation-info p{color:#9ca3af;margin-bottom:1.5rem;font-size:.95rem}.external-link-button{display:inline-block;background:#2563eb;color:#fff;padding:.875rem 1.75rem;border-radius:8px;text-decoration:none;font-weight:500;font-size:1rem;transition:all .2s;border:2px solid #2563eb}.external-link-button:hover{background:#1d4ed8;border-color:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.external-url-display{margin-top:1.5rem;padding:.75rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:6px;word-break:break-all}.external-url-display small{color:#60a5fa;font-size:.85rem}.recording-indicator-bar{position:absolute;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;background:#b91c1cf2;border-bottom:2px solid #dc2626;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:recording-pulse 2s ease-in-out infinite}@keyframes recording-pulse{0%,to{background:#b91c1cf2}50%{background:#dc2626f2}}.recording-indicator-left{display:flex;align-items:center;gap:.75rem}.recording-dot{width:12px;height:12px;background:#fecaca;border-radius:50%;animation:recording-dot-blink 1s ease-in-out infinite}@keyframes recording-dot-blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.recording-info{display:flex;flex-direction:column;gap:.125rem}.recording-label{font-size:.875rem;font-weight:600;color:#fecaca}.recording-stats{font-size:.75rem;color:#fca5a5}.recording-actions{display:flex;gap:.5rem}.recording-btn-capture{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#16a34a;border:none;border-radius:4px;color:#fff;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s}.recording-btn-capture:hover:not(:disabled){background:#15803d}.recording-btn-capture:disabled{opacity:.5;cursor:not-allowed}.recording-btn-cancel{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:transparent;border:1px solid #fca5a5;border-radius:4px;color:#fecaca;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s}.recording-btn-cancel:hover{background:#fecaca1a;border-color:#fecaca}.simulation-runner-container.recording{border-color:#dc2626;box-shadow:0 0 20px #dc26264d}@media (max-width: 768px){.recording-indicator-bar{padding:.375rem .5rem;flex-wrap:wrap;gap:.375rem}.recording-indicator-left{gap:.5rem}.recording-dot{width:10px;height:10px}.recording-label{font-size:.75rem}.recording-stats{font-size:.625rem}.recording-btn-capture,.recording-btn-cancel{padding:.25rem .5rem;font-size:.75rem}}.skeleton-card{background:color-mix(in srgb,var(--tenant-background-color),transparent 5%);border-radius:.9rem;border:1px solid var(--tenant-border-color);padding:.85rem;display:flex;flex-direction:column;gap:.6rem}.skeleton-thumbnail{position:relative;border-radius:.75rem;background:#1e293b;height:160px;overflow:hidden}.skeleton-info{display:flex;flex-direction:column;gap:.5rem}.skeleton-title{position:relative;height:1rem;width:60%;background:#1e293b;border-radius:4px;overflow:hidden}.skeleton-description{display:flex;flex-direction:column;gap:.4rem}.skeleton-line{position:relative;height:.85rem;background:#1e293b;border-radius:4px;overflow:hidden}.skeleton-line-full{width:100%}.skeleton-line-partial{width:75%}.skeleton-tags{display:flex;gap:.25rem;margin-top:.25rem}.skeleton-tag{position:relative;height:1.25rem;width:3.5rem;background:#1e293b;border-radius:8px;overflow:hidden}.skeleton-stats{display:flex;gap:1rem;margin-top:.25rem}.skeleton-stat{position:relative;height:.85rem;width:2.5rem;background:#1e293b;border-radius:4px;overflow:hidden}.featured-galleries{margin-bottom:2rem}.featured-galleries-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.featured-galleries-title{margin:0;font-size:1.25rem;font-weight:600;color:#e5e7eb}.featured-galleries-container{position:relative}.featured-scroll-button{position:absolute;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:50%;background:#1f2937f2;border:1px solid #374151;color:#e5e7eb;font-size:1.5rem;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 4px 12px #0006}.featured-scroll-button:hover{background:#374151f2;transform:translateY(-50%) scale(1.1)}.featured-scroll-left{left:-18px}.featured-scroll-right{right:-18px}.featured-galleries-scroll{display:flex;gap:1rem;overflow-x:auto;scroll-behavior:smooth;padding:.5rem 0;scrollbar-width:none;-ms-overflow-style:none}.featured-galleries-scroll::-webkit-scrollbar{display:none}.gallery-preview-card{flex-shrink:0;width:280px;background:color-mix(in srgb,var(--tenant-surface-color, #1f2937),transparent 40%);border:1px solid var(--tenant-border-color, #374151);border-radius:.75rem;overflow:hidden;cursor:pointer;transition:all .2s ease}.gallery-preview-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:var(--tenant-primary-color, #8b5cf6)}.gallery-preview-grid{aspect-ratio:16 / 9;display:grid;gap:2px;background:#0f1419;overflow:hidden}.gallery-preview-grid.grid-1{grid-template-columns:1fr;grid-template-rows:1fr}.gallery-preview-grid.grid-2{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.gallery-preview-grid.grid-3{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.gallery-preview-grid.grid-3 .gallery-preview-thumb:first-child{grid-row:span 2}.gallery-preview-grid.grid-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.gallery-preview-thumb{position:relative;overflow:hidden;background:#1a1f2e}.gallery-preview-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-preview-card:hover .gallery-preview-thumb img{transform:scale(1.05)}.gallery-preview-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a);color:#4b5563;font-size:1.5rem}.gallery-preview-empty .gallery-preview-placeholder{background:linear-gradient(135deg,#1e293b,#0f172a);color:#374151;font-size:1.25rem}.gallery-preview-info{padding:.75rem 1rem}.gallery-preview-name{margin:0 0 .25rem;font-size:.95rem;font-weight:600;color:#e5e7eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-preview-meta{margin:0;font-size:.8rem;color:#9ca3af}.gallery-preview-owner{color:#6b7280}.gallery-preview-card.skeleton{pointer-events:none}.skeleton-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px}.skeleton-thumb{background:linear-gradient(90deg,#1e293b,#2d3748,#1e293b);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-text{background:linear-gradient(90deg,#1e293b,#2d3748,#1e293b);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}.skeleton-title{height:1rem;width:70%;margin-bottom:.5rem}.skeleton-meta{height:.75rem;width:50%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.featured-galleries-error{padding:2rem;text-align:center;color:#9ca3af;font-style:italic}@media (max-width: 768px){.featured-galleries{margin-bottom:1.5rem}.featured-galleries-title{font-size:1.1rem}.gallery-preview-card{width:240px}.featured-scroll-button{display:none}.featured-galleries-scroll{padding-left:0;padding-right:0}}@media (max-width: 480px){.gallery-preview-card{width:200px}.gallery-preview-info{padding:.5rem .75rem}.gallery-preview-name{font-size:.85rem}.gallery-preview-meta{font-size:.75rem}}.history-view{width:100%;max-width:900px;margin:0 auto;padding:1rem 0}.history-loading,.history-error{text-align:center;padding:3rem;color:#9ca3af;font-size:1.1rem}.history-error{color:#f87171}.history-empty{text-align:center;padding:4rem 2rem;color:#9ca3af}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.history-empty h3{margin:0 0 .5rem;font-size:1.5rem;color:#cbd5e1}.history-empty p{margin:0;font-size:1rem;color:#64748b}.history-group{margin-bottom:2.5rem}.history-group-title{font-size:.75rem;font-weight:700;letter-spacing:.1em;color:#64748b;margin:0 0 1rem;padding:0 0 .5rem;border-bottom:2px solid rgba(100,116,139,.2)}.history-items{display:flex;flex-direction:column;gap:.75rem}.history-card{display:flex;gap:1rem;background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:.75rem;padding:1rem;cursor:pointer;transition:all .2s ease}.history-card:hover{background:#0f172acc;border-color:#6366f166;transform:translate(4px);box-shadow:0 4px 12px #6366f11a}.history-card-thumbnail{flex-shrink:0;width:120px;height:90px;background:var(--tenant-surface-color);border-radius:.5rem;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 70%)}.history-card-no-thumb{font-size:.75rem;color:#64748b;text-align:center}.history-card-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.5rem}.history-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.history-card-title{margin:0;font-size:1.1rem;font-weight:600;color:#e5e7eb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-card-time{flex-shrink:0;font-size:.85rem;color:#94a3b8;font-weight:500}.history-card-description{margin:0;font-size:.9rem;color:#94a3b8;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.history-card-tags{display:flex;gap:.375rem;flex-wrap:wrap}.history-card-tag{font-size:.7rem;padding:.125rem .5rem;background:#1f2937cc;color:#60a5fa;border-radius:6px;border:1px solid rgba(55,65,81,.6)}.history-card-stats{display:flex;gap:1rem;font-size:.85rem;color:#6b7280;margin-top:auto}.history-card-stats span{display:flex;align-items:center;gap:.25rem}.history-load-more{margin-top:2rem;padding:2rem 1rem;text-align:center;background:#0f172a66;border-radius:.75rem;border:1px solid rgba(148,163,184,.15)}.load-more-button{padding:.75rem 2rem;background:#6366f11a;border:2px solid rgba(99,102,241,.3);border-radius:.5rem;color:#a5b4fc;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.load-more-button:hover:not(:disabled){background:#6366f133;border-color:#6366f180;color:#c7d2fe;transform:translateY(-2px);box-shadow:0 4px 12px #6366f133}.load-more-button:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.history-view{padding:.5rem}.history-card{flex-direction:column}.history-card-thumbnail{width:100%;height:180px}.history-card-header{flex-direction:column;gap:.25rem;align-items:flex-start}.history-card-title{white-space:normal}.history-card-time{font-size:.75rem}}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.history-group{animation:slideIn .3s ease-out}.skeleton-history-card{pointer-events:none}.skeleton-element{background:#37415180;border-radius:.375rem;overflow:hidden;position:relative}.skeleton-shimmer{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);animation:shimmer 1.5s infinite}.skeleton-group-title{width:80px;height:14px;margin-bottom:1rem}.skeleton-title{width:60%;height:20px;flex:1}.skeleton-time{width:80px;height:16px;flex-shrink:0}.skeleton-description{width:100%;height:40px}.skeleton-tags-row{display:flex;gap:.375rem}.skeleton-tag{width:50px;height:18px;border-radius:6px}.skeleton-stats-row{display:flex;gap:1rem;margin-top:auto}.skeleton-stat{width:40px;height:16px}.settings-view{width:100%;max-width:800px;margin:0 auto;padding:2rem 1rem}.settings-not-signed-in{text-align:center;padding:4rem 2rem;color:#9ca3af}.not-signed-in-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.settings-not-signed-in h3{margin:0 0 .5rem;font-size:1.5rem;color:#cbd5e1}.settings-not-signed-in p{margin:0;font-size:1rem;color:#64748b}.settings-container{display:flex;flex-direction:column;gap:1.5rem}.settings-card{background:#0f172a99;border:1px solid rgba(148,163,184,.2);border-radius:1rem;padding:1.5rem;transition:all .2s ease}.settings-card:hover{border-color:#94a3b84d;background:#0f172ab3}.settings-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(148,163,184,.1)}.settings-card-icon{font-size:1.5rem}.settings-card-title{margin:0;font-size:1.25rem;font-weight:600;color:#e5e7eb}.settings-card-content{display:flex;flex-direction:column;gap:1.5rem}.settings-field{display:flex;flex-direction:column;gap:.5rem}.settings-field-danger{padding-top:1.5rem;border-top:1px solid rgba(239,68,68,.2)}.settings-label{font-size:.95rem;font-weight:500;color:#cbd5e1}.settings-value{font-size:1rem;color:#94a3b8;display:flex;align-items:center;gap:.5rem}.verified-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;background:#22c55e1a;color:#4ade80;border:1px solid rgba(34,197,94,.3);border-radius:.375rem;font-size:.75rem;font-weight:500}.settings-hint{font-size:.875rem;color:#64748b;line-height:1.4}.settings-radio-group{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.radio-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 60%);border:2px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.5rem;cursor:pointer;transition:all .2s ease}.radio-option:hover{border-color:color-mix(in srgb,var(--tenant-primary-color),transparent 60%);background:var(--tenant-surface-color)}.radio-option input[type=radio]{margin-top:.25rem;cursor:pointer}.radio-option input[type=radio]:checked+.radio-label{color:#e5e7eb}.radio-label{display:flex;flex-direction:column;gap:.25rem;flex:1;color:#94a3b8;font-weight:500}.radio-icon{margin-right:.25rem}.radio-hint{font-size:.75rem;color:#64748b;font-weight:400}.settings-select{padding:.75rem 1rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:2px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.5rem;color:#e5e7eb;font-size:.95rem;cursor:pointer;transition:all .2s ease;max-width:200px}.settings-select:hover{border-color:var(--tenant-border-color)}.settings-select:focus{outline:none;border-color:#6366f199;box-shadow:0 0 0 3px #6366f11a}.settings-button{padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s ease;max-width:fit-content}.settings-button:disabled{opacity:.5;cursor:not-allowed}.settings-button-primary{background:#6366f1;color:#fff}.settings-button-primary:hover:not(:disabled){background:#5558e3}.settings-button-secondary{background:#94a3b81a;color:#cbd5e1;border:1px solid rgba(148,163,184,.3)}.settings-button-secondary:hover:not(:disabled){background:#94a3b833;border-color:#94a3b866}.settings-button-danger{background:#ef44441a;color:#f87171;border:1px solid rgba(239,68,68,.3)}.settings-button-danger:hover:not(:disabled){background:#ef444433;border-color:#ef444466}.settings-confirm{padding:1rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 60%);border:1px solid color-mix(in srgb,var(--tenant-border-color),transparent 50%);border-radius:.5rem;margin-top:.5rem}.confirm-text{margin:0 0 1rem;font-size:.9rem;color:#cbd5e1;line-height:1.5}.confirm-text strong{color:#f87171}.confirm-actions{display:flex;gap:.75rem;flex-wrap:wrap}@media (max-width: 768px){.settings-view{padding:1rem .5rem}.settings-card{padding:1rem}.settings-card-header{margin-bottom:1rem;padding-bottom:.75rem}.settings-select{max-width:100%}.settings-button{width:100%;max-width:100%}.confirm-actions{flex-direction:column}.radio-option{padding:.75rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-card{animation:fadeIn .3s ease-out}.settings-card:nth-child(1){animation-delay:0s}.settings-card:nth-child(2){animation-delay:.1s}.settings-card:nth-child(3){animation-delay:.2s}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{position:relative;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:1rem;max-width:480px;width:100%;padding:2rem;animation:modalSlideIn .2s ease}@keyframes modalSlideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#9ca3af;font-size:1.25rem;cursor:pointer;padding:.25rem;border-radius:.25rem;transition:all .2s}.modal-close:hover{color:#e5e7eb;background:color-mix(in srgb,var(--tenant-surface-color),white 10%)}.create-gallery-modal h2{margin:0 0 1.5rem;color:#e5e7eb;font-size:1.5rem}.form-group{margin-bottom:1.25rem}.form-group label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem;color:#e5e7eb;font-weight:500;font-size:.9rem}.label-hint{font-size:.8rem;color:#6b7280;font-weight:400}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.5rem;color:#e5e7eb;font-size:1rem;transition:all .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-background-color),transparent 20%);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 80%)}.form-group input.input-error{border-color:#ef4444}.form-group input.input-error:focus{box-shadow:0 0 0 3px #ef444433}.form-group textarea{resize:vertical;min-height:80px}.field-error{display:block;margin-top:.35rem;color:#ef4444;font-size:.8rem}.char-count{display:block;margin-top:.35rem;text-align:right;color:#6b7280;font-size:.75rem}.form-error{padding:.75rem 1rem;background:color-mix(in srgb,#ef4444,transparent 85%);border:1px solid #ef4444;border-radius:.5rem;color:#fca5a5;font-size:.9rem;margin-bottom:1rem}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}@media (max-width: 480px){.modal-content{padding:1.5rem}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.add-simulation-modal{max-width:700px;max-height:90vh;display:flex;flex-direction:column}.add-simulation-modal h2{margin:0 0 1.25rem;color:#e5e7eb;font-size:1.35rem;padding-right:2rem}.search-box{position:relative;margin-bottom:1rem}.search-box .search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);font-size:1rem;opacity:.6}.search-box input{width:100%;padding:.65rem .75rem .65rem 2.5rem;background:color-mix(in srgb,var(--tenant-background-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.5rem;color:#e5e7eb;font-size:.95rem;box-sizing:border-box}.search-box input:focus{outline:none;border-color:var(--tenant-primary-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--tenant-primary-color),transparent 80%)}.simulations-container{flex:1;overflow-y:auto;max-height:400px;padding:.25rem}.sim-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.sim-select-item{position:relative;cursor:pointer;border:2px solid transparent;border-radius:.5rem;padding:.5rem;transition:all .2s;background:color-mix(in srgb,var(--tenant-surface-color),transparent 60%)}.sim-select-item:hover{background:color-mix(in srgb,var(--tenant-surface-color),transparent 30%)}.sim-select-item.selected{border-color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%)}.sim-select-checkbox{position:absolute;top:.75rem;left:.75rem;width:20px;height:20px;background:color-mix(in srgb,var(--tenant-background-color),transparent 20%);border:2px solid var(--tenant-border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;z-index:1;transition:all .2s}.sim-select-item.selected .sim-select-checkbox{background:var(--tenant-primary-color);border-color:var(--tenant-primary-color)}.sim-select-thumb{border-radius:.35rem;overflow:hidden;aspect-ratio:16/10}.sim-select-thumb .sim-thumbnail{position:relative;width:100%;height:100%;background-color:color-mix(in srgb,var(--tenant-surface-color),transparent 20%)}.sim-select-title{margin-top:.5rem;font-size:.8rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sim-select-item.selected .sim-select-title{color:#e5e7eb}.sim-private-badge{position:absolute;bottom:.5rem;right:.5rem;padding:2px 6px;background:#000000bf;border-radius:4px;font-size:.65rem;color:#fbbf24;z-index:2;cursor:help;pointer-events:auto}.sim-select-item.is-private{opacity:.85}.sim-select-item.is-private:hover{opacity:1}.sim-select-item.skeleton{cursor:default;pointer-events:none}.sim-select-thumb.skeleton-element{position:relative;overflow:hidden;aspect-ratio:16/10;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%);border-radius:.35rem}.sim-select-title.skeleton-element{position:relative;overflow:hidden;height:14px;margin-top:.5rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%);border-radius:.25rem}.error-message,.empty-message{text-align:center;padding:2rem;color:#9ca3af}.error-message p,.empty-message p{margin:0 0 1rem}.retry-button{padding:.5rem 1rem;background:var(--tenant-primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s}.retry-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.modal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--tenant-border-color)}.selection-count{color:#9ca3af;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.change-indicator{display:flex;gap:.35rem}.add-indicator{color:#22c55e;font-weight:600}.remove-indicator{color:#ef4444;font-weight:600}.modal-actions{display:flex;gap:.75rem}.btn-cancel{padding:.6rem 1.25rem;background:transparent;border:1px solid var(--tenant-border-color);color:#9ca3af;border-radius:.5rem;cursor:pointer;font-size:.95rem;transition:all .2s}.btn-cancel:hover{background:color-mix(in srgb,var(--tenant-surface-color),white 10%);color:#e5e7eb}.btn-primary{padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));border:none;color:#0b1120;border-radius:.5rem;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 600px){.add-simulation-modal{max-height:85vh}.sim-select-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.modal-footer{flex-direction:column;gap:1rem}.modal-actions{width:100%}.modal-actions button{flex:1}}.user-selector{background:color-mix(in srgb,var(--tenant-primary-color),transparent 85%);border:1px solid var(--tenant-border-color);border-radius:.75rem;padding:1rem 1.25rem;margin-bottom:1.5rem}.user-selector-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#9ca3af;font-size:.875rem}.user-selector-header .selector-icon{font-size:1rem}.user-selector-dropdown-container{position:relative}.user-selector-input-wrapper{position:relative;display:flex;align-items:center}.user-selector-input{width:100%;padding:.625rem 2.5rem .625rem 1rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;color:#e5e7eb;font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s}.user-selector-input:focus{border-color:var(--tenant-primary-color);box-shadow:0 0 0 2px color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.user-selector-input::placeholder{color:#6b7280}.user-selector-dropdown-arrow{position:absolute;right:1rem;color:#9ca3af;font-size:.75rem;pointer-events:none;transition:transform .2s}.user-selector-dropdown-arrow.open{transform:rotate(180deg)}.user-selector-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;max-height:280px;overflow-y:auto;z-index:100;box-shadow:0 10px 30px #0006}.user-selector-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;color:#e5e7eb;text-align:left;cursor:pointer;transition:background .15s}.user-selector-option:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%)}.user-selector-option.selected{background:color-mix(in srgb,var(--tenant-primary-color),transparent 70%)}.user-selector-option.my-galleries-option{border-bottom:1px solid var(--tenant-border-color)}.user-option-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#0b1120;flex-shrink:0}.user-option-info{flex:1;min-width:0;overflow:hidden}.user-option-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-option-email{font-size:.8rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-selector-selected-indicator{color:var(--tenant-primary-color);font-size:1rem}.user-selector-loading,.user-selector-empty{padding:1rem;text-align:center;color:#9ca3af;font-size:.875rem}.user-selector-loading{display:flex;align-items:center;justify-content:center;gap:.5rem}.loading-spinner{width:16px;height:16px;border:2px solid var(--tenant-border-color);border-top-color:var(--tenant-primary-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.user-selector-selected-display{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;cursor:pointer;transition:border-color .2s}.user-selector-selected-display:hover{border-color:var(--tenant-primary-color)}.user-selector-selected-display .user-option-info{flex:1}.user-selector-selected-display .dropdown-trigger{color:#9ca3af;font-size:.75rem}.user-selector-quick-select{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.quick-select-label{color:#6b7280;font-size:.8rem}.quick-select-button{padding:.375rem .75rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:1rem;color:#e5e7eb;font-size:.8rem;cursor:pointer;transition:all .2s}.quick-select-button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%);border-color:var(--tenant-primary-color)}.quick-select-button.active{background:var(--tenant-primary-color);border-color:var(--tenant-primary-color);color:#0b1120}@media (max-width: 768px){.user-selector{padding:.875rem 1rem}.user-selector-quick-select{flex-direction:column;align-items:flex-start}}.galleries-view{padding:0;position:relative}.galleries-page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.galleries-title{margin:0;font-size:1.5rem;font-weight:600;color:#e5e7eb}.create-gallery-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff;border:none;border-radius:.5rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #8b5cf64d}.create-gallery-button:hover{transform:translateY(-1px);box-shadow:0 4px 16px #8b5cf666}.create-gallery-button .button-icon{font-size:1rem}.create-gallery-button .button-label{white-space:nowrap}.feedback-toast{position:fixed;top:1rem;right:1rem;padding:.75rem 1.25rem;border-radius:.5rem;color:#fff;font-weight:500;z-index:1000;animation:slideIn .3s ease}.feedback-toast.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.feedback-toast.error{background:linear-gradient(135deg,#ef4444,#dc2626)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.galleries-loading{display:flex;flex-direction:column;gap:1.5rem}.gallery-card.skeleton{background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%)}.gallery-card-header.skeleton-element,.sim-thumb-skeleton{position:relative;overflow:hidden}.gallery-card-header.skeleton-element{height:48px;border-radius:.5rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%)}.sim-thumb-skeleton{width:140px;height:100px;border-radius:.5rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%);flex-shrink:0}.gallery-simulations-skeleton{display:flex;gap:.75rem;padding:1rem 0}.galleries-error{text-align:center;padding:3rem;color:#9ca3af}.galleries-error p{margin-bottom:1rem}.retry-button{padding:.5rem 1rem;background:var(--tenant-primary-color);color:#fff;border:none;border-radius:.5rem;cursor:pointer}.galleries-empty{text-align:center;padding:4rem 2rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 60%);border:1px dashed var(--tenant-border-color);border-radius:1rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.galleries-empty h3{margin:0 0 .5rem;color:#e5e7eb;font-size:1.25rem}.galleries-empty p{margin:0 0 1.5rem;color:#9ca3af}.create-gallery-button-large{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));color:#0b1120;border:none;border-radius:.5rem;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease}.create-gallery-button-large:hover{transform:translateY(-2px);box-shadow:0 8px 20px #6366f166}.galleries-list{display:flex;flex-direction:column;gap:1.5rem}.gallery-card{background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;overflow:hidden}.gallery-card-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%);border-bottom:1px solid var(--tenant-border-color)}.gallery-info{display:flex;flex-direction:column;gap:.25rem}.gallery-name{color:#e5e7eb;font-size:1.1rem;font-weight:600;text-decoration:none;transition:color .2s}.gallery-name:hover{color:var(--tenant-primary-color)}.gallery-meta{color:#9ca3af;font-size:.85rem}.gallery-actions{position:relative}.gallery-menu-button{padding:.5rem;background:transparent;border:none;color:#9ca3af;font-size:1.25rem;cursor:pointer;border-radius:.25rem;transition:all .2s}.gallery-menu-button:hover{background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);color:#e5e7eb}.gallery-menu{position:absolute;top:100%;right:0;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;padding:.5rem 0;min-width:150px;z-index:500;box-shadow:0 10px 30px #00000080}.gallery-menu button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem 1rem;background:transparent;border:none;color:#e5e7eb;text-align:left;cursor:pointer;transition:background .2s}.gallery-menu button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%)}.gallery-menu .delete-button{color:#ef4444}.gallery-menu .delete-button:hover{background:color-mix(in srgb,#ef4444,transparent 80%)}.menu-divider{height:1px;background:var(--tenant-border-color);margin:.5rem 0}.gallery-content{padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem}.gallery-simulations-loading{display:flex;gap:.75rem;flex:1}.gallery-empty-message{flex:1;color:#6b7280;font-style:italic;padding:1rem 0}.gallery-simulations-wrapper{position:relative;flex:1;min-width:0}.gallery-simulations{display:flex;gap:.75rem;overflow-x:auto;padding:.5rem 0;scroll-behavior:smooth}.gallery-simulations-wrapper:before,.gallery-simulations-wrapper:after{content:"";position:absolute;top:0;bottom:6px;width:40px;pointer-events:none;opacity:0;transition:opacity .3s ease;z-index:2}.gallery-simulations-wrapper:before{left:0;background:linear-gradient(to right,var(--tenant-surface-color) 0%,transparent 100%)}.gallery-simulations-wrapper:after{right:0;background:linear-gradient(to left,var(--tenant-surface-color) 0%,transparent 100%)}.gallery-simulations-wrapper.can-scroll-left:before{opacity:1}.gallery-simulations-wrapper.can-scroll-right:after{opacity:1}.scroll-hint{position:absolute;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;background:color-mix(in srgb,var(--tenant-surface-color),white 15%);border:1px solid var(--tenant-border-color);color:#9ca3af;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s,transform .2s,color .2s;z-index:3;font-size:.9rem}.scroll-hint:hover{color:#e5e7eb;transform:translateY(-50%) scale(1.1)}.scroll-hint-left{left:4px}.scroll-hint-right{right:4px}.gallery-simulations-wrapper:hover .scroll-hint.visible{opacity:1}.gallery-simulations::-webkit-scrollbar{height:6px}.gallery-simulations::-webkit-scrollbar-track{background:color-mix(in srgb,var(--tenant-surface-color),transparent 60%);border-radius:3px}.gallery-simulations::-webkit-scrollbar-thumb{background:var(--tenant-border-color);border-radius:3px}.gallery-simulations::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 50%)}.gallery-sim-thumb{flex-shrink:0;width:140px;position:relative}.sim-thumb-clickable{cursor:pointer;transition:transform .2s}.sim-thumb-clickable:hover{transform:scale(1.02)}.gallery-thumb-wrapper{position:relative;width:100%;height:90px;border-radius:.5rem;overflow:hidden;background-color:color-mix(in srgb,var(--tenant-surface-color),transparent 20%)}.gallery-thumb-wrapper .sim-thumbnail{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:inherit}.private-indicator{position:absolute;top:4px;left:4px;padding:2px 5px;background:#000000b3;border-radius:4px;font-size:.7rem;z-index:2;cursor:help}.sim-thumb-title{margin-top:.35rem;font-size:.75rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sim-menu-button{position:absolute;top:4px;right:4px;padding:.25rem .4rem;background:#0009;border:none;color:#fff;border-radius:4px;cursor:pointer;font-size:.9rem;opacity:0;transition:opacity .2s}.gallery-sim-thumb:hover .sim-menu-button{opacity:1}.sim-menu{position:absolute;top:28px;right:4px;background:var(--tenant-surface-color);border:1px solid var(--tenant-border-color);border-radius:.5rem;padding:.5rem 0;min-width:160px;z-index:500;box-shadow:0 10px 30px #00000080}.sim-menu button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem 1rem;background:transparent;border:none;color:#e5e7eb;text-align:left;cursor:pointer;font-size:.85rem;transition:background .2s}.sim-menu button:hover{background:color-mix(in srgb,var(--tenant-primary-color),transparent 80%)}.add-simulation-button{flex-shrink:0;padding:.5rem 1rem;background:transparent;border:1px dashed var(--tenant-border-color);color:#9ca3af;border-radius:.5rem;cursor:pointer;font-size:.9rem;transition:all .2s;white-space:nowrap}.add-simulation-button:hover{border-color:var(--tenant-primary-color);color:var(--tenant-primary-color);background:color-mix(in srgb,var(--tenant-primary-color),transparent 90%)}@media (max-width: 768px){.galleries-page-header{flex-wrap:wrap}.galleries-title{font-size:1.25rem}.create-gallery-button{padding:.4rem .75rem;font-size:.8rem}.gallery-card-header{flex-direction:column;align-items:flex-start;gap:.75rem}.gallery-actions{align-self:flex-end}.gallery-content{flex-direction:column;align-items:stretch}.add-simulation-button{width:100%}}.gallery-public-view{padding:0}.gallery-public-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--tenant-border-color)}.gallery-public-title{margin:0 0 .5rem;font-size:2rem;font-weight:700;color:#e5e7eb}.gallery-public-description{margin:0 0 .75rem;color:#9ca3af;font-size:1rem;line-height:1.5;max-width:800px}.gallery-public-meta{color:#6b7280;font-size:.9rem}.gallery-public-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.gallery-public-sim-card{background:color-mix(in srgb,var(--tenant-surface-color),transparent 40%);border:1px solid var(--tenant-border-color);border-radius:.75rem;overflow:hidden;cursor:pointer;transition:all .2s ease}.gallery-public-sim-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:var(--tenant-primary-color)}.gallery-public-sim-thumb{position:relative;aspect-ratio:16/10;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%)}.gallery-public-sim-thumb .sim-thumbnail{position:absolute;top:0;left:0;width:100%;height:100%}.gallery-public-sim-info{padding:1rem}.gallery-public-sim-title{margin:0 0 .35rem;font-size:1rem;font-weight:600;color:#e5e7eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-public-sim-description{margin:0;font-size:.85rem;color:#9ca3af;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.gallery-public-empty{text-align:center;padding:4rem 2rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 60%);border:1px dashed var(--tenant-border-color);border-radius:1rem;color:#9ca3af}.gallery-public-error{text-align:center;padding:4rem 2rem}.gallery-public-error .error-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.gallery-public-error h2{margin:0 0 .5rem;color:#e5e7eb;font-size:1.5rem}.gallery-public-error p{margin:0 0 1.5rem;color:#9ca3af}.back-home-link{display:inline-block;padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--tenant-primary-color),var(--tenant-secondary-color));color:#0b1120;text-decoration:none;border-radius:.5rem;font-weight:600;transition:all .2s ease}.back-home-link:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.gallery-public-loading{display:flex;flex-direction:column;gap:2rem}.gallery-header-skeleton{height:100px;border-radius:.5rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%);position:relative;overflow:hidden}.gallery-grid-skeleton{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.gallery-sim-skeleton{aspect-ratio:16/12;border-radius:.75rem;background:color-mix(in srgb,var(--tenant-surface-color),transparent 20%);position:relative;overflow:hidden}.skeleton-shimmer{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 768px){.gallery-public-title{font-size:1.5rem}.gallery-public-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}}@media (max-width: 480px){.gallery-public-grid{grid-template-columns:1fr}}.login-required-container{display:flex;justify-content:center;align-items:center;min-height:400px;padding:40px 20px}.login-required-content{text-align:center;max-width:400px;padding:40px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.login-required-icon{font-size:64px;margin-bottom:20px;opacity:.8}.login-required-title{font-size:24px;font-weight:600;color:#1a1a1a;margin:0 0 12px}.login-required-message{font-size:16px;color:#666;margin:0 0 24px;line-height:1.5}.login-required-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 32px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000001a}.login-required-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.login-required-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.login-required-help{font-size:14px;color:#888;margin:20px 0 0;line-height:1.4}
