.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-md);animation:fadeIn .2s ease-out}.modal-content{background-color:var(--color-bg-primary);border-radius:var(--radius-lg);padding:var(--spacing-lg);max-width:500px;width:100%;box-shadow:var(--shadow-lg);animation:modalSlideIn .3s ease-out;max-height:90vh;overflow-y:auto}.modal-title{margin:0 0 var(--spacing-md) 0;font-size:1.25rem;font-weight:700;color:var(--color-text-primary)}.modal-message{margin:0 0 var(--spacing-lg) 0;font-size:1rem;line-height:1.5;color:var(--color-text-primary)}.modal-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;flex-wrap:wrap}.modal-button{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;font-weight:500;min-height:44px;transition:all var(--transition-fast)}.modal-button-primary{background-color:var(--color-primary);color:var(--color-text-inverse)}.modal-button-primary:hover{background-color:var(--color-primary-hover)}.modal-button-secondary{background-color:var(--color-text-tertiary);color:var(--color-text-inverse)}.modal-button-secondary:hover{background-color:#5a6268}.modal-button-danger{background-color:var(--color-error);color:var(--color-text-inverse)}.modal-button-danger:hover{background-color:#c82333}.modal-input{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;box-sizing:border-box;background-color:var(--color-bg-primary);color:var(--color-text-primary);min-height:44px;transition:border-color var(--transition-fast)}.modal-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.modal-input-error{border-color:var(--color-error)}.modal-error{margin-top:var(--spacing-sm);color:var(--color-error);font-size:.875rem}.modal-progress-container{margin-bottom:var(--spacing-md)}.modal-progress-bar{width:100%;height:24px;background-color:var(--color-bg-tertiary);border-radius:12px;overflow:hidden;position:relative}.modal-progress-fill{height:100%;background-color:var(--color-primary);transition:width .3s ease,background-color .3s ease;border-radius:12px;position:relative;overflow:hidden}.modal-progress-fill.paused{background-color:var(--color-text-tertiary)}.modal-progress-shimmer{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}.modal-progress-percent{margin-top:var(--spacing-sm);text-align:center;font-size:.9rem;font-weight:700;color:var(--color-primary)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 768px){.modal-backdrop{padding:var(--spacing-sm)}.modal-content{max-width:100%;max-height:95vh;padding:var(--spacing-md)}.modal-actions{flex-direction:column-reverse}.modal-button{width:100%}}@media (max-width: 480px){.modal-backdrop{padding:0;align-items:flex-end}.modal-content{max-width:100%;max-height:100vh;max-height:100dvh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--spacing-md);padding-bottom:max(var(--spacing-md),env(safe-area-inset-bottom))}}.guest-upload-page{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;background:var(--color-bg-secondary, #f5f5f7);padding:var(--spacing-xl) var(--spacing-md)}.guest-upload-loading{min-height:100vh;display:flex;align-items:center;justify-content:center}.guest-upload-container{max-width:640px;width:100%;background:var(--color-bg-primary, #fff);border-radius:var(--radius-lg, 16px);padding:var(--spacing-xl);box-shadow:var(--shadow-md, 0 4px 16px rgba(0,0,0,.08))}.guest-upload-title{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-sm) 0}.guest-upload-description{color:var(--color-text-secondary);font-size:1rem;line-height:1.5;margin:0 0 var(--spacing-lg) 0}.guest-upload-error{background:var(--color-danger-bg, #fff2f0);color:var(--color-danger, #ff3b30);padding:var(--spacing-md);border-radius:var(--radius-sm, 8px);margin-bottom:var(--spacing-md);font-weight:500}.guest-upload-section{margin-bottom:var(--spacing-lg)}.guest-upload-label{display:block;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.guest-upload-password-row,.guest-upload-name-row{display:flex;gap:var(--spacing-sm)}.guest-upload-password-row .control,.guest-upload-name-row .control{flex:1;min-height:var(--control-h, 44px)}.guest-upload-field-error{color:var(--color-danger, #ff3b30);font-size:.875rem;margin-top:var(--spacing-xs)}.guest-upload-uploader-badge{display:inline-block;background:var(--color-primary-light, #e8f0fe);color:var(--color-primary, #007aff);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full, 100px);font-weight:600;font-size:.875rem;margin-bottom:var(--spacing-md)}.guest-upload-dropzone{border:2px dashed var(--color-border, #d1d1d6);border-radius:var(--radius-md, 12px);padding:var(--spacing-xl) var(--spacing-md);text-align:center;cursor:pointer;transition:all var(--transition-normal, .16s) ease;margin-bottom:var(--spacing-md)}.guest-upload-dropzone:hover,.guest-upload-dropzone.active{border-color:var(--color-primary, #007aff);background:var(--color-primary-light, #e8f0fe)}.guest-upload-dropzone-icon{font-size:2.5rem;color:var(--color-text-muted, #8e8e93);line-height:1;margin-bottom:var(--spacing-sm)}.guest-upload-dropzone.active .guest-upload-dropzone-icon{color:var(--color-primary, #007aff)}.guest-upload-dropzone-text{color:var(--color-text-primary);font-weight:500;margin:0 0 var(--spacing-xs) 0}.guest-upload-dropzone-hint{color:var(--color-text-muted, #8e8e93);font-size:.8125rem;margin:0}.guest-upload-stats{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.guest-upload-stat{font-size:.875rem;font-weight:600}.guest-upload-stat.success{color:var(--color-success, #34c759)}.guest-upload-stat.error{color:var(--color-danger, #ff3b30)}.guest-upload-stat.limit{color:var(--color-text-secondary)}.guest-upload-file-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.guest-upload-file-item{background:var(--color-bg-secondary, #f5f5f7);border-radius:var(--radius-sm, 8px);padding:var(--spacing-sm) var(--spacing-md)}.guest-upload-file-item.uploaded{background:var(--color-success-bg, #f0faf4)}.guest-upload-file-item.error{background:var(--color-danger-bg, #fff2f0)}.guest-upload-file-info{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.guest-upload-file-name{font-size:.875rem;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.guest-upload-file-size{font-size:.75rem;color:var(--color-text-muted, #8e8e93);flex-shrink:0}.guest-upload-file-status{display:flex;align-items:center;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.guest-upload-status-badge{font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:4px}.guest-upload-status-badge.pending{color:var(--color-text-muted)}.guest-upload-status-badge.uploading{color:var(--color-primary, #007aff)}.guest-upload-status-badge.uploaded{color:var(--color-success, #34c759)}.guest-upload-status-badge.error{color:var(--color-danger, #ff3b30)}.guest-upload-file-remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.25rem;padding:0 4px;line-height:1}.guest-upload-file-remove:hover{color:var(--color-danger, #ff3b30)}.guest-upload-progress{height:3px;background:var(--color-border, #d1d1d6);border-radius:2px;margin-top:var(--spacing-xs);overflow:hidden}.guest-upload-progress-bar{height:100%;background:var(--color-primary, #007aff);border-radius:2px;transition:width .15s linear}.guest-upload-file-error{font-size:.75rem;color:var(--color-danger, #ff3b30);margin-top:var(--spacing-xs)}.guest-upload-footer{margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border, #d1d1d6);text-align:center}.guest-upload-register{font-size:.9375rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.guest-upload-register a{color:var(--color-primary, #007aff);text-decoration:none;font-weight:600}.guest-upload-register a:hover{text-decoration:underline}.guest-upload-copyright{font-size:.75rem;color:var(--color-text-muted, #8e8e93)}@media (max-width: 480px){.guest-upload-page{padding:var(--spacing-sm)}.guest-upload-container{padding:var(--spacing-lg);border-radius:var(--radius-md, 12px)}.guest-upload-title{font-size:1.375rem}.guest-upload-password-row,.guest-upload-name-row{flex-direction:column}}.cookie-consent-overlay{position:fixed;bottom:0;left:0;right:0;z-index:9998;display:flex;justify-content:center;padding:16px;pointer-events:none}.cookie-consent{pointer-events:auto;max-width:480px;width:100%;background:var(--panel);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:18px;animation:consent-slide-up .3s ease}@keyframes consent-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cookie-consent__title{font-size:15px;font-weight:700;margin-bottom:6px;color:var(--text)}.cookie-consent__text{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:14px}.cookie-consent__actions{display:flex;gap:8px}.cookie-consent__actions .btn{flex:1;font-size:13px;height:38px;border-radius:12px}.cookie-consent__details{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.cookie-consent__category{display:flex;align-items:center;justify-content:space-between;gap:12px}.cookie-consent__category-info{flex:1;min-width:0}.cookie-consent__category-label{font-size:14px;font-weight:600;color:var(--text)}.cookie-consent__category-desc{font-size:12px;color:var(--muted);line-height:1.4;margin-top:2px}.cookie-consent__save-row{display:flex;justify-content:flex-end;margin-top:4px}.cookie-consent__save-row .btn{font-size:13px;height:38px;border-radius:12px}@media (max-width: 520px){.cookie-consent-overlay{padding:8px}.cookie-consent{max-width:100%;border-radius:var(--radius-lg)}.cookie-consent__actions{flex-direction:column}}.bugreport-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;background:transparent;border-radius:var(--radius, 6px);color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.bugreport-btn:hover{background:var(--hover);color:var(--text)}.bugreport-btn:active{background:var(--active)}.service-bar{height:48px;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;position:sticky;top:0;z-index:100}.service-bar-left{display:flex;align-items:center;gap:24px}.service-bar-logo{font-weight:700;font-size:1.125rem;color:var(--accent)}.service-tabs{display:flex;gap:4px}.service-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);color:var(--muted);text-decoration:none;font-weight:500;transition:background-color .2s,color .2s}.service-tab:hover{background:#0000000d;color:var(--text);text-decoration:none}[data-theme=dark] .service-tab:hover{background:#ffffff1a}.service-tab.active{background:var(--accent);color:#fff}.service-tab-icon{font-size:1rem}.service-tab-label{font-size:.875rem}.service-bar-right{display:flex;align-items:center;gap:16px}.service-bar-user{color:var(--text);font-weight:500;text-decoration:none}.service-bar-user:hover{color:var(--accent)}.service-bar-quota{font-size:.8125rem;color:var(--muted);white-space:nowrap}.service-bar-lang{height:36px;padding:0 8px;font-size:.8125rem;font-weight:600;background:var(--bg, #fff);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer}.service-bar-lang:focus{outline:none;border-color:var(--accent)}.service-bar-theme-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;transition:color .2s,border-color .2s;line-height:1}.service-bar-theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.service-bar-logout{padding:6px 12px;font-size:.875rem;font-weight:500;color:var(--muted);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:color .2s,border-color .2s}.service-bar-logout:hover{color:var(--danger);border-color:var(--danger)}.service-bar-ops-btn{position:relative;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;transition:color .2s,border-color .2s}.service-bar-ops-btn:hover{color:var(--accent);border-color:var(--accent)}.service-tab-badge{min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;text-align:center;color:#fff;background:var(--accent, #007bff);border-radius:8px;margin-left:4px}.service-bar-ops-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;text-align:center;color:#fff;background:var(--accent, #007bff);border-radius:8px;animation:opsPulse 2s ease-in-out infinite}@keyframes opsPulse{0%,to{opacity:1}50%{opacity:.6}}.service-bar-ops-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;overflow-y:auto;background:var(--panel, #fff);border:1px solid var(--border);border-radius:var(--radius, 8px);box-shadow:0 8px 24px #0000001f;z-index:200}.ops-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px}.ops-dropdown-clear{padding:2px 8px;font-size:11px;background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);cursor:pointer}.ops-dropdown-clear:hover{border-color:var(--accent);color:var(--accent)}.ops-dropdown-item{padding:10px 14px;border-bottom:1px solid var(--border-light, rgba(0,0,0,.06));transition:background .15s}.ops-dropdown-item:hover{background:#00000008}[data-theme=dark] .ops-dropdown-item:hover{background:#ffffff0d}.ops-dropdown-item:last-child{border-bottom:none}.ops-dropdown-item-row{display:flex;align-items:center;gap:8px}.ops-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ops-dot--running{background:var(--accent, #007bff);animation:opsPulse 1.5s ease-in-out infinite}.ops-dot--done{background:#28a745}.ops-dot--error{background:#dc3545}.ops-dropdown-item-label{flex:1;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ops-dropdown-item-close{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:0 2px;line-height:1}.ops-dropdown-item-close:hover{color:var(--danger, #dc3545)}.ops-dropdown-item-progress{margin-top:4px;margin-left:16px;font-size:11px;color:var(--muted)}.ops-dropdown-item-error{margin-top:4px;margin-left:16px;font-size:11px;color:var(--danger, #dc3545)}.service-bar-burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px}.burger-line{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:transform .25s,opacity .25s}.burger-line.open:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger-line.open:nth-child(2){opacity:0}.burger-line.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.service-bar-mobile-menu,.service-tabs-mobile{display:none}@media (max-width: 768px){.service-bar{padding:0 12px}.service-bar-logo,.service-tabs-desktop,.service-bar-right-desktop{display:none}.service-bar-burger{display:flex}.service-bar-mobile-menu{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--panel);border-bottom:1px solid var(--border);box-shadow:0 8px 24px #0000001f;z-index:200;padding:8px;gap:8px;animation:mobileMenuSlideIn .2s ease}@keyframes mobileMenuSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.service-tabs-mobile{display:flex;flex-direction:column;gap:2px}.service-tabs-mobile .service-tab{width:100%;padding:10px 14px;min-height:44px;border-radius:var(--radius-sm)}.service-tabs-mobile .service-tab-label{display:inline}.service-bar-mobile-controls{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 6px;border-top:1px solid var(--border)}.service-bar-mobile-controls .service-bar-user{width:100%;padding:8px 0}.service-bar-mobile-controls .service-bar-logout{min-height:44px;flex:1}.service-bar-ops-dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;width:100%;max-height:60vh;border-radius:16px 16px 0 0}}.module-nav{min-height:44px;background:var(--bg);border-bottom:1px solid var(--border)}.module-nav-inner{display:flex;flex-wrap:wrap;align-items:center;gap:2px 4px;padding:4px 12px}.module-nav-item{padding:4px 10px;font-size:.8125rem;font-weight:500;color:var(--muted);text-decoration:none;white-space:nowrap;border-radius:var(--radius-sm);transition:color .2s,background-color .2s}.module-nav-item:hover{color:var(--text);background:#0000000d;text-decoration:none}[data-theme=dark] .module-nav-item:hover{background:#ffffff1a}.module-nav-item.active{color:var(--accent);background:#0071e31a}@media (max-width: 768px){.module-nav-inner{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 8px;gap:2px}.module-nav-inner::-webkit-scrollbar{display:none}.module-nav-item{padding:8px 12px;min-height:36px;flex-shrink:0;scroll-snap-align:center}}.app-footer{padding:16px 24px;text-align:center;font-size:.75rem;color:var(--muted);border-top:1px solid var(--border);background:var(--panel);flex-shrink:0}@media (max-width: 480px){.app-footer{padding:12px 16px}}.chat-photo-grid{border-radius:var(--radius-sm);overflow:hidden}.chat-photo-grid-items{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}.chat-photo-thumb{aspect-ratio:1;overflow:hidden;background:var(--bg);cursor:pointer}.chat-photo-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .15s}.chat-photo-thumb:hover img{transform:scale(1.05)}.chat-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--muted)}.chat-photo-grid-more{padding:6px 0;text-align:center;font-size:.8125rem;color:var(--accent);cursor:pointer}.chat-photo-grid-count{padding:4px 0;text-align:center;font-size:.75rem;color:var(--muted)}.chat-album-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--accent-light);text-decoration:none;color:inherit;transition:background var(--transition-fast)}.chat-album-card:hover{background:var(--row-hover)}.chat-album-card-icon{flex-shrink:0;color:var(--accent)}.chat-album-card-info{flex:1;min-width:0}.chat-album-card-name{font-weight:600;font-size:.875rem}.chat-album-card-desc{font-size:.8125rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-album-card-type{font-size:.75rem;color:var(--muted);margin-top:2px}.chat-story-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);background:#34c7591a;text-decoration:none;color:inherit;transition:background var(--transition-fast)}.chat-story-card:hover{background:var(--row-hover)}.chat-story-card-icon{flex-shrink:0;color:var(--accent-2)}.chat-story-card-info{flex:1;min-width:0}.chat-story-card-title{font-weight:600;font-size:.875rem}.chat-story-card-desc{font-size:.8125rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-story-card-status{font-size:.75rem;color:var(--accent-2);margin-top:2px}.chat-confirm{border-radius:var(--radius-sm, 8px);padding:12px;font-size:.875rem}.chat-confirm-destructive{background:var(--color-error-bg, #fff5f5);border:1px solid var(--color-error-border, #fecaca)}.chat-confirm-warning{background:#fffbeb;border:1px solid #fde68a}.chat-confirm-header{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:8px}.chat-confirm-icon{font-size:1.1rem}.chat-confirm-details{margin-bottom:10px}.chat-confirm-merge{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.chat-confirm-person{font-size:.8125rem}.chat-confirm-meta{color:var(--muted, #888)}.chat-confirm-target{color:var(--accent, #2563eb);font-size:.75rem;font-weight:500}.chat-confirm-preview{font-size:.8125rem;margin-bottom:6px;display:flex;flex-direction:column;gap:2px}.chat-confirm-warning-text{font-size:.8125rem;color:var(--color-error-text, #b91c1c);font-style:italic}.chat-confirm-actions{display:flex;gap:8px}.chat-confirm-btn{padding:6px 16px;border-radius:var(--radius-sm, 6px);border:none;font-size:.8125rem;font-weight:500;cursor:pointer;min-height:32px;transition:opacity .15s}.chat-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.chat-confirm-btn-approve{background:var(--color-error-text, #dc2626);color:#fff}.chat-confirm-warning .chat-confirm-btn-approve{background:var(--accent, #2563eb)}.chat-confirm-btn-deny{background:var(--field-bg, #f3f4f6);color:var(--text, #333);border:1px solid var(--border, #e0e0e0)}.chat-confirm-decided{padding:6px 0;font-size:.8125rem;font-weight:500}.chat-confirm-decided-yes{color:var(--color-error-text, #dc2626)}.chat-confirm-warning .chat-confirm-decided-yes{color:var(--accent, #2563eb)}.chat-confirm-decided-no{color:var(--muted, #888)}.chat-message{display:flex;padding:4px 16px}.chat-message-user{justify-content:flex-end}.chat-message-assistant{justify-content:flex-start}.chat-bubble{max-width:80%;padding:10px 14px;border-radius:var(--radius-md);font-size:.9375rem;line-height:1.5;word-break:break-word}.chat-message-user .chat-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-message-assistant .chat-bubble{background:var(--field-bg);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-bubble-text{white-space:pre-wrap}.chat-md-p{margin:0 0 .25em}.chat-md-p:last-child{margin-bottom:0}.chat-md-list{margin:.25em 0;padding-left:1.25em}.chat-inline-code{background:var(--panel-solid, #f0f0f0);padding:1px 4px;border-radius:3px;font-size:.875em}.chat-tool-step{color:var(--muted, #888);font-size:.85em;line-height:1.6}.chat-cursor{animation:blink .8s infinite;font-weight:700}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-tool-results{margin-top:10px;display:flex;flex-direction:column;gap:8px}.chat-tool-error{padding:8px 12px;background:var(--color-error-bg, #fff0f0);color:var(--color-error-text, #c00);border-radius:6px;font-size:.85rem;display:flex;align-items:center;gap:6px}.chat-tool-error-icon{width:18px;height:18px;border-radius:50%;background:var(--color-error-text, #c00);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.chat-tool-success{padding:8px 12px;background:#f0fff0;color:#28a745;border-radius:6px;font-size:.85rem}.chat-tool-info{padding:8px 12px;background:var(--field-bg, #f8f8f8);color:var(--muted, #888);border-radius:6px;font-size:.85rem}.chat-tool-stats{padding:8px 12px;background:var(--field-bg, #f8f8f8);border-radius:6px;font-size:.85rem;display:grid;grid-template-columns:1fr 1fr;gap:4px 16px}.chat-event-list{display:flex;flex-direction:column;gap:6px}.chat-event-card{padding:8px 12px;background:var(--panel-solid, #f8f8f8);border:1px solid var(--border, #e0e0e0);border-radius:6px;cursor:pointer;transition:background var(--transition-fast, .15s)}.chat-event-card:hover{background:var(--row-hover, #f0f0f0)}.chat-event-name{font-weight:500;font-size:.9rem}.chat-event-meta{font-size:.8rem;color:var(--muted, #888);display:flex;gap:12px;margin-top:2px}.chat-persons-list{display:flex;flex-wrap:wrap;gap:8px}.chat-person-card{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--panel-solid, #f8f8f8);border:1px solid var(--border, #e0e0e0);border-radius:6px;cursor:pointer;transition:background var(--transition-fast, .15s)}.chat-person-card:hover{background:var(--row-hover, #f0f0f0)}.chat-person-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.chat-person-info{display:flex;flex-direction:column}.chat-person-name{font-weight:500;font-size:.85rem}.chat-person-count{font-size:.75rem;color:var(--muted, #888)}.chat-photo-detail{display:flex;gap:12px;padding:8px;background:var(--panel-solid, #f8f8f8);border:1px solid var(--border, #e0e0e0);border-radius:6px;cursor:pointer;transition:background var(--transition-fast, .15s)}.chat-photo-detail:hover{background:var(--row-hover, #f0f0f0)}.chat-photo-detail-img{width:120px;height:120px;object-fit:cover;border-radius:4px;flex-shrink:0}.chat-photo-detail-info{font-size:.85rem;display:flex;flex-direction:column;gap:2px}.chat-photo-detail-summary{margin-top:4px;font-style:italic;color:var(--muted, #888)}.chat-message-list{flex:1;overflow-y:auto;padding:16px 0;display:flex;flex-direction:column;gap:8px}.chat-bubble-loading{display:flex;align-items:center;gap:4px;padding:14px 18px;background:var(--field-bg);border:1px solid var(--border);border-radius:var(--radius-md);border-bottom-left-radius:4px}.chat-typing-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);animation:chatTyping 1.2s infinite ease-in-out}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes chatTyping{0%,60%,to{opacity:.3;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}.chat-input{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--panel-solid);position:relative}.chat-input textarea{flex:1;min-height:var(--control-h);max-height:120px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--field-bg);color:var(--text);font-family:var(--font-sans);font-size:.9375rem;line-height:1.4;resize:none;outline:none;transition:border-color var(--transition-fast)}.chat-input textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--focus)}.chat-input textarea::placeholder{color:var(--placeholder)}.chat-send-btn{display:flex;align-items:center;justify-content:center;width:var(--control-h);height:var(--control-h);border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast)}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-stop-btn{display:flex;align-items:center;justify-content:center;width:var(--control-h);height:var(--control-h);border:none;border-radius:var(--radius-sm);background:var(--danger, #e53e3e);color:#fff;cursor:pointer;flex-shrink:0;transition:background var(--transition-fast)}.chat-stop-btn:hover{background:var(--danger-hover, #c53030)}.chat-mic-btn{display:flex;align-items:center;justify-content:center;width:var(--control-h);height:var(--control-h);border:none;border-radius:var(--radius-sm);background:transparent;color:var(--muted);cursor:pointer;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast)}.chat-mic-btn:hover:not(:disabled){background:var(--row-hover);color:var(--text)}.chat-mic-btn:disabled{opacity:.4;cursor:not-allowed}.chat-mic-btn--active{background:var(--danger, #e53e3e);color:#fff;animation:chat-mic-pulse 1.5s ease-in-out infinite}.chat-mic-btn--active:hover:not(:disabled){background:var(--danger-hover, #c53030)}@keyframes chat-mic-pulse{0%,to{box-shadow:0 0 #e53e3e66}50%{box-shadow:0 0 0 8px #e53e3e00}}.chat-voice-error{position:absolute;bottom:calc(100% + 4px);right:16px;padding:6px 12px;background:var(--color-error-bg);color:var(--color-error-text);font-size:.75rem;border-radius:var(--radius-sm);white-space:nowrap;animation:chat-voice-error-fade 3s ease-in-out forwards;pointer-events:none;z-index:10}@keyframes chat-voice-error-fade{0%{opacity:0;transform:translateY(4px)}10%{opacity:1;transform:translateY(0)}80%{opacity:1}to{opacity:0}}.chat-attach-wrap{position:relative;flex-shrink:0}.chat-attach-btn{display:flex;align-items:center;justify-content:center;width:var(--control-h, 44px);height:var(--control-h, 44px);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--field-bg);color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.chat-attach-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light, rgba(74, 144, 217, .06))}.chat-attach-popover{position:absolute;bottom:calc(100% + 8px);left:0;min-width:220px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panel-solid, #fff);box-shadow:0 8px 24px #0000001f;z-index:10;padding:6px;animation:chatAttachIn .12s ease-out}@keyframes chatAttachIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-attach-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:4px;background:none;color:var(--text);font-size:.8125rem;cursor:pointer;text-align:left;transition:background .15s}.chat-attach-option:hover{background:var(--field-bg, #f5f5f5)}.chat-attach-option--disabled{opacity:.5;cursor:default;font-size:.75rem}.chat-attach-option--disabled:hover{background:none}.chat-attach-option svg{color:var(--muted);flex-shrink:0}.chat-attach-hint{padding:6px 10px;font-size:.7rem;color:var(--muted);line-height:1.3;border-top:1px solid var(--border);margin-top:4px}.chat-context-bar{display:flex;flex-direction:column;border-top:1px solid var(--border);background:var(--field-bg);flex-shrink:0}.chat-context-bar-row{display:flex;align-items:center;justify-content:space-between;padding:4px 16px;min-height:28px;gap:12px}.chat-context-bar-left{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--muted);min-width:0}.chat-context-page{background:var(--accent-light);color:var(--accent);padding:1px 6px;border-radius:var(--radius-sm);font-weight:500;white-space:nowrap}.chat-context-msgs{white-space:nowrap}.chat-context-summarized{color:var(--accent);font-style:italic;cursor:help;white-space:nowrap}.chat-context-bar-right{flex-shrink:0;width:80px}.chat-context-progress{height:4px;border-radius:2px;background:var(--border);overflow:hidden}.chat-context-progress-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .3s ease}.chat-context-progress--warn .chat-context-progress-fill{background:var(--color-warning, #e6a817)}.chat-context-progress--full .chat-context-progress-fill{background:var(--color-error-text, #d9534f)}.chat-context-chips{display:flex;align-items:center;gap:6px;padding:4px 16px 6px;overflow-x:auto;scrollbar-width:none}.chat-context-chips::-webkit-scrollbar{display:none}.chat-context-clear{border:none;background:none;color:var(--muted);font-size:.7rem;cursor:pointer;padding:2px 6px;white-space:nowrap;border-radius:var(--radius-sm);transition:color .15s,background .15s}.chat-context-clear:hover{color:var(--color-error-text, #d9534f);background:var(--color-error-bg, rgba(217, 83, 79, .08))}.ctx-chip{display:flex;align-items:center;gap:4px;padding:2px 6px 2px 4px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary, #fff);font-size:.7rem;color:var(--text);white-space:nowrap;max-width:180px;cursor:pointer;transition:border-color .15s}.ctx-chip:hover{border-color:var(--accent)}.ctx-chip-thumb{width:18px;height:18px;border-radius:3px;object-fit:cover;flex-shrink:0}.ctx-chip-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;color:var(--muted)}.ctx-chip-label{overflow:hidden;text-overflow:ellipsis}.ctx-chip-remove{border:none;background:none;color:var(--muted);font-size:14px;line-height:1;cursor:pointer;padding:0 1px;margin-left:2px;border-radius:3px;transition:color .15s,background .15s}.ctx-chip-remove:hover{color:var(--color-error-text, #d9534f);background:var(--color-error-bg, rgba(217, 83, 79, .1))}.ai-drawer{width:0;min-width:0;overflow:hidden;display:flex;flex-direction:column;background:var(--panel-solid);border-left:1px solid transparent;box-shadow:none;flex-shrink:0;transition:width .3s cubic-bezier(.32,.72,0,1),min-width .3s cubic-bezier(.32,.72,0,1),border-color .3s ease,box-shadow .3s ease}.ai-drawer--open{width:380px;min-width:380px;border-left-color:var(--border);box-shadow:var(--shadow-lg)}.ai-drawer--drag-over{outline:2px solid var(--accent, #4a90d9);outline-offset:-2px;background:var(--accent-light, rgba(74, 144, 217, .05))}.ai-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 14px 18px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--panel);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));white-space:nowrap}.ai-drawer-header-title{display:flex;align-items:center;gap:10px}.ai-drawer-header-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent);animation:ai-dot-breathe 2.5s ease-in-out infinite}@keyframes ai-dot-breathe{0%,to{opacity:.6;box-shadow:0 0 4px var(--accent)}50%{opacity:1;box-shadow:0 0 10px var(--accent)}}.ai-drawer-header h3{font-size:.9375rem;font-weight:600;margin:0;letter-spacing:-.01em;color:var(--text)}.ai-drawer-header-actions{display:flex;align-items:center;gap:2px}.ai-drawer-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast),transform .12s ease}.ai-drawer-btn:hover{background:var(--row-hover);color:var(--text);transform:scale(1.06)}.ai-drawer-btn:active{transform:scale(.92)}.ai-drawer-btn--close:hover{background:var(--color-error-bg);color:var(--danger)}.ai-drawer-context-badge{display:flex;align-items:center;gap:8px;padding:7px 16px;background:var(--accent-light);border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden;white-space:nowrap;animation:ai-badge-slide-in .3s ease-out .15s both}@keyframes ai-badge-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ai-drawer-context-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--accent);color:#fff;flex-shrink:0}.ai-drawer-context-icon svg{width:12px;height:12px}.ai-drawer-context-text{font-size:.75rem;font-weight:500;color:var(--text);opacity:.75;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.005em}.ai-drawer-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;scroll-behavior:smooth}.ai-drawer-body::-webkit-scrollbar{width:5px}.ai-drawer-body::-webkit-scrollbar-track{background:transparent}.ai-drawer-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.ai-drawer-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.25rem 1.5rem;text-align:center;animation:ai-welcome-in .4s ease-out .1s both}@keyframes ai-welcome-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ai-drawer-welcome-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;background:var(--accent-light);color:var(--accent);position:relative}.ai-drawer-welcome-icon:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:19px;border:1.5px dashed var(--accent);opacity:.2;animation:ai-icon-spin 20s linear infinite}@keyframes ai-icon-spin{to{transform:rotate(360deg)}}.ai-drawer-welcome-text{color:var(--muted);font-size:.875rem;margin:0 0 1.25rem;line-height:1.5;max-width:280px}.ai-drawer-examples{display:flex;flex-direction:column;gap:6px;width:100%}.ai-drawer-example-btn{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--field-bg);color:var(--text);font-size:.8125rem;text-align:left;cursor:pointer;line-height:1.4;letter-spacing:-.005em;transition:background var(--transition-fast),border-color var(--transition-fast),transform .15s ease,box-shadow .15s ease;opacity:0;animation:ai-example-in .35s ease-out forwards}@keyframes ai-example-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-drawer-example-btn:hover{background:var(--accent-light);border-color:var(--accent);transform:translate(3px);box-shadow:0 2px 8px #007aff14}.ai-drawer-example-btn:active{transform:translate(1px) scale(.98)}.ai-drawer-example-arrow{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--accent-light);color:var(--accent);flex-shrink:0;transition:background var(--transition-fast),transform .15s ease}.ai-drawer-example-btn:hover .ai-drawer-example-arrow{background:var(--accent);color:#fff;transform:translate(2px)}.ai-drawer-error{padding:8px 16px;background:var(--color-error-bg);color:var(--color-error-text);font-size:.8125rem;text-align:center;flex-shrink:0;border-top:1px solid var(--color-error-border)}.ai-drawer-input-wrap{flex-shrink:0;border-top:1px solid var(--border);background:var(--panel);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur))}.ai-drawer-overlay{display:none}@media (max-width: 768px){.ai-drawer-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000002e;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1001;animation:ai-overlay-in .25s ease-out}@keyframes ai-overlay-in{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}.ai-drawer{position:fixed;top:0;right:0;height:100vh;height:100dvh;z-index:1002;width:0;min-width:0;transform:translate(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}.ai-drawer--open{width:100vw;min-width:100vw;transform:translate(0)}}[data-theme=dark] .ai-drawer--open{box-shadow:-4px 0 32px #00000080,-1px 0 #ffffff0f}[data-theme=dark] .ai-drawer-overlay{background:#0006}[data-theme=dark] .ai-drawer-example-btn:hover{box-shadow:0 2px 8px #0a84ff1f}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .ai-drawer--open{box-shadow:-4px 0 32px #00000080,-1px 0 #ffffff0f}:root:not([data-theme=light]) .ai-drawer-overlay{background:#0006}}.voice-mic-btn{border:none;background:none;cursor:pointer;color:var(--muted, #999);padding:4px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;position:relative}.voice-mic-btn:hover{color:var(--accent, #4a90d9)}.voice-mic-btn--active{color:var(--danger, #e53e3e);animation:mic-pulse 1s ease-in-out infinite}@keyframes mic-pulse{0%,to{opacity:1}50%{opacity:.5}}.voice-mic-btn--sm{width:28px;height:28px}.voice-mic-btn--md{width:36px;height:36px}.voice-mic-error{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--danger, #e53e3e);color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;white-space:nowrap;z-index:10}.annotation-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:99998;cursor:crosshair}.annotation-bg{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.annotation-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.annotation-toolbar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--panel-solid, #fff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 8px 32px rgba(0,0,0,.2));z-index:99999}.annotation-toolbar-hint{font-size:.875rem;color:var(--text-secondary)}.annotation-label-popup{position:fixed;z-index:99999;background:var(--panel-solid, #fff);border-radius:var(--radius, 6px);box-shadow:var(--shadow-lg, 0 8px 32px rgba(0,0,0,.2));padding:12px;display:flex;flex-direction:column;gap:8px;max-width:280px}.annotation-label-input{min-height:36px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius, 6px);font-size:.875rem;background:var(--input-bg, #fff);color:var(--text);width:100%}.annotation-label-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring, rgba(74,144,217,.2))}.annotation-label-actions{display:flex;gap:6px}.bugreport-drawer{width:0;min-width:0;overflow:hidden;display:flex;flex-direction:column;background:var(--panel-solid);border-left:1px solid transparent;box-shadow:none;flex-shrink:0;transition:width .3s cubic-bezier(.32,.72,0,1),min-width .3s cubic-bezier(.32,.72,0,1),border-color .3s ease,box-shadow .3s ease}.bugreport-drawer--open{width:380px;min-width:380px;border-left-color:var(--border);box-shadow:var(--shadow-lg)}.bugreport-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 14px 18px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--panel);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));white-space:nowrap}.bugreport-drawer-header-title{display:flex;align-items:center;gap:10px}.bugreport-drawer-header h3{font-size:.9375rem;font-weight:600;margin:0;color:var(--text)}.bugreport-drawer-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;font-size:1.25rem;color:var(--text-secondary);border-radius:var(--radius, 6px)}.bugreport-drawer-close:hover{background:var(--hover);color:var(--text)}.bugreport-drawer-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:20px}.bugreport-section{display:flex;flex-direction:column;gap:10px}.bugreport-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary)}.bugreport-capturing{display:flex;align-items:center;gap:8px;padding:12px;color:var(--text-secondary);font-size:.875rem}.bugreport-actions-row{display:flex;gap:6px;flex-wrap:wrap}.bugreport-actions-row .btn{font-size:.8125rem;padding:4px 10px}.bugreport-type-selector{display:flex;gap:4px}.bugreport-type-btn{flex:1;min-height:36px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);border-radius:var(--radius, 6px);cursor:pointer;font-size:.8125rem;font-weight:500;transition:all .15s}.bugreport-type-btn:hover{background:var(--hover)}.bugreport-type-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.bugreport-note-wrap{position:relative}.bugreport-note{width:100%;min-height:80px;padding:10px 40px 10px 10px;border:1px solid var(--border);border-radius:var(--radius, 6px);background:var(--input-bg, #fff);color:var(--text);font-family:inherit;font-size:.875rem;resize:vertical}.bugreport-note:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring, rgba(74,144,217,.2))}.bugreport-voice-btn{position:absolute;right:6px;top:6px}.bugreport-console-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--danger-light, rgba(255,59,48,.08));color:var(--danger, #ff3b30);border-radius:var(--radius, 6px);font-size:.8125rem;font-weight:500}.bugreport-annotations-list{display:flex;flex-direction:column;gap:4px}.bugreport-annotation-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-secondary, #f5f5f5);border-radius:var(--radius, 6px);font-size:.8125rem}.bugreport-annotation-badge{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.6875rem;font-weight:700;flex-shrink:0}.bugreport-annotation-label{flex:1;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bugreport-annotation-remove{width:20px;height:20px;border:none;background:transparent;cursor:pointer;color:var(--text-tertiary);font-size:1rem;padding:0;flex-shrink:0}.bugreport-annotation-remove:hover{color:var(--danger, #ff3b30)}.bugreport-regions{display:flex;gap:8px;flex-wrap:wrap}.bugreport-region-item{position:relative;width:80px;height:60px;border-radius:var(--radius, 6px);overflow:hidden;border:1px solid var(--border)}.bugreport-region-thumb{width:100%;height:100%;object-fit:cover}.bugreport-region-item .bugreport-annotation-remove{position:absolute;top:2px;right:2px;background:#0009;color:#fff;border-radius:50%;width:18px;height:18px;font-size:.75rem}.bugreport-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;text-align:center}.bugreport-success h4{margin:0;font-size:1.125rem;color:var(--text)}.bugreport-success p{margin:0;color:var(--text-secondary);font-size:.875rem}@media (max-width: 768px){.bugreport-drawer--open{position:fixed;top:0;right:0;width:100vw;min-width:100vw;height:100vh;z-index:10000}}.main-layout{height:100vh;height:100dvh;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.main-body{flex:1;display:flex;min-height:0;overflow:hidden}.main-body-content{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto}@media (max-width: 768px){.main-content{padding:16px}}@media (max-width: 480px){.main-content{padding:12px}}.error-boundary{padding:var(--spacing-xl);max-width:800px;margin:0 auto;text-align:center}.error-boundary-title{color:var(--color-error);margin-bottom:var(--spacing-md);font-size:2rem}.error-boundary-message{margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}.error-boundary-details{margin-top:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-sm);text-align:left;font-size:.9em}.error-boundary-summary{cursor:pointer;margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.error-boundary-pre{white-space:pre-wrap;word-break:break-word;color:var(--color-error-text)}.error-boundary-button{margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background-color:var(--color-primary);color:var(--color-text-inverse);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;min-height:44px;transition:all var(--transition-fast)}.error-boundary-button:hover{background-color:var(--color-primary-hover)}@media (max-width: 768px){.error-boundary{padding:var(--spacing-md)}.error-boundary-title{font-size:1.5rem}}:root{--font-sans: ui-sans-serif, system-ui, -apple-system, "SF Pro Display", "SF Pro Text", "Segoe UI", Roboto, Arial, "Apple Color Emoji", "Segoe UI Emoji";--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;--radius-xl: 20px;--radius-lg: 16px;--radius-md: 12px;--radius-sm: 8px;--bg: #f5f6f8;--panel: rgba(255, 255, 255, .72);--panel-solid: #ffffff;--text: rgba(0, 0, 0, .92);--muted: rgba(0, 0, 0, .58);--placeholder: rgba(0, 0, 0, .35);--border: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .18);--shadow-sm: 0 6px 18px rgba(0, 0, 0, .08);--shadow-md: 0 12px 30px rgba(0, 0, 0, .1);--shadow-lg: 0 16px 40px rgba(0, 0, 0, .12);--focus: rgba(0, 122, 255, .35);--accent: #007aff;--accent-hover: #0056b3;--accent-light: rgba(0, 122, 255, .12);--accent-2: #34c759;--danger: #ff3b30;--warning: #ffcc00;--field-bg: #ffffff;--field-hover: #f8f8fa;--field-disabled: #f0f0f2;--blur: 18px;--control-h: 44px;--row-hover: rgba(0, 0, 0, .03);--row-selected: rgba(0, 122, 255, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--map-marker-size: 36px;--map-marker-size-highlighted: 44px;--map-cluster-size-sm: 36px;--map-cluster-size-md: 42px;--map-cluster-size-lg: 50px;--map-popup-max-width: 280px;--map-timeline-height: 72px;--map-timeline-height-collapsed: 32px;--page-max-width: 1240px;--content-gutter: clamp(14px, 2.2vw, 28px);--section-gap: clamp(18px, 2.6vw, 32px);--form-row-gap: 14px;--form-col-gap: 14px;--action-bar-height: 44px;--transition-fast: .06s ease;--transition-normal: .16s ease;--transition-slow: .3s ease;--color-bg-primary: var(--panel-solid);--color-bg-secondary: var(--bg);--color-bg-tertiary: rgba(0, 0, 0, .05);--color-bg-hover: rgba(0, 0, 0, .05);--color-text-primary: var(--text);--color-text-secondary: var(--muted);--color-text-tertiary: var(--placeholder);--color-text-inverse: #ffffff;--color-border: var(--border);--color-border-light: var(--border);--color-border-dark: var(--border-strong);--color-primary: var(--accent);--color-primary-hover: var(--accent-hover);--color-primary-light: var(--accent-light);--color-success: var(--accent-2);--color-success-bg: rgba(52, 199, 89, .12);--color-success-border: rgba(52, 199, 89, .25);--color-success-text: #1d7a34;--color-error: var(--danger);--color-error-bg: rgba(255, 59, 48, .12);--color-error-border: rgba(255, 59, 48, .25);--color-error-text: #c41e16;--color-warning: var(--warning);--color-warning-bg: rgba(255, 204, 0, .16);--color-warning-border: rgba(255, 204, 0, .35);--color-warning-text: #8a6d00;--color-info: #5ac8fa;--color-info-bg: rgba(90, 200, 250, .12);--color-info-border: rgba(90, 200, 250, .25);--color-info-text: #0077b3}[data-theme=dark]{--bg: #0b0c10;--panel: rgba(24, 26, 33, .55);--panel-solid: #171922;--text: rgba(255, 255, 255, .92);--muted: rgba(255, 255, 255, .62);--placeholder: rgba(255, 255, 255, .38);--border: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .18);--shadow-sm: 0 8px 22px rgba(0, 0, 0, .35);--shadow-md: 0 16px 40px rgba(0, 0, 0, .45);--shadow-lg: 0 20px 50px rgba(0, 0, 0, .55);--field-bg: #1c1e28;--field-hover: #22242f;--field-disabled: #15171f;--focus: rgba(10, 132, 255, .4);--accent: #0a84ff;--accent-hover: #409cff;--accent-light: rgba(10, 132, 255, .2);--accent-2: #30d158;--danger: #ff453a;--warning: #ffd60a;--row-hover: rgba(255, 255, 255, .06);--row-selected: rgba(10, 132, 255, .16);--color-bg-primary: var(--panel-solid);--color-bg-secondary: var(--bg);--color-bg-tertiary: rgba(255, 255, 255, .06);--color-bg-hover: rgba(255, 255, 255, .08);--color-text-primary: var(--text);--color-text-secondary: var(--muted);--color-text-tertiary: var(--placeholder);--color-text-inverse: #0b0c10;--color-border: var(--border);--color-border-light: var(--border);--color-border-dark: var(--border-strong);--color-primary: var(--accent);--color-primary-hover: var(--accent-hover);--color-primary-light: var(--accent-light);--color-success: var(--accent-2);--color-success-bg: rgba(48, 209, 88, .16);--color-success-border: rgba(48, 209, 88, .3);--color-success-text: #7aefa0;--color-error: var(--danger);--color-error-bg: rgba(255, 69, 58, .16);--color-error-border: rgba(255, 69, 58, .3);--color-error-text: #ff9590;--color-warning: var(--warning);--color-warning-bg: rgba(255, 214, 10, .16);--color-warning-border: rgba(255, 214, 10, .3);--color-warning-text: #ffe866;--color-info: #64d2ff;--color-info-bg: rgba(100, 210, 255, .16);--color-info-border: rgba(100, 210, 255, .3);--color-info-text: #a8e4ff}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]){--bg: #0b0c10;--panel: rgba(24, 26, 33, .55);--panel-solid: #171922;--text: rgba(255, 255, 255, .92);--muted: rgba(255, 255, 255, .62);--placeholder: rgba(255, 255, 255, .38);--border: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .18);--shadow-sm: 0 8px 22px rgba(0, 0, 0, .35);--shadow-md: 0 16px 40px rgba(0, 0, 0, .45);--shadow-lg: 0 20px 50px rgba(0, 0, 0, .55);--field-bg: rgba(28, 30, 40, .7);--field-hover: rgba(28, 30, 40, .85);--field-disabled: rgba(28, 30, 40, .45);--focus: rgba(10, 132, 255, .4);--accent: #0a84ff;--accent-hover: #409cff;--accent-light: rgba(10, 132, 255, .2);--accent-2: #30d158;--danger: #ff453a;--warning: #ffd60a;--row-hover: rgba(255, 255, 255, .06);--row-selected: rgba(10, 132, 255, .16);--color-bg-primary: var(--panel-solid);--color-bg-secondary: var(--bg);--color-bg-tertiary: rgba(255, 255, 255, .06);--color-bg-hover: rgba(255, 255, 255, .08);--color-text-primary: var(--text);--color-text-secondary: var(--muted);--color-text-tertiary: var(--placeholder);--color-text-inverse: #0b0c10;--color-border: var(--border);--color-border-light: var(--border);--color-border-dark: var(--border-strong);--color-primary: var(--accent);--color-primary-hover: var(--accent-hover);--color-primary-light: var(--accent-light);--color-success: var(--accent-2);--color-success-bg: rgba(48, 209, 88, .16);--color-success-border: rgba(48, 209, 88, .3);--color-success-text: #7aefa0;--color-error: var(--danger);--color-error-bg: rgba(255, 69, 58, .16);--color-error-border: rgba(255, 69, 58, .3);--color-error-text: #ff9590;--color-warning: var(--warning);--color-warning-bg: rgba(255, 214, 10, .16);--color-warning-border: rgba(255, 214, 10, .3);--color-warning-text: #ffe866;--color-info: #64d2ff;--color-info-bg: rgba(100, 210, 255, .16);--color-info-border: rgba(100, 210, 255, .3);--color-info-text: #a8e4ff}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:var(--font-sans);color:var(--text);background:radial-gradient(1200px 700px at 20% -10%,rgba(0,122,255,.12),transparent 60%),radial-gradient(900px 600px at 90% 10%,rgba(52,199,89,.08),transparent 55%),radial-gradient(1000px 800px at 60% 120%,rgba(255,59,48,.06),transparent 55%),var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-slow),color var(--transition-normal)}[data-theme=dark] body{background:radial-gradient(1200px 700px at 20% -10%,rgba(10,132,255,.15),transparent 60%),radial-gradient(900px 600px at 90% 10%,rgba(48,209,88,.1),transparent 55%),radial-gradient(1000px 800px at 60% 120%,rgba(255,69,58,.08),transparent 55%),var(--bg)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) body{background:radial-gradient(1200px 700px at 20% -10%,rgba(10,132,255,.15),transparent 60%),radial-gradient(900px 600px at 90% 10%,rgba(48,209,88,.1),transparent 55%),radial-gradient(1000px 800px at 60% 120%,rgba(255,69,58,.08),transparent 55%),var(--bg)}}#root{min-height:100%;display:flex;flex-direction:column}[data-e2e-mode=true] *,[data-e2e-mode=true] *:before,[data-e2e-mode=true] *:after{transition:none!important;animation:none!important;animation-duration:0s!important;animation-delay:0s!important;transition-duration:0s!important;transition-delay:0s!important}@media (prefers-reduced-motion: reduce){*{transition:none!important;scroll-behavior:auto!important}}.container{max-width:1200px;margin:0 auto;padding:max(16px,env(safe-area-inset-top)) 16px max(20px,env(safe-area-inset-bottom))}.control,.input,input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],input[type=url],input[type=tel],input[type=date],input[type=time],input[type=datetime-local],select,textarea{height:var(--control-h);width:100%;border-radius:14px;border:1px solid var(--border);background:var(--field-bg);color:var(--text);padding:0 14px;outline:none;box-shadow:0 1px #ffffff59 inset;transition:transform var(--transition-fast),border-color var(--transition-normal),background var(--transition-normal),box-shadow var(--transition-normal);font-size:14px;font-family:var(--font-sans)}.control:hover,.input:hover,input:hover,select:hover,textarea:hover{background:var(--field-hover);border-color:var(--border-strong)}.control:focus,.input:focus,input:focus,select:focus,textarea:focus{border-color:transparent;box-shadow:0 0 0 4px var(--focus),0 1px #ffffff59 inset}.control::placeholder,.input::placeholder,input::placeholder,textarea::placeholder{color:var(--placeholder)}.control:disabled,.input:disabled,input:disabled,select:disabled,textarea:disabled{opacity:.55;cursor:not-allowed;background:var(--field-disabled);box-shadow:none}textarea,textarea.control,textarea.input{height:auto;min-height:110px;padding:12px 14px;resize:vertical}select,select.control,select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) 52%,calc(100% - 12px) 52%;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:36px;cursor:pointer}.btn,button{height:var(--control-h);border-radius:14px;border:1px solid var(--border);background:#ffffff8c;color:var(--text);padding:0 16px;font-size:14px;font-weight:700;font-family:var(--font-sans);cursor:pointer;transition:transform var(--transition-fast),filter var(--transition-normal),background var(--transition-normal),box-shadow var(--transition-normal);box-shadow:0 1px #ffffff59 inset,var(--shadow-sm);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:inline-flex;align-items:center;justify-content:center;gap:8px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:hover,button:hover{background:#ffffffbf;border-color:var(--border-strong)}.btn:active,button:active{transform:translateY(1px) scale(.99)}.btn:focus,button:focus{outline:none;box-shadow:0 0 0 4px var(--focus),var(--shadow-sm)}.btn:disabled,button:disabled{opacity:.55;cursor:not-allowed;background:var(--field-disabled);box-shadow:none}.btn-primary{background:linear-gradient(180deg,#007afff2,#007affc7);border-color:#0000000f;color:#fff;box-shadow:0 10px 26px #007aff40}.btn-primary:hover{background:linear-gradient(180deg,#007aff,#007affd9)}.btn-danger{background:linear-gradient(180deg,#ff3b30f2,#ff3b30bf);border-color:#0000000f;color:#fff;box-shadow:0 10px 26px #ff3b3033}.btn-danger:hover{background:linear-gradient(180deg,#ff3b30,#ff3b30d1)}.btn-success{background:linear-gradient(180deg,#34c759f2,#34c759c7);border-color:#0000000f;color:#fff;box-shadow:0 10px 26px #34c75933}.btn-ghost{background:transparent;box-shadow:none;border-color:transparent}.btn-ghost:hover{background:#0000000d}.btn.icon-only{width:var(--control-h);padding:0}.btn-block{width:100%}[data-theme=dark] .btn,[data-theme=dark] button{background:#ffffff14}[data-theme=dark] .btn:hover,[data-theme=dark] button:hover{background:#ffffff1f}[data-theme=dark] .btn-ghost:hover{background:#ffffff14}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .btn,:root:not([data-theme=light]):not([data-theme=dark]) button{background:#ffffff14}:root:not([data-theme=light]):not([data-theme=dark]) .btn:hover,:root:not([data-theme=light]):not([data-theme=dark]) button:hover{background:#ffffff1f}}.card{border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--panel);backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:16px 18px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.card-title{margin:0;font-size:15px;font-weight:800;letter-spacing:.2px}.card-subtitle{margin:6px 0 0;font-size:13px;color:var(--muted);line-height:1.35}.card-body{padding:16px 18px 18px}.section{display:grid;gap:14px;padding:14px;border-radius:var(--radius-lg);background:#ffffff73;border:1px solid var(--border)}[data-theme=dark] .section{background:#0000001a}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .section{background:#0000001a}}.grid{display:grid;gap:16px;grid-template-columns:1fr}@media (min-width: 980px){.grid{grid-template-columns:1fr 1fr}}.row{display:grid;gap:10px}@media (min-width: 560px){.row.cols-2{grid-template-columns:1fr 1fr}.row.cols-3{grid-template-columns:1fr 1fr 1fr}.row.cols-4{grid-template-columns:1fr 1fr 1fr 1fr}}.label,label{font-size:12px;color:var(--muted);margin-bottom:6px;display:inline-flex;gap:8px;align-items:center;font-weight:600}.hint{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.35}.badge,.pill{font-size:12px;padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:#ffffff8c;color:var(--muted);white-space:nowrap;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:inline-flex;align-items:center}[data-theme=dark] .badge,[data-theme=dark] .pill{background:#ffffff14}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .badge,:root:not([data-theme=light]):not([data-theme=dark]) .pill{background:#ffffff14}}.badge-success{background:var(--color-success-bg);color:var(--color-success-text);border-color:var(--color-success-border)}.badge-danger{background:var(--color-error-bg);color:var(--color-error-text);border-color:var(--color-error-border)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning-text);border-color:var(--color-warning-border)}.badge-info{background:var(--color-info-bg);color:var(--color-info-text);border-color:var(--color-info-border)}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;background:#ffffff73}[data-theme=dark] .table-wrap{background:#ffffff0f}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .table-wrap{background:#ffffff0f}}.table-scroller{max-height:500px;overflow:auto}table{width:100%;border-collapse:collapse}thead th{position:sticky;top:0;z-index:1;text-align:left;font-size:12px;color:var(--muted);font-weight:800;letter-spacing:.2px;background:#ffffffb3;backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));border-bottom:1px solid var(--border);padding:12px}[data-theme=dark] thead th{background:#181a219e}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) thead th{background:#181a219e}}tbody td{padding:12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}tbody tr:hover{background:var(--row-hover)}tbody tr.selected{background:var(--row-selected)}tbody tr:last-child td{border-bottom:none}.switch{display:inline-flex;align-items:center;gap:10px;-webkit-user-select:none;user-select:none;cursor:pointer}.switch input{position:absolute;opacity:0;pointer-events:none}.switch-ui{width:52px;height:32px;border-radius:999px;border:1px solid var(--border);background:#78788038;position:relative;transition:background var(--transition-normal),border-color var(--transition-normal),box-shadow var(--transition-normal);flex:0 0 auto}.switch-ui:after{content:"";width:26px;height:26px;border-radius:999px;position:absolute;top:2px;left:2px;background:#fffffff2;box-shadow:0 8px 18px #0000002e;transition:transform .18s ease}.switch input:checked+.switch-ui{background:#34c759eb;border-color:#0000000f}.switch input:checked+.switch-ui:after{transform:translate(20px)}.switch input:focus+.switch-ui{box-shadow:0 0 0 4px var(--focus)}.seg{display:inline-flex;background:#ffffff80;border:1px solid var(--border);border-radius:16px;padding:4px;gap:4px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);overflow:hidden;width:fit-content;max-width:100%}[data-theme=dark] .seg{background:#ffffff14}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .seg{background:#ffffff14}}.seg input{position:absolute;opacity:0;pointer-events:none}.seg label{height:34px;padding:0 12px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--muted);cursor:pointer;transition:background var(--transition-normal),color var(--transition-normal),transform var(--transition-fast);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;white-space:nowrap}.seg label:active{transform:scale(.99)}.seg input:checked+label{background:#fffc;color:var(--text);box-shadow:0 8px 18px #0000001a}[data-theme=dark] .seg input:checked+label{background:#ffffff24;box-shadow:0 12px 22px #00000059}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .seg input:checked+label{background:#ffffff24;box-shadow:0 12px 22px #00000059}}.status{display:inline-flex;align-items:center;gap:8px}.status .bubble,.dot{width:10px;height:10px;border-radius:999px;background:var(--accent-2);box-shadow:0 0 0 4px #34c7591f;flex:0 0 auto}.status.warn .bubble{background:var(--warning);box-shadow:0 0 0 4px #ffcc0029}.status.danger .bubble{background:var(--danger);box-shadow:0 0 0 4px #ff3b3024}.icon{width:20px;height:20px;display:inline-block;vertical-align:-4px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto}.icon.sm{width:16px;height:16px;vertical-align:-3px}.icon.lg{width:24px;height:24px;vertical-align:-5px}.icon.xl{width:28px;height:28px;vertical-align:-6px}.icon.solid{fill:currentColor;stroke:none}.mono{font-family:var(--font-mono)}.muted{color:var(--muted)}.text-center{text-align:center}.text-right{text-align:right}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.page-title{font-size:24px;font-weight:800;letter-spacing:-.3px;margin:0}.page-actions{display:flex;gap:10px;align-items:center}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px}.form-row{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.alert{padding:14px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--panel);margin-bottom:16px}.alert-success{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success-text)}.alert-danger,.alert-error{background:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error-text)}.alert-warning{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning-text)}.alert-info{background:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info-text)}.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--muted)}.loading-screen{flex:1;display:flex;align-items:center;justify-content:center;min-height:100vh}.skeleton{background:linear-gradient(90deg,var(--field-bg) 25%,var(--field-hover) 50%,var(--field-bg) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:40px 20px;color:var(--muted)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-title{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--text)}.empty-state-description{font-size:14px;line-height:1.5}.modal-overlay{background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.modal-content{border-radius:var(--radius-xl);background:var(--panel-solid);border:1px solid var(--border);box-shadow:var(--shadow-lg)}.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(var(--blur));-webkit-backdrop-filter:blur(var(--blur));background:linear-gradient(to bottom,#ffffff8c,#ffffff47);border-bottom:1px solid var(--border)}[data-theme=dark] .topbar{background:linear-gradient(to bottom,#0a0c12bf,#0a0c1259)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]):not([data-theme=dark]) .topbar{background:linear-gradient(to bottom,#0a0c12bf,#0a0c1259)}}.topbar-inner{max-width:1200px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap}.divider{display:flex;align-items:center;margin:16px 0;color:var(--muted)}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.divider span{padding:0 16px;font-size:.875rem}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.photo-grid-item{aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform .2s ease}.photo-grid-item:hover{transform:scale(1.02)}.photo-grid-item img{width:100%;height:100%;object-fit:cover}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000}.lightbox img{max-width:90vw;max-height:90vh;object-fit:contain}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.main-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:24px}.toast-container{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 24px;border-radius:var(--radius-sm);color:#fff;font-weight:500;cursor:pointer;animation:slideIn .3s ease}.toast-success{background-color:var(--accent-2)}.toast-error{background-color:var(--danger)}.toast-warning{background-color:var(--warning)}.toast-info{background-color:var(--accent)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}
