:root{--primary-color: #1e3a8a;--primary-hover-color: #1d4ed8;--primary-rgb: 30, 58, 138;--primary-light: #f1f5f9;--accent-color: #0369a1;--accent-hover: #0284c7;--background-color: #fafbfe;--background-secondary: #f1f5f9;--card-background: #ffffff;--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(30, 58, 138, .08);--glass-blur: blur(12px);--glass-blur-light: blur(8px);--surface-elevation: 0 4px 12px -2px rgba(0, 0, 0, .06), 0 2px 4px -1px rgba(0, 0, 0, .03);--text-color: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-light: #cbd5e1;--border-color: #e2e8f0;--border-light: #f1f5f9;--border-subtle: rgba(30, 58, 138, .05);--success-color: #10b981;--success-light: #d1fae5;--error-color: #ef4444;--error-light: #fee2e2;--warning-color: #f59e0b;--warning-light: #fef3c7;--info-color: #3b82f6;--info-light: #dbeafe;--hover-overlay: rgba(30, 58, 138, .04);--active-overlay: rgba(124, 58, 237, .08);--focus-ring: none;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-family: "Vazirmatn", ui-sans-serif, system-ui, sans-serif;--font-mono: ui-monospace, "Cascadia Code", "Fira Code", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal: 1040;--z-popover: 1050;--z-tooltip: 1060;--z-sidebar: 1100}*{box-sizing:border-box;margin:0;padding:0}*:focus-visible{outline:none}input:focus,textarea:focus,select:focus{outline:none!important;box-shadow:none!important;border-color:var(--primary-color)!important}*{-webkit-tap-highlight-color:transparent}*:focus{outline:none!important;box-shadow:none!important}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--text-color);background:linear-gradient(135deg,var(--background-color) 0%,var(--background-secondary) 100%);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;max-width:1400px;margin:0 auto;min-height:100vh}.page-container{display:flex;align-items:flex-start;gap:var(--space-xl);padding:var(--space-lg);min-height:100vh}@media (min-width: 1025px){.page-container{flex-direction:row!important;padding:var(--space-lg)!important;gap:var(--space-xl)!important;background:none!important}}@media (max-width: 768px){.page-container{flex-direction:column;gap:var(--space-lg);padding:var(--space-md)}}.sidebar{flex:0 0 280px;background:linear-gradient(145deg,#fffffffa,#f8fafcf2);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(226,232,240,.8);border-radius:20px;box-shadow:0 8px 32px #0000000f,0 2px 8px #0000000a;position:sticky;top:var(--space-lg);max-height:calc(100vh - var(--space-2xl));overflow:hidden;display:flex;flex-direction:column;transition:all .4s cubic-bezier(.16,1,.3,1)}.sidebar:hover{box-shadow:0 12px 40px #00000014,0 4px 12px #0000000f}@media (min-width: 1025px){.sidebar{position:sticky!important;transform:none!important;right:auto!important;top:var(--space-lg)!important;width:300px!important;max-width:none!important;height:auto!important;max-height:calc(100vh - var(--space-2xl))!important;z-index:auto!important;display:flex!important;flex-direction:column!important}.sidebar .sidebar-header,.sidebar .folder-tree{display:block!important}.sidebar .sidebar-header{padding:var(--space-xl) var(--space-lg) var(--space-lg)!important;border-bottom:1px solid var(--border-light)!important;background:linear-gradient(145deg,rgba(30,58,138,.02),transparent)!important}.sidebar .sidebar-header h2{font-size:var(--font-size-xl)!important;font-weight:700!important;color:var(--text-color)!important;margin-bottom:var(--space-md)!important;display:flex!important;align-items:center!important;gap:var(--space-sm)!important}}.sidebar-header{padding:1.25rem 1rem 1rem;border-bottom:1px solid rgba(226,232,240,.5);background:linear-gradient(180deg,rgba(248,250,252,.5),transparent)}@media (min-width: 1025px){.sidebar-header{display:block!important;position:relative}.close-sidebar-button{display:none!important}}.sidebar-header h2{font-size:1.125rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 .875rem;display:flex;align-items:center;gap:.5rem;letter-spacing:-.01em}.sidebar-header h2:before{content:"📚";font-size:1.25rem;background:none;-webkit-text-fill-color:initial;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.sidebar-header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.import-json-button{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--hover-overlay);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);position:relative}.import-json-button:hover{background:var(--primary-color);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed40}.import-json-button svg{width:20px;height:20px;stroke-width:2}.sidebar-top-actions{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--border-light);background:#ffffff80;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sidebar-export-button{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.sidebar-export-button:hover{background:var(--primary-hover-color);transform:translateY(-1px)}.sidebar-export-button svg{width:16px;height:16px}.close-sidebar-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:#ffffffe6;color:#64748b;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);z-index:10;box-shadow:0 2px 8px #0000001a}.close-sidebar-button:hover{background:#ef44441a;color:#dc2626;transform:scale(1.05)}.close-sidebar-button svg{width:18px;height:18px;opacity:1!important;visibility:visible!important;color:inherit;stroke:currentColor;stroke-width:2;flex-shrink:0}@media (max-width: 768px){.sidebar{position:fixed;top:0;right:-100%;width:85vw;max-width:320px;height:100vh;max-height:none;z-index:var(--z-modal);transition:right var(--transition-base);border-radius:0;border-right:none}.sidebar.open{right:0}.close-sidebar-button{display:flex;align-items:center;justify-content:center}}.main-wrapper{flex:1;min-width:0;padding:var(--space-md);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:var(--radius-xl);border:var(--glass-border);margin:var(--space-sm);overflow:hidden}@media (min-width: 1025px){.main-wrapper{padding:var(--space-md)!important;margin:var(--space-sm)!important;padding-bottom:var(--space-md)!important;width:auto!important}}main{display:flex;flex-direction:column;gap:var(--space-lg);height:100%}.empty-view-message{text-align:center;color:var(--text-secondary);padding:var(--space-4xl) var(--space-xl);background:var(--surface-primary);border-radius:var(--radius-lg);border:2px dashed var(--border-secondary);margin:var(--space-lg);position:relative;overflow:hidden}.empty-view-message:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent 0%,var(--primary-light) 50%,transparent 100%);opacity:.02;pointer-events:none}.home-page-container{padding:var(--space-2xl) var(--space-xl);max-width:1200px;margin:0 auto}.home-page-welcome{text-align:center;margin-bottom:var(--space-3xl);animation:fadeInDown .6s cubic-bezier(.16,1,.3,1)}.home-page-welcome h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-md)}.home-page-welcome p{font-size:1.125rem;color:var(--text-secondary);font-weight:400}.home-page-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;margin-top:.5rem}.home-card{background:linear-gradient(145deg,#fffffffa,#f8fafcf2);border:1px solid rgba(226,232,240,.8);border-radius:12px;padding:.9rem;cursor:pointer;transition:transform .22s cubic-bezier(.16,1,.3,1),box-shadow .22s;box-shadow:0 6px 18px #0000000a;display:flex;align-items:center;gap:.75rem;position:relative;overflow:hidden;animation:fadeInUp .52s cubic-bezier(.16,1,.3,1) both}.home-card:nth-child(1){animation-delay:.1s}.home-card:nth-child(2){animation-delay:.2s}.home-card:nth-child(3){animation-delay:.3s}.home-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--primary-dark));transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.16,1,.3,1)}.home-card:hover{transform:translateY(-8px);box-shadow:0 12px 32px #00000014,0 4px 12px #0000000a;border-color:var(--primary)}.home-card:hover:before{transform:scaleX(1);transform-origin:left}.home-card:active{transform:translateY(-4px)}.home-card.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.home-card-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease}.home-card-icon svg{width:26px;height:26px;stroke-width:1.8}.home-card:hover .home-card-icon{transform:scale(1.06) rotate(-4deg)}.home-card-icon.questions-icon{background:linear-gradient(135deg,#3b82f61f,#2563eb1f);color:#2563eb}.home-card-icon.highlights-icon{background:linear-gradient(135deg,#f59e0b26,#d9770626);color:#f59e0b}.home-card-icon.bookmarks-icon{background:linear-gradient(135deg,#ef444426,#dc262626);color:#ef4444}.home-card-content{flex:1;min-width:0}.home-card-content h3{font-size:1rem;font-weight:700;color:var(--text-color);margin:0;overflow:hidden;text-overflow:ellipsis}.home-card-content p{font-size:.85rem;color:var(--text-secondary);line-height:1.25;margin:.125rem 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-card-stat{display:none}.home-card-arrow{margin-left:.5rem;width:32px;height:32px;border-radius:8px;background:#3b82f60f;display:inline-flex;align-items:center;justify-content:center;color:var(--primary);transition:transform .16s ease,background .16s ease}.home-card:hover .home-card-arrow{background:var(--primary-hover-color);color:#fff;transform:translate(-2px)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.home-page-welcome h1{font-size:2rem}.home-page-welcome p{font-size:1rem}.home-page-cards{grid-template-columns:1fr;gap:var(--space-lg)}.home-card{padding:.75rem;gap:.5rem}.home-card-icon{width:40px;height:40px}.home-card-icon svg{width:22px;height:22px}.home-card-content h3{font-size:.95rem}}.empty-archive-message{text-align:center;color:var(--text-secondary);padding:var(--space-xl);background:var(--card-background);border-radius:var(--radius-md);border:1px solid var(--border-color);margin:var(--space-md);font-size:var(--font-size-sm);line-height:1.5}.search-container{display:flex;flex-direction:column;padding-bottom:.25rem;border-bottom:1px solid var(--border-secondary);margin-bottom:.25rem;position:relative}.search-input-group{flex-grow:1;display:flex;background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);-webkit-backdrop-filter:var(--glass-blur-light);backdrop-filter:var(--glass-blur-light);position:relative;overflow:hidden}.search-input-group:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--primary-light),transparent);opacity:0;transition:var(--transition-smooth)}.search-input-group:focus-within{border-color:var(--primary-color);box-shadow:none}.search-input-group:focus-within:before{opacity:1}.search-field-main{display:flex;align-items:center;gap:var(--space-sm);position:relative;flex:1 1 auto;padding:0 var(--space-md)}.search-field-main svg{color:var(--text-tertiary);flex-shrink:0;transition:var(--transition-smooth)}.search-input-group:focus-within .search-field-main svg{color:var(--primary)}.search-input-group input{border:none;outline:none;background:transparent;padding:calc(var(--space-sm) + 4px) 0;font-size:.98rem;font-family:var(--font-family);font-weight:500;width:100%;color:var(--text-primary);transition:var(--transition-smooth)}.search-input-group input::placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.clear-search-button{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:var(--space-sm);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:var(--transition-smooth);margin-right:var(--space-sm)}.clear-search-button:hover{color:var(--text-primary);background:var(--surface-hover);transform:scale(1.1)}.advanced-search-toggle{flex-shrink:0;background:none;border:none;border-right:1px solid var(--border-primary);cursor:pointer;color:var(--text-tertiary);padding:0 var(--space-md);display:flex;align-items:center;justify-content:center;transition:var(--transition-smooth);position:relative}.advanced-search-toggle:before{content:"";position:absolute;right:0;top:20%;bottom:20%;width:1px;background:var(--border-primary);transition:var(--transition-smooth)}.advanced-search-toggle:hover,.advanced-search-toggle.active{color:var(--primary);background:var(--surface-hover)}.advanced-search-toggle:hover:before,.advanced-search-toggle.active:before{background:var(--primary)}.advanced-search-panel{display:flex;gap:var(--space-md);padding:var(--space-lg);background:var(--surface-secondary);border-radius:var(--radius-lg);margin-top:var(--space-md);border:1px solid var(--border-primary);-webkit-backdrop-filter:var(--glass-blur-light);backdrop-filter:var(--glass-blur-light);box-shadow:var(--shadow-sm);animation:slideDown var(--duration-normal) var(--ease-smooth)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.advanced-search-panel .form-group{padding-bottom:0}.advanced-search-panel .form-group input{font-size:var(--text-sm);background:var(--surface-primary);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--space-md);transition:var(--transition-smooth)}.advanced-search-panel .form-group input:focus{border-color:var(--primary-color);box-shadow:none}.search-results-container{margin-top:var(--space-lg);padding-bottom:60px}.search-results-header{display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:var(--space-lg);margin-bottom:var(--space-xl);padding:var(--space-md) 0;border-bottom:1px solid var(--border-secondary)}.floating-toolbar{position:fixed;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--surface-elevation);z-index:var(--z-fixed);-webkit-user-select:none;user-select:none;padding:var(--space-xs);display:flex;will-change:transform;contain:none;transition:width .25s ease,height .25s ease,border-radius .25s ease;overflow:visible}.floating-toolbar.dragging{transition:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;box-shadow:0 4px 12px #00000026;z-index:calc(var(--z-fixed) + 10)}.floating-toolbar.drag-perf-mode{pointer-events:none}.floating-toolbar.drag-perf-mode .secondary-action-button,.floating-toolbar.drag-perf-mode .toolbar-drag-handle,.floating-toolbar.drag-perf-mode .toolbar-close-btn{cursor:grabbing!important}.floating-toolbar.drag-perf-mode .secondary-action-button:hover,.floating-toolbar.drag-perf-mode .toolbar-drag-handle:hover{transform:none!important}.floating-toolbar.dragging *{transition:none!important}.floating-toolbar.collapsed{width:48px;height:48px;border-radius:50%;padding:0;cursor:pointer;align-items:center;justify-content:center;background:var(--primary);border:none;box-shadow:0 4px 16px #1e3a8a4d;transition:transform .2s ease,box-shadow .2s ease}.floating-toolbar.collapsed:hover{transform:scale(1.1);box-shadow:0 8px 24px #1e3a8a66}.floating-toolbar.vertical{flex-direction:column;width:50px;min-height:100px;border-radius:25px}.floating-toolbar.horizontal{flex-direction:row;height:50px;min-width:140px;border-radius:25px}.toolbar-header{display:none}.toolbar-drag-handle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:grab;transition:background-color .2s ease,transform .2s ease;flex-shrink:0;position:relative;order:-1;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.floating-toolbar.vertical .toolbar-drag-handle{margin-bottom:var(--space-xs);align-self:center}.floating-toolbar.horizontal .toolbar-drag-handle{margin-right:var(--space-xs);align-self:center}.toolbar-drag-handle:hover{background:#fff3;transform:scale(1.05)}.toolbar-drag-handle:active,.toolbar-drag-handle.dragging,.floating-toolbar.dragging .toolbar-drag-handle{cursor:grabbing!important;background:#ffffff4d;transform:scale(.95)}.toolbar-drag-handle:before{content:"";width:3px;height:3px;background:currentColor;border-radius:50%;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);box-shadow:-4px -4px 0 currentColor,0 -4px 0 currentColor,4px -4px 0 currentColor,-4px 0 0 currentColor,4px 0 0 currentColor,-4px 4px 0 currentColor,0 4px 0 currentColor,4px 4px 0 currentColor;opacity:.8}.toolbar-close-btn{position:absolute;top:-10px;right:-10px;background:var(--error-color);color:#fff;border:2px solid white;border-radius:50%;width:24px;height:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;line-height:1;padding:0;opacity:0;transform:scale(.8);z-index:10;box-shadow:0 2px 8px #0003;clip-path:none}.floating-toolbar:hover .toolbar-close-btn{opacity:1;transform:scale(1)}.toolbar-close-btn:hover{background:#dc2626;transform:scale(1.1);box-shadow:0 4px 12px #0000004d}.toolbar-content{display:flex;gap:var(--space-xs);align-items:center;position:relative;width:100%;height:100%;transition:flex-direction .6s cubic-bezier(.23,1,.32,1)}.floating-toolbar.vertical .toolbar-content{flex-direction:column;align-items:center}.floating-toolbar.horizontal .toolbar-content{flex-direction:row;align-items:center}.floating-toolbar.collapsed .toolbar-content{display:none}.toolbar-expand-btn{display:none;background:none;color:#fff;border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;transition:all .2s ease;font-size:18px;align-items:center;justify-content:center}.floating-toolbar.collapsed .toolbar-expand-btn{display:flex}.toolbar-expand-btn:hover{transform:scale(1.1)}.floating-toolbar.vertical .header-actions,.floating-toolbar.horizontal .header-actions{gap:var(--space-xs);align-items:center;transition:flex-direction .6s cubic-bezier(.23,1,.32,1)}.floating-toolbar.vertical .header-actions{flex-direction:column}.floating-toolbar.horizontal .header-actions{flex-direction:row}.floating-toolbar .items-per-page-selector{display:none}.floating-toolbar .secondary-action-button.icon-button{width:32px;height:32px;padding:var(--space-xs);margin:0;border-radius:var(--radius-sm);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);transition:background-color .2s ease,transform .2s ease;cursor:pointer}.floating-toolbar .secondary-action-button.icon-button:hover{background:#fff3;transform:translateY(-1px)}.floating-toolbar .secondary-action-button.icon-button:active{transform:translateY(0)}.floating-toolbar .secondary-action-button.icon-button.active{background:#1f2937;border-color:#1f2937;color:#fff}.floating-toolbar .secondary-action-button.icon-button.active svg{color:#fff!important;opacity:1!important;visibility:visible!important;fill:#fff!important;stroke:#fff!important;stroke-width:2!important}.floating-toolbar .secondary-action-button.icon-button svg{width:14px;height:14px}@keyframes toolbarSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toolbarCollapse{0%{opacity:1;transform:scale(1)}to{opacity:1;transform:scale(1)}}.floating-toolbar{animation:toolbarSlideIn .3s cubic-bezier(.4,0,.2,1)}.header-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.header-actions .secondary-action-button.icon-button:focus svg,.header-actions .secondary-action-button.icon-button:active svg{color:var(--text-primary);opacity:1;visibility:visible}.icon-button svg,.secondary-action-button svg{opacity:1!important;visibility:visible!important}.icon-button:focus svg,.icon-button:active svg,.secondary-action-button:focus svg,.secondary-action-button:active svg{opacity:1!important;visibility:visible!important}.icon-button.active svg,.secondary-action-button.active svg{opacity:1!important;visibility:visible!important;color:#fff!important;fill:#fff!important;stroke:#fff!important;stroke-width:2!important}.items-per-page-selector{display:flex;align-items:center;gap:var(--space-sm);background:var(--surface-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.items-per-page-selector label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:var(--font-medium)}.items-per-page-selector select{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--surface-primary);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary);transition:var(--transition-smooth)}.items-per-page-selector select:focus{outline:none;border-color:var(--primary-color);box-shadow:none}.icon-button.active{background:#1f2937;border-color:#1f2937;color:#fff;font-weight:var(--font-semibold);box-shadow:var(--shadow-md);transform:translateY(-1px)}.icon-button.active svg{color:#fff!important;fill:#fff!important;stroke:#fff!important;stroke-width:2!important;opacity:1!important;visibility:visible!important}.edit-mode-banner{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);background:linear-gradient(135deg,#fef9c3,#fde047);color:#a16207;border:1px solid #fde047;border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur-light);backdrop-filter:var(--glass-blur-light);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.edit-mode-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#a16207,transparent)}.edit-mode-banner svg{flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(161,98,7,.2))}.folder-tree{display:flex;flex-direction:column}.folder-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .625rem;cursor:pointer;border-radius:10px;transition:all .3s cubic-bezier(.16,1,.3,1);-webkit-user-select:none;user-select:none;position:relative}.folder-header:hover{background-color:#64748b14;transform:translate(-2px)}.folder-name{font-weight:500;flex-grow:1;font-size:.9375rem}.chevron-icon{transition:transform .4s cubic-bezier(.16,1,.3,1);color:var(--secondary-text-color);flex-shrink:0}.folder.expanded>.folder-header .chevron-icon{transform:rotate(90deg)}.folder.level-1>.folder-header{font-size:1rem;font-weight:700;color:var(--text-color);padding:.625rem .75rem}.folder.level-1>.folder-header:hover{background:linear-gradient(135deg,#3b82f614,#2563eb0d)}.folder.level-2>.folder-header,.folder.level-3>.folder-header{color:#334155;font-size:.9375rem}.folder.level-3.active>.folder-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 2px 8px #3b82f640;transform:translate(-2px)}.folder.level-3.active>.folder-header .chevron-icon{color:#fff}.folder.level-3{position:relative;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.folder.level-3.deleting>.folder-header{background-color:var(--error-light);border-color:var(--error-color);cursor:progress;animation:pulse-delete .5s ease-in-out infinite}@keyframes pulse-delete{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.delete-progress-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background-color:#ef444433;border-radius:0 0 var(--radius-sm) var(--radius-sm);overflow:hidden}.delete-progress-fill{height:100%;background:linear-gradient(90deg,#f87171,#ef4444);transition:width 20ms linear;box-shadow:0 0 8px #ef444499}.folder-content{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s ease;padding-right:1.75rem;opacity:0}.folder.expanded>.folder-content{max-height:3000px;opacity:1}.delete-folder-button{position:absolute;left:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--error-color);cursor:pointer;opacity:0;transition:all .2s;padding:5px;display:flex;align-items:center;justify-content:center;border-radius:50%}.folder-header:hover .delete-folder-button{opacity:.6}.folder.level-3.active>.folder-header:hover .delete-folder-button{color:#fff;opacity:.8}.delete-folder-button:hover{opacity:1;color:var(--error-hover-color);background-color:#fee2e2}.folder.level-3.active>.folder-header .delete-folder-button:hover{background-color:#fff3}.form-group{flex:1 1 200px;display:flex;flex-direction:column;text-align:right;position:relative;padding-bottom:1.2rem}.form-group label{margin-bottom:.5rem;font-weight:500;font-size:.9rem;color:var(--secondary-text-color)}.form-group input,.form-group select{padding:var(--space-md);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-medium);width:100%;background:var(--surface-primary);color:var(--text-primary);transition:var(--transition-smooth);box-shadow:var(--shadow-sm)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:none;background:var(--surface-primary)}.form-group input::placeholder{color:var(--text-tertiary);font-weight:var(--font-normal)}.validation-error{color:var(--error-color);font-size:.8rem;position:absolute;bottom:0;right:.2rem;line-height:1.2rem}.autocomplete-wrapper{position:relative}.autocomplete-suggestions{position:absolute;top:100%;left:0;right:0;background-color:var(--card-background);border:1px solid var(--border-color);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #00000014;z-index:100;max-height:220px;overflow-y:auto;list-style-type:none}.autocomplete-suggestions li{padding:.75rem 1rem;cursor:pointer;transition:background-color .2s;text-align:right;font-size:.95rem}.autocomplete-suggestions li:hover{background-color:var(--folder-hover-bg)}.modal-content .autocomplete-suggestions{z-index:1002}button{background-color:var(--primary-color);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-family:var(--font-family);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .3s,transform .2s;align-self:center}button:hover:not(:disabled){background-color:var(--primary-hover-color);transform:translateY(-2px)}button:disabled{background-color:#94a3b8;cursor:not-allowed;transform:none}.secondary-button{background-color:var(--secondary-button-color)}.secondary-button:hover:not(:disabled){background-color:var(--secondary-button-hover-color)}.question-list-detail{display:flex;flex-direction:column;gap:1.5rem}.question-item-detail{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;transition:box-shadow .2s}.question-item-detail:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.question-header{display:flex;justify-content:flex-start;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(226,232,240,.6)}.question-number{font-weight:700;color:var(--primary-color);margin:0;font-size:1.125rem;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;display:flex;align-items:center;gap:.375rem;flex-shrink:0}.question-header h4{font-weight:700;color:var(--primary-color);margin-bottom:0;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;flex-grow:1}.exam-info-compact{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:6px;font-size:.75rem;font-weight:500;background:#64748b14;color:#64748b;border:1px solid rgba(100,116,139,.12);white-space:nowrap;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.exam-info-badges{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;flex:1}.exam-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border-radius:6px;font-size:.8125rem;font-weight:500;background:#64748b14;color:#475569;border:1px solid rgba(100,116,139,.15);transition:all .2s ease}.exam-badge svg{flex-shrink:0;opacity:.7}.exam-badge:hover{background:#64748b1f;border-color:#64748b40}.question-header-meta{font-weight:400;font-size:.9rem;color:var(--secondary-text-color);margin-right:.5rem}.question-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;margin-left:auto}.question-header-actions .action-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid rgba(100,116,139,.15);background:#f8fafc80;color:#64748b;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.question-header-actions .action-btn svg{width:16px;height:16px}.question-header-actions .action-btn:hover{background:#64748b1a;border-color:#64748b40;color:#475569;transform:translateY(-1px)}.question-header-actions .action-btn.active,.question-header-actions .action-btn.has-note{background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-color:var(--primary);color:#fff}.question-header-actions .action-btn.active:hover,.question-header-actions .action-btn.has-note:hover{background:linear-gradient(135deg,var(--primary-dark),#1e3a8a);box-shadow:0 2px 8px #3b82f64d}@media (max-width: 768px){.question-header{flex-wrap:nowrap;gap:.5rem}.question-number{font-size:1rem}.exam-info-compact{font-size:.7rem;padding:.2rem .4rem;max-width:150px}.exam-info-badges{order:2;width:100%;margin-top:.25rem}.exam-badge{font-size:.75rem;padding:.25rem .5rem;gap:.25rem}.exam-badge svg{width:10px;height:10px}.question-header-actions{order:1;margin-left:auto}.question-header-actions .action-btn{width:30px;height:30px}.question-header-actions .action-btn svg{width:14px;height:14px}}.per-question-edit{padding:.6rem}@keyframes fadeInOut{0%,to{opacity:0;transform:translateY(5px)}20%,80%{opacity:1;transform:translateY(0)}}.copy-success-indicator{position:relative;display:inline-flex;align-items:center;font-size:.75rem;font-weight:500;color:var(--primary);animation:fadeInOut 2s ease-in-out forwards}.question-text{line-height:1.8;color:var(--text-color);white-space:pre-wrap;word-wrap:break-word;margin-top:1rem;margin-bottom:1.5rem}.options-list{list-style-type:none;padding:0;display:flex;flex-direction:column;gap:.5rem}.options-list li{padding:.75rem 1rem;border-radius:8px;background-color:var(--folder-hover-bg);border:1px solid var(--border-color);transition:background-color .2s,border-color .2s;display:flex;align-items:center;gap:.75rem}.option-letter{font-weight:500}.option-text{flex:1}.options-list li.correct-answer{background-color:#dcfce7;border-color:var(--success-color);font-weight:500;color:#15803d}.options-list li.incorrect-answer{background-color:#fee2e2;border-color:var(--error-color);font-weight:500;color:#b91c1c}.options-list.quiz-mode li{cursor:pointer}.options-list.quiz-mode li:hover{background-color:#eff6ff;border-color:var(--primary-color)}.options-list.edit-mode li{cursor:pointer;transition:background-color .2s,border-color .2s,transform .1s,box-shadow .2s}.options-list.edit-mode li:hover{background-color:#dbeafe;border-color:var(--primary-color);transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.options-list.edit-mode li:active{transform:translateY(0)}.options-list.edit-mode li.correct-answer:hover{background-color:#bbf7d0;border-color:#16a34a}.correct-answer-icon{color:var(--success-color);margin-right:auto;flex-shrink:0}.incorrect-answer-icon{color:var(--error-color);margin-right:auto;flex-shrink:0}.question-actions{margin-top:var(--space-xl);display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:flex-start;flex-direction:row-reverse;align-items:center}.question-actions button{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);align-self:initial}.secondary-action-button{background:var(--surface-primary);color:var(--text-secondary);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:var(--space-sm);transition:var(--transition-smooth);border-radius:var(--radius-md);font-weight:var(--font-medium);-webkit-backdrop-filter:var(--glass-blur-light);backdrop-filter:var(--glass-blur-light);position:relative;overflow:hidden}.secondary-action-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--primary-light),var(--primary));opacity:0;transition:var(--transition-smooth)}.secondary-action-button:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-hover);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.secondary-action-button:hover:not(:disabled):before{opacity:.05}.secondary-action-button:focus,.secondary-action-button:active{outline:none;background:var(--surface-hover);border-color:var(--primary-color);color:var(--text-primary);transform:translateY(-1px);box-shadow:none}.secondary-action-button:focus svg,.secondary-action-button:active svg{opacity:1!important;visibility:visible!important}.secondary-action-button.active{background:#1f2937!important;border-color:#1f2937!important;color:#fff!important}.secondary-action-button.active svg{color:#fff!important;opacity:1!important;visibility:visible!important;fill:#fff!important;stroke:#fff!important;stroke-width:2!important}.secondary-action-button:disabled{background:var(--surface-disabled);color:var(--text-disabled);cursor:not-allowed;transform:none;opacity:.6}.secondary-action-button.copied{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:var(--success);color:#15803d;box-shadow:var(--shadow-success)}.secondary-action-button.icon-button{padding:var(--space-md);gap:0;width:44px;height:44px;justify-content:center;border-radius:var(--radius-lg);display:flex;align-items:center}.secondary-action-button.icon-button svg{width:18px;height:18px;flex-shrink:0;opacity:1;visibility:visible;transition:var(--transition-smooth)}.question-actions .secondary-action-button.icon-button{padding:var(--space-sm);width:40px;height:40px;align-self:center}.question-actions .secondary-action-button.icon-button svg{width:16px;height:16px;opacity:1;visibility:visible;transition:var(--transition-smooth)}.bookmark-button svg,.note-button svg{transition:var(--transition-smooth);fill:none}.bookmark-button.bookmarked{color:var(--warning);background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:var(--warning)}.bookmark-button.bookmarked svg{fill:var(--warning)!important;stroke:var(--warning)!important;opacity:1!important;visibility:visible!important}.bookmark-button:hover:not(.bookmarked){color:#ca8a04;background:var(--surface-warning)}.note-button.has-note{color:#854d0e;background:linear-gradient(135deg,#fefce8,#fef9c3);border-color:#facc15}.note-button.has-note svg{fill:#fefce8}.note-button:hover:not(.has-note){color:#a16207;background:var(--surface-warning)}.question-notes-display{margin-top:1.5rem;padding:1rem;background-color:#fefce8;border-radius:8px;border:1px solid #fde047}.question-notes-editor{margin-top:1.5rem;padding:1rem;background-color:#fefce8;border-radius:8px;border:1px solid #fde047;display:flex;gap:.5rem;align-items:flex-start}.question-notes-display{cursor:pointer;transition:border-color .2s,background-color .2s}.question-notes-display:hover{background-color:#fef9c3;border-color:#facc15}.question-notes-display h5{font-size:.9rem;font-weight:700;color:#a16207;margin:0 0 .5rem}.question-notes-display p{line-height:1.7;color:#854d0e;white-space:pre-wrap;word-wrap:break-word;margin:0}.question-notes-editor textarea{min-height:100px;border:none;background:transparent;padding:0;font-family:var(--font-family);font-size:1rem;line-height:1.7;color:#854d0e;resize:vertical;flex-grow:1}.question-notes-editor textarea:focus{outline:none;box-shadow:none}.note-mic-button{flex-shrink:0;align-self:flex-start}.note-mic-button.recording{background-color:#fee2e2;color:var(--error-color);animation:pulse 2s infinite}.results-footer{position:sticky;bottom:0;z-index:100;display:flex;justify-content:center;align-items:center;margin-top:var(--space-md);padding:var(--space-md) var(--space-xl);background:linear-gradient(180deg,#fffffff2,#fffffffa);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:2px solid var(--border-secondary);box-shadow:0 -4px 16px #00000014,0 -2px 8px #0000000a;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.pagination-summary,.pagination-text,.pagination-range,.pagination-total,.show-all-toggle{display:none}.show-all-toggle svg{display:none}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--radius-xl);border:2px solid #e2e8f0;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a;min-width:auto;max-width:600px}.pagination-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #3b82f64d,0 2px 4px #3b82f633;flex-shrink:0}.pagination-btn .btn-text{display:none}.pagination-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #3b82f666,0 3px 8px #3b82f64d;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.pagination-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.pagination-btn:disabled{background:linear-gradient(135deg,#cbd5e1,#94a3b8);color:#e2e8f0;cursor:not-allowed;opacity:.5;box-shadow:none}.pagination-btn svg{width:22px;height:22px;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.pagination-info{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,#fff,#f8fafc);border-radius:var(--radius-lg);font-weight:var(--font-semibold);color:var(--text-primary);box-shadow:inset 0 2px 4px #0000000f,0 1px 2px #0000000d;border:2px solid #e2e8f0;white-space:nowrap;flex-shrink:0}.pagination-label{font-size:var(--text-base);color:#1e40af;font-weight:var(--font-bold);letter-spacing:.3px}.pagination-divider{font-size:var(--text-sm);color:#64748b;opacity:.8;margin:0 .25rem}.pagination-total-count{font-size:var(--text-sm);color:#475569;font-weight:var(--font-medium)}.pagination-pages,.current-page,.page-separator,.total-pages{display:none}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0f172a99;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:slideIn .3s;-webkit-backdrop-filter:none;backdrop-filter:none;opacity:1}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-header h3{margin:0;font-size:1.2rem;color:var(--text-color)}.close-button{background:none;border:none;color:var(--secondary-text-color);cursor:pointer;padding:.5rem;line-height:1;align-self:initial;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s,background-color .2s}.close-button:hover{color:var(--text-color);background-color:var(--folder-hover-bg);transform:none}.close-button svg{width:24px;height:24px}.modal-body{padding:1.5rem;overflow-y:auto;flex-grow:1;background-color:#fff;opacity:1}p.metadata-prompt{line-height:1.7;margin:0 0 1.5rem;text-align:center;font-size:.95rem}p.metadata-prompt strong{font-weight:700;color:var(--primary-hover-color)}.modal-actions{padding:1rem 1.5rem;border-top:1px solid var(--border-color);text-align:left;display:flex;gap:1rem;justify-content:flex-start;flex-shrink:0;background-color:var(--folder-hover-bg);border-radius:0 0 12px 12px}.modal-actions button{align-self:initial}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translateY(-20px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.metadata-modal-content{max-width:650px}.metadata-form{display:flex;flex-wrap:wrap;gap:1rem;width:100%;align-items:flex-start}.metadata-form .form-group{padding-bottom:1.2rem;flex-grow:1;flex-shrink:1}.metadata-form .form-group.subject{flex-basis:220px}.metadata-form .form-group.year{flex-basis:120px}.metadata-form .form-group.group{flex-basis:180px}.glass-chip-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.75rem}.glass-chip{position:relative;display:flex;flex-direction:column;gap:4px;padding:.65rem .9rem .55rem;min-width:120px;border-radius:14px;background:linear-gradient(135deg,#ffffff8c,#ffffff40);-webkit-backdrop-filter:blur(10px) saturate(1.3);backdrop-filter:blur(10px) saturate(1.3);border:1px solid rgba(255,255,255,.4);box-shadow:0 4px 12px -2px #0f172a1f,0 2px 4px #0f172a14;cursor:text;transition:box-shadow .25s,border-color .25s,background .25s}.glass-chip:hover:not(.editing){box-shadow:0 6px 16px -2px #0f172a2e,0 3px 8px #0f172a1f}.glass-chip.editing{background:linear-gradient(135deg,#ffffffe6,#ffffff8c);border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f640,0 4px 10px #0f172a1f}.glass-chip.invalid{border-color:var(--error-color)}.glass-chip .chip-label{font-size:.65rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--secondary-text-color);opacity:.9;pointer-events:none;-webkit-user-select:none;user-select:none}.glass-chip .chip-value,.glass-chip .chip-input{font-size:.85rem;font-weight:500;line-height:1.2;color:var(--text-color)}.glass-chip .chip-value.placeholder{color:var(--secondary-text-color);font-weight:400}.glass-chip .chip-error{position:absolute;top:4px;left:6px;width:18px;height:18px;border-radius:50%;background:var(--error-color);color:#fff;font-size:.65rem;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 2px 4px #00000040;cursor:help}.glass-chip .chip-input{background:transparent;border:none;outline:none;padding:0;margin:0;font-family:var(--font-family);width:100%}.glass-chip .chip-input::placeholder{color:var(--secondary-text-color);font-weight:400}.glass-chip.page-chip .chip-value.error{color:var(--error-color);font-weight:600}.page-error-inline{margin-top:.75rem;font-size:.7rem;color:var(--error-color);text-align:center;font-weight:500}@media (max-width: 640px){.glass-chip-row{gap:.6rem}.glass-chip{flex:1 1 calc(50% - .6rem);min-width:0}}.loader{border:4px solid var(--folder-hover-bg);border-top:4px solid var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}.loader.small{width:20px;height:20px;border-width:3px}.sidebar-sync-compact.loading{opacity:.9}.sidebar-sync-compact .sidebar-sync-inner{display:flex;align-items:center;gap:.5rem}.sidebar-sync-compact .sync-indicator.loading{width:10px;height:10px;border-radius:50%;background:linear-gradient(90deg,var(--primary-color),var(--accent-color));box-shadow:0 0 8px rgba(var(--primary-rgb),.35);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%{transform:scale(.85);opacity:.8}50%{transform:scale(1.15);opacity:1}to{transform:scale(.85);opacity:.8}}.sync-loading-overlay{position:fixed;bottom:20px;right:20px;z-index:1200;pointer-events:none}.sync-loading-content{background:#fffffff2;border:1px solid var(--border-light);padding:.75rem 1rem;border-radius:12px;display:flex;gap:.75rem;align-items:center;box-shadow:var(--surface-elevation)}.sync-spinner{width:36px;height:36px;border-radius:50%;border:4px solid rgba(0,0,0,.06);border-top:4px solid var(--primary-color);animation:spin 1s linear infinite}.sync-pulse{width:8px;height:8px;border-radius:50%;background:var(--primary-color);box-shadow:0 0 12px #1e3a8a40}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-interaction-area{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-color)}.chat-history{display:flex;flex-direction:column;gap:1rem;max-height:0;overflow-y:auto;padding:0 .5rem;opacity:0;transition:max-height .5s ease-in-out,opacity .3s ease-in-out,padding .5s ease-in-out,margin-bottom .5s ease-in-out;margin-bottom:0}.chat-history.visible{max-height:400px;opacity:1;padding:.5rem;margin-bottom:1rem}.chat-message{padding:.75rem 1rem;border-radius:12px;max-width:85%;line-height:1.7}.chat-message p{margin:0}.chat-message p:not(:last-child){margin-bottom:.5rem}.chat-message.user{background-color:var(--primary-color);color:#fff;align-self:flex-start;border-bottom-right-radius:4px;text-align:right}.chat-message.ai{background-color:var(--folder-hover-bg);color:var(--text-color);align-self:flex-end;border-bottom-left-radius:4px;text-align:right;border:1px solid var(--border-color)}.chat-message.ai strong{font-weight:700;color:var(--primary-hover-color)}.chat-message.ai ul,.chat-message.ai ol{padding-right:1.5rem;margin-top:.5rem;margin-bottom:.5rem}.ai-message-content>p,.ai-message-content>ul,.ai-message-content>ol{margin-bottom:.5rem}.ai-message-content>*:last-child{margin-bottom:0}.ai-message-content p,.ai-message-content li{position:relative;padding:.5rem;border-radius:8px;transition:background-color .2s ease;cursor:pointer;-webkit-tap-highlight-color:transparent}.ai-message-content .ai-paragraph-highlighted{background-color:#eff6ff}.ai-message-content .ai-paragraph-highlighted:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border:2px solid var(--primary-color);border-radius:8px;pointer-events:none}@keyframes flash-border{0%{box-shadow:0 0 #3b82f6b3}50%{box-shadow:0 0 0 4px #3b82f6b3}to{box-shadow:0 0 0 4px #3b82f600}}.flash-highlight{animation:flash-border 2s ease-out}.chat-input-form{display:flex;gap:.5rem;align-items:center}.chat-input-wrapper{flex-grow:1;flex-shrink:1;min-width:0;display:flex;align-items:center;background-color:#fff;border:1px solid var(--border-color);border-radius:8px;transition:border-color .2s,box-shadow .2s;padding:0 .25rem}.chat-input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:none}.chat-input-form input{flex-grow:1;flex-shrink:1;min-width:80px;border:none;background:transparent;padding:.75rem .5rem;font-family:var(--font-family);font-size:.95rem;outline:none;color:var(--text-color)}.chat-input-form input:focus{box-shadow:none}.chat-input-form button[type=submit]{flex-shrink:0;border-radius:var(--radius-md);padding:var(--space-md);line-height:1;transform:none;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary-color);color:#fff;border:none;transition:var(--transition-smooth)}.chat-input-form button[type=submit]:hover:not(:disabled){transform:none;background:var(--primary-hover-color)}.chat-input-form button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.chat-input-form button[type=submit] svg{width:20px;height:20px;opacity:1!important;visibility:visible!important;fill:none;stroke:currentColor}.chat-input-wrapper .secondary-action-button.icon-button{border:none;box-shadow:none;background-color:transparent;padding:var(--space-md);width:44px;height:44px}.chat-input-wrapper .secondary-action-button.icon-button:hover:not(:disabled){background-color:var(--surface-hover);color:var(--text-primary);transform:none}.chat-input-wrapper .secondary-action-button.icon-button svg{width:20px;height:20px}@keyframes pulse{0%{box-shadow:0 0 #ef4444b3}70%{box-shadow:0 0 0 10px #ef444400}to{box-shadow:0 0 #ef444400}}.mic-button.recording{background-color:#fee2e2!important;color:var(--error-color);animation:pulse 2s infinite}@media (max-width: 640px){.chat-input-form{padding:0 .25rem;gap:.25rem;max-width:100%;overflow:visible}.chat-input-wrapper{min-width:0;flex-shrink:1}.chat-input-form input{min-width:60px;flex-shrink:1}.chat-input-form button[type=submit]{width:40px;height:40px;flex-shrink:0;margin-left:.25rem}.chat-input-wrapper .secondary-action-button.icon-button{width:40px;height:40px;padding:.5rem;flex-shrink:0}.ai-settings-container{flex-shrink:0;margin-right:.25rem}}@media (max-width: 380px){.chat-input-form{gap:.15rem}.chat-input-form button[type=submit]{width:36px;height:36px;padding:.5rem;margin-left:.15rem}.chat-input-wrapper .secondary-action-button.icon-button{width:36px;height:36px;padding:.4rem}.chat-input-form button[type=submit] svg,.chat-input-wrapper .secondary-action-button.icon-button svg{width:18px;height:18px}.chat-input-form input{font-size:.875rem;padding:.5rem .4rem}}.ai-settings-container{position:relative;display:flex;flex-shrink:0}.ai-settings-popover{position:absolute;bottom:calc(100% + 8px);left:0;width:220px;background-color:#fff;border-radius:8px;border:1px solid var(--border-light);box-shadow:0 8px 32px #00000014,0 2px 8px #0000000a;z-index:1050;padding:.75rem;display:flex;flex-direction:column;gap:.75rem;animation:slideUp .2s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2)}.ai-settings-popover .setting-group{display:flex;flex-direction:column;gap:.25rem}.ai-settings-popover .setting-group label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.125rem}.ai-settings-popover .segmented-control{display:flex;background-color:var(--border-light);border-radius:6px;padding:2px;width:100%}.ai-settings-popover .segmented-control button{flex:1;padding:.3rem .4rem;border:none;background-color:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);border-radius:4px;transform:none;align-self:initial}.ai-settings-popover .segmented-control button:hover:not(.active){background-color:#1e3a8a0d;color:var(--text-color);transform:none}.ai-settings-popover .segmented-control button.active{background-color:var(--primary-color);color:#fff;box-shadow:0 1px 3px #1e3a8a4d;font-weight:700;box-shadow:0 1px 3px #0000001a;transform:none}.setting-group-divider{height:1px;background-color:var(--border-color);margin:.5rem 0}.ai-settings-popover .toggle-group-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.ai-settings-popover .toggle-switch-container{cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.ai-settings-popover .toggle-switch{position:relative;width:36px;height:20px;background-color:#e2e8f0;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid var(--border-light)}.ai-settings-popover .toggle-switch.active{background-color:var(--primary-color);border-color:var(--primary-color)}.ai-settings-popover .toggle-switch-slider{position:absolute;top:1px;right:1px;width:16px;height:16px;background-color:#fff;border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000001f}.ai-settings-popover .toggle-switch.active .toggle-switch-slider{transform:translate(-16px)}.ai-settings-popover .setting-description{font-size:.8rem;color:var(--secondary-text-color);line-height:1.5;margin-top:.25rem}.ai-settings-popover .setting-group:not(:last-child){border-bottom:1px solid var(--border-light);padding-bottom:1rem;margin-bottom:1rem}.ai-settings-popover .setting-group:first-child{margin-top:0}.chat-message.ai.loading{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;width:auto;min-width:150px}.cancel-chat-button{background-color:transparent;border:1px solid var(--border-color);color:var(--secondary-text-color);padding:.3rem .75rem;font-size:.85rem;border-radius:6px;display:flex;align-items:center;gap:.4rem;transform:none;align-self:center;transition:all .2s ease-in-out}.cancel-chat-button:hover{background-color:var(--folder-hover-bg);border-color:#cbd5e1;color:var(--text-color);transform:none}.cancel-chat-button svg{width:14px;height:14px}.dot-flashing{position:relative;width:10px;height:10px;border-radius:5px;background-color:var(--primary-color);color:var(--primary-color);animation:dot-flashing 1s infinite linear alternate;animation-delay:.5s}.dot-flashing:before,.dot-flashing:after{content:"";display:inline-block;position:absolute;top:0}.dot-flashing:before{left:-15px;width:10px;height:10px;border-radius:5px;background-color:var(--primary-color);color:var(--primary-color);animation:dot-flashing 1s infinite alternate;animation-delay:0s}.dot-flashing:after{left:15px;width:10px;height:10px;border-radius:5px;background-color:var(--primary-color);color:var(--primary-color);animation:dot-flashing 1s infinite alternate;animation-delay:1s}@keyframes dot-flashing{0%{background-color:var(--primary-color)}50%,to{background-color:#dbeafe}}.import-modal-content{max-width:500px}.import-modal-content .modal-body{padding:1rem 1.5rem 1.5rem}.import-mode-selector{display:flex;width:100%;background-color:var(--folder-hover-bg);border-radius:8px;padding:4px;margin-bottom:1.5rem}.import-mode-selector button{flex:1;padding:.6rem;border:none;background-color:transparent;color:var(--secondary-text-color);font-size:.9rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease-in-out;transform:none;align-self:initial}.import-mode-selector button:hover:not(.active){background-color:#fffc;transform:none}.import-mode-selector button.active{background-color:#fff;color:var(--primary-hover-color);font-weight:700;box-shadow:0 1px 3px #0000001a;transform:none}.file-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1.5rem;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;transition:border-color .2s,background-color .2s}.file-drop-zone.dragging,.file-drop-zone:hover{border-color:var(--primary-color);background-color:#eff6ff}.file-drop-zone svg{color:var(--primary-color);margin-bottom:.75rem;opacity:.8}.file-drop-zone p{font-weight:500;color:var(--text-color);margin:0}.file-drop-zone p code{background-color:var(--border-color);padding:2px 5px;border-radius:4px;font-size:.9em}.drop-zone-divider{color:var(--secondary-text-color);font-size:.9rem;margin:.75rem 0}.file-drop-zone .secondary-button{pointer-events:none}.text-paste-area{display:flex;flex-direction:column;gap:1rem}.json-paste-input{width:100%;min-height:180px;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-family:monospace;font-size:.9rem;resize:vertical}.json-paste-input:focus{outline:none;border-color:var(--primary-color);box-shadow:none}.paste-submit-button{align-self:flex-start}.import-error-message{background-color:#fee2e2;color:var(--error-hover-color);padding:.75rem 1rem;border-radius:8px;margin-top:1.5rem;text-align:center;font-size:.9rem;border:1px solid var(--error-color)}.floating-queue-container{position:fixed;bottom:2rem;left:2rem;z-index:950;display:flex;flex-direction:column;align-items:flex-start}.floating-queue-toggle{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px #0000001f;border:none;transition:all .3s cubic-bezier(.4,0,.2,1);transform:none}.floating-queue-toggle:hover{transform:translateY(-3px) scale(1.08);box-shadow:0 6px 20px #0000002e}.floating-queue-toggle.processing{background:linear-gradient(135deg,var(--primary-color) 0%,#2563eb 100%);color:#fff}.floating-queue-toggle.completed{background:linear-gradient(135deg,var(--success-color) 0%,#059669 100%);color:#fff}.floating-queue-toggle.error{background:linear-gradient(135deg,var(--error-color) 0%,#dc2626 100%);color:#fff}.floating-queue-panel{background-color:var(--card-background);border-radius:16px;box-shadow:0 12px 32px #0000001f,0 2px 8px #00000014;width:300px;margin-bottom:.75rem;max-height:0;overflow:hidden;opacity:0;transform:translateY(20px) scale(.95);transition:all .35s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.floating-queue-container.expanded .floating-queue-panel{max-height:350px;opacity:1;transform:translateY(0) scale(1)}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:.65rem .85rem;border-bottom:1px solid var(--border-color);background:linear-gradient(to bottom,rgba(255,255,255,.03),transparent)}.panel-header h4{font-size:.9rem;font-weight:600;margin:0;letter-spacing:-.01em}.close-panel-button{background:none;border:none;cursor:pointer;color:var(--secondary-text-color);padding:.3rem;border-radius:6px;display:flex;transition:all .2s ease}.close-panel-button:hover{background-color:var(--folder-hover-bg);color:var(--text-color)}.floating-queue-panel .job-list{padding:.5rem;max-height:280px;overflow-y:auto}.job-item{display:flex;align-items:center;gap:.65rem;padding:.6rem .7rem;border-radius:10px;margin-bottom:.4rem;transition:all .2s ease;background-color:transparent;animation:slideInJob .3s cubic-bezier(.4,0,.2,1) both}@keyframes slideInJob{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.job-item:last-child{margin-bottom:0}.job-item.clickable{cursor:pointer;position:relative;overflow:hidden}.job-item.clickable:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#10b98133;transform:translate(-50%,-50%);transition:width .6s,height .6s}.job-item.clickable:active:before{width:200px;height:200px}.job-item.clickable:hover{background-color:var(--folder-hover-bg);transform:translate(-2px)}.job-item.completed.clickable:hover{background-color:#10b98114}.job-item.processing{background-color:#3b82f60d}.job-item.error{background-color:#ef44440d}.job-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1}.job-item.completed .job-icon{background-color:#10b98126;color:var(--success-color)}.job-item.processing .job-icon{background-color:#3b82f626;color:var(--primary-color)}.job-item.error .job-icon{background-color:#ef444426;color:var(--error-color)}.job-details{flex:1;min-width:0;position:relative;z-index:1}.job-filename{font-size:.85rem;font-weight:600;margin:0 0 .2rem;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-status-message{font-size:.75rem;color:var(--secondary-text-color);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-duration{font-size:.72rem;color:var(--secondary-text-color);font-weight:500;flex-shrink:0;background-color:#0000000d;padding:.2rem .4rem;border-radius:6px;position:relative;z-index:1}.job-arrow{flex-shrink:0;color:var(--secondary-text-color);opacity:0;transform:translate(-4px);transition:all .2s ease;position:relative;z-index:1}.job-item.clickable:hover .job-arrow{opacity:1;transform:translate(0);color:var(--success-color)}.json-context-menu{position:fixed;background:var(--card-background);border-radius:12px;box-shadow:0 8px 24px #00000026,0 2px 8px #00000014;padding:.5rem;z-index:1100;transform:translate(-50%,-100%) translateY(-10px);animation:contextMenuFadeIn .2s ease-out both;border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:200px}@keyframes contextMenuFadeIn{0%{opacity:0;transform:translate(-50%,-100%) translateY(-5px) scale(.95)}to{opacity:1;transform:translate(-50%,-100%) translateY(-10px) scale(1)}}.context-menu-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-color);font-size:.9rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease;width:100%;text-align:right}.context-menu-item:hover{background-color:var(--folder-hover-bg);color:var(--primary-color)}.context-menu-item svg{flex-shrink:0;color:var(--secondary-text-color);transition:color .2s ease}.context-menu-item:hover svg{color:var(--primary-color)}.context-menu-item span{flex:1}.sidebar-overlay,.modern-nav-bar{display:none}html{scroll-behavior:smooth}@media (max-width: 1024px){.modern-nav-bar{display:flex}}@media (min-width: 1025px){.sidebar-overlay{display:none!important;pointer-events:none!important}.modern-nav-bar{display:none!important}}.mobile-bottom-bar{display:none}.desktop-add-button{position:fixed;bottom:2rem;right:2rem;background-color:var(--primary-color);color:#fff;width:56px;height:56px;border-radius:50%;border:none;box-shadow:0 4px 12px #3b82f666;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .3s ease}.desktop-add-button:hover{background-color:var(--primary-hover-color);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f680}.desktop-add-button svg{width:36px;height:36px;flex-shrink:0}.desktop-only{display:flex}.sidebar-header-actions{display:flex;gap:.5rem}.import-json-button{background:none;border:none;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);width:36px;height:36px}.import-json-button:hover{background-color:var(--surface-secondary, #f8f9fa);color:var(--text-color)}@media (max-width: 1024px){body{padding:0;background:var(--gradient-bg)}#root{max-width:100%}.page-container{flex-direction:column;padding:0;gap:0;background:transparent}.modern-nav-bar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#fffffffa,#f8fafcfa);-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);border:1px solid rgba(226,232,240,.8);border-radius:28px;padding:10px 12px;display:flex;align-items:center;gap:6px;box-shadow:0 10px 40px #0000001f,0 2px 10px #667eea14;z-index:800;animation:slideUpFade .6s cubic-bezier(.16,1,.3,1) both}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.nav-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:22px;background:transparent;color:#64748b;cursor:pointer;transition:all .4s cubic-bezier(.16,1,.3,1);font-size:inherit;position:relative;overflow:visible}.nav-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#64748b1a;opacity:0;transform:scale(.8);transition:all .4s cubic-bezier(.16,1,.3,1)}.nav-btn:hover:before{opacity:1;transform:scale(1)}.nav-btn:hover{color:#334155;transform:translateY(-2px)}.nav-btn:active{transform:translateY(0)}.nav-btn.active{background:linear-gradient(135deg,#e2e8f0e6,#cbd5e1e6);color:var(--primary);box-shadow:0 2px 8px #64748b33}.nav-btn.active:before{display:none}.nav-btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8)!important;color:#fff!important;box-shadow:0 4px 12px #3b82f666}.nav-btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1e40af)!important;transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680}.nav-btn-primary:active{transform:translateY(0)}.nav-btn svg{width:22px;height:22px;flex-shrink:0;opacity:1;visibility:visible;transition:transform .4s cubic-bezier(.16,1,.3,1)}.nav-btn:hover svg{transform:scale(1.1)}.nav-btn.active svg{transform:scale(1.05)}@media (prefers-color-scheme: dark){.modern-nav-bar{background:#0f172afa;border:1px solid rgba(255,255,255,.1);box-shadow:0 -4px 20px #0000004d}.nav-btn{color:#94a3b8}.nav-btn:before{background:#94a3b826}.nav-btn:hover{color:#e2e8f0}.nav-btn.active{background:linear-gradient(135deg,#334155e6,#1e293be6);color:#60a5fa;box-shadow:0 2px 12px #60a5fa33}}.main-wrapper{margin:var(--space-sm);padding-bottom:120px;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border)}.sidebar{position:fixed;top:0;right:0;width:340px;max-width:85vw;height:100vh;z-index:var(--z-sidebar);background:linear-gradient(135deg,#fffffffa,#f8fafcfa);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-left:none;box-shadow:-10px 0 40px #00000014,-2px 0 10px #667eea0d;transform:translate(100%);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s ease,opacity .3s ease;padding:0;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;will-change:transform;opacity:.95}.sidebar:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--primary),var(--primary-dark));opacity:0;transition:opacity .5s ease}.sidebar:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(59,130,246,.03) 0%,transparent 70%);opacity:0;transition:opacity .6s ease;pointer-events:none}.sidebar.open{transform:translate(0);box-shadow:-20px 0 60px #0000001f,-5px 0 20px #667eea1a;opacity:1}.sidebar.open:before{opacity:1}.sidebar.open:after{opacity:1}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-xl) var(--space-lg) var(--space-lg);border-bottom:1px solid rgba(226,232,240,.6);background:linear-gradient(145deg,rgba(248,250,252,.8),transparent);flex-shrink:0;position:relative}.sidebar-header h2{font-size:var(--font-size-xl);font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex-grow:1;margin:0}.sidebar-header .sidebar-header-actions{display:flex;align-items:center;gap:var(--space-xs);order:1}.close-sidebar-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:#f871711a;color:#dc2626;border-radius:50%;cursor:pointer;transition:all .4s cubic-bezier(.16,1,.3,1);font-size:16px;order:2;position:relative;overflow:hidden}.close-sidebar-button:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#dc26261a;border-radius:inherit;opacity:0;transform:scale(.8);transition:all .4s cubic-bezier(.16,1,.3,1)}.close-sidebar-button:hover:before{opacity:1;transform:scale(1)}.close-sidebar-button:hover{background:#f8717133;color:#b91c1c;transform:rotate(90deg)}.close-sidebar-button:active{transform:rotate(90deg) scale(.9)}.sidebar-top-actions{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);border-bottom:1px solid var(--border-light);background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sidebar-export-button{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.close-sidebar-button svg{width:18px;height:18px;opacity:1!important;visibility:visible!important;color:inherit;stroke:currentColor;stroke-width:2;flex-shrink:0}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0006,#667eea26);z-index:1090;opacity:0;transition:opacity .5s cubic-bezier(.16,1,.3,1),backdrop-filter .5s ease;pointer-events:none;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);display:block}.sidebar-overlay.active{opacity:1;pointer-events:auto;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}body.sidebar-open{overflow:hidden;position:fixed;width:100%}.sidebar .folder-tree{flex:1;padding:var(--space-md);overflow-y:auto}.main-wrapper{padding:1rem;width:100%}.search-container{padding-bottom:1rem;margin-bottom:.5rem}.advanced-search-panel{flex-direction:column;padding:1rem}.question-item-detail{padding:1rem}.search-results-header{flex-direction:column;align-items:flex-start;gap:1rem}.desktop-only{display:none}.results-footer{position:sticky;bottom:0;margin-top:var(--space-sm);padding:var(--space-sm) var(--space-md);background:linear-gradient(180deg,#fffffffa,#fff)}.search-results-container{padding-bottom:60px}.pagination-summary,.pagination-text{display:none}.pagination-controls{width:100%;min-width:auto;max-width:100%;padding:var(--space-sm) var(--space-md);gap:var(--space-sm)}.pagination-btn{width:40px;height:40px;flex-shrink:0}.pagination-btn svg{width:20px;height:20px}.pagination-info{flex:1;justify-content:center;padding:var(--space-sm) var(--space-md);gap:.25rem}.pagination-label{font-size:var(--text-sm)}.pagination-divider,.pagination-total-count{font-size:var(--text-xs)}.pagination-pages,.desktop-add-button{display:none}.floating-queue-container{bottom:100px;left:1rem}.floating-queue-panel{width:calc(100vw - 2.5rem);max-width:320px}.floating-queue-toggle{width:48px;height:48px}.floating-queue-container.expanded .floating-queue-panel{max-height:300px}.floating-queue-panel .job-list{max-height:230px}.modal-content{width:calc(100% - 2rem);margin:1rem;max-height:85vh}.modal-body{padding:1rem}.metadata-form{flex-direction:column;gap:1rem}.metadata-form .form-group.subject,.metadata-form .form-group.year,.metadata-form .form-group.group{flex-basis:100%}}.restore-confirmation-modal{max-width:480px}.restore-confirmation-modal .modal-body{padding-top:1.5rem;padding-bottom:2rem}.confirmation-warning{display:flex;flex-direction:column;align-items:center;text-align:center}.confirmation-warning svg{color:var(--highlight-color);margin-bottom:1rem}.confirmation-warning h4{font-size:1.25rem;font-weight:700;margin-bottom:.75rem;color:var(--text-color)}.confirmation-warning p{line-height:1.7;color:var(--secondary-text-color);max-width:400px}.confirmation-warning p strong{color:var(--error-hover-color);font-weight:700}.confirm-restore-button{background-color:var(--error-color)}.confirm-restore-button:hover:not(:disabled){background-color:var(--error-hover-color)}.settings-modal-content{max-width:500px;background-color:#fff!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;opacity:1!important}.settings-modal-content .modal-body{display:flex;flex-direction:column;gap:2rem}.settings-section{display:flex;flex-direction:column;gap:1.25rem}.settings-section h4{font-size:1rem;font-weight:700;padding-bottom:.75rem;border-bottom:1px solid var(--border-color);margin:0}.setting-item{display:flex;flex-direction:column;gap:.5rem}.setting-item>label{font-size:.9rem;font-weight:500;color:var(--text-color)}.setting-item.toggle-item .toggle-group-header label{font-size:.9rem;font-weight:500;color:var(--text-color)}.setting-select{width:100%;padding:.7rem;border-radius:8px;border:1px solid var(--border-color);background-color:#fff;font-family:var(--font-family);font-size:.95rem;cursor:pointer}.setting-select:focus{outline:none;border-color:var(--primary-color);box-shadow:none}.settings-section .segmented-control{width:100%}.api-keys-container{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.api-key-item{display:flex;gap:.5rem;align-items:center}.api-key-input{flex:1;padding:.7rem;border-radius:8px;border:1px solid var(--border-color);background-color:#fff;font-family:var(--font-family);font-size:.9rem;transition:border-color .2s}.api-key-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1)}.remove-key-btn{padding:.6rem;border:1px solid var(--error-color);background-color:#fff;color:var(--error-color);border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.remove-key-btn:hover{background-color:var(--error-color);color:#fff}.add-key-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1rem;border:2px dashed var(--border-color);background-color:#fff;color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500}.add-key-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background-color:var(--primary-light)}.highlights-modal-content{max-width:650px}.empty-highlights-message{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:var(--secondary-text-color)}.empty-highlights-message svg{margin-bottom:1rem;opacity:.5}.empty-highlights-message p{font-size:1.1rem;font-weight:500;color:var(--text-color);margin-bottom:.5rem}.highlights-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.highlight-item{padding:1rem;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease-in-out}.highlight-item:hover{border-color:var(--primary-color);background-color:#eff6ff;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.highlight-item-context{font-size:.85rem;font-weight:500;color:var(--secondary-text-color);margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.highlight-item-content{line-height:1.7;color:var(--text-color)}.highlight-item-content p,.highlight-item-content li{padding:0;cursor:default}.highlight-item-content .ai-paragraph-highlighted:before{display:none}.minimal-upload-modal{position:relative;background:#ffffffd9;backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,.4);border-radius:20px;width:min(520px,92vw);max-height:88vh;overflow:hidden;padding:1.25rem 1.25rem 1.75rem;display:flex;flex-direction:column;gap:1rem;animation:fadeIn .35s ease,scaleIn .35s ease}@keyframes scaleIn{0%{transform:translateY(6px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.minimal-close-btn{position:absolute;top:8px;left:8px;width:34px;height:34px;border:none;border-radius:10px;background:#fff9;display:flex;align-items:center;justify-content:center;color:#475569;cursor:pointer;transition:background .25s,color .25s,transform .25s}.minimal-close-btn:hover{background:#ffffffd9;color:#0f172a}.minimal-close-btn:active{transform:scale(.92)}.mini-mode-switch{display:inline-flex;background:#ffffff8c;border:1px solid rgba(255,255,255,.4);padding:4px;border-radius:14px;gap:4px}.mini-mode-switch button{all:unset;cursor:pointer;font-size:.75rem;padding:6px 14px;border-radius:10px;font-weight:500;color:#475569}.mini-mode-switch button.active{background:var(--primary-color);color:#fff;box-shadow:0 2px 4px #3b82f659}.mini-mode-switch button:not(.active):hover{background:#fffc}.mini-drop-zone{position:relative;border:1.5px dashed rgba(71,85,105,.35);border-radius:16px;padding:2.25rem 1.25rem;text-align:center;display:flex;flex-direction:column;gap:.65rem;cursor:pointer;background:linear-gradient(145deg,#ffffffb3,#ffffff73);transition:border-color .25s,background .35s}.mini-drop-zone.dragging{border-color:var(--primary-color);background:linear-gradient(145deg,#ffffffd9,#ffffff8c)}.mini-drop-zone .dz-icon{color:var(--primary-color);opacity:.85}.mini-drop-zone .dz-text{font-size:.85rem;color:#0f172a;font-weight:500}.mini-drop-zone .dz-hint{font-size:.65rem;color:#64748b}.mini-json-box{display:flex;flex-direction:column;gap:.5rem}.mini-json-box textarea{min-height:160px;resize:vertical;border:1px solid var(--border-color);border-radius:14px;padding:.75rem .9rem;font-family:monospace;font-size:.75rem;background:#ffffffbf}.mini-json-box textarea:focus{outline:2px solid var(--primary-color)}.mini-json-box .mini-validate{align-self:flex-start;font-size:.7rem;padding:.55rem 1rem}.file-summary-list{display:flex;flex-direction:column;gap:.35rem;max-height:180px;overflow:auto;padding:.25rem .2rem .4rem}.file-summary-row{display:flex;align-items:center;gap:.6rem;background:#ffffff8c;border:1px solid rgba(255,255,255,.35);padding:.55rem .7rem;border-radius:14px;position:relative}.file-summary-row .file-icon{width:30px;height:34px;border-radius:8px;background:linear-gradient(135deg,#64748b,#94a3b8);position:relative}.file-summary-row .file-icon.pdf{background:linear-gradient(135deg,#dc2626,#ef4444)}.file-summary-row .file-icon.img{background:linear-gradient(135deg,#0ea5e9,#06b6d4)}.file-summary-row .file-icon.json{background:linear-gradient(135deg,#16a34a,#22c55e)}.file-summary-row .file-meta-text{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.file-summary-row .fname{font-size:.72rem;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-summary-row .fsize{font-size:.6rem;color:#64748b}.remove-file-mini{all:unset;cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:#64748b;transition:background .25s,color .25s}.remove-file-mini:hover{background:#ffffffb3;color:#0f172a}.inline-spec-box{display:flex;gap:.5rem;flex-wrap:wrap;background:#ffffff8c;padding:.75rem;border-radius:16px;border:1px solid rgba(255,255,255,.4)}.inline-spec-box.has-errors{box-shadow:0 0 0 1px var(--error-color) inset}.combobox-wrapper{position:relative;flex:1 1 auto;min-width:90px}.spec-input{width:100%;font-size:.7rem;border:1px solid var(--border-color);border-radius:10px;background:#fffc;padding:.55rem .65rem}.spec-input.year{max-width:110px}.spec-input.invalid{border-color:var(--error-color);background:#ff00000d}.spec-input:focus{outline:2px solid var(--primary-color)}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid var(--border-light);border-radius:10px;box-shadow:0 8px 24px #0000001f;max-height:200px;overflow-y:auto;z-index:100;animation:slideDown .2s ease}.suggestion-item{padding:.6rem .75rem;cursor:pointer;font-size:.7rem;color:var(--text-primary);transition:background .15s ease;border-bottom:1px solid var(--border-light)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--bg-secondary);color:var(--primary-color)}.suggestion-item.selected{background:var(--primary-color);color:#fff}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.page-pill-btn{display:inline-flex;align-items:center;gap:.4rem;background:var(--primary-color);color:#fff;border:none;border-radius:30px;padding:.55rem .9rem;font-size:.65rem;cursor:pointer;box-shadow:0 4px 12px -2px #3b82f666;transition:background .25s,transform .25s}.page-pill-btn.invalid{background:#dc2626;box-shadow:0 4px 10px -2px #dc262673}.page-pill-btn:hover{background:var(--primary-hover-color)}.page-pill-btn:active{transform:scale(.94)}.page-range-edit{font-size:.7rem;border:1px solid var(--border-color);border-radius:12px;padding:.55rem .7rem;background:#ffffffd9}.page-range-edit:focus{outline:2px solid var(--primary-color)}.process-hint-row{display:flex;align-items:center;gap:.6rem;margin-top:.35rem}.process-fab{all:unset;cursor:pointer;width:54px;height:54px;display:flex;align-items:center;justify-content:center;border-radius:18px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover-color));color:#fff;box-shadow:0 10px 24px -6px #3b82f68c;transition:transform .3s,box-shadow .3s}.process-fab:disabled{cursor:not-allowed;opacity:.45;box-shadow:none}.process-fab:not(:disabled):hover{transform:translateY(-3px);box-shadow:0 16px 30px -10px #3b82f699}.add-more-mini{all:unset;cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:#ffffffa6;color:#475569;border:1px solid rgba(255,255,255,.5);transition:background .25s,color .25s,transform .25s}.add-more-mini:hover{background:#ffffffe6;color:#0f172a}.add-more-mini:active{transform:scale(.92)}.mini-error-inline{font-size:.6rem;color:var(--error-color);margin-top:.2rem;padding:0 .35rem}.import-error-message.minimal{font-size:.65rem;margin-top:.5rem}.json-paste-stage{display:flex;flex-direction:column;gap:1rem}.json-paste-stage h4{font-size:1rem;font-weight:600;margin:0;color:var(--text-color)}.json-paste-textarea{width:100%;min-height:300px;resize:vertical;border:1px solid var(--border-color);border-radius:14px;padding:.85rem;font-family:Courier New,Consolas,monospace;font-size:.8rem;background:#ffffffd9;direction:ltr;text-align:left;line-height:1.5}.json-paste-textarea:focus{outline:2px solid var(--primary-color);background:#fff}.json-paste-actions{display:flex;gap:.75rem;justify-content:flex-end}.file-upload-stage{display:flex;flex-direction:column;gap:1rem}.drag-drop-zone{border:2px dashed rgba(71,85,105,.35);border-radius:16px;padding:3rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;background:linear-gradient(145deg,#ffffffb3,#ffffff73);transition:border-color .25s,background .35s}.drag-drop-zone.dragging{border-color:var(--primary-color);background:linear-gradient(145deg,#ffffffd9,#ffffff8c)}.drag-drop-zone svg{color:var(--primary-color);opacity:.85}.drag-drop-zone p{font-size:.9rem;color:var(--text-color);font-weight:500;margin:0}.drag-drop-zone .supported-formats{font-size:.75rem;color:var(--secondary-text-color)}@media (max-width:520px){.minimal-upload-modal{padding:1rem 1rem 1.25rem;width:94vw}.file-summary-row{padding:.5rem .6rem}.process-fab{width:50px;height:50px}.add-more-mini{width:40px;height:40px}.inline-spec-box{gap:.4rem}.spec-input{font-size:.68rem}.combobox-wrapper{min-width:80px}.suggestions-dropdown{font-size:.65rem}.suggestion-item{padding:.5rem .6rem}}.upload-mini-popover{position:fixed;z-index:1200;transform:translate(-50%,-100%);background:transparent;border:none;box-shadow:none;padding:0;display:flex;flex-direction:column;align-items:center;gap:.5rem}.upload-mini-popover.icon-only{width:auto}.mini-popover-row{display:flex;flex-direction:row-reverse;align-items:flex-start;gap:.5rem}.mini-json-area.side{min-width:220px}@media (max-width:640px){.mini-popover-row{flex-direction:column}.mini-json-area.side{order:2;width:80vw}}.mini-actions-vertical{display:flex;flex-direction:column;gap:.35rem;align-items:center}.mini-icon-btn{all:unset;cursor:pointer;width:46px;height:46px;display:flex;align-items:center;justify-content:center;color:#0f172a;transition:color .25s,transform .3s cubic-bezier(.4,.8,.4,1);opacity:0;animation:iconPop .55s forwards}.mini-actions-vertical .mini-icon-btn:nth-child(1){animation-delay:40ms}.mini-actions-vertical .mini-icon-btn:nth-child(2){animation-delay:.12s}.mini-actions-vertical .mini-icon-btn:nth-child(3){animation-delay:.2s}.mini-icon-btn svg{pointer-events:none}.mini-icon-btn:hover{color:var(--primary-color);transform:scale(1.18)}.mini-icon-btn:active{transform:scale(.88)}@keyframes iconPop{0%{opacity:0;transform:translateY(10px) scale(.65) rotate(-8deg)}60%{opacity:1;transform:translateY(-2px) scale(1.08) rotate(1deg)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:640px){.mini-icon-btn{width:42px;height:42px}}.mini-json-area{display:flex;flex-direction:column;gap:.4rem;animation:fadeIn .2s ease}.mini-json-area textarea{width:100%;min-height:110px;resize:vertical;border:1px solid var(--border-color);border-radius:12px;background:#ffffffd9;padding:.55rem .65rem;font-family:monospace;font-size:.68rem;direction:ltr;text-align:left}.mini-json-area textarea:focus{outline:2px solid var(--primary-color)}.mini-json-actions{display:flex;justify-content:flex-end}.mini-confirm{all:unset;cursor:pointer;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover-color));color:#fff;font-size:.65rem;padding:.45rem .9rem;border-radius:10px;font-weight:600;box-shadow:0 6px 14px -4px #3b82f680;transition:transform .25s,box-shadow .25s}.mini-confirm:hover{box-shadow:0 10px 24px -6px #3b82f68c}.mini-confirm:active{transform:translateY(2px)}.mini-error{font-size:.6rem;color:var(--error-color)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--surface-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,var(--primary-light),var(--primary));border-radius:var(--radius-full);transition:var(--transition-smooth)}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,var(--primary),var(--primary-dark))}::selection{background:linear-gradient(135deg,var(--primary-light),var(--primary));color:#fff}.admin-panel-content{max-width:1000px;max-height:85vh;overflow-y:auto}.admin-panel-body{padding:1.5rem}.admin-section{margin-bottom:2rem}.admin-section h4{font-size:1.1rem;font-weight:600;color:var(--text-color);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.empty-state{text-align:center;padding:2rem;color:var(--text-muted);background:var(--background-secondary);border-radius:var(--radius-md)}.api-stats-table{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-color);background:#fff}.api-stats-table table{width:100%;border-collapse:collapse;font-size:.875rem}.api-stats-table thead{background:var(--background-secondary)}.api-stats-table th{padding:.75rem 1rem;text-align:right;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color);white-space:nowrap}.api-stats-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-light);color:var(--text-color)}.api-stats-table tbody tr:hover{background:var(--hover-overlay)}.api-stats-table tbody tr:last-child td{border-bottom:none}.key-cell code{background:var(--background-secondary);padding:.25rem .5rem;border-radius:var(--radius-xs);font-family:Courier New,monospace;font-size:.75rem;direction:ltr;display:inline-block}.source-badge{display:inline-block;padding:.25rem .6rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;white-space:nowrap}.source-env{background:var(--warning-light);color:var(--warning-color)}.source-user{background:var(--info-light);color:var(--info-color)}.status-badge{display:inline-block;padding:.25rem .6rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;white-space:nowrap}.status-active{background:var(--success-light);color:var(--success-color)}.status-blocked{background:var(--error-light);color:var(--error-color)}.number-cell{text-align:center;font-weight:600;font-family:Segoe UI,system-ui,sans-serif}.number-cell.success{color:var(--success-color)}.number-cell.failed{color:var(--error-color)}.limit-hint{color:var(--text-muted);font-size:.7rem;font-weight:400;margin-right:2px}.time-cell{direction:ltr;text-align:center;font-size:.8rem;color:var(--text-secondary);font-family:Courier New,monospace}.admin-info{margin-top:1.5rem;padding:1rem;background:var(--info-light);border-radius:var(--radius-md);border-right:4px solid var(--info-color)}.admin-info p{margin:0 0 .5rem;color:var(--text-color);font-weight:600}.admin-info ul{margin:.5rem 0 0;padding-right:1.5rem;color:var(--text-secondary)}.admin-info li{margin:.25rem 0}@media (max-width: 768px){.admin-panel-content{max-width:95vw;max-height:90vh}.api-stats-table{font-size:.75rem}.api-stats-table th,.api-stats-table td{padding:.5rem}}::-moz-selection{background:linear-gradient(135deg,var(--primary-light),var(--primary));color:#fff}@media (max-width:640px){.upload-mini-popover{width:clamp(200px,70vw,320px);transform:translate(-50%,-105%)}}.delete-modal-overlay{animation:fadeIn .2s ease}.delete-modal-content{max-width:480px;text-align:center;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.delete-modal-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#fee2e2,#fecaca);animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1) .1s backwards}.delete-modal-icon svg{color:var(--error-color)}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.delete-modal-content h3{font-size:1.5rem;font-weight:700;color:var(--text-color);margin-bottom:1rem}.delete-modal-message{font-size:1rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}.delete-modal-message strong{color:var(--text-color);font-weight:600}.delete-modal-warning{padding:.75rem 1rem;background:var(--warning-light);border-radius:var(--radius-md);color:var(--warning-color);font-size:.9rem;font-weight:500;margin-bottom:1.5rem;border:1px solid rgba(245,158,11,.2)}.delete-modal-actions{display:flex;gap:.75rem;justify-content:center}.delete-modal-cancel,.delete-modal-confirm{flex:1;padding:.875rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.5rem}.delete-modal-cancel{background:var(--background-secondary);color:var(--text-color)}.delete-modal-cancel:hover{background:var(--border-color);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.delete-modal-confirm{background:linear-gradient(135deg,var(--error-color) 0%,#dc2626 100%);color:#fff}.delete-modal-confirm:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.delete-modal-confirm:active,.delete-modal-cancel:active{transform:translateY(0)}@media (max-width: 640px){.delete-modal-content{max-width:90vw}.delete-modal-actions{flex-direction:column-reverse}.delete-modal-cancel,.delete-modal-confirm{width:100%}}.export-modal-overlay{animation:fadeIn .2s ease}.export-modal-content{max-width:720px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.export-modal-content .modal-header{flex-shrink:0}.export-modal-content .modal-header h3{display:flex;align-items:center;gap:.75rem}.export-modal-content .modal-header svg{color:var(--primary-color)}.export-mode-selector{display:flex;gap:.75rem;padding:1.25rem;background:var(--background-secondary);border-radius:var(--radius-md);margin-bottom:1.5rem}.export-mode-selector button{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.25rem;border:2px solid var(--border-color);border-radius:var(--radius-md);background:#fff;color:var(--text-secondary);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);position:relative}.export-mode-selector button:hover{border-color:var(--primary-color);background:var(--primary-light);transform:translateY(-1px)}.export-mode-selector button.active{border-color:var(--primary-color);background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;box-shadow:0 4px 12px #1e3a8a40}.export-mode-selector button svg{flex-shrink:0}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;border-radius:var(--radius-full);background:#ffffff40;color:#fff;font-size:.75rem;font-weight:700;margin-right:auto}.export-mode-selector button:not(.active) .count-badge{background:var(--background-secondary);color:var(--text-secondary)}.export-mode-selector button:not(.active) .count-badge.selected{background:var(--primary-light);color:var(--primary-color)}.export-modal-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.export-search-bar{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:2px solid var(--border-color);border-radius:var(--radius-md);background:#fff;transition:all var(--transition-base)}.export-search-bar:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #1e3a8a1a}.export-search-bar svg{color:var(--text-muted);flex-shrink:0}.export-search-bar input{flex:1;border:none;outline:none;font-size:.95rem;color:var(--text-color);background:transparent}.export-search-bar input::placeholder{color:var(--text-muted)}.export-search-bar .clear-search{padding:.25rem;border:none;background:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.export-search-bar .clear-search:hover{background:var(--background-secondary);color:var(--text-color)}.export-selection-actions{display:flex;gap:.5rem}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:#fff;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base)}.action-btn:hover{border-color:var(--primary-color);background:var(--primary-light);color:var(--primary-color);transform:translateY(-1px)}.action-btn svg{width:18px;height:18px}.export-exam-tree{display:flex;flex-direction:column;gap:1rem}.export-subject-group{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:#fff}.export-subject-header{padding:1rem 1.25rem;background:linear-gradient(135deg,var(--primary-light) 0%,rgba(241,245,249,.5) 100%);font-weight:700;font-size:1.05rem;color:var(--primary-color);border-bottom:1px solid var(--border-color)}.export-year-group{border-bottom:1px solid var(--border-light)}.export-year-group:last-child{border-bottom:none}.export-year-header{padding:.875rem 1.25rem;background:var(--background-secondary);font-weight:600;font-size:.95rem;color:var(--text-secondary);border-bottom:1px solid var(--border-light)}.export-group-item{border-bottom:1px solid var(--border-light)}.export-group-item:last-child{border-bottom:none}.export-checkbox-label{display:flex;align-items:center;gap:.875rem;padding:1rem 1.25rem;cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none}.export-checkbox-label:hover{background:var(--hover-overlay)}.export-checkbox-label input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}.checkbox-custom{width:22px;height:22px;border:2px solid var(--border-color);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;background:#fff;transition:all var(--transition-base);flex-shrink:0}.export-checkbox-label:hover .checkbox-custom{border-color:var(--primary-color)}.export-checkbox-label.checked .checkbox-custom{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.export-checkbox-label.indeterminate .checkbox-custom{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.export-group-name{font-weight:600;color:var(--text-color);font-size:.95rem}.export-exam-count{margin-right:auto;font-size:.85rem;color:var(--text-muted);font-weight:500}.export-all-summary{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 2rem;min-height:300px}.summary-icon{width:96px;height:96px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--primary-light) 0%,rgba(241,245,249,.5) 100%);margin-bottom:1.5rem;animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1) .1s backwards}.summary-icon svg{color:var(--primary-color)}.export-all-summary h4{font-size:1.5rem;font-weight:700;color:var(--text-color);margin-bottom:.5rem}.export-all-summary p{font-size:1rem;color:var(--text-secondary);margin-bottom:2rem}.summary-stats{display:flex;gap:3rem}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-value{font-size:2.5rem;font-weight:800;color:var(--primary-color);line-height:1}.stat-label{font-size:.95rem;color:var(--text-secondary);font-weight:500}.export-modal-footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:1.5rem;border-top:2px solid var(--border-light)}.export-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem}.export-info svg{flex-shrink:0;color:var(--info-color)}.export-info strong{color:var(--primary-color);font-weight:700}.export-actions{display:flex;gap:.75rem}.export-cancel-btn,.export-confirm-btn{padding:.875rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:.5rem}.export-cancel-btn{background:var(--background-secondary);color:var(--text-color)}.export-cancel-btn:hover{background:var(--border-color);transform:translateY(-1px)}.export-confirm-btn{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff}.export-confirm-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-color) 0%,var(--primary-color) 100%);transform:translateY(-1px);box-shadow:0 4px 12px #1e3a8a4d}.export-confirm-btn:disabled{opacity:.5;cursor:not-allowed}.export-confirm-btn svg{width:20px;height:20px}@media (max-width: 768px){.export-modal-content{max-width:95vw;max-height:90vh}.export-mode-selector{flex-direction:column;gap:.5rem}.export-modal-footer{flex-direction:column;align-items:stretch}.export-info{justify-content:center;text-align:center}.export-actions{flex-direction:column-reverse;width:100%}.export-cancel-btn,.export-confirm-btn{width:100%;justify-content:center}.summary-stats{gap:2rem}}.upload-history-overlay{animation:fadeIn .2s ease}.upload-history-content{max-width:900px;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.sidebar-history-button{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:linear-gradient(135deg,#10b9811a,#0596691a);color:var(--text-primary);border:none;border-radius:.5rem;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.sidebar-history-button:hover{background:linear-gradient(135deg,#10b98126,#05966926);transform:translateY(-1px);box-shadow:0 2px 8px #10b98133}.sidebar-history-button svg{width:18px;height:18px;stroke:#10b981}.history-stats-bar{display:flex;gap:.5rem;padding:.75rem 1rem;background:rgba(var(--primary-color-rgb),.05);border-radius:.5rem;margin-bottom:1rem;flex-wrap:wrap}.stat-chip{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;background:var(--bg-primary);border-radius:.4rem;font-size:.85rem;color:var(--text-secondary);box-shadow:0 1px 3px #0000000d}.stat-chip{display:none!important}.stat-chip svg{width:16px;height:16px;stroke:var(--primary-color)}.stat-chip.stat-success{background:linear-gradient(135deg,#10b98114,#05966914);border-color:#10b98133}.stat-chip.stat-success svg{stroke:#10b981}.stat-chip.stat-failed{background:linear-gradient(135deg,#ef444414,#dc262614);border-color:#ef444433}.stat-chip.stat-failed svg{stroke:#dc2626}.history-controls{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.history-search{flex:1;min-width:200px;display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;transition:all .2s ease}.history-search:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-color-rgb),.1)}.history-search svg{width:18px;height:18px;stroke:var(--text-tertiary);flex-shrink:0}.history-search input{flex:1;border:none;background:none;outline:none;font-size:.9rem;color:var(--text-primary)}.history-search input::placeholder{color:var(--text-tertiary)}.history-sort{display:flex;gap:.5rem}.sort-btn{display:flex;align-items:center;gap:.3rem;padding:.6rem .9rem;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.5rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.sort-btn:hover{background:var(--bg-secondary);border-color:var(--primary-color)}.sort-btn.active{background:linear-gradient(135deg,rgba(var(--primary-color-rgb),.1),rgba(var(--accent-color-rgb),.1));border-color:var(--primary-color);color:var(--primary-color);font-weight:600}.sort-btn svg{width:16px;height:16px}.history-list{display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;max-height:50vh;padding-right:.5rem}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.history-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:.75rem;transition:all .2s ease;animation:slideInRight .3s ease}.history-item:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #00000014;transform:translate(-2px)}.history-icon{width:48px;height:48px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.history-icon:before{content:"";position:absolute;width:24px;height:28px;background-size:contain;background-repeat:no-repeat;background-position:center}.history-icon.pdf{background:linear-gradient(135deg,#ef444426,#dc262626)}.history-icon.pdf:before{content:"PDF";font-size:.7rem;font-weight:700;color:#dc2626;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.history-icon.img{background:linear-gradient(135deg,#3b82f626,#2563eb26)}.history-icon.img:before{content:"IMG";font-size:.7rem;font-weight:700;color:#2563eb;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.history-icon.json{background:linear-gradient(135deg,#10b98126,#05966926)}.history-icon.json:before{content:"JSON";font-size:.65rem;font-weight:700;color:#10b981;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.history-icon.file{background:linear-gradient(135deg,#6b728026,#4b556326)}.history-icon.file:before{content:"FILE";font-size:.65rem;font-weight:700;color:#6b7280;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.history-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:.4rem}.history-name{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-meta{font-size:.8rem;color:var(--text-tertiary)}.meta-item{display:inline-flex;align-items:center;gap:.3rem}.history-stats{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.8rem}.history-stats .stat{display:inline-flex;align-items:center;gap:.3rem;color:var(--text-secondary);padding:.2rem .5rem;background:var(--bg-secondary);border-radius:.3rem}.history-stats .stat.time{color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1);font-weight:500}.history-delete-btn{width:36px;height:36px;border-radius:.5rem;border:none;background:#ef44441a;color:#dc2626;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.history-delete-btn:hover{background:#ef444433;transform:scale(1.05)}.history-delete-btn:active{transform:scale(.95)}.history-delete-btn svg{width:18px;height:18px}.history-item-failed{border-color:#ef44444d;background:#ef444408}.history-item-failed .history-icon{opacity:.6;filter:grayscale(.3)}.failed-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.15rem .5rem;margin-right:.5rem;font-size:.7rem;font-weight:600;color:#dc2626;background:#ef444426;border-radius:.3rem}.history-error{display:flex;align-items:flex-start;gap:.4rem;padding:.5rem;margin:.3rem 0;background:#ef444414;border-radius:.4rem;border-right:3px solid #dc2626}.history-error svg{flex-shrink:0;margin-top:.1rem;color:#dc2626}.history-error span{font-size:.8rem;line-height:1.4;color:#b91c1c;direction:rtl}.history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;color:var(--text-tertiary)}.history-empty svg{width:64px;height:64px;stroke:var(--border-medium);margin-bottom:1rem;opacity:.6}.history-empty h4{font-size:1.1rem;color:var(--text-secondary);margin-bottom:.5rem}.history-empty p{font-size:.9rem;line-height:1.5}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.upload-history-content{max-width:95vw;max-height:90vh}.history-controls{flex-direction:column}.history-search{width:100%}.history-sort{justify-content:center}.history-item{flex-direction:column;align-items:flex-start;gap:.75rem}.history-icon{width:40px;height:40px}.history-details{width:100%}.history-stats{gap:.5rem}.history-stats .stat{font-size:.75rem;padding:.2rem .4rem}.history-delete-btn{position:absolute;top:.75rem;left:.75rem}.stat-chip{font-size:.8rem;padding:.35rem .6rem}}.sync-status-bar{position:fixed;top:0;left:0;right:0;height:36px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;z-index:1000;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.sync-status-bar.offline{background:linear-gradient(135deg,#64748b,#94a3b8)}.sync-status-content{display:flex;align-items:center;gap:12px;font-size:13px;font-weight:500}.sync-indicator{width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse 2s infinite}.sync-indicator.offline{background:#ef4444;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.sync-text{display:flex;align-items:center;gap:8px}.sync-refresh-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:4px 8px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sync-refresh-btn:hover{background:#ffffff4d;transform:rotate(180deg)}.sync-refresh-btn:active{transform:rotate(180deg) scale(.95)}.sidebar-sync-compact{display:flex;align-items:center;gap:8px}.sidebar-sync-compact .sidebar-sync-inner{display:inline-flex;align-items:center;gap:8px}.sidebar-sync-compact .sync-indicator{width:10px;height:10px;border-radius:50%;background:var(--success-color);box-shadow:0 0 0 6px #10b98114}.sidebar-sync-compact .sync-indicator.offline{background:var(--error-color);box-shadow:0 0 0 6px #ef44440f}.sidebar-sync-compact .sync-time{font-size:.875rem;color:var(--text-secondary);white-space:nowrap}.sidebar-sync-compact .sync-refresh-btn{background:transparent;border:none;color:var(--text-secondary);padding:4px;display:inline-flex;align-items:center;justify-content:center}.sidebar-sync-compact .sync-refresh-btn svg{width:16px;height:16px}.sidebar-export-button.icon-only{padding:6px;width:40px;height:40px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:0}.sidebar-export-button.icon-only svg{width:18px;height:18px}.page-container{padding-top:36px}.sync-notification{position:fixed;bottom:80px;right:20px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #10b9814d;font-size:14px;font-weight:500;z-index:10000;animation:slideInRight .3s ease;display:flex;align-items:center;gap:8px}.sync-notification.fade-out{animation:fadeOut .5s ease forwards}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{to{opacity:0;transform:translate(400px)}}.sync-loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fafbfef2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10001;display:flex;align-items:center;justify-content:center;animation:fadeInOverlay .3s ease}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.sync-loading-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.sync-loading-animation{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.sync-spinner{width:80px;height:80px;border:4px solid rgba(30,58,138,.1);border-top:4px solid var(--primary-color);border-radius:50%;animation:syncSpin 1s cubic-bezier(.68,-.55,.265,1.55) infinite;position:relative;z-index:2}@keyframes syncSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-pulse{position:absolute;width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#1e3a8a26,#0369a11a);animation:syncPulse 2s ease-in-out infinite;z-index:1}@keyframes syncPulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.4);opacity:0}}.sync-loading-text{display:flex;flex-direction:column;gap:.5rem}.sync-loading-text h3{font-size:1.25rem;font-weight:600;color:var(--primary-color);margin:0;animation:syncTextFade 1.5s ease-in-out infinite}.sync-loading-text p{font-size:.95rem;color:var(--text-secondary);margin:0}@keyframes syncTextFade{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 640px){.sync-loading-animation{width:100px;height:100px}.sync-spinner,.sync-pulse{width:60px;height:60px}.sync-loading-text h3{font-size:1.1rem}.sync-loading-text p{font-size:.875rem}}
